Difference between revisions of "Team:Dundee/Modeling/Appendix1"

Line 230: Line 230:
 
     </section>
 
     </section>
 
<div class="content"><pre class="codeinput"><span class="comment"><h2>MATLAB code from spermsen.m file.</h2><b>% Function to define the non-dimensionalised system of ODEs describing the binding between Spermidine and PotD.</b></span>
 
<div class="content"><pre class="codeinput"><span class="comment"><h2>MATLAB code from spermsen.m file.</h2><b>% Function to define the non-dimensionalised system of ODEs describing the binding between Spermidine and PotD.</b></span>
<span class="comment">% u is a 3 dimensional vector</span>
+
<span class="comment">% Parameter u is a 3 dimensional vector where;</span>
<span class="comment">% where;</span>
+
 
<span class="comment">% u(1)= P (PotD Concentration),</span>
 
<span class="comment">% u(1)= P (PotD Concentration),</span>
<span class="comment">% u(2)= S (Spermidine Concentration)</span>
+
<span class="comment">% u(2)= S (Spermidine Concentration),</span>
<span class="comment">% u(3)= C (PotD and Spermidine Complex Concentration. )</span>
+
<span class="comment">% u(3)= C (PotD and Spermidine Complex Concentration).</span>
<span class="comment">% t is the time that the simulation is run over.</span>
+
<span class="comment">% Parameter t is the time that the simulation is run over.</span>
<span class="comment">% kappa is the binding parameter determoned by the binding rates and</span>
+
<span class="comment">% Parameter kappa is the binding parameter determined by the binding rates and initial concentration of Spermidine.</span>
<span class="comment">% initial concentration of Spermidine.</span>
+
 
<span class="keyword">function</span> f = spermsen(t,u,kappa)
 
<span class="keyword">function</span> f = spermsen(t,u,kappa)
 
<span class="comment">% Define the system of ODEs by setting the vector f = left hand side of the system.</span>
 
<span class="comment">% Define the system of ODEs by setting the vector f = left hand side of the system.</span>
Line 245: Line 243:
 
<span class="comment">% The function is then ended.</span>
 
<span class="comment">% The function is then ended.</span>
 
<span class="keyword">end</span>
 
<span class="keyword">end</span>
<span class="comment">% This function can then be called in the run_spermsen.m file by using</span>
+
<span class="comment">% This function can then be called in the run_spermsen.m file by using the @spermsen command.</span>
<span class="comment">% @spermsen command.</span>
+
 
<span class="comment">% END OF FILE</span>
 
<span class="comment">% END OF FILE</span>
  
Line 252: Line 249:
 
<span class="comment"><h2>MATLAB code for run_spermsen.m file.</h2><b>%% Section 1: File to perform sensitivity analysis for PotD and Spermidine binding model.</b></span>
 
<span class="comment"><h2>MATLAB code for run_spermsen.m file.</h2><b>%% Section 1: File to perform sensitivity analysis for PotD and Spermidine binding model.</b></span>
 
<span class="comment">% This section runs the analysis on both the binding parameter kappa and the ratio between PotD and Spermidine, u0.</span>
 
<span class="comment">% This section runs the analysis on both the binding parameter kappa and the ratio between PotD and Spermidine, u0.</span>
<span class="comment">% a is the number of datapoints in the range for both kappa and u0, chosen to be 50.</span>
+
<span class="comment">% Define a as the number of datapoints in the range for both kappa and u0, chosen to be 50.</span>
 
a=50;
 
a=50;
<span class="comment">% kappa1 is the range of values for kappa that the system will be solved over,</span>
+
<span class="comment">% Define kappa1 as the range of values for kappa that the system will be solved over, where the max is twice the expected value.</span>
<span class="comment">% where the max is twice the expected value.</span>
+
 
kappa1=linspace(0,(129.0875)*2,a);
 
kappa1=linspace(0,(129.0875)*2,a);
<span class="comment">% u0 is the range of values for u0 that the system will be solved over</span>
+
<span class="comment">% Define u0 as the range of values for u0 that the system will be solved over, where the max is four times the expected value.</span>
<span class="comment">% where the max is four times the expected value.</span>
+
 
