Generated Code

The following is matlab code generated by the CellML API from this CellML file. (Back to language selection)

The raw code is available.

function [VOI, STATES, ALGEBRAIC, CONSTANTS] = mainFunction()
    % This is the "main function".  In Matlab, things work best if you rename this function to match the filename.
   [VOI, STATES, ALGEBRAIC, CONSTANTS] = solveModel();
end

function [algebraicVariableCount] = getAlgebraicVariableCount() 
    % Used later when setting a global variable with the number of algebraic variables.
    % Note: This is not the "main method".  
    algebraicVariableCount =21;
end
% There are a total of 21 entries in each of the rate and state variable arrays.
% There are a total of 116 entries in the constant variable array.
%

function [VOI, STATES, ALGEBRAIC, CONSTANTS] = solveModel()
    % Create ALGEBRAIC of correct size
    global algebraicVariableCount;  algebraicVariableCount = getAlgebraicVariableCount();
    % Initialise constants and state variables
    [INIT_STATES, CONSTANTS] = initConsts;

    % Set timespan to solve over 
    tspan = [0, 10];

    % Set numerical accuracy options for ODE solver
    options = odeset('RelTol', 1e-06, 'AbsTol', 1e-06, 'MaxStep', 1);

    % Solve model with ODE solver
    [VOI, STATES] = ode15s(@(VOI, STATES)computeRates(VOI, STATES, CONSTANTS), tspan, INIT_STATES, options);

    % Compute algebraic variables
    [RATES, ALGEBRAIC] = computeRates(VOI, STATES, CONSTANTS);
    ALGEBRAIC = computeAlgebraic(ALGEBRAIC, CONSTANTS, STATES, VOI);

    % Plot state variables against variable of integration
    [LEGEND_STATES, LEGEND_ALGEBRAIC, LEGEND_VOI, LEGEND_CONSTANTS] = createLegends();
    figure();
    plot(VOI, STATES);
    xlabel(LEGEND_VOI);
    l = legend(LEGEND_STATES);
    set(l,'Interpreter','none');
end

function [LEGEND_STATES, LEGEND_ALGEBRAIC, LEGEND_VOI, LEGEND_CONSTANTS] = createLegends()
    LEGEND_STATES = ''; LEGEND_ALGEBRAIC = ''; LEGEND_VOI = ''; LEGEND_CONSTANTS = '';
    LEGEND_VOI = strpad('time in component environment (minute)');
    LEGEND_STATES(:,1) = strpad('GLY in component GLY (millimolar)');
    LEGEND_ALGEBRAIC(:,4) = strpad('flux_GP in component flux_GP (flux)');
    LEGEND_STATES(:,2) = strpad('G1P in component G1P (millimolar)');
    LEGEND_ALGEBRAIC(:,5) = strpad('V_PGLM in component V_PGLM (flux)');
    LEGEND_STATES(:,3) = strpad('G6P in component G6P (millimolar)');
    LEGEND_ALGEBRAIC(:,6) = strpad('V_PGI in component V_PGI (flux)');
    LEGEND_STATES(:,4) = strpad('F6P in component F6P (millimolar)');
    LEGEND_ALGEBRAIC(:,10) = strpad('V_PFK in component V_PFK (flux)');
    LEGEND_STATES(:,5) = strpad('FBP in component FBP (millimolar)');
    LEGEND_ALGEBRAIC(:,11) = strpad('V_ALD in component V_ALD (flux)');
    LEGEND_STATES(:,6) = strpad('DHAP in component DHAP (millimolar)');
    LEGEND_ALGEBRAIC(:,12) = strpad('V_TPI in component V_TPI (flux)');
    LEGEND_STATES(:,7) = strpad('GAP in component GAP (millimolar)');
    LEGEND_ALGEBRAIC(:,14) = strpad('V_GAPDH in component V_GAPDH (flux)');
    LEGEND_STATES(:,8) = strpad('Thirteen_BPG in component Thirteen_BPG (millimolar)');
    LEGEND_ALGEBRAIC(:,15) = strpad('V_PGK in component V_PGK (flux)');
    LEGEND_STATES(:,9) = strpad('three_PG in component three_PG (millimolar)');
    LEGEND_ALGEBRAIC(:,16) = strpad('V_PGM in component V_PGM (flux)');
    LEGEND_STATES(:,10) = strpad('two_PG in component two_PG (millimolar)');
    LEGEND_ALGEBRAIC(:,17) = strpad('V_ENOL in component V_ENOL (flux)');
    LEGEND_STATES(:,11) = strpad('PEP in component PEP (millimolar)');
    LEGEND_ALGEBRAIC(:,18) = strpad('V_PK in component V_PK (flux)');
    LEGEND_STATES(:,12) = strpad('PYR in component PYR (millimolar)');
    LEGEND_ALGEBRAIC(:,19) = strpad('V_LDH in component V_LDH (flux)');
    LEGEND_STATES(:,13) = strpad('LAC in component LAC (millimolar)');
    LEGEND_ALGEBRAIC(:,1) = strpad('output in component LAC (flux)');
    LEGEND_STATES(:,14) = strpad('Pi in component Pi (millimolar)');
    LEGEND_CONSTANTS(:,1) = strpad('V_ATPase in component V_ATPase (flux)');
    LEGEND_STATES(:,15) = strpad('ADP in component ADP (millimolar)');
    LEGEND_ALGEBRAIC(:,21) = strpad('V_ADK in component V_ADK (flux)');
    LEGEND_ALGEBRAIC(:,20) = strpad('V_CK in component V_CK (flux)');
    LEGEND_STATES(:,16) = strpad('ATP in component ATP (millimolar)');
    LEGEND_STATES(:,17) = strpad('AMP in component AMP (millimolar)');
    LEGEND_STATES(:,18) = strpad('PCr in component PCr (millimolar)');
    LEGEND_STATES(:,19) = strpad('Cr in component Cr (millimolar)');
    LEGEND_STATES(:,20) = strpad('NADH in component NADH (millimolar)');
    LEGEND_STATES(:,21) = strpad('NAD in component NAD (millimolar)');
    LEGEND_CONSTANTS(:,2) = strpad('frac_a in component flux_GP (dimensionless)');
    LEGEND_CONSTANTS(:,3) = strpad('frac_b in component flux_GP (dimensionless)');
    LEGEND_ALGEBRAIC(:,2) = strpad('V_GPa in component V_GPa (flux)');
    LEGEND_ALGEBRAIC(:,3) = strpad('V_GPb in component V_GPb (flux)');
    LEGEND_CONSTANTS(:,4) = strpad('Ki_GLY_f in component V_GPa (millimolar)');
    LEGEND_CONSTANTS(:,5) = strpad('Ki_GLY_b in component V_GPa (millimolar)');
    LEGEND_CONSTANTS(:,6) = strpad('K_GLY_f in component V_GPa (millimolar)');
    LEGEND_CONSTANTS(:,7) = strpad('K_GLY_b in component V_GPa (millimolar)');
    LEGEND_CONSTANTS(:,8) = strpad('Keq_GP in component V_GPa (dimensionless)');
    LEGEND_CONSTANTS(:,9) = strpad('Ki_Pi in component V_GPa (millimolar)');
    LEGEND_CONSTANTS(:,10) = strpad('K_Pi in component V_GPa (millimolar)');
    LEGEND_CONSTANTS(:,11) = strpad('Ki_G1P in component V_GPa (millimolar)');
    LEGEND_CONSTANTS(:,101) = strpad('V_max_r in component V_GPa (flux)');
    LEGEND_CONSTANTS(:,12) = strpad('V_max_f in component V_GPa (flux)');
    LEGEND_CONSTANTS(:,13) = strpad('Ki_GLY_f in component V_GPb (millimolar)');
    LEGEND_CONSTANTS(:,14) = strpad('Ki_GLY_b in component V_GPb (millimolar)');
    LEGEND_CONSTANTS(:,15) = strpad('K_GLY_f in component V_GPb (millimolar)');
    LEGEND_CONSTANTS(:,16) = strpad('Keq_GP in component V_GPb (dimensionless)');
    LEGEND_CONSTANTS(:,17) = strpad('nH in component V_GPb (dimensionless)');
    LEGEND_CONSTANTS(:,18) = strpad('K_AMP in component V_GPb (millimolar_1_75)');
    LEGEND_CONSTANTS(:,19) = strpad('K_GLY_b in component V_GPb (millimolar)');
    LEGEND_CONSTANTS(:,20) = strpad('Ki_Pi in component V_GPb (millimolar)');
    LEGEND_CONSTANTS(:,21) = strpad('K_Pi in component V_GPb (millimolar)');
    LEGEND_CONSTANTS(:,22) = strpad('Ki_G1P in component V_GPb (millimolar)');
    LEGEND_CONSTANTS(:,23) = strpad('K_G1P in component V_GPb (millimolar)');
    LEGEND_CONSTANTS(:,102) = strpad('V_max_r in component V_GPb (flux)');
    LEGEND_CONSTANTS(:,24) = strpad('V_max_f in component V_GPb (flux)');
    LEGEND_CONSTANTS(:,25) = strpad('K_G1P in component V_PGLM (millimolar)');
    LEGEND_CONSTANTS(:,26) = strpad('K_G6P in component V_PGLM (millimolar)');
    LEGEND_CONSTANTS(:,27) = strpad('Keq_PGLM in component V_PGLM (dimensionless)');
    LEGEND_CONSTANTS(:,103) = strpad('V_max_r in component V_PGLM (flux)');
    LEGEND_CONSTANTS(:,28) = strpad('V_max_f in component V_PGLM (flux)');
    LEGEND_CONSTANTS(:,29) = strpad('K_G6P in component V_PGI (millimolar)');
    LEGEND_CONSTANTS(:,30) = strpad('K_F6P in component V_PGI (millimolar)');
    LEGEND_CONSTANTS(:,31) = strpad('Keq_PGI in component V_PGI (dimensionless)');
    LEGEND_CONSTANTS(:,32) = strpad('V_max_r in component V_PGI (flux)');
    LEGEND_CONSTANTS(:,104) = strpad('V_max_f in component V_PGI (flux)');
    LEGEND_CONSTANTS(:,33) = strpad('K_FBP in component V_PFK (millimolar)');
    LEGEND_CONSTANTS(:,34) = strpad('K_FBP_ in component V_PFK (millimolar)');
    LEGEND_CONSTANTS(:,35) = strpad('K_F6P in component V_PFK (millimolar)');
    LEGEND_CONSTANTS(:,36) = strpad('K_ATP in component V_PFK (millimolar)');
    LEGEND_CONSTANTS(:,37) = strpad('K_F6P_ in component V_PFK (millimolar)');
    LEGEND_CONSTANTS(:,38) = strpad('K_ATP_ in component V_PFK (millimolar)');
    LEGEND_CONSTANTS(:,39) = strpad('K_ADP in component V_PFK (millimolar)');
    LEGEND_CONSTANTS(:,40) = strpad('K_ADP_ in component V_PFK (millimolar)');
    LEGEND_CONSTANTS(:,41) = strpad('Ki_ATP in component V_PFK (millimolar)');
    LEGEND_CONSTANTS(:,42) = strpad('Ka_AMP in component V_PFK (millimolar)');
    LEGEND_CONSTANTS(:,105) = strpad('V_max_r in component V_PFK (flux)');
    LEGEND_CONSTANTS(:,43) = strpad('V_max_f in component V_PFK (flux)');
    LEGEND_CONSTANTS(:,106) = strpad('alpha in component V_PFK (dimensionless)');
    LEGEND_ALGEBRAIC(:,9) = strpad('L in component V_PFK (dimensionless)');
    LEGEND_CONSTANTS(:,44) = strpad('Lo in component V_PFK (dimensionless)');
    LEGEND_ALGEBRAIC(:,7) = strpad('delta in component V_PFK (dimensionless)');
    LEGEND_ALGEBRAIC(:,8) = strpad('delta_ in component V_PFK (dimensionless)');
    LEGEND_CONSTANTS(:,45) = strpad('d in component V_PFK (dimensionless)');
    LEGEND_CONSTANTS(:,46) = strpad('var_e in component V_PFK (dimensionless)');
    LEGEND_CONSTANTS(:,47) = strpad('K_GAP in component V_ALD (millimolar)');
    LEGEND_CONSTANTS(:,48) = strpad('K_FBP in component V_ALD (millimolar)');
    LEGEND_CONSTANTS(:,49) = strpad('K_DHAP in component V_ALD (millimolar)');
    LEGEND_CONSTANTS(:,50) = strpad('Keq_ALD in component V_ALD (millimolar)');
    LEGEND_CONSTANTS(:,107) = strpad('V_max_r in component V_ALD (flux)');
    LEGEND_CONSTANTS(:,51) = strpad('V_max_f in component V_ALD (flux)');
    LEGEND_CONSTANTS(:,52) = strpad('K_GAP in component V_TPI (millimolar)');
    LEGEND_CONSTANTS(:,53) = strpad('K_DHAP in component V_TPI (millimolar)');
    LEGEND_CONSTANTS(:,54) = strpad('Keq_TPI in component V_TPI (dimensionless)');
    LEGEND_CONSTANTS(:,108) = strpad('V_max_r in component V_TPI (flux)');
    LEGEND_CONSTANTS(:,55) = strpad('V_max_f in component V_TPI (flux)');
    LEGEND_ALGEBRAIC(:,13) = strpad('D_GAPDH in component V_GAPDH (dimensionless)');
    LEGEND_CONSTANTS(:,56) = strpad('K_GAP in component V_GAPDH (millimolar)');
    LEGEND_CONSTANTS(:,57) = strpad('K_Pi in component V_GAPDH (millimolar)');
    LEGEND_CONSTANTS(:,58) = strpad('K_NAD in component V_GAPDH (millimolar)');
    LEGEND_CONSTANTS(:,59) = strpad('K_NADH in component V_GAPDH (millimolar)');
    LEGEND_CONSTANTS(:,60) = strpad('K_Thirteen_BPG in component V_GAPDH (millimolar)');
    LEGEND_CONSTANTS(:,61) = strpad('Keq_GAPDH in component V_GAPDH (dimensionless)');
    LEGEND_CONSTANTS(:,109) = strpad('V_max_r in component V_GAPDH (flux)');
    LEGEND_CONSTANTS(:,62) = strpad('V_max_f in component V_GAPDH (flux)');
    LEGEND_CONSTANTS(:,63) = strpad('K_three_PG in component V_PGK (millimolar)');
    LEGEND_CONSTANTS(:,64) = strpad('K_ADP in component V_PGK (millimolar)');
    LEGEND_CONSTANTS(:,65) = strpad('K_ATP in component V_PGK (millimolar)');
    LEGEND_CONSTANTS(:,66) = strpad('K_Thirteen_BPG in component V_PGK (millimolar)');
    LEGEND_CONSTANTS(:,67) = strpad('Keq_PGK in component V_PGK (dimensionless)');
    LEGEND_CONSTANTS(:,68) = strpad('V_max_r in component V_PGK (flux)');
    LEGEND_CONSTANTS(:,110) = strpad('V_max_f in component V_PGK (flux)');
    LEGEND_CONSTANTS(:,69) = strpad('K_two_PG in component V_PGM (millimolar)');
    LEGEND_CONSTANTS(:,70) = strpad('K_three_PG in component V_PGM (millimolar)');
    LEGEND_CONSTANTS(:,71) = strpad('Keq_PGM in component V_PGM (dimensionless)');
    LEGEND_CONSTANTS(:,111) = strpad('V_max_r in component V_PGM (flux)');
    LEGEND_CONSTANTS(:,72) = strpad('V_max_f in component V_PGM (flux)');
    LEGEND_CONSTANTS(:,73) = strpad('K_PEP in component V_ENOL (millimolar)');
    LEGEND_CONSTANTS(:,74) = strpad('K_two_PG in component V_ENOL (millimolar)');
    LEGEND_CONSTANTS(:,75) = strpad('Keq_ENOL in component V_ENOL (dimensionless)');
    LEGEND_CONSTANTS(:,112) = strpad('V_max_r in component V_ENOL (flux)');
    LEGEND_CONSTANTS(:,76) = strpad('V_max_f in component V_ENOL (flux)');
    LEGEND_CONSTANTS(:,77) = strpad('K_PYR in component V_PK (millimolar)');
    LEGEND_CONSTANTS(:,78) = strpad('K_ADP in component V_PK (millimolar)');
    LEGEND_CONSTANTS(:,79) = strpad('K_ATP in component V_PK (millimolar)');
    LEGEND_CONSTANTS(:,80) = strpad('K_PEP in component V_PK (millimolar)');
    LEGEND_CONSTANTS(:,81) = strpad('Keq_PK in component V_PK (dimensionless)');
    LEGEND_CONSTANTS(:,113) = strpad('V_max_r in component V_PK (flux)');
    LEGEND_CONSTANTS(:,82) = strpad('V_max_f in component V_PK (flux)');
    LEGEND_CONSTANTS(:,83) = strpad('K_LAC in component V_LDH (millimolar)');
    LEGEND_CONSTANTS(:,84) = strpad('K_NADH in component V_LDH (millimolar)');
    LEGEND_CONSTANTS(:,85) = strpad('K_NAD in component V_LDH (millimolar)');
    LEGEND_CONSTANTS(:,86) = strpad('K_PYR in component V_LDH (millimolar)');
    LEGEND_CONSTANTS(:,87) = strpad('Keq_LDH in component V_LDH (dimensionless)');
    LEGEND_CONSTANTS(:,114) = strpad('V_max_r in component V_LDH (flux)');
    LEGEND_CONSTANTS(:,88) = strpad('V_max_f in component V_LDH (flux)');
    LEGEND_CONSTANTS(:,89) = strpad('Ki_ADP in component V_CK (millimolar)');
    LEGEND_CONSTANTS(:,90) = strpad('K_Cr in component V_CK (millimolar)');
    LEGEND_CONSTANTS(:,91) = strpad('K_PCr in component V_CK (millimolar)');
    LEGEND_CONSTANTS(:,92) = strpad('Ki_PCr in component V_CK (millimolar)');
    LEGEND_CONSTANTS(:,93) = strpad('Ki_ATP in component V_CK (millimolar)');
    LEGEND_CONSTANTS(:,94) = strpad('Keq_CK in component V_CK (dimensionless)');
    LEGEND_CONSTANTS(:,95) = strpad('V_max_r in component V_CK (flux)');
    LEGEND_CONSTANTS(:,115) = strpad('V_max_f in component V_CK (flux)');
    LEGEND_CONSTANTS(:,96) = strpad('K_ADP in component V_ADK (millimolar)');
    LEGEND_CONSTANTS(:,97) = strpad('K_AMP in component V_ADK (millimolar)');
    LEGEND_CONSTANTS(:,98) = strpad('K_ATP in component V_ADK (millimolar)');
    LEGEND_CONSTANTS(:,99) = strpad('Keq_ADK in component V_ADK (dimensionless)');
    LEGEND_CONSTANTS(:,116) = strpad('V_max_r in component V_ADK (flux)');
    LEGEND_CONSTANTS(:,100) = strpad('V_max_f in component V_ADK (flux)');
    LEGEND_RATES(:,1) = strpad('d/dt GLY in component GLY (millimolar)');
    LEGEND_RATES(:,2) = strpad('d/dt G1P in component G1P (millimolar)');
    LEGEND_RATES(:,3) = strpad('d/dt G6P in component G6P (millimolar)');
    LEGEND_RATES(:,4) = strpad('d/dt F6P in component F6P (millimolar)');
    LEGEND_RATES(:,5) = strpad('d/dt FBP in component FBP (millimolar)');
    LEGEND_RATES(:,6) = strpad('d/dt DHAP in component DHAP (millimolar)');
    LEGEND_RATES(:,7) = strpad('d/dt GAP in component GAP (millimolar)');
    LEGEND_RATES(:,8) = strpad('d/dt Thirteen_BPG in component Thirteen_BPG (millimolar)');
    LEGEND_RATES(:,9) = strpad('d/dt three_PG in component three_PG (millimolar)');
    LEGEND_RATES(:,10) = strpad('d/dt two_PG in component two_PG (millimolar)');
    LEGEND_RATES(:,11) = strpad('d/dt PEP in component PEP (millimolar)');
    LEGEND_RATES(:,12) = strpad('d/dt PYR in component PYR (millimolar)');
    LEGEND_RATES(:,13) = strpad('d/dt LAC in component LAC (millimolar)');
    LEGEND_RATES(:,14) = strpad('d/dt Pi in component Pi (millimolar)');
    LEGEND_RATES(:,15) = strpad('d/dt ADP in component ADP (millimolar)');
    LEGEND_RATES(:,16) = strpad('d/dt ATP in component ATP (millimolar)');
    LEGEND_RATES(:,17) = strpad('d/dt AMP in component AMP (millimolar)');
    LEGEND_RATES(:,18) = strpad('d/dt PCr in component PCr (millimolar)');
    LEGEND_RATES(:,19) = strpad('d/dt Cr in component Cr (millimolar)');
    LEGEND_RATES(:,20) = strpad('d/dt NADH in component NADH (millimolar)');
    LEGEND_RATES(:,21) = strpad('d/dt NAD in component NAD (millimolar)');
    LEGEND_STATES  = LEGEND_STATES';
    LEGEND_ALGEBRAIC = LEGEND_ALGEBRAIC';
    LEGEND_RATES = LEGEND_RATES';
    LEGEND_CONSTANTS = LEGEND_CONSTANTS';
