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 78 entries in the algebraic variable array.
C There are a total of 28 entries in each of the rate and state variable arrays.
C There are a total of 52 entries in the constant variable array.
C
C
C VOI is time in component environment (second).
C STATES(1) is V in component membrane (millivolt).
C CONSTS(1) is R in component membrane (millijoule_per_mole_kelvin).
C CONSTS(2) is T in component membrane (kelvin).
C CONSTS(3) is F in component membrane (coulomb_per_mole).
C CONSTS(4) is Cm in component membrane (nanoF).
C ALGBRC(31) is i_Na in component sodium_current (picoA).
C ALGBRC(53) is i_Ca_L in component L_type_Ca_channel (picoA).
C ALGBRC(58) is i_Ca_T in component T_type_Ca_channel (picoA).
C ALGBRC(62) is i_to in component Ca_independent_transient_outward_K_current (picoA).
C ALGBRC(65) is i_K1 in component inward_rectifier (picoA).
C ALGBRC(64) is i_Kr in component delayed_rectifier_K_current (picoA).
C ALGBRC(63) is i_Ks in component delayed_rectifier_K_current (picoA).
C ALGBRC(67) is i_B_Na in component background_currents (picoA).
C ALGBRC(68) is i_B_Ca in component background_currents (picoA).
C ALGBRC(69) is i_B_Cl in component background_currents (picoA).
C ALGBRC(70) is i_p in component sodium_potassium_pump (picoA).
C ALGBRC(71) is i_CaP in component sarcolemmal_calcium_pump_current (picoA).
C ALGBRC(72) is i_NaCa in component Na_Ca_ion_exchanger_current (picoA).
C ALGBRC(1) is i_Stim in component membrane (picoA).
C CONSTS(5) is stim_start in component membrane (second).
C CONSTS(6) is stim_end in component membrane (second).
C CONSTS(7) is stim_period in component membrane (second).
C CONSTS(8) is stim_duration in component membrane (second).
C CONSTS(9) is stim_amplitude in component membrane (picoA).
C ALGBRC(16) is E_Na in component sodium_current (millivolt).
C CONSTS(10) is P_Na in component sodium_current (nanolitre_per_second).
C CONSTS(11) is Na_c in component cleft_space_ion_concentrations (millimolar).
C STATES(2) is Na_i in component intracellular_ion_concentrations (millimolar).
C STATES(3) is m in component sodium_current_m_gate (dimensionless).
C STATES(4) is h1 in component sodium_current_h1_gate (dimensionless).
C STATES(5) is h2 in component sodium_current_h2_gate (dimensionless).
C ALGBRC(2) is E0_m in component sodium_current_m_gate (millivolt).
C ALGBRC(17) is alpha_m in component sodium_current_m_gate (per_second).
C ALGBRC(32) is beta_m in component sodium_current_m_gate (per_second).
C ALGBRC(3) is alpha_h in component sodium_current_h1_gate (per_second).
C ALGBRC(18) is beta_h in component sodium_current_h1_gate (per_second).
C ALGBRC(33) is h_infinity in component sodium_current_h1_gate (dimensionless).
C ALGBRC(43) is tau_h1 in component sodium_current_h1_gate (second).
C ALGBRC(44) is tau_h2 in component sodium_current_h2_gate (second).
C CONSTS(12) is g_Ca_L in component L_type_Ca_channel (nanoS).
C CONSTS(13) is E_Ca_app in component L_type_Ca_channel (millivolt).
C ALGBRC(42) is d_prime in component L_type_Ca_channel (dimensionless).
C STATES(6) is d_L in component L_type_Ca_channel_d_L_gate (dimensionless).
C STATES(7) is f_L in component L_type_Ca_channel_f_L_gate (dimensionless).
C ALGBRC(4) is E0_alpha_d_L in component L_type_Ca_channel_d_L_gate (millivolt).
C ALGBRC(19) is E0_beta_d_L in component L_type_Ca_channel_d_L_gate (millivolt).
C ALGBRC(34) is alpha_d_L in component L_type_Ca_channel_d_L_gate (per_second).
C ALGBRC(45) is beta_d_L in component L_type_Ca_channel_d_L_gate (per_second).
C ALGBRC(54) is d_L_infinity in component L_type_Ca_channel_d_L_gate (dimensionless).
C ALGBRC(59) is tau_d_L in component L_type_Ca_channel_d_L_gate (second).
C ALGBRC(5) is E0_f_L in component L_type_Ca_channel_f_L_gate (millivolt).
C ALGBRC(20) is alpha_f_L in component L_type_Ca_channel_f_L_gate (per_second).
C ALGBRC(35) is beta_f_L in component L_type_Ca_channel_f_L_gate (per_second).
C ALGBRC(46) is f_L_infinity in component L_type_Ca_channel_f_L_gate (dimensionless).
C ALGBRC(55) is x_f in component L_type_Ca_channel_f_L_gate (dimensionless).
C ALGBRC(60) is tau_f_L in component L_type_Ca_channel_f_L_gate (second).
C CONSTS(14) is g_Ca_T in component T_type_Ca_channel (nanoS).
C CONSTS(15) is E_Ca_T in component T_type_Ca_channel (millivolt).
C STATES(8) is d_T in component T_type_Ca_channel_d_T_gate (dimensionless).
C STATES(9) is f_T in component T_type_Ca_channel_f_T_gate (dimensionless).
C ALGBRC(6) is E0_d_T in component T_type_Ca_channel_d_T_gate (millivolt).
C ALGBRC(21) is alpha_d_T in component T_type_Ca_channel_d_T_gate (per_second).
C ALGBRC(36) is beta_d_T in component T_type_Ca_channel_d_T_gate (per_second).
C ALGBRC(47) is d_T_infinity in component T_type_Ca_channel_d_T_gate (dimensionless).
C ALGBRC(56) is tau_d_T in component T_type_Ca_channel_d_T_gate (second).
C ALGBRC(7) is E0_f_T in component T_type_Ca_channel_f_T_gate (millivolt).
C ALGBRC(22) is alpha_f_T in component T_type_Ca_channel_f_T_gate (per_second).
C ALGBRC(37) is beta_f_T in component T_type_Ca_channel_f_T_gate (per_second).
C ALGBRC(48) is f_T_infinity in component T_type_Ca_channel_f_T_gate (dimensionless).
C ALGBRC(57) is tau_f_T in component T_type_Ca_channel_f_T_gate (second).
C ALGBRC(61) is E_K in component Ca_independent_transient_outward_K_current (millivolt).
C CONSTS(16) is g_to in component Ca_independent_transient_outward_K_current (nanoS).
C CONSTS(17) is K_c in component cleft_space_ion_concentrations (millimolar).
C STATES(10) is K_i in component intracellular_ion_concentrations (millimolar).
C STATES(11) is r in component Ca_independent_transient_outward_K_current_r_gate (dimensionless).
C STATES(12) is s1 in component Ca_independent_transient_outward_K_current_s1_gate (dimensionless).
C STATES(13) is s2 in component Ca_independent_transient_outward_K_current_s2_gate (dimensionless).
C STATES(14) is s3 in component Ca_independent_transient_outward_K_current_s3_gate (dimensionless).
C ALGBRC(8) is alpha_r in component Ca_independent_transient_outward_K_current_r_gate (per_second).
C ALGBRC(23) is beta_r in component Ca_independent_transient_outward_K_current_r_gate (per_second).
C ALGBRC(49) is tau_r in component Ca_independent_transient_outward_K_current_r_gate (second).
C ALGBRC(38) is r_infinity in component Ca_independent_transient_outward_K_current_r_gate (dimensionless).
C ALGBRC(24) is tau_s1 in component Ca_independent_transient_outward_K_current_s1_gate (second).
C ALGBRC(9) is s1_infinity in component Ca_independent_transient_outward_K_current_s1_gate (dimensionless).
C ALGBRC(25) is tau_s2 in component Ca_independent_transient_outward_K_current_s2_gate (second).
C ALGBRC(10) is s2_infinity in component Ca_independent_transient_outward_K_current_s2_gate (dimensionless).
C ALGBRC(26) is tau_s3 in component Ca_independent_transient_outward_K_current_s3_gate (second).
C ALGBRC(11) is s3_infinity in component Ca_independent_transient_outward_K_current_s3_gate (dimensionless).
C CONSTS(18) is g_Ks in component delayed_rectifier_K_current (nanoS).
C CONSTS(19) is g_Kr in component delayed_rectifier_K_current (nanoS).
C STATES(15) is z in component delayed_rectifier_K_current_z_gate (dimensionless).
C STATES(16) is p_a in component delayed_rectifier_K_current_pa_gate (dimensionless).
C STATES(17) is p_i in component delayed_rectifier_K_current_pi_gate (dimensionless).
C ALGBRC(12) is alpha_z in component delayed_rectifier_K_current_z_gate (per_second).
C ALGBRC(27) is beta_z in component delayed_rectifier_K_current_z_gate (per_second).
C ALGBRC(50) is tau_z in component delayed_rectifier_K_current_z_gate (second).
C ALGBRC(39) is z_infinity in component delayed_rectifier_K_current_z_gate (dimensionless).
C ALGBRC(13) is alpha_p_a in component delayed_rectifier_K_current_pa_gate (per_second).
C ALGBRC(28) is beta_p_a in component delayed_rectifier_K_current_pa_gate (per_second).
C ALGBRC(51) is tau_p_a in component delayed_rectifier_K_current_pa_gate (second).
C ALGBRC(40) is p_a_infinity in component delayed_rectifier_K_current_pa_gate (dimensionless).
C ALGBRC(14) is alpha_p_i in component delayed_rectifier_K_current_pi_gate (per_second).
C ALGBRC(29) is beta_p_i in component delayed_rectifier_K_current_pi_gate (per_second).
C ALGBRC(52) is tau_p_i in component delayed_rectifier_K_current_pi_gate (second).
C ALGBRC(41) is p_i_infinity in component delayed_rectifier_K_current_pi_gate (dimensionless).
C CONSTS(20) is g_K1 in component inward_rectifier (nanoS).
C CONSTS(21) is KmK1 in component inward_rectifier (millimolar).
C CONSTS(22) is steepK1 in component inward_rectifier (dimensionless).
C CONSTS(23) is shiftK1 in component inward_rectifier (millivolt).
C CONSTS(24) is g_B_Na in component background_currents (nanoS).
C CONSTS(25) is g_B_Ca in component background_currents (nanoS).
C CONSTS(26) is g_B_Cl in component background_currents (nanoS).
C ALGBRC(66) is E_Ca in component background_currents (millivolt).
C CONSTS(51) is E_Cl in component background_currents (millivolt).
C CONSTS(52) is E_B_Cl in component background_currents (millivolt).
C CONSTS(27) is Ca_c in component cleft_space_ion_concentrations (millimolar).
C STATES(18) is Ca_i in component intracellular_ion_concentrations (millimolar).
C CONSTS(28) is Cl_c in component cleft_space_ion_concentrations (millimolar).
C CONSTS(29) is Cl_i in component intracellular_ion_concentrations (millimolar).
C CONSTS(30) is k_NaK_K in component sodium_potassium_pump (millimolar).
C CONSTS(31) is k_NaK_Na in component sodium_potassium_pump (millimolar).
C CONSTS(32) is i_NaK_max in component sodium_potassium_pump (picoA).
C CONSTS(33) is i_CaP_max in component sarcolemmal_calcium_pump_current (picoA).
C CONSTS(34) is k_CaP in component sarcolemmal_calcium_pump_current (millimolar).
C CONSTS(35) is k_NaCa in component Na_Ca_ion_exchanger_current (picoA_per_millimolar_4).
C CONSTS(36) is d_NaCa in component Na_Ca_ion_exchanger_current (per_millimolar_4).
C CONSTS(37) is gamma in component Na_Ca_ion_exchanger_current (dimensionless).
C CONSTS(38) is Vol_i in component intracellular_ion_concentrations (nanolitre).
C CONSTS(39) is Vol_Ca in component intracellular_ion_concentrations (nanolitre).
C ALGBRC(76) is i_up in component Ca_handling_by_the_SR (picoA).
C ALGBRC(78) is i_rel in component Ca_handling_by_the_SR (picoA).
C ALGBRC(73) is dOCdt in component intracellular_Ca_buffering (per_second).
C ALGBRC(74) is dOTCdt in component intracellular_Ca_buffering (per_second).
C ALGBRC(75) is dOTMgCdt in component intracellular_Ca_buffering (per_second).
C STATES(19) is O_C in component intracellular_Ca_buffering (dimensionless).
C STATES(20) is O_TC in component intracellular_Ca_buffering (dimensionless).
C STATES(21) is O_TMgC in component intracellular_Ca_buffering (dimensionless).
C STATES(22) is O_TMgMg in component intracellular_Ca_buffering (dimensionless).
C CONSTS(40) is Mg_i in component intracellular_Ca_buffering (millimolar).
C ALGBRC(77) is i_tr in component Ca_handling_by_the_SR (picoA).
C CONSTS(41) is I_up_max in component Ca_handling_by_the_SR (picoA).
C CONSTS(42) is k_cyca in component Ca_handling_by_the_SR (millimolar).
C CONSTS(43) is k_srca in component Ca_handling_by_the_SR (millimolar).
C CONSTS(44) is k_xcs in component Ca_handling_by_the_SR (dimensionless).
C CONSTS(45) is alpha_rel in component Ca_handling_by_the_SR (picoA_per_millimolar).
C STATES(23) is Ca_rel in component Ca_handling_by_the_SR (millimolar).
C STATES(24) is Ca_up in component Ca_handling_by_the_SR (millimolar).
C CONSTS(46) is Vol_up in component Ca_handling_by_the_SR (nanolitre).
C CONSTS(47) is Vol_rel in component Ca_handling_by_the_SR (nanolitre).
C ALGBRC(15) is r_act in component Ca_handling_by_the_SR (per_second).
C ALGBRC(30) is r_inact in component Ca_handling_by_the_SR (per_second).
C STATES(25) is O_Calse in component Ca_handling_by_the_SR (dimensionless).
C STATES(26) is F1 in component Ca_handling_by_the_SR (dimensionless).
C STATES(27) is F2 in component Ca_handling_by_the_SR (dimensionless).
C STATES(28) is F3 in component Ca_handling_by_the_SR (dimensionless).
C CONSTS(48) is tau_tr in component Ca_handling_by_the_SR (second).
C CONSTS(49) is k_rel in component Ca_handling_by_the_SR (millimolar).
C CONSTS(50) is k_F3 in component Ca_handling_by_the_SR (per_second).
C RATES(1) is d/dt V in component membrane (millivolt).
C RATES(3) is d/dt m in component sodium_current_m_gate (dimensionless).
C RATES(4) is d/dt h1 in component sodium_current_h1_gate (dimensionless).
C RATES(5) is d/dt h2 in component sodium_current_h2_gate (dimensionless).
C RATES(6) is d/dt d_L in component L_type_Ca_channel_d_L_gate (dimensionless).
C RATES(7) is d/dt f_L in component L_type_Ca_channel_f_L_gate (dimensionless).
C RATES(8) is d/dt d_T in component T_type_Ca_channel_d_T_gate (dimensionless).
C RATES(9) is d/dt f_T in component T_type_Ca_channel_f_T_gate (dimensionless).
C RATES(11) is d/dt r in component Ca_independent_transient_outward_K_current_r_gate (dimensionless).
C RATES(12) is d/dt s1 in component Ca_independent_transient_outward_K_current_s1_gate (dimensionless).
C RATES(13) is d/dt s2 in component Ca_independent_transient_outward_K_current_s2_gate (dimensionless).
C RATES(14) is d/dt s3 in component Ca_independent_transient_outward_K_current_s3_gate (dimensionless).
C RATES(15) is d/dt z in component delayed_rectifier_K_current_z_gate (dimensionless).
C RATES(16) is d/dt p_a in component delayed_rectifier_K_current_pa_gate (dimensionless).
C RATES(17) is d/dt p_i in component delayed_rectifier_K_current_pi_gate (dimensionless).
C RATES(2) is d/dt Na_i in component intracellular_ion_concentrations (millimolar).
C RATES(10) is d/dt K_i in component intracellular_ion_concentrations (millimolar).
C RATES(18) is d/dt Ca_i in component intracellular_ion_concentrations (millimolar).
C RATES(19) is d/dt O_C in component intracellular_Ca_buffering (dimensionless).
C RATES(20) is d/dt O_TC in component intracellular_Ca_buffering (dimensionless).
C RATES(21) is d/dt O_TMgC in component intracellular_Ca_buffering (dimensionless).
C RATES(22) is d/dt O_TMgMg in component intracellular_Ca_buffering (dimensionless).
C RATES(25) is d/dt O_Calse in component Ca_handling_by_the_SR (dimensionless).
C RATES(23) is d/dt Ca_rel in component Ca_handling_by_the_SR (millimolar).
C RATES(24) is d/dt Ca_up in component Ca_handling_by_the_SR (millimolar).
C RATES(26) is d/dt F1 in component Ca_handling_by_the_SR (dimensionless).
C RATES(27) is d/dt F2 in component Ca_handling_by_the_SR (dimensionless).
C RATES(28) is d/dt F3 in component Ca_handling_by_the_SR (dimensionless).
C
      SUBROUTINE initConsts(CONSTS, RATES, STATES)
      REAL CONSTS(*), RATES(*), STATES(*)
      STATES(1) = -69.83663
      CONSTS(1) = 8314.472
      CONSTS(2) = 308
      CONSTS(3) = 96485.3415
      CONSTS(4) = 0.00005
      CONSTS(5) = 0.1
      CONSTS(6) = 100000
      CONSTS(7) = 1
      CONSTS(8) = 0.0008
      CONSTS(9) = -2
      CONSTS(10) = 0.0000014
      CONSTS(11) = 140
      STATES(2) = 8.4
      STATES(3) = 0.01309
      STATES(4) = 0.706
      STATES(5) = 0.61493
      CONSTS(12) = 0.004
      CONSTS(13) = 60
      STATES(6) = 3e-5
      STATES(7) = 0.99981
      CONSTS(14) = 0.006
      CONSTS(15) = 38
      STATES(8) = 4.6e-4
      STATES(9) = 0.30752
      CONSTS(16) = 0.050002
      CONSTS(17) = 5
      STATES(10) = 100
      STATES(11) = 6e-5
      STATES(12) = 0.5753
      STATES(13) = 0.39871
      STATES(14) = 0.57363
      CONSTS(18) = 0.0025
      CONSTS(19) = 0.0035
      STATES(15) = 0.02032
      STATES(16) = 1.6e-4
      STATES(17) = 0.76898
      CONSTS(20) = 0.005088
      CONSTS(21) = 0.59
      CONSTS(22) = 1.393
      CONSTS(23) = -3.6
      CONSTS(24) = 6.4e-5
      CONSTS(25) = 3.1e-5
      CONSTS(26) = 1.2e-4
      CONSTS(27) = 2.5
      STATES(18) = 7.305e-5
      CONSTS(28) = 132
      CONSTS(29) = 30
      CONSTS(30) = 1
      CONSTS(31) = 11
      CONSTS(32) = 0.06441
      CONSTS(33) = 0.009509
      CONSTS(34) = 2e-4
      CONSTS(35) = 2e-5
      CONSTS(36) = 3e-4
      CONSTS(37) = 0.45
      CONSTS(38) = 1.26e-5
      CONSTS(39) = 5.884e-6
      STATES(19) = 0.02981
      STATES(20) = 0.01442
      STATES(21) = 0.23532
      STATES(22) = 0.67476
      CONSTS(40) = 2.5
      CONSTS(41) = 2.8
      CONSTS(42) = 0.0003
      CONSTS(43) = 0.5
      CONSTS(44) = 0.4
      CONSTS(45) = 200
      STATES(23) = 0.59984
      STATES(24) = 0.64913
      CONSTS(46) = 3.969e-7
      CONSTS(47) = 4.41e-8
      STATES(25) = 0.41837
      STATES(26) = 0.21603
      STATES(27) = 0.00205
      STATES(28) = 0.68492
      CONSTS(48) = 0.01
      CONSTS(49) = 0.0003
      CONSTS(50) = 0.815
      CONSTS(51) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(29)/CONSTS(28))
      CONSTS(52) = CONSTS(51) -  0.490000*(CONSTS(51)+30.5900)
      RETURN
      END
      SUBROUTINE computeRates(VOI, CONSTS,  RATES, STATES, ALGBRC)
      REAL VOI, CONSTS(*), RATES(*), STATES(*), ALGBRC(*)
      RATES(22) =  2000.00*CONSTS(40)*((1.00000 - STATES(21)) - STATES(22)) -  666.000*STATES(22)
      ALGBRC(15) =  203.800*EXP( 0.0800000*(STATES(1) - 40.0000))+ 203.800*STATES(18)/(STATES(18)+CONSTS(49)) ** 4.00000
      RATES(26) =  CONSTS(50)*STATES(28) -  ALGBRC(15)*STATES(26)
      ALGBRC(24) = 0.546600/(1.00000+EXP((STATES(1)+32.8000)/0.100000))+0.0204000
      ALGBRC(9) = 1.00000/(1.00000+EXP((STATES(1)+28.2900)/7.06000))
      RATES(12) = (ALGBRC(9) - STATES(12))/ALGBRC(24)
      ALGBRC(25) = 5.75000/(1.00000+EXP((STATES(1)+32.8000)/0.100000))+0.450000/(1.00000+EXP((STATES(1) - 13.5400)/- 13.9700))
      ALGBRC(10) = 1.00000/(1.00000+EXP((STATES(1)+28.2900)/7.06000))
      RATES(13) = (ALGBRC(10) - STATES(13))/ALGBRC(25)
      ALGBRC(26) = 7.50000/(1.00000+EXP((STATES(1)+23.0000)/0.500000))+0.500000
      ALGBRC(11) = (1.00000/(1.00000+EXP((STATES(1)+50.6700)/27.3800))+0.666000)/1.66600
      RATES(14) = (ALGBRC(11) - STATES(14))/ALGBRC(26)
      ALGBRC(30) = 33.9600+ 339.600*STATES(18)/(STATES(18)+CONSTS(49)) ** 4.00000
      RATES(27) =  ALGBRC(15)*STATES(26) -  ALGBRC(30)*STATES(27)
      RATES(28) =  STATES(27)*ALGBRC(30) -  CONSTS(50)*STATES(28)
      ALGBRC(2) = STATES(1)+44.4000
      ALGBRC(17) = ( - 460.000*ALGBRC(2))/(EXP(ALGBRC(2)/- 12.6730) - 1.00000)
      ALGBRC(32) =  18400.0*EXP(ALGBRC(2)/- 12.6730)
      RATES(3) =  ALGBRC(17)*(1.00000 - STATES(3)) -  ALGBRC(32)*STATES(3)
      ALGBRC(3) =  44.9000*EXP((STATES(1)+66.9000)/- 5.57000)
      ALGBRC(18) = 1491.00/(1.00000+ 323.300*EXP((STATES(1)+94.6000)/- 12.9000))
      ALGBRC(33) = ALGBRC(3)/(ALGBRC(3)+ALGBRC(18))
      ALGBRC(43) = 0.0300000/(1.00000+EXP((STATES(1)+40.0000)/6.00000))+0.000350000
      RATES(4) = (ALGBRC(33) - STATES(4))/ALGBRC(43)
      ALGBRC(44) = 0.120000/(1.00000+EXP((STATES(1)+60.0000)/2.00000))+0.00295000
      RATES(5) = (ALGBRC(33) - STATES(5))/ALGBRC(44)
      ALGBRC(8) =  386.600*EXP(STATES(1)/12.0000)
      ALGBRC(23) =  8.01100*EXP(STATES(1)/- 7.20000)
      ALGBRC(49) = 1.00000/(ALGBRC(8)+ALGBRC(23))+0.000400000
      ALGBRC(38) = 1.00000/(1.00000+EXP((STATES(1)+15.0000)/- 5.63300))
      RATES(11) = (ALGBRC(38) - STATES(11))/ALGBRC(49)
      ALGBRC(12) =  1.66000*EXP(STATES(1)/69.4520)
      ALGBRC(27) =  0.300000*EXP(STATES(1)/- 21.8260)
      ALGBRC(50) = 1.00000/(ALGBRC(12)+ALGBRC(27))+0.0600000
      ALGBRC(39) = 1.00000/(1.00000+EXP((STATES(1) - 0.900000)/- 13.8000))
      RATES(15) = (ALGBRC(39) - STATES(15))/ALGBRC(50)
      ALGBRC(13) =  9.00000*EXP(STATES(1)/25.3710)
      ALGBRC(28) =  1.30000*EXP(STATES(1)/- 13.0260)
      ALGBRC(51) = 1.00000/(ALGBRC(13)+ALGBRC(28))
      ALGBRC(40) = 1.00000/(1.00000+EXP((STATES(1)+5.10000)/- 7.40000))
      RATES(16) = (ALGBRC(40) - STATES(16))/ALGBRC(51)
      ALGBRC(14) =  100.000*EXP(STATES(1)/- 54.6450)
      ALGBRC(29) =  656.000*EXP(STATES(1)/106.157)
      ALGBRC(52) = 1.00000/(ALGBRC(14)+ALGBRC(29))
      ALGBRC(41) = 1.00000/(1.00000+EXP((STATES(1)+47.3921)/18.6603))
      RATES(17) = (ALGBRC(41) - STATES(17))/ALGBRC(52)
      ALGBRC(6) = STATES(1)+23.0000
      ALGBRC(47) = 1.00000/(1.00000+EXP(ALGBRC(6)/- 6.10000))
      ALGBRC(21) =  674.173*EXP(ALGBRC(6)/30.0000)
      ALGBRC(36) =  674.173*EXP(ALGBRC(6)/- 30.0000)
      ALGBRC(56) = 1.00000/(ALGBRC(21)+ALGBRC(36))
      RATES(8) = (ALGBRC(47) - STATES(8))/ALGBRC(56)
      ALGBRC(7) = STATES(1)+75.0000
      ALGBRC(22) =  9.63700*EXP(ALGBRC(7)/- 83.3330)
      ALGBRC(37) =  9.63700*EXP(ALGBRC(7)/15.3850)
      ALGBRC(48) = ALGBRC(22)/(ALGBRC(22)+ALGBRC(37))
      ALGBRC(57) = 1.00000/(ALGBRC(22)+ALGBRC(37))
      RATES(9) = (ALGBRC(48) - STATES(9))/ALGBRC(57)
      ALGBRC(54) = 1.00000/(1.00000+EXP((STATES(1)+0.950000)/- 6.60000))
      ALGBRC(4) = STATES(1)+35.0000
      ALGBRC(34) = ( - 16.7200*ALGBRC(4))/(EXP(ALGBRC(4)/- 2.50000) - 1.00000)+( - 50.0000*STATES(1))/(EXP(STATES(1)/- 4.80800) - 1.00000)
      ALGBRC(19) = STATES(1) - 5.00000
      ALGBRC(45) = ( 4.48000*ALGBRC(19))/(EXP(ALGBRC(19)/2.50000) - 1.00000)
      ALGBRC(59) = 1.00000/(ALGBRC(34)+ALGBRC(45))
      RATES(6) = (ALGBRC(54) - STATES(6))/ALGBRC(59)
      ALGBRC(5) = STATES(1)+28.0000
      ALGBRC(20) = ( 8.49000*ALGBRC(5))/(EXP(ALGBRC(5)/4.00000) - 1.00000)
      ALGBRC(35) = 67.9220/(1.00000+EXP(ALGBRC(5)/- 4.00000))
      ALGBRC(46) = ALGBRC(20)/(ALGBRC(20)+ALGBRC(35))
      ALGBRC(55) = (STATES(1)+37.4270)/20.2130
      ALGBRC(60) =  0.211000*EXP( - ALGBRC(55)*ALGBRC(55))+0.0150000
      RATES(7) = (ALGBRC(46) - STATES(7))/ALGBRC(60)
      ALGBRC(61) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(17)/STATES(10))
      ALGBRC(62) =  CONSTS(16)*STATES(11)*( 0.590000*STATES(12) ** 3.00000+ 0.410000*STATES(13) ** 3.00000)*( 0.600000*STATES(14) ** 6.00000+0.400000)*(STATES(1) - ALGBRC(61))
      ALGBRC(65) = ( CONSTS(20)*(STATES(1) - ALGBRC(61))*CONSTS(17)/(CONSTS(17)+CONSTS(21)) ** 3.00000*1.00000)/(1.00000+EXP(( CONSTS(22)*CONSTS(3)*((STATES(1) - ALGBRC(61)) - CONSTS(23)))/( CONSTS(1)*CONSTS(2))))
      ALGBRC(64) =  CONSTS(19)*STATES(16)*STATES(17)*(STATES(1) - ALGBRC(61))
      ALGBRC(63) =  CONSTS(18)*STATES(15)*(STATES(1) - ALGBRC(61))
      ALGBRC(70) = ( (( (( CONSTS(32)*CONSTS(17))/(CONSTS(17)+CONSTS(30)))*STATES(2) ** 1.50000)/(STATES(2) ** 1.50000+CONSTS(31) ** 1.50000))*1.60000)/(1.50000+EXP((STATES(1)+60.0000)/- 40.0000))
      RATES(10) = - ((ALGBRC(62)+ALGBRC(65)+ALGBRC(64)+ALGBRC(63)) -  2.00000*ALGBRC(70))/( CONSTS(38)*CONSTS(3))
      ALGBRC(16) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(11)/STATES(2))
      ALGBRC(31) = ( (( CONSTS(10)*STATES(3) ** 3.00000*( 0.635000*STATES(4)+ 0.365000*STATES(5))*CONSTS(11)*STATES(1)*CONSTS(3) ** 2.00000)/( CONSTS(1)*CONSTS(2)))*(EXP(( (STATES(1) - ALGBRC(16))*CONSTS(3))/( CONSTS(1)*CONSTS(2))) - 1.00000))/(EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) - 1.00000)
      ALGBRC(42) = 1.00000/(1.00000+EXP((STATES(1) - 33.0000)/- 12.0000))
      ALGBRC(53) =  CONSTS(12)*STATES(6)*STATES(7)*ALGBRC(42)*(STATES(1) - CONSTS(13))
      ALGBRC(58) =  CONSTS(14)*STATES(8)*STATES(9)*(STATES(1) - CONSTS(15))
      ALGBRC(67) =  CONSTS(24)*(STATES(1) - ALGBRC(16))
      ALGBRC(66) =  (( CONSTS(1)*CONSTS(2))/( 2.00000*CONSTS(3)))*log(CONSTS(27)/STATES(18))
      ALGBRC(68) =  CONSTS(25)*(STATES(1) - ALGBRC(66))
      ALGBRC(69) =  CONSTS(26)*(STATES(1) - CONSTS(52))*(1.00000+EXP((STATES(1) - (CONSTS(51)+36.9500))/74.5140))
      ALGBRC(71) = ( CONSTS(33)*STATES(18))/(STATES(18)+CONSTS(34))
      ALGBRC(72) = ( CONSTS(35)*( STATES(2) ** 3.00000*CONSTS(27)*EXP(( CONSTS(37)*CONSTS(3)*STATES(1))/( CONSTS(1)*CONSTS(2))) -  CONSTS(11) ** 3.00000*STATES(18)*EXP(( (CONSTS(37) - 1.00000)*STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))))/(1.00000+ CONSTS(36)*( CONSTS(11) ** 3.00000*STATES(18)+ STATES(2) ** 3.00000*CONSTS(27))*(1.00000+STATES(18)/0.00690000))
      ALGBRC(1) = TERNRY(VOI.GE.CONSTS(5).AND.VOI.LE.CONSTS(6).AND.(VOI - CONSTS(5)) -  INT((VOI - CONSTS(5))/CONSTS(7))*CONSTS(7).LE.CONSTS(8), CONSTS(9), 0.00000)
      RATES(1) =  (- 1.00000/CONSTS(4))*(ALGBRC(64)+ALGBRC(63)+ALGBRC(31)+ALGBRC(53)+ALGBRC(58)+ALGBRC(62)+ALGBRC(65)+ALGBRC(67)+ALGBRC(68)+ALGBRC(69)+ALGBRC(70)+ALGBRC(71)+ALGBRC(72)+ALGBRC(1))
      RATES(2) = - (ALGBRC(31)+ALGBRC(67)+ 3.00000*ALGBRC(70)+ 3.00000*ALGBRC(72))/( CONSTS(38)*CONSTS(3))
      ALGBRC(73) =  200000.*STATES(18)*(1.00000 - STATES(19)) -  476.000*STATES(19)
      RATES(19) = ALGBRC(73)
      ALGBRC(74) =  78400.0*STATES(18)*(1.00000 - STATES(20)) -  392.000*STATES(20)
      RATES(20) = ALGBRC(74)
      RATES(25) =  480.000*STATES(23)*(1.00000 - STATES(25)) -  400.000*STATES(25)
      ALGBRC(75) =  200000.*STATES(18)*((1.00000 - STATES(21)) - STATES(22)) -  6.60000*STATES(21)
      RATES(21) = ALGBRC(75)
      ALGBRC(76) = ( CONSTS(41)*(STATES(18)/CONSTS(42) - ( CONSTS(44) ** 2.00000*STATES(24))/CONSTS(43)))/((STATES(18)+CONSTS(42))/CONSTS(42)+( CONSTS(44)*(STATES(24)+CONSTS(43)))/CONSTS(43))
      ALGBRC(77) = ( (STATES(24) - STATES(23))*2.00000*CONSTS(3)*CONSTS(47))/CONSTS(48)
      RATES(24) = (ALGBRC(76) - ALGBRC(77))/( 2.00000*CONSTS(46)*CONSTS(3))
      ALGBRC(78) =  CONSTS(45)*STATES(27)/(STATES(27)+0.250000) ** 2.00000*(STATES(23) - STATES(18))
      RATES(18) = - ((((ALGBRC(53)+ALGBRC(58)+ALGBRC(68)+ALGBRC(71)) -  2.00000*ALGBRC(72))+ALGBRC(76)) - ALGBRC(78))/( 2.00000*CONSTS(39)*CONSTS(3)) - ( 0.0800000*ALGBRC(74)+ 0.160000*ALGBRC(75)+ 0.0450000*ALGBRC(73))
      RATES(23) = (ALGBRC(77) - ALGBRC(78))/( 2.00000*CONSTS(47)*CONSTS(3)) -  31.0000*RATES(25)
      RETURN
      END
      SUBROUTINE computeVariables(VOI, CONSTS, RATES, STATES, ALGBRC)
      REAL VOI, CONSTS(*), RATES(*), STATES(*), ALGBRC(*)
      ALGBRC(15) =  203.800*EXP( 0.0800000*(STATES(1) - 40.0000))+ 203.800*STATES(18)/(STATES(18)+CONSTS(49)) ** 4.00000
      ALGBRC(24) = 0.546600/(1.00000+EXP((STATES(1)+32.8000)/0.100000))+0.0204000
      ALGBRC(9) = 1.00000/(1.00000+EXP((STATES(1)+28.2900)/7.06000))
      ALGBRC(25) = 5.75000/(1.00000+EXP((STATES(1)+32.8000)/0.100000))+0.450000/(1.00000+EXP((STATES(1) - 13.5400)/- 13.9700))
      ALGBRC(10) = 1.00000/(1.00000+EXP((STATES(1)+28.2900)/7.06000))
      ALGBRC(26) = 7.50000/(1.00000+EXP((STATES(1)+23.0000)/0.500000))+0.500000
      ALGBRC(11) = (1.00000/(1.00000+EXP((STATES(1)+50.6700)/27.3800))+0.666000)/1.66600
      ALGBRC(30) = 33.9600+ 339.600*STATES(18)/(STATES(18)+CONSTS(49)) ** 4.00000
      ALGBRC(2) = STATES(1)+44.4000
      ALGBRC(17) = ( - 460.000*ALGBRC(2))/(EXP(ALGBRC(2)/- 12.6730) - 1.00000)
      ALGBRC(32) =  18400.0*EXP(ALGBRC(2)/- 12.6730)
      ALGBRC(3) =  44.9000*EXP((STATES(1)+66.9000)/- 5.57000)
      ALGBRC(18) = 1491.00/(1.00000+ 323.300*EXP((STATES(1)+94.6000)/- 12.9000))
      ALGBRC(33) = ALGBRC(3)/(ALGBRC(3)+ALGBRC(18))
      ALGBRC(43) = 0.0300000/(1.00000+EXP((STATES(1)+40.0000)/6.00000))+0.000350000
      ALGBRC(44) = 0.120000/(1.00000+EXP((STATES(1)+60.0000)/2.00000))+0.00295000
      ALGBRC(8) =  386.600*EXP(STATES(1)/12.0000)
      ALGBRC(23) =  8.01100*EXP(STATES(1)/- 7.20000)
      ALGBRC(49) = 1.00000/(ALGBRC(8)+ALGBRC(23))+0.000400000
      ALGBRC(38) = 1.00000/(1.00000+EXP((STATES(1)+15.0000)/- 5.63300))
      ALGBRC(12) =  1.66000*EXP(STATES(1)/69.4520)
      ALGBRC(27) =  0.300000*EXP(STATES(1)/- 21.8260)
      ALGBRC(50) = 1.00000/(ALGBRC(12)+ALGBRC(27))+0.0600000
      ALGBRC(39) = 1.00000/(1.00000+EXP((STATES(1) - 0.900000)/- 13.8000))
      ALGBRC(13) =  9.00000*EXP(STATES(1)/25.3710)
      ALGBRC(28) =  1.30000*EXP(STATES(1)/- 13.0260)
      ALGBRC(51) = 1.00000/(ALGBRC(13)+ALGBRC(28))
      ALGBRC(40) = 1.00000/(1.00000+EXP((STATES(1)+5.10000)/- 7.40000))
      ALGBRC(14) =  100.000*EXP(STATES(1)/- 54.6450)
      ALGBRC(29) =  656.000*EXP(STATES(1)/106.157)
      ALGBRC(52) = 1.00000/(ALGBRC(14)+ALGBRC(29))
      ALGBRC(41) = 1.00000/(1.00000+EXP((STATES(1)+47.3921)/18.6603))
      ALGBRC(6) = STATES(1)+23.0000
      ALGBRC(47) = 1.00000/(1.00000+EXP(ALGBRC(6)/- 6.10000))
      ALGBRC(21) =  674.173*EXP(ALGBRC(6)/30.0000)
      ALGBRC(36) =  674.173*EXP(ALGBRC(6)/- 30.0000)
      ALGBRC(56) = 1.00000/(ALGBRC(21)+ALGBRC(36))
      ALGBRC(7) = STATES(1)+75.0000
      ALGBRC(22) =  9.63700*EXP(ALGBRC(7)/- 83.3330)
      ALGBRC(37) =  9.63700*EXP(ALGBRC(7)/15.3850)
      ALGBRC(48) = ALGBRC(22)/(ALGBRC(22)+ALGBRC(37))
      ALGBRC(57) = 1.00000/(ALGBRC(22)+ALGBRC(37))
      ALGBRC(54) = 1.00000/(1.00000+EXP((STATES(1)+0.950000)/- 6.60000))
      ALGBRC(4) = STATES(1)+35.0000
      ALGBRC(34) = ( - 16.7200*ALGBRC(4))/(EXP(ALGBRC(4)/- 2.50000) - 1.00000)+( - 50.0000*STATES(1))/(EXP(STATES(1)/- 4.80800) - 1.00000)
      ALGBRC(19) = STATES(1) - 5.00000
      ALGBRC(45) = ( 4.48000*ALGBRC(19))/(EXP(ALGBRC(19)/2.50000) - 1.00000)
      ALGBRC(59) = 1.00000/(ALGBRC(34)+ALGBRC(45))
      ALGBRC(5) = STATES(1)+28.0000
      ALGBRC(20) = ( 8.49000*ALGBRC(5))/(EXP(ALGBRC(5)/4.00000) - 1.00000)
      ALGBRC(35) = 67.9220/(1.00000+EXP(ALGBRC(5)/- 4.00000))
      ALGBRC(46) = ALGBRC(20)/(ALGBRC(20)+ALGBRC(35))
      ALGBRC(55) = (STATES(1)+37.4270)/20.2130
      ALGBRC(60) =  0.211000*EXP( - ALGBRC(55)*ALGBRC(55))+0.0150000
      ALGBRC(61) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(17)/STATES(10))
      ALGBRC(62) =  CONSTS(16)*STATES(11)*( 0.590000*STATES(12) ** 3.00000+ 0.410000*STATES(13) ** 3.00000)*( 0.600000*STATES(14) ** 6.00000+0.400000)*(STATES(1) - ALGBRC(61))
      ALGBRC(65) = ( CONSTS(20)*(STATES(1) - ALGBRC(61))*CONSTS(17)/(CONSTS(17)+CONSTS(21)) ** 3.00000*1.00000)/(1.00000+EXP(( CONSTS(22)*CONSTS(3)*((STATES(1) - ALGBRC(61)) - CONSTS(23)))/( CONSTS(1)*CONSTS(2))))
      ALGBRC(64) =  CONSTS(19)*STATES(16)*STATES(17)*(STATES(1) - ALGBRC(61))
      ALGBRC(63) =  CONSTS(18)*STATES(15)*(STATES(1) - ALGBRC(61))
      ALGBRC(70) = ( (( (( CONSTS(32)*CONSTS(17))/(CONSTS(17)+CONSTS(30)))*STATES(2) ** 1.50000)/(STATES(2) ** 1.50000+CONSTS(31) ** 1.50000))*1.60000)/(1.50000+EXP((STATES(1)+60.0000)/- 40.0000))
      ALGBRC(16) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(11)/STATES(2))
      ALGBRC(31) = ( (( CONSTS(10)*STATES(3) ** 3.00000*( 0.635000*STATES(4)+ 0.365000*STATES(5))*CONSTS(11)*STATES(1)*CONSTS(3) ** 2.00000)/( CONSTS(1)*CONSTS(2)))*(EXP(( (STATES(1) - ALGBRC(16))*CONSTS(3))/( CONSTS(1)*CONSTS(2))) - 1.00000))/(EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) - 1.00000)
      ALGBRC(42) = 1.00000/(1.00000+EXP((STATES(1) - 33.0000)/- 12.0000))
      ALGBRC(53) =  CONSTS(12)*STATES(6)*STATES(7)*ALGBRC(42)*(STATES(1) - CONSTS(13))
      ALGBRC(58) =  CONSTS(14)*STATES(8)*STATES(9)*(STATES(1) - CONSTS(15))
      ALGBRC(67) =  CONSTS(24)*(STATES(1) - ALGBRC(16))
      ALGBRC(66) =  (( CONSTS(1)*CONSTS(2))/( 2.00000*CONSTS(3)))*log(CONSTS(27)/STATES(18))
      ALGBRC(68) =  CONSTS(25)*(STATES(1) - ALGBRC(66))
      ALGBRC(69) =  CONSTS(26)*(STATES(1) - CONSTS(52))*(1.00000+EXP((STATES(1) - (CONSTS(51)+36.9500))/74.5140))
      ALGBRC(71) = ( CONSTS(33)*STATES(18))/(STATES(18)+CONSTS(34))
      ALGBRC(72) = ( CONSTS(35)*( STATES(2) ** 3.00000*CONSTS(27)*EXP(( CONSTS(37)*CONSTS(3)*STATES(1))/( CONSTS(1)*CONSTS(2))) -  CONSTS(11) ** 3.00000*STATES(18)*EXP(( (CONSTS(37) - 1.00000)*STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))))/(1.00000+ CONSTS(36)*( CONSTS(11) ** 3.00000*STATES(18)+ STATES(2) ** 3.00000*CONSTS(27))*(1.00000+STATES(18)/0.00690000))
      ALGBRC(1) = TERNRY(VOI.GE.CONSTS(5).AND.VOI.LE.CONSTS(6).AND.(VOI - CONSTS(5)) -  INT((VOI - CONSTS(5))/CONSTS(7))*CONSTS(7).LE.CONSTS(8), CONSTS(9), 0.00000)
      ALGBRC(73) =  200000.*STATES(18)*(1.00000 - STATES(19)) -  476.000*STATES(19)
      ALGBRC(74) =  78400.0*STATES(18)*(1.00000 - STATES(20)) -  392.000*STATES(20)
      ALGBRC(75) =  200000.*STATES(18)*((1.00000 - STATES(21)) - STATES(22)) -  6.60000*STATES(21)
      ALGBRC(76) = ( CONSTS(41)*(STATES(18)/CONSTS(42) - ( CONSTS(44) ** 2.00000*STATES(24))/CONSTS(43)))/((STATES(18)+CONSTS(42))/CONSTS(42)+( CONSTS(44)*(STATES(24)+CONSTS(43)))/CONSTS(43))
      ALGBRC(77) = ( (STATES(24) - STATES(23))*2.00000*CONSTS(3)*CONSTS(47))/CONSTS(48)
      ALGBRC(78) =  CONSTS(45)*STATES(27)/(STATES(27)+0.250000) ** 2.00000*(STATES(23) - STATES(18))
      RETURN
      END
      REAL FUNCTION TERNRY(TEST, VALA, VALB)
      LOGICAL TEST
      REAL VALA, VALB
      IF (TEST) THEN
        TERNRY = VALA
      ELSE
        TERNRY = VALB
      ENDIF
      RETURN
      END