马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?我要加入
x
求救:
在采用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,的具体表达式,因为太复杂没有异议列出,在主函数中调用
[x] = fsolve('myfunyuan',[0 0 0 0]');时计算正常。但由于f1~f4在不同情况下是变换的,因此我将以上子函数改写为以下形式:
function F = myfunyuan(x)
global w1 w2 w3 n1 n2 n3
syms u 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);时出错
那么应该怎样修改呢
请各位多提宝贵意见 |