mirror of
https://github.com/triqs/dft_tools
synced 2025-01-03 10:05:49 +01:00
128 lines
3.4 KiB
Bash
Executable File
128 lines
3.4 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
MPIRUN_CMD=mpirun
|
|
|
|
show_help()
|
|
{
|
|
echo "
|
|
Usage: vasp_dmft [-n <number of cores>] -i <number of iterations> -j <number of VASP iterations with fixed charge density> [-v <VASP version>] [-p <path to VASP directory>] [<dmft_script.py>]
|
|
|
|
If the number of cores is not specified it is set to 1 by default.
|
|
|
|
Set the number of times the dmft solver is called with -i <number of iterations>
|
|
|
|
Set the number of VASP iteration with a fixed charge density update
|
|
inbetween the dmft runs with -j <number of VASP iterations with fixed charge density>
|
|
|
|
Set the version of VASP by -v standard(default)/no_gamma_write to
|
|
specify if VASP writes the GAMMA file or not.
|
|
|
|
If the path to VASP directory is not specified it must be provided by a
|
|
variable VASP_DIR.
|
|
|
|
<dmft_script.py> must provide an importable function 'dmft_cycle()'
|
|
which is invoked once per DFT+DMFT iteration. If the script name is
|
|
omitted the default name 'csc_dmft.py' is used.
|
|
|
|
|
|
"
|
|
}
|
|
|
|
while getopts ":n:i:j:v:p:h" opt; do
|
|
case $opt in
|
|
n)
|
|
# echo "Option: Ncpu, argument: $OPTARG"
|
|
if [ -n "$OPTARG" ]; then
|
|
NPROC=$OPTARG
|
|
# echo "Number of cores: $NPROC"
|
|
fi
|
|
;;
|
|
i)
|
|
# echo "Option: Niter"
|
|
if [ -n "$OPTARG" ]; then
|
|
NITER=$OPTARG
|
|
# echo "Number of iterations: $NITER"
|
|
fi
|
|
;;
|
|
j)
|
|
# echo "Option: Ndftiter"
|
|
if [ -n "$OPTARG" ]; then
|
|
NDFTITER=$OPTARG
|
|
# echo "Number of iterations with fixed density: $NDFTITER"
|
|
fi
|
|
;;
|
|
p)
|
|
if [ -n "$OPTARG" ]; then
|
|
VASP_DIR=$OPTARG
|
|
fi
|
|
;;
|
|
v)
|
|
if [ -n "$OPTARG" ]; then
|
|
VASP_VERSION=$OPTARG
|
|
# echo "Version of VASP (writing GAMMA file (standard) or not (no_gamma_write): $VASP_VERSION"
|
|
fi
|
|
;;
|
|
h)
|
|
show_help
|
|
exit 1
|
|
;;
|
|
:)
|
|
echo " Error: Option -$OPTARG requires an argument" >&2
|
|
show_help
|
|
exit 1
|
|
;;
|
|
\?)
|
|
echo " Error: Invalid option -$OPTARG" >&2
|
|
esac
|
|
done
|
|
|
|
if [ -z "$NITER" ]; then
|
|
echo " Error: Number of iterations must be specified with option -i" >&2
|
|
show_help
|
|
exit 1
|
|
fi
|
|
|
|
|
|
if [ -z "$VASP_DIR" ]; then
|
|
echo " Error: A path to VASP directory must be given either with option -p or by setting variable VASP_DIR" >&2
|
|
show_help
|
|
exit 1
|
|
fi
|
|
|
|
if [ -z "$NPROC" ]; then
|
|
echo " Number of cores not specified, setting to 1"
|
|
NPROC=1
|
|
fi
|
|
|
|
if [ -z "$NDFTITER" ]; then
|
|
echo " Number of VASP iterations without updating density not specified, setting to 1"
|
|
NDFTITER=1
|
|
fi
|
|
|
|
if [ -z "$VASP_VERSION" ]; then
|
|
echo " VASP version not specified, setting to standard"
|
|
VASP_VERSION="standard"
|
|
fi
|
|
|
|
shift $((OPTIND-1))
|
|
|
|
if [ -z "$1" ]; then
|
|
DMFT_SCRIPT=csc_dmft.py
|
|
else
|
|
DMFT_SCRIPT=$1
|
|
fi
|
|
|
|
echo " Number of cores: $NPROC"
|
|
echo " Number of iterations: $NITER"
|
|
echo " Number of iterations with fixed density: $NDFTITER"
|
|
echo " VASP version: $VASP_VERSION"
|
|
echo " Script name: $DMFT_SCRIPT"
|
|
|
|
rm -f vasp.lock STOPCAR
|
|
# run in serial and use OMP_NUM_THREADS here for vasp >=6.2 in case there are problems
|
|
stdbuf -o 0 $MPIRUN_CMD -np $NPROC "$VASP_DIR" &
|
|
|
|
|
|
$MPIRUN_CMD -np $NPROC @TRIQS_PYTHON_EXECUTABLE@ -m triqs_dft_tools.converters.plovasp.sc_dmft $(jobs -p) $NITER $NDFTITER $DMFT_SCRIPT 'plo.cfg' $VASP_VERSION || kill %1
|
|
|