Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Quantum ESPRESSO is an integrated suite of Open-Source computer codes for electronic-structure calculations and materials modeling at the nanoscale. It is based on density-functional theory, plane waves, and pseudopotentials.

Official website : https://www.quantum-espresso.org

updated : 3 5 August 20232024

...

Available Version

QuantumEspresso version 7.2 is available on Lanta. QuantumEspresso/7.2-libxc-6.1.0-cpu is used to run on CPU node, while QuantumEspresso/7.2-libxc-6.1.0-gpu is used to run on GPU node. Both module versions are linked to https://tddft.org/programs/libxc/

Version

Processing unit

Module name

7.2

CPU

QuantumESPRESSO/7.2-libxc-6.1.0-cpu

GPU

QuantumESPRESSO/7.2-libxc-6.1.0-gpu

1. Input file

The basic input files for running Quantum Espresso on Lanta are Quantum Espresso inputs and job submission script.

2. Job submission script

create a script using vi submit.sh command and specify the following details depending on computational resources you want to use.

2.1 Run Quantum Espresso on CPU node

Code Block
#!/bin/bash
#SBATCH -p compute                        # select the partition
#SBATCH --nodes=1                         # define number of node
#SBATCH --ntasks-per-node=64              # define number of tasks per node
#SBATCH --cpus-per-task=1                 # OMP threads
#SBATCH -t 2:00:00                        # define reserve time
#SBATCH -J test_QE                        # define the job name
#SBATCH -A ltXXXXXX                       # define your project account

module purge
module load QuantumESPRESSO/7.2-libxc-6.1.0-cpu

mkdir export ESPRESSO_TMPDIR=-p /scratch/ltXXXXXX-YYYY/$USER/$SLURM_JOB_ID     # change ltXXXXXX-YYYY to yours             
export ESPRESSO_TMPDIR=/scratch/ltXXXXXX-YYYY/$USER/${SLURM_JOB_ID}  # the location of the outdir
export OMP_NUM_THREADS=${SLURM_CPUS_PER_TASK}
export ESPRESSO_PSEUDO=./                               # the location of pseudo potential

ulimit -s unlimited

srun --cpus-per-task=${SLURM_CPUS_PER_TASK} pw.x -inp ausurf.in > ausurf.out

The script above using compute partition (-p compute), 1 node (-N 1) with 64 tasks per node (--ntasks-per-node=64), so the total CPUs core for this job is 64 (the number of tasks) x 1 (default CPU per task) = 64 cores. The account is set to ltXXXXXX (-A ltXXXXXX) that is subjected to change to your own account.

Please check ESPRESSO_TMPDIR regularly and deleted unwanted files since they can consumes large amount of space.

2.2 Run Quantum Espresso on GPU node

Code Block
#!/bin/bash
#SBATCH -p gpu                        # select the partition
#SBATCH --nodes=1                     # define number of node
#SBATCH --ntasks-per-node=1           # define number of tasks per node
#SBATCH --gpus-per-node=1             # define number of gpus
#SBATCH --cpus-per-task=4             # OMP threads
#SBATCH -t 2:00:00                    # define reserve time
#SBATCH -J test_QE                    # define the job name
#SBATCH -A ltXXXXXX                   # define your project account

module purge
module load QuantumESPRESSO/7.2-libxc-6.1.0-gpu

export ESPRESSO_TMPDIR=mkdir -p /scratch/ltXXXXXX-YYYY/$USER/$SLURM_JOB_ID    # change ltXXXXXX-YYYY to yours 
export ESPRESSO_TMPDIR=/scratch/ltXXXXXX-YYYY/$USER/${SLURM_JOB_ID}  # the location of the outdir
export OMP_NUM_THREADS=${SLURM_CPUS_PER_TASK}
export ESPRESSO_PSEUDO=./                              # the location of pseudo potential

ulimit -s unlimited

srun --cpus-per-task=${SLURM_CPUS_PER_TASK} pw.x -inp ausurf.in > ausurf.out

...

Info

the number of MPI ranks (ntasks) should equal to the number of GPUs ( ntasks-per-node = gpus-per-node)

3. Job submission

using sbatch submit.sh command to submit the job to the queuing system.