u0=linspace(0,2,a);
 
u0=linspace(0,2,a);
<span class="comment">% T is the final time of the simulation in seconds.</span>
+
<span class="comment">% T is the final time of the simulation, in seconds.</span>
 
T=0.10;
 
T=0.10;
<span class="comment">% Store is set as an empty matrix that will be filled by the values for the</span>
+
<span class="comment">% Store is set as an empty matrix that will be filled by the values for the complex concentration for each of the values of kappa and u0.</span>
<span class="comment">% complex concentration for each of the values of kappa and u0.</span>
+
 
Store = zeros(a,a);
 
Store = zeros(a,a);
<span class="comment">% The for loop solves the function spermsen.m using ode23 for the range of values of</span>
+
<span class="comment">% The for loop solves the function spermsen.m using ode23 for the range of values of kappa and u0, and stores the complex concentration values in the Store matrix.<</span>
<span class="comment">% kappa and u0, and stores the complex concentration values in the Store matrix.</span>
+
 
<span class="keyword">for</span> i=1:a
 
<span class="keyword">for</span> i=1:a
 
     <span class="keyword">for</span> j=1:a
 
     <span class="keyword">for</span> j=1:a
Line 273: Line 266:
 
     <span class="keyword">end</span>
 
     <span class="keyword">end</span>
 
<span class="keyword">end</span>
 
<span class="keyword">end</span>
<span class="comment">% imagesc plots the complex concentration against u0 and kappa.</span>
+
<span class="comment">% Command imagesc plots the complex concentration against u0 and kappa.</span>
 
imagesc(Store)
 
imagesc(Store)
<span class="comment">% label function adds x labels to both the x and y axis.</span>
+
<span class="comment">% Command label adds x labels to both the x and y axis.</span>
 
xlabel(<span class="string">'Increasing R_{0}'</span>,<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);
 
xlabel(<span class="string">'Increasing R_{0}'</span>,<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);
 
ylabel(<span class="string">'Increasing \kappa'</span>,<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);
 
ylabel(<span class="string">'Increasing \kappa'</span>,<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);
<span class="comment">% the set function removes the values from the x and y axis.</span>
+
<span class="comment">% The set function removes the values from the x and y axis.</span>
 
set(gca,<span class="string">'YTick'</span>,[],<span class="string">'XTick'</span>,[]);
 
set(gca,<span class="string">'YTick'</span>,[],<span class="string">'XTick'</span>,[]);
<span class="comment">% the color bar function adds a user defined colourbar with the label,</span>
+
<span class="comment">% The color bar function adds a user defined colourbar with the label, 'Complex Concentration'.</span>
<span class="comment">% 'Complex Concentration'.</span>
+
 
c=colorbar(<span class="string">'Ticks'</span>,[0,0.99],<span class="string">'TickLabels'</span>,{<span class="string">'None'</span>,<span class="string">'High'</span>},<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);
 
c=colorbar(<span class="string">'Ticks'</span>,[0,0.99],<span class="string">'TickLabels'</span>,{<span class="string">'None'</span>,<span class="string">'High'</span>},<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);
 
c.Label.String = <span class="string">'Complex Concentration'</span>;
 
c.Label.String = <span class="string">'Complex Concentration'</span>;
Line 288: Line 280:
 
<span class="comment">%</span>
 
<span class="comment">%</span>
 
<span class="comment"><b>%% Section 2: This section is used to plot only u0 against complex concentration over time.</b></span>
 
<span class="comment"><b>%% Section 2: This section is used to plot only u0 against complex concentration over time.</b></span>
<span class="comment">% a is the number of datapoints in the range for u0, chosen to be 50.</span>
+
<span class="comment">% Define a as the number of datapoints in the range for u0, chosen to be 50.</span>
 
a=50;
 
