Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Surface Chemistry - Modified mechanism.H preprocessor directives & mechanism.cpp reaction maps #473

Merged
merged 22 commits into from
Feb 9, 2024

Conversation

jAnirudh
Copy link
Contributor

@jAnirudh jAnirudh commented Feb 1, 2024

Added

  1. User input informing CEPTR the reaction mechanism type along with the names of the gas and interface phases
    • Works for mechanism files (both in single and batch modes)
    • usage for individual files: poetry run convert -f ${PELEPHYSICS_HOME}/Mechanisms/${MECHANISM}/mechanism.yaml --chemistry {mechanism-type} --gas_name {gas-name} --interface_name {interface-name}
      • can also use -c instead of --chemistry
      • mechanism-type has to be either homogeneous or heterogeneous; the default is homogeneous
      • the default values of gas-name and interface-name are gas and None respectively
      • for heterogeneous mechanisms, interface-name has to be explicitly specified
    • default usage for batch conversion of homogeneous reaction mechanism remains unchanged: poetry run convert {-l/lq} ${PELEPHYSICS_HOME}/Mechanisms/{list_mech/list_qss_mech}
  2. Heterogeneous species information in the Converter.set_species method
  3. Indexing for Heterogeneous reactions in the reaction_info.py module

Modified

  1. Converter.mechanism_header_includes to specify surface elements, species, reactions, site density information
  2. reaction map methods in mechanism.cpp that are generated by ReactionInfo.rmap and ReactionInfo.get_rmap methods

This work was performed at the FLAME Lab headed by Dr. Konduri Aditya at CDS, IISc Bengaluru with funding from Shell India Markets Pvt. Ltd. and periodic reviews from the Fluid Flow and Reaction Engineering Group at Shell Technology Center Bengaluru.


Only one of two chemistry arguments are accepted
namely homogeneous and heterogeneous.
mechanism.H now explicitly incorporates surface information
to species_info.py and the set_species method in
converter.py
Essentially surface species, e.g. H(S), are now being
defined as H_S_ID instead of HS_ID
to use NUM_REACTIONS instead of getting n_reactions
ceptr.py:
    chemistry argument is not required and defaults to homogeneous
reaction_info:
    improved verbosity & rewrote isinstance based conditions
converter.py:
    used ternary operator, list comprehension & merged site density
    definition to one line

Also conformed to black and flake8 formatting
converter.py:
    used ternary operator for Converter.species_info.n_all_species
reaction_info.py:
    improved readability of if conditions using and/or keywords
@marchdf marchdf requested review from malihass and baperry2 February 1, 2024 15:16
@marchdf
Copy link
Contributor

marchdf commented Feb 1, 2024

Thank you for doing this!!

We typically run in batch mode. Do you think you could make the defaults such that the following works:

poetry run convert -l ${HOME}/combustion/Pele/PelePhysics/Mechanisms/list_mech
Using 10 processes
multiprocessing.pool.RemoteTraceback:
"""
Traceback (most recent call last):
  File "/Users/mhenryde/.pyenv/versions/3.10.11/lib/python3.10/multiprocessing/pool.py", line 125, in worker
    result = (True, func(*args, **kwds))
  File "/Users/mhenryde/.pyenv/versions/3.10.11/lib/python3.10/multiprocessing/pool.py", line 51, in starmapstar
    return list(itertools.starmap(args[0], args[1]))
TypeError: convert() missing 3 required positional arguments: 'chemistry', 'gas_name', and 'interface_name'
"""

@marchdf marchdf self-requested a review February 1, 2024 16:39
@jAnirudh
Copy link
Contributor Author

jAnirudh commented Feb 2, 2024

@marchdf no worries :)

Also, a quick question: do the sources for qss mechanisms change every time they are regenerated?

@jAnirudh jAnirudh changed the title Surface Chemistry - Modifiied mechanism.H preprocessor directives & mechanism.cpp reaction maps Surface Chemistry - Modified mechanism.H preprocessor directives & mechanism.cpp reaction maps Feb 2, 2024
@marchdf
Copy link
Contributor

marchdf commented Feb 2, 2024

Thanks for doing that. Before we merge, you should run the batch convert and checkin all the changes that triggers.

One of them I noticed needs to be changed:

#define NUM_ELEMENTS NUM_GAS_ELEMENTS + NUM_SURFACE_ELEMENTS
#define NUM_SPECIES NUM_GAS_SPECIES + NUM_SURFACE_SPECIES
#define NUM_REACTIONS NUM_GAS_REACTIONS + NUM_SURFACE_REACTIONS

this is incorrect. It should read:

#define NUM_ELEMENTS (NUM_GAS_ELEMENTS + NUM_SURFACE_ELEMENTS)
#define NUM_SPECIES (NUM_GAS_SPECIES + NUM_SURFACE_SPECIES)
#define NUM_REACTIONS (NUM_GAS_REACTIONS + NUM_SURFACE_REACTIONS)

The () are important.

@marchdf
Copy link
Contributor

marchdf commented Feb 2, 2024

do the sources for qss mechanisms change every time they are regenerated?

they shouldn't... it's always the same for me on the development branch. If they are diffing every time something is wrong with your setup or the new code.

@jAnirudh
Copy link
Contributor Author

jAnirudh commented Feb 2, 2024

do the sources for qss mechanisms change every time they are regenerated?

