Problem with solving a quadratic equation
조회 수: 8 (최근 30일)
이전 댓글 표시
Hello everybody!:)
I would need some help in solving a quadratic equation, where I have to find the two solutions for the variable "z" in function of many parameters
the equation is pretty long and I did the following steps:
syms d N m h b c A U R P k y z
I = ((d+1)/d)*z^(1/d)*N^(1/d)*b-3*c*z^2-U*A*h^k+P*h+R*A-m-h*P^(1+y); (I is the long euqation)
solve(I)
; the answer I got was:
ans =
log(-(m - P*h + 3*c*z^2 - A*R + A*U*h^k - (N^(1/d)*b*z^(1/d)*(d + 1))/d)/h)/log(P) - 1
Now, are the two solutions coincident? (I do not understand why I only got one of them)
But, main issue, how come I have the variable (z) in the root???? It should not be there!
Maybe I did some mistake..I don't know:/ Any help would be really appreciated!
I apologize if maybe this looks stupid but I am a beginner with matlab
Thank you!
Kodi
댓글 수: 0
채택된 답변
Walter Roberson
2013년 12월 15일
편집: Walter Roberson
2013년 12월 15일
You did not specify which variable to solve for, so it picked "y".
Note: because of the z^(1/d) term, the expression is not quadratic in z.
댓글 수: 0
추가 답변 (2개)
Kodi
2013년 12월 15일
댓글 수: 4
Walter Roberson
2013년 12월 15일
You can do the solve(). It will return a form involving RootOf(), which the symbolic toolbox knows how to reason about. RootOf(f(x),x) means "the set of values, x, such that f(x) is 0".
When you eventually substitute in enough actual values for your parameters, the Symbolic Toolbox is sometimes able to break down the expression into closed form solutions. When all parameters have been given values, the Symbolic Toolbox is able to find numeric solutions, if you use vpa() or double(). However, the Symbolic Toolbox is often unable to find all solutions in such situations; in some cases it is not able to find any numeric solutions at all even though real-valued solutions exist.
Kodi
2013년 12월 15일
댓글 수: 4
Walter Roberson
2013년 12월 16일
Then you will need to work numerically, which is not unexpected. Use fsolve or something like that.
Define values for all of your variables except z. Then
initial_guess = 1; %why not
fun = @(z) ((d+1)/d)*z^(1/d)*N^(1/d)*b-3*c*z^2-U*A*h^k+P*h+R*A-m-h*P^(1+y);
approximate_z = fsolve(fun, initial_guess);
참고 항목
카테고리
Help Center 및 File Exchange에서 Logical에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!