a=50;
<span class="comment">% u0 is the range of values for u0 that the system will be solved over</span>
+
<span class="comment">% Define u0 as the range of values for u0 that the system will be solved over, where the max is four times the expected value.</span>
<span class="comment">% where the max is four times the expected value.</span>
+
 
u0=linspace(0,2,a);
 
u0=linspace(0,2,a);
<span class="comment">% store is set as an empty matrix that will be filled by the values for the</span>
+
<span class="comment">% Define store as an empty matrix that will be filled by the values for the time values, PotD concentration, Spermidine concentration and complex concentration for each value of u0.</span>
<span class="comment">% time values, PotD concentration, Spermidine concentration and</span>
+
<span class="comment">% complex concentration for each value of u0.</span>
+
 
store = zeros(a,4,a); <span class="comment">% 1st is time, 2:4 are u.</span>
 
store = zeros(a,4,a); <span class="comment">% 1st is time, 2:4 are u.</span>
<span class="comment">% The for loop solves spermsen.m for the range of values of u0 and stores</span>
+
<span class="comment">% The for loop solves spermsen.m for the range of values of u0 and stores the values in the store matrix.</span>
<span class="comment">% tha values in the store matrix.</span>
+
 
<span class="keyword">for</span> i=1:a
 
<span class="keyword">for</span> i=1:a
  
Line 306: Line 294:
  
 
<span class="keyword">end</span>
 
<span class="keyword">end</span>
<span class="comment">% figure calls up an empty figure so that figure 2 is not overwritten.</span>
+
<span class="comment">% Command figure calls up an empty figure so that figure 2 is not overwritten.</span>
 
figure
 
figure
<span class="comment">% u0 is then plotted against complex concentration, u(3).</span>
+
<span class="comment">% Then u0 can be plotted against complex concentration, u(3).</span>
 
  plot(u0,squeeze(store(end,4,:)),<span class="string">'LineWidth'</span>,2);
 
  plot(u0,squeeze(store(end,4,:)),<span class="string">'LineWidth'</span>,2);
  <span class="comment">% label function adds x labels to both the x and y axis.</span>
+
  <span class="comment">% Command label adds x labels to both the x and y axis.</span>
 
  xlabel(<span class="string">'Increasing R_{0}'</span>,<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);
 
  xlabel(<span class="string">'Increasing R_{0}'</span>,<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);
 
ylabel(<span class="string">'Concentration of Complex Formed'</span>,<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);
 
ylabel(<span class="string">'Concentration of Complex Formed'</span>,<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);
Line 317: Line 305:
 
<span class="comment">%</span>
 
<span class="comment">%</span>
 
<span class="comment"><b>%% Section 3: This section is used to plot only kappa against complex concentration over time.</b></span>
 
<span class="comment"><b>%% Section 3: This section is used to plot only kappa against complex concentration over time.</b></span>
<span class="comment">% a is the number of datapoints in the range for kappa, chosen to be 50.</span>
+
<span class="comment">% Define a as the number of datapoints in the range for kappa, chosen to be 50.</span>
 
a=50;
 
a=50;
<span class="comment">% kappa1 is the range of values for kappa that the system will be solved over,</span>
+
<span class="comment">% Define kappa1 as the range of values for kappa that the system will be solved over, where the max is twice the expected value.</span>
<span class="comment">% where the max is twice the expected value.</span>
+
 
kappa1=linspace(0,(129.0875)*2,a);
 
kappa1=linspace(0,(129.0875)*2,a);
<span class="comment">% store is set as an empty matrix that will be filled by the values for the</span>
+
<span class="comment">% Define store as an empty matrix that will be filled by the values for the time values, PotD concentration, Spermidine concentration and complex concentration for each value of kappa.</span>
<span class="comment">% time values, PotD concentration, Spermidine concentration and</span>
+
<span class="comment">% complex concentration for each value of kappa.</span>
+
 
store = zeros(a,4,a); <span class="comment">% 1st is time, 2:4 are u</span>
 
