版块导航
正在加载中...
客户端APP下载
论文辅导
申博辅导
登录
注册
帖子
帖子
用户
本版
应《网络安全法》要求,自2017年10月1日起,未进行实名认证将不得使用互联网跟帖服务。为保障您的帐号能够正常使用,请尽快对帐号进行手机号验证,感谢您的理解与支持!
24小时热门版块排行榜
>
论坛更新日志
(1037)
>
虫友互识
(136)
>
论文投稿
(19)
>
硕博家园
(16)
>
导师招生
(15)
>
基金申请
(14)
>
考研
(11)
>
考博
(10)
>
文献求助
(10)
>
教师之家
(9)
>
论文道贺祈福
(8)
>
公派出国
(8)
>
休闲灌水
(8)
>
找工作
(3)
>
海归之家
(1)
>
海外博后
(1)
小木虫论坛-学术科研互动平台
»
计算模拟区
»
分子模拟
»
Monte Carlo
»
【原创】MCM-41的孔径分布的计算
5
1/1
返回列表
查看: 2235 | 回复: 13
只看楼主
@他人
存档
新回复提醒
(忽略)
收藏
在APP中查看
本帖产生 1 个 模拟EPI ,点击这里进行查看
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖
zyj8119
木虫
(著名写手)
模拟EPI: 10
应助: 65
(初中生)
贵宾: 0.003
金币: 915.1
散金: 1440
红花: 35
帖子: 2936
在线: 1329.4小时
虫号: 664177
注册: 2008-11-29
性别: GG
专业: 理论和计算化学
[交流]
【原创】MCM-41的孔径分布的计算
已有4人参与
接上一个帖子,MCM-41建好的模型会有孔径分布,这个在定义中是很复杂的,应该怎么计算呢,可以导出MCM-41中所有的H原子,然后自己写程序去计算孔径分布,我使用的是FORTRAN语言,导出的car结构中,可以使用EXCEL找到所有的H原子,这些H原子的 car文件可以保存为一个名叫H.car的文件,这个文件就可以进行孔径分布的计算,car文件的优点是带有电荷。读入这个car文件,可以输出一个名叫output.car的文件。
CODE:
integer hno
parameter(hno=2356)
character a(hno)*5,fx(hno)*4,fft(hno)*5,natom(hno)*1
double precision xc(hno),yc(hno),zc(hno)
integer occupation(hno)
real charge(hno)
open(10,file='H.car',status='old')
do 20 i=1,hno
read(10,*)a(i),xc(i),yc(i),zc(i),fx(i),occupation(i),fft(i),
& natom(i),charge(i)
20 continue
close(10)
jmm=0
open(30,file='output.car',access='append')
*40 amm=RAN2(IDUM)
40 imm=int(RAN2(IDUM)*hno)
if(charge(imm).lt.1.0)then
jmm=jmm+1
write(30,888)a(imm),xc(imm),yc(imm),zc(imm),fx(imm),
& occupation(imm),fft(imm),natom(imm),charge(imm)
charge(imm)=2.0
endif
if(jmm.eq.50.or.jmm.eq.100.or.jmm.eq.150.or.jmm.eq.200.or.
& jmm.eq.250.or.jmm.eq.300.or.jmm.eq.350.or.jmm.eq.400)then
write(30,*)'********************',jmm,'**************************'
write(30,*)'********************',jmm,'**************************'
endif
if(jmm.lt.415)then
goto 40
else
goto 50
endif
50 close(30)
888 format(A5,3X,F12.9,2X,F13.9,3X,F12.9,1X,A4,1X,I1,6X,A5,3X,A1,F8.3)
end
*&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
* Random Number Generator
*&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
FUNCTION RAN2(IDUM)
INTEGER idum,IM1,IM2,IMM1,IA1,IA2,IQ1,IQ2,IR1,IR2,NTAB,NDIV
REAL ran2,AM,EPS,RNMX
PARAMETER (IM1=2147483563,IM2=2147483399,AM=1./IM1,IMM1=IM1-1,
*IA1=40014,IA2=40692,IQ1=53668,IQ2=52774,IR1=12211,IR2=3791,
*NTAB=32,NDIV=1+IMM1/NTAB,EPS=1.2e-7,RNMX=1.-EPS)
INTEGER idum2,j,k,iv(NTAB),iy
SAVE iv,iy,idum2
DATA idum2/123456789/, iv/NTAB*0/, iy/0/
if (idum.le.0) then
idum=max(-idum,1)
idum2=idum
do 11 j=NTAB+8,1,-1
k=idum/IQ1
idum=IA1*(idum-k*IQ1)-k*IR1
if (idum.lt.0) idum=idum+IM1
if (j.le.NTAB) iv(j)=idum
11 continue
iy=iv(1)
endif
k=idum/IQ1
idum=IA1*(idum-k*IQ1)-k*IR1
if (idum.lt.0) idum=idum+IM1
k=idum2/IQ2
idum2=IA2*(idum2-k*IQ2)-k*IR2
if (idum2.lt.0) idum2=idum2+IM2
j=1+iy/NDIV
iy=iv(j)-idum2
iv(j)=idum
if(iy.lt.1)iy=iy+IMM1
ran2=min(AM*iy,RNMX)
return
END
其中的nho是你的H.car中H原子的个数,可以按照你的文件的不同随意更改成你所需要的值,得到的output.car可以做下一步的计算。
[
Last edited by zyj8119 on 2010-12-2 at 14:14
]
回复此楼
» 猜你喜欢
博士读完未来一定会好吗
已经有6人回复
小论文投稿
已经有3人回复
Bioresource Technology期刊,第一次返修的时候被退回好几次了
已经有9人回复
心脉受损
已经有3人回复
到新单位后,换了新的研究方向,没有团队,持续积累2区以上论文,能申请到面上吗
已经有8人回复
申请2026年博士
已经有6人回复
请问哪里可以有青B申请的本子可以借鉴一下。
已经有5人回复
高级回复
» 本主题相关价值贴推荐,对您同样有帮助:
【求助】氮吸附曲线
已经有17人回复
【求助】为什么我在不同温度下制备的MCM-41的小角XRD和孔径都一样,但BET和孔容差别很
已经有5人回复
【讨论】关于N2吸附脱附的问题问题.
已经有9人回复
【求助】BET 孔径计算
已经有10人回复
【求助】如何计算Cu-MCM-41的晶胞常数
已经有3人回复
【求助】mcm-41的xrd,求高手指点
已经有32人回复
【求助成功】MS模拟MCM-41过程中forcite filed计算的问题
已经有12人回复
好好学习,天天向上。
1楼
2010-12-02 00:24:27
已阅
回复此楼
关注TA
给TA发消息
送TA红花
TA的回帖
zyj8119
木虫
(著名写手)
模拟EPI: 10
应助: 65
(初中生)
贵宾: 0.003
金币: 915.1
散金: 1440
红花: 35
帖子: 2936
在线: 1329.4小时
虫号: 664177
注册: 2008-11-29
性别: GG
专业: 理论和计算化学
统计完成以后,接下来就是计算孔径分布了,源程序是这样的:
CODE:
* main program
real cx,cy
integer HNO,lattice
open(1000,file='parameter.txt',status='old')
read(1000,*)cx
read(1000,*)cy
read(1000,*)HNO
read(1000,*)lattic
call statistic(cx,cy,HNO,lattic)
* write(*,*)cx,cy,HNO
end
subroutine statistic(cx,cy,HNO,lattic)
real cx,cy,cz,fc0,cx0,cy0,range,step
integer HNO,cyc,lattic
real p(HNO,11),r(lattic,lattic,HNO),rp(lattic,100)
real d(HNO),rmin,rmax,fc(lattic,lattic)
integer nb(0:99)
range=10.0
open(10,file='input.txt',status='old')
do 10 i=1,HNO
read(10,*)(p(i,j),j=1,11)
* if(p(i,6).gt.29)then
* p(i,6)=p(i,6)-57.975988
* end if
* if(p(i,7).gt.67)then
* p(i,7)=p(i,7)-133.758958
* end if
100 continue
close(10)
***************print the coordinate***********************
open(1000,file='output.txt',access='append')
write(1000,*)'**********x coordinate*****************
do 1001 i=1,HNO
write(1000,*)p(i,6)
1001 continue
write(1000,*)'**********y coordinate*****************
do 1002 i=1,HNO
write(1000,*)p(i,7)
1002 continue
write(1000,*)'**********y coordinate*****************
do 1003 i=1,HNO
write(1000,*)p(i,8)
1003 continue
close(1000)
********************************************************
do 220 cyc=1,10
fc0=1.0e20
cx0=cx
cy0=cy
step=range*2.0/(1.0*lattic)
do 101 i=1,lattic
do 102 j=1,lattic
rp(i,j)=0.0
fc(i,j)=0.0
102 continue
101 continue
do 110 i=1,lattic
do 120 j=1,lattic
do 130 k=1,HNO
cx=cx0-range+step*i
cy=cy0-range+step*j
r(i,j,k)=sqrt((p(k,6)-cx)**2+(p(k,6)-cy)**2)
rp(i,j)=rp(i,j)+r(i,j,k)/(HNO*1.0)
130 continue
120 continue
110 continue
do 140 i=1,lattic
do 150 j=1,lattic
do 160 k=1,HNO
fc(i,j)=fc(i,j)+(r(i,j,k)-rp(i,j))**2
160 continue
fc(i,j)=sqrt(fc(i,j)/1.0*(HNO-1)))
if(fc(i,j).lt.fc0)then
fc0=fc(i,j)
cx=cx0-range+step*i
cy=cy0-range+step*j
end if
150 continue
140 continue
range=range/2.0
220 continue
do 170 i=1,HNO
d(i)=sqrt((p(i,6)-cx)**2+(p(i,7)-cy)**2)
170 continue
open(20,file='output.txt',access='append')
write(20,*)'the center of pore'
write(20,*)'x=',cx,'y=',cy
write(20,*)'fangcha=',fc0
write(20,*)'****************************'
write(20,*)'distance between Hydrogen atom and the center of pore'
do 180 i=1,HNO
write(20,*)d(i)
180 continue
close(20)
do 185 i=0,99
nb(i)=0
185 continue
do 190 i=0,99
rmin=10.0+0.1*i
rmax=10.0+0.1*(i+1)
do 200 j=1,HNO
if(rmin.lt.d(j).and.rmax.ge.d(j))then
nb(i)=nb(i)+1
200 continue
190 continue
open(30,file='output.txt',access='append')
write(30,*)'****************nb*****************'
write(30,*)'distribution of pore radius'
do 210 i=0,99
rr=10.1+0.1*i
write(30,*)nb(i)
* write(30,*)nb(i)
210 continue
close(30)
end
对文件中nb(i)画图拟合,就是所要得到的孔径分布曲线。
[
Last edited by zyj8119 on 2010-12-2 at 10:03
]
赞
一下
回复此楼
高级回复
好好学习,天天向上。
7楼
2010-12-02 10:01:19
已阅
回复此楼
关注TA
给TA发消息
送TA红花
TA的回帖
查看全部 14 个回答
qphll
金虫
(正式写手)
模拟EPI: 10
应助: 18
(小学生)
金币: 2708.7
散金: 2294
红花: 8
帖子: 554
在线: 227.1小时
虫号: 89654
注册: 2005-08-29
性别: GG
专业: 碳素材料与超硬材料
★
小木虫(金币
+0.5
):给个红包,谢谢回帖交流
赞一下.
自己动手, 其乐无穷.
赞
一下
(1人)
回复此楼
Life, Love, Laugh.
2楼
2010-12-02 00:27:09
已阅
回复此楼
关注TA
给TA发消息
送TA红花
TA的回帖
zyj8119
木虫
(著名写手)
模拟EPI: 10
应助: 65
(初中生)
贵宾: 0.003
金币: 915.1
散金: 1440
红花: 35
帖子: 2936
在线: 1329.4小时
虫号: 664177
注册: 2008-11-29
性别: GG
专业: 理论和计算化学
引用回帖:
Originally posted by
qphll
at 2010-12-02 00:27:09:
赞一下.
自己动手, 其乐无穷.
多谢,这个输出的output.car文件在下一步还有用,程序明天给出。
赞
一下
回复此楼
好好学习,天天向上。
3楼
2010-12-02 00:28:52
已阅
回复此楼
关注TA
给TA发消息
送TA红花
TA的回帖
qphll
金虫
(正式写手)
模拟EPI: 10
应助: 18
(小学生)
金币: 2708.7
散金: 2294
红花: 8
帖子: 554
在线: 227.1小时
虫号: 89654
注册: 2005-08-29
性别: GG
专业: 碳素材料与超硬材料
★
小木虫(金币
+0.5
):给个红包,谢谢回帖交流
引用回帖:
Originally posted by
zyj8119
at 2010-12-02 00:28:52:
多谢,这个输出的output.car文件在下一步还有用,程序明天给出。
嗯, 期待!
我也可以喘口气, 更新一下前面的几个帖子. 连着看了三天的lammps manual.....
赞
一下
(1人)
回复此楼
Life, Love, Laugh.
4楼
2010-12-02 01:12:32
已阅
回复此楼
关注TA
给TA发消息
送TA红花
TA的回帖
查看全部 14 个回答
如果回帖内容含有宣传信息,请如实选中。否则帐号将被全论坛禁言
普通表情
龙
兔
虎
猫
高级回复
(可上传附件)
百度网盘
|
360云盘
|
千易网盘
|
华为网盘
在新窗口页面中打开自己喜欢的网盘网站,将文件上传后,然后将下载链接复制到帖子内容中就可以了。
信息提示
关闭
请填处理意见
关闭
确定