end

function [STATES, CONSTANTS] = initConsts()
    VOI = 0; CONSTANTS = []; STATES = []; ALGEBRAIC = [];
    STATES(:,1) = 112.0;
    STATES(:,2) = 0.0589;
    STATES(:,3) = 0.75;
    STATES(:,4) = 0.228;
    STATES(:,5) = 0.0723;
    STATES(:,6) = 0.0764;
    STATES(:,7) = 0.0355;
    STATES(:,8) = 0.065;
    STATES(:,9) = 0.052;
    STATES(:,10) = 0.005;
    STATES(:,11) = 0.0194;
    STATES(:,12) = 0.0994;
    STATES(:,13) = 1.3;
    STATES(:,14) = 4.1;
    CONSTANTS(:,1) = 600.0;
    STATES(:,15) = 0.013;
    STATES(:,16) = 8.2;
    STATES(:,17) = 0.99;
    STATES(:,18) = 34.67;
    STATES(:,19) = 35.0;
    STATES(:,20) = 0.001;
    STATES(:,21) = 0.5;
    CONSTANTS(:,2) = 0.4;
    CONSTANTS(:,3) = 0.6;
    CONSTANTS(:,4) = 2.0;
    CONSTANTS(:,5) = 2.0;
    CONSTANTS(:,6) = 1.7;
    CONSTANTS(:,7) = 0.15;
    CONSTANTS(:,8) = 0.42;
    CONSTANTS(:,9) = 4.7;
    CONSTANTS(:,10) = 4.0;
    CONSTANTS(:,11) = 10.1;
    CONSTANTS(:,12) = 20.0;
    CONSTANTS(:,13) = 15.0;
    CONSTANTS(:,14) = 4.4;
    CONSTANTS(:,15) = 1.7;
    CONSTANTS(:,16) = 0.42;
    CONSTANTS(:,17) = 1.75;
    CONSTANTS(:,18) = 1.9E-6;
    CONSTANTS(:,19) = 0.15;
    CONSTANTS(:,20) = 4.6;
    CONSTANTS(:,21) = 0.2;
    CONSTANTS(:,22) = 7.4;
    CONSTANTS(:,23) = 1.5;
    CONSTANTS(:,24) = 30.0;
    CONSTANTS(:,25) = 0.063;
    CONSTANTS(:,26) = 0.03;
    CONSTANTS(:,27) = 16.62;
    CONSTANTS(:,28) = 480.0;
    CONSTANTS(:,29) = 0.18;
    CONSTANTS(:,30) = 0.119;
    CONSTANTS(:,31) = 0.45;
    CONSTANTS(:,32) = 880.0;
    CONSTANTS(:,33) = 4.02;
    CONSTANTS(:,34) = 4.02;
    CONSTANTS(:,35) = 0.18;
    CONSTANTS(:,36) = 0.08;
    CONSTANTS(:,37) = 20.0;
    CONSTANTS(:,38) = 0.25;
    CONSTANTS(:,39) = 2.7;
    CONSTANTS(:,40) = 2.7;
    CONSTANTS(:,41) = 0.87;
    CONSTANTS(:,42) = 0.06;
    CONSTANTS(:,43) = 56.0;
    CONSTANTS(:,44) = 13.0;
    CONSTANTS(:,45) = 0.01;
    CONSTANTS(:,46) = 0.01;
    CONSTANTS(:,47) = 1.0;
    CONSTANTS(:,48) = 0.05;
    CONSTANTS(:,49) = 2.0;
    CONSTANTS(:,50) = 9.5E-5;
    CONSTANTS(:,51) = 104.0;
    CONSTANTS(:,52) = 0.32;
    CONSTANTS(:,53) = 0.61;
    CONSTANTS(:,54) = 0.052;
    CONSTANTS(:,55) = 12000.0;
    CONSTANTS(:,56) = 0.0025;
    CONSTANTS(:,57) = 0.29;
    CONSTANTS(:,58) = 0.09;
    CONSTANTS(:,59) = 0.0033;
    CONSTANTS(:,60) = 0.0008;
    CONSTANTS(:,61) = 0.089;
    CONSTANTS(:,62) = 1265.0;
    CONSTANTS(:,63) = 1.2;
    CONSTANTS(:,64) = 0.008;
    CONSTANTS(:,65) = 0.35;
    CONSTANTS(:,66) = 0.002;
    CONSTANTS(:,67) = 57109.0;
    CONSTANTS(:,68) = 1120.0;
    CONSTANTS(:,69) = 0.014;
    CONSTANTS(:,70) = 0.2;
    CONSTANTS(:,71) = 0.18;
    CONSTANTS(:,72) = 1120.0;
    CONSTANTS(:,73) = 0.37;
    CONSTANTS(:,74) = 0.1;
    CONSTANTS(:,75) = 0.49;
    CONSTANTS(:,76) = 192.0;
    CONSTANTS(:,77) = 7.05;
    CONSTANTS(:,78) = 0.3;
    CONSTANTS(:,79) = 1.13;
    CONSTANTS(:,80) = 0.08;
    CONSTANTS(:,81) = 10304.0;
    CONSTANTS(:,82) = 1440.0;
    CONSTANTS(:,83) = 17.0;
    CONSTANTS(:,84) = 0.002;
    CONSTANTS(:,85) = 0.849;
    CONSTANTS(:,86) = 0.335;
    CONSTANTS(:,87) = 16198.0;
    CONSTANTS(:,88) = 1920.0;
    CONSTANTS(:,89) = 0.135;
    CONSTANTS(:,90) = 3.8;
    CONSTANTS(:,91) = 1.11;
    CONSTANTS(:,92) = 3.9;
    CONSTANTS(:,93) = 3.5;
    CONSTANTS(:,94) = 233.0;
    CONSTANTS(:,95) = 500.0;
    CONSTANTS(:,96) = 0.35;
    CONSTANTS(:,97) = 0.32;
    CONSTANTS(:,98) = 0.27;
    CONSTANTS(:,99) = 2.21;
    CONSTANTS(:,100) = 880.0;
    CONSTANTS(:,101) = ( CONSTANTS(:,12).*CONSTANTS(:,7).*CONSTANTS(:,11))./( CONSTANTS(:,4).*CONSTANTS(:,10).*CONSTANTS(:,8));
    CONSTANTS(:,102) = ( CONSTANTS(:,24).*CONSTANTS(:,14).*CONSTANTS(:,23))./( CONSTANTS(:,15).*CONSTANTS(:,20).*CONSTANTS(:,16));
    CONSTANTS(:,103) = ( CONSTANTS(:,28).*CONSTANTS(:,26))./( CONSTANTS(:,25).*CONSTANTS(:,27));
    CONSTANTS(:,104) = ( CONSTANTS(:,32).*CONSTANTS(:,29).*CONSTANTS(:,31))./CONSTANTS(:,30);
    CONSTANTS(:,105) = ( CONSTANTS(:,43).*CONSTANTS(:,39).*CONSTANTS(:,33))./( CONSTANTS(:,36).*CONSTANTS(:,35));
    CONSTANTS(:,106) = ( CONSTANTS(:,35).*CONSTANTS(:,36))./( CONSTANTS(:,37).*CONSTANTS(:,38));
    CONSTANTS(:,107) = ( CONSTANTS(:,51).*CONSTANTS(:,49).*CONSTANTS(:,47))./( CONSTANTS(:,48).*CONSTANTS(:,50));
    CONSTANTS(:,108) = ( CONSTANTS(:,55).*CONSTANTS(:,53))./( CONSTANTS(:,52).*CONSTANTS(:,54));
    CONSTANTS(:,109) = ( CONSTANTS(:,62).*1.00000.*CONSTANTS(:,60).*CONSTANTS(:,59))./( CONSTANTS(:,56).*CONSTANTS(:,58).*CONSTANTS(:,57).*CONSTANTS(:,61));
    CONSTANTS(:,110) = ( CONSTANTS(:,68).*CONSTANTS(:,66).*CONSTANTS(:,64).*CONSTANTS(:,67))./( CONSTANTS(:,63).*CONSTANTS(:,65));
    CONSTANTS(:,111) = ( CONSTANTS(:,72).*CONSTANTS(:,69))./( CONSTANTS(:,70).*CONSTANTS(:,71));
    CONSTANTS(:,112) = ( CONSTANTS(:,76).*CONSTANTS(:,73))./( CONSTANTS(:,74).*CONSTANTS(:,75));
    CONSTANTS(:,113) = ( CONSTANTS(:,82).*CONSTANTS(:,79).*CONSTANTS(:,77))./( CONSTANTS(:,80).*CONSTANTS(:,78).*CONSTANTS(:,81));
    CONSTANTS(:,114) = ( CONSTANTS(:,88).*CONSTANTS(:,83).*CONSTANTS(:,85))./( CONSTANTS(:,86).*CONSTANTS(:,84).*CONSTANTS(:,87));
    CONSTANTS(:,115) = ( CONSTANTS(:,95).*CONSTANTS(:,93).*CONSTANTS(:,90).*CONSTANTS(:,94))./( CONSTANTS(:,89).*CONSTANTS(:,91));
    CONSTANTS(:,116) = ( CONSTANTS(:,100).*power(CONSTANTS(:,96), 2.00000))./( CONSTANTS(:,98).*CONSTANTS(:,97).*CONSTANTS(:,99));
    if (isempty(STATES)), warning('Initial values for states not set');, end
