Skip to content

Quantum-CODEX is a proof-of-concept WebApp, CLI and API for sharing, archiving, and annotating computational materials science projects.

License

Notifications You must be signed in to change notification settings

oashour/quantum-codex

Repository files navigation

Quantum-CODEX

Quantum-CODEX was an independent project I worked on during my PhD. I conceived the idea in June 2023 and (sloppily) wrote the full stack over the next 3 weeks. Due to the realities and priorities of being a senior PhD student, the project has been abandoned since. I decided to make the repo public in the hopes that it might benefit someone.

The backend is written in flask and can be deployed using gunicorn on a Kubernetes cluster. The documentation database is MongoDB, and the file database is Postgres. The frontend uses jinja templates, BootstrapCSS, and jQuery. A test version of CODEX was deployed in mid-June 2023 on NERSC's Kubernetes-based cluster, Spin, and was shortly available at https://codex.lbl.gov.

Discalimer: the WebApp is functional but buggy and ugly, and is not particularly well-written since I had never done any web development prior to this. The CLI was never completed. I never learned how to write proper unit tests for web apps, so there are none.

I am indebted to John Farrell (@jfarre19) for the immensely helpful feedback he's given me while I worked on this project.

Below is the original version of the README.

Introduction

Quantum-CODEX is a proof-of-concept web app for sharing, archiving, and annotating computational materials science projects. Both the web interface, command line interface, and REST API allow for uploading files, calculations (a collection of files that collectively form a full calculation), and projects (a collection of calculations for, e.g., a publication). Each component is assigned a unique identifier and stored in a database, allowing for sharing via a permalink to the web interface or downloading from the command line via the unique ID. CODEX is also capable of annotating input files automatically by pulling the relevant tags from the relevant package's documentation. It currently supports VASP and Quantum ESPRESSO, but the documentation module can ingest JSON serialized documentation, so that support for new packages can be added without knowing anything about how the front and backend work.


Usage

CODEX is currently still in development and there is no publicly accessible URL. You will have to install it locally.

The repository is currently private so you need to have your GitHub SSH keys setup properly.

Note that CODEX is built and tested with Python 3.11.3, I have no idea how well it will work with older versions, but anything after 3.8 will probably work?

Development Installation

git clone https://github.com/oashour/quantum-codex.git
cd dft-codex/
# Activate a venv, make sure python points to the right version
python -m venv /path/to/your/venvs/codex-dev
source /path/to/your/venvs/codex-dev/bin/activate
pip install --editable .

Using the --editable flag keeps the source code on your path so you don't have to reinstall every time you change something.

Testing Installation

# Activate a venv, make sure python points to the right version
python -m venv /path/to/your/venvs/codex
source /path/to/your/venvs/codex/bin/activate
pip install git+ssh://[email protected]/oashour/quantum-codex.git

Running CODEX

