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 35 entries in the algebraic variable array.
C There are a total of 9 entries in each of the rate and state variable arrays.
C There are a total of 49 entries in the constant variable array.
C
C
C VOI is time in component environment (second).
C CONSTS(45) is E_Na in component reversal_potentials (millivolt).
C ALGBRC(25) is E_Ca in component reversal_potentials (millivolt).
C CONSTS(46) is E_K in component reversal_potentials (millivolt).
C CONSTS(47) is E_Cl in component reversal_potentials (millivolt).
C CONSTS(1) is R in component model_parameters (millijoule_per_mole_kelvin).
C CONSTS(2) is T in component model_parameters (kelvin).
C CONSTS(3) is F in component model_parameters (coulomb_per_mole).
C CONSTS(4) is Nai in component model_parameters (millimolar).
C CONSTS(5) is Nao in component model_parameters (millimolar).
C ALGBRC(23) is Cai in component model_parameters (millimolar).
C CONSTS(6) is Cao in component model_parameters (millimolar).
C CONSTS(7) is Ki in component model_parameters (millimolar).
C CONSTS(8) is Ko in component model_parameters (millimolar).
C CONSTS(9) is Cli in component model_parameters (millimolar).
C CONSTS(10) is Clo in component model_parameters (millimolar).
C ALGBRC(1) is i_Kdr in component delayed_rectifier_K_current (nanoA).
C CONSTS(11) is g_Kdr in component delayed_rectifier_K_current (microS).
C CONSTS(12) is gamma_KSS in component delayed_rectifier_K_current (dimensionless).
C STATES(1) is V in component membrane (millivolt).
C STATES(2) is xa in component delayed_rectifier_K_current_xa_gate (dimensionless).
C STATES(3) is xi1 in component delayed_rectifier_K_current_xi1_gate (dimensionless).
C STATES(4) is xi2 in component delayed_rectifier_K_current_xi2_gate (dimensionless).
C ALGBRC(2) is xa_infinity in component delayed_rectifier_K_current_xa_gate (dimensionless).
C ALGBRC(9) is tau_xa in component delayed_rectifier_K_current_xa_gate (second).
C ALGBRC(3) is xi1_infinity in component delayed_rectifier_K_current_xi1_gate (dimensionless).
C CONSTS(13) is tau_xi1 in component delayed_rectifier_K_current_xi1_gate (second).
C ALGBRC(4) is xi2_infinity in component delayed_rectifier_K_current_xi2_gate (dimensionless).
C CONSTS(14) is tau_xi2 in component delayed_rectifier_K_current_xi2_gate (second).
C ALGBRC(27) is i_CaL in component L_type_Ca_current (nanoA).
C CONSTS(15) is P_CaL in component L_type_Ca_current (nanoA_per_millimolar).
C CONSTS(16) is V_surf in component L_type_Ca_current (millivolt).
C ALGBRC(8) is ICaL_perm1 in component L_type_Ca_current (dimensionless).
C ALGBRC(26) is ICaL_perm2 in component L_type_Ca_current (millimolar).
C STATES(5) is d in component L_type_Ca_current_d_gate (dimensionless).
C STATES(6) is f in component L_type_Ca_current_f_gate (dimensionless).
C ALGBRC(5) is alpha_d in component L_type_Ca_current_d_gate (per_second).
C ALGBRC(10) is beta_d in component L_type_Ca_current_d_gate (per_second).
C CONSTS(17) is tau_f in component L_type_Ca_current_f_gate (second).
C ALGBRC(6) is f_infinity in component L_type_Ca_current_f_gate (dimensionless).
C ALGBRC(12) is i_KCa in component Ca_activated_K_current (nanoA).
C CONSTS(18) is g_KCa in component Ca_activated_K_current (microS).
C STATES(7) is xCa1 in component Ca_activated_K_current_xCa1_gate (dimensionless).
C STATES(8) is B in component Ca_activated_K_current_B_gate (dimensionless).
C ALGBRC(24) is xCa1_infinity in component Ca_activated_K_current_xCa1_gate (dimensionless).
C CONSTS(19) is tau_xCa1 in component Ca_activated_K_current_xCa1_gate (second).
C ALGBRC(14) is K2 in component Ca_activated_K_current_xCa1_gate (millimolar).
C ALGBRC(13) is K4 in component Ca_activated_K_current_xCa1_gate (millimolar).
C CONSTS(20) is alpha in component Ca_activated_K_current_xCa1_gate (per_second).
C CONSTS(21) is beta in component Ca_activated_K_current_xCa1_gate (per_second).
C ALGBRC(15) is K1 in component Ca_activated_K_current_B_gate (per_millimolar_per_second).
C ALGBRC(16) is K_1 in component Ca_activated_K_current_B_gate (per_second).
C ALGBRC(28) is i_ClCa in component Ca_activated_Cl_current (nanoA).
C CONSTS(22) is g_Cl in component Ca_activated_Cl_current (microS).
C CONSTS(23) is CaCT in component Ca_activated_Cl_current (millimolar).
C CONSTS(24) is h in component Ca_activated_Cl_current (dimensionless).
C ALGBRC(33) is i_cationic in component nonspecific_cationic_current (nanoA).
C ALGBRC(30) is i_nsNa in component nonspecific_cationic_current (nanoA).
C ALGBRC(31) is i_nsK in component nonspecific_cationic_current (nanoA).
C ALGBRC(32) is i_nsCa in component nonspecific_cationic_current (nanoA).
C CONSTS(25) is P_nsCa in component nonspecific_cationic_current (nanoA_per_millimolar_mole_per_C).
C ALGBRC(29) is alpha_Ca in component nonspecific_cationic_current (dimensionless).
C CONSTS(26) is Km_nsCa in component nonspecific_cationic_current (millimolar).
C STATES(9) is ns in component nonspecific_cationic_current_ns_gate (dimensionless).
C ALGBRC(11) is tau_ns in component nonspecific_cationic_current_ns_gate (second).
C ALGBRC(7) is ns_infinity in component nonspecific_cationic_current_ns_gate (dimensionless).
C ALGBRC(34) is i_pCa in component Ca_pump_current (nanoA).
C CONSTS(27) is i_pCamax in component Ca_pump_current (nanoA).
C CONSTS(28) is Kmp_Ca in component Ca_pump_current (millimolar).
C CONSTS(48) is i_NaK in component Na_K_pump_current (nanoA).
C CONSTS(29) is i_NaKmax in component Na_K_pump_current (nanoA).
C CONSTS(30) is Km_Na in component Na_K_pump_current (millimolar).
C CONSTS(31) is Km_K in component Na_K_pump_current (millimolar).
C ALGBRC(35) is i_bCa in component Ca_background_current (nanoA).
C CONSTS(32) is g_bCa in component Ca_background_current (microS).
C ALGBRC(17) is i_bK in component K_background_current (nanoA).
C CONSTS(33) is g_bK in component K_background_current (microS).
C ALGBRC(18) is i_bNa in component Na_background_current (nanoA).
C CONSTS(34) is g_bNa in component Na_background_current (microS).
C CONSTS(35) is cap in component membrane (microF).
C ALGBRC(20) is upeak in component model_parameters (millimolar).
C ALGBRC(19) is up in component model_parameters (millimolar).
C ALGBRC(21) is peak in component model_parameters (millimolar).
C ALGBRC(22) is plat in component model_parameters (millimolar).
C CONSTS(36) is A in component model_parameters (millimolar).
C CONSTS(37) is B in component model_parameters (millimolar).
C CONSTS(38) is C in component model_parameters (millimolar).
C CONSTS(49) is x0 in component model_parameters (second).
C CONSTS(39) is x1 in component model_parameters (second).
C CONSTS(40) is x2 in component model_parameters (second).
C CONSTS(41) is ds in component model_parameters (second).
C CONSTS(42) is p in component model_parameters (second).
C CONSTS(43) is n in component model_parameters (second).
C CONSTS(44) is t36 in component model_parameters (second).
C RATES(2) is d/dt xa in component delayed_rectifier_K_current_xa_gate (dimensionless).
C RATES(3) is d/dt xi1 in component delayed_rectifier_K_current_xi1_gate (dimensionless).
C RATES(4) is d/dt xi2 in component delayed_rectifier_K_current_xi2_gate (dimensionless).
C RATES(5) is d/dt d in component L_type_Ca_current_d_gate (dimensionless).
C RATES(6) is d/dt f in component L_type_Ca_current_f_gate (dimensionless).
C RATES(7) is d/dt xCa1 in component Ca_activated_K_current_xCa1_gate (dimensionless).
C RATES(8) is d/dt B in component Ca_activated_K_current_B_gate (dimensionless).
C RATES(9) is d/dt ns in component nonspecific_cationic_current_ns_gate (dimensionless).
C RATES(1) is d/dt V in component membrane (millivolt).
C
      SUBROUTINE initConsts(CONSTS, RATES, STATES)
      REAL CONSTS(*), RATES(*), STATES(*)
      CONSTS(1) = 8314.472
      CONSTS(2) = 310
      CONSTS(3) = 96485.3415
      CONSTS(4) = 12
      CONSTS(5) = 130
      CONSTS(6) = 2
      CONSTS(7) = 150
      CONSTS(8) = 5
      CONSTS(9) = 55
      CONSTS(10) = 140
      CONSTS(11) = 0.035
      CONSTS(12) = 0.15
      STATES(1) = -60
      STATES(2) = 0.001
      STATES(3) = 0
      STATES(4) = 0
      CONSTS(13) = 0.25
      CONSTS(14) = 1.98
      CONSTS(15) = 0.003
      CONSTS(16) = 150
      STATES(5) = 0
      STATES(6) = 1
      CONSTS(17) = 0.0173
      CONSTS(18) = 2.45
      STATES(7) = 1
      STATES(8) = 0.001
      CONSTS(19) = 1
      CONSTS(20) = 280
      CONSTS(21) = 480
      CONSTS(22) = 0.01
      CONSTS(23) = 0.0005
      CONSTS(24) = 3
      CONSTS(25) = 0.000000175
      CONSTS(26) = 0.0012
      STATES(9) = 1
      CONSTS(27) = 1.15
      CONSTS(28) = 0.05
      CONSTS(29) = 0.7
      CONSTS(30) = 40
      CONSTS(31) = 1
      CONSTS(32) = 1.194e-5
      CONSTS(33) = 0.008729
      CONSTS(34) = 0.003263
      CONSTS(35) = 0.00002
      CONSTS(36) = 0.0008
      CONSTS(37) = 0.00008
      CONSTS(38) = 0.00012
      CONSTS(39) = 15
      CONSTS(40) = 0.8
      CONSTS(41) = 30
      CONSTS(42) = 0.4
      CONSTS(43) = 0.2
      CONSTS(44) = 1.5
      CONSTS(45) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(5)/CONSTS(4))
      CONSTS(46) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(8)/CONSTS(7))
      CONSTS(47) =  (( CONSTS(1)*CONSTS(2))/CONSTS(3))*log(CONSTS(9)/CONSTS(10))
      CONSTS(48) = ( (( CONSTS(29)*CONSTS(8))/(CONSTS(8)+CONSTS(31)))*CONSTS(4))/(CONSTS(4)+CONSTS(30))
      CONSTS(49) = CONSTS(39)+CONSTS(40)
      RETURN
      END
      SUBROUTINE computeRates(VOI, CONSTS,  RATES, STATES, ALGBRC)
      REAL VOI, CONSTS(*), RATES(*), STATES(*), ALGBRC(*)
      ALGBRC(3) = 1.00000/(1.00000+EXP((STATES(1)+4.30000)/7.50000))
      RATES(3) = (ALGBRC(3) - STATES(3))/CONSTS(13)
      ALGBRC(4) = 1.00000/(1.00000+EXP((STATES(1)+4.30000)/7.50000))
      RATES(4) = (ALGBRC(4) - STATES(4))/CONSTS(14)
      ALGBRC(6) = 1.00000/(1.00000+EXP((23.0000+STATES(1))/6.60000))
      RATES(6) = (ALGBRC(6) - STATES(6))/CONSTS(17)
      ALGBRC(2) = 1.00000/(1.00000+EXP((5.50000 - STATES(1))/6.00000))
      ALGBRC(9) = 0.00326200 -  3.55200e-05*STATES(1)
      RATES(2) = (ALGBRC(2) - STATES(2))/ALGBRC(9)
      ALGBRC(5) = ( 30.0000*(STATES(1)+18.0000))/(1.00000 - EXP( - 0.250000*(STATES(1)+18.0000)))
      ALGBRC(10) = ( 12.0000*(STATES(1)+18.0000))/(EXP( 0.100000*(STATES(1)+18.0000)) - 1.00000)
      RATES(5) = ALGBRC(5) -  (ALGBRC(5)+ALGBRC(10))*STATES(5)
      ALGBRC(11) = 0.200250 -  0.000898750*STATES(1)
      ALGBRC(7) = 1.00000/(1.00000+EXP((STATES(1) - 69.8000)/- 11.9000))
      RATES(9) = (ALGBRC(7) - STATES(9))/ALGBRC(11)
      ALGBRC(19) = TERNRY(VOI.LT.CONSTS(39), 0.00000, ( (VOI - CONSTS(39))*CONSTS(36))/CONSTS(40))
      ALGBRC(20) = TERNRY(VOI.LT.CONSTS(39)+CONSTS(40), ALGBRC(19), 0.00000)
      ALGBRC(21) = TERNRY(VOI.LT.CONSTS(49), 0.00000,  CONSTS(36)*EXP(- (VOI - CONSTS(49))/CONSTS(44)))
      ALGBRC(22) = CONSTS(37)/(1.00000+EXP((VOI - (CONSTS(39)+CONSTS(42)+CONSTS(41)))/CONSTS(43))) - CONSTS(37)/(1.00000+EXP((VOI - (CONSTS(39)+CONSTS(42)))/CONSTS(43)))
      ALGBRC(23) = CONSTS(38)+ALGBRC(20)+ALGBRC(21)+ALGBRC(22)
      ALGBRC(15) =  0.850000*EXP( 0.0400000*STATES(1))
      ALGBRC(16) =  0.240000*EXP( - 0.0120000*STATES(1))
      RATES(8) = TERNRY(ALGBRC(23).GE.0.100000,  ALGBRC(15)*ALGBRC(23)*STATES(7) -  ALGBRC(16)*STATES(8), 1.00000)
      ALGBRC(14) =  0.000275000*EXP(( - 1.51000*STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))
      ALGBRC(13) =  1.25000e-05*EXP(( - 1.99000*STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))
      ALGBRC(24) = (ALGBRC(23) ** 2.00000+ ALGBRC(13)*ALGBRC(23))/(ALGBRC(23) ** 2.00000+ ALGBRC(13)*ALGBRC(23)*(1.00000+CONSTS(20)/CONSTS(21))+( ALGBRC(13)*ALGBRC(14)*CONSTS(20))/CONSTS(21))
      RATES(7) = (ALGBRC(24) - STATES(7))/CONSTS(19)
      ALGBRC(1) =  CONSTS(11)*(CONSTS(12)+ (STATES(3)+STATES(4))*(1.00000 - CONSTS(12)))*STATES(2) ** 2.00000*(STATES(1) - CONSTS(46))
      ALGBRC(8) = ( (STATES(1) - CONSTS(16))*CONSTS(3))/( CONSTS(1)*CONSTS(2)*(1.00000 - EXP(( - (STATES(1) - CONSTS(16))*2.00000*CONSTS(3))/( CONSTS(1)*CONSTS(2)))))
      ALGBRC(26) =  ALGBRC(8)*( ALGBRC(23)*EXP(CONSTS(16)/(( 0.500000*CONSTS(1)*CONSTS(2))/CONSTS(3))) -  CONSTS(6)*EXP(- (STATES(1) - CONSTS(16))/(( 0.500000*CONSTS(1)*CONSTS(2))/CONSTS(3))))
      ALGBRC(27) =  4.00000*CONSTS(15)*STATES(5)*STATES(6)*ALGBRC(26)
      ALGBRC(12) =  CONSTS(18)*STATES(7)*STATES(8)*(STATES(1) - CONSTS(46))
      ALGBRC(28) = ( CONSTS(22)*(STATES(1) - CONSTS(47))*1.00000)/(1.00000+CONSTS(23)/ALGBRC(23) ** CONSTS(24))
      ALGBRC(29) = 1.00000/(1.00000+CONSTS(26)/ALGBRC(23) ** 3.00000)
      ALGBRC(30) = ( (( STATES(9)*ALGBRC(29)*CONSTS(25)*STATES(1)*CONSTS(3) ** 2.00000)/( CONSTS(1)*CONSTS(2)))*( 0.750000*CONSTS(4)*EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) -  0.750000*CONSTS(5)))/(EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) - 1.00000)
      ALGBRC(31) = ( (( STATES(9)*ALGBRC(29)*CONSTS(25)*STATES(1)*CONSTS(3) ** 2.00000)/( CONSTS(1)*CONSTS(2)))*( 0.750000*CONSTS(7)*EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) -  0.750000*CONSTS(8)))/(EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) - 1.00000)
      ALGBRC(32) = ( (( STATES(9)*ALGBRC(29)*CONSTS(25)*4.00000*STATES(1)*CONSTS(3) ** 2.00000)/( CONSTS(1)*CONSTS(2)))*( 1.50000*ALGBRC(23)*EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) -  1.50000*CONSTS(6)))/(EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) - 1.00000)
      ALGBRC(33) = ALGBRC(30)+ALGBRC(31)+ALGBRC(32)
      ALGBRC(34) = ( CONSTS(27)*ALGBRC(23))/(CONSTS(28)+ALGBRC(23))
      ALGBRC(25) =  (( CONSTS(1)*CONSTS(2))/( 2.00000*CONSTS(3)))*log(CONSTS(6)/ALGBRC(23))
      ALGBRC(35) =  CONSTS(32)*(STATES(1) - ALGBRC(25))
      ALGBRC(17) =  CONSTS(33)*(STATES(1) - CONSTS(46))
      ALGBRC(18) =  CONSTS(34)*(STATES(1) - CONSTS(45))
      RATES(1) =  (- 1.00000/CONSTS(35))*(ALGBRC(27)+ALGBRC(1)+ALGBRC(12)+ALGBRC(28)+ALGBRC(33)+CONSTS(48)+ALGBRC(34)+ALGBRC(35)+ALGBRC(17)+ALGBRC(18))
      RETURN
      END
      SUBROUTINE computeVariables(VOI, CONSTS, RATES, STATES, ALGBRC)
      REAL VOI, CONSTS(*), RATES(*), STATES(*), ALGBRC(*)
      ALGBRC(3) = 1.00000/(1.00000+EXP((STATES(1)+4.30000)/7.50000))
      ALGBRC(4) = 1.00000/(1.00000+EXP((STATES(1)+4.30000)/7.50000))
      ALGBRC(6) = 1.00000/(1.00000+EXP((23.0000+STATES(1))/6.60000))
      ALGBRC(2) = 1.00000/(1.00000+EXP((5.50000 - STATES(1))/6.00000))
      ALGBRC(9) = 0.00326200 -  3.55200e-05*STATES(1)
      ALGBRC(5) = ( 30.0000*(STATES(1)+18.0000))/(1.00000 - EXP( - 0.250000*(STATES(1)+18.0000)))
      ALGBRC(10) = ( 12.0000*(STATES(1)+18.0000))/(EXP( 0.100000*(STATES(1)+18.0000)) - 1.00000)
      ALGBRC(11) = 0.200250 -  0.000898750*STATES(1)
      ALGBRC(7) = 1.00000/(1.00000+EXP((STATES(1) - 69.8000)/- 11.9000))
      ALGBRC(19) = TERNRY(VOI.LT.CONSTS(39), 0.00000, ( (VOI - CONSTS(39))*CONSTS(36))/CONSTS(40))
      ALGBRC(20) = TERNRY(VOI.LT.CONSTS(39)+CONSTS(40), ALGBRC(19), 0.00000)
      ALGBRC(21) = TERNRY(VOI.LT.CONSTS(49), 0.00000,  CONSTS(36)*EXP(- (VOI - CONSTS(49))/CONSTS(44)))
      ALGBRC(22) = CONSTS(37)/(1.00000+EXP((VOI - (CONSTS(39)+CONSTS(42)+CONSTS(41)))/CONSTS(43))) - CONSTS(37)/(1.00000+EXP((VOI - (CONSTS(39)+CONSTS(42)))/CONSTS(43)))
      ALGBRC(23) = CONSTS(38)+ALGBRC(20)+ALGBRC(21)+ALGBRC(22)
      ALGBRC(15) =  0.850000*EXP( 0.0400000*STATES(1))
      ALGBRC(16) =  0.240000*EXP( - 0.0120000*STATES(1))
      ALGBRC(14) =  0.000275000*EXP(( - 1.51000*STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))
      ALGBRC(13) =  1.25000e-05*EXP(( - 1.99000*STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2)))
      ALGBRC(24) = (ALGBRC(23) ** 2.00000+ ALGBRC(13)*ALGBRC(23))/(ALGBRC(23) ** 2.00000+ ALGBRC(13)*ALGBRC(23)*(1.00000+CONSTS(20)/CONSTS(21))+( ALGBRC(13)*ALGBRC(14)*CONSTS(20))/CONSTS(21))
      ALGBRC(1) =  CONSTS(11)*(CONSTS(12)+ (STATES(3)+STATES(4))*(1.00000 - CONSTS(12)))*STATES(2) ** 2.00000*(STATES(1) - CONSTS(46))
      ALGBRC(8) = ( (STATES(1) - CONSTS(16))*CONSTS(3))/( CONSTS(1)*CONSTS(2)*(1.00000 - EXP(( - (STATES(1) - CONSTS(16))*2.00000*CONSTS(3))/( CONSTS(1)*CONSTS(2)))))
      ALGBRC(26) =  ALGBRC(8)*( ALGBRC(23)*EXP(CONSTS(16)/(( 0.500000*CONSTS(1)*CONSTS(2))/CONSTS(3))) -  CONSTS(6)*EXP(- (STATES(1) - CONSTS(16))/(( 0.500000*CONSTS(1)*CONSTS(2))/CONSTS(3))))
      ALGBRC(27) =  4.00000*CONSTS(15)*STATES(5)*STATES(6)*ALGBRC(26)
      ALGBRC(12) =  CONSTS(18)*STATES(7)*STATES(8)*(STATES(1) - CONSTS(46))
      ALGBRC(28) = ( CONSTS(22)*(STATES(1) - CONSTS(47))*1.00000)/(1.00000+CONSTS(23)/ALGBRC(23) ** CONSTS(24))
      ALGBRC(29) = 1.00000/(1.00000+CONSTS(26)/ALGBRC(23) ** 3.00000)
      ALGBRC(30) = ( (( STATES(9)*ALGBRC(29)*CONSTS(25)*STATES(1)*CONSTS(3) ** 2.00000)/( CONSTS(1)*CONSTS(2)))*( 0.750000*CONSTS(4)*EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) -  0.750000*CONSTS(5)))/(EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) - 1.00000)
      ALGBRC(31) = ( (( STATES(9)*ALGBRC(29)*CONSTS(25)*STATES(1)*CONSTS(3) ** 2.00000)/( CONSTS(1)*CONSTS(2)))*( 0.750000*CONSTS(7)*EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) -  0.750000*CONSTS(8)))/(EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) - 1.00000)
      ALGBRC(32) = ( (( STATES(9)*ALGBRC(29)*CONSTS(25)*4.00000*STATES(1)*CONSTS(3) ** 2.00000)/( CONSTS(1)*CONSTS(2)))*( 1.50000*ALGBRC(23)*EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) -  1.50000*CONSTS(6)))/(EXP(( STATES(1)*CONSTS(3))/( CONSTS(1)*CONSTS(2))) - 1.00000)
      ALGBRC(33) = ALGBRC(30)+ALGBRC(31)+ALGBRC(32)
      ALGBRC(34) = ( CONSTS(27)*ALGBRC(23))/(CONSTS(28)+ALGBRC(23))
      ALGBRC(25) =  (( CONSTS(1)*CONSTS(2))/( 2.00000*CONSTS(3)))*log(CONSTS(6)/ALGBRC(23))
      ALGBRC(35) =  CONSTS(32)*(STATES(1) - ALGBRC(25))
      ALGBRC(17) =  CONSTS(33)*(STATES(1) - CONSTS(46))
      ALGBRC(18) =  CONSTS(34)*(STATES(1) - CONSTS(45))
      RETURN
      END
      REAL FUNCTION TERNRY(TEST, VALA, VALB)
      LOGICAL TEST
      REAL VALA, VALB
      IF (TEST) THEN
        TERNRY = VALA
      ELSE
        TERNRY = VALB
      ENDIF
      RETURN
      END