| 查看: 862 | 回复: 7 | |||
| 本帖产生 1 个 模拟EPI ,点击这里进行查看 | |||
[交流]
【求助】求高人给我发一份GEMC的模拟程序
|
|||
|
小弟,最近在学习MC,觉得GEMC对我比较有用,可是在网上,我怎么都找不着。 如果有人有的话,能否给我发一份呢?万分感谢! 我的邮箱地址:zw198204@163.com |
» 猜你喜欢
遇见不省心的家人很难过
已经有16人回复
退学或坚持读
已经有25人回复
博士延得我,科研能力直往上蹿
已经有4人回复
免疫学博士有名额,速联系
已经有14人回复
面上基金申报没有其他的参与者成吗
已经有4人回复
多组分精馏求助
已经有6人回复
» 本主题相关价值贴推荐,对您同样有帮助:
求助sybyl关于添加形式电荷的问题
已经有8人回复
正在做大学生创新实践项目,车身方面,研究方向一直反复不定,跪求高人指点啊
已经有4人回复
苯环上的烷基取代。求高人指点。谢谢!
已经有23人回复
除掉反应生成的乙醇,拉动反应平衡。求高人指点
已经有15人回复
求各位高人给小弟支个招:我是否需要跨专业考研?
已经有24人回复
【求助】求将c语言改写为C++,求教高人啊!
已经有6人回复
【求助】求高人给分析一下三方相的xrd,帮我算算晶胞参数啊,自己不在行这个啊,赞助50
已经有8人回复
【求助】100金币求助高人一个程序解方程
已经有15人回复
» 抢金币啦!回帖就可以得到:
哈尔滨工程大学青岛创新发展基地招聘青年教师
+1/511
南方科技大学周友运课题组诚聘博士后、科研助理
+1/172
Postdoctoral Research Fellow Position in Causal Inference Weill CorneIl Medicine
+1/92
中国海洋大学与中国水产科学研究院 联合培养 专硕 食品加工与安全
+1/75
香港科技大学计算物理及流体力学课题组招收全奖博士后及博士生(2026年9月入学)
+1/44
操作求助
+1/36
科罗拉多大学 Congjun Yu 课题组招聘
+1/29
山东科技大学招聘化学化工博士博士后
+1/28
武汉工程大学绿碳技术与智能材料课题组诚招2026年博士研究生
+2/22
意大利华人老师University of Padova-全额奖学金博士
+1/13
求资源
+1/12
南京林业大学国家级青年人才团队招收2026年生物质转化/炭材料/储能等方向博士生
+1/10
南方科技大学仉晶晶课题组诚聘有机方向博士后、科研助理
+1/8
上海理工大学顾敏院士、张轶楠教授团队 招聘 2026级 光学工程 博士生
+1/7
苏州大学招收申请考核制博士生、博士后(2026)
+1/6
加氢裂化
+1/5
《中文期刊点评》这个模块,怎么不能点评期刊了呢自动跳转到主页了
+1/5
广东省智能院与澳门大学/澳门理工联培博士招生
+1/5
英国兰卡斯特大学(Lancaster University)大模型、计算机视觉PhD招生
+1/2
海南大学生态学博士点招收2026年博士研究生(第二批)
+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













回复此楼