Generated Code

The following is c code generated by the CellML API from this CellML file. (Back to language selection)

The raw code is available.

/*
   There are a total of 0 entries in the algebraic variable array.
   There are a total of 8 entries in each of the rate and state variable arrays.
   There are a total of 12 entries in the constant variable array.
 */
/*
 * VOI is t in component environment (s).
 * CONSTANTS[0] is km2 in component PIPtoDAG (um).
 * CONSTANTS[1] is km6 in component PIPtoDAG (um).
 * CONSTANTS[2] is Vmax2 in component PIPtoDAG (per_s).
 * CONSTANTS[3] is Vmax6 in component PIPtoDAG (per_s).
 * STATES[0] is PIP2 in component PIPtoDAG (um).
 * STATES[1] is DAG in component PIPtoDAG (um).
 * STATES[2] is IP3 in component PIPtoDAG (um).
 * STATES[3] is CaPLCg in component PLC (um).
 * STATES[4] is CaPLCg_star in component PLC (um).
 * CONSTANTS[4] is kf1 in component PLC (per_um_s).
 * CONSTANTS[5] is kb1 in component PLC (per_s).
 * CONSTANTS[6] is kf3 in component PLC (per_s).
 * CONSTANTS[7] is kf5 in component PLC (per_um_s).
 * CONSTANTS[8] is kb5 in component PLC (per_s).
 * CONSTANTS[9] is km4 in component PLC (um).
 * CONSTANTS[10] is Vmax4 in component PLC (per_s).
 * STATES[5] is PLCg in component PLC (um).
 * STATES[6] is PLCg_star in component PLC (um).
 * CONSTANTS[11] is EGF_EGFR in component UndefinedVariables (um).
 * STATES[7] is Ca in component PLC (um).
 * RATES[0] is d/dt PIP2 in component PIPtoDAG (um).
 * RATES[1] is d/dt DAG in component PIPtoDAG (um).
 * RATES[2] is d/dt IP3 in component PIPtoDAG (um).
 * RATES[5] is d/dt PLCg in component PLC (um).
 * RATES[3] is d/dt CaPLCg in component PLC (um).
 * RATES[4] is d/dt CaPLCg_star in component PLC (um).
 * RATES[6] is d/dt PLCg_star in component PLC (um).
 * RATES[7] is d/dt Ca in component PLC (um).
 */
void
initConsts(double* CONSTANTS, double* RATES, double *STATES)
{
CONSTANTS[0] = 97;
CONSTANTS[1] = 19.79166667;
CONSTANTS[2] = 14;
CONSTANTS[3] = 57;
STATES[0] = 10;
STATES[1] = 0;
STATES[2] = 0;
STATES[3] = 0;
STATES[4] = 0;
CONSTANTS[4] = 0.0003;
CONSTANTS[5] = 10;
CONSTANTS[6] = 0.05;
CONSTANTS[7] = 0.00002;
CONSTANTS[8] = 10;
CONSTANTS[9] = 0.33333333333;
CONSTANTS[10] = 0.2;
STATES[5] = 0.82;
STATES[6] = 0;
CONSTANTS[11] = 0.1;
STATES[7] = 0.1;
}
void
computeRates(double VOI, double* CONSTANTS, double* RATES, double* STATES, double* ALGEBRAIC)
{
RATES[0] = ( - STATES[3]*CONSTANTS[2]*STATES[0])/(CONSTANTS[0]+STATES[0]) - ( STATES[4]*CONSTANTS[3]*STATES[0])/(CONSTANTS[1]+STATES[0]);
RATES[1] = ( STATES[3]*CONSTANTS[2]*STATES[0])/(CONSTANTS[0]+STATES[0])+( STATES[4]*CONSTANTS[3]*STATES[0])/(CONSTANTS[1]+STATES[0]);
RATES[2] = ( STATES[3]*CONSTANTS[2]*STATES[0])/(CONSTANTS[0]+STATES[0])+( STATES[4]*CONSTANTS[3]*STATES[0])/(CONSTANTS[1]+STATES[0]);
RATES[5] =  - STATES[7]*STATES[5]*CONSTANTS[4]+ STATES[3]*CONSTANTS[5];
RATES[3] = (- ( - STATES[7]*STATES[5]*CONSTANTS[4]+ STATES[3]*CONSTANTS[5])+ CONSTANTS[6]*STATES[4]) - ( CONSTANTS[10]*CONSTANTS[11]*STATES[3])/(CONSTANTS[9]+STATES[3]);
RATES[4] = (- ( CONSTANTS[6]*STATES[4] - ( CONSTANTS[10]*CONSTANTS[11]*STATES[3])/(CONSTANTS[9]+STATES[3]))+ STATES[7]*STATES[6]*CONSTANTS[7]) -  CONSTANTS[8]*STATES[4];
RATES[6] =  - STATES[7]*STATES[6]*CONSTANTS[7]+ CONSTANTS[8]*STATES[4];
RATES[7] = ( - STATES[7]*STATES[5]*CONSTANTS[4]+ STATES[3]*CONSTANTS[5]+ CONSTANTS[8]*STATES[4]) -  STATES[7]*STATES[6]*CONSTANTS[7];
}
void
computeVariables(double VOI, double* CONSTANTS, double* RATES, double* STATES, double* ALGEBRAIC)
{
}