increasing fsolve accuracy when fval values are different in terms of order of magnitude
조회 수: 2 (최근 30일)
이전 댓글 표시
I have a set of six equations-six unknowns. When I solve it by fsolve, it "stops prematurely" and gives me 6 values for unknowns that are not exactly the answers that I'm expecting (I've tried different initial guesses, but it's the same). Answer set that fval gives is:
[x1=6.242, x2=2.148, x3=2.688, x4=1.563, x5=-3.359, x6=0.996]
and values of "fval" after solving are:
[-9e-9, 1e-10, -2e-6, 0.0054, -0.1208, -0.1615 ]
(The last 3 fvals are comparatively larger). Please let me know what I can do to enhance the results accuracy? Thanks
댓글 수: 0
답변 (1개)
John D'Errico
2015년 6월 25일
편집: John D'Errico
2015년 6월 25일
The simple answer is the one you need to use.
SCALE YOUR VARIABLES. Scale them so they are all roughly the same order of magnitude. A factor of 10 is irrelevant. A dynamic range of 1e10 is a problem.
Then after the solve is done, scale them back.
댓글 수: 6
참고 항목
카테고리
Help Center 및 File Exchange에서 Ordinary Differential Equations에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!