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

Line 222: Line 222:
 
       </div>
 
       </div>
 
     </section>
 
     </section>
 +
<div class="content"><pre class="codeinput"><span class="comment">%Function to define the non-dimensionalised system of ODEs describing the</span>
 +
<span class="comment">%binding between Spermidine and PotD. u is a 3 dimensional vector</span>
 +
<span class="comment">%where;</span>
 +
<span class="comment">% u(1)= P (PotD 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">% 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">% initial concentration of Spermidine.</span>
 +
<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>
 +
f = [u(3)-kappa.*u(1)*u(2);
 +
    u(3)-kappa.*u(1)*u(2);
 +
    kappa.*u(1)*u(2)-u(3)];
 +
<span class="comment">% The function is then ended.</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">% @spermsen command.</span>
 +
</pre>
 +
 +
 +
 +
 +
 
<a class="anchor" id="Saliva_code"></a>
 
<a class="anchor" id="Saliva_code"></a>
 
     <section id="Saliva_code">
 
     <section id="Saliva_code">

Revision as of 15:33, 9 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 Lactoferrim 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)=alphaHemo (Free Hemoglobin) % u(3)=alphaHemo/Hapto complex (Haptoglobin + alphaHemo complex) % u(4)=Hemo/Hapto complex (Full hemo/hapto complex). % t is the time that the simulation is run over. % lambda represents the parameter in the system determined by binding rates nd initial concentration of haemoglobin. % 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 % @haptosen command.

MATLAB code from run_haptosen.m file

File to perform sensitivity analysis for Haptoglobin and Haemoglobin
% binding model. % a is the number of values chosen for each of the ranges of parameters. % Therefore 100 different values were chosen. a=100; %Lambda1 is the range of values for the parameter Lambda, chosen with the %expected value of (100/317)*0.3878494524 as the mean value. lambda1=linspace(0,((100/317)*0.3878494524)*2,a); %Gamma1 is the range of values for the parameter Gamma, chosen with the %expected value of (83/317) as the mean value. gamma1=linspace(0,(83/317)*2,a); %T is the final time of the simulation. T=30; % Store sets an empty matrix for the final concentrations of the complex % with the varied parameter values. Store = zeros(a,a); %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 %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'); %set removes the x and y axis set(gca,'YTick',[],'XTick',[]); % The following lines add a colour bar with defined labal 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;

Semen: PotD and Spermidine Binding MATLAB Code

%Function to define the non-dimensionalised system of ODEs describing the
%binding between Spermidine and PotD. 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. )
% t is the time that the simulation is run over.
% kappa is the binding parameter determoned 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
% @spermsen command.

Saliva: Lactoferrin and Lactoferrin Binding Protein Binding MATLAB Code

Nasal Mucus: Oderant Binding Protein Folding MATLAB Code.