Skip to main content

Input file generators for computational chemistry

Project description

Table of Contents

About

img

Hatch project

A pure-python project to generate input files for various common computational chemistry workflows. This means:

  • Generating input structures for jobflow / Fireworks
    • From unified toml inputs

This is a spin-off from wailord (here) which is meant to handle aggregated runs in a specific workflow, while pychum is meant to generate single runs. It is also a companion to chemparseplot (here) which is meant to provide uniform visualizations for the outputs of various computational chemistry programs.

Ecosystem Overview

pychum is part of the rgpycrumbs suite of interlinked libraries.

img

Features

  • Jobflow support
    • Along with Fireworks
  • Unit aware conversions
    • Via pint

Supported Engines

  • NEB calculations
    • ORCA
    • EON
  • Single point calculations
    • ORCA
    • EON

Rationale

I needed to run a bunch of systems. jobflow / Fireworks / AiiDA were ideal, until I realized only VASP is really well supported by them.

Also there were some minor problems with the ORCA input parser…

  • It chokes on multiple # symbols, so # MaxIter 50 # something will error out on SOMETHING
  • No real ordering or syntax highlighting in major IDEs

Along with other minor inconveniences which make for enough friction over time to necessitate this library.

Usage

The simplest usage is via the CLI:

uv run pychum --help
# Or alternatively
python -m pychum.cli --help

Development

Before writing tests and incorporating the functions into the CLI it is helpful to often visualize the intermediate steps. For this we can setup a complete development environment including the notebook server.

uv sync --all-extras
uv run jupyter lab --ServerApp.allow_remote_access=1 \
    --ServerApp.open_browser=False --port=8889

Then go through the nb folder notebooks.

Adding ORCA blocks

Changes are to be made in the following files under the pychum/engine/orca/ folder:

  • The relevant .jinja file in the _blocks directory
  • The configuration loading mechanism in config_loader.py
  • The dataclasses folder
  • A sample test .toml file under tests/test_orca

While working on this, it may be instructive to use the nb folder notebooks. Also all PRs must include a full test suite for the new blocks.

Documentation

Readme

The readme can be constructed via:

./scripts/org_to_md.sh readme_src.org readme.md

License

MIT. However, this is an academic resource, so please cite as much as possible via:

  • The Zenodo DOI for general use.
  • The wailord paper for ORCA usage

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pychum-1.4.1.tar.gz (20.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pychum-1.4.1-py3-none-any.whl (25.8 kB view details)

Uploaded Python 3

File details

Details for the file pychum-1.4.1.tar.gz.

File metadata

  • Download URL: pychum-1.4.1.tar.gz
  • Upload date:
  • Size: 20.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for pychum-1.4.1.tar.gz
Algorithm Hash digest
SHA256 eb1a2cee02f4c089aa8110ed697a3c285dee83a96b89a62739e830da9aa0c744
MD5 061c7621e4c85b0cf9500f2d0ee7c860
BLAKE2b-256 a3608d1c73c392007fdf1b4fe942bb3f2f5e8cc0d85084924af4c83daa8ef6cb

See more details on using hashes here.

File details

Details for the file pychum-1.4.1-py3-none-any.whl.

File metadata

  • Download URL: pychum-1.4.1-py3-none-any.whl
  • Upload date:
  • Size: 25.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for pychum-1.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 dff80e66adb91228c482a298c685751c3d1a24084ba55e67a3405ad0c32be259
MD5 b911497f61bd4b4496cf32e7e732b36a
BLAKE2b-256 8d5a81d1f4dc630925df3b6f823229daa258967b01e2b5ee630034806d587bc9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page