store = zeros(a,4,a); <span class="comment">% 1st is time, 2:4 are u</span>
<span class="comment">% The for loop solves spermsen.m for the range of values of kappa and stores</span>
+
<span class="comment">% The for loop solves spermsen.m for the range of values of kappa and stores the values in the store matrix.</span>
<span class="comment">% tha values in the store matrix.</span>
+
 
<span class="keyword">for</span> i=1:a
 
<span class="keyword">for</span> i=1:a
  
Line 335: Line 319:
  
 
<span class="keyword">end</span>
 
<span class="keyword">end</span>
<span class="comment">% figure calls up an empty figure so that figure 3 is not overwritten.</span>
+
<span class="comment">% Command figure calls up an empty figure so that figure 3 is not overwritten.</span>
 
figure
 
figure
<span class="comment">% kappa is then plotted against complex concentration, u(3).</span>
+
<span class="comment">% Then kappa can be plotted against complex concentration, u(3).</span>
 
  plot(kappa1,squeeze(store(end,4,:)),<span class="string">'LineWidth'</span>,2);
 
  plot(kappa1,squeeze(store(end,4,:)),<span class="string">'LineWidth'</span>,2);
  <span class="comment">% axis tight ensures the axis are not too large for the datapoints.</span>
+
  <span class="comment">% Command axis tight ensures the axis are not too large for the datapoints.</span>
 
  axis <span class="string">tight</span>
 
  axis <span class="string">tight</span>
   <span class="comment">% label function adds x labels to both the x and y axis.</span>
+
   <span class="comment">% Command label adds x labels to both the x and y axis.</span>
 
  xlabel(<span class="string">'Increasing \kappa'</span>,<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);
 
  xlabel(<span class="string">'Increasing \kappa'</span>,<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);
 
ylabel(<span class="string">'Concentration of Complex Formed'</span>,<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);
 
ylabel(<span class="string">'Concentration of Complex Formed'</span>,<span class="string">'FontSize'</span>,15,<span class="string">'FontWeight'</span>,<span class="string">'bold'</span>);

Revision as of 11:10, 10 August 2015

Appendix 1

BioSpray Code

Blood

MATLAB code for Haemoglobin and Haptoglobin binding.

Semen

MATLAB code for Spermidine and PotD binding.

Saliva

MATLAB code for Lactoferrin and Lactoferrin Binding Protein binding.

Nasal Mucus

MATLAB code for Oderant Binding Protein folding.

Blood: Haptoglobin and Haemoglobin Binding MATLAB Code

Before using MATLAB the original system of equations was non-dimensionalised to the system:

$$ \begin{eqnarray*} \frac{dHp}{d\tau}&=&[Hp\cdot \alpha_{H}]-\lambda Hp \alpha_{H},\\ \frac{d\alpha_{H}}{d\tau}&=&[Hp\cdot \alpha_{H}]-\lambda Hp \alpha_{H},\\ \frac{d[Hp \cdot \alpha_{H}]}{d\tau}&=&\lambda Hp \alpha_{H}-[Hp \cdot \alpha_{H}]-\gamma [Hp \cdot \alpha_{H}],\\ \frac{d[Hp \cdot \alpha_{H} \cdot \beta_{H}]}{d\tau}&=&\gamma [Hp \cdot \alpha_{H}]. \end{eqnarray*} $$

The initial conditions were also non-dimensionalised to become:

$$ \begin{eqnarray*} Hp(0)&=&4.17,\\ \alpha_{H}(0)&=&1,\\ [Hp \cdot \alpha_{H}](0)&=&0,\\ [Hp \cdot \alpha_{H} \cdot \beta_{H}](0)&=&0. \end{eqnarray*} $$

To perform senstivity analysis that is described in the Blood section of the BioSpray models, MATLAB was used. Two files were written one to set the function, haptosen.m, and one to solve the function and plot the results in Figure 1, run_haptosen.m. Both files are shown below, where the green is comments to aid in understanding of the scripts.

  

MATLAB code from haptosen.m file

