From 91405ec075ab4ac5a1f61d13e9487ffc588e8862 Mon Sep 17 00:00:00 2001 From: Nick Wogan Date: Tue, 4 Jun 2024 22:21:04 -0400 Subject: [PATCH] function that generates thermo file --- photochem/equilibrate.py | 36 +++++++++++++++++++++++++++++++++++- 1 file changed, 35 insertions(+), 1 deletion(-) diff --git a/photochem/equilibrate.py b/photochem/equilibrate.py index 6d9edd1..f5e405b 100644 --- a/photochem/equilibrate.py +++ b/photochem/equilibrate.py @@ -1,2 +1,36 @@ from ._equilibrate import ChemEquiAnalysis, EquilibrateException -from ._equilibrate import __version__ \ No newline at end of file +from ._equilibrate import __version__ +from .utils._format import FormatReactions_main, yaml, Loader, MyDumper +import os + +def generate_zahnle_earth_thermo(outfile='zahnle_earth_thermo.yaml'): + """Generates a thermodynamic file for equilibrium solving that includes + condensible species (e.g., H2O condensate). + + Parameters + ---------- + outfile : str, optional + Name of the output file, by default 'zahnle_earth_thermo.yaml' + """ + + rx_folder = os.path.dirname(os.path.realpath(__file__))+'/data/reaction_mechanisms/' + + with open(rx_folder+'zahnle_earth.yaml','r') as f: + dat = yaml.load(f, Loader=Loader) + + with open(rx_folder+'condensate_thermo.yaml','r') as f: + dat1 = yaml.load(f, Loader=Loader) + + # Delete information that is not needed + for i,atom in enumerate(dat['atoms']): + del dat['atoms'][i]['redox'] + del dat['particles'] + del dat['reactions'] + + for i,sp in enumerate(dat1['species']): + dat['species'].append(sp) + + dat = FormatReactions_main(dat) + + with open(outfile, 'w') as f: + yaml.dump(dat,f,Dumper=MyDumper,sort_keys=False,width=70)