wszc 发表于 2008-4-20 15:08

fsolve求解非线性方程组问题

求救:
在采用fsolve求解非线性方程组过程中遇到以下问题:
当采用以下格式计算时计算无误:
设置子函数为
function F = myfunyuan(x)
global w1 w2 w3 n1 n2 n3
u=x(1);b=x(2);t=x(3);n=x(4);
F = [-u+f1(b,t);
   -(w1+n1*n)+f2(b,t,u);
   -(w2+n2*n)+f3(b,t,u)
   -(w3+n3*n)+f4(b,t,u);
];
其中f1(b,t),f2(b,t,u),f3(b,t,u),f4(b,t,u)是包含b,t,u,的具体表达式,因为太复杂没有异议列出,在主函数中调用
= fsolve('myfunyuan',');时计算正常。但由于f1~f4在不同情况下是变换的,因此我将以上子函数改写为以下形式:
function F = myfunyuan(x)
global w1 w2 w3 n1 n2 n3

symsu b t
-
-(该省略部分表示将u,b,t作为变量的运算过程,得到以下计算式)
f1=f(b,t);
f2=f2(u,b,t);
f3=f3(u,b,t);
f4=f4(u,b,t);
再代入以下计算式
u=x(1);b=x(2);t=x(3);n=x(4);
F = [-u+f1;
   -(w1+n1*n)+f2;
   -(w2+n2*n)+f3;
   -(w3+n3*n)+f4;];
在主函数中调用出现以下错误:
??? Conversion to double from sym is not possible.
请问是不是因为在子函数中之前已将u,b,t定义为syms格式 后采用u=x(1);b=x(2);t=x(3);n=x(4);时出错
那么应该怎样修改呢

请各位多提宝贵意见!!!!

ch_j1985 发表于 2008-4-20 15:52

回复 楼主 的帖子

把程序改成这样试试看:
function F = myfunyuan(u,b,t,n)
global w1 w2 w3 n1 n2 n3
F = [-u+f1(b,t);
   -(w1+n1*n)+f2(b,t,u);
   -(w2+n2*n)+f3(b,t,u)
   -(w3+n3*n)+f4(b,t,u);
];
在主函数中调用
x= fsolve('myfunyuan',',u,b,t,n);

eight 发表于 2008-4-21 21:22

请问是不是因为在子函数中之前已将u,b,t定义为syms格式 后采用u=x(1);b=x(2);t=x(3);n=x(4);时出错

估计是,这个错误版面讨论过,请搜索

wszc 发表于 2008-4-22 09:10

ch-j 1985 采用你所说的方法之后运行结果提示:
Input argument "t" is undefined.
在计算f1时  需要用到以下计算式
c=ww*t;
以上提示错误表明将u,b,t,n直接写到fuction中后  程序认为没有设置变量u,t,b了 
呵呵  
不知道还有没有其它方法

ch_j1985 发表于 2008-4-22 10:21

原帖由 wszc 于 2008-4-22 09:10 发表 http://www.chinavib.com/forum/images/common/back.gif
ch-j 1985 采用你所说的方法之后运行结果提示:
Input argument "t" is undefined.
在计算f1时  需要用到以下计算式
c=ww*t;
以上提示错误表明将u,b,t,n直接写到fuction中后  程序认为没有设置变量u,t,b了  ...


能不能把你的程序代码全部帖出来,这样在想方法修改程序之后可以调试?
页: [1]
查看完整版本: fsolve求解非线性方程组问题