PyThermoDB Settings is a Python package that acts as an interface between pythermdb and other applications, providing robust, Pydantic-based data models and configuration structures for managing thermodynamic database (ThermoDB) settings.
-
🧪 Component Modeling:
Define chemical components with attributes such as name, formula, state (gas, liquid, solid, aqueous), and mole fraction.
-
🌡️ Condition Models:
Represent temperature and pressure conditions with unit validation.
-
⚙️ Component Configuration:
TypedDict-based configuration for databook, table, mode, and custom labels.
-
📚 Reference Models:
ReferenceThermoDB: Structure for reference thermodynamic databases, including references, contents, configs, rules, and label management.ComponentReferenceThermoDB: Links a component to its reference database.ReferencesThermoDB: Handles multiple references and their configurations.
-
📏 Rule Management:
Define and manage rules for components using dictionary-based structures.
-
✅ Extensible and Validated:
All models use Pydantic for input validation and extensibility.
Install via pip (after packaging):
pip install pythermodb_settingsfrom pythermodb_settings.models import Component, Temperature, Pressure
# component example
component = Component(
name="Water",
formula="H2O",
state="l",
mole_fraction=1.0
)
# condition examples
temperature = Temperature(value=298.15, unit="K")
pressure = Pressure(value=1.0, unit="atm")-
Component
name: str — Name of the componentformula: str — Chemical formulastate: Literal['g', 'l', 's', 'aq'] — State (gas, liquid, solid, aqueous)mole_fraction: float — Mole fraction (default 1.0)
-
Temperature
value: float — Temperature valueunit: str — Unit (e.g., 'K', 'C', 'F')
-
Pressure
value: float — Pressure valueunit: str — Unit (e.g., 'bar', 'atm', 'Pa')
-
ComponentConfig
databook: str — Name of the databooktable: str — Table namemode: str — Mode (e.g., 'DATA', 'EQUATION')label: str — Optional labellabels: dict[str, str] — Optional labels
-
ReferenceThermoDB
reference: Dict[str, List[str]] — References and contentscontents: List[str] — Reference contentsconfigs: Dict[str, ComponentConfig] — Reference configsrules: Dict[str, ComponentRule] — Reference ruleslabels,ignore_labels,ignore_props: Optional label/property management
-
ComponentReferenceThermoDB
component: Componentreference_thermodb: ReferenceThermoDB
-
ReferencesThermoDB
- Handles multiple references, contents, configs, rules, and label management
Contributions are welcome! Please feel free to submit a Pull Request to improve the project.
This project is licensed under the MIT License. You are free to use, modify, and distribute this software in your own applications or projects. However, if you choose to use this app in another app or software, please ensure that my name, Sina Gilassi, remains credited as the original author. This includes retaining any references to the original repository or documentation where applicable. By doing so, you help acknowledge the effort and time invested in creating this project.
For any questions, contact me on LinkedIn.