| 查看: 843 | 回复: 7 | |||
| 本帖产生 1 个 模拟EPI ,点击这里进行查看 | |||
[交流]
【求助】求高人给我发一份GEMC的模拟程序
|
|||
|
小弟,最近在学习MC,觉得GEMC对我比较有用,可是在网上,我怎么都找不着。 如果有人有的话,能否给我发一份呢?万分感谢! 我的邮箱地址:zw198204@163.com |
» 猜你喜欢
参与限项
已经有3人回复
假如你的研究生提出不合理要求
已经有7人回复
实验室接单子
已经有4人回复
全日制(定向)博士
已经有4人回复
对氯苯硼酸纯化
已经有3人回复
求助:我三月中下旬出站,青基依托单位怎么办?
已经有12人回复
不自信的我
已经有12人回复
所感
已经有4人回复
要不要辞职读博?
已经有7人回复
北核录用
已经有3人回复
» 本主题相关价值贴推荐,对您同样有帮助:
求助sybyl关于添加形式电荷的问题
已经有8人回复
正在做大学生创新实践项目,车身方面,研究方向一直反复不定,跪求高人指点啊
已经有4人回复
苯环上的烷基取代。求高人指点。谢谢!
已经有23人回复
除掉反应生成的乙醇,拉动反应平衡。求高人指点
已经有15人回复
求各位高人给小弟支个招:我是否需要跨专业考研?
已经有24人回复
【求助】求将c语言改写为C++,求教高人啊!
已经有6人回复
【求助】求高人给分析一下三方相的xrd,帮我算算晶胞参数啊,自己不在行这个啊,赞助50
已经有8人回复
【求助】100金币求助高人一个程序解方程
已经有15人回复
» 抢金币啦!回帖就可以得到:
上海科技大学物质科学与技术学院|王平鸾课题组长期招聘(博后/博硕/科研助理)
+1/176
上海交通大学任垭萌课题组招聘申请-考核博士
+1/87
供应EXAKT德国艾卡特3D打印材料分散用三辊研磨机80E PLUS
+1/86
上海师范大学生物医用材料方向招收2026级博士研究生
+1/77
深圳大学材料学院黄妍斐教授课题组诚招2026年秋季入学博士生
+1/75
昆士兰科技大学(QUT)博士招生信息 导师:李志勇教授
+1/41
坐标济南,山东农科院招 有机合成 or 药物化学 联培硕士研究生
+1/35
上海科技大学物质科学与技术学院|王平鸾课题组联合招聘博士后
+1/29
中科院理化技术研究所张飞龙研究员/王树涛研究员团队招生(博士/硕士)
+1/27
SCI,计算机相关可以写
+1/21
SCI,计算机相关可以写
+1/20
中国矿业大学(徐州)蒋江民课题组招收2026年秋季新能源储能材料与器件方向博士生
+1/15
武汉双一流高校干细胞与肿瘤生物学团队招聘2026级申请考核制博士生
+1/7
英国斯旺西大学(Swansea University)招半导体材料和器件方向CSC博士生
+1/5
上海大学李浩源课题组招收2026年秋季材料计算/机器学习方向博士生
+1/5
浙江大学傅杰团队(杰青)高薪招聘博士后
+1/4
中国科学院大学-杨晗课题组-诚聘-博士后、副研究员
+1/3
湘潭大学沈志刚教授课题组欢迎博士生报考,博士后加盟
+1/3
武汉双一流高校干细胞与肿瘤生物学团队招聘2026级申请考核制博士生
+1/2
福建师范大学海峡柔性电子学院-2026年9月入学博士-考核制
+1/1
2楼2010-11-29 00:01:34
3楼2010-11-29 09:50:07
4楼2010-12-02 10:47:45
5楼2010-12-02 12:43:57
6楼2010-12-03 10:52:50
★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
zh1987hs(金币+10):谢谢 2010-12-04 23:13:56
ghcacj(金币+3, 模拟EPI+1):精彩答疑 2010-12-06 12:16:56
zh1987hs(金币+10):谢谢 2010-12-04 23:13:56
ghcacj(金币+3, 模拟EPI+1):精彩答疑 2010-12-06 12:16:56
|
答应过的事情, 虽然觉得其实对楼主帮助也不大. 因为我不可能给你写一个完整的GibbsMC, 如果你自己不努力去理解, 那么什么都是白搭. 这是大体结构. 按照需要填充就是了. 应该此贴不会再更新了. 文件名: GibbsMC.f90 文件内容如下: PROGRAM MC USE global IMPLICIT NONE ! Local INTEGER :: ibox, iblock, istep INTEGER :: ts,tf,rate DOUBLE PRECISION :: engtst, virtst, engerr ! Initialize the random number generator CALL seed_random(idum) ! Read the input file CALL read_input ! Get the start time CALL system_clock(count=ts, count_rate=rate) ! Perform minimization CALL relax ! Calculate energy and virial DO ibox = 1,n_box CALL eng_total(ibox,energy(ibox),virial(ibox)) CALL write_config(ibox,0) ENDDO ! Loop over the blocks DO iblock = 1,n_blocks ! Reset basic statistics CALL stats(1,0,0) ! Reset optional statistics IF(opt .EQ. 1) CALL sample(1,0,0) ! Loop over the steps per block DO istep = 1,n_steps ! Perform a trial move CALL trial_move(iblock,istep) ! Accumulate basic statistics CALL stats(2,iblock,istep) ! Accumulate optional statistics IF(opt .EQ. 1) call sample(2,iblock,istep) ! End loop over the steps per block ENDDO ! Average basic statistics for iblock CALL stats(3,iblock,0) ! Average optional statistics for iblock IF(opt .EQ. 1) call sample(3,iblock,0) ! Update the max values (disp, volchng, etc) CALL update_max ! Print status IF(iblock .LE. n_equil) THEN IF(iblock .EQ. 1) WRITE(*,'(A)')'Equilibration stage... ' IF(MOD(NINT(100.0d0*DBLE(iblock)),10*n_equil) .EQ. 0)& &WRITE(*,'(I0,A3)')NINT(100.0d0*DBLE(iblock)/DBLE(n_equil)),'% ' IF(iblock .EQ. n_equil) WRITE(*,*)'' ELSE IF(iblock .EQ. n_equil + 1) WRITE(*,'(A)')'Production stage... ' IF(MOD(NINT(100.0d0*DBLE(iblock-n_equil)),10*(n_blocks-n_equil)).EQ. 0)& &WRITE(*,'(I0,A3)')NINT(100.0d0*DBLE(iblock-n_equil)/DBLE(n_blocks-n_equil)),'% ' IF(iblock .EQ. n_blocks) WRITE(*,*)'' ENDIF ! Check the total and updated energy consistency for each box (every 10 blocks) IF(MOD(iblock,1) .EQ. 0) THEN DO ibox = 1,n_box CALL eng_total(ibox,engtst,virtst) engerr = dABS((engtst - energy(ibox))) IF (engerr .GE. 1.0d-5) THEN WRITE(*,*) 'WARNING: LARGE ERROR BETWEEN THE TOTAL AND UPDATED ENERGY' WRITE(*,'(A7,I0,A6,I0,A10,F20.8,A10,F20.8)')& &'BLOCK: ',iblock,' BOX: ',ibox,' UPD ENG: ',energy(ibox),' TOT ENG: ',engtst ENDIF ENDDO ENDIF ! End loop over the blocks ENDDO ! Get the finish time CALL system_clock(count=tf, count_rate=rate) ! Write the elapsed time to screen CALL time_elapsed(tf,ts,rate) ! Write basic statistics CALL stats(4,0,0) ! Write optional statistics IF(opt .EQ. 1) CALL sample(4,n_blocks+1,0) ! Write the final configurations DO ibox = 1,n_box CALL write_config(ibox,n_blocks+1) ENDDO END PROGRAM MC |
7楼2010-12-04 23:08:18
8楼2010-12-05 08:58:05












回复此楼