24小时热门版块排行榜    

CyRhmU.jpeg
南方科技大学公共卫生及应急管理学院2026级博士研究生招生报考通知(长期有效)
查看: 1196  |  回复: 12
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

郑美琴琴

金虫 (著名写手)

[求助] 求助,程序中的错误时什么原因已有1人参与

这是Command window的程序:
global  nr nz  dr dz drs dzs...
r  z  Dc Dt  ca  Tk...
cae Tke  h  k   E   R...
rk0   v rho Cp Tw  dH...
ncall
%模型参数
ca0=0;
cae=0.01;
Tk0=305.0;
Tke=305.0;
Tw=355.0;
r0=2.0;
z1=100.0;
v=1;
Dc=0.1;
Dt=0.1;
k=0.01;
h=0.01;
rho=1.0;
Cp=0.5;
rk0=1.5e+09;
dH=-10000.0;
E=15000.0;
R=1.987;
%x轴网格
nz=20;
dz=z1/nz;
for i=1:nz;
z(i)=i*dz;
end
%半径网格化
nr=7;
dr=r0/(nr-1);
for j=1:nr;
r(j)=(j-1)*dr;
end
drs=dr^2;
%自变量
tf=200.0;
tout=[0:50:tf]';
nout=5;
ncall=0;
%初始条件
for i=1:nz;
for j=1:nr
ca(i,j)=ca0;
Tk(i,j)=Tk0;
y0((i-1)*nr+j)=ca(i,j);
y0((i-1)*nr+j*nz*nr)=Tk(i,j);
end
end
%ODE集成
reltol=1.0e-04;abstol=1.0e-04;
options=odeset('RelTol',reltol,'AbsTol',abstol);
[t,y]=ode15s(@pde_13,tout,y0,options);


这是function pde_的程序:
function yt=pde_13(t,y)
global  nr nz  dr dz drs dzs...
         r  z  Dc Dt  ca  Tk...
       cae Tke  h  k   E   R...
       rk0   v rho Cp Tw  dH...
       ncall
   for i=1:nz
       for j=1:nr
           ij=(i-1)*nr+j;
           ca(i,j)=y(ij);
           Tk(i,j)=y(ij+nr*nz);
       end
   end
   for i=1:nz
       for j=1:nr
           if(j==1)
               car(i,j)=2*(ca(i,j+1)-ca(i,j))/drs;
               Tkr(i,j)=2*(Tk(i,j+1)-Tk(i,j))/drs;
           elseif(j==nr)
               car(i,j)=0.0;
               Tkr(i,j)=(1/r(j))*(h/k)*(Tw-Tk(i,j));
           else
               car(i,j)=(1/r(j))*(ca(i,j+1)-ca(i,j-1))/(2*dr);
               Tkr(i,j)=(1/r(j))*(Tk(i,j+1)-Tk(i,j-1))/(2*dr);
           end
           if(j==1)
               carr(i,j)=2*(ca(i,j+1)-ca(i,j))/drs;
               Tkrr(i,j)=2*(Tk(i,j+1)-Tk(i,j))/drs;
           elseif(j==nr)
               carr(i,j)=2*(ca(i,j-1)-ca(i,j))/drs;
               Tkf(i,j)=Tk(i,j-1)+2*dr*h/k*(Tw-Tk(i,j));
               Tkrr(i,j)=(Tkf-2.0*Tk(i,j)+Tk(i,j-1))/drs;
           else
               carr(i,j)=(ca(i,j+1)-2.0*ca(i,j)+ca(i,j-1))/drs;
               Tkrr(i,j)=(Tk(i,j+1)-2.0*Tk(i,j)+Tk(i,j-1))/drs;
           end
           if(i==1)
               caz(i,j)=(ca(i,j)-cae)/dz;
               Tkz(i,j)=(Tk(i,j)-Tke)/dz;
           else
               caz(i,j)=(ca(i,j)-ca(i-1,j))/dz;
               Tkz(i,j)=(Tk(i,j)-Tk(i-1,j))/dz;
           end
           rk=rk0*exp(-E/(R*Tk(i,j)))*ca(i,j)^2;
           cat(i,j)=Dc*(carr(i,j)+car(i,j))-v*caz(i,j)-rk;
           Tkt(i,j)=Dt*(Tkrr(i,j)+Tkr(i,j))-v*Tkz(i,j)-dH/(rho*Cp)*rk;
       end
   end
   for i=1:nz
       for j=1:nr
           ij=(i-1)*nr+j;
           yt(ij)=cat(i,j);
           yt(ij+nr*nz)=Tkt(i,h);
       end
   end
   yt=yt';
   ncall=ncall+1;


运行结果:
Warning: Divide by zero.
> In pde_13 at 44
  In funfun\private\odearguments at 110
  In ode15s at 227
Warning: Divide by zero.
> In pde_13 at 44
  In funfun\private\odearguments at 110
  In ode15s at 227
Warning: Divide by zero.
> In pde_13 at 44
  In funfun\private\odearguments at 110
  In ode15s at 227
Warning: Divide by zero.
> In pde_13 at 44
  In funfun\private\odearguments at 110
  In ode15s at 227
Warning: Divide by zero.
> In pde_13 at 44
  In funfun\private\odearguments at 110
  In ode15s at 227
Warning: Divide by zero.
> In pde_13 at 44
  In funfun\private\odearguments at 110
  In ode15s at 227
??? Subscripted assignment dimension mismatch.

Error in ==> pde_13 at 32
               Tkrr(i,j)=(Tkf-2.0*Tk(i,j)+Tk(i,j-1))/drs;

Error in ==> funfun\private\odearguments at 110
f0 = feval(ode,t0,y0,args{:});   % ODE15I sets args{1} to yp0.

Error in ==> ode15s at 227
[neq, tspan, ntspan, next, t0, tfinal, tdir, y0, f0, odeArgs, ...
各位大神,帮帮忙。感激不尽!
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

grangergaga

木虫 (正式写手)

引用回帖:
3楼: Originally posted by 郑美琴琴 at 2015-04-19 16:15:14
大神,太牛了,膜拜啊!...

请显示一下回复的内容啊, 我遇到了同样的问题
13楼2021-10-22 23:30:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 13 个回答

mylifeljy

禁虫 (正式写手)

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ...
感谢参与,应助指数 +1
郑美琴琴: 金币+100, ★★★★★最佳答案 2015-04-19 16:14:21
本帖内容被屏蔽

2楼2015-04-19 11:23:19
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

郑美琴琴

金虫 (著名写手)

引用回帖:
2楼: Originally posted by mylifeljy at 2015-04-19 11:23:19
楼主,你程序中的主要问题在于没有注意变量下标的使用!程序修改后如下(修改部分用% +五角星标出):
clc;  clear all;  close all;
global  nr nz  dr dz drs dzs...
r  z  Dc Dt  ca  Tk...
cae Tke  h  k   E  ...

大神,太牛了,膜拜啊!
3楼2015-04-19 16:15:14
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

mylifeljy

禁虫 (正式写手)

本帖内容被屏蔽

4楼2015-04-19 16:39:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
信息提示
请填处理意见