end

function [RATES, ALGEBRAIC] = computeRates(VOI, STATES, CONSTANTS)
    global algebraicVariableCount;
    statesSize = size(STATES);
    statesColumnCount = statesSize(2);
    if ( statesColumnCount == 1)
        STATES = STATES';
        ALGEBRAIC = zeros(1, algebraicVariableCount);
        utilOnes = 1;
    else
        statesRowCount = statesSize(1);
        ALGEBRAIC = zeros(statesRowCount, algebraicVariableCount);
        RATES = zeros(statesRowCount, statesColumnCount);
        utilOnes = ones(statesRowCount, 1);
    end
    ALGEBRAIC(:,2) = ( CONSTANTS(:,12).*(( STATES(:,1).*STATES(:,14))./( CONSTANTS(:,4).*CONSTANTS(:,10))) -  CONSTANTS(:,101).*(( STATES(:,1).*STATES(:,2))./( CONSTANTS(:,5).*CONSTANTS(:,11))))./(1.00000+STATES(:,1)./CONSTANTS(:,4)+STATES(:,14)./CONSTANTS(:,9)+STATES(:,1)./CONSTANTS(:,5)+STATES(:,2)./CONSTANTS(:,11)+( STATES(:,1).*STATES(:,14))./( CONSTANTS(:,6).*CONSTANTS(:,9))+( STATES(:,1).*STATES(:,2))./( CONSTANTS(:,7).*CONSTANTS(:,11)));
    ALGEBRAIC(:,3) =  (( CONSTANTS(:,24).*(( STATES(:,1).*STATES(:,14))./( CONSTANTS(:,13).*CONSTANTS(:,21))) -  CONSTANTS(:,102).*(( STATES(:,1).*STATES(:,2))./( CONSTANTS(:,14).*CONSTANTS(:,22))))./(1.00000+STATES(:,1)./CONSTANTS(:,13)+STATES(:,14)./CONSTANTS(:,20)+STATES(:,1)./CONSTANTS(:,14)+STATES(:,2)./CONSTANTS(:,22)+( STATES(:,1).*STATES(:,14))./( CONSTANTS(:,15).*CONSTANTS(:,20))+( STATES(:,1).*STATES(:,2))./( CONSTANTS(:,19).*CONSTANTS(:,22)))).*((power(STATES(:,17), CONSTANTS(:,17))./CONSTANTS(:,18))./(1.00000+power(STATES(:,17), CONSTANTS(:,17))./CONSTANTS(:,18)));
    ALGEBRAIC(:,4) =  CONSTANTS(:,2).*ALGEBRAIC(:,2)+ CONSTANTS(:,3).*ALGEBRAIC(:,3);
    RATES(:,1) =  - ALGEBRAIC(:,4);
    ALGEBRAIC(:,5) = ( CONSTANTS(:,28).*(STATES(:,2)./CONSTANTS(:,25)) -  CONSTANTS(:,103).*(STATES(:,3)./CONSTANTS(:,26)))./(1.00000+STATES(:,2)./CONSTANTS(:,25)+STATES(:,3)./CONSTANTS(:,26));
    RATES(:,2) = ALGEBRAIC(:,4) - ALGEBRAIC(:,5);
    ALGEBRAIC(:,6) = ( CONSTANTS(:,104).*(STATES(:,3)./CONSTANTS(:,29)) -  CONSTANTS(:,32).*(STATES(:,4)./CONSTANTS(:,30)))./(1.00000+STATES(:,3)./CONSTANTS(:,29)+STATES(:,4)./CONSTANTS(:,30));
    RATES(:,3) = ALGEBRAIC(:,5) - ALGEBRAIC(:,6);
    ALGEBRAIC(:,9) =  CONSTANTS(:,44).*power( ((1.00000+STATES(:,16)./CONSTANTS(:,41))./(1.00000+ CONSTANTS(:,45).*(STATES(:,16)./CONSTANTS(:,41)))).*((1.00000+ CONSTANTS(:,46).*(STATES(:,17)./CONSTANTS(:,42)))./(1.00000+STATES(:,17)./CONSTANTS(:,42))), 4.00000);
    ALGEBRAIC(:,7) =  (1.00000+STATES(:,4)./CONSTANTS(:,35)).*(1.00000+STATES(:,16)./CONSTANTS(:,36))+STATES(:,15)./CONSTANTS(:,39)+ (STATES(:,5)./CONSTANTS(:,33)).*(1.00000+STATES(:,15)./CONSTANTS(:,39));
    ALGEBRAIC(:,8) =  (1.00000+STATES(:,4)./CONSTANTS(:,37)).*(1.00000+STATES(:,16)./CONSTANTS(:,38))+STATES(:,15)./CONSTANTS(:,40)+ (STATES(:,5)./CONSTANTS(:,34)).*(1.00000+STATES(:,15)./CONSTANTS(:,40));
    ALGEBRAIC(:,10) =  (( CONSTANTS(:,43).*(( STATES(:,16).*STATES(:,4))./( CONSTANTS(:,36).*CONSTANTS(:,35))) -  CONSTANTS(:,105).*(( STATES(:,15).*STATES(:,5))./( CONSTANTS(:,39).*CONSTANTS(:,33))))./ALGEBRAIC(:,7)).*((1.00000+ CONSTANTS(:,106).*ALGEBRAIC(:,9).*power(ALGEBRAIC(:,8)./ALGEBRAIC(:,7), 3.00000))./(1.00000+ ALGEBRAIC(:,9).*power(ALGEBRAIC(:,8)./ALGEBRAIC(:,7), 4.00000)));
    RATES(:,4) = ALGEBRAIC(:,6) - ALGEBRAIC(:,10);
    ALGEBRAIC(:,11) = ( CONSTANTS(:,51).*(STATES(:,5)./CONSTANTS(:,48)) -  CONSTANTS(:,107).*(( STATES(:,6).*STATES(:,7))./( CONSTANTS(:,49).*CONSTANTS(:,47))))./(1.00000+STATES(:,5)./CONSTANTS(:,48)+STATES(:,6)./CONSTANTS(:,49)+STATES(:,7)./CONSTANTS(:,47));
    RATES(:,5) = ALGEBRAIC(:,10) - ALGEBRAIC(:,11);
    ALGEBRAIC(:,12) = ( CONSTANTS(:,55).*(STATES(:,7)./CONSTANTS(:,52)) -  CONSTANTS(:,108).*(STATES(:,6)./CONSTANTS(:,53)))./(1.00000+STATES(:,6)./CONSTANTS(:,53)+STATES(:,7)./CONSTANTS(:,52));
    RATES(:,6) = ALGEBRAIC(:,11)+ALGEBRAIC(:,12);
    ALGEBRAIC(:,13) = 1.00000+STATES(:,7)./CONSTANTS(:,56)+STATES(:,21)./CONSTANTS(:,58)+STATES(:,14)./CONSTANTS(:,57)+( STATES(:,7).*STATES(:,21))./( CONSTANTS(:,56).*CONSTANTS(:,58))+( STATES(:,7).*STATES(:,21).*STATES(:,14))./( CONSTANTS(:,56).*CONSTANTS(:,58).*CONSTANTS(:,57))+STATES(:,8)./CONSTANTS(:,60)+STATES(:,20)./CONSTANTS(:,59)+( STATES(:,8).*STATES(:,20))./( CONSTANTS(:,60).*CONSTANTS(:,59));
    ALGEBRAIC(:,14) = ( CONSTANTS(:,62).*(( STATES(:,7).*STATES(:,21).*STATES(:,14))./( CONSTANTS(:,56).*CONSTANTS(:,58).*CONSTANTS(:,57))) -  CONSTANTS(:,109).*(( STATES(:,8).*STATES(:,20))./( CONSTANTS(:,60).*CONSTANTS(:,59))))./ALGEBRAIC(:,13);
    RATES(:,7) = ALGEBRAIC(:,11) - (ALGEBRAIC(:,12)+ALGEBRAIC(:,14));
    RATES(:,14) = CONSTANTS(:,1) - (ALGEBRAIC(:,4)+ALGEBRAIC(:,14));
    ALGEBRAIC(:,15) = ( CONSTANTS(:,110).*(( STATES(:,8).*STATES(:,15))./( CONSTANTS(:,66).*CONSTANTS(:,64))) -  CONSTANTS(:,68).*(( STATES(:,9).*STATES(:,16))./( CONSTANTS(:,63).*CONSTANTS(:,65))))./(1.00000+STATES(:,8)./CONSTANTS(:,66)+STATES(:,15)./CONSTANTS(:,64)+( STATES(:,8).*STATES(:,15))./( CONSTANTS(:,66).*CONSTANTS(:,64))+STATES(:,9)./CONSTANTS(:,63)+STATES(:,16)./CONSTANTS(:,65)+( STATES(:,9).*STATES(:,16))./( CONSTANTS(:,63).*CONSTANTS(:,65)));
    RATES(:,8) = ALGEBRAIC(:,14) - ALGEBRAIC(:,15);
    ALGEBRAIC(:,16) = ( CONSTANTS(:,72).*(STATES(:,9)./CONSTANTS(:,70)) -  CONSTANTS(:,111).*(STATES(:,10)./CONSTANTS(:,69)))./(1.00000+STATES(:,9)./CONSTANTS(:,70)+STATES(:,10)./CONSTANTS(:,69));
    RATES(:,9) = ALGEBRAIC(:,15) - ALGEBRAIC(:,16);
    ALGEBRAIC(:,17) = ( CONSTANTS(:,76).*(STATES(:,10)./CONSTANTS(:,74)) -  CONSTANTS(:,112).*(STATES(:,11)./CONSTANTS(:,73)))./(1.00000+STATES(:,10)./CONSTANTS(:,74)+STATES(:,11)./CONSTANTS(:,73));
    RATES(:,10) = ALGEBRAIC(:,16) - ALGEBRAIC(:,17);
    ALGEBRAIC(:,18) = ( CONSTANTS(:,82).*(( STATES(:,11).*STATES(:,15))./( CONSTANTS(:,80).*CONSTANTS(:,78))) -  CONSTANTS(:,113).*(( STATES(:,12).*STATES(:,16))./( CONSTANTS(:,77).*CONSTANTS(:,79))))./(1.00000+STATES(:,11)./CONSTANTS(:,80)+STATES(:,15)./CONSTANTS(:,78)+( STATES(:,11).*STATES(:,15))./( CONSTANTS(:,80).*CONSTANTS(:,78))+STATES(:,12)./CONSTANTS(:,77)+STATES(:,16)./CONSTANTS(:,79)+( STATES(:,12).*STATES(:,16))./( CONSTANTS(:,77).*CONSTANTS(:,79)));
    RATES(:,11) = ALGEBRAIC(:,17) - ALGEBRAIC(:,18);
    ALGEBRAIC(:,19) = ( CONSTANTS(:,88).*(( STATES(:,12).*STATES(:,20))./( CONSTANTS(:,86).*CONSTANTS(:,84))) -  CONSTANTS(:,114).*(( STATES(:,13).*STATES(:,21))./( CONSTANTS(:,83).*CONSTANTS(:,85))))./(1.00000+STATES(:,12)./CONSTANTS(:,86)+STATES(:,20)./CONSTANTS(:,84)+( STATES(:,12).*STATES(:,20))./( CONSTANTS(:,86).*CONSTANTS(:,84))+STATES(:,13)./CONSTANTS(:,83)+STATES(:,21)./CONSTANTS(:,85)+( STATES(:,13).*STATES(:,21))./( CONSTANTS(:,83).*CONSTANTS(:,85)));
    RATES(:,12) = ALGEBRAIC(:,18) - ALGEBRAIC(:,19);
    ALGEBRAIC(:,1) =  0.200000.*STATES(:,13);
    RATES(:,13) = ALGEBRAIC(:,19) - ALGEBRAIC(:,1);
    ALGEBRAIC(:,20) = ( CONSTANTS(:,115).*(( STATES(:,16).*STATES(:,19))./( CONSTANTS(:,93).*CONSTANTS(:,90))) -  CONSTANTS(:,95).*(( STATES(:,15).*STATES(:,18))./( CONSTANTS(:,89).*CONSTANTS(:,91))))./(1.00000+STATES(:,15)./CONSTANTS(:,89)+STATES(:,18)./CONSTANTS(:,92)+( STATES(:,15).*STATES(:,18))./( CONSTANTS(:,89).*CONSTANTS(:,91))+STATES(:,16)./CONSTANTS(:,93)+( STATES(:,16).*STATES(:,19))./( CONSTANTS(:,93).*CONSTANTS(:,90)));
    RATES(:,18) = ALGEBRAIC(:,20);
    RATES(:,19) =  - ALGEBRAIC(:,20);
    RATES(:,20) = ALGEBRAIC(:,14) - ALGEBRAIC(:,19);
    RATES(:,21) = ALGEBRAIC(:,19) - ALGEBRAIC(:,14);
    ALGEBRAIC(:,21) = ( CONSTANTS(:,100).*(( STATES(:,16).*STATES(:,17))./( CONSTANTS(:,98).*CONSTANTS(:,97))) -  CONSTANTS(:,116).*(power(STATES(:,15), 2.00000)./power(CONSTANTS(:,96), 2.00000)))./(1.00000+STATES(:,16)./CONSTANTS(:,98)+STATES(:,17)./CONSTANTS(:,97)+( STATES(:,16).*STATES(:,17))./( CONSTANTS(:,98).*CONSTANTS(:,97))+( 2.00000.*STATES(:,15))./CONSTANTS(:,96)+power(STATES(:,15), 2.00000)./power(CONSTANTS(:,96), 2.00000));
    RATES(:,15) = ALGEBRAIC(:,10)+ 2.00000.*ALGEBRAIC(:,21)+ALGEBRAIC(:,20)+CONSTANTS(:,1)+ - (ALGEBRAIC(:,15)+ALGEBRAIC(:,18));
    RATES(:,16) = ALGEBRAIC(:,15)+ALGEBRAIC(:,18)+ - (ALGEBRAIC(:,10)+ALGEBRAIC(:,21)+ALGEBRAIC(:,20)+CONSTANTS(:,1));
    RATES(:,17) =  - ALGEBRAIC(:,21);
   RATES = RATES';