they shouldn't... it's always the same for me on the development branch. If they are diffing every time something is wrong with your setup or the new code.

Hi @marchdf I think the qss mechanisms in the development branch haven't been updated. I've checked with poetry run -lq ../../Mechanisms/list_qss_mech in the development branch of my fork and I get a few modified mechanism.H files. Would it be possible to verify if this is indeed the case?

I think I got confused because the new code gives files with all the changes whereas I was expecting only the changes which the new code affected.

@marchdf
Copy link
Contributor

marchdf commented Feb 5, 2024

Would it be possible to verify if this is indeed the case?

I just ran it on the development branch and I get no diffs... maybe your development branch is out of date?

@jAnirudh
Copy link
Contributor Author

jAnirudh commented Feb 6, 2024

I just ran it on the development branch and I get no diffs... maybe your development branch is out of date?

I don't know if I'm doing something wrong, but I still get diffs on the original development branch..

I created a fresh clone of PelePhysics, redirected to Support/ceptr and ran poetry update; poetry install. Then I run poetry run convert -lq ../../Mechanisms/list_qss_mechanisms. A git status then gives me

modified:   ../../Mechanisms/C1-C2-NO_qss/mechanism.H
modified:   ../../Mechanisms/CH4_lean_qss/mechanism.H
modified:   ../../Mechanisms/LuEthylene_qss/mechanism.H
modified:   ../../Mechanisms/dodecane_lu_qss/mechanism.H
modified:   ../../Mechanisms/heptane_lu_qss/mechanism.H

I have then verified that the changes from the new code overlaid on top of these only modify the preprocessor directives..

@marchdf
Copy link
Contributor

marchdf commented Feb 6, 2024

How strange... are these a lot of diffs? here's my poetry.lock file. Do you see anything there compared to yours that would indicate a diff? Are your diffs formatting things or actual code stuff?
poetry.lock.txt

@jAnirudh
Copy link
Contributor Author

jAnirudh commented Feb 6, 2024

Exactly the same outcome even with your lock file. The mechanisms change quite a bit which is why I pointed it out.

Does the procedure for qss stuff involve stochastic optimization algorithms? I ask because the differences could be due to a random seed issue. Or it may be a platform-dependent issue since I use an Ubuntu box.

@marchdf
Copy link
Contributor

marchdf commented Feb 6, 2024

maybe this is a clang-format problem?

$ clang-format --version
clang-format version 17.0.6

@baperry2
Copy link
Contributor

baperry2 commented Feb 6, 2024

That's what I was thinking. If it is not formatting properly with clang-format, you should get messages like Clang-format not found. C++ files will be hard to parse by a human. in the output, but they may be buried. We should add the clang-format dependency through poetry to avoid this issue in the future.

Once the QSS mechanisms are committed here, I'll verify that the PeleC and PeleLMeX tests all still pass with the modified mechanisms (I don't see any reason they wouldn't, but it would be good to verify), then we should get this merged.

@marchdf
Copy link
Contributor

marchdf commented Feb 6, 2024

I created #475 to ensure the same clang-format is used by everyone running ceptr.

@jAnirudh
Copy link
Contributor Author

jAnirudh commented Feb 7, 2024

Still no joy. I regenerated the qss mechanisms on another fresh clone of PelePhysics which has the clang-format commit. I've included the files in this zip. The same diffs persist.

The newly generated poetry.lock file poetry.lock.txt has newer versions of the dependencies wrt the lock file you shared. I suppose if you ran a poetry update and regenerated the mechanisms, they might change to what I'm getting?

I am not sure, but I have a feeling this behavior may be due to different numpy versions giving different values of np.random.seed as described in this SO answer. I see that NetworkX has some documentation on RNGs, so it may well be the case that there is a call to np.random.seedsomewhere.

@marchdf
Copy link
Contributor

marchdf commented Feb 8, 2024

Ok I pushed the qss file update. @baperry2 please check and see if all is good now.

@baperry2
Copy link
Contributor

baperry2 commented Feb 9, 2024

Verified this PR won't break LMeX or C, so I'm going to approve. Sorry this PR has taken unusually long to get through with all the mechanism regeneration stuff.

@jAnirudh one last request though, can you update the docs (https://github.com/AMReX-Combustion/PelePhysics/blob/development/Docs/sphinx/Ceptr.rst) with the modified usage that you put in the PR description?

@jAnirudh
Copy link
Contributor Author

jAnirudh commented Feb 9, 2024

Verified this PR won't break LMeX or C, so I'm going to approve. Sorry this PR has taken unusually long to get through with all the mechanism regeneration stuff.

@jAnirudh one last request though, can you update the docs (https://github.com/AMReX-Combustion/PelePhysics/blob/development/Docs/sphinx/Ceptr.rst) with the modified usage that you put in the PR description?

No worries! I've modified the documentation as well.


$ cd ${PELE_PHYSICS_HOME}/Support/ceptr
$ poetry run convert -f ${PELE_PHYSICS_HOME}/Mechanisms/LiDryer/mechanism.yaml

NOTE: CEPTR interpretations of heterogeneous mechanisms is currently a work in progress.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you make this an actual rst type note? there are some examples in here somewhere

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Added a new commit with the rst type note

@marchdf marchdf merged commit de505b3 into AMReX-Combustion:development Feb 9, 2024
9 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants