atomate2 setup

This page serves as a guiding resource for atomate2 in the Strachan Lab. As of now, it is intended to be a companion to the installation guide at materials project. If there exists demand for a more comprehensive guide, that can be done later.

What is atomate2?

According to their README,

Atomate2 is a free, open-source software for performing complex materials science workflows using simple Python functions. Features of atomate2 include

  • It is built on open-source libraries: pymatgen, custodian, jobflow, and FireWorks.
  • A library of “standard” workflows to compute a wide variety of desired materials properties.
  • The ability scale from a single material, to 100 materials, or 100,000 materials.
  • Easy routes to modifying and chaining workflows together.
  • It can build large databases of output properties that you can query, analyze, and share in a systematic way.
  • It automatically keeps meticulous records of jobs, their directories, runtime parameters, and more.

After using and refining my implementation of atomate2 for over a year, it has allowed me to escape the cycle of hacky python scripts and messy file structures. Instead, atomate2 lets me use a robust, scalable set of workflows that are consistent with the state of the art in our field.

Installing atomate2

The atomate2 installation guide is fairly robust; go follow those instructions. Notes on each step are available below.

VASP

If you don’t already have access, ask Kat (or another group member) about getting access to VASP in our HPC environment.

A VASP 5.4.4 executable is available at /depot/prism/apps/vasp_std

MongoDB

If you’re not familiar with MongoDB already, it is a database that stores information as documents. In atomate2, a document often corresponds with a VASP run, an intermediate script, or some post-processing analysis. It’s worth getting some basic familiarity with the MongoDB syntax, as it is the main way to query documents in the database. The idea here is that instead of keeping track of runs through messy file structures in temporary scratch directories across different HPC systems, you can just query for the run you want based on the run details (system of interest, calculation type, user-supplied tags).

While you could self-host your own MongoDB, it’s a lot easier to use the infrastructure that already exists in our group. Kat has deployed a MongoDB docker image on Geddes, and created services to make this IP accessible to outside services. Details of the database are provided below, but for direct access to the database you should speak to Kat directly about getting added as a user.

Conda

Unfortunately, the atomate2 library is a mess of dependencies, and installation can be a bit tricky. Follow the atomate2 guide as far as you can, but expect additional issues to arise with dependencies. You will likely need to modify some of the codebase; so again, ask Kat as needed :)

There is a conda env available at /depot/prism/data/knykiel/autoplex with atomate2 and its utilities installed, as of January 2025

Config files

A collection of some of the more specific atomate2 config files I use for my instance on Negishi are copied below.

jobflow.yaml

JOB_STORE:
  docs_store:
    type: MongoStore
    database: yourdbname
    host: ask-kat
    port: 27017
    username: username
    password: password
    collection_name: outputs
  additional_stores:
    data:
      type: GridFSStore
      database: yourdbname
      host: ask-kat
      port: 27017
      username: username
      password: password
      collection_name: outputs_blobs

my_launchpad.yaml

host: ask-kat
port: 27017
name: yourdbname
username: username
password: password
ssl_ca_file: null
logdir: null
Istrm_lvl: DEBUG
user_indices: []
wf_user_indices: []
authsource: admin
retry: true

my_qadapter.yaml (this is for negishi - other cluster will be different)

_fw_name: CommonAdapter
_fw_q_type: SLURM
rocket_launch: rlaunch -c /home/knykiel/atomate2/config singleshot
nodes:  1
ntasks: 72
walltime: 04:00:00
account: standby
job_name: null
logdir: /home/knykiel/atomate2/logs/
launch_dir: /scratch/negishi/knykiel/launches/
pre_rocket: | 
  set echo

  module --force purge
  module load rcac
  module load intel
  module load openmpi
  module load impi
  module load intel-mkl
  module load anaconda
  module list

  export PATH="$HOME/bin:$PATH"

post_rocket: null

There are some scripts floating around Kat’s system that are used for mass submitting, restarting, and modifying workflows. These can be combined into a GitHub repo upon request.

General atomate2 tips

  • reading the fireworks documentation will greatly help you understand the system of fireworks, workflows, rockets, launches, etc.
  • atomate2 has many standard workflows, and you can often extend them with pymatgen (i.e. SQSTransformation)
  • adding a metadata tag to each FW with fw.spec.update can help with querying later
  • you can apply INCAR updates with powerups
  • launching with qlaunch -r rapidfire -m N is a convenient system to launch N jobs at once, and queue new jobs as they finish. This can be done with SLURM to run for weeks.

TODOs

  • Make a GitHub repository of the atomate2 setup for cloning without the secrets.
  • Figure out environment variables and PMG_POTCAR_PATH.
  • Clarify CPU vs GPU compiled versions of VASP.
  • Run everything inside of an Apptainer?