| 查看: 1537 | 回复: 8 | ||
| 当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖 | ||
[求助]
matlab实现牛顿迭代法求非线性方程组程序运行出现问题 已有3人参与
|
||
|
已知非线性方程组如下: log(rhomcA*x1*(1-yA*rhob/rhomcA-yB*rhob/rhomcB)/(yA*rhob*(1-x1-x2)))+EAA/T*(7*x1-8*yA*rhob/rhomcA)+(EAA*EBB)^0.5/T*(7*x2-8*yB*rhob/rhomcB)+EAs/T=0 f2=log(rhomcB*x2*(1-yA*rhob/rhomcA-yB*rhob/rhomcB)/(yB*rhob*(1-x1-x2)))+EBB/T*(7*x2-8*yB*rhob/rhomcB)+(EAA*EBB)^0.5/T*(7*x1-8*yA*rhob/rhomcA)+EBs/T=0 首先建立函数fun function f=fun(x); %定义非线性方程组如下 %变量x1 x2 %函数f1 f2 T=318.2; %(K) rhomcA=0.34; %(g/cm3) CA=3.26; %(mmol/g) EAA=64; %(K) EAs=-1385; %(K) rhomcB=0.98; %(g/cm3) CB=4.53; %(mmol/g) EBB=82; %(K) EBs=-1690; %(K) rhob=[0.0047 0.0090 0.0177 0.0264 0.0367 0.0466 0.0566 0.0674 0.0787 0.0890]'; yA=[0.89 0.886 0.884 0.883 0.877 0.871 0.866 0.861 0.856 0.852]'; yB=[0.11 0.114 0.116 0.117 0.123 0.129 0.134 0.139 0.144 0.148]'; syms x1 x2 x3 x4 f1=log(rhomcA*x1.*(1-yA.*rhob/rhomcA-yB.*rhob/rhomcB)./(yA.*rhob.*(1-x1-x2)))+EAA/T*(7*x1-8*yA.*rhob/rhomcA)+(EAA*EBB)^0.5/T*(7*x2-8*yB.*rhob/rhomcB)+EAs/T; f2=log(rhomcB*x2.*(1-yA.*rhob/rhomcA-yB.*rhob/rhomcB)./(yB.*rhob.*(1-x1-x2)))+EBB/T*(7*x2-8*yB.*rhob/rhomcB)+(EAA*EBB)^0.5/T*(7*x1-8*yA.*rhob/rhomcA)+EBs/T; %f3=nexA-2*CA*(x1-x3*rhob/rhomcA); %f4=nexB-2*CB*(x2-x4*rhob/rhomcB); f=[f1 f2]; 建立函数dfun function df=dfun(x); %用来求解方程组的雅克比矩阵储存在dfun中 f=fun(x); df=[diff(f,'x1');diff(f,'x2')]; df=conj(df'); 编程牛顿法求解非线性方程组将newton.m保存到工作路径中: function x=newton(x0,eps,N); con=0; %其中x0为迭代初值,eps为精度要求N为最大迭代步数,con用来记录结果是否收敛 for i=1:N; f=subs(fun(x0),{'x1' 'x2'},{x0(1) x0(2)}); df=subs(dfun(x0),{'x1' 'x2'},{x0(1) x0(2)}); x=x0-f./df; for j=1:length(x0); il(i,j)=x(j); end if norm(x-x0)<eps con=1; break; end x0=x; end %以下是将迭代过程写入txt文档文件名为iteration.txt fid=fopen('iteration.txt','w'); fprintf(fid,'iteration'); for j=1:length(x0) fprintf(fid,' x%d',j); end for j=1:i fprintf(fid,'\n%6d ',j); for k=1:length(x0) fprintf(fid,' %10.6f',il(j,k)); end end if con==1 fprintf(fid,'\n计算结果收敛!'); end if con==0 fprintf(fid,'\n迭代步数过多可能不收敛!'); end fclose(fid); 在matlab中命令窗口中输入: newton([0.8 0.8],0.00001,20) 结果出现: ??? Error using ==> rdivide Matrix dimensions must agree. Error in ==> newton at 7 x=x0-f./df; 检查了几遍程序没发现问题出现在哪,请高手指点 |
» 猜你喜欢
表哥与省会女结婚,父母去帮带孩子被省会女气回家生重病了
已经有12人回复
依托企业入选了国家启明计划青年人才。有无高校可以引进的。
已经有14人回复
江汉大学解明教授课题组招博士研究生/博士后
已经有3人回复
AI 太可怕了,写基金时,提出想法,直接生成的文字比自己想得深远,还有科学性
已经有11人回复
依托企业入选了国家启明计划青年人才。有无高校可以引进的。
已经有11人回复
» 本主题相关价值贴推荐,对您同样有帮助:
求助如何用matlab求非线性方程组的解
已经有8人回复
求解决matlab解非线性方程组出现的问题
已经有6人回复
MATLAB解非线性方程组
已经有9人回复
解线性方程组的时候如何取限定条件使解是正解?
已经有6人回复
matlab 解非线性偏微分方程组
已经有6人回复
病态方程组求解问题,望指导啊
已经有7人回复
求用牛顿迭代法解非线性方程组的matlab程序
已经有4人回复
非线性二阶微分方程组求解,matlab
已经有12人回复
有限差分法化之后化简为线性方程组
已经有50人回复
matlab 非线性微分方程求解
已经有3人回复
请教一个matlab求解非线性方程组的问题
已经有9人回复
用matlab求解非线性方程组说无解,一定是方程组本身无解,还是有可能程序有问题呢?
已经有11人回复
matlab如何求解一个非线性微分方程组
已经有8人回复
用fortran程序遗传算法解非线性方程组
已经有7人回复
牛顿迭代法解含对数的非线性方程组
已经有11人回复
MATLAB求解非线性方程组
已经有5人回复
求Matlab高手解决线性方程组的迭代求解问题
已经有17人回复
Matlab:Newton-Raphson 解线非线性性方程组的问题
已经有12人回复
matlab求解非线性方程组,错误提示怎么解决
已经有5人回复
求助matlab---fsolve解非线性方程组
已经有6人回复
matlab求解非线性方程组
已经有16人回复
求一个mathmetica的程序
已经有10人回复
【求助】求教matlab解非线性方程组
已经有9人回复
8楼2015-04-20 21:02:48
感谢参与,应助指数 +1
|
本帖内容被屏蔽 |
2楼2015-04-20 15:18:07
3楼2015-04-20 15:33:42
|
本帖内容被屏蔽 |
4楼2015-04-20 15:42:05













回复此楼
