Skip to main content

Encode qcdata inputs into native quantum chemistry files and decode (parse) program outputs into structured qcdata objects.

Project description

qccodec

Encode qcdata inputs into native quantum chemistry files and decode (parse) program outputs into structured qcdata objects.. Uses data structures from qcdata.

image image image Actions status Actions status

qccodec works in harmony with a suite of other quantum chemistry tools for fast, structured, and interoperable quantum chemistry.

The QC Suite of Programs

  • qcconst - Physical constants, conversion factors, and a periodic table with clear source information for every value.
  • qcdata - Beautiful and user friendly data structures for quantum chemistry, featuring seamless Jupyter Notebook visualizations. Documentation
  • qccodec - Encode qcdata inputs into native quantum chemistry files and decode (parse) program outputs into structured qcdata objects.
  • qcop - A package for operating quantum chemistry programs using qcdata standardized data structures. Compatible with TeraChem, psi4, QChem, NWChem, ORCA, Molpro, geomeTRIC and many more.
  • BigChem - A distributed application for running quantum chemistry calculations at scale across clusters of computers or the cloud. Bring multi-node scaling to your favorite quantum chemistry program.
  • ChemCloud - A web application and associated Python client for exposing a BigChem cluster securely over the internet.

✨ Basic Usage

  • Installation:

    python -m pip install qccodec
    
  • Parse QC program outputs into structured data files with a single line of code.

    from pathlib import Path
    from qcdata import CalcType
    from qccodec import decode
    
    stdout = Path("tc.out").read_text()
    data = decode("terachem", CalcType.gradient, stdout=stdout)
    
  • The data object will be a qcdata object, either SinglePointData, OptimizationData, ConformerSearchData or other *Data structure depending on the calctype. Run dir(data) inside a Python interpreter to see the various values you can access. A few prominent values are shown here as an example:

    from pathlib import Path
    from qcdata import CalcType
    from qccodec import decode
    
    stdout = Path("tc.out").read_text()
    data = decode("terachem", CalcType.hessian, stdout=stdout)
    
    data.energy
    data.gradient # If a gradient calc
    data.hessian # If a hessian calc
    data.calcinfo_nmo # Number of molecular orbitals
    
  • Parsed values can be written to disk like this:

    with open("data.json", "w") as f:
        f.write(data.model_dumps_json())
    
  • And read from disk like this:

    from qcdata import SinglePointData
    
    data = SinglePointData.open("data.json")
    
  • You can also run qccodec from the command line like this:

    qccodec -h # Get help message for cli
    
    qccodec terachem hessian tests/data/terachem/water.frequencies.out > data.json # Parse TeraChem stdout to json
    
  • More complex parsing can be accomplished by passing the directory containing the scratch files to decode and optionally the input data used to generate the calculation (usually done from qcop which uses structure data):

    from pathlib import Path
    from qcdata import CalcType, ProgramInput
    from qccodec import decode
    
    stdout = Path("tc.out").read_text()
    directory = Path(".") / "scr.geom"
    input_data = ProgramInput.open("prog_inp.json")
    
    data = decode("terachem", CalcType.hessian, stdout=stdout, directory=directory, input_data=input_data)
    

💻 Contributing

Please see the contributing guide for details on how to contribute new parsers to this project :)

If there's data you'd like parsed from output files or want to support input files for a new program, please open an issue in this repo explaining the data items you'd like parsed and include an example output file containing the data, like this.

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

qccodec-0.10.1.tar.gz (518.2 kB view details)

Uploaded Source

Built Distribution

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

qccodec-0.10.1-py3-none-any.whl (27.7 kB view details)

Uploaded Python 3

File details

Details for the file qccodec-0.10.1.tar.gz.

File metadata

  • Download URL: qccodec-0.10.1.tar.gz
  • Upload date:
  • Size: 518.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for qccodec-0.10.1.tar.gz
Algorithm Hash digest
SHA256 84a9c2fc3ce8fe7c59c9caa128e0c746dfb43e2521ffb0fcc388da56f7f2738a
MD5 2f33c3c5b0050662e6cdd62a30ab5ea8
BLAKE2b-256 ada10f92a91fc53b6741a695b1c32e39fec634e507399ac2fd31e40a5199922c

See more details on using hashes here.

Provenance

The following attestation bundles were made for qccodec-0.10.1.tar.gz:

Publisher: publish-to-pypi.yaml on coltonbh/qccodec

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file qccodec-0.10.1-py3-none-any.whl.

File metadata

  • Download URL: qccodec-0.10.1-py3-none-any.whl
  • Upload date:
  • Size: 27.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for qccodec-0.10.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7bbd7392580e3d81159d143bacd0efa600ef354bb758b7a6efcfdc2224c1b7a8
MD5 e7ab6aef2151301cc7d5e82bdf1892a9
BLAKE2b-256 5964b8170ea3ac40c805f9927e8775dfe2f8d13b9194804fccbd0c981274fd5d

See more details on using hashes here.

Provenance

The following attestation bundles were made for qccodec-0.10.1-py3-none-any.whl:

Publisher: publish-to-pypi.yaml on coltonbh/qccodec

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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