How can the least square optimizer LSQNONLIN be well conditiond?
조회 수: 1 (최근 30일)
이전 댓글 표시
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
채택된 답변
Alan Weiss
2012년 7월 13일
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
Alan Weiss
2012년 7월 13일
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
추가 답변 (0개)
참고 항목
제품
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!