How can the least square optimizer LSQNONLIN be well conditiond?
1 view (last 30 days)
Show older comments
Hi,
i am doing a least square optimasation with LSQNONLIN. The problem is that at a certain point I always get comlex values as result. This is coming from my logarithlc function. So my question is: is it possible to restrict the used parameters to positive values? my code looks sth like this:
options = optimset('MaxIter',10000,'MaxFunEvals',50000,'FunValCheck','on','Algorithm',{'levenberg-marquardt',.005});
alfaZ = lsqnonlin(@myfun,fgalfa1,1e-7,1e-3,options);
function f = myfun(alfa)
global LR Stmp H;
f=Stmp(:)-log(LR*alfa(:))+H*alfa(:);
end
I already tried around with the options, but it didnt change anything yet. So the problem is that LSQNONLIN tries also negative values for alfa... If anybody has an idea how to overcome this problem, it would be great. Thanks for your help!
0 Comments
Accepted Answer
Alan Weiss
on 13 Jul 2012
I suggest you use the lsqnonlin trust-region-reflective algorithm. As explained here, this algorithm satisfies bounds at every iteration.
It is also possible you should scale your problem so that your range of possible values is larger.
It appears that you have a 1-D problem (scalar alfa). If so, why not use fminbnd to minimize the sum of squares?
If your problem is not scalar, then you need to set vector values for your bounds. See Bound Constraints.
Alan Weiss
MATLAB mathematical toolbox documentation
2 Comments
Alan Weiss
on 13 Jul 2012
One other thing I forgot to say. The levenberg-marquardt algorithm does not accept bound constraints, so there is no point specifying this algorithm when you give bounds--lsqnonlin switches to trust-region-reflective anyway.
Alan Weiss
MATLAB mathematical toolbox documentation
More Answers (0)
See Also
Products
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!