24小时热门版块排行榜    

Znn3bq.jpeg
查看: 1772  |  回复: 16

wdxiao

银虫 (正式写手)

[求助] 最优化计算求助!(1stopt或者Matlab)

本人有一个最优化计算的问题。用1stopt1.5注册版编写的代码。但是运行的时候总是没有任何显示。故意将代码改错,编译的时候的确能报告出错。

另外,貌似1stopt的pascal编程与标准pascal语言有很多不同,比如:
不能自定义结构类型数据,不能自定义函数,自定义过程貌似也有问题。等等。

请大侠帮忙看看。另外,不知道MatLab能否处理这一问题?

先大致说说这个问题的物理本质和程序的思路。

本质就是计算三个分子间的范德华力相互作用能。
每个分子有24个原子。每个原子有x,y坐标和范德华力相关参数两个。
所有信息存放在三维数组里面。数组的第一指标表示不同分子;第二指标表示分子内各个原子;第三指标表示每个原子有x,y坐标和范德华力相关参数两个。

M0为分子标准的位置(0,0)和角度。
M1,M2,M3具有相同的分子角度,即将M0的标准角度绕(0,0)点旋转phi角度,
M1,M2,M3分别为放置在(0,0), (b,0),和(a*cos(theta),a*sin(theta))位置。
然后分别计算不同分子各个原子对间的范德华力作用能。

程序是用Pascal语言编写,如下:

Title "Type your title here"
Parameters a[1,4], b[1,4],theta[0,pi/2],phi[-pi/8,pi/8];
Minimum;
StartProgram;
const xx: array[1..24] of double
        =(0.703,1.698,1.698,0.703,-0.703,-1.698,-1.698,-0.703,1.246,3.008,3.008,1.246,-1.246,
        -3.008,-3.008,-1.246,0,-2.926,-4.138,-2.926,0,2.926,4.138,2.926);
      yy: array[1..24] of double
        =(1.698,0.703,-0.703,-1.698,-1.698,-0.703,0.703,1.698,3.008,1.246,-1.246,-3.008,-3.008,
        -1.246,1.246,3.008,4.138,2.926,0,-2.926,-4.138,-2.926,0,2.926);
var i,j: Integer;
    Etot,r,angle,out1,out2,out3: double;
    Ax,Ay,Ar,Ae,Bx,By,Br,Be,dist,rou: double;
    M: array[0..3,1..24,1..4] of double;
Begin
for i:=1 to 24 do
    begin
        M[0,i,1]:=xx;
        M[0,i,2]:=yy;
    end;
for i:=1 to 8 do
    begin
         M[0,i,3]:= 1.9;
         M[0,i,4]:= 0.044;
         M[0,i+8,3]:= 1.9;
         M[0,i+8,4]:= 0.044;
         M[0,i+16,3]:= 2.11;
         M[0,i+16,4]:= 0.202;
    end;
M[1]:=M[0];
for i:=1 to 24 do
  begin
         r:=sqrt(M[1,i,1]*M[1,i,1]+M[1,i,2]*M[1,i,2]);
         if M[1,i,1]>=0 then
              angle:=arcsin(M[1,i,2]/r)
            else
              angle:= (M[1,i,2]/abs(M[1,i,2]))*(pi-abs(arcsin(M[1,i,2]/r)));
          angle:=angle+phi;
          M[1,i,1]:=r*cos(angle);
          M[1,i,2]:=r*sin(angle);
  end;
M[2]:=M[1];
M[3]:=M[1];
for i:=1 to 24 do
  begin
    M[2,i,1]:=M[1,i,1]+b;
    M[3,i,1]:=M[1,i,1]+a*cos(theta);
    M[3,i,2]:=M[1,i,2]+a*sin(theta);
  end;