CODEX's backend is written in Flask. From the root directory and with your virtual environment active, simply run flask run and go to 127.0.0.1:5000 in your browser. If you're debugging, you can also use the --debug flag (i.e., flask run --debug. (Note: use the development installation for now.)

In the future, there will be a command line interface that generates a permalink to the website from local files, so you don't have to download your files from the cluster and go through the pain of uploading them to the website. (Partially written)

Roadmap

Barebones Alpha

  • Full QE database
    • Automatic executable detection solely from the structure of the input file
  • Full VASP database
    • Incremental database generation code without pulling everything
  • Modular/abstract classes and uniform database format
    • easy to add support for other codes with minimal modification
  • Generating a codex
    • CLI --> deprecated
    • Python API
  • Interacting with and rebuilding the database
    • CLI --> deprecated
    • Python API
  • Demo front end
    • Usable but sorta ugly interface
    • Responsive, dynamically generated
    • Click on a tag to go to the full documentation

More fully featured Alpha

  • Backend
    • Flask for the routing etc
    • General improvements to back-end file handling etc --> See below, good first issues
    • Database (MongoDB)
    • REST API
    • Lightweight Python wrapper/CLI for REST API
    • Containerization and deployment (NERSC spin)
    • Gunicorn
  • Front end
    • Full facelift for the UI and UX --> See below, good first issues
    • Modular Jinja templates
    • Crystal structure visualizer (can use crystal-toolkit react component)
    • Info about k-grid (number of points in IBZ, packing fraction, etc.)
    • Explanation of "cards" (e.g., QE card options, certain tags in POSCAR, etc.)
    • Robo crystallographer integration --> Good first issue
    • BZ visualizer --> long-term, probably hard
    • POTCAR analysis (is it recommended on VASP wiki or not, what do _sv mean, etc.) --> Good first issue long-term
    • UPF analysis (just file name) for PSLib and ONCVPSP --> Good first issue, longterm
    • Prettier XSL template for QE --> long-term
  • Documentation
    • Developer guide
  • DevOps
    • Unit tests...
    • GitHub actions for documentation
    • GitHub actions for containerization and deployment
    • LBL domain and TLS cert
  • Refactor
    • Use an abstract class for the Codex
    • Fully refactor database generation code
    • Restructure the package into subpackages for CLI, app and database generation.
    • Clean up deps

Front-end good first issues

  • More Proper layout
  • CSS improvements
  • Drag and drop upload and reorder (might take a fair bit of JS)
  • Light/dark theme
  • Parse markdown from README
  • Better code copy button, find a better solution than the current one (rolled my own with jQuery). Bootstrap docs look nice.
  • Add an adjustable divider between doc preview/code block, so you can focus one or the other on smaller screens
  • Better looking and closable alerts.
  • Hints, tooltips, short explanations of what toggles do, etc.
  • Maybe: figure out whether something is QE/VASP based on file name and change code selection? Might not be sustainable since a lot of codes use .in for input files.
  • Proper exception handling that goes to the frontend

Back-end good first issues

  • Accept only uploads with .pwi and .in extensions and INCAR*, KPOINTS* etc. filenames.
  • Proper logging

Beta

  • Documentation
    • User guide
  • Support for MP IDs
  • Icon/logo
  • OAuth
    • User accounts
    • GitHub user accounts
  • Move codex DB to Postgres (partially done in dev branch)

Contributing

Developer documentation is coming soon.

If you find any bugs or would like to request any features, please use the issue tracker.

If you'd like to help develop CODEX, clone the repo as in option 1 above but use pip install --editable . so that changes to the source code are reflected in your environment immediately without needing to reinstall.

We prefer a fork and pull model for contributions. Make sure your code complies with PEP8.

Database

Note: will be overhauled soon.

CODEX provides utilities for generating new databases for Quantum ESPRESSO and VASP.

The databases are located with the package files, in the directory codex/database/{code}-{version}, where {code} is either qe or vasp, and version is either a QE version (e.g., 7.2) or a date (YYYYMMDD) of when the VASP database was created.

Quantum ESPRESSO

Building the QE database for a version not included by default or rebuilding it from scratch requires some external utilities (namely, tcl, tcllib and xsltproc). You should not normally have to do this, but a user interface is available for conveience.

You can install the dependencies as follows:

$ apt-get install tcl tcllib xsltproc # Debian
$ yum install tcl tcllib xsltproc # Red Hat
$ brew install tcl-tk libxslt # Mac with [Homebrew](https://brew.sh)

You also need git version 2.37.1 or later (which was released in 2020 and many systems have ancient default versions of git, make sure to check).

These packages are required because of how QE's documentation is built using helpdoc, Quantum ESPRESSO's homebrew documentation generator, written in tcl, which DFT-CODEX combines with a custom XSL template to modernize its look. First, a minimal clone of the QE repo (around 2 MB) is built, with the bare minimum necessary files to build the documentation for the intended version. Then helpdoc is run on all the INPUT_*.def files which have the documentation for each *.x executable. This generates XML and HTML files, and the database is built from them.

You can generate the entire database from scratch for some version (e.g., 6.4.1) as:

from codex.database.espresso import run_helpdoc, generate_database
v = '6.4.1'
run_helpdoc(v)
generate_database(v)

Calling run_helpdoc is only necessary the first time when you don't have the HTML and XML files already there.

VASP

VASP does not have versioned documentation, so the database is built from the wiki. The distribution also includes the most recent mirror of the VASP wiki.

About

Quantum-CODEX is a proof-of-concept WebApp, CLI and API for sharing, archiving, and annotating computational materials science projects.

Topics

Resources

License

Stars

Watchers

Forks