How to use polyfit instead of fit for fitting an exponential. For GPU processing.
Mostrar comentarios más antiguos
Ok, I've been fighting this for way too long, and I've posed a similar question to this months ago, but I still do not get the values I so desparately need.
How do I use polyfit to get the 'b' value in the output from fit(X,Y,'exp1')?
I've taken the natural log of every combination of value, used polyval in various ways, and still get nothing within 5 orders of magnitude to what I need. I've read many different answers to this same question in the community, so if you post a link to one, I've probably seen it.
This would be moot if I could use fit with a GPU.
6 comentarios
Matt J
el 13 de Mzo. de 2019
This would be moot if I could use fit with a GPU.
If you have a large batch of fits to do (otherwise, I don't see why GPU power would be necessary), you should probably use lsqcurvefit. This would allow you to do all the fits simultaneously and also use the GPU for the objective function evaluations.
Also, you could use your original noise model, instead of distorting it with log operations.
Matt J
el 13 de Mzo. de 2019
I'm glad it helped you, but I'm not really sure how. It doesn't look like you've used lsqcurvefit so far to do anything differently from what you were doing with fit().
Kris Hoffman
el 13 de Mzo. de 2019
Kris Hoffman
el 13 de Mzo. de 2019
Matt J
el 13 de Mzo. de 2019
You can use gpuArray operations inside the objective function. In doing so, you can potentially gain speed advantages from your GPU.
It is probably a good idea for you to describe the structure of TE and SSS so we can better delve into how you would optimize the computation time. Are you looping over i,j and computing a separate pair [x1,x2] for each one? What are the dimensions of TE and SSS?
Walter Roberson
el 13 de Mzo. de 2019
If i and j are both scalars, then you only need one squeeze() there instead of 2. You could also use
SS = reshape(SSS(i,j,:), [], 1);
Respuestas (1)
For example,
a=1;
b=2;
x=gpuArray.linspace(0,2,100);
y=a*exp(b*x);
p=polyfit(x,log(y),1);
b_fit=p(1),
produces the desired value,
b_fit =
2
6 comentarios
Kris Hoffman
el 13 de Mzo. de 2019
Kris Hoffman
el 13 de Mzo. de 2019
Editada: Kris Hoffman
el 13 de Mzo. de 2019
Walter Roberson
el 13 de Mzo. de 2019
Any time you see major coefficients such as a crossing 0 in the confidence bounds for a fit, then you should understand the implication as being that the fit is undecideable to within the precision you are using -- at least given that starting point. There might not be a single solution, or the "basin of attraction" of the best solution might be relatively narrow.
Note that using [0 0] as a starting point is prone to failing in fitting: it is easy for the search to get stuck not being able to find a gradient because of the odd behavior that equations can have at 0 exactly. Sometimes it helps to give a slight non-zero value as the starting point.
The only time you can have an exponential fit to negative y values is if the y values are all negative (leading to a negative a coefficient).
If you have some y readings that are negative because of noise in the system, consider excluding them from the fit.
John D'Errico
el 13 de Mzo. de 2019
+1 of course. But note that you need not get exactly rthe same result as you would from fit. In the presence of noise, the result from fit will essentially be weighted differently, so the coefficients might differ somewhat.
Kris Hoffman
el 13 de Mzo. de 2019
Walter Roberson
el 13 de Mzo. de 2019
polyfit runs on GPU.
If you are requiring 1.5 hours to do the fit() or polyfit then I would worry you would exceed the memory capacity of your GPU.
Categorías
Más información sobre Get Started with Curve Fitting Toolbox en Centro de ayuda y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!
