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 34 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 54 entries in the constant variable array.
C
C
C VOI is time in component environment (millisecond).
C CONSTS(1) is isotonic in component parameters (dimensionless).
C CONSTS(2) is alpha_1 in component parameters (per_um).
C CONSTS(3) is beta_1 in component parameters (mN).
C CONSTS(4) is alpha_2 in component parameters (per_um).
C CONSTS(5) is beta_2 in component parameters (mN).
C CONSTS(6) is alpha_3 in component parameters (per_um).
C CONSTS(7) is beta_3 in component parameters (mN).
C CONSTS(8) is lambda in component parameters (mN).
C CONSTS(9) is A_half in component parameters (dimensionless).
C CONSTS(10) is mu in component parameters (dimensionless).
C CONSTS(11) is chi in component parameters (dimensionless).
C CONSTS(12) is chi_0 in component parameters (dimensionless).
C CONSTS(13) is m_0 in component parameters (dimensionless).
C CONSTS(14) is v_max in component parameters (um_per_msec).
C CONSTS(15) is a in component parameters (dimensionless).
C CONSTS(16) is d_h in component parameters (dimensionless).
C CONSTS(17) is alpha_P in component parameters (dimensionless).
C ALGBRC(10) is l in component length (um).
C ALGBRC(6) is F_muscle in component force (mN).
C ALGBRC(12) is flag in component isotonic (dimensionless).
C CONSTS(18) is F_afterload in component isotonic (mN).
C ALGBRC(14) is isotonic_mode in component isotonic (dimensionless).
C CONSTS(19) is l_0 in component isotonic (um).
C CONSTS(20) is S_0 in component parameters_izakov_et_al_1991 (um).
C ALGBRC(1) is q_v in component parameters_izakov_et_al_1991 (per_millisecond).
C CONSTS(21) is q_1 in component parameters_izakov_et_al_1991 (per_millisecond).
C CONSTS(22) is q_2 in component parameters_izakov_et_al_1991 (per_millisecond).
C CONSTS(23) is q_3 in component parameters_izakov_et_al_1991 (per_millisecond).
C CONSTS(24) is q_4 in component parameters_izakov_et_al_1991 (per_millisecond).
C CONSTS(25) is v_star in component parameters_izakov_et_al_1991 (um_per_msec).
C CONSTS(51) is v_1 in component parameters_izakov_et_al_1991 (um_per_msec).
C CONSTS(26) is alpha_G in component parameters_izakov_et_al_1991 (dimensionless).
C CONSTS(27) is a_on in component parameters_izakov_et_al_1991 (per_millisecond).
C CONSTS(28) is a_off in component parameters_izakov_et_al_1991 (per_millisecond).
C CONSTS(29) is k_A in component parameters_izakov_et_al_1991 (dimensionless).
C STATES(1) is v in component CE_velocity (um_per_msec).
C CONSTS(30) is alpha_Q in component parameters_izakov_et_al_1991 (dimensionless).
C CONSTS(31) is beta_Q in component parameters_izakov_et_al_1991 (dimensionless).
C ALGBRC(32) is F_CE in component force (mN).
C ALGBRC(5) is F_XSE in component force (mN).
C ALGBRC(2) is F_SE in component force (mN).
C ALGBRC(3) is F_PE in component force (mN).
C STATES(2) is N in component crossbridge_kinetics (dimensionless).
C ALGBRC(18) is k_P_vis in component CE_velocity (mN_msec_per_um).
C ALGBRC(21) is k_S_vis in component PE_velocity (mN_msec_per_um).
C STATES(3) is w in component PE_velocity (um_per_msec).
C STATES(4) is l_1 in component length (um).
C STATES(5) is l_2 in component length (um).
C STATES(6) is l_3 in component length (um).
C ALGBRC(31) is p_v in component average_crossbridge_force (dimensionless).
C ALGBRC(28) is K_chi in component crossbridge_kinetics (per_millisecond).
C ALGBRC(7) is M_A in component crossbridge_kinetics (dimensionless).
C ALGBRC(8) is n_1 in component crossbridge_kinetics (dimensionless).
C ALGBRC(9) is L_oz in component crossbridge_kinetics (dimensionless).
C ALGBRC(26) is k_p_v in component crossbridge_kinetics (per_millisecond).
C ALGBRC(27) is k_m_v in component crossbridge_kinetics (per_millisecond).
C STATES(7) is A in component calcium_handling (dimensionless).
C ALGBRC(25) is G_star in component average_crossbridge_force (dimensionless).
C ALGBRC(22) is P_star in component average_crossbridge_force (dimensionless).
C CONSTS(32) is v_0 in component crossbridge_kinetics (um_per_msec).
C CONSTS(33) is q_star in component crossbridge_kinetics (per_millisecond).
C ALGBRC(4) is dl_1_dt in component length (um_per_msec).
C ALGBRC(23) is dl_2_dt in component length (um_per_msec).
C ALGBRC(24) is dl_3_dt in component length (um_per_msec).
C ALGBRC(19) is phi_chi_2 in component CE_velocity (um_per_msec).
C ALGBRC(34) is phi_chi in component CE_velocity (um_per_msec2).
C ALGBRC(33) is p_prime_v in component average_crossbridge_force (msec_per_um).
C CONSTS(34) is alpha_P_lengthening in component CE_velocity (per_um).
C CONSTS(35) is beta_P_lengthening in component CE_velocity (mN_msec_per_um).
C CONSTS(36) is alpha_P_shortening in component CE_velocity (per_um).
C CONSTS(37) is beta_P_shortening in component CE_velocity (mN_msec_per_um).
C ALGBRC(16) is alp_p in component CE_velocity (per_um).
C CONSTS(38) is alpha_S_lengthening in component PE_velocity (per_um).
C CONSTS(39) is beta_S_lengthening in component PE_velocity (mN_msec_per_um).
C CONSTS(40) is alpha_S_shortening in component PE_velocity (per_um).
C CONSTS(41) is beta_S_shortening in component PE_velocity (mN_msec_per_um).
C ALGBRC(20) is alp_s in component PE_velocity (per_um).
C CONSTS(54) is gamma in component average_crossbridge_force (dimensionless).
C CONSTS(52) is case_1 in component average_crossbridge_force (msec_per_um).
C ALGBRC(29) is case_2 in component average_crossbridge_force (msec_per_um).
C CONSTS(53) is case_3 in component average_crossbridge_force (msec_per_um).
C ALGBRC(30) is case_4 in component average_crossbridge_force (msec_per_um).
C ALGBRC(15) is dA_dt in component calcium_handling (per_millisecond).
C ALGBRC(11) is N_A in component calcium_handling (dimensionless).
C ALGBRC(13) is pi_N_A in component calcium_handling (dimensionless).
C STATES(8) is B in component calcium_handling (dimensionless).
C ALGBRC(17) is dB_dt in component calcium_handling (per_millisecond).
C STATES(9) is Ca_C in component calcium_handling (dimensionless).
C CONSTS(42) is A_tot in component calcium_handling (dimensionless).
C CONSTS(43) is B_tot in component calcium_handling (dimensionless).
C CONSTS(44) is b_on in component calcium_handling (per_millisecond).
C CONSTS(45) is b_off in component calcium_handling (per_millisecond).
C CONSTS(46) is a_c in component calcium_handling (per_millisecond2).
C CONSTS(47) is r_Ca in component calcium_handling (per_millisecond).
C CONSTS(48) is q_Ca in component calcium_handling (dimensionless).
C CONSTS(49) is t_d in component calcium_handling (millisecond).
C CONSTS(50) is Ca_m in component calcium_handling (dimensionless).
C RATES(2) is d/dt N in component crossbridge_kinetics (dimensionless).
C RATES(4) is d/dt l_1 in component length (um).
C RATES(5) is d/dt l_2 in component length (um).
C RATES(6) is d/dt l_3 in component length (um).
C RATES(1) is d/dt v in component CE_velocity (um_per_msec).
C RATES(3) is d/dt w in component PE_velocity (um_per_msec).
C RATES(7) is d/dt A in component calcium_handling (dimensionless).
C RATES(8) is d/dt B in component calcium_handling (dimensionless).
C RATES(9) is d/dt Ca_C in component calcium_handling (dimensionless).
C
      SUBROUTINE initConsts(CONSTS, RATES, STATES)
      REAL CONSTS(*), RATES(*), STATES(*)
      CONSTS(1) = 0
      CONSTS(2) = 19
      CONSTS(3) = 0.29
      CONSTS(4) = 14.6
      CONSTS(5) = 0.000924
      CONSTS(6) = 48
      CONSTS(7) = 0.01
      CONSTS(8) = 96
      CONSTS(9) = 0.6
      CONSTS(10) = 3
      CONSTS(11) = 0.705
      CONSTS(12) = 3
      CONSTS(13) = 0.9
      CONSTS(14) = 0.0056
      CONSTS(15) = 0.25
      CONSTS(16) = 0.5
      CONSTS(17) = 4
      CONSTS(18) = 2
      CONSTS(19) = 0.527
      CONSTS(20) = 1.14
      CONSTS(21) = 0.0173
      CONSTS(22) = 0.259
      CONSTS(23) = 0.0173
      CONSTS(24) = 0.015
      CONSTS(25) = 0.0053035675
      CONSTS(26) = 1
      CONSTS(27) = 2.3
      CONSTS(28) = 0.29
      CONSTS(29) = 2.8
      STATES(1) = 0
      CONSTS(30) = 10
      CONSTS(31) = 5000
      STATES(2) = 0.0001
      STATES(3) = 0
      STATES(4) = 0.437
      STATES(5) = 0.439
      STATES(6) = 0.089
      STATES(7) = 0.01
      CONSTS(32) = 0.0056
      CONSTS(33) = 1
      CONSTS(34) = 16
      CONSTS(35) = 1.5
      CONSTS(36) = 16
      CONSTS(37) = 1.5
      CONSTS(38) = 39
      CONSTS(39) = 8
      CONSTS(40) = 46
      CONSTS(41) = 6
      STATES(8) = 0
      STATES(9) = 0
      CONSTS(42) = 1
      CONSTS(43) = 0.4
      CONSTS(44) = 2.6
      CONSTS(45) = 0.182
      CONSTS(46) = 0.0052
      CONSTS(47) = 0.65
      CONSTS(48) = 50
      CONSTS(49) = 33
      CONSTS(50) = 0.03
      CONSTS(51) = CONSTS(14)/10.0000
      CONSTS(52) = ( CONSTS(15)*(0.400000+ 0.400000*CONSTS(15)))/( CONSTS(14)* (CONSTS(15)+1.00000)*0.400000 ** 2.00000)
      CONSTS(53) = ( 0.400000*CONSTS(15)+1.00000)/( CONSTS(15)*CONSTS(14))
      CONSTS(54) = ( CONSTS(15)*CONSTS(16)*CONSTS(51)/CONSTS(14) ** 2.00000)/( 3.00000*CONSTS(15)*CONSTS(16) - ( (CONSTS(15)+1.00000)*CONSTS(51))/CONSTS(14))
      RETURN
      END
      SUBROUTINE computeRates(VOI, CONSTS,  RATES, STATES, ALGBRC)
      REAL VOI, CONSTS(*), RATES(*), STATES(*), ALGBRC(*)
      ALGBRC(4) = STATES(1)
      RATES(4) = ALGBRC(4)
      ALGBRC(9) = (STATES(4)+CONSTS(20))/(0.460000+CONSTS(20))
      ALGBRC(11) = STATES(2)/( ALGBRC(9)*STATES(7))
      ALGBRC(13) = TERNRY(ALGBRC(11).GE.1.00000, 1.00000, 0.0200000 ** ALGBRC(11))
      ALGBRC(15) =  CONSTS(27)*(CONSTS(42) - STATES(7))*STATES(9) -  CONSTS(28)*EXP( - CONSTS(29)*STATES(7))*ALGBRC(13)*STATES(7)
      RATES(7) = ALGBRC(15)
      ALGBRC(17) =  CONSTS(44)*(CONSTS(43) - STATES(8))*STATES(9) -  CONSTS(45)*STATES(8)
      RATES(8) = ALGBRC(17)
      RATES(9) = TERNRY(VOI.LT.CONSTS(49),  4.00000*CONSTS(46)*CONSTS(50)*VOI*(1.00000 - EXP( - CONSTS(46)*VOI ** 2.00000))*EXP( - CONSTS(46)*VOI ** 2.00000), (- ALGBRC(15) - ALGBRC(17)) -  CONSTS(47)*EXP( - CONSTS(48)*STATES(9))*STATES(9))
      ALGBRC(21) = TERNRY(STATES(3).LE.STATES(1),  CONSTS(39)*EXP( CONSTS(38)*(STATES(5) - STATES(4))),  CONSTS(41)*EXP( CONSTS(40)*(STATES(5) - STATES(4))))
      ALGBRC(10) = STATES(5)+STATES(6)
      ALGBRC(5) =  CONSTS(7)*(EXP( CONSTS(6)*STATES(6)) - 1.00000)
      ALGBRC(6) = ALGBRC(5)
      ALGBRC(12) = TERNRY(ALGBRC(10).GE.CONSTS(19).AND.VOI.LT.150.000, 0.00000, 1.00000)
      ALGBRC(14) = TERNRY(CONSTS(1).EQ.0.00000, 0.00000, TERNRY(CONSTS(1).EQ.1.00000.AND.ALGBRC(6).GE.CONSTS(18), 1.00000, TERNRY(CONSTS(1).EQ.1.00000.AND.ALGBRC(10).GE.CONSTS(19).AND.ALGBRC(12).EQ.1.00000, 0.00000, 0.0/0.0)
      ALGBRC(19) = TERNRY(ALGBRC(14).EQ.1.00000, ( CONSTS(2)*CONSTS(3)*EXP( CONSTS(2)*(STATES(5) - STATES(4)))*STATES(1))/( CONSTS(2)*CONSTS(3)*EXP( CONSTS(2)*(STATES(5) - STATES(4)))+ CONSTS(4)*CONSTS(5)*EXP( CONSTS(4)*STATES(5))), ( CONSTS(2)*CONSTS(3)*EXP( CONSTS(2)*(STATES(5) - STATES(4)))*STATES(1))/( CONSTS(2)*CONSTS(3)*EXP( CONSTS(2)*(STATES(5) - STATES(4)))+ CONSTS(4)*CONSTS(5)*EXP( CONSTS(4)*STATES(5))+ CONSTS(6)*CONSTS(7)*EXP( CONSTS(6)*STATES(6))))
      ALGBRC(23) = TERNRY(ALGBRC(21).EQ.0.00000, ALGBRC(19), STATES(3))
      RATES(5) = ALGBRC(23)
      ALGBRC(24) = TERNRY(ALGBRC(14).EQ.1.00000, 0.00000, TERNRY(ALGBRC(14).EQ.0.00000.AND.ALGBRC(21).EQ.0.00000, - ALGBRC(19), - STATES(3))
      RATES(6) = ALGBRC(24)
      ALGBRC(7) = STATES(7) ** CONSTS(10)/(STATES(7) ** CONSTS(10)+CONSTS(9) ** CONSTS(10))
      ALGBRC(8) =  0.600000*STATES(4)+0.500000
      ALGBRC(1) = TERNRY(STATES(1).LE.0.00000, CONSTS(21) - ( CONSTS(22)*STATES(1))/CONSTS(14), TERNRY(STATES(1).LE.CONSTS(25).AND.0.00000.LT.STATES(1), ( (CONSTS(24) - CONSTS(23))*STATES(1))/CONSTS(25)+CONSTS(23), CONSTS(24)/1.00000+( CONSTS(31)*(STATES(1) - CONSTS(25)))/CONSTS(14) ** CONSTS(30))
      ALGBRC(22) = TERNRY(STATES(1).LE.0.00000, ( CONSTS(15)*(1.00000+STATES(1)/CONSTS(14)))/(CONSTS(15) - STATES(1)/CONSTS(14)), (1.00000+CONSTS(16)) - ( CONSTS(16) ** 2.00000*CONSTS(15))/( (( CONSTS(15)*CONSTS(16))/CONSTS(54))*STATES(1)/CONSTS(14) ** 2.00000+( (CONSTS(15)+1.00000)*STATES(1))/CONSTS(14)+ CONSTS(15)*CONSTS(16)))
      ALGBRC(25) = TERNRY(- CONSTS(14).LE.STATES(1).AND.STATES(1).LE.0.00000, 1.00000+( 0.600000*STATES(1))/CONSTS(14), TERNRY(0.00000.LT.STATES(1).AND.STATES(1).LE.CONSTS(51), ALGBRC(22)/(( ( 0.400000*CONSTS(15)+1.00000)*STATES(1))/( CONSTS(15)*CONSTS(14))+1.00000), ( ALGBRC(22)*EXP( - CONSTS(26)*(STATES(1) - CONSTS(51))/CONSTS(14) ** CONSTS(17)))/(( ( 0.400000*CONSTS(15)+1.00000)*STATES(1))/( CONSTS(15)*CONSTS(14))+1.00000))
      ALGBRC(26) =  CONSTS(11)*CONSTS(12)*ALGBRC(1)*CONSTS(13)*ALGBRC(25)
      ALGBRC(27) = TERNRY(STATES(1).LE.CONSTS(25),  CONSTS(12)*ALGBRC(1)*(1.00000 -  CONSTS(11)*CONSTS(13)*ALGBRC(25)),  CONSTS(12)*( CONSTS(24)*(1.00000 -  CONSTS(11)*CONSTS(13)*ALGBRC(25))+( CONSTS(33)*(STATES(1) - CONSTS(25)))/(CONSTS(32) - CONSTS(25))))
      ALGBRC(28) =  ALGBRC(26)*ALGBRC(7)*ALGBRC(8)*ALGBRC(9)*(1.00000 - STATES(2)) -  ALGBRC(27)*STATES(2)
      RATES(2) = ALGBRC(28)
      ALGBRC(18) = TERNRY(STATES(1).LE.0.00000,  CONSTS(35)*EXP( CONSTS(34)*STATES(4)),  CONSTS(37)*EXP( CONSTS(36)*STATES(4)))
      ALGBRC(31) = ALGBRC(22)/ALGBRC(25)
      ALGBRC(29) = ( CONSTS(15)*1.00000*(1.00000+ 0.400000*CONSTS(15)+( 1.20000*STATES(1))/CONSTS(14)+ 0.600000*STATES(1)/CONSTS(14) ** 2.00000))/( CONSTS(14)* (CONSTS(15) - STATES(1)/CONSTS(14))*(1.00000+( 0.600000*STATES(1))/CONSTS(14)) ** 2.00000)
      ALGBRC(30) =  (1.00000/CONSTS(14))*EXP( - CONSTS(26)*STATES(1)/CONSTS(14) - CONSTS(51)/CONSTS(14) ** CONSTS(17))*(( 0.400000*CONSTS(15)+1.00000)/CONSTS(15)+ CONSTS(26)*CONSTS(17)*(1.00000+( ( 0.400000*CONSTS(15)+1.00000)*STATES(1))/( CONSTS(15)*CONSTS(14)))*STATES(1)/CONSTS(14) - CONSTS(51)/CONSTS(14) ** CONSTS(17) - 1.00000)
      ALGBRC(33) = TERNRY(STATES(1).LE.- CONSTS(14), CONSTS(52), TERNRY(- CONSTS(14).LT.STATES(1).AND.STATES(1).LE.0.00000, ALGBRC(29), TERNRY(0.00000.LT.STATES(1).AND.STATES(1).LE.CONSTS(51), CONSTS(53), ALGBRC(30))
      ALGBRC(16) = TERNRY(STATES(1).LE.0.00000, CONSTS(34), CONSTS(36))
      ALGBRC(34) = TERNRY(ALGBRC(14).EQ.1.00000, - ( CONSTS(8)*ALGBRC(28)*ALGBRC(31)+ ALGBRC(16)*ALGBRC(18)*STATES(1) ** 2.00000+ CONSTS(4)*CONSTS(5)*EXP( CONSTS(4)*STATES(5))*STATES(3))/( CONSTS(8)*STATES(2)*ALGBRC(33)+ALGBRC(18)), - ( CONSTS(8)*ALGBRC(28)*ALGBRC(31)+ ALGBRC(16)*ALGBRC(18)*STATES(1) ** 2.00000+ ( CONSTS(4)*CONSTS(5)*EXP( CONSTS(4)*STATES(5))+ CONSTS(6)*CONSTS(7)*EXP( CONSTS(6)*STATES(6)))*STATES(3))/( CONSTS(8)*STATES(2)*ALGBRC(33)+ALGBRC(18)))
      RATES(1) = TERNRY(ALGBRC(21).EQ.0.00000, ( CONSTS(2)*CONSTS(3)*EXP( CONSTS(2)*(STATES(5) - STATES(4)))*(ALGBRC(19) - STATES(1)) - ( CONSTS(8)*ALGBRC(28)*ALGBRC(31)+ ALGBRC(16)*ALGBRC(18)*STATES(1) ** 2.00000))/( CONSTS(8)*STATES(2)*ALGBRC(33)+ALGBRC(18)), ALGBRC(34))
      ALGBRC(20) = TERNRY(STATES(3).LE.STATES(1), CONSTS(38), CONSTS(40))
      RATES(3) = TERNRY(ALGBRC(14).EQ.1.00000, (( ALGBRC(21)*(ALGBRC(34) -  ALGBRC(20)*STATES(3) - STATES(1) ** 2.00000) -  CONSTS(2)*CONSTS(3)*EXP( CONSTS(2)*(STATES(5) - STATES(4)))*(STATES(3) - STATES(1))) -  CONSTS(4)*CONSTS(5)*EXP( CONSTS(4)*STATES(5))*STATES(3))/ALGBRC(21), (ALGBRC(34) -  ALGBRC(20)*STATES(3) - STATES(1) ** 2.00000) - ( CONSTS(2)*CONSTS(3)*EXP( CONSTS(2)*(STATES(5) - STATES(4)))*(STATES(3) - STATES(1))+ ( CONSTS(4)*CONSTS(5)*EXP( CONSTS(4)*STATES(5))+ CONSTS(6)*CONSTS(7)*EXP( CONSTS(6)*STATES(6)))*STATES(3))/ALGBRC(21))
      RETURN
      END
      SUBROUTINE computeVariables(VOI, CONSTS, RATES, STATES, ALGBRC)
      REAL VOI, CONSTS(*), RATES(*), STATES(*), ALGBRC(*)
      ALGBRC(4) = STATES(1)
      ALGBRC(9) = (STATES(4)+CONSTS(20))/(0.460000+CONSTS(20))
      ALGBRC(11) = STATES(2)/( ALGBRC(9)*STATES(7))
      ALGBRC(13) = TERNRY(ALGBRC(11).GE.1.00000, 1.00000, 0.0200000 ** ALGBRC(11))
      ALGBRC(15) =  CONSTS(27)*(CONSTS(42) - STATES(7))*STATES(9) -  CONSTS(28)*EXP( - CONSTS(29)*STATES(7))*ALGBRC(13)*STATES(7)
      ALGBRC(17) =  CONSTS(44)*(CONSTS(43) - STATES(8))*STATES(9) -  CONSTS(45)*STATES(8)
      ALGBRC(21) = TERNRY(STATES(3).LE.STATES(1),  CONSTS(39)*EXP( CONSTS(38)*(STATES(5) - STATES(4))),  CONSTS(41)*EXP( CONSTS(40)*(STATES(5) - STATES(4))))
      ALGBRC(10) = STATES(5)+STATES(6)
      ALGBRC(5) =  CONSTS(7)*(EXP( CONSTS(6)*STATES(6)) - 1.00000)
      ALGBRC(6) = ALGBRC(5)
      ALGBRC(12) = TERNRY(ALGBRC(10).GE.CONSTS(19).AND.VOI.LT.150.000, 0.00000, 1.00000)
      ALGBRC(14) = TERNRY(CONSTS(1).EQ.0.00000, 0.00000, TERNRY(CONSTS(1).EQ.1.00000.AND.ALGBRC(6).GE.CONSTS(18), 1.00000, TERNRY(CONSTS(1).EQ.1.00000.AND.ALGBRC(10).GE.CONSTS(19).AND.ALGBRC(12).EQ.1.00000, 0.00000, 0.0/0.0)
      ALGBRC(19) = TERNRY(ALGBRC(14).EQ.1.00000, ( CONSTS(2)*CONSTS(3)*EXP( CONSTS(2)*(STATES(5) - STATES(4)))*STATES(1))/( CONSTS(2)*CONSTS(3)*EXP( CONSTS(2)*(STATES(5) - STATES(4)))+ CONSTS(4)*CONSTS(5)*EXP( CONSTS(4)*STATES(5))), ( CONSTS(2)*CONSTS(3)*EXP( CONSTS(2)*(STATES(5) - STATES(4)))*STATES(1))/( CONSTS(2)*CONSTS(3)*EXP( CONSTS(2)*(STATES(5) - STATES(4)))+ CONSTS(4)*CONSTS(5)*EXP( CONSTS(4)*STATES(5))+ CONSTS(6)*CONSTS(7)*EXP( CONSTS(6)*STATES(6))))
      ALGBRC(23) = TERNRY(ALGBRC(21).EQ.0.00000, ALGBRC(19), STATES(3))
      ALGBRC(24) = TERNRY(ALGBRC(14).EQ.1.00000, 0.00000, TERNRY(ALGBRC(14).EQ.0.00000.AND.ALGBRC(21).EQ.0.00000, - ALGBRC(19), - STATES(3))
      ALGBRC(7) = STATES(7) ** CONSTS(10)/(STATES(7) ** CONSTS(10)+CONSTS(9) ** CONSTS(10))
      ALGBRC(8) =  0.600000*STATES(4)+0.500000
      ALGBRC(1) = TERNRY(STATES(1).LE.0.00000, CONSTS(21) - ( CONSTS(22)*STATES(1))/CONSTS(14), TERNRY(STATES(1).LE.CONSTS(25).AND.0.00000.LT.STATES(1), ( (CONSTS(24) - CONSTS(23))*STATES(1))/CONSTS(25)+CONSTS(23), CONSTS(24)/1.00000+( CONSTS(31)*(STATES(1) - CONSTS(25)))/CONSTS(14) ** CONSTS(30))
      ALGBRC(22) = TERNRY(STATES(1).LE.0.00000, ( CONSTS(15)*(1.00000+STATES(1)/CONSTS(14)))/(CONSTS(15) - STATES(1)/CONSTS(14)), (1.00000+CONSTS(16)) - ( CONSTS(16) ** 2.00000*CONSTS(15))/( (( CONSTS(15)*CONSTS(16))/CONSTS(54))*STATES(1)/CONSTS(14) ** 2.00000+( (CONSTS(15)+1.00000)*STATES(1))/CONSTS(14)+ CONSTS(15)*CONSTS(16)))
      ALGBRC(25) = TERNRY(- CONSTS(14).LE.STATES(1).AND.STATES(1).LE.0.00000, 1.00000+( 0.600000*STATES(1))/CONSTS(14), TERNRY(0.00000.LT.STATES(1).AND.STATES(1).LE.CONSTS(51), ALGBRC(22)/(( ( 0.400000*CONSTS(15)+1.00000)*STATES(1))/( CONSTS(15)*CONSTS(14))+1.00000), ( ALGBRC(22)*EXP( - CONSTS(26)*(STATES(1) - CONSTS(51))/CONSTS(14) ** CONSTS(17)))/(( ( 0.400000*CONSTS(15)+1.00000)*STATES(1))/( CONSTS(15)*CONSTS(14))+1.00000))
      ALGBRC(26) =  CONSTS(11)*CONSTS(12)*ALGBRC(1)*CONSTS(13)*ALGBRC(25)
      ALGBRC(27) = TERNRY(STATES(1).LE.CONSTS(25),  CONSTS(12)*ALGBRC(1)*(1.00000 -  CONSTS(11)*CONSTS(13)*ALGBRC(25)),  CONSTS(12)*( CONSTS(24)*(1.00000 -  CONSTS(11)*CONSTS(13)*ALGBRC(25))+( CONSTS(33)*(STATES(1) - CONSTS(25)))/(CONSTS(32) - CONSTS(25))))
      ALGBRC(28) =  ALGBRC(26)*ALGBRC(7)*ALGBRC(8)*ALGBRC(9)*(1.00000 - STATES(2)) -  ALGBRC(27)*STATES(2)
      ALGBRC(18) = TERNRY(STATES(1).LE.0.00000,  CONSTS(35)*EXP( CONSTS(34)*STATES(4)),  CONSTS(37)*EXP( CONSTS(36)*STATES(4)))
      ALGBRC(31) = ALGBRC(22)/ALGBRC(25)
      ALGBRC(29) = ( CONSTS(15)*1.00000*(1.00000+ 0.400000*CONSTS(15)+( 1.20000*STATES(1))/CONSTS(14)+ 0.600000*STATES(1)/CONSTS(14) ** 2.00000))/( CONSTS(14)* (CONSTS(15) - STATES(1)/CONSTS(14))*(1.00000+( 0.600000*STATES(1))/CONSTS(14)) ** 2.00000)
      ALGBRC(30) =  (1.00000/CONSTS(14))*EXP( - CONSTS(26)*STATES(1)/CONSTS(14) - CONSTS(51)/CONSTS(14) ** CONSTS(17))*(( 0.400000*CONSTS(15)+1.00000)/CONSTS(15)+ CONSTS(26)*CONSTS(17)*(1.00000+( ( 0.400000*CONSTS(15)+1.00000)*STATES(1))/( CONSTS(15)*CONSTS(14)))*STATES(1)/CONSTS(14) - CONSTS(51)/CONSTS(14) ** CONSTS(17) - 1.00000)
      ALGBRC(33) = TERNRY(STATES(1).LE.- CONSTS(14), CONSTS(52), TERNRY(- CONSTS(14).LT.STATES(1).AND.STATES(1).LE.0.00000, ALGBRC(29), TERNRY(0.00000.LT.STATES(1).AND.STATES(1).LE.CONSTS(51), CONSTS(53), ALGBRC(30))
      ALGBRC(16) = TERNRY(STATES(1).LE.0.00000, CONSTS(34), CONSTS(36))
      ALGBRC(34) = TERNRY(ALGBRC(14).EQ.1.00000, - ( CONSTS(8)*ALGBRC(28)*ALGBRC(31)+ ALGBRC(16)*ALGBRC(18)*STATES(1) ** 2.00000+ CONSTS(4)*CONSTS(5)*EXP( CONSTS(4)*STATES(5))*STATES(3))/( CONSTS(8)*STATES(2)*ALGBRC(33)+ALGBRC(18)), - ( CONSTS(8)*ALGBRC(28)*ALGBRC(31)+ ALGBRC(16)*ALGBRC(18)*STATES(1) ** 2.00000+ ( CONSTS(4)*CONSTS(5)*EXP( CONSTS(4)*STATES(5))+ CONSTS(6)*CONSTS(7)*EXP( CONSTS(6)*STATES(6)))*STATES(3))/( CONSTS(8)*STATES(2)*ALGBRC(33)+ALGBRC(18)))
      ALGBRC(20) = TERNRY(STATES(3).LE.STATES(1), CONSTS(38), CONSTS(40))
      ALGBRC(2) =  CONSTS(3)*(EXP( CONSTS(2)*(STATES(5) - STATES(4))) - 1.00000)
      ALGBRC(3) =  CONSTS(5)*(EXP( CONSTS(4)*STATES(5)) - 1.00000)
      ALGBRC(32) =  CONSTS(8)*ALGBRC(31)*STATES(2)
      RETURN
      END
      REAL FUNCTION TERNRY(TEST, VALA, VALB)
      LOGICAL TEST
      REAL VALA, VALB
      IF (TEST) THEN
        TERNRY = VALA
      ELSE
        TERNRY = VALB
      ENDIF
      RETURN
      END