2013-10-01 21:43:14 +08:00
|
|
|
c
|
|
|
|
c do a sanity check on index parameters
|
|
|
|
subroutine meam_checkindex(num,lim,nidx,idx,ierr)
|
|
|
|
implicit none
|
|
|
|
integer i,num,lim,nidx,idx(3),ierr
|
|
|
|
|
|
|
|
ierr = 0
|
|
|
|
if (nidx.lt.num) then
|
|
|
|
ierr = 2
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
|
|
|
|
do i=1,num
|
|
|
|
if ((idx(i).lt.1).or.(idx(i).gt.lim)) then
|
|
|
|
ierr = 3
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
enddo
|
|
|
|
end
|
|
|
|
|
2007-01-31 05:53:58 +08:00
|
|
|
c
|
|
|
|
c Declaration in pair_meam.h:
|
|
|
|
c
|
|
|
|
c void meam_setup_param(int *, double *, int *, int *, int *);
|
|
|
|
c
|
|
|
|
c Call in pair_meam.cpp
|
|
|
|
c
|
|
|
|
c meam_setup_param(&which,&value,&nindex,index,&errorflag);
|
|
|
|
c
|
|
|
|
c
|
|
|
|
c
|
|
|
|
c The "which" argument corresponds to the index of the "keyword" array
|
|
|
|
c in pair_meam.cpp:
|
|
|
|
c
|
|
|
|
c 0 = Ec_meam
|
|
|
|
c 1 = alpha_meam
|
|
|
|
c 2 = rho0_meam
|
|
|
|
c 3 = delta_meam
|
|
|
|
c 4 = lattce_meam
|
|
|
|
c 5 = attrac_meam
|
|
|
|
c 6 = repuls_meam
|
|
|
|
c 7 = nn2_meam
|
|
|
|
c 8 = Cmin_meam
|
|
|
|
c 9 = Cmax_meam
|
|
|
|
c 10 = rc_meam
|
|
|
|
c 11 = delr_meam
|
|
|
|
c 12 = augt1
|
|
|
|
c 13 = gsmooth_factor
|
|
|
|
c 14 = re_meam
|
2009-08-19 01:02:09 +08:00
|
|
|
c 15 = ialloy
|
2011-02-23 04:30:53 +08:00
|
|
|
c 16 = mixture_ref_t
|
|
|
|
c 17 = erose_form
|
|
|
|
c 18 = zbl_meam
|
2011-07-20 02:31:58 +08:00
|
|
|
c 19 = emb_lin_neg
|
|
|
|
c 20 = bkgd_dyn
|
2007-01-31 05:53:58 +08:00
|
|
|
|
|
|
|
subroutine meam_setup_param(which, value, nindex,
|
|
|
|
$ index, errorflag)
|
|
|
|
|
|
|
|
use meam_data
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
integer which, nindex, index(3), errorflag
|
|
|
|
real*8 value
|
2011-02-23 04:30:53 +08:00
|
|
|
integer i1, i2
|
2007-01-31 05:53:58 +08:00
|
|
|
|
|
|
|
errorflag = 0
|
|
|
|
|
|
|
|
c 0 = Ec_meam
|
|
|
|
if (which.eq.0) then
|
2013-10-01 21:43:14 +08:00
|
|
|
call meam_checkindex(2,maxelt,nindex,index,errorflag)
|
|
|
|
if (errorflag.ne.0) return
|
2007-01-31 05:53:58 +08:00
|
|
|
Ec_meam(index(1),index(2)) = value
|
|
|
|
|
|
|
|
c 1 = alpha_meam
|
|
|
|
else if (which.eq.1) then
|
2013-10-01 21:43:14 +08:00
|
|
|
call meam_checkindex(2,maxelt,nindex,index,errorflag)
|
|
|
|
if (errorflag.ne.0) return
|
2007-01-31 05:53:58 +08:00
|
|
|
alpha_meam(index(1),index(2)) = value
|
|
|
|
|
|
|
|
c 2 = rho0_meam
|
|
|
|
else if (which.eq.2) then
|
2013-10-01 21:43:14 +08:00
|
|
|
call meam_checkindex(1,maxelt,nindex,index,errorflag)
|
|
|
|
if (errorflag.ne.0) return
|
2007-01-31 05:53:58 +08:00
|
|
|
rho0_meam(index(1)) = value
|
|
|
|
|
|
|
|
c 3 = delta_meam
|
|
|
|
else if (which.eq.3) then
|
2013-10-01 21:43:14 +08:00
|
|
|
call meam_checkindex(2,maxelt,nindex,index,errorflag)
|
|
|
|
if (errorflag.ne.0) return
|
2007-01-31 05:53:58 +08:00
|
|
|
delta_meam(index(1),index(2)) = value
|
|
|
|
|
|
|
|
c 4 = lattce_meam
|
|
|
|
else if (which.eq.4) then
|
2013-10-01 21:43:14 +08:00
|
|
|
call meam_checkindex(2,maxelt,nindex,index,errorflag)
|
|
|
|
if (errorflag.ne.0) return
|
2007-01-31 05:53:58 +08:00
|
|
|
if (value.eq.0) then
|
|
|
|
lattce_meam(index(1),index(2)) = "fcc"
|
|
|
|
else if (value.eq.1) then
|
|
|
|
lattce_meam(index(1),index(2)) = "bcc"
|
|
|
|
else if (value.eq.2) then
|
|
|
|
lattce_meam(index(1),index(2)) = "hcp"
|
|
|
|
else if (value.eq.3) then
|
|
|
|
lattce_meam(index(1),index(2)) = "dim"
|
|
|
|
else if (value.eq.4) then
|
|
|
|
lattce_meam(index(1),index(2)) = "dia"
|
|
|
|
else if (value.eq.5) then
|
|
|
|
lattce_meam(index(1),index(2)) = 'b1'
|
|
|
|
else if (value.eq.6) then
|
|
|
|
lattce_meam(index(1),index(2)) = 'c11'
|
2009-08-19 01:02:09 +08:00
|
|
|
else if (value.eq.7) then
|
|
|
|
lattce_meam(index(1),index(2)) = 'l12'
|
2011-02-23 04:30:53 +08:00
|
|
|
else if (value.eq.8) then
|
|
|
|
lattce_meam(index(1),index(2)) = 'b2'
|
2007-01-31 05:53:58 +08:00
|
|
|
endif
|
|
|
|
|
|
|
|
c 5 = attrac_meam
|
|
|
|
else if (which.eq.5) then
|
2013-10-01 21:43:14 +08:00
|
|
|
call meam_checkindex(2,maxelt,nindex,index,errorflag)
|
|
|
|
if (errorflag.ne.0) return
|
2007-01-31 05:53:58 +08:00
|
|
|
attrac_meam(index(1),index(2)) = value
|
|
|
|
|
|
|
|
c 6 = repuls_meam
|
|
|
|
else if (which.eq.6) then
|
2013-10-01 21:43:14 +08:00
|
|
|
call meam_checkindex(2,maxelt,nindex,index,errorflag)
|
|
|
|
if (errorflag.ne.0) return
|
2007-01-31 05:53:58 +08:00
|
|
|
repuls_meam(index(1),index(2)) = value
|
|
|
|
|
|
|
|
c 7 = nn2_meam
|
|
|
|
else if (which.eq.7) then
|
2013-10-01 21:43:14 +08:00
|
|
|
call meam_checkindex(2,maxelt,nindex,index,errorflag)
|
|
|
|
if (errorflag.ne.0) return
|
2011-02-23 04:30:53 +08:00
|
|
|
i1 = min(index(1),index(2))
|
|
|
|
i2 = max(index(1),index(2))
|
|
|
|
nn2_meam(i1,i2) = value
|
2007-01-31 05:53:58 +08:00
|
|
|
|
|
|
|
c 8 = Cmin_meam
|
|
|
|
else if (which.eq.8) then
|
2013-10-01 21:43:14 +08:00
|
|
|
call meam_checkindex(3,maxelt,nindex,index,errorflag)
|
|
|
|
if (errorflag.ne.0) return
|
2007-01-31 05:53:58 +08:00
|
|
|
Cmin_meam(index(1),index(2),index(3)) = value
|
|
|
|
|
|
|
|
c 9 = Cmax_meam
|
|
|
|
else if (which.eq.9) then
|
2013-10-01 21:43:14 +08:00
|
|
|
call meam_checkindex(3,maxelt,nindex,index,errorflag)
|
|
|
|
if (errorflag.ne.0) return
|
2007-01-31 05:53:58 +08:00
|
|
|
Cmax_meam(index(1),index(2),index(3)) = value
|
|
|
|
|
|
|
|
c 10 = rc_meam
|
|
|
|
else if (which.eq.10) then
|
|
|
|
rc_meam = value
|
|
|
|
|
|
|
|
c 11 = delr_meam
|
|
|
|
else if (which.eq.11) then
|
|
|
|
delr_meam = value
|
|
|
|
|
|
|
|
c 12 = augt1
|
|
|
|
else if (which.eq.12) then
|
|
|
|
augt1 = value
|
|
|
|
|
|
|
|
c 13 = gsmooth
|
|
|
|
else if (which.eq.13) then
|
|
|
|
gsmooth_factor = value
|
|
|
|
|
|
|
|
c 14 = re_meam
|
|
|
|
else if (which.eq.14) then
|
2013-10-01 21:43:14 +08:00
|
|
|
call meam_checkindex(2,maxelt,nindex,index,errorflag)
|
|
|
|
if (errorflag.ne.0) return
|
2007-01-31 05:53:58 +08:00
|
|
|
re_meam(index(1),index(2)) = value
|
|
|
|
|
2009-08-19 01:02:09 +08:00
|
|
|
c 15 = ialloy
|
|
|
|
else if (which.eq.15) then
|
|
|
|
ialloy = value
|
|
|
|
|
2011-02-23 04:30:53 +08:00
|
|
|
c 16 = mixture_ref_t
|
|
|
|
else if (which.eq.16) then
|
|
|
|
mix_ref_t = value
|
|
|
|
|
|
|
|
c 17 = erose_form
|
|
|
|
else if (which.eq.17) then
|
|
|
|
erose_form = value
|
|
|
|
|
|
|
|
c 18 = zbl_meam
|
|
|
|
else if (which.eq.18) then
|
2013-10-01 21:43:14 +08:00
|
|
|
call meam_checkindex(2,maxelt,nindex,index,errorflag)
|
|
|
|
if (errorflag.ne.0) return
|
2011-02-23 04:30:53 +08:00
|
|
|
i1 = min(index(1),index(2))
|
|
|
|
i2 = max(index(1),index(2))
|
|
|
|
zbl_meam(i1,i2) = value
|
|
|
|
|
2011-07-20 02:31:58 +08:00
|
|
|
c 19 = emb_lin_neg
|
|
|
|
else if (which.eq.19) then
|
|
|
|
emb_lin_neg = value
|
|
|
|
|
|
|
|
c 20 = bkgd_dyn
|
|
|
|
else if (which.eq.20) then
|
|
|
|
bkgd_dyn = value
|
|
|
|
|
2007-01-31 05:53:58 +08:00
|
|
|
else
|
|
|
|
errorflag = 1
|
|
|
|
endif
|
|
|
|
|
|
|
|
return
|
|
|
|
end
|