Note: qcjson is no longer actively developed or maintained. The main developer (Alex Maldonado) has created reptar as a more robust computational chemistry parser and data management framework.
Reproducibility is a cornerstone of science, and computational chemistry is no different. With decreasing levels of transparency and reproducibility in computational chemistry, researchers should provide source codes, raw output files, input files, or some sort of machine-readable database (e.g., XML and JSON). Since commercial software is commonly used, this incentivizes providing output files and a machine readable database instead. This repository contains scripts for the creation and use of Quantum Chemistry JSONs, QCJSONs, for computational chemistry output files using a modified QCSchema.
The following computational packages and calculation types are currently supported (versions tested):
- ORCA (v4.2) optimizations, single point energies, gradients, frequencies.
- xtb (v6.3.3) optimizations, single point energies, molecular dynamics.
Python 3 with the following packages:
- cclib (>=1.7).
-
Clone the repo
git clone https://github.com/keithgroup/qcjson
-
Install the qcjson package using pip.
cd qcjson pip install . --user
Python scripts are provided for common uses.
Python script that creates QCJSON files from computational chemistry output files.
-o
,--overwrite
: Overwrite JSON file if it already exists.-r
,--recursive
: Recursively find output files to make QCJSONs.-p
,--prettify
: Indent JSON properties.--geom_split
: Geometries are in a separate file. For some programs this is required and disables recursive operation (xtb).--save_dir
: Path to directory to store JSON files; for example,--save_dir json_dir
. Defaults to current directory.--exclude
: Does not include file paths that have these strings in their path; for example,--exclude bad bp86
will not include any files with 'bad' or 'bp86' in the path.--include
: Will only include files that have all of these strings in their path; for example,--include b3lyp
will only include files withb3lyp
in the path.-d
,--debug
: Will raise errors instead of skipping failed JSONs.
There are multiple example calculations and QCJSONs in the data
directory.
For example, this is how to create QCJSONs for all of the examples in the orca
directory.
$ qcjson-creator.py -rop .
QCJSON creator v0.3.0
Written by Alex M. Maldonado (@aalexmmaldonado)
Energies and distances are Hartrees and Angstroms
Looking for output files in data/orca/, recursively
Found 14 output files
Making QCJSON for neb-bare.0-orca.sp-wb97x.def2tzvp
Making QCJSON for neb-bare.0-orca.sp-bp86.def2tzvp.smd
Making QCJSON for he.chrg1.mult2-orca.sp-hf.anopvqz.vtightscf.sym
Making QCJSON for na.chrg1.mult3-orca.sp.esp-wb97mv.anopvqz.vtightscf
Making QCJSON for cr.c6.o6.chrg-1.mult2-orca.sp-dlpnoccsdt.madef2tzvp.smd.mecn
Making QCJSON for neb-bare.0-orca.sp-bp86.def2svp
Making QCJSON for na.chrg1.mult1-orca.sp.esp-wb97mv.anopvqz.vtightscf
Making QCJSON for co2-orca.sp-dlpnoccsdt.madef2tzvp.smd.mecn
Making QCJSON for he.chrg0.mult1-orca.sp-ccsd.anopvqz.vtightscf.sym
Making QCJSON for 12h2o.su.etal-orca.sp-mp2.def2tzvp.frozencore
Making QCJSON for alo3h3.h2o-orca.freq-bp86.def2svp.cpcm
Making QCJSON for alo4h5-orca.freq-bp86.def2svp
Making QCJSON for 5h2o.abc0.iter1.mp2.md.300k.iter1.mol0,1,2,3,4-orca.engrad-mp2.def2tzvp
Making QCJSON for 4h2o.abc0.iter2-orca.opt-mp2.def2tzvp
0 file(s) encountered errors and not written
$
ORCA calculation examples descriptions.
4h2o.abc0.iter2-orca.opt-mp2.def2tzvp.out
: An optimization using MP2/def2-TZVP with the default frozen core approximation.5h2o.abc0.iter1.mp2.md.300k.iter1.mol0,1,2,3,4-orca.engrad-mp2.def2tzvp.out
: An ORCA job running multiple energy+gradient calculations on different configurations of the same system.alo3h3.h2o-orca.freq-bp86.def2svp.cpcm.out
: An analytical frequency calculation with an implicit solvent and one imaginary frequency.alo4h5-orca.freq-bp86.def2svp.out
: An analytical frequency calculation with zero imaginary frequencies.he.chrg1.mult2-orca.sp-hf.anopvqz.vtightscf.sym.out
: A UHF/ano-pVQZ calculation on He+.he.chrg0.mult1-orca.sp-ccsd.anopvqz.vtightscf.sym.out
: A CCSD/ano-pVQZ calculation on He.na.chrg1.mult1-orca.sp.esp-wb97mv.anopvqz.vtightscf.out
: ωB97M-V/ano-pVQZ calculation on Na+.na.chrg1.mult3-orca.sp.esp-wb97mv.anopvqz.vtightscf.out
: ωB97M-V/ano-pVQZ calculation on excited Na+.neb-bare.0-orca.sp-bp86.def2svp.out
: A single-point energy calculation using BP86-D3BJ/def2-TZVP.neb-bare.0-orca.sp-bp86.def2tzvp.smd.out
: A single-point energy calculation using BP86-D3BJ/def2-TZVP with a water implicit solvent model (SMD).neb-bare.0-orca.sp-wb97x.def2tzvp.out
: A single-point energy calculation using ωB97X-D3BJ/def2-TZVP.
The xtb program is one example where the geometries during the calculation are not printed directly in the output file.
Instead, they are put into a .log
or a .trj
file.
This forces us to use the --geom_split
option to provide two files to create the QCJSON for every calculation type.
Here is an example used to create a QCJSON for an xtb optimization.
$ qcjson-creator.py -opd 5h2o.example-xtb.opt-gfn2.out --geom_split 5h2o.example-xtb.opt-gfn2.log
QCJSON creator v0.3.0
Written by Alex M. Maldonado (@aalexmmaldonado)
Energies and distances are Hartrees and Angstroms
Making QCJSON for 5h2o.example-xtb.opt-gfn2.out
0 file(s) encountered errors and not written
$
Here are the example calculations provided in the data/xtb
directory.
5h2o.example-xtb.sp-gfn2.out
: A single point energy using GFN2-xTB.5h2o.example-xtb.opt-gfn2.out
: An optimization using GFN2-xTB.5h2o.example.xtb-xtb.md-gfn2.md
: A NVT molecular dynamics simulation using GFN2-xTB with no pre-optimization.
Python script that combines JSON files into a single JSON. Useful for aggregating many calculations into a single JSON file.
-r
,--recursive
: Recursively find output files to make QCJSONs.-o
,--overwrite
: Overwrite JSON file if it already exists.-p
,--prettify
: Indent JSON properties.-n
,--name
: Name of the combined JSON file. Defaults to 'combined'.--nest_jsons
: Nest a single JSON file under a directory key if there is only one JSON. The default behavior assumes that each calculation (and respective JSON) is in its own directory. When the script encounters this situation, it will add the JSON file at the same level as the directory instead of nested under the directory. For example, suppose you have a file./cl/cl.ccsdt/cl.ccsdt.anopvtz.json
with no other json files in./cl/cl.ccsdt/
. With the default script behavior you would accesscl.ccsdt.anopvtz.json
by using['cl']['cl.ccsdt.anopvtz']
. With--nest_jsons
, you would have to use['cl']['cl.ccsdt']['cl.ccsdt.anopvtz']
.--save_dir
: Path to directory to store JSON files; for example,--save_dir json_dir
. Defaults to the current directory.
Custom modifications are made to QCSchema to meet the immediate needs of our research.
-
QCSchema does not support multiple configurations in a single JSON file: one file per structure and calculation. This is inherently incompatible with geometry optimizations, trajectories, or any other iterative procedure. At of the time of writing (2021-02-09), there has been no consensus of how to manage these files.
Our immediate solution is to have lists of each QCSchema (i.e., [ { }, { }, { }, ... ] ). Furthermore, only iterations that have the same topology are supported (no checks are provided).
-
Other information with keywords not defined in the QCSchema.
Here are definitions of all QCSchema and custom keys used in this package. Not all QCJSONs will have every key all the time; some are method dependent like the frozen core approximation. All custom keys are marked with a *.
"atomic_numbers"
: list [int, int, ...], atomic numbers, nuclear charge for atoms. Ghostedness should be indicated through ‘real’ field, not zeros here."driver"
: str, what are you looking to calculate: energy, gradient, Hessian, or property. Note, we implement other driver options: optimization."error"
: dict, for unsuccessful computations standard errors will be placed in the output such as convergence, IO errors, etc."error_message"
: str, specific program message. Not yet implemented in this script."error_type"
: str, what caused the error. Not yet implemented in this script.
"keywords"
: dict, various tunable parameters for the calculation. These vary widely, depending on the basis and model chemistry. These represent the keywords of individual programs currently."cosx_approximation"
*: bool, if the chain-of-spheres integration approximation to the exchange term (COSX) is used. Note, this property is only included if true."dispersion"
*: str, if empirical dispersion corrections are used (with DFT), this specifies the method."final_grid_level"
*: int, specifies program-specific integration grid level for the final energy calculation."frozen_core"
*: bool, if the core electrons are frozen."frozen_electrons"
*: int, the number of frozen core electrons."hf_type"
*: str, Hartree–Fock type (RHF or UHF) for ab initio methods."implicit_solvent"
*: str, the implicit solvent model if used. For example, "SMD" or "CPCM". Note, this property is only included if included."rij_approximation"
*: bool, if the resolution of identity approximation for the Coulomb integrals (RI-J) is used. Note, this property is only included if true."scf_convergence_tolerance"
*: str, program-specific SCF convergence criteria. For example, "tight"."scf_grid_level"
*: int, specifies program-specific integration grid level for the scf cycle."solvent_name"
*: str, name of the solvent. For example, "water". Note, this property is only included if an implicit solvent is used.
"model"
: dict, the overall mathematical model we are using for our calculation. Another way to think about this is the largest superset that still obtains roughly the same result. In QM, this is the Hamiltonian (HF, DFT, ...) combined with the overall basis of the calculation. An example in QM would be HF/STO-3G or B3LYP/6-311G**. Custom basis sets can be handled with custom keywords."aux_basis"
*: str, auxillary basis set if RI approximation is used."basis"
: str, overall basis set."method"
: str, primary method or level of theory.
"molecule"
: dict, a full description of the overall molecule(s) (e.g., its geometry, fragments, and charges)."geometry"
: list [[float, float, float], [float, float, float], ...], vector of XYZ coordinates of the atoms of length equal to the number of atoms."symbols"
: list [str, str, ...], atom symbols in title case (e.g., "H" and "Na").
"molecular_charge"
: int, the overall charge of the system."molecular_multiplicity"
: int, the overall multiplicity of the system."name"
: str, desired name of the system (currently is just the file name)."n_electrons"
*: int, the total number of electrons of the system."properties"
: dict, a list of valid quantum chemistry properties tracked by the schema."alpha_homo_energy"
*: float, highest occupied molecular orbital energy of the alpha electron."alpha_homo_lumo_gap_energy"
*: float, energy difference between lowest unoccupied and highest occupied molecule orbital of the alpha electron."beta_homo_energy"
*: float, highest occupied molecular orbital energy of the beta electron."beta_homo_lumo_gap_energy"
*: float, energy difference between lowest unoccupied and highest occupied molecule orbital of the alpha electron."calcinfo_nbasis"
: int, the number of basis functions for the computation."calcinfo_nmo"
: int, the number of molecular orbitals for the computation."ccsd_total_energy"
*: float, the total CCSD energy."ccsd(t)_total_energy"
*: float, the total CCSD(T) energy."enthalpic_corrections"
*: float, the thermal enthalpy corrections for the electronic energy at the specified temperature."entropic_corrections"
*: float, the translational, rotational, and vibrational entropic corrections to enthalpy to get Gibbs free energy (i.e., TS)."loewdin_charges"
*: list [float, float, ...], the Loewdin atomic charges."mp2_total_energy"
: float, the total MP2 energy (MP2 correlation energy + HF energy)."mp2_correlation_energy"
: float, the MP2 correlation energy."mp2_dipole_moment"
: list [float, float, ...], the x, y, and z dipole components."mulliken_charges"
*: list [float, float, ...], the Mulliken atomic charges."nuclear_repulsion_energy"
: float, the nuclear repulsion energy contribution to the total SCF energy."omega"
*: list [float, float, ...], vibrational frequencies in cm-1. Includes zero frequencies."q"
*: list [[float, float, ...], [float, float, ...], ...], the normalized, mass-weighted normal modes."return_energy"
: float, the energy of the requested method, identical to return_value for energy computations. For frequency calculations, this will be the Gibbs free energy."scf_dipole_moment"
: list [float, float, ...], the x, y, and z dipole components."scf_dispersion_correction_energy"
: float, the dispersion correction appended to an underlying functional when a DFT-D method is requested."scf_iterations"
: int, the number of SCF iterations taken before convergence."scf_one_electron_energy"
: float, the one-electron (core Hamiltonian) energy contribution to the total SCF energy."scf_total_energy"
: float, the total electronic energy of the SCF stage of the calculation. For Moller–Plesset and coupled cluster calculations this is the Hartree–Fock energy."scf_two_electron_energy"
: float, the two-electron energy contribution to the total SCF energy."scf_xc_energy"
: float, the functional energy contribution to the total SCF energy."t1_diagnostic"
*: float, the T1 diagnostic from coupled cluster calculations."temperature"
*: float, the temperature, in Kelvin, used for thermochemistry."thermal_energy_corrections"
*: float, the thermal vibrational, rotational, and translational correction to the electronic energy."uhf_ideal_average_total_spin_squared"
*: float, the ideal value of <Ŝ2> = S(S + 1) where S is the unpaired spin (e.g., 0 for singlets, 1/2 for doublets, 1 for triplets, etc.)."uhf_calculated_average_total_spin_squared"
*: float, the expectation value of Ŝ2 (i.e., <Ŝ2>) from an unrestricted Hartree–Fock calculation. Deviations from the ideal value represents spin contamination from different electronic spin-states."zero_point_vibrational_correction"
*: float, the zero-point vibrational energy correction at 0 K to the electronic energy.
"provenance"
: dict, a brief description of the program, version, and routine used to generate the output. Can include more detailed information such as computation time, processor information, and host location."creator"
: str, name of the QC package."version"
: str, version of the QC package.
"qcjson_creator_version"
*: str, specifies the qcjson-creator script version."return_result"
: str, the “primary” return of a given computation. For energy, gradient, and Hessian quantities these are either single numbers or a array representing the derivative quantity."schema_name"
: str, specifies the type of QCJSON. Always equal to "qc_schema_output"."schema_version"
: int, specifies the QCSchema version. Current version is 1."success"
: bool, a description if the computation was successful or not.
All QCJSONs use Angstrom and Hartree as the units of distance and energy, respectively. Derived units adhere to this specification as well; for example, gradients will be in Hartree/Angstrom. If properties use other units (e.g., cm-1 for vibrational frequencies) these are specified in the key descriptions above.
Distributed under the MIT License. See LICENSE
for more information.