Etot:=0;
for i:=1 to 24 do
    for j:=1 to 24 do
       begin
            Ax:=M[1,i,1];
            Ay:=M[1,i,2];
            Ar:=M[1,i,3];
            Ae:=M[1,i,4];
            Bx:=M[2,j,1];
            By:=M[2,j,2];
            Br:=M[2,j,3];
            Be:=M[2,j,4];
            dist:=sqrt((Ax-Bx)*(Ax-Bx)+(Ay-By)*(Ay-By));
            rou:=dist/(Ar+Br);
            if dist>3.311 then
                out1:= sqrt(Ae*Be)*(290000*exp(-12.5*rou)-2.25/exp(6*ln(rou)))
            else
                out1:= 336.176*sqrt(Ae*Be)/(rou*rou);
            Bx:=M[3,j,1];
            By:=M[3,j,2];
            Br:=M[3,j,3];
            Be:=M[3,j,4];
            dist:=sqrt((Ax-Bx)*(Ax-Bx)+(Ay-By)*(Ay-By));
            rou:=dist/(Ar+Br);
            if dist>3.311 then
                out2:= sqrt(Ae*Be)*(290000*exp(-12.5*rou)-2.25/exp(6*ln(rou)))
            else
                out2:= 336.176*sqrt(Ae*Be)/(rou*rou);
            Ax:=M[2,i,1];
            Ay:=M[2,i,2];
            Ar:=M[2,i,3];
            Ae:=M[2,i,4];
            dist:=sqrt((Ax-Bx)*(Ax-Bx)+(Ay-By)*(Ay-By));
            rou:=dist/(Ar+Br);
            if dist>3.311 then
                out3:= sqrt(Ae*Be)*(290000*exp(-12.5*rou)-2.25/exp(6*ln(rou)))
            else
                out3:= 336.176*sqrt(Ae*Be)/(rou*rou);
         Etot:=out1+out2+out3+Etot;
        end;
FunctionResult:= Etot;
End;
EndProgram;

[ Last edited by wdxiao on 2012-3-26 at 14:06 ]
回复此楼

» 猜你喜欢

» 本主题相关商家推荐: (我也要在这里推广)

» 本主题相关价值贴推荐,对您同样有帮助:

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

dingd

铁杆木虫 (职业作家)

【答案】应助回帖

感谢参与,应助指数 +1
不知道你的M值是在哪赋值的?
2楼2012-03-26 14:28:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wdxiao

银虫 (正式写手)

引用回帖:
2楼: Originally posted by dingd at 2012-03-26 14:28:57:
不知道你的M值是在哪赋值的?

xx,yy数组分别赋值给M[0,1..24,1]和M[0,1..24,2],表示标准位置的分子内各个原子的x,y坐标。对应的表示范德华力的参数M[0,1..24,3]和M[0,1..24,4]由第一个for...do循环赋值。(分子的1~16号原子是同一种原子,17~24号原子是另一种原子)。

M0赋值给M1。然后M1旋转phi角度后,赋值给M2和M3。然后M2和M3的各个原子坐标经过平移变换。
3楼2012-03-26 14:47:22
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wdxiao

银虫 (正式写手)

引用回帖:
2楼: Originally posted by dingd at 2012-03-26 14:28:57:
不知道你的M值是在哪赋值的?

xx,yy数组分别赋值给M[0,1..24,1]和M[0,1..24,2],表示标准位置的分子内各个原子的x,y坐标(第一个for....do循环)。对应的表示范德华力的参数M[0,1..24,3]和M[0,1..24,4]由第二个for...do循环赋值。(分子的1~16号原子是同一种原子,17~24号原子是另一种原子)。

M0赋值给M1。然后M1旋转phi角度后,赋值给M2和M3。然后M2和M3的各个原子坐标经过平移变换。
4楼2012-03-26 14:50:40
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wdxiao

银虫 (正式写手)

引用回帖:
2楼: Originally posted by dingd at 2012-03-26 14:28:57:
不知道你的M值是在哪赋值的?

xx,yy数组分别赋值给M[0,1..24,1]和M[0,1..24,2],表示标准位置的分子内各个原子的x,y坐标(第一个for....do循环)。对应的表示范德华力的参数M[0,1..24,3]和M[0,1..24,4]由第二个for...do循环赋值。(分子的1~16号原子是同一种原子,17~24号原子是另一种原子)。

M0赋值给M1。然后M1旋转phi角度后(第三个for...do循环),赋值给M2和M3。然后M2和M3的各个原子坐标经过平移变换(第四个for.....do 循环)。

另外,很奇怪的是,我的源程序上第一个for.....do 循环为:

