Problem in solving equation with Gamma distribution parameters as unknowns
조회 수: 2 (최근 30일)
이전 댓글 표시
I am trying to solve the following sets of equations using the solve command.
gaminv(0.95,((2*y)-1),(1/(2*z)))-gaminv(0.05,((2*y)-1),(1/(2*z)))=6.73;
gaminv(0.45,((2*y)-1),(1/(2*z)))=7.19;
sqrt((Ia*(2*z)^((2*y)-1))/gamma((2*y)-1))=1.219;
It is giving an error of "Unable to prove '2*y - 1 < Inf & 0 < 2*y - 1 & 0 < 1/(2*z)' literally. Use 'isAlways' to test the statement mathematically."
I have also used the assume condition with the following lines
assume(0 < (2*y - 1) & (2*y - 1) < Inf);
assumeAlso(0 < (1/(2*z)));
Still same error. Is there any other way to solve them?
댓글 수: 0
채택된 답변
Torsten
2023년 8월 31일
편집: Torsten
2023년 8월 31일
I'd try it numerically. Better initial values for y,z and la might give convergence.
fun = @(y,z,la)[gaminv(0.95,y,z)-gaminv(0.05,y,z)-6.73;gaminv(0.45,y,z)-7.19;la/z^y-1.219^2*gamma(y)];
F = @(x)fun(x(1),x(2),x(3));
y0 = 1; z0 = 1; la0 = 1 ;
x0 = [y0,z0,la0];
sol = fsolve(F,x0,optimset('MaxIter',2500000,'MaxFunEvals',2500000));
norm(F(sol))
y = 2*sol(1)-1
z = 1/(2*sol(2))
la = sol(3)
추가 답변 (0개)
참고 항목
카테고리
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!