Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ipqa-research/ugropy
A Python library designed to swiftly and effortlessly obtain the UNIFAC groups from molecules by their names and subsequently integrate them into inputs for thermodynamic libraries.
https://github.com/ipqa-research/ugropy
chemical chemical-engineering compound contribution engineering excess fragmentation functional gibbs group groups grupal joback molecule properties pure python thermodynamics unifac
Last synced: 27 days ago
JSON representation
A Python library designed to swiftly and effortlessly obtain the UNIFAC groups from molecules by their names and subsequently integrate them into inputs for thermodynamic libraries.
- Host: GitHub
- URL: https://github.com/ipqa-research/ugropy
- Owner: ipqa-research
- License: mit
- Created: 2023-07-27T03:07:31.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-03-06T02:12:58.000Z (8 months ago)
- Last Synced: 2024-04-06T04:02:52.647Z (7 months ago)
- Topics: chemical, chemical-engineering, compound, contribution, engineering, excess, fragmentation, functional, gibbs, group, groups, grupal, joback, molecule, properties, pure, python, thermodynamics, unifac
- Language: Python
- Homepage: https://ipqa-research.github.io/ugropy/
- Size: 3.67 MB
- Stars: 6
- Watchers: 2
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
![logo](logo.png)
[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/ipqa-research/ugropy/main)
[![License](https://img.shields.io/badge/License-MIT-blue.svg)](https://tldrlegal.com/license/mit-license)
![Python 3.10+](https://img.shields.io/badge/Python-3.10%2B-blue)
[![Docs](https://img.shields.io/badge/docs%20-%20green?style=flat&label=Sphinx&link=https%3A%2F%2Fipqa-research.github.io%2Fugropy%2Findex.html)](https://salvadorbrandolin.github.io/ugropy/)
[![PyPI
version](https://badge.fury.io/py/ugropy.svg)](https://badge.fury.io/py/ugropy)`ugropy` is a `Python` library to obtain subgroups from different thermodynamic
group contribution models using both the name or the SMILES representation of a
molecule. If the name is given, the library uses the
[PubChemPy](https://github.com/mcs07/PubChemPy) library to obtain the SMILES
representation from PubChem. In both cases, `ugropy` uses the
[RDKit](https://github.com/rdkit/rdkit) library to search the functional groups
in the molecule.`ugropy` is in an early development stage, leaving issues of examples of
molecules that `ugropy` fails solving the subgroups of a model is very helpful.`ugropy` is tested for `Python` 3.10, 3.11 and 3.12 on Linux, Windows and Mac
OS.# Try ugropy now
You can try ugropy from its
[Binder](https://mybinder.org/v2/gh/ipqa-research/ugropy/main). Open the
binder.ipynb file to explore the basic features.# Models supported v2.0.7
- Classic liquid-vapor UNIFAC
- Predictive Soave-Redlich-Kwong (PSRK)
- Joback# Writers
`ugropy` allows you to convert the obtained functional groups or estimated
properties to the input format required by the following thermodynamic
libraries:- [Clapeyron.jl](https://github.com/ClapeyronThermo/Clapeyron.jl)
- [Thermo](https://github.com/CalebBell/thermo)# Example of use
You can check the full tutorial
[here](https://ipqa-research.github.io/ugropy/tutorial/tutorial.html).Get groups from the molecule's name:
```python
from ugropy import Groupshexane = Groups("hexane")
print(hexane.unifac.subgroups)
print(hexane.psrk.subgroups)
print(hexane.joback.subgroups)
```{'CH3': 2, 'CH2': 4}
{'CH3': 2, 'CH2': 4}
{'-CH3': 2, '-CH2-': 4}Get groups from molecule's SMILES:
```python
propanol = Groups("CCCO", "smiles")print(propanol.unifac.subgroups)
print(propanol.psrk.subgroups)
print(propanol.joback.subgroups)
```{'CH3': 1, 'CH2': 2, 'OH': 1}
{'CH3': 1, 'CH2': 2, 'OH': 1}
{'-CH3': 1, '-CH2-': 2, '-OH (alcohol)': 1}Estimate properties with the Joback model!
```python
limonene = Groups("limonene")print(limonene.joback.subgroups)
print(f"{limonene.joback.critical_temperature} K")
print(f"{limonene.joback.vapor_pressure(176 + 273.15)} bar")
```{'-CH3': 2, '=CH2': 1, '=C<': 1, 'ring-CH2-': 3, 'ring>CH-': 1, 'ring=CH-': 1, 'ring=C<': 1}
657.4486692170663 K
1.0254019428522743 barVisualize your results! (The next code creates the `ugropy` logo)
```Python
from IPython.display import SVGmol = Groups("CCCC1=C(COC(C)(C)COC(=O)OCC)C=C(CC2=CC=CC=C2)C=C1", "smiles")
svg = mol.unifac.draw(
title="ugropy",
width=800,
height=450,
title_font_size=50,
legend_font_size=14
)SVG(svg)
```Write down the [Clapeyron.jl](https://github.com/ClapeyronThermo/Clapeyron.jl)
.csv input files.```python
from ugropy import writersnames = ["limonene", "adrenaline", "Trinitrotoluene"]
grps = [Groups(n) for n in names]
# Write the csv files into a database directory
writers.to_clapeyron(
molecules_names=names,
unifac_groups=[g.unifac.subgroups for g in grps],
psrk_groups=[g.psrk.subgroups for g in grps],
joback_objects=[g.joback for g in grps],
path="database"
)
```
Obtain the [Caleb Bell's Thermo](https://github.com/CalebBell/thermo) subgroups```python
from ugropy import unifacnames = ["hexane", "2-butanone"]
grps = [Groups(n) for n in names]
[writers.to_thermo(g.unifac.subgroups, unifac) for g in grps]
``````
[{1: 2, 2: 4}, {1: 1, 2: 1, 18: 1}]
```## Installation
```
pip install ugropy
```