Minimize using fminsearch?

6 visualizzazioni (ultimi 30 giorni)
Brady Retzlaff
Brady Retzlaff il 3 Nov 2015
Modificato: Geoff Hayes il 4 Nov 2015
The question is this
Use fminsearch to minimize the function you wrote above, using an initial guess of your choosing. Use the resulting c1 and c2 to evaluate f(x) at the values of x from exercise 2, storing the result as y. Plot the data and your curve (using x and y) to verify the fit. Once verified, save the first 10 elements of y
My code is:
objFunc = @(c) ( errFunc(c) );
C = fminsearch(objFunc, [1.0;1.0]);
for j=1:n
y(j) = C(1)*sin(x(j)+C(2));
end
What am i doing wrong??? i'm sure my errFunc is correct...
  3 Commenti
Brady Retzlaff
Brady Retzlaff il 4 Nov 2015
Modificato: Geoff Hayes il 4 Nov 2015
if true
% code
end
my effFunc is as follows...
function [e] = errFunc(c)
data2x =
data2y =
e = 0.0;
M=length(data2x);
for j=1:M
e = e + (c(1)*sin(data2x(j)+c(2)) - data2y(j))^2;
end
end
I know that it's incorrect because when i plot it next to the data im trying to fit, the graph is not even close... but im not getting an error
Star Strider
Star Strider il 4 Nov 2015
You need to use fminsearch to minimise the sum of squares difference between your objective function (which is a function only of your parameters and your independent variable) and your dependent variable. I usually do this with two functions, the objective function and the sum-of-squares cost function, and minimise the cost function.

Accedi per commentare.

Risposte (0)

Categorie

Scopri di più su Get Started with Curve Fitting Toolbox in Help Center e File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by