C C There are a total of 4 entries in the algebraic variable array. C There are a total of 4 entries in each of the rate and state variable arrays. C There are a total of 14 entries in the constant variable array. C C C VOI is time in component environment (minute). C STATES(1) is r in component r (nanomolar). C ALGBRC(1) is Ir in component r (flux). C CONSTS(1) is k6 in component r (first_order_rate_constant). C STATES(2) is s in component s (nanomolar). C ALGBRC(2) is Is in component model_parameters (flux). C CONSTS(2) is k7 in component model_parameters (first_order_rate_constant). C STATES(3) is f in component f (dimensionless). C CONSTS(3) is k1 in component f (second_order_rate_constant). C CONSTS(4) is k2 in component f (first_order_rate_constant). C CONSTS(5) is k3 in component f (first_order_rate_constant). C ALGBRC(3) is phi_b_s in component f (dimensionless). C CONSTS(6) is sb in component f (dimensionless). C CONSTS(7) is delta_b in component f (dimensionless). C CONSTS(8) is c in component model_parameters (nanomolar). C STATES(4) is h in component h (nanomolar). C CONSTS(9) is k4 in component h (first_order_rate_constant). C CONSTS(10) is k5 in component h (first_order_rate_constant). C ALGBRC(4) is phi_r_s in component h (dimensionless). C CONSTS(11) is sr in component h (dimensionless). C CONSTS(12) is delta_r in component h (dimensionless). C CONSTS(13) is k8 in component model_parameters (first_order_rate_constant). C CONSTS(14) is j1 in component model_parameters (dimensionless). C RATES(1) is d/dt r in component r (nanomolar). C RATES(2) is d/dt s in component s (nanomolar). C RATES(3) is d/dt f in component f (dimensionless). C RATES(4) is d/dt h in component h (nanomolar). C SUBROUTINE initConsts(CONSTS, RATES, STATES) REAL CONSTS(*), RATES(*), STATES(*) STATES(1) = 0.0 CONSTS(1) = 5.0 STATES(2) = 0.0 CONSTS(2) = 5.0 STATES(3) = 0.3 CONSTS(3) = 0.1 CONSTS(4) = 0.002 CONSTS(5) = 0.018 CONSTS(6) = 0.029 CONSTS(7) = 0.3 CONSTS(8) = 0.01 STATES(4) = 0.0 CONSTS(9) = 9.0 CONSTS(10) = 71.0 CONSTS(11) = -0.56 CONSTS(12) = 0.3 CONSTS(13) = 0.07 CONSTS(14) = 10 RETURN END SUBROUTINE computeRates(VOI, CONSTS, RATES, STATES, ALGBRC) REAL VOI, CONSTS(*), RATES(*), STATES(*), ALGBRC(*) ALGBRC(1) = TERNRY(VOI.GE.0.00000.AND.VOI.LE.90.0000, 0.00000, TERNRY(VOI.GE.91.0000.AND.VOI.LE.92.0000, 10.0000, TERNRY(VOI.GE.93.0000.AND.VOI.LE.113.000, 0.00000, TERNRY(VOI.GE.114.000.AND.VOI.LE.115.000, 10.0000, TERNRY(VOI.GE.116.000.AND.VOI.LE.136.000, 0.00000, TERNRY(VOI.GE.137.000.AND.VOI.LE.138.000, 10.0000, TERNRY(VOI.GE.139.000.AND.VOI.LE.159.000, 0.00000, TERNRY(VOI.GE.160.000.AND.VOI.LE.161.000, 10.0000, TERNRY(VOI.GE.162.000.AND.VOI.LE.252.000, 0.00000, TERNRY(VOI.GE.253.000.AND.VOI.LE.254.000, 10.0000, TERNRY(VOI.GE.255.000.AND.VOI.LE.275.000, 0.00000, TERNRY(VOI.GE.276.000.AND.VOI.LE.277.000, 10.0000, TERNRY(VOI.GE.278.000.AND.VOI.LE.298.000, 0.00000, TERNRY(VOI.GE.299.000.AND.VOI.LE.300.000, 10.0000, TERNRY(VOI.GE.301.000.AND.VOI.LE.321.000, 0.00000, TERNRY(VOI.GE.322.000.AND.VOI.LE.323.000, 10.0000, 0.00000) RATES(1) = ALGBRC(1) - CONSTS(1)*STATES(1) ALGBRC(2) = TERNRY(VOI.GT.0.00000.AND.VOI.LE.90.0000, 10.0000, TERNRY(VOI.GT.90.0000.AND.VOI.LE.180.000, 0.00000, TERNRY(VOI.GT.180.000.AND.VOI.LE.270.000, 10.0000, TERNRY(VOI.GT.270.000.AND.VOI.LE.360.000, 0.00000, 0.00000) RATES(2) = ALGBRC(2) - CONSTS(2)*STATES(2) ALGBRC(3) = 1.00000/(1.00000+EXP(- (arbitrary_log( 1.00000*STATES(2), 10) - CONSTS(6))/CONSTS(7))) RATES(3) = - ( CONSTS(3)*(STATES(1)+CONSTS(8))*STATES(3))+ (CONSTS(4)+ CONSTS(5)*ALGBRC(3))*(1.00000 - STATES(3)) ALGBRC(4) = 1.00000/(1.00000+EXP(- (arbitrary_log( 1.00000*STATES(2), 10) - CONSTS(11))/CONSTS(12))) RATES(4) = CONSTS(14)*( (CONSTS(9)+ CONSTS(10)*(1.00000 - ALGBRC(4)))*( (STATES(1)+CONSTS(8))*STATES(3)) - CONSTS(13)*STATES(4)) RETURN END SUBROUTINE computeVariables(VOI, CONSTS, RATES, STATES, ALGBRC) REAL VOI, CONSTS(*), RATES(*), STATES(*), ALGBRC(*) ALGBRC(1) = TERNRY(VOI.GE.0.00000.AND.VOI.LE.90.0000, 0.00000, TERNRY(VOI.GE.91.0000.AND.VOI.LE.92.0000, 10.0000, TERNRY(VOI.GE.93.0000.AND.VOI.LE.113.000, 0.00000, TERNRY(VOI.GE.114.000.AND.VOI.LE.115.000, 10.0000, TERNRY(VOI.GE.116.000.AND.VOI.LE.136.000, 0.00000, TERNRY(VOI.GE.137.000.AND.VOI.LE.138.000, 10.0000, TERNRY(VOI.GE.139.000.AND.VOI.LE.159.000, 0.00000, TERNRY(VOI.GE.160.000.AND.VOI.LE.161.000, 10.0000, TERNRY(VOI.GE.162.000.AND.VOI.LE.252.000, 0.00000, TERNRY(VOI.GE.253.000.AND.VOI.LE.254.000, 10.0000, TERNRY(VOI.GE.255.000.AND.VOI.LE.275.000, 0.00000, TERNRY(VOI.GE.276.000.AND.VOI.LE.277.000, 10.0000, TERNRY(VOI.GE.278.000.AND.VOI.LE.298.000, 0.00000, TERNRY(VOI.GE.299.000.AND.VOI.LE.300.000, 10.0000, TERNRY(VOI.GE.301.000.AND.VOI.LE.321.000, 0.00000, TERNRY(VOI.GE.322.000.AND.VOI.LE.323.000, 10.0000, 0.00000) ALGBRC(2) = TERNRY(VOI.GT.0.00000.AND.VOI.LE.90.0000, 10.0000, TERNRY(VOI.GT.90.0000.AND.VOI.LE.180.000, 0.00000, TERNRY(VOI.GT.180.000.AND.VOI.LE.270.000, 10.0000, TERNRY(VOI.GT.270.000.AND.VOI.LE.360.000, 0.00000, 0.00000) ALGBRC(3) = 1.00000/(1.00000+EXP(- (arbitrary_log( 1.00000*STATES(2), 10) - CONSTS(6))/CONSTS(7))) ALGBRC(4) = 1.00000/(1.00000+EXP(- (arbitrary_log( 1.00000*STATES(2), 10) - CONSTS(11))/CONSTS(12))) RETURN END REAL FUNCTION TERNRY(TEST, VALA, VALB) LOGICAL TEST REAL VALA, VALB IF (TEST) THEN TERNRY = VALA ELSE TERNRY = VALB ENDIF RETURN END