% Function to define the non-dimensionalised system of ODEs describing the binding between Haptoglobin and Haemoglobin.
% u is a 4 dimensional vector where; % u(1)=Hp (Haptoglobin concentration), % u(2)=alphaHaemoglobin (Free Haemoglobin), % u(3)=alphaHaemoglobin/Haptoglobin complex (Haptoglobin + alphaHaemoglobin complex), % u(4)=Haemoglobin/Haptoglobin complex (Full haemoglobin/haptoglobin complex). % Parameter t is the time that the simulation is run over. % Parameter lambda represents the parameter in the system determined by binding rates and initial concentration of haemoglobin. % Parameter gamma represents the parameter in the system determined by binding rates. function f = haptosen(t,u,lambda,gamma); % Define the system of ODEs by setting the vector f = left hand side of the system. f = [u(3)-lambda.*u(1)*u(2); u(3)-lambda.*u(1)*u(2); -u(3)+lambda.*u(1)*u(2)-gamma.*u(3); gamma.*u(3)]; % The function is then ended. end % This function can then be called in the run_haptosen.m file by using the @haptosen command. % END OF FILE

MATLAB code from run_haptosen.m file

% File to perform sensitivity analysis for Haptoglobin and Haemoglobin binding model.
% Variable a is the number of values chosen for each of the ranges of parameters, 100 different values were chosen.. a=100; % Define lambda1 as the range of values for the parameter lambda, chosen with the max as twice the expected value. lambda1=linspace(0,((100/317)*0.3878494524)*2,a); % Define gamma1 as the range of values for the parameter gamma, chosen with the max as twice the expected value. gamma1=linspace(0,(83/317)*2,a); % T is the final time of the simulation. T=30; % Define Store as an empty matrix for the final concentrations of the complex with the varied parameter values. Store = zeros(a,a); % Command figure(1) calls up a new figure. figure(1) % The for loop solves the ode system defined in haptosen function using ode23 for the range of values for both parameters. for i=1:a for j=1:a [t,u]=ode23(@haptosen,[0 T],[4.17 1 0 0],[],lambda1(a+1-i),gamma1(j)); Store(i,j) = u(end,4); % Store(i,j) = (u(3,4)-u(2,4))/(t(3)-t(2)); end end % Command imagesc plots the surf plot of the parameters and the complex concentration. imagesc(Store) % xlabel and ylabel add labels to the plot. xlabel('Increasing \lambda','FontSize',15,'FontWeight','bold'); ylabel('Increasing \gamma','FontSize',15,'FontWeight','bold'); % Command set removes the x and y axis values. set(gca,'YTick',[],'XTick',[]); % The following lines add a colour bar with defined label and text. c=colorbar('Ticks',[0,0.99],'TickLabels',{'None','High'},'FontSize',15,'FontWeight','bold'); c.Label.String = 'Complex Concentration'; % The following lines add a text arrow to allow for annotation of the graph with defined colours positions and width. ta1 = annotation('textarrow', [0.13 0.79], [0.13 0.92]); h = text(0.5,0.5,'Complex Formation'); s = h.FontSize; h.FontSize = 12; j = h.Rotation; h.Rotation=45; k = h.Position; h.Position = [0.5 0.5 0]; b = ta1.Color; d=ta1.LineWidth; ta1.Color = 'red'; ta1.LineWidth= 4; % END OF FILE

Semen: PotD and Spermidine Binding MATLAB Code

Before using MATLAB the original system of equations was non-dimensionalised to the system:

$$ \begin{eqnarray*} \frac{dP}{d\tau}&=&C-\kappa P S,\\ \frac{dS}{d\tau}&=&C-\kappa P S,\\ \frac{dC}{d\tau}&=&\kappa P S -C. \end{eqnarray*} $$

The initial conditions were also non-dimensionalised to become:

$$ \begin{eqnarray*} P(0)&=&R_{0},\\ S(0)&=&1,\\ C(0)&=&0. \end{eqnarray*} $$

