SOLVE querry

[EDIT: 20110614 09:07 - reformat - WDR]
Hi
I am trying to run the following code but its taking too long.
syms a b c
f(1)=4576632.912*(a.^1.75)+152579042.4*(a.^2)-2364.98637*((0.008-a).^1.75)-(4576632.912*(b.^1.75)+152579042.4*(b.^2));
f(2)=4576632.912*(b.^1.75)+152579042.4*(b.^2)-2364.98637*((0.008-a-b).^1.75)-(4576632.912*(c.^1.75)+152579042.4*(c.^2));
f(3)=a+b+c-0.008;
[A,B,C]=solve(f(1),f(2),f(3))
  1. Kindly suggest an alternative.
  2. Also is there a way to initialize a b c like i can give a=b=c initially.
  3. the eqns are f(1),f(2) and f(3). if there is another way to solve the same.
Akshayy Garg

回答(1 个)

Walter Roberson
Walter Roberson 2011-6-14

0 个投票

Are you expecting "a", "b", and "c" to be purely positive reals? If not then what meaning do you want to give to raising those values to the floating point power 1.75 ?
If you substitute the definition for c in to f(1) and f(2) you can reduce this to two equations in two variables. If you solve the parts for a in terms of b, and subtract the two and solve for 0, you find you are working with balancing the roots of a 32 degree polynomial against the roots of a 16 degree polynomial (I think it is). I am not convinced at the moment that any real roots exist.
I do not see how you can justify having some constants to 3 decimal places, some to 5, some to 2, and some of them to only 1 decimal place. The 32 degree polynomial needed to solve the expression becomes more or less numeric trash under those conditions.

1 个评论

Hi
thnx a lot. I will try using 2 equations surely.
but i got it working using fsolve. as below:
F=inline('[4576632.912*(V(1).^1.75)+152579042.4*(V(1).^2)-2364.98637*((0.008-V(1)).^1.75)-(4576632.912*(V(2).^1.75)+152579042.4*(V(2).^2)); 4576632.912*(V(2).^1.75)+152579042.4*(V(2).^2)-2364.98637*((0.008-V(1)-V(2)).^1.75)-(4576632.912*(V(3).^1.75)+152579042.4*(V(3).^2)); V(1)+V(2)+V(3)-0.008]', 'V')
ig=[(0.008/3);(0.008/3);(0.008/3)];
Options = optimset('Display','iter');
XYZ = fsolve(F, ig, Options);
and the answers are:
a= 0.002666876643911
b= 0.002666602440224
c= 0.002666520915865
thnx a lot again..

请先登录,再进行评论。

类别

帮助中心File Exchange 中查找有关 Symbolic Math Toolbox 的更多信息

标签

尚未输入任何标签。

Community Treasure Hunt

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

Start Hunting!

Translated by