| 查看: 863 | 回复: 7 | |||
| 本帖产生 1 个 模拟EPI ,点击这里进行查看 | |||
[交流]
【求助】求高人给我发一份GEMC的模拟程序
|
|||
|
小弟,最近在学习MC,觉得GEMC对我比较有用,可是在网上,我怎么都找不着。 如果有人有的话,能否给我发一份呢?万分感谢! 我的邮箱地址:zw198204@163.com |
» 猜你喜欢
遇见不省心的家人很难过
已经有17人回复
退学或坚持读
已经有25人回复
博士延得我,科研能力直往上蹿
已经有4人回复
免疫学博士有名额,速联系
已经有14人回复
面上基金申报没有其他的参与者成吗
已经有4人回复
多组分精馏求助
已经有6人回复
» 本主题相关价值贴推荐,对您同样有帮助:
求助sybyl关于添加形式电荷的问题
已经有8人回复
正在做大学生创新实践项目,车身方面,研究方向一直反复不定,跪求高人指点啊
已经有4人回复
苯环上的烷基取代。求高人指点。谢谢!
已经有23人回复
除掉反应生成的乙醇,拉动反应平衡。求高人指点
已经有15人回复
求各位高人给小弟支个招:我是否需要跨专业考研?
已经有24人回复
【求助】求将c语言改写为C++,求教高人啊!
已经有6人回复
【求助】求高人给分析一下三方相的xrd,帮我算算晶胞参数啊,自己不在行这个啊,赞助50
已经有8人回复
【求助】100金币求助高人一个程序解方程
已经有15人回复
» 抢金币啦!回帖就可以得到:
南方科技大学周友运课题组诚聘博士后、科研助理
+1/172
多功能 电子微生物生长分析仪 及 微生物快检技术开发服务
+2/150
Postdoctoral Research Fellow Position in Causal Inference Weill CorneIl Medicine
+1/92
黄汉民团队联合淮北师范大学招聘师资博士后(年薪30-40万)
+1/84
结构动力学与结构健康监测方向欧盟玛丽居里全奖博士招聘
+1/78
诚聘 有机光电材料计算方向 博士后、科研助理、访问学生
+1/75
中国海洋大学与中国水产科学研究院 联合培养 专硕 食品加工与安全
+1/75
深圳大学信息功能电子材料方向“申请-考核制”博士生招生
+2/70
电力全国重点实验室双一流A类长江学者团队招2026年全日制博士1-2名/博士后
+2/68
江西理工大学 稀土学院 稀土功能材料方向 招收2026届博士研究生、硕士研究生
+1/28
武汉工程大学绿碳技术与智能材料课题组诚招2026年博士研究生
+2/22
德国Karlsruhe Institute of Technology招收电化学储能及联合培养CSC博士
+1/14
中科院深圳先进院-免疫治疗方向-招收1名博士生(26年9月入学)
+1/13
考博求助
+1/13
南方科技大学仉晶晶课题组诚聘有机方向博士后、科研助理
+1/8
苏州大学招收申请考核制博士生、博士后(2026)
+1/6
澳科大招收2026年秋季入学药剂学/生物材料方向全奖博士研究生
+1/4
武汉工程大学董志兵教授课题组招收博士/硕士研究生(长期有效)
+1/2
英国兰卡斯特大学(Lancaster University)大模型、计算机视觉PhD招生
+1/2
接理论计算,主要包含第一性原理、分子动力学、机器学习、有限元模拟等,欢迎学术交流
+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













回复此楼