Solving Equation

조회 수: 7 (최근 30일)
Mark
Mark 2011년 2월 11일
I'm trying to solve a equation, and I'm having some issues...
syms Xell Xelr Xerl Xerr s q; s = solve('(Xell-Xelr)/(Xerl-Xerr) = -(((s-1)*(s-(1+2/q)))/((s+1)*(s+(1+2/q))))', s);
How do i use the results and enter values in for the syms (i.e. Xell Xelr Xerl Xerr q) to solve for s?
Thanks! Mark
  댓글 수: 1
Oleg Komarov
Oleg Komarov 2011년 2월 11일
Format the code please.

댓글을 달려면 로그인하십시오.

채택된 답변

Oleg Komarov
Oleg Komarov 2011년 2월 11일
Not sure the best method, convert to function handles:
syms Xell Xelr Xerl Xerr s q;
s = solve('(Xell-Xelr)/(Xerl-Xerr) = -(((s-1)*(s-(1+2/q)))/((s+1)*(s+(1+2/q))))', s)
s1 = str2func(['@(Xell, Xelr, Xerl, Xerr, q)' char(s(1))]);
s2 = str2func(['@(Xell, Xelr, Xerl, Xerr, q)' char(s(2))]);
% Evaluate at the desired values
s1(1,1,3,1,2)
s2(1,1,4,1,2)
Oleg

추가 답변 (3개)

Mark
Mark 2011년 2월 11일
Thanks Oleg, but I hit a snag...
If you solve the following code: syms Xell Xelr Xerl Xerr s q; s = solve('(Xell-Xelr)/(Xerl-Xerr) = -(((s-1)*(s-(1+2/q)))/((s+1)*(s+(1+2/q))))', s)
you get this: (1/(2*(Q*Xell - Q*Xelr + Q*Xerl - Q*Xerr)))*(2*Xell - 2*Q*Xell - 2*Xelr + 2*Q*Xelr - 2*Xerl + 2*Q*Xerl + 2*Xerr - 2*Q*Xerr - sqrt(-4*(Q*Xell - Q*Xelr + Q*Xerl - Q*Xerr)*(-2*Xell + Q*Xell + 2*Xelr - Q*Xelr - 2*Xerl + Q*Xerl + 2*Xerr - Q*Xerr) + (-2*Xell + 2*Q*Xell + 2*Xelr - 2*Q*Xelr + 2*Xerl - 2*Q*Xerl - 2*Xerr + 2*Q*Xerr)^2));
When I run your code, I get the following: (Xelr-Xell+Xerl-Xerr-Q*Xell+Q*Xelr+Q*Xerl-Q*Xerr+(4*Q^2*Xell*Xerr-4*Q^2*Xell*Xerl+4*Q^2*Xelr*Xerl-4*Q^2*Xelr*Xerr-8*Q*Xell*Xerl+8*Q*Xell*Xerr+8*Q*Xelr*Xerl-8*Q*Xelr*Xerr+Xell^2-2*Xell*Xelr-2*Xell*Xerl+2*Xell*Xerr+Xelr^2+2*Xelr*Xerl-2*Xelr*Xerr+Xerl^2-2*Xerl*Xerr+Xerr^2)^(1/2))/(Q*Xell-Q*Xelr+Q*Xerl-Q*Xerr)
I'm get a real number for my equation, but an imaginary for yours.... Any suggestions?
Thanks for the help!
  댓글 수: 1
Oleg Komarov
Oleg Komarov 2011년 2월 11일
I'm running your part of the code first and then my part of the code and don't get the difference you say.
Clear all and run again the script, which I'll complete with your part.

댓글을 달려면 로그인하십시오.


