#get density and box size from user if not specified
if(! -var msf) getvar msf checkfile=true \
msg="Please tell the msf file of basic unit"
if(! -var density) getvar density msg="no density specified" \
default=1.0 min=1e-6 max=100
if(! -var a) getvar a msg="no box length specified"\
default=32 min=18 max=1000
#load force field
include "loadff.inc"
#load MSF built previously
loadmsf file="$msf"
#reorient molecule and move center to origin
atom reorient select="all"
#get atoms count for the single unit
tell natom select="all"
natomu=$natom
#compute the unit extension, assume it's in cubic shape
tell mass select="all"
vol=$totmass/0.602214199/$density
lunit=pow($vol,1/3)
#compute number of replication for each dimmension
nx=int($a/$lunit+1)
ny=int($a/$lunit+1)
nz=int($a/$lunit+1)
#do replication
replicate nx=$nx ny=$ny nz=$nz stride=($lunit,$lunit,$lunit)
#make random orient for each single unit
if(-var rotate) {
iu=0
nu=$nx*$ny*$nz
while($iu<$nu) {
ias=$iu*$natomu
iae=$ias+$natomu-1
tell center select="atomidx $ias:$iae"
xv=rand(1.0)
yv=rand(1.0)
zv=sqrt(1-$xv*$xv-$yv*$yv)
th=rand(360)
atom rotate origin=($xce,$yce,$zce) vector=($xv,$yv,$zv) theta=$th \
select="atomidx $ias:$iae"
iu=$iu+1
}
}
#the actual box size
a=$nx*$lunit
#move center to origin
atom transto pos=(0,0,0) select="all"
#setup crystal/pbc box
pbcbox type=cubic a=$a
#save PBC setup for further usage
tell box
echo "crystal type=$boxtype a=$boxa" > pbc.inc
tell bestfft
echo "fftx=$fftx" >> pbc.inc
echo "ffty=$ffty" >> pbc.inc
echo "fftz=$fftz" >> pbc.inc
#image groups
imggroup method=resid sorted=true select="all"
#nonbond setup
nonbond type=pme nblcutoff=12.0 nbcutoff=10.0 swcutoff=8.0 eps=1.0 \
beta=0.34 ftx=$fftx fty=$ffty ftz=$fftz bsorder=4
tell msf_info
echo -hs "number of residues: $nres"
echo -hs "number of atoms: $natom"
tell box
echo -hs "box type: $boxtype"
echo -hs "box size: $boxa x $boxb x $boxc"
tell density
echo -hs "density: $density"
#do minimization
echo -hs "running minimization ..."
minimize type=sdfuse nstep=200 nprint=10 ftol=1e-5 \
frqene=1 enefile=step2_solvbox_min1.ene
minimize type=mc nstep=200 nprint=10 ftol=1e-5 \
frqene=1 enefile=step2_solvbox_min2.ene
minimize type=sd nstep=200 nprint=10 ftol=1e-5 \
frqene=1 enefile=step2_solvbox_min3.ene
#save msf and crd
savemsf file="step2_solvbox.msf"
savecrd fmt=pdb file="step2_solvbox.pdb"
tell density
tell msf_info |