C C There are a total of 15 entries in the algebraic variable array. C There are a total of 5 entries in each of the rate and state variable arrays. C There are a total of 24 entries in the constant variable array. C C C VOI is time in component environment (minute). C STATES(1) is y0 in component y0 (dimensionless). C ALGBRC(11) is g0 in component y0 (dimensionless). C ALGBRC(6) is r0 in component y0 (dimensionless). C ALGBRC(1) is h0 in component y0 (dimensionless). C CONSTS(1) is S0 in component y0 (dimensionless). C STATES(2) is y2 in component y2 (dimensionless). C CONSTS(2) is a00 in component model_parameters (dimensionless). C CONSTS(3) is a02 in component model_parameters (dimensionless). C CONSTS(4) is c0 in component model_parameters (first_order_rate_constant). C CONSTS(5) is e0 in component model_parameters (first_order_rate_constant). C CONSTS(6) is epsilon in component model_parameters (dimensionless). C STATES(3) is y1 in component y1 (dimensionless). C ALGBRC(12) is g1 in component y1 (dimensionless). C ALGBRC(7) is r1 in component y1 (dimensionless). C ALGBRC(2) is h1 in component y1 (dimensionless). C CONSTS(7) is S1 in component y1 (dimensionless). C CONSTS(8) is a10 in component model_parameters (dimensionless). C CONSTS(9) is a12 in component model_parameters (dimensionless). C CONSTS(10) is a11 in component model_parameters (dimensionless). C CONSTS(11) is e1 in component model_parameters (first_order_rate_constant). C ALGBRC(13) is g2 in component y2 (dimensionless). C ALGBRC(8) is r2 in component y2 (dimensionless). C ALGBRC(3) is h2 in component y2 (dimensionless). C CONSTS(12) is S2 in component y2 (dimensionless). C STATES(4) is y3 in component y3 (dimensionless). C STATES(5) is y4 in component y4 (dimensionless). C CONSTS(13) is a23 in component model_parameters (dimensionless). C CONSTS(14) is a24 in component model_parameters (dimensionless). C CONSTS(15) is a20 in component model_parameters (dimensionless). C CONSTS(16) is a21 in component model_parameters (dimensionless). C CONSTS(17) is a22 in component model_parameters (dimensionless). C CONSTS(18) is e2 in component model_parameters (first_order_rate_constant). C ALGBRC(14) is g3 in component y3 (dimensionless). C ALGBRC(9) is r3 in component y3 (dimensionless). C ALGBRC(4) is h3 in component y3 (dimensionless). C CONSTS(19) is S3 in component y3 (dimensionless). C CONSTS(20) is a32 in component model_parameters (dimensionless). C CONSTS(21) is a33 in component model_parameters (dimensionless). C ALGBRC(15) is g4 in component y4 (dimensionless). C ALGBRC(10) is r4 in component y4 (dimensionless). C ALGBRC(5) is h4 in component y4 (dimensionless). C CONSTS(22) is S4 in component y4 (dimensionless). C CONSTS(23) is a42 in component model_parameters (dimensionless). C CONSTS(24) is a44 in component model_parameters (dimensionless). C RATES(1) is d/dt y0 in component y0 (dimensionless). C RATES(3) is d/dt y1 in component y1 (dimensionless). C RATES(2) is d/dt y2 in component y2 (dimensionless). C RATES(4) is d/dt y3 in component y3 (dimensionless). C RATES(5) is d/dt y4 in component y4 (dimensionless). C SUBROUTINE initConsts(CONSTS, RATES, STATES) REAL CONSTS(*), RATES(*), STATES(*) STATES(1) = 0.4 CONSTS(1) = 0.010 STATES(2) = 1.17 CONSTS(2) = -0.00843 CONSTS(3) = -0.440 CONSTS(4) = 0.443 CONSTS(5) = 0.0 CONSTS(6) = 0.50 STATES(3) = 1.4 CONSTS(7) = 0.010 CONSTS(8) = 0.082 CONSTS(9) = -0.0668 CONSTS(10) = -0.0040 CONSTS(11) = 0.0 CONSTS(12) = 0.010 STATES(4) = 0.95 STATES(5) = 0.65 CONSTS(13) = 0.0576 CONSTS(14) = 3.25E-4 CONSTS(15) = 0.0 CONSTS(16) = 0.0310 CONSTS(17) = -0.0957 CONSTS(18) = 0.0 CONSTS(19) = 0.010 CONSTS(20) = 0.00869 CONSTS(21) = -0.00857 CONSTS(22) = 0.010 CONSTS(23) = 1.39E-4 CONSTS(24) = -1.43E-4 RETURN END SUBROUTINE computeRates(VOI, CONSTS, RATES, STATES, ALGBRC) REAL VOI, CONSTS(*), RATES(*), STATES(*), ALGBRC(*) ALGBRC(6) = TERNRY(STATES(1).LT.CONSTS(6).AND. CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2).LT.0.00000, 1.00000 - EXP(( CONSTS(1)*STATES(1) ** 2.00000)/( ( CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2))*CONSTS(6) - STATES(1) ** 2.00000)), 1.00000) ALGBRC(1) = TERNRY( CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2).GT.0.00000, ( CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2))/(1.00000+ (( CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2))/CONSTS(1))*(1.00000 - EXP(- (( CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2))/CONSTS(1))))), TERNRY( CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2).LE.0.00000, CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2), 0.0/0.0) ALGBRC(11) = ALGBRC(1)*ALGBRC(6) RATES(1) = 1.00000*ALGBRC(11)+CONSTS(4)+CONSTS(5) ALGBRC(7) = TERNRY(STATES(3).LT.CONSTS(6).AND. CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2).LT.0.00000, 1.00000 - EXP(( CONSTS(7)*STATES(3) ** 2.00000)/( ( CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2))*CONSTS(6) - STATES(3) ** 2.00000)), 1.00000) ALGBRC(2) = TERNRY( CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2).GT.0.00000, ( CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2))/(1.00000+ (( CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2))/CONSTS(7))*(1.00000 - EXP(- (( CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2))/CONSTS(7))))), TERNRY( CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2).LE.0.00000, CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2), 0.0/0.0) ALGBRC(12) = ALGBRC(2)*ALGBRC(7) RATES(3) = 1.00000*ALGBRC(12)+CONSTS(11) ALGBRC(8) = TERNRY(STATES(2).LT.CONSTS(6).AND. CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5).LT.0.00000, 1.00000 - EXP(( CONSTS(12)*STATES(2) ** 2.00000)/( ( CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5))*CONSTS(6) - STATES(2) ** 2.00000)), 1.00000) ALGBRC(3) = TERNRY( CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5).GT.0.00000, ( CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5))/(1.00000+ (( CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5))/CONSTS(12))*(1.00000 - EXP(- (( CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5))/CONSTS(12))))), TERNRY( CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5).LE.0.00000, CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5), 0.0/0.0) ALGBRC(13) = ALGBRC(3)*ALGBRC(8) RATES(2) = 1.00000*ALGBRC(13)+CONSTS(18) ALGBRC(9) = TERNRY(STATES(4).LT.CONSTS(6).AND. CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4).LT.0.00000, 1.00000 - EXP(( CONSTS(19)*STATES(4) ** 2.00000)/( ( CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4))*CONSTS(6) - STATES(4) ** 2.00000)), 1.00000) ALGBRC(4) = TERNRY( CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4).GT.0.00000, ( CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4))/(1.00000+ (( CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4))/CONSTS(19))*(1.00000 - EXP(- (( CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4))/CONSTS(19))))), TERNRY( CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4).LE.0.00000, CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4), 0.0/0.0) ALGBRC(14) = ALGBRC(4)*ALGBRC(9) RATES(4) = 1.00000*ALGBRC(14) ALGBRC(10) = TERNRY(STATES(5).LT.CONSTS(6).AND. CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5).LT.0.00000, 1.00000 - EXP(( CONSTS(22)*STATES(5) ** 2.00000)/( ( CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5))*CONSTS(6) - STATES(5) ** 2.00000)), 1.00000) ALGBRC(5) = TERNRY( CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5).GT.0.00000, ( CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5))/(1.00000+ (( CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5))/CONSTS(22))*(1.00000 - EXP(- (( CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5))/CONSTS(22))))), TERNRY( CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5).LE.0.00000, CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5), 0.0/0.0) ALGBRC(15) = ALGBRC(5)*ALGBRC(10) RATES(5) = 1.00000*ALGBRC(15) RETURN END SUBROUTINE computeVariables(VOI, CONSTS, RATES, STATES, ALGBRC) REAL VOI, CONSTS(*), RATES(*), STATES(*), ALGBRC(*) ALGBRC(6) = TERNRY(STATES(1).LT.CONSTS(6).AND. CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2).LT.0.00000, 1.00000 - EXP(( CONSTS(1)*STATES(1) ** 2.00000)/( ( CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2))*CONSTS(6) - STATES(1) ** 2.00000)), 1.00000) ALGBRC(1) = TERNRY( CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2).GT.0.00000, ( CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2))/(1.00000+ (( CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2))/CONSTS(1))*(1.00000 - EXP(- (( CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2))/CONSTS(1))))), TERNRY( CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2).LE.0.00000, CONSTS(2)*STATES(1)+ CONSTS(3)*STATES(2), 0.0/0.0) ALGBRC(11) = ALGBRC(1)*ALGBRC(6) ALGBRC(7) = TERNRY(STATES(3).LT.CONSTS(6).AND. CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2).LT.0.00000, 1.00000 - EXP(( CONSTS(7)*STATES(3) ** 2.00000)/( ( CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2))*CONSTS(6) - STATES(3) ** 2.00000)), 1.00000) ALGBRC(2) = TERNRY( CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2).GT.0.00000, ( CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2))/(1.00000+ (( CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2))/CONSTS(7))*(1.00000 - EXP(- (( CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2))/CONSTS(7))))), TERNRY( CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2).LE.0.00000, CONSTS(8)*STATES(1)+ CONSTS(10)*STATES(3)+ CONSTS(9)*STATES(2), 0.0/0.0) ALGBRC(12) = ALGBRC(2)*ALGBRC(7) ALGBRC(8) = TERNRY(STATES(2).LT.CONSTS(6).AND. CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5).LT.0.00000, 1.00000 - EXP(( CONSTS(12)*STATES(2) ** 2.00000)/( ( CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5))*CONSTS(6) - STATES(2) ** 2.00000)), 1.00000) ALGBRC(3) = TERNRY( CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5).GT.0.00000, ( CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5))/(1.00000+ (( CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5))/CONSTS(12))*(1.00000 - EXP(- (( CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5))/CONSTS(12))))), TERNRY( CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5).LE.0.00000, CONSTS(15)*STATES(1)+ CONSTS(16)*STATES(3)+ CONSTS(17)*STATES(2)+ CONSTS(13)*STATES(4)+ CONSTS(14)*STATES(5), 0.0/0.0) ALGBRC(13) = ALGBRC(3)*ALGBRC(8) ALGBRC(9) = TERNRY(STATES(4).LT.CONSTS(6).AND. CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4).LT.0.00000, 1.00000 - EXP(( CONSTS(19)*STATES(4) ** 2.00000)/( ( CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4))*CONSTS(6) - STATES(4) ** 2.00000)), 1.00000) ALGBRC(4) = TERNRY( CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4).GT.0.00000, ( CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4))/(1.00000+ (( CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4))/CONSTS(19))*(1.00000 - EXP(- (( CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4))/CONSTS(19))))), TERNRY( CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4).LE.0.00000, CONSTS(20)*STATES(2)+ CONSTS(21)*STATES(4), 0.0/0.0) ALGBRC(14) = ALGBRC(4)*ALGBRC(9) ALGBRC(10) = TERNRY(STATES(5).LT.CONSTS(6).AND. CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5).LT.0.00000, 1.00000 - EXP(( CONSTS(22)*STATES(5) ** 2.00000)/( ( CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5))*CONSTS(6) - STATES(5) ** 2.00000)), 1.00000) ALGBRC(5) = TERNRY( CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5).GT.0.00000, ( CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5))/(1.00000+ (( CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5))/CONSTS(22))*(1.00000 - EXP(- (( CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5))/CONSTS(22))))), TERNRY( CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5).LE.0.00000, CONSTS(23)*STATES(2)+ CONSTS(24)*STATES(5), 0.0/0.0) ALGBRC(15) = ALGBRC(5)*ALGBRC(10) RETURN END REAL FUNCTION TERNRY(TEST, VALA, VALB) LOGICAL TEST REAL VALA, VALB IF (TEST) THEN TERNRY = VALA ELSE TERNRY = VALB ENDIF RETURN END