for i:=1 to 24 do
    begin
        M[0,i,1]:=xx;
        M[0,i,2]:=yy;
    end;

发帖的时候自动去掉了,不知道为啥。
5楼2012-03-26 14:56:46
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wdxiao

银虫 (正式写手)

引用回帖:
5楼: Originally posted by wdxiao at 2012-03-26 14:56:46:
xx,yy数组分别赋值给M和M,表示标准位置的分子内各个原子的x,y坐标(第一个for....do循环)。对应的表示范德华力的参数M和M由第二个for...do循环赋值。(分子的1~16号原子是同一种原子,17~24号原子是另一种原子 ...

for i:=1 to 24 do
    begin
        M[1,i,1]:=xx ;
        M[1,i,2]:=yy ;
    end;
6楼2012-03-26 15:10:32
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wdxiao

银虫 (正式写手)

奇怪,还是没法写成xx, yy
7楼2012-03-26 15:11:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wdxiao

银虫 (正式写手)

"xx, yy"
8楼2012-03-26 15:11:36
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wdxiao

银虫 (正式写手)

xx【i】
yy【i】
9楼2012-03-26 15:12:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wdxiao

银虫 (正式写手)

真奇怪,发帖的时候没法用英文的中括号写xx i 。
10楼2012-03-26 15:12:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 wdxiao 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料工程281还有调剂机会吗 +19 xaw. 2026-04-11 19/950 2026-04-11 23:20 by labixiaoqiao
[考研] 求调剂,985材料与化工348分 +7 涵竹刘 2026-04-11 9/450 2026-04-11 23:13 by 溪涧流水
[考研] 一志愿211,0703化学305分求调剂 +26 严西西戏 2026-04-06 33/1650 2026-04-11 23:01 by 314126402
[考研] 求调剂 +6 小聂爱学习 2026-04-11 9/450 2026-04-11 21:20 by 蓝云思雨
[考研] 301求调剂 +6 XYPLR 2026-04-05 9/450 2026-04-11 20:37 by Delta2012
[考研] 293求调剂 +8 勇远库爱314 2026-04-06 8/400 2026-04-11 20:25 by 蓝云思雨
[考研] 本人女孩 +7 吼吼, 2026-04-10 9/450 2026-04-11 14:45 by ACS Nano——
[考研] 295求调剂 +3 桂秋二十八 2026-04-05 5/250 2026-04-11 11:36 by zhq0425
[考研] 295分求调剂 +9 ?要上岸? 2026-04-10 9/450 2026-04-11 10:48 by qingpingzhu
[考研] 生物学调剂 可调剂到生物与医药 +8 李政莹 2026-04-06 9/450 2026-04-11 10:36 by wwj2530616
[考研] 工科273调剂 +6 X1999 2026-04-09 7/350 2026-04-11 10:23 by zhq0425
[考研] 289 分105500药学专硕求调剂(找B区学校) +6 白云123456789 2026-04-09 8/400 2026-04-10 21:13 by zhouxiaoyu
[考研] 284求调剂 +19 梵@@ 2026-04-06 21/1050 2026-04-10 21:12 by zhouxiaoyu
[考研] 一志愿华东师范生物学326分,求调剂 +8 刘墨墨 2026-04-09 8/400 2026-04-10 12:00 by pengliang8036
[考研] 调剂申请086000一志愿西北农林科技大学生物与医药320分-本科齐鲁工业大学 +3 美美女士 2026-04-09 3/150 2026-04-10 10:31 by liuhuiying09
[考研] 考研二轮调剂 +8 故人?? 2026-04-09 8/400 2026-04-10 09:44 by 青梅duoduo
[考研] 301求调剂 +6 静静想想 2026-04-05 6/300 2026-04-10 09:15 by Delta2012
[考研] 307求调剂 +14 超级伊昂大王 2026-04-06 14/700 2026-04-08 07:03 by 无际的草原
[考研] 计算机408|在校多次国家级竞赛获奖|申请调剂 +4 东山大白鹅 2026-04-05 4/200 2026-04-08 00:18 by chongya
[考研] 生物医药调剂|SCI中科院三区一作+多项科研成果 +8 likangxing 2026-04-07 11/550 2026-04-08 00:02 by lys0704
信息提示
请填处理意见