Source code for rxn_network.entries.freed

"""Implements an Entry that looks up pre-tabulated Gibbs free energies from the NIST-JANAF
tables.
"""

from __future__ import annotations

from typing import TYPE_CHECKING

from rxn_network.data import PATH_TO_FREED, load_experimental_data
from rxn_network.entries.experimental import ExperimentalReferenceEntry

if TYPE_CHECKING:
    from pymatgen.entries.computed_entries import EnergyAdjustment

    from rxn_network.core import Composition

G_COMPOUNDS = load_experimental_data(PATH_TO_FREED / "compounds.json.gz")


[docs] class FREEDReferenceEntry(ExperimentalReferenceEntry): """An Entry class for FREED experimental reference data. Given a composition, automatically finds the Gibbs free energy of formation, dGf(T) from tabulated reference values. Reference: https://www.thermart.net/freed-thermodynamic-database/ """ REFERENCES = G_COMPOUNDS def __init__( self, composition: Composition, temperature: float, energy_adjustments: list[EnergyAdjustment] | None = None, data: dict | None = None, ): """ Args: composition: Composition object temperature: Temperature in Kelvin. If temperature is not selected from one of [300, 400, 500, ... 2000 K], then free energies will be interpolated. Defaults to 300 K. energy_adjustments: A list of EnergyAdjustments to apply to the entry. data: Optional dictionary containing entry data. """ super().__init__( composition=composition, temperature=temperature, energy_adjustments=energy_adjustments, data=data, )