Generated Code

The following is c_ida 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).
 * There are a total of 0 condition variables.
 */
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;
RATES[0] = 0.1001;
RATES[1] = 0.1001;
RATES[2] = 0.1001;
RATES[5] = 0.1001;
RATES[3] = 0.1001;
RATES[4] = 0.1001;
RATES[6] = 0.1001;
RATES[7] = 0.1001;
}
void
computeResiduals(double VOI, double* CONSTANTS, double* RATES, double* OLDRATES, double* STATES,
                 double* OLDSTATES, double* ALGEBRAIC, double* CONDVARS)
{
resid[0] = RATES[0] - ( - STATES[3]*CONSTANTS[2]*STATES[0])/(CONSTANTS[0]+STATES[0]) - ( STATES[4]*CONSTANTS[3]*STATES[0])/(CONSTANTS[1]+STATES[0]);
resid[1] = RATES[1] - ( STATES[3]*CONSTANTS[2]*STATES[0])/(CONSTANTS[0]+STATES[0])+( STATES[4]*CONSTANTS[3]*STATES[0])/(CONSTANTS[1]+STATES[0]);
resid[2] = RATES[2] - ( STATES[3]*CONSTANTS[2]*STATES[0])/(CONSTANTS[0]+STATES[0])+( STATES[4]*CONSTANTS[3]*STATES[0])/(CONSTANTS[1]+STATES[0]);
resid[3] = RATES[5] -  - STATES[7]*STATES[5]*CONSTANTS[4]+ STATES[3]*CONSTANTS[5];
resid[4] = 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]);
resid[5] = 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];
resid[6] = RATES[6] -  - STATES[7]*STATES[6]*CONSTANTS[7]+ CONSTANTS[8]*STATES[4];
resid[7] = 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)
{
}
void
computeEssentialVariables(double VOI, double* CONSTANTS, double* RATES, double* STATES, double* ALGEBRAIC)
{
}
void
getStateInformation(double* SI)
{
SI[0] = 1.0;
SI[1] = 1.0;
SI[2] = 1.0;
SI[3] = 1.0;
SI[4] = 1.0;
SI[5] = 1.0;
SI[6] = 1.0;
SI[7] = 1.0;
}
void
computeRoots(double VOI, double* CONSTANTS, double* RATES, double* OLDRATES, double* STATES,
             double* OLDSTATES, double* ALGEBRAIC, double* CONDVARS)
{
}