24小时热门版块排行榜    

Znn3bq.jpeg
查看: 1317  |  回复: 11

吕京毛衣

银虫 (小有名气)

[求助] 自己编写了一段Matlab代码,运行时出现bug 已有1人参与

一段模拟化学反应的代码,运行时出现“Undefined function 'P' for input arguments of type 'double',而我只是想用P(i)作为一个数组储存分子数,请大家帮我看看,怎么修改?谢谢大家!


Xm=2000;Xa=2;Xr=0;  % [Xm]=2 mol/L
kd=0.00001;kp=1000;kt=10000000;
kd1=0.00001;kp1=1;kt1=10000; % VNa=1000
T=0;
j=0;
I=[];X=[];U=[];V=[];Pn=[];
while(T<=2400)
    Rd=kd1*Xa;
    Rp=kp1*Xm*Xr;
    Rt=0.5*kt1*Xr*Xr;
    R=Rd+Rp+Rt;
    Pd=Rd/R;Pp=Rp/R;Pt=Rt/R;
    r1=rand(1);
    t=(1/R)*log(1/r1);
    r2=rand(1);
    if r2<=Pd  %链引发(不区分单体和初级自由基)
        Xm=Xm-2;
        Xa=Xa-1;
        Xr=Xr+2;
        j=j+1;
        X=[X;j];
        R(j)=1;
        j=j+1;
        X=[X;j];
        R(j)=1;
    else
        if r2>Pd&&r2<=Pd+Pp %链增长
            Xm=Xm-1;
            b=ceil(Xr*rand(1));
            r3=X(b);
            R(r3)=R(r3)+1;
        else
            if r2>Pd+Pp&&r2<=1
                Xr=Xr-2;
                c=ceil(Xr*rand(1));
                r4=X(c);
                X(c)=[];
                d=ceil((Xr-1)*rand(1));
                r5=X(d);
                X(d)=[];
                i=R(r4)+R(r5);
               
                z=find(I==i);
                if z>=1
                    P(i)=P(i)+1;%储存分子数
                else
                    P(i)=1;%储存终止产物链长
                end
                 I=[I;i];
            end
        end
    end
   
    T=T+t;U=[U;T];%储存时间
    C=(2000-Xm)*100/2000;
    V=[V;C];%储存单体转化率
    L=length(I);S=sum(I);
    E=S/L;%平均链长
    Pn=[Pn;E];
end
  N=sum(P(i));
  f(i)=P(i)./N;%数量分布
  m(i)=i.*P(i);
  M=sum(m(i));
  w(i)=m(i)./M;%重量分布
  subplot(221);
  plot(I,f(i))
  subplot(222);
  plot(I,w(i))
  subplot(223);
  plot(U,V)    %转化率-时间曲线
  subplot(224);
  plot(U,Pn)   %平均链长-时间曲线
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
回帖支持 ( 显示支持度最高的前 50 名 )

lifang2009

银虫 (小有名气)

P(i)被赋值时候没有问题,Matlab会自动处理,但是在右侧作为一个操作数的时候必须有确定的值

发自小木虫IOS客户端
8楼2016-04-08 14:46:41
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通回帖

月只蓝

主管区长 (职业作家)

P的初始值没有定义。
MATLAB、MS小问题、普通问题请发帖求助!时间精力有限,恕不接受无偿私信求助。
2楼2016-04-07 13:47:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

1049569501

新虫 (初入文坛)

【答案】应助回帖

感谢参与,应助指数 +1
没有定义函数或数组P,在循环前定义一下就行了。
3楼2016-04-07 18:59:41
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

吕京毛衣

银虫 (小有名气)

引用回帖:
2楼: Originally posted by 月只蓝 at 2016-04-07 13:47:30
P的初始值没有定义。

这种数组的初始值怎么定义呢?应该是空的吧

发自小木虫IOS客户端
4楼2016-04-08 08:36:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

吕京毛衣

银虫 (小有名气)

引用回帖:
2楼: Originally posted by 月只蓝 at 2016-04-07 13:47:30
P的初始值没有定义。

我运行时第一次会进入到选择P(i)=1呀,我试过把这块程序拿出来写成一个小程序,就是可以运行的,不需要定义初始值或数组。这让我很疑惑是不是问题出在我整个程序里的其他地方?

