24小时热门版块排行榜    

Znn3bq.jpeg
查看: 585  |  回复: 1

firstlaker

金虫 (正式写手)

[求助] 请问这个程序如何优化呀,求数值积分的问题

如题。
unispec[w_,n_,d_,min_,max_,epsi10_,epsi1e_,epsi20_,epsi2e_]:=Module[{},
dkx=(max-min)/n;
kx=Table[0,{i,1,n+1}];
swkx=Table[0,{i,1,n+1}];
k0=w/c0;
Table[{
kx[[ind]]=min+(ind-1)*dkx;
kz10=If[Im[Sqrt[epsi10 k0^2-kx[[ind]]^2]]>=0,Sqrt[epsi10 k0^2-kx[[ind]]^2],-Sqrt[epsi10 k0^2-kx[[ind]]^2]];
kz20=If[Im[Sqrt[epsi20 k0^2-kx[[ind]]^2]]>=0,Sqrt[epsi20 k0^2-kx[[ind]]^2],-Sqrt[epsi20 k0^2-kx[[ind]]^2]];
kz1e=If[Im[Sqrt[epsi10 k0^2-kx[[ind]]^2 epsi10/epsi1e]]>=0,Sqrt[epsi10 k0^2-kx[[ind]]^2 epsi10/epsi1e],
-Sqrt[epsi10 k0^2-kx[[ind]]^2 epsi10/epsi1e]];
kz2e=If[Im[Sqrt[epsi20 k0^2-kx[[ind]]^2 epsi20/epsi2e]]>=0,Sqrt[epsi20 k0^2-kx[[ind]]^2 epsi20/epsi2e],
-Sqrt[epsi20 k0^2-kx[[ind]]^2 epsi20/epsi2e]];
kz3=Sqrt[k0^2-kx[[ind]]^2];
rs31=(kz3-kz10)/(kz3+kz10);
rp31=(epsi10 kz3-kz1e)/(epsi10 kz3+kz1e);
rs32=(kz3-kz20)/(kz3+kz20);
rp32=(epsi20 kz3-kz2e)/(epsi20 kz3+kz2e);
tpstemp=Abs[1-rs31 rs32 Exp[2 I kz3 d]];
tpptemp=Abs[1-rp31 rp32 Exp[2I kz3 d]];
etemp=Exp[-2Im[kz3]d];
If[kx[[ind]]<=k0,{trans=(1-Abs[rs31]^2)(1-Abs[rs32]^2)/tpstemp^2+(1-Abs[rp31]^2)(1-Abs[rp32]^2)/tpptemp^2;
swkx[[ind]]=kx[[ind]]trans/(4Pi^2);},
{trans=4 etemp Im[rs31]Im[rs32]/Abs[1-rs31 rs32 etemp]^2+4 etemp Im[rp31]Im[rp32]/Abs[1-rp31 rp32 etemp]^2;
swkx[[ind]]=kx[[ind]] trans/(4Pi^2)}];}
,{ind,1,n+1}];
swtot=(swkx[[1]]+4Sum[swkx[[k]],{k,2,n,2}]+2 Sum[swkx[[k]],{k,3,n-1,2}]+swkx[[n+1]])*dkx/3]

