add cores args
This commit is contained in:
@@ -14,6 +14,8 @@ WATERMODEL=${WATERMODEL:-"tip3p"}
|
||||
WATERTOPFILE=${WATERTOPFILE:-"spc216.gro"}
|
||||
BOXTYPE=${BOXTYPE:-"tric"}
|
||||
BOXORIENTATION=${BOXORIENTATION:-"1.0"}
|
||||
NUM_CORES=${NUM_CORES:-$(($(nproc) - 2))} # 默认使用 CPU 核心数减去 2,如果外部有设置则使用外部值
|
||||
NUM_CORES=$((NUM_CORES > 0 ? NUM_CORES : 1)) # 确保 NUM_CORES 至少为 1
|
||||
NSTEPS=${NSTEPS:-500000} # 50,000 steps for 1 ns
|
||||
DT=${DT:-0.002} # 2 fs
|
||||
#BOXSIZE="5.0"
|
||||
@@ -48,13 +50,14 @@ echo "XTC_FILE: $XTC_FILE"
|
||||
echo "NO_PBC_XTC_FILE: $NO_PBC_XTC_FILE"
|
||||
echo "OUTPUT_FOLDER: $OUTPUT_FOLDER"
|
||||
echo "EXTRACT_EVERY_PS: $EXTRACT_EVERY_PS"
|
||||
echo "NUM_CORES: $NUM_CORES"
|
||||
|
||||
# generate GROMACS .gro file
|
||||
gmx_mpi pdb2gmx -f $NAME.pdb -o $NAME.gro -ff $FORCEFIELD -water $WATERMODEL -ignh -p topol.top
|
||||
mpirun -np $NUM_CORES gmx_mpi pdb2gmx -f $NAME.pdb -o $NAME.gro -ff $FORCEFIELD -water $WATERMODEL -ignh -p topol.top
|
||||
# define the box
|
||||
gmx_mpi editconf -f $NAME.gro -o $NAME-box.gro -bt $BOXTYPE -c -d $BOXORIENTATION
|
||||
mpirun -np $NUM_CORES gmx_mpi editconf -f $NAME.gro -o $NAME-box.gro -bt $BOXTYPE -c -d $BOXORIENTATION
|
||||
# add solvate
|
||||
gmx_mpi solvate -cp $NAME-box.gro -cs $WATERTOPFILE -o $NAME-solv.gro -p topol.top
|
||||
mpirun -np $NUM_CORES gmx_mpi solvate -cp $NAME-box.gro -cs $WATERTOPFILE -o $NAME-solv.gro -p topol.top
|
||||
# add icons # ! ions.mdp add by manual
|
||||
# --- ions.mdp file content --- #
|
||||
cat << EOF > ions.mdp
|
||||
@@ -73,8 +76,9 @@ rcoulomb = 1.0 ; Short-range electrostatic cut-off
|
||||
rvdw = 1.0 ; Short-range Van der Waals cut-off
|
||||
pbc = xyz ; Periodic Boundary Conditions in all 3 dimensions
|
||||
EOF
|
||||
gmx_mpi grompp -f ions.mdp -c $NAME-solv.gro -p topol.top -o ions.tpr -maxwarn 1
|
||||
echo SOL | gmx_mpi genion -s ions.tpr -o $NAME-solv-ions.gro -p topol.top -pname NA -nname CL -conc 0.125 -neutral
|
||||
mpirun -np $NUM_CORES gmx_mpi grompp -f ions.mdp -c $NAME-solv.gro -p topol.top -o ions.tpr -maxwarn 1
|
||||
echo "SOL" > ions_input.txt
|
||||
mpirun -np $NUM_CORES gmx_mpi genion -s ions.tpr -o $NAME-solv-ions.gro -p topol.top -pname NA -nname CL -conc 0.125 -neutral < ions_input.txt
|
||||
# energy minimization of the structure in solvate # ! minim.mdp add by manual
|
||||
# --- minim.mdp file content --- #
|
||||
cat << EOF > minim.mdp
|
||||
@@ -93,8 +97,8 @@ rcoulomb = 1.0 ; Short-range electrostatic cut-off
|
||||
rvdw = 1.0 ; Short-range Van der Waals cut-off
|
||||
pbc = xyz ; Periodic Boundary Conditions in all 3 dimensions
|
||||
EOF
|
||||
gmx_mpi grompp -f minim.mdp -c $NAME-solv-ions.gro -p topol.top -o em.tpr
|
||||
gmx_mpi mdrun -v -deffnm em
|
||||
mpirun -np $NUM_CORES gmx_mpi grompp -f minim.mdp -c $NAME-solv-ions.gro -p topol.top -o em.tpr
|
||||
mpirun -np $NUM_CORES gmx_mpi mdrun -v -deffnm em
|
||||
# optional em, you will need the Xmgrace plotting too
|
||||
#gmx_mpi energy -f em.edr -o potential.xvg
|
||||
#position restrain
|
||||
@@ -146,8 +150,8 @@ gen_vel = yes ; assign velocities from Maxwell distributio
|
||||
gen_temp = 300 ; temperature for Maxwell distribution
|
||||
gen_seed = -1 ; generate a random seed
|
||||
EOF
|
||||
gmx_mpi grompp -f nvt.mdp -c em.gro -r em.gro -p topol.top -o nvt.tpr
|
||||
gmx_mpi mdrun -v -deffnm nvt
|
||||
mpirun -np $NUM_CORES gmx_mpi grompp -f nvt.mdp -c em.gro -r em.gro -p topol.top -o nvt.tpr
|
||||
mpirun -np $NUM_CORES gmx_mpi mdrun -v -deffnm nvt
|
||||
# optional : Let's analyze the temperature progression, again using energy:
|
||||
# gmx_mpi energy -f nvt.edr -o temperature.xvg
|
||||
# npt
|
||||
@@ -199,8 +203,8 @@ pbc = xyz ; 3-D PBC
|
||||
; Velocity generation
|
||||
gen_vel = no ; Velocity generation is off
|
||||
EOF
|
||||
gmx_mpi grompp -f npt.mdp -c nvt.gro -r nvt.gro -t nvt.cpt -p topol.top -o npt.tpr
|
||||
gmx_mpi mdrun -v -deffnm npt
|
||||
mpirun -np $NUM_CORES gmx_mpi grompp -f npt.mdp -c nvt.gro -r nvt.gro -t nvt.cpt -p topol.top -o npt.tpr
|
||||
mpirun -np $NUM_CORES gmx_mpi mdrun -v -deffnm npt
|
||||
# Optional: Let's analyze the pressure progression, again using energy: type 18 0
|
||||
# gmx energy -f npt.edr -o pressure.xvg
|
||||
# Optional: Let's take a look at density as well, this time using energy and entering "24 0" at the prompt.
|
||||
@@ -257,10 +261,10 @@ gen_vel = no ; Velocity generation is off
|
||||
EOF
|
||||
|
||||
# Generate GROMACS .tpr file for the simulation
|
||||
gmx_mpi grompp -f ${MDRUN_NAME}.mdp -c npt.gro -t npt.cpt -p topol.top -o ${TPR_FILE}
|
||||
mpirun -np $NUM_CORES gmx_mpi grompp -f ${MDRUN_NAME}.mdp -c npt.gro -t npt.cpt -p topol.top -o ${TPR_FILE}
|
||||
|
||||
# Run the simulation
|
||||
gmx_mpi mdrun -deffnm ${MDRUN_NAME}
|
||||
mpirun -np $NUM_CORES gmx_mpi mdrun -deffnm ${MDRUN_NAME}
|
||||
# mpirun -np $(ls | egrep "Scaled[0-9]+$" | wc -l) gmx_mpi mdrun -v --deffnm md -cpi Scaled.cpt -multidir $(ls -v | egrep "Scaled[0-9]+$") -plumed plumed.dat -hrex -replex 1000 >& run_$(date "+%H%M%S_%d%m%Y").log || { echo "mdrun failed at line ${LINENO} "; exit -1; }
|
||||
# extra ndx file , select protein
|
||||
echo -e "1\nq" | gmx_mpi make_ndx -f ${MDRUN_NAME}.gro -o ${NDX_FILE}
|
||||
|
||||
Reference in New Issue
Block a user