发自小木虫IOS客户端
5楼2016-04-08 08:46:20
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

吕京毛衣

银虫 (小有名气)

引用回帖:
3楼: Originally posted by 1049569501 at 2016-04-07 18:59:41
没有定义函数或数组P,在循环前定义一下就行了。

里面的R(i)数组也没有定义什么,为什么就没有问题呢?

发自小木虫IOS客户端
6楼2016-04-08 09:17:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
7楼2016-04-08 10:11:59
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lifang2009

银虫 (小有名气)

可以在z=find(l==i)加断点调试,肯定先执行第一个分支了

发自小木虫IOS客户端
9楼2016-04-08 14:49:35
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

吕京毛衣

银虫 (小有名气)

引用回帖:
2楼: Originally posted by 月只蓝 at 2016-04-07 13:47:30
P的初始值没有定义。

这个代码就是可以运行的

I=[];t=0
while (t<=3)
i=ceil(rand(1));
z=find(I==i);
if z>=1
     P(i)=P(i)+1;
else
     P(i)=1;
end
I=[I;i],t=t+1
end
P
10楼2016-04-08 16:04:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 吕京毛衣 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[基金申请] 青C资助名额大幅增加! +9 西葫芦炒鸡蛋 2026-05-13 13/650 2026-05-15 00:18 by jackeychen7922
[文学芳草园] 风把牡丹吹跑了 +4 myrtle 2026-05-12 7/350 2026-05-14 23:58 by myrtle
[教师之家] 教学课件你会给同学吗 +8 硕士研究生吗 2026-05-13 8/400 2026-05-14 22:23 by 常规沥青
[考博] 26应届毕业生考博求助 +3 wo一定上岸 2026-05-13 3/150 2026-05-14 21:47 by 明海天涯
[基金申请] 重磅!青年科学基金项目(C类)资助增幅预计超过50% +5 水和泥不是水泥 2026-05-13 7/350 2026-05-14 20:57 by 水和泥不是水泥
[有机交流] 求助2,4-二氯-5-嘧啶甲醛的合成方法 20+3 光吃不拉 2026-05-14 5/250 2026-05-14 20:15 by 一切都是空工
[高分子] 本人最近太闲了,谁有问题可以提,每天会统一回复 +8 一切都是空工 2026-05-12 19/950 2026-05-14 20:03 by 一切都是空工
[考博] 申博自荐 +4 食品的橙子 2026-05-09 6/300 2026-05-14 16:05 by great1919
[基金申请] 这年头没有找到涵评专家,还有中面上的可能吗 +7 dd921ww 2026-05-12 8/400 2026-05-14 14:22 by dd921ww
[考博] 材料类只有一篇综述能申博么 +4 乐逍遥谷 2026-05-13 4/200 2026-05-14 12:05 by zhyzzh
[基金申请] 请问大佬b0816评完了吗 +3 市民华南虎 2026-05-12 7/350 2026-05-14 07:41 by 市民华南虎
[基金申请] 精华III评审感受-评审感受-评审感受 +12 ferrarichen 2026-05-11 16/800 2026-05-14 07:33 by 2000zf36392
[论文投稿] 有带发论文的吗 +3 山楂之术 2026-05-09 3/150 2026-05-13 17:56 by Cyhcl2629
[硕博家园] 导师各种操作恶心咋办 +11 苍白的小青天 2026-05-09 13/650 2026-05-13 17:11 by 六两废铜
[论文投稿] 护理论文 晋升 +5 Taylor1990, 2026-05-08 5/250 2026-05-13 14:40 by tegsgjy20
[论文投稿] 求助大佬sci投稿哪个好中 +3 江沅188 2026-05-12 4/200 2026-05-13 14:35 by 江沅188
[考博] 西南大学考核制博士 +3 lijunjie84 2026-05-11 6/300 2026-05-12 18:09 by lijunjie84
[文学芳草园] 窗边初夏的小雨 +7 阿美_Lml888 2026-05-09 10/500 2026-05-12 15:27 by 阿美_Lml888
[考博] 现在不知道怎么办,感觉很痛苦 +4 qweww 2026-05-11 5/250 2026-05-11 20:23 by Oversize
[考博] 生物学博士 +3 17749024330 2026-05-08 6/300 2026-05-11 14:29 by 17749024330
信息提示
请填处理意见