Qtd={};
For[i=1,i<=3,i=i+0.2,
d=10^i nm;
Print[10^i];
Print[DateString[]];
Table[{
wi=wstart+(ii-1)dw;
a1=(wi-10)/c0;
ae1=(wi+10)/c0;
ae2=Max[0.6/d,const1 wi/c0];
ae3=Max[5/d,const2 wi/c0];
Q1[[ii]]=h wi/(Exp[h wi/(kb T1)]-1);
Q2[[ii]]=h wi/(Exp[h wi/(kb T2)]-1);
twp[[ii]]=unispec[wi,nk,d,a0,a1,epsi01[wi],epsie1[wi],epsi02[wi],epsie2[wi]];
twe1[[ii]]=unispec[wi,nk,d,ae1,ae2,epsi01[wi],epsie1[wi],epsi02[wi],epsie2[wi]];
twe2[[ii]]=unispec[wi,nk,d,ae2,ae3,epsi01[wi],epsie1[wi],epsi02[wi],epsie2[wi]];
sw[[ii]]=(twp[[ii]]+twe1[[ii]]+twe2[[ii]])(Q1[[ii]]-Q2[[ii]])}
,{ii,1,nw}];
Qt=(sw[[1]]+4 Sum[sw[[k]],{k,2,nw-1,2}]+2Sum[sw[[k]],{k,3,nw-1,2}]+sw[[nw]])dw/3;
AppendTo[Qtd,Qt];
Print[DateString[]];
]
如上所示,其实整个程序就是一个双重的数值积分,所以这里需要有两个长循环,利用Simpson法求积分(两个长的Table语句,一个在子函数unispec里,一个在最后的结果里)。写的时候思路是做For循环,写完For换成Table而已.
我觉得这个运行得太慢了(结果应该没问题)。程序应该从哪里进行优化?
这里我尝试把Table换成 ParallelTable,算出来结果却不对了(都是0)。
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

virtualzx

木虫 (著名写手)

直接用内置数值积分函数。比你自己写的快,精度还更高

发自小木虫IOS客户端
2楼2016-02-25 00:04:55
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 firstlaker 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料085601调剂 +25 何润采123 2026-04-10 27/1350 2026-04-10 23:17 by Ftglcn90
[考研] 296求调剂 +11 汪!?! 2026-04-10 13/650 2026-04-10 23:16 by Ftglcn90
[考研] 297求调剂 +11 ORCHID1 2026-04-10 12/600 2026-04-10 21:07 by cyh—315
[考研] 362求调剂 +10 我要考大 2026-04-06 14/700 2026-04-10 17:00 by luoyongfeng
[考研] 材料工程302分求调剂 +18 zyx上岸! 2026-04-04 18/900 2026-04-10 10:07 by 314126402
[考研] 一志愿2110,化学学硕310分,本科重点双非求调剂 +18 努力奋斗112 2026-04-08 18/900 2026-04-09 23:28 by wolf97
[考研] 278求调剂 +27 范婷娜 2026-04-07 31/1550 2026-04-09 20:49 by zhouxiaoyu
[考研] 070300化学 求调剂 +13 73372112 2026-04-08 13/650 2026-04-09 20:22 by maddjdld
[考研] 材料专硕322 +14 哈哈哈吼吼吼哈 2026-04-05 14/700 2026-04-09 13:25 by 5268321
[考研] 0703化学调剂 348分 +14 唉我超真没招了 2026-04-06 15/750 2026-04-08 19:16 by 我减肥1
[考研] 301求调剂 +18 121. 2026-04-04 18/900 2026-04-07 17:49 by 蓝云思雨
[考研] 一志愿北京化工085600 310分求调剂 +20 0856材料与化工3 2026-04-04 22/1100 2026-04-07 15:14 by 上岸快快
[考研] 305分求调剂 +3 哈_哈_哈_哈_哈 2026-04-04 5/250 2026-04-07 14:49 by 哈_哈_哈_哈_哈
[考研] 295求调剂 +18 xndjjj 2026-04-04 19/950 2026-04-07 11:02 by wangjy2002
[考研] 材料工程310专硕调剂 +14 捞捞我…. 2026-04-04 15/750 2026-04-06 14:18 by lqwchd
[考研] 专硕304找调剂,一线城市最好 +3 李lsl李 2026-04-05 3/150 2026-04-06 12:16 by ffffjjjj
[考研] 327求调剂 +4 拾光任染 2026-04-05 4/200 2026-04-05 20:16 by 南航~万老师
[考研] 考研调剂 +3 mcbbc 2026-04-04 3/150 2026-04-05 10:03 by barlinike
[考研] 材料调剂 +7 dxy调剂 2026-04-04 7/350 2026-04-05 09:15 by 陌秋26
[考研] 278求调剂 +14 范婷娜 2026-04-04 15/750 2026-04-04 22:15 by lqwchd
信息提示
请填处理意见