end

% Calculate algebraic variables
function ALGEBRAIC = computeAlgebraic(ALGEBRAIC, CONSTANTS, STATES, VOI)
    statesSize = size(STATES);
    statesColumnCount = statesSize(2);
    if ( statesColumnCount == 1)
        STATES = STATES';
        utilOnes = 1;
    else
        statesRowCount = statesSize(1);
        utilOnes = ones(statesRowCount, 1);
    end
    ALGEBRAIC(:,2) = ( CONSTANTS(:,12).*(( STATES(:,1).*STATES(:,14))./( CONSTANTS(:,4).*CONSTANTS(:,10))) -  CONSTANTS(:,101).*(( STATES(:,1).*STATES(:,2))./( CONSTANTS(:,5).*CONSTANTS(:,11))))./(1.00000+STATES(:,1)./CONSTANTS(:,4)+STATES(:,14)./CONSTANTS(:,9)+STATES(:,1)./CONSTANTS(:,5)+STATES(:,2)./CONSTANTS(:,11)+( STATES(:,1).*STATES(:,14))./( CONSTANTS(:,6).*CONSTANTS(:,9))+( STATES(:,1).*STATES(:,2))./( CONSTANTS(:,7).*CONSTANTS(:,11)));
    ALGEBRAIC(:,3) =  (( CONSTANTS(:,24).*(( STATES(:,1).*STATES(:,14))./( CONSTANTS(:,13).*CONSTANTS(:,21))) -  CONSTANTS(:,102).*(( STATES(:,1).*STATES(:,2))./( CONSTANTS(:,14).*CONSTANTS(:,22))))./(1.00000+STATES(:,1)./CONSTANTS(:,13)+STATES(:,14)./CONSTANTS(:,20)+STATES(:,1)./CONSTANTS(:,14)+STATES(:,2)./CONSTANTS(:,22)+( STATES(:,1).*STATES(:,14))./( CONSTANTS(:,15).*CONSTANTS(:,20))+( STATES(:,1).*STATES(:,2))./( CONSTANTS(:,19).*CONSTANTS(:,22)))).*((power(STATES(:,17), CONSTANTS(:,17))./CONSTANTS(:,18))./(1.00000+power(STATES(:,17), CONSTANTS(:,17))./CONSTANTS(:,18)));
    ALGEBRAIC(:,4) =  CONSTANTS(:,2).*ALGEBRAIC(:,2)+ CONSTANTS(:,3).*ALGEBRAIC(:,3);
    ALGEBRAIC(:,5) = ( CONSTANTS(:,28).*(STATES(:,2)./CONSTANTS(:,25)) -  CONSTANTS(:,103).*(STATES(:,3)./CONSTANTS(:,26)))./(1.00000+STATES(:,2)./CONSTANTS(:,25)+STATES(:,3)./CONSTANTS(:,26));
    ALGEBRAIC(:,6) = ( CONSTANTS(:,104).*(STATES(:,3)./CONSTANTS(:,29)) -  CONSTANTS(:,32).*(STATES(:,4)./CONSTANTS(:,30)))./(1.00000+STATES(:,3)./CONSTANTS(:,29)+STATES(:,4)./CONSTANTS(:,30));
    ALGEBRAIC(:,9) =  CONSTANTS(:,44).*power( ((1.00000+STATES(:,16)./CONSTANTS(:,41))./(1.00000+ CONSTANTS(:,45).*(STATES(:,16)./CONSTANTS(:,41)))).*((1.00000+ CONSTANTS(:,46).*(STATES(:,17)./CONSTANTS(:,42)))./(1.00000+STATES(:,17)./CONSTANTS(:,42))), 4.00000);
    ALGEBRAIC(:,7) =  (1.00000+STATES(:,4)./CONSTANTS(:,35)).*(1.00000+STATES(:,16)./CONSTANTS(:,36))+STATES(:,15)./CONSTANTS(:,39)+ (STATES(:,5)./CONSTANTS(:,33)).*(1.00000+STATES(:,15)./CONSTANTS(:,39));
    ALGEBRAIC(:,8) =  (1.00000+STATES(:,4)./CONSTANTS(:,37)).*(1.00000+STATES(:,16)./CONSTANTS(:,38))+STATES(:,15)./CONSTANTS(:,40)+ (STATES(:,5)./CONSTANTS(:,34)).*(1.00000+STATES(:,15)./CONSTANTS(:,40));
    ALGEBRAIC(:,10) =  (( CONSTANTS(:,43).*(( STATES(:,16).*STATES(:,4))./( CONSTANTS(:,36).*CONSTANTS(:,35))) -  CONSTANTS(:,105).*(( STATES(:,15).*STATES(:,5))./( CONSTANTS(:,39).*CONSTANTS(:,33))))./ALGEBRAIC(:,7)).*((1.00000+ CONSTANTS(:,106).*ALGEBRAIC(:,9).*power(ALGEBRAIC(:,8)./ALGEBRAIC(:,7), 3.00000))./(1.00000+ ALGEBRAIC(:,9).*power(ALGEBRAIC(:,8)./ALGEBRAIC(:,7), 4.00000)));
    ALGEBRAIC(:,11) = ( CONSTANTS(:,51).*(STATES(:,5)./CONSTANTS(:,48)) -  CONSTANTS(:,107).*(( STATES(:,6).*STATES(:,7))./( CONSTANTS(:,49).*CONSTANTS(:,47))))./(1.00000+STATES(:,5)./CONSTANTS(:,48)+STATES(:,6)./CONSTANTS(:,49)+STATES(:,7)./CONSTANTS(:,47));
    ALGEBRAIC(:,12) = ( CONSTANTS(:,55).*(STATES(:,7)./CONSTANTS(:,52)) -  CONSTANTS(:,108).*(STATES(:,6)./CONSTANTS(:,53)))./(1.00000+STATES(:,6)./CONSTANTS(:,53)+STATES(:,7)./CONSTANTS(:,52));
    ALGEBRAIC(:,13) = 1.00000+STATES(:,7)./CONSTANTS(:,56)+STATES(:,21)./CONSTANTS(:,58)+STATES(:,14)./CONSTANTS(:,57)+( STATES(:,7).*STATES(:,21))./( CONSTANTS(:,56).*CONSTANTS(:,58))+( STATES(:,7).*STATES(:,21).*STATES(:,14))./( CONSTANTS(:,56).*CONSTANTS(:,58).*CONSTANTS(:,57))+STATES(:,8)./CONSTANTS(:,60)+STATES(:,20)./CONSTANTS(:,59)+( STATES(:,8).*STATES(:,20))./( CONSTANTS(:,60).*CONSTANTS(:,59));
    ALGEBRAIC(:,14) = ( CONSTANTS(:,62).*(( STATES(:,7).*STATES(:,21).*STATES(:,14))./( CONSTANTS(:,56).*CONSTANTS(:,58).*CONSTANTS(:,57))) -  CONSTANTS(:,109).*(( STATES(:,8).*STATES(:,20))./( CONSTANTS(:,60).*CONSTANTS(:,59))))./ALGEBRAIC(:,13);
    ALGEBRAIC(:,15) = ( CONSTANTS(:,110).*(( STATES(:,8).*STATES(:,15))./( CONSTANTS(:,66).*CONSTANTS(:,64))) -  CONSTANTS(:,68).*(( STATES(:,9).*STATES(:,16))./( CONSTANTS(:,63).*CONSTANTS(:,65))))./(1.00000+STATES(:,8)./CONSTANTS(:,66)+STATES(:,15)./CONSTANTS(:,64)+( STATES(:,8).*STATES(:,15))./( CONSTANTS(:,66).*CONSTANTS(:,64))+STATES(:,9)./CONSTANTS(:,63)+STATES(:,16)./CONSTANTS(:,65)+( STATES(:,9).*STATES(:,16))./( CONSTANTS(:,63).*CONSTANTS(:,65)));
    ALGEBRAIC(:,16) = ( CONSTANTS(:,72).*(STATES(:,9)./CONSTANTS(:,70)) -  CONSTANTS(:,111).*(STATES(:,10)./CONSTANTS(:,69)))./(1.00000+STATES(:,9)./CONSTANTS(:,70)+STATES(:,10)./CONSTANTS(:,69));
    ALGEBRAIC(:,17) = ( CONSTANTS(:,76).*(STATES(:,10)./CONSTANTS(:,74)) -  CONSTANTS(:,112).*(STATES(:,11)./CONSTANTS(:,73)))./(1.00000+STATES(:,10)./CONSTANTS(:,74)+STATES(:,11)./CONSTANTS(:,73));
    ALGEBRAIC(:,18) = ( CONSTANTS(:,82).*(( STATES(:,11).*STATES(:,15))./( CONSTANTS(:,80).*CONSTANTS(:,78))) -  CONSTANTS(:,113).*(( STATES(:,12).*STATES(:,16))./( CONSTANTS(:,77).*CONSTANTS(:,79))))./(1.00000+STATES(:,11)./CONSTANTS(:,80)+STATES(:,15)./CONSTANTS(:,78)+( STATES(:,11).*STATES(:,15))./( CONSTANTS(:,80).*CONSTANTS(:,78))+STATES(:,12)./CONSTANTS(:,77)+STATES(:,16)./CONSTANTS(:,79)+( STATES(:,12).*STATES(:,16))./( CONSTANTS(:,77).*CONSTANTS(:,79)));
    ALGEBRAIC(:,19) = ( CONSTANTS(:,88).*(( STATES(:,12).*STATES(:,20))./( CONSTANTS(:,86).*CONSTANTS(:,84))) -  CONSTANTS(:,114).*(( STATES(:,13).*STATES(:,21))./( CONSTANTS(:,83).*CONSTANTS(:,85))))./(1.00000+STATES(:,12)./CONSTANTS(:,86)+STATES(:,20)./CONSTANTS(:,84)+( STATES(:,12).*STATES(:,20))./( CONSTANTS(:,86).*CONSTANTS(:,84))+STATES(:,13)./CONSTANTS(:,83)+STATES(:,21)./CONSTANTS(:,85)+( STATES(:,13).*STATES(:,21))./( CONSTANTS(:,83).*CONSTANTS(:,85)));
    ALGEBRAIC(:,1) =  0.200000.*STATES(:,13);
    ALGEBRAIC(:,20) = ( CONSTANTS(:,115).*(( STATES(:,16).*STATES(:,19))./( CONSTANTS(:,93).*CONSTANTS(:,90))) -  CONSTANTS(:,95).*(( STATES(:,15).*STATES(:,18))./( CONSTANTS(:,89).*CONSTANTS(:,91))))./(1.00000+STATES(:,15)./CONSTANTS(:,89)+STATES(:,18)./CONSTANTS(:,92)+( STATES(:,15).*STATES(:,18))./( CONSTANTS(:,89).*CONSTANTS(:,91))+STATES(:,16)./CONSTANTS(:,93)+( STATES(:,16).*STATES(:,19))./( CONSTANTS(:,93).*CONSTANTS(:,90)));
    ALGEBRAIC(:,21) = ( CONSTANTS(:,100).*(( STATES(:,16).*STATES(:,17))./( CONSTANTS(:,98).*CONSTANTS(:,97))) -  CONSTANTS(:,116).*(power(STATES(:,15), 2.00000)./power(CONSTANTS(:,96), 2.00000)))./(1.00000+STATES(:,16)./CONSTANTS(:,98)+STATES(:,17)./CONSTANTS(:,97)+( STATES(:,16).*STATES(:,17))./( CONSTANTS(:,98).*CONSTANTS(:,97))+( 2.00000.*STATES(:,15))./CONSTANTS(:,96)+power(STATES(:,15), 2.00000)./power(CONSTANTS(:,96), 2.00000));
end

% Pad out or shorten strings to a set length
function strout = strpad(strin)
    req_length = 160;
    insize = size(strin,2);
    if insize > req_length
        strout = strin(1:req_length);
    else
        strout = [strin, blanks(req_length - insize)];
    end
end