Mark
Mark 2011년 2월 11일
Nope, I get the same issue. If I run the following code, I get the below code:
s = solve('(Xell-Xelr)/(Xerl-Xerr) = -(((s-1)*(s-(1+2/q)))/((s+1)*(s+(1+2/q))))', s)
sneg = (1/(2*(Q*Xell - Q*Xelr + Q*Xerl - Q*Xerr)))*(2*Xell - 2*Q*Xell - 2*Xelr + 2*Q*Xelr - 2*Xerl + 2*Q*Xerl + 2*Xerr - 2*Q*Xerr - sqrt(-4*(Q*Xell - Q*Xelr + Q*Xerl - Q*Xerr)*(-2*Xell + Q*Xell + 2*Xelr - Q*Xelr - 2*Xerl + Q*Xerl + 2*Xerr - Q*Xerr) + (-2*Xell + 2*Q*Xell + 2*Xelr - 2*Q*Xelr + 2*Xerl - 2*Q*Xerl - 2*Xerr + 2*Q*Xerr)^2));
spos = (1/(2*(Q*Xell - Q*Xelr + Q*Xerl - Q*Xerr)))*(2*Xell - 2*Q*Xell - 2*Xelr + 2*Q*Xelr - 2*Xerl + 2*Q*Xerl + 2*Xerr - 2*Q*Xerr + sqrt(-4*(Q*Xell - Q*Xelr + Q*Xerl - Q*Xerr)*(-2*Xell + Q*Xell + 2*Xelr - Q*Xelr - 2*Xerl + Q*Xerl + 2*Xerr - Q*Xerr) + (-2*Xell + 2*Q*Xell + 2*Xelr - 2*Q*Xelr + 2*Xerl - 2*Q*Xerl - 2*Xerr + 2*Q*Xerr)^2));
I'm getting the following for your s1 and s2
(Xelr-Xell+Xerl-Xerr-Q*Xell+Q*Xelr+Q*Xerl-Q*Xerr+(4*Q^2*Xell*Xerr-4*Q^2*Xell*Xerl+4*Q^2*Xelr*Xerl-4*Q^2*Xelr*Xerr-8*Q*Xell*Xerl+8*Q*Xell*Xerr+8*Q*Xelr*Xerl-8*Q*Xelr*Xerr+Xell^2-2*Xell*Xelr-2*Xell*Xerl+2*Xell*Xerr+Xelr^2+2*Xelr*Xerl-2*Xelr*Xerr+Xerl^2-2*Xerl*Xerr+Xerr^2)^(1/2))/(Q*Xell-Q*Xelr+Q*Xerl-Q*Xerr)
-(Xell-Xelr-Xerl+Xerr+Q*Xell-Q*Xelr-Q*Xerl+Q*Xerr+(4*Q^2*Xell*Xerr-4*Q^2*Xell*Xerl+4*Q^2*Xelr*Xerl-4*Q^2*Xelr*Xerr-8*Q*Xell*Xerl+8*Q*Xell*Xerr+8*Q*Xelr*Xerl-8*Q*Xelr*Xerr+Xell^2-2*Xell*Xelr-2*Xell*Xerl+2*Xell*Xerr+Xelr^2+2*Xelr*Xerl-2*Xelr*Xerr+Xerl^2-2*Xerl*Xerr+Xerr^2)^(1/2))/(Q*Xell-Q*Xelr+Q*Xerl-Q*Xerr)
Different then what I get using the solver.
  댓글 수: 1
Oleg Komarov
Oleg Komarov 2011년 2월 11일
How can you get sneg = ... if you're solving s = solve...? Where does sneg come from? (btw I corrected again my original post)

댓글을 달려면 로그인하십시오.


Walter Roberson
Walter Roberson 2011년 2월 11일
You are going to get two solutions returned. You need to take that in to account. You are effectively solving a quadratic, so two solutions.
for K=1:length(s); funcs{K} = matlabFunction(s(K)); end
Now funcs{K} will be a function handle that you can pass the values in to and get solutions for s. Please see the matlabFunction documentation for information as to what parameter order the generated functions will expect.

카테고리

Help CenterFile Exchange에서 Mathematics에 대해 자세히 알아보기

제품

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by