data:image/s3,"s3://crabby-images/d7a86/d7a86ab8e7fb8423b56c702bb852f247ea86fe0d" alt=""
Fitting Experimental Data with a Differential Equation
data:image/s3,"s3://crabby-images/15cde/15cdeed7b875902a2a203a47bb9174db5daf8323" alt=""
iherrera
Function MM (pw,xx,yw,dydx) // Michaelis-Menten relationship //pw[0] = Volume Distribution (Vd) //pw[1] = Maximal Elimination (Vmax) //pw[2] = Drug Concentration (Km) Wave pw, yw, dydx Variable xx dydx[0] = -pw[1]*yw[0]/(pw[0]*(pw[2]+yw[0])) return 0 End
Any ideas on how to use this function as part of a Fitting function of the form
Function myFitFunc(pw, yw, xw) : FitFunc
WAVE pw, yw, xw
yw = ....
End
The experimental data that I'm trying to fit is for a titration calorimetry experiment that has three fitting parameters. The binding constant (K), the binding enthalpy (H), and the molar equivalents (n). In this case, the signal measured is the differential heat (dq/dXt) after each injection and it can be expressed as:
d_q/d_Xt = d_XM/d_Xt * H * n
for the equilibrium reaction X + M ---> XM. In this case, the ODE is derived from the mass balance equations and the binding constant as follows:
Xt = X + XM
Mt = M + XM
K = XM/(X*M)
Mt*Xt - (Mt-Xt+1/K)*XM + XM^2 = 0
which gives the ODE
d_XM/d_Xt = (Mt -XM)/ (2*XM-Mt-Xt-1/K)
Function OneSite_ODE(pw, xx, yw, dydx) Wave pw Variable xx Wave yw Wave dydx //pw[0] = Mt total cocentration of Macromolecule //pw[1] = Kb binding constant dydx[0]= (yw[0]-pw[0])/(2*yw[0]-pw[0]-xx-(1/pw[1])) return 0 end
The OneSite_ODE has expected shape when Integrated an plotted against Xt. However, I was not able to fit my experimental data using the differential equation. This is the fitting function that I wrote, but it doesn't work.
Function OneSite(pw,wH,wX,wM ) : FitFunc wave pw, wX, wM, wH //pw[0] = n //pw[1] = K //pw[2] = H //pw[3] = Lo , hold constant //pw[4] = Mo , hold constant //pw[5] = Vo , hold constant Duplicate/O wX XM Make/O/D/n=2 pODE pODE[0]= pw[4] pODE[1]= pw[1] XM[0]=0 IntegrateODE OneSite_ODE, pODE , XM wH = pw[0]*pw[2]*pw[5]*(XM-wM)/(2*XM-wX-wM-(1/pw[1])) End
Any help would be greatly appreciated!
data:image/s3,"s3://crabby-images/ea50c/ea50c49b69879c68e2e1de2902c106ee5c672eaf" alt="MM_Numerical Integration"
Your fitting function has the form of a multivariate fitting function (it has the coefficient wave, pw, the Y wave, wH, and two X waves, wX and wM) but the graph you show is a simple XY graph. That seems to imply that you have just one independent variable, not two. On the other hand, you didn't say what the graph shows, so maybe I've interpreted this incorrectly.
The fit coefficients pw[3] isn't used. Your comments indicate that it will be held. If you truly have held that coefficient, it would be OK; if you forgot it would cause a singular matrix error.
Otherwise it seems like it should be OK.
John Weeks
WaveMetrics, Inc.
support@wavemetrics.com
December 14, 2010 at 09:55 am - Permalink
Then, I defined the differential equation and the curve fitting function as follows:
I'm not sure if the parameter /X=xw is necessary in this case, but it gives better results. The values are closer to the ones generated with the CurveFit function. Here are the commands I used to generate the fits.
December 17, 2010 at 04:20 pm - Permalink
1) The assignment in the fitting function must be an error in transferring it to the posting: it needs to be "yw" instead of "w"
2) You are correct that it is more accurate using /X=xw. That way the IntegrateODE solution points are exactly where you need them. Without it, you will get solution points at evenly-spaced intervals based on the wave scaling of the yw input wave. If the actual X values are not at those evenly-spaced X values, then Igor will do a linear interpolation, which won't be quite the same as the actual IntegrateODE solution.
3) At least for this problem, you don't need the intermediate wave yw1:
That might a bit faster, saving the time required to make the intermediate wave.
John Weeks
WaveMetrics, Inc.
support@wavemetrics.com
December 21, 2010 at 02:21 pm - Permalink