To perform senstivity analysis that is described in the Semen section of the BioSpray models, MATLAB was used. Two files were written one to set the function, spermsen.m, and one to solve the function and plot the results in Figure 2, Figure 3 and Figure 4, run_spermsen.m. Both files are shown below, where the green is comments to aid in understanding of the scripts.

MATLAB code from spermsen.m file.

% Function to define the non-dimensionalised system of ODEs describing the binding between Spermidine and PotD.
% Parameter u is a 3 dimensional vector where; % u(1)= P (PotD Concentration), % u(2)= S (Spermidine Concentration), % u(3)= C (PotD and Spermidine Complex Concentration). % Parameter t is the time that the simulation is run over. % Parameter kappa is the binding parameter determined by the binding rates and initial concentration of Spermidine. function f = spermsen(t,u,kappa) % Define the system of ODEs by setting the vector f = left hand side of the system. f = [u(3)-kappa.*u(1)*u(2); u(3)-kappa.*u(1)*u(2); kappa.*u(1)*u(2)-u(3)]; % The function is then ended. end % This function can then be called in the run_spermsen.m file by using the @spermsen command. % END OF FILE

MATLAB code for run_spermsen.m file.

%% Section 1: File to perform sensitivity analysis for PotD and Spermidine binding model.
% This section runs the analysis on both the binding parameter kappa and the ratio between PotD and Spermidine, u0. % Define a as the number of datapoints in the range for both kappa and u0, chosen to be 50. a=50; % Define kappa1 as the range of values for kappa that the system will be solved over, where the max is twice the expected value. kappa1=linspace(0,(129.0875)*2,a); % Define u0 as the range of values for u0 that the system will be solved over, where the max is four times the expected value. u0=linspace(0,2,a); % T is the final time of the simulation, in seconds. T=0.10; % Store is set as an empty matrix that will be filled by the values for the complex concentration for each of the values of kappa and u0. Store = zeros(a,a); % The for loop solves the function spermsen.m using ode23 for the range of values of kappa and u0, and stores the complex concentration values in the Store matrix.< for i=1:a for j=1:a [t,u]=ode23(@spermsen,[0 T],[u0(a-i+1) 1 0],[],kappa1(j)); Store(i,j) = u(end,3); end end % Command imagesc plots the complex concentration against u0 and kappa. imagesc(Store) % Command label adds x labels to both the x and y axis. xlabel('Increasing R_{0}','FontSize',15,'FontWeight','bold'); ylabel('Increasing \kappa','FontSize',15,'FontWeight','bold'); % The set function removes the values from the x and y axis. set(gca,'YTick',[],'XTick',[]); % The color bar function adds a user defined colourbar with the label, 'Complex Concentration'. c=colorbar('Ticks',[0,0.99],'TickLabels',{'None','High'},'FontSize',15,'FontWeight','bold'); c.Label.String = 'Complex Concentration'; % The resulting plot is Figure 2. % % %% Section 2: This section is used to plot only u0 against complex concentration over time. % Define a as the number of datapoints in the range for u0, chosen to be 50. a=50; % Define u0 as the range of values for u0 that the system will be solved over, where the max is four times the expected value. u0=linspace(0,2,a); % Define store as an empty matrix that will be filled by the values for the time values, PotD concentration, Spermidine concentration and complex concentration for each value of u0. store = zeros(a,4,a); % 1st is time, 2:4 are u. % The for loop solves spermsen.m for the range of values of u0 and stores the values in the store matrix. for i=1:a [t,u]=ode23(@spermsen,[0 0.1],[u0(i) 1 0],[],129.0875); store(end-size(t,1)+1:end,1,i) = t; store(end-size(t,1)+1:end,2:4,i) = u; end % Command figure calls up an empty figure so that figure 2 is not overwritten. figure % Then u0 can be plotted against complex concentration, u(3). plot(u0,squeeze(store(end,4,:)),'LineWidth',2); % Command label adds x labels to both the x and y axis. xlabel('Increasing R_{0}','FontSize',15,'FontWeight','bold'); ylabel('Concentration of Complex Formed','FontSize',15,'FontWeight','bold'); % This plot is Figure 3. % % %% Section 3: This section is used to plot only kappa against complex concentration over time. % Define a as the number of datapoints in the range for kappa, chosen to be 50. a=50; % Define kappa1 as the range of values for kappa that the system will be solved over, where the max is twice the expected value. kappa1=linspace(0,(129.0875)*2,a); % Define store as an empty matrix that will be filled by the values for the time values, PotD concentration, Spermidine concentration and complex concentration for each value of kappa. store = zeros(a,4,a); % 1st is time, 2:4 are u % The for loop solves spermsen.m for the range of values of kappa and stores the values in the store matrix. for i=1:a [t,u]=ode23(@spermsen,[0 0.1],[1.4 1 0],[],kappa1(i)); store(end-size(t,1)+1:end,1,i) = t; store(end-size(t,1)+1:end,2:4,i) = u; end % Command figure calls up an empty figure so that figure 3 is not overwritten. figure % Then kappa can be plotted against complex concentration, u(3). plot(kappa1,squeeze(store(end,4,:)),'LineWidth',2); % Command axis tight ensures the axis are not too large for the datapoints. axis tight % Command label adds x labels to both the x and y axis. xlabel('Increasing \kappa','FontSize',15,'FontWeight','bold'); ylabel('Concentration of Complex Formed','FontSize',15,'FontWeight','bold'); % This plot is Figure 4. % END OF FILE

Saliva: Lactoferrin and Lactoferrin Binding Protein Binding MATLAB Code

Nasal Mucus: Oderant Binding Protein Folding MATLAB Code.

Before using MATLAB the original system of equations was non-dimensionalised to the system:

$$ \begin{eqnarray*} \frac{d\alpha}{d\tau}&=&OBP-\psi \alpha \beta,\\ \frac{d\beta}{d\tau}&=&OBP-\psi \alpha \beta,\\ \frac{dOBP}{d\tau}&=&\psi \alpha \beta -OBP. \end{eqnarray*} $$

The initial conditions were also non-dimensionalised to become:

$$ \begin{eqnarray*} \alpha(0)&=&1,\\ \beta(0)&=&D_{0},\\ OBP(0)&=&0. \end{eqnarray*} $$

To perform senstivity analysis that is described in the Nasal Mucus section of the BioSpray models, MATLAB was used. Two files were written one to set the function, obp.m, and one to solve the function and plot the results in Figure 5, Figure 6 and Figure 7, run_obp.m. Both files are shown below, where the green is comments to aid in understanding of the scripts.

MATLAB code from obp.m file

% Function to define the non-dimensionalised system of ODEs describing the folding of the Oderant Binding Protein (OBP).
% u is a 3 dimensional vector % where; % u(1)= alpha (Alpha Helix Concentration), % u(2)= beta (Beta Barrel Concentration) % u(3)= OBP (Folded OBP Concentration. ) % t is the time that the simulation is run over. % K represents psi, the binding parameter determined by the binding rates and % initial concentration of alpha helices. function f = obp(t,u,K) % define the system of ODEs by setting the vector f = left hand side of the system. f = [u(3)-K*u(1)*u(2); u(3)-K*u(1)*u(2); -u(3)+K*u(1)*u(2)]; % The function is then ended. end % This function can then be called in the run_obp.m file by using % @obp command. % END OF FILE

MATLAB code for run_obp.m file.

% File to perform sensitivity analysis for OBP folding model.
%% Section 1: This section runs sensitivity analysis for both the parameter psi (K) and the ratio between beta barrels and alpha helices, D_{0} (v0). % a is the number of datapoints in the range for both K and v0, chosen to be 50. a=50; % K is the range of values for K that the system will be solved over, where % the max is twice the expected value. K=linspace(0,(5291.005292)*2,a); % u0 is the range of values for v0 that the system will be solved over, % where the max is twice the expected value. v0=linspace(0,4,a); % T is the final time of the simulation in seconds. T=0.001; % Store is set as an empty matrix that will be filled by the values for the % folded OBP concentration for each of the values of K and v0. Store = zeros(a,a); % Call up first empty figure to plot in. figure(1) % The for loop solves the function obp.m using ode23 for the range of values of % K and v0, and stores the complex concentration values in the Store matrix. for i=1:a for j=1:a [t,u]=ode23(@obp,[0 T],[1 v0(a-i+1) 0],[],K(j)); Store(i,j) = u(end,3); end end % imagesc plots the complex concentration against v0 and K. imagesc(Store) % label function adds x labels to both the x and y axis. xlabel('Increasing D_{0}','FontSize',15,'FontWeight','bold'); ylabel('Increasing \psi','FontSize',15,'FontWeight','bold'); % the set function removes the values from the x and y axis.. set(gca,'YTick',[],'XTick',[]); % the color bar function adds a user defined colourbar with the label, % 'Complex Concentration'. c=colorbar('Ticks',[0,0.99],'TickLabels',{'None','High'},'FontSize',15,'FontWeight','bold'); c.Label.String = 'Complex Concentration'; % The resulting plot is Figure 5. % % %% Section 2: This section is used to plot only v0 against complex concentration over time. a is the number of datapoints in the range for v0, chosen to be 50. a=50; % v0 is the range of values for v0 that the system will be solved over % where the max is four times the expected value. v0=linspace(0,4,a); % store is set as an empty matrix that will be filled by the values for the % time values, alpha helix concentration, beta-barrel concentration and % folded OBP concentration for each value of v0. store = zeros(a,4,a); %1st is time, 2:4 are u. % The for loop solves obp.m for the range of values of v0 and stores % the values in the store matrix. for i=1:a [t,u]=ode23(@spermsen,[0 0.001],[1 v0(i) 0],[],5291.005292); store(end-size(t,1)+1:end,1,i) = t; store(end-size(t,1)+1:end,2:4,i) = u; end % figure calls up an empty figure so that Figure 5 is not overwritten. figure(2) % v0 is then plotted against complex concentration, u(3). plot(v0,squeeze(store(end,4,:)),'LineWidth',2); % label function adds x labels to both the x and y axis. xlabel('Ratio of \beta to \alpha, D_{0}','FontSize',15,'FontWeight','bold'); ylabel('Concentration of Complex Formed','FontSize',15,'FontWeight','bold'); % annotation command allows us to add lines with specified style, width and colour % for annotation of the graph, % these can then be manually manipulated by using the edit plot tool. t2 = annotation('line', [0.42 0.42], [0.15 0.91]); b = t2.Color; d=t2.LineWidth; g=t2.LineStyle; t2.Color = 'red'; t2.LineWidth= 2; t2.LineStyle= ':'; % This plot is Figure 3. % % %% Section 3: This section is used to plot only K against folded OBP over time. % a is the number of datapoints in the range for K, chosen to be 50. a=50; % K is the range of values for K that the system will be solved over, % where the max is twice the expected value. K=linspace(0,(5291.005292)*2,a); % store is set as an empty matrix that will be filled by the values for the % time values, alpha helix concentration, beta-barrel concentration and % folded OBP concentration for each value of K. store = zeros(a,4,a); %1st is time, 2:4 are u for i=1:a [t,u]=ode23(@spermsen,[0 0.001],[1.5 1 0],[],K(i)); store(end-size(t,1)+1:end,1,i) = t; store(end-size(t,1)+1:end,2:4,i) = u; end % The for loop solves obp.m for the range of values of K and stores % the values in the store matrix. % figure calls up an empty figure so that Figure 6 is not overwritten. figure(3) % K is then plotted against complex concentration, u(3). plot(K,squeeze(store(end,4,:)),'LineWidth',2); % axis tight ensures the axis are not too large for the datapoints. axis tight % label function adds x labels to both the x and y axis. xlabel('Increasing K','FontSize',15,'FontWeight','bold'); ylabel('Concentration of Complex Formed','FontSize',15,'FontWeight','bold'); % This plot is Figure 7. % END OF FILE
-->