Generated Code

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

The raw code is available.

C
C There are a total of 51 entries in the algebraic variable array.
C There are a total of 23 entries in each of the rate and state variable arrays.
C There are a total of 69 entries in the constant variable array.
C
C
C VOI is time in component environment (second).
C CONSTS(1) is R in component cell_parameters (millijoule_per_mole_kelvin).
C CONSTS(2) is T in component cell_parameters (kelvin).
C CONSTS(3) is F in component cell_parameters (coulomb_per_mole).
C CONSTS(4) is Cm in component cell_parameters (microF).
C CONSTS(5) is v_i in component cell_parameters (microlitre).
C CONSTS(6) is v_SR in component cell_parameters (microlitre).
C CONSTS(7) is Na_o in component cell_parameters (millimolar).
C CONSTS(8) is K_o in component cell_parameters (millimolar).
C CONSTS(9) is Ca_o in component cell_parameters (millimolar).
C STATES(1) is V in component membrane_potential (millivolt).
C ALGBRC(22) is i_Na in component fast_sodium_current (nanoA).
C ALGBRC(24) is i_K1 in component time_independent_potassium_current (nanoA).
C ALGBRC(25) is i_to in component transient_outward_current (nanoA).
C ALGBRC(23) is i_K in component time_dependent_rectifier_potassium_current (nanoA).
C ALGBRC(29) is i_Ca_L in component L_type_Ca_channel (nanoA).
C ALGBRC(33) is i_NaK in component sodium_potassium_pump (nanoA).
C ALGBRC(31) is i_NaCa in component sodium_calcium_exchanger (nanoA).
C ALGBRC(40) is i_b_Na in component sodium_background_current (nanoA).
C ALGBRC(37) is i_b_K in component potassium_background_current (nanoA).
C ALGBRC(36) is i_b_Ca in component calcium_background_current (nanoA).
C ALGBRC(1) is i_Stim in component membrane_potential (nanoA).
C CONSTS(10) is stim_start in component membrane_potential (second).
C CONSTS(11) is stim_end in component membrane_potential (second).
C CONSTS(12) is stim_period in component membrane_potential (second).
C CONSTS(13) is stim_duration in component membrane_potential (second).
C CONSTS(14) is stim_amplitude in component membrane_potential (nanoA).
C ALGBRC(9) is E_Na in component reversal_potentials (millivolt).
C ALGBRC(16) is E_K in component reversal_potentials (millivolt).
C ALGBRC(20) is E_Ca in component reversal_potentials (millivolt).
C ALGBRC(21) is E_mh in component reversal_potentials (millivolt).
C STATES(2) is K_i in component intracellular_potassium_concentration (millimolar).
C STATES(3) is Na_i in component intracellular_sodium_concentration (millimolar).
C STATES(4) is Ca_i in component intracellular_calcium_concentration (millimolar).
C CONSTS(15) is g_Na in component fast_sodium_current (microS).
C STATES(5) is m in component fast_sodium_current_m_gate (dimensionless).
C STATES(6) is h in component fast_sodium_current_h_gate (dimensionless).
C ALGBRC(10) is alpha_m in component fast_sodium_current_m_gate (per_second).
C ALGBRC(17) is beta_m in component fast_sodium_current_m_gate (per_second).
C CONSTS(16) is delta_m in component fast_sodium_current_m_gate (millivolt).
C ALGBRC(2) is E0_m in component fast_sodium_current_m_gate (millivolt).
C ALGBRC(3) is alpha_h in component fast_sodium_current_h_gate (per_second).
C ALGBRC(11) is beta_h in component fast_sodium_current_h_gate (per_second).
C CONSTS(17) is shift_h in component fast_sodium_current_h_gate (millivolt).
C CONSTS(18) is i_Kmax in component time_dependent_rectifier_potassium_current (nanoA).
C STATES(7) is x in component time_dependent_rectifier_potassium_current_x_gate (dimensionless).
C ALGBRC(4) is alpha_x in component time_dependent_rectifier_potassium_current_x_gate (per_second).
C ALGBRC(12) is beta_x in component time_dependent_rectifier_potassium_current_x_gate (per_second).
C CONSTS(19) is K_mk1 in component time_independent_potassium_current (millimolar).
C CONSTS(20) is g_K1 in component time_independent_potassium_current (microS).
C CONSTS(21) is g_to in component transient_outward_current (microS).
C STATES(8) is s in component transient_outward_current_s_gate (dimensionless).
C STATES(9) is r in component transient_outward_current_r_gate (dimensionless).
C ALGBRC(5) is alpha_s in component transient_outward_current_s_gate (per_second).
C ALGBRC(13) is beta_s in component transient_outward_current_s_gate (per_second).
C ALGBRC(28) is i_Ca_L_Na in component L_type_Ca_channel (nanoA).
C ALGBRC(27) is i_Ca_L_K in component L_type_Ca_channel (nanoA).
C ALGBRC(26) is i_Ca_L_Ca in component L_type_Ca_channel (nanoA).
C CONSTS(22) is P_Ca_L_Ca in component L_type_Ca_channel (nanoA_per_millimolar).
C STATES(10) is d in component L_type_Ca_channel_d_gate (dimensionless).
C STATES(11) is f in component L_type_Ca_channel_f_gate (dimensionless).
C ALGBRC(14) is alpha_d in component L_type_Ca_channel_d_gate (per_second).
C ALGBRC(18) is beta_d in component L_type_Ca_channel_d_gate (per_second).
C ALGBRC(6) is E0_d in component L_type_Ca_channel_d_gate (millivolt).
C CONSTS(23) is speed_d in component L_type_Ca_channel_d_gate (dimensionless).
C ALGBRC(15) is alpha_f in component L_type_Ca_channel_f_gate (per_second).
C ALGBRC(19) is beta_f in component L_type_Ca_channel_f_gate (per_second).
C CONSTS(24) is speed_f in component L_type_Ca_channel_f_gate (dimensionless).
C ALGBRC(7) is E0_f in component L_type_Ca_channel_f_gate (millivolt).
C CONSTS(25) is i_NaCa_max in component sodium_calcium_exchanger (nanoA_per_millimolar4).
C CONSTS(26) is gamma in component sodium_calcium_exchanger (dimensionless).
C CONSTS(27) is i_NaK_max in component sodium_potassium_pump (nanoA).
C CONSTS(28) is K_mK in component sodium_potassium_pump (millimolar).
C CONSTS(29) is K_mNa in component sodium_potassium_pump (millimolar).
C CONSTS(30) is g_b_Ca in component calcium_background_current (microS).
C CONSTS(31) is g_b_K in component potassium_background_current (microS).
C CONSTS(32) is g_b_Na in component sodium_background_current (microS).
C STATES(12) is F_CaMK in component CaMKII_factor (dimensionless).
C ALGBRC(8) is Inf_CaMK in component CaMKII_factor (dimensionless).
C CONSTS(33) is Tau_CaMK in component CaMKII_factor (second).
C STATES(13) is Cmdn_Ca in component calmodulin (millimolar).
C ALGBRC(42) is j_rel in component RyR (millimolar_per_second).
C ALGBRC(41) is K_rel in component RyR (per_second).
C ALGBRC(38) is F_rel in component RyR (dimensionless).
C STATES(14) is Ca_SR in component SR_calcium_concentration (millimolar).
C CONSTS(34) is K_rel_max in component RyR (per_second).
C STATES(15) is F_SRCa_RyR in component RyR (millimolar).
C CONSTS(35) is Tau_SRCa_RyR in component RyR (second).
C ALGBRC(30) is N_CaMK in component RyR (dimensionless).
C CONSTS(36) is gain_k1 in component RyR (dimensionless).
C CONSTS(37) is gain_k2 in component RyR (dimensionless).
C CONSTS(38) is gain_k3 in component RyR (dimensionless).
C CONSTS(39) is gain_k4 in component RyR (dimensionless).
C ALGBRC(32) is k_1 in component RyR (per_second).
C ALGBRC(34) is k_2 in component RyR (per_second).
C ALGBRC(35) is k_3 in component RyR (per_second).
C CONSTS(54) is k_4 in component RyR (per_second).
C STATES(16) is F_1 in component RyR (dimensionless).
C STATES(17) is F_2 in component RyR (dimensionless).
C ALGBRC(39) is F_3 in component RyR (dimensionless).
C CONSTS(40) is K_leak_rate in component RyR (per_second).
C ALGBRC(45) is j_up in component SERCA (millimolar_per_second).
C CONSTS(41) is V_max_f in component SERCA (millimolar_per_second).
C CONSTS(42) is V_max_r in component SERCA (millimolar_per_second).
C ALGBRC(43) is f_b in component SERCA (dimensionless).
C ALGBRC(44) is r_b in component SERCA (dimensionless).
C CONSTS(43) is Cmdn_tot in component calmodulin (millimolar).
C CONSTS(44) is alpha_cmdn in component calmodulin (per_millimolar_per_second).
C CONSTS(45) is beta_cmdn in component calmodulin (per_second).
C ALGBRC(46) is dCmdn_Ca_dtime in component calmodulin (millimolar_per_second).
C STATES(18) is Trpn_Ca in component troponin (millimolar).
C CONSTS(46) is Trpn_tot in component troponin (millimolar).
C CONSTS(47) is alpha_trpn in component troponin (per_millimolar_per_second).
C CONSTS(48) is beta_trpn in component troponin (per_second).
C ALGBRC(49) is Force_norm in component Force (dimensionless).
C ALGBRC(50) is dTrpn_Ca_dtime in component troponin (millimolar_per_second).
C ALGBRC(51) is Force in component Force (N_per_mm2).
C CONSTS(49) is zeta in component Force (N_per_mm2).
C CONSTS(69) is Force_max in component Force (dimensionless).
C CONSTS(55) is phi_SL in component Force (dimensionless).
C CONSTS(66) is P_1_max in component Force (dimensionless).
C CONSTS(67) is P_2_max in component Force (dimensionless).
C CONSTS(68) is P_3_max in component Force (dimensionless).
C CONSTS(65) is sigma_paths in component Force (dimensionless).
C STATES(19) is N_0 in component Force (dimensionless).
C STATES(20) is P_0 in component Force (dimensionless).
C STATES(21) is P_1 in component Force (dimensionless).
C STATES(22) is P_2 in component Force (dimensionless).
C STATES(23) is P_3 in component Force (dimensionless).
C ALGBRC(48) is N_1 in component Force (dimensionless).
C ALGBRC(47) is alpha_tm in component Force (per_second).
C CONSTS(50) is beta_tm in component Force (per_second).
C CONSTS(58) is K_tm in component Force (dimensionless).
C CONSTS(59) is N_tm in component Force (dimensionless).
C CONSTS(51) is SL in component Force (micrometre).
C CONSTS(56) is SL_norm in component Force (dimensionless).
C CONSTS(57) is f_01 in component Force (per_second).
C CONSTS(60) is f_12 in component Force (per_second).
C CONSTS(64) is f_23 in component Force (per_second).
C CONSTS(61) is g_01 in component Force (per_second).
C CONSTS(62) is g_12 in component Force (per_second).
C CONSTS(63) is g_23 in component Force (per_second).
C CONSTS(52) is f_XB in component Force (per_second).
C CONSTS(53) is g_XB in component Force (per_second).
C RATES(1) is d/dt V in component membrane_potential (millivolt).
C RATES(5) is d/dt m in component fast_sodium_current_m_gate (dimensionless).
C RATES(6) is d/dt h in component fast_sodium_current_h_gate (dimensionless).
C RATES(7) is d/dt x in component time_dependent_rectifier_potassium_current_x_gate (dimensionless).
C RATES(8) is d/dt s in component transient_outward_current_s_gate (dimensionless).
C RATES(9) is d/dt r in component transient_outward_current_r_gate (dimensionless).
C RATES(10) is d/dt d in component L_type_Ca_channel_d_gate (dimensionless).
C RATES(11) is d/dt f in component L_type_Ca_channel_f_gate (dimensionless).
C RATES(12) is d/dt F_CaMK in component CaMKII_factor (dimensionless).
C RATES(16) is d/dt F_1 in component RyR (dimensionless).
C RATES(17) is d/dt F_2 in component RyR (dimensionless).
C RATES(15) is d/dt F_SRCa_RyR in component RyR (millimolar).
C RATES(13) is d/dt Cmdn_Ca in component calmodulin (millimolar).
C RATES(18) is d/dt Trpn_Ca in component troponin (millimolar).
C RATES(4) is d/dt Ca_i in component intracellular_calcium_concentration (millimolar).
C RATES(14) is d/dt Ca_SR in component SR_calcium_concentration (millimolar).
C RATES(3) is d/dt Na_i in component intracellular_sodium_concentration (millimolar).
C RATES(2) is d/dt K_i in component intracellular_potassium_concentration (millimolar).
C RATES(19) is d/dt N_0 in component Force (dimensionless).
C RATES(20) is d/dt P_0 in component Force (dimensionless).
C RATES(21) is d/dt P_1 in component Force (dimensionless).
C RATES(22) is d/dt P_2 in component Force (dimensionless).
C RATES(23) is d/dt P_3 in component Force (dimensionless).
C
      SUBROUTINE initConsts(CONSTS, RATES, STATES)
      REAL CONSTS(*), RATES(*), STATES(*)
      CONSTS(1) = 8314.472
      CONSTS(2) = 310
      CONSTS(3) = 96485.3415
      CONSTS(4) = 9.5e-5
      CONSTS(5) = 1.6404e-5
      CONSTS(6) = 3.3477e-6
      CONSTS(7) = 140
      CONSTS(8) = 4
      CONSTS(9) = 2
      STATES(1) = -92.849333
      CONSTS(10) = 0
      CONSTS(11) = 1000
      CONSTS(12) = 0.5
      CONSTS(13) = 0.002
      CONSTS(14) = -4
      STATES(2) = 138.22
      STATES(3) = 5.8041
      STATES(4) = 9.91e-6
      CONSTS(15) = 2.5
      STATES(5) = 0.0013809
      STATES(6) = 0.99569
      CONSTS(16) = 1e-5
      CONSTS(17) = 0
      CONSTS(18) = 1
      STATES(7) = 5.1127e-2
      CONSTS(19) = 10
      CONSTS(20) = 1
      CONSTS(21) = 0.005
      STATES(8) = 0.95854
      STATES(9) = 1.5185e-8
      CONSTS(22) = 0.25
      STATES(10) = 1.7908e-8
      STATES(11) = 1
      CONSTS(23) = 3
      CONSTS(24) = 0.5
      CONSTS(25) = 0.0005
      CONSTS(26) = 0.5
      CONSTS(27) = 1.36
      CONSTS(28) = 1
      CONSTS(29) = 21.7
      CONSTS(30) = 0.00025
      CONSTS(31) = 0.0006
      CONSTS(32) = 0.0006
      STATES(12) = 1.028
      CONSTS(33) = 0.8
      STATES(13) = 3.9636e-6
      STATES(14) = 0.24886
      CONSTS(34) = 500
      STATES(15) = 0.25089
      CONSTS(35) = 0.05
      CONSTS(36) = 1
      CONSTS(37) = 1
      CONSTS(38) = 1
      CONSTS(39) = 1
      STATES(16) = 0.5268
      STATES(17) = 8.7508e-6
      CONSTS(40) = 0
      CONSTS(41) = 0.292
      CONSTS(42) = 0.391
      CONSTS(43) = 0.02
      CONSTS(44) = 10000
      CONSTS(45) = 500
      STATES(18) = 2.7661e-4
      CONSTS(46) = 0.07
      CONSTS(47) = 80000
      CONSTS(48) = 200
      CONSTS(49) = 0.1
      STATES(19) = 0.99917
      STATES(20) = 9.8593e-5
      STATES(21) = 1.3331e-4
      STATES(22) = 2.3505e-4
      STATES(23) = 1.5349e-4
      CONSTS(50) = 40
      CONSTS(51) = 2.15
      CONSTS(52) = 10
      CONSTS(53) = 30
      CONSTS(54) =  CONSTS(39)*1.80000
      CONSTS(55) = TERNRY(CONSTS(51).GE.1.70000.AND.CONSTS(51).LE.2.00000, (CONSTS(51) - 0.600000)/1.40000, TERNRY(CONSTS(51).GT.2.00000.AND.CONSTS(51).LE.2.20000, 1.00000, TERNRY(CONSTS(51).GT.2.20000.AND.CONSTS(51).LE.2.30000, (3.60000 - CONSTS(51))/1.40000, 0.0/0.0)
      CONSTS(56) = (CONSTS(51) - 1.70000)/0.700000
      CONSTS(57) =  3.00000*CONSTS(52)
      CONSTS(58) = 1.00000/(1.00000+(CONSTS(48)/CONSTS(47))/(0.00170000 -  0.000900000*CONSTS(56)))
      CONSTS(59) = 3.50000+ 2.50000*CONSTS(56)
      CONSTS(60) =  10.0000*CONSTS(52)
      CONSTS(61) =  CONSTS(53)*(2.00000 - CONSTS(56))
      CONSTS(62) =  2.00000*CONSTS(53)*(2.00000 - CONSTS(56))
      CONSTS(63) =  3.00000*CONSTS(53)*(2.00000 - CONSTS(56))
      CONSTS(64) =  7.00000*CONSTS(52)
      CONSTS(65) =  1.00000*CONSTS(53)*2.00000*CONSTS(53)*3.00000*CONSTS(53)+ 1.00000*CONSTS(57)*2.00000*CONSTS(53)*3.00000*CONSTS(53)+ 1.00000*CONSTS(57)*1.00000*CONSTS(60)*3.00000*CONSTS(53)+ 1.00000*CONSTS(57)*1.00000*CONSTS(60)*1.00000*CONSTS(64)
      CONSTS(66) = ( 1.00000*CONSTS(57)*2.00000*CONSTS(53)*3.00000*CONSTS(53))/CONSTS(65)
      CONSTS(67) = ( 1.00000*CONSTS(57)*1.00000*CONSTS(60)*3.00000*CONSTS(53))/CONSTS(65)
      CONSTS(68) = ( 1.00000*CONSTS(57)*1.00000*CONSTS(60)*1.00000*CONSTS(64))/CONSTS(65)
      CONSTS(69) = CONSTS(66)+ 2.00000*CONSTS(67)+ 3.00000*CONSTS(68)
      RETURN
      END
      SUBROUTINE computeRates(VOI, CONSTS,  RATES, STATES, ALGBRC)
      REAL VOI, CONSTS(*), RATES(*), STATES(*), ALGBRC(*)
      RATES(9) =  333.000*(1.00000/(1.00000+EXP(- (STATES(1)+4.00000)/5.00000)) - STATES(9))
      RATES(15) = (STATES(14) - STATES(15))/CONSTS(35)
      RATES(13) =  CONSTS(44)*(CONSTS(43) - STATES(13))*STATES(4) -  CONSTS(45)*STATES(13)
      RATES(22) =  - (CONSTS(64)+CONSTS(62))*STATES(22)+ CONSTS(60)*STATES(21)+ CONSTS(63)*STATES(23)
      RATES(23) =  - CONSTS(63)*STATES(23)+ CONSTS(64)*STATES(22)
      ALGBRC(8) = STATES(13)/5.00000e-05
      RATES(12) = (ALGBRC(8) - STATES(12))/CONSTS(33)
      ALGBRC(3) =  20.0000*EXP( - 0.125000*((STATES(1)+75.0000) - CONSTS(17)))
      ALGBRC(11) = 2000.00/(1.00000+ 320.000*EXP( - 0.100000*((STATES(1)+75.0000) - CONSTS(17))))
      RATES(6) =  ALGBRC(3)*(1.00000 - STATES(6)) -  ALGBRC(11)*STATES(6)
      ALGBRC(4) = ( 0.500000*EXP( 0.0826000*(STATES(1)+50.0000)))/(1.00000+EXP( 0.0570000*(STATES(1)+50.0000)))
      ALGBRC(12) = ( 1.30000*EXP( - 0.0600000*(STATES(1)+20.0000)))/(1.00000+EXP( - 0.0400000*(STATES(1)+20.0000)))
      RATES(7) =  ALGBRC(4)*(1.00000 - STATES(7)) -  ALGBRC(12)*STATES(7)
      ALGBRC(5) =  0.0330000*EXP(- STATES(1)/17.0000)
      ALGBRC(13) = 33.0000/(1.00000+EXP( - 0.125000*(STATES(1)+10.0000)))
      RATES(8) =  ALGBRC(5)*(1.00000 - STATES(8)) -  ALGBRC(13)*STATES(8)
      ALGBRC(2) = STATES(1)+41.0000
      ALGBRC(10) = TERNRY(ABS(ALGBRC(2)).LT.CONSTS(16), 2000.00, ( 200.000*ALGBRC(2))/(1.00000 - EXP( - 0.100000*ALGBRC(2))))
      ALGBRC(17) =  8000.00*EXP( - 0.0560000*(STATES(1)+66.0000))
      RATES(5) =  ALGBRC(10)*(1.00000 - STATES(5)) -  ALGBRC(17)*STATES(5)
      ALGBRC(6) = (STATES(1)+24.0000) - 5.00000
      ALGBRC(14) = TERNRY(ABS(ALGBRC(6)).LT.1.00000e-05,  CONSTS(23)*120.000, ( CONSTS(23)*30.0000*ALGBRC(6))/(1.00000 - EXP(- ALGBRC(6)/4.00000)))
      ALGBRC(18) = TERNRY(ABS(ALGBRC(6)).LT.1.00000e-05,  CONSTS(23)*120.000, ( CONSTS(23)*- 12.0000*ALGBRC(6))/(1.00000 - EXP(ALGBRC(6)/10.0000)))
      RATES(10) =  ALGBRC(14)*(1.00000 - STATES(10)) -  ALGBRC(18)*STATES(10)
      ALGBRC(7) = STATES(1)+34.0000
      ALGBRC(15) = TERNRY(ABS(ALGBRC(7)).LT.1.00000e-05,  CONSTS(24)*25.0000, ( CONSTS(24)*6.25000*ALGBRC(7))/(- 1.00000+EXP(ALGBRC(7)/4.00000)))
      ALGBRC(19) = ( CONSTS(24)*50.0000)/(1.00000+EXP(- ALGBRC(7)/4.00000))
      RATES(11) =  ALGBRC(15)*(1.00000 - STATES(11)) -  ALGBRC(19)*STATES(11)
      ALGBRC(28) =  (( 0.0100000*STATES(10)*STATES(11)*CONSTS(22)*(STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2)*(1.00000 - EXP(( - (STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))))*( STATES(3)*EXP(( 50.0000*CONSTS(3))/( CONSTS(1)*CONSTS(2))) -  CONSTS(7)*EXP(( - (STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))
      ALGBRC(27) =  (( 0.00200000*STATES(10)*STATES(11)*CONSTS(22)*(STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2)*(1.00000 - EXP(( - (STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))))*( STATES(2)*EXP(( 50.0000*CONSTS(3))/( CONSTS(1)*CONSTS(2))) -  CONSTS(8)*EXP(( - (STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))
      ALGBRC(26) =  (( 4.00000*STATES(10)*STATES(11)*CONSTS(22)*(STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2)*(1.00000 - EXP(( - 2.00000*(STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))))*( STATES(4)*EXP(( 100.000*CONSTS(3))/( CONSTS(1)*CONSTS(2))) -  CONSTS(9)*EXP(( - 2.00000*(STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))
      ALGBRC(29) = ALGBRC(26)+ALGBRC(27)+ALGBRC(28)
      ALGBRC(32) =  CONSTS(36)*( 3.06250e+07*STATES(4) ** 2.00000 -  245.000*ALGBRC(29))
      ALGBRC(34) = ( CONSTS(37)*450.000)/(1.00000+0.360000/STATES(14))
      RATES(17) =  ALGBRC(32)*STATES(16) -  ALGBRC(34)*STATES(17)
      ALGBRC(30) = STATES(12)/0.700000 ** 2.00000
      ALGBRC(35) =  CONSTS(38)*1.88500*STATES(15)/0.220000 ** ALGBRC(30)
      ALGBRC(39) = 1.00000 - (STATES(16)+STATES(17))
      RATES(16) = ( ALGBRC(35)*ALGBRC(39) -  CONSTS(54)*STATES(16)) -  ALGBRC(32)*STATES(16)
      ALGBRC(16) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(8)/STATES(2))
      ALGBRC(24) = ( (( CONSTS(20)*CONSTS(8))/(CONSTS(8)+CONSTS(19)))*(STATES(1) - ALGBRC(16)))/(1.00000+EXP(( 2.00000*CONSTS(3)*((STATES(1) - ALGBRC(16)) - 10.0000))/( CONSTS(1)*CONSTS(2))))
      ALGBRC(25) =  CONSTS(21)*STATES(8)*STATES(9)*(STATES(1) - ALGBRC(16))
      ALGBRC(23) = ( CONSTS(18)*STATES(7)*(STATES(2) -  CONSTS(8)*EXP(( - STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))))/140.000
      ALGBRC(33) = ( (( (( CONSTS(27)*CONSTS(8))/(CONSTS(28)+CONSTS(8)))*STATES(3))/(CONSTS(29)+STATES(3)))*1.00000)/(1.00000+ 0.124500*EXP(( - 0.100000*STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))+ 0.0353000*EXP(( - STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))
      ALGBRC(37) =  CONSTS(31)*(STATES(1) - ALGBRC(16))
      RATES(2) = - ((ALGBRC(24)+ALGBRC(23)+ALGBRC(25)+ALGBRC(37)+ALGBRC(27)) -  2.00000*ALGBRC(33))/( CONSTS(5)*CONSTS(3))
      ALGBRC(21) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log((CONSTS(7)+ 0.120000*CONSTS(8))/(STATES(3)+ 0.120000*STATES(2)))
      ALGBRC(22) =  CONSTS(15)*STATES(5) ** 3.00000*STATES(6)*(STATES(1) - ALGBRC(21))
      ALGBRC(31) = ( CONSTS(25)*( EXP(( CONSTS(26)*STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))*STATES(3) ** 3.00000*CONSTS(9) -  EXP(( (CONSTS(26) - 1.00000)*STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))*CONSTS(7) ** 3.00000*STATES(4)))/(1.00000+STATES(4)/0.00690000)
      ALGBRC(9) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(7)/STATES(3))
      ALGBRC(40) =  CONSTS(32)*(STATES(1) - ALGBRC(9))
      ALGBRC(20) =  (( 0.500000*CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(9)/STATES(4))
      ALGBRC(36) =  CONSTS(30)*(STATES(1) - ALGBRC(20))
      ALGBRC(1) = TERNRY(VOI.GE.CONSTS(10).AND.VOI.LE.CONSTS(11).AND.(VOI - CONSTS(10)) -  INT((VOI - CONSTS(10))/CONSTS(12))*CONSTS(12).LE.CONSTS(13), CONSTS(14), 0.00000)
      RATES(1) =  (- 1.00000/CONSTS(4))*(ALGBRC(22)+ALGBRC(40)+ALGBRC(24)+ALGBRC(23)+ALGBRC(25)+ALGBRC(37)+ALGBRC(29)+ALGBRC(36)+ALGBRC(31)+ALGBRC(33)+ALGBRC(1))
      RATES(3) = - (ALGBRC(22)+ALGBRC(40)+ALGBRC(28)+ 3.00000*ALGBRC(31)+ 3.00000*ALGBRC(33))/( CONSTS(5)*CONSTS(3))
      ALGBRC(41) = ( CONSTS(34)*STATES(15))/(STATES(15)+0.200000)
      ALGBRC(38) = STATES(17)/(STATES(17)+0.250000) ** 2.00000
      ALGBRC(42) =  ( ALGBRC(41)*ALGBRC(38)+CONSTS(40))*(STATES(14) - STATES(4))
      ALGBRC(43) = STATES(4)/0.000240000 ** 2.00000
      ALGBRC(44) = STATES(14)/1.64000 ** 2.00000
      ALGBRC(45) = ( STATES(12)*CONSTS(41)*ALGBRC(43) -  CONSTS(42)*ALGBRC(44))/(1.00000+ALGBRC(43)+ALGBRC(44))
      RATES(14) = ( ALGBRC(45)*CONSTS(5))/CONSTS(6) - ALGBRC(42)
      ALGBRC(47) =  CONSTS(50)*STATES(18)/( CONSTS(46)*CONSTS(58)) ** CONSTS(59)
      RATES(20) =  - (CONSTS(50)+CONSTS(57))*STATES(20)+ ALGBRC(47)*STATES(19)+ CONSTS(61)*STATES(21)
      ALGBRC(48) = 1.00000 - (STATES(19)+STATES(20)+STATES(21)+STATES(22)+STATES(23))
      RATES(19) = ( CONSTS(50)*STATES(20) -  ALGBRC(47)*STATES(19))+ CONSTS(61)*ALGBRC(48)
      RATES(21) =  - (CONSTS(50)+CONSTS(60)+CONSTS(61))*STATES(21)+ ALGBRC(47)*ALGBRC(48)+ CONSTS(57)*STATES(20)+ CONSTS(62)*STATES(22)
      ALGBRC(49) = ( CONSTS(55)*(STATES(21)+ALGBRC(48)+ 2.00000*STATES(22)+ 3.00000*STATES(23)))/CONSTS(69)
      RATES(18) =  CONSTS(47)*(CONSTS(46) - STATES(18))*STATES(4) -  (( CONSTS(48)*(1.00000+ 2.00000*(1.00000 - ALGBRC(49))))/3.00000)*STATES(18)
      ALGBRC(46) =  CONSTS(44)*(CONSTS(43) - STATES(13))*STATES(4) -  CONSTS(45)*STATES(13)
      ALGBRC(50) =  CONSTS(47)*(CONSTS(46) - STATES(18))*STATES(4) -  (( CONSTS(48)*(1.00000+ 2.00000*(1.00000 - ALGBRC(49))))/3.00000)*STATES(18)
      RATES(4) = (((- ((ALGBRC(26)+ALGBRC(36)) -  2.00000*ALGBRC(31))/( 2.00000*CONSTS(5)*CONSTS(3)) - ALGBRC(45))+( ALGBRC(42)*CONSTS(6))/CONSTS(5)) - ALGBRC(46)) - ALGBRC(50)
      RETURN
      END
      SUBROUTINE computeVariables(VOI, CONSTS, RATES, STATES, ALGBRC)
      REAL VOI, CONSTS(*), RATES(*), STATES(*), ALGBRC(*)
      ALGBRC(8) = STATES(13)/5.00000e-05
      ALGBRC(3) =  20.0000*EXP( - 0.125000*((STATES(1)+75.0000) - CONSTS(17)))
      ALGBRC(11) = 2000.00/(1.00000+ 320.000*EXP( - 0.100000*((STATES(1)+75.0000) - CONSTS(17))))
      ALGBRC(4) = ( 0.500000*EXP( 0.0826000*(STATES(1)+50.0000)))/(1.00000+EXP( 0.0570000*(STATES(1)+50.0000)))
      ALGBRC(12) = ( 1.30000*EXP( - 0.0600000*(STATES(1)+20.0000)))/(1.00000+EXP( - 0.0400000*(STATES(1)+20.0000)))
      ALGBRC(5) =  0.0330000*EXP(- STATES(1)/17.0000)
      ALGBRC(13) = 33.0000/(1.00000+EXP( - 0.125000*(STATES(1)+10.0000)))
      ALGBRC(2) = STATES(1)+41.0000
      ALGBRC(10) = TERNRY(ABS(ALGBRC(2)).LT.CONSTS(16), 2000.00, ( 200.000*ALGBRC(2))/(1.00000 - EXP( - 0.100000*ALGBRC(2))))
      ALGBRC(17) =  8000.00*EXP( - 0.0560000*(STATES(1)+66.0000))
      ALGBRC(6) = (STATES(1)+24.0000) - 5.00000
      ALGBRC(14) = TERNRY(ABS(ALGBRC(6)).LT.1.00000e-05,  CONSTS(23)*120.000, ( CONSTS(23)*30.0000*ALGBRC(6))/(1.00000 - EXP(- ALGBRC(6)/4.00000)))
      ALGBRC(18) = TERNRY(ABS(ALGBRC(6)).LT.1.00000e-05,  CONSTS(23)*120.000, ( CONSTS(23)*- 12.0000*ALGBRC(6))/(1.00000 - EXP(ALGBRC(6)/10.0000)))
      ALGBRC(7) = STATES(1)+34.0000
      ALGBRC(15) = TERNRY(ABS(ALGBRC(7)).LT.1.00000e-05,  CONSTS(24)*25.0000, ( CONSTS(24)*6.25000*ALGBRC(7))/(- 1.00000+EXP(ALGBRC(7)/4.00000)))
      ALGBRC(19) = ( CONSTS(24)*50.0000)/(1.00000+EXP(- ALGBRC(7)/4.00000))
      ALGBRC(28) =  (( 0.0100000*STATES(10)*STATES(11)*CONSTS(22)*(STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2)*(1.00000 - EXP(( - (STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))))*( STATES(3)*EXP(( 50.0000*CONSTS(3))/( CONSTS(1)*CONSTS(2))) -  CONSTS(7)*EXP(( - (STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))
      ALGBRC(27) =  (( 0.00200000*STATES(10)*STATES(11)*CONSTS(22)*(STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2)*(1.00000 - EXP(( - (STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))))*( STATES(2)*EXP(( 50.0000*CONSTS(3))/( CONSTS(1)*CONSTS(2))) -  CONSTS(8)*EXP(( - (STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))
      ALGBRC(26) =  (( 4.00000*STATES(10)*STATES(11)*CONSTS(22)*(STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2)*(1.00000 - EXP(( - 2.00000*(STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))))*( STATES(4)*EXP(( 100.000*CONSTS(3))/( CONSTS(1)*CONSTS(2))) -  CONSTS(9)*EXP(( - 2.00000*(STATES(1) - 50.0000)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))
      ALGBRC(29) = ALGBRC(26)+ALGBRC(27)+ALGBRC(28)
      ALGBRC(32) =  CONSTS(36)*( 3.06250e+07*STATES(4) ** 2.00000 -  245.000*ALGBRC(29))
      ALGBRC(34) = ( CONSTS(37)*450.000)/(1.00000+0.360000/STATES(14))
      ALGBRC(30) = STATES(12)/0.700000 ** 2.00000
      ALGBRC(35) =  CONSTS(38)*1.88500*STATES(15)/0.220000 ** ALGBRC(30)
      ALGBRC(39) = 1.00000 - (STATES(16)+STATES(17))
      ALGBRC(16) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(8)/STATES(2))
      ALGBRC(24) = ( (( CONSTS(20)*CONSTS(8))/(CONSTS(8)+CONSTS(19)))*(STATES(1) - ALGBRC(16)))/(1.00000+EXP(( 2.00000*CONSTS(3)*((STATES(1) - ALGBRC(16)) - 10.0000))/( CONSTS(1)*CONSTS(2))))
      ALGBRC(25) =  CONSTS(21)*STATES(8)*STATES(9)*(STATES(1) - ALGBRC(16))
      ALGBRC(23) = ( CONSTS(18)*STATES(7)*(STATES(2) -  CONSTS(8)*EXP(( - STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))))/140.000
      ALGBRC(33) = ( (( (( CONSTS(27)*CONSTS(8))/(CONSTS(28)+CONSTS(8)))*STATES(3))/(CONSTS(29)+STATES(3)))*1.00000)/(1.00000+ 0.124500*EXP(( - 0.100000*STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))+ 0.0353000*EXP(( - STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))))
      ALGBRC(37) =  CONSTS(31)*(STATES(1) - ALGBRC(16))
      ALGBRC(21) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log((CONSTS(7)+ 0.120000*CONSTS(8))/(STATES(3)+ 0.120000*STATES(2)))
      ALGBRC(22) =  CONSTS(15)*STATES(5) ** 3.00000*STATES(6)*(STATES(1) - ALGBRC(21))
      ALGBRC(31) = ( CONSTS(25)*( EXP(( CONSTS(26)*STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))*STATES(3) ** 3.00000*CONSTS(9) -  EXP(( (CONSTS(26) - 1.00000)*STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))*CONSTS(7) ** 3.00000*STATES(4)))/(1.00000+STATES(4)/0.00690000)
      ALGBRC(9) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(7)/STATES(3))
      ALGBRC(40) =  CONSTS(32)*(STATES(1) - ALGBRC(9))
      ALGBRC(20) =  (( 0.500000*CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(9)/STATES(4))
      ALGBRC(36) =  CONSTS(30)*(STATES(1) - ALGBRC(20))
      ALGBRC(1) = TERNRY(VOI.GE.CONSTS(10).AND.VOI.LE.CONSTS(11).AND.(VOI - CONSTS(10)) -  INT((VOI - CONSTS(10))/CONSTS(12))*CONSTS(12).LE.CONSTS(13), CONSTS(14), 0.00000)
      ALGBRC(41) = ( CONSTS(34)*STATES(15))/(STATES(15)+0.200000)
      ALGBRC(38) = STATES(17)/(STATES(17)+0.250000) ** 2.00000
      ALGBRC(42) =  ( ALGBRC(41)*ALGBRC(38)+CONSTS(40))*(STATES(14) - STATES(4))
      ALGBRC(43) = STATES(4)/0.000240000 ** 2.00000
      ALGBRC(44) = STATES(14)/1.64000 ** 2.00000
      ALGBRC(45) = ( STATES(12)*CONSTS(41)*ALGBRC(43) -  CONSTS(42)*ALGBRC(44))/(1.00000+ALGBRC(43)+ALGBRC(44))
      ALGBRC(47) =  CONSTS(50)*STATES(18)/( CONSTS(46)*CONSTS(58)) ** CONSTS(59)
      ALGBRC(48) = 1.00000 - (STATES(19)+STATES(20)+STATES(21)+STATES(22)+STATES(23))
      ALGBRC(49) = ( CONSTS(55)*(STATES(21)+ALGBRC(48)+ 2.00000*STATES(22)+ 3.00000*STATES(23)))/CONSTS(69)
      ALGBRC(46) =  CONSTS(44)*(CONSTS(43) - STATES(13))*STATES(4) -  CONSTS(45)*STATES(13)
      ALGBRC(50) =  CONSTS(47)*(CONSTS(46) - STATES(18))*STATES(4) -  (( CONSTS(48)*(1.00000+ 2.00000*(1.00000 - ALGBRC(49))))/3.00000)*STATES(18)
      ALGBRC(51) =  CONSTS(49)*ALGBRC(49)
      RETURN
      END
      REAL FUNCTION TERNRY(TEST, VALA, VALB)
      LOGICAL TEST
      REAL VALA, VALB
      IF (TEST) THEN
        TERNRY = VALA
      ELSE
        TERNRY = VALB
      ENDIF
      RETURN
      END