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

Corbett/kernel specs #3273

Draft
wants to merge 16 commits into
base: develop
Choose a base branch
from
Draft

Corbett/kernel specs #3273

wants to merge 16 commits into from

Conversation

corbett5
Copy link
Contributor

@corbett5 corbett5 commented Aug 7, 2024

TODO: If the json file is modified CMake doesn't run again.

Not a fan of having to duplicate the function declarations again in the .cpp.template file. Many of the functions have very complicated declarations and the errors obtained from mistakes are sure to cause headaches. For me this was in physicsSolvers/fluidFlow/CompositionalMultiphaseHybridFVMKernels_impl.hpp. One alternative is to define explicit instantiation macros in this header so at least you don't have to update two different files. You'd still have to list out the function arguments twice unless we resorted to some more intrusive macros.

"( "<<( ( "\n " + LvArray::system::demangle( internal::typeIdWrapper( objects ).name() ) ) + ... )<<" \n)\n"
// <<
// "and the dispatch options are:\n"<<
// internal::listToString( combinations, "\n(", "\n)", typeListPrinter )
Copy link
Contributor Author

Choose a reason for hiding this comment

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

Because combinations has so many different types I have run into compiler bugs when trying to print it out. Luckily the stack trace here seems to work find and that contains the types.

Comment on lines +508 to +509
// using SUBREGION_TYPES = types::Slice< DISPATCH_TYPE_LIST >;
using SUBREGION_TYPES = types::TypeList< CellElementSubRegion >;
Copy link
Contributor Author

Choose a reason for hiding this comment

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

This is a hack, but I am not sure how we want to do this. The types::Slice that I commented out will return a list of the first element from the list-of-lists DISPATCH_TYPE_LIST, but for what we have now this is just a list containing many copies of CellElementSubRegion. So many copies in fact that NVCC gives up in forElementSubRegions.

Copy link
Collaborator

Choose a reason for hiding this comment

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

Can we just extract a list of unique subregion types from that slice? I am not saying I know how to do it but I am sure we can come up with some meta-programming magic to do that. To be seen if nvcc does not crash while doing that though...

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I thought about that, I wanted to check in here before I invested the time.

Copy link
Collaborator

Choose a reason for hiding this comment

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

we could also just loop over all subRegions and then have a runtime check on the type inside the dispatch and only launch the kernels if the real type matches the dispatched one. Basically if the subregion cast failsinstead of errorring out we just ignore it.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

That was what I tried at first. Aside from the fact that I imagine there are cases where we would prefer to error out instead of silently proceeding it has the problem that not all subregions have the FiniteElementBase subgroup so the following call will fail

FiniteElementBase & subRegionFE = elementSubRegion.template getReference< FiniteElementBase >( finiteElementName );

If we want to go this way we could do the same thing as we do for the constitutive model and allocate a NullFiniteElement class.

Copy link
Collaborator

Choose a reason for hiding this comment

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

I had not though of that... this is certainly not the most elegant path so let's see if we can come up with something cleaner as we add use cases for this.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Certainly for now the simplest thing would be to just keep it as is using SUBREGION_TYPES = types::TypeList< CellElementSubRegion >; and then re-evaluate once we have a need for other types.

@@ -0,0 +1,512 @@
{
Copy link
Contributor Author

Choose a reason for hiding this comment

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

@rrsettgast do we need all these combinations?

@corbett5
Copy link
Contributor Author

@rrsettgast @wrtobin I think you guys should give this a look over. I commented a few of the pain points. It passes most of the integrated tests on ruby (except a few FPE runtime errors and restart checks I think are unrelated to this PR) and I have been unable to run them on Lassen.

All in all the compilation is still extremely slow. It takes almost two hours to compile on Lassen, most of which is spent linking.

"H1_Prism11_VEM_Gauss1"
]
},
"explicit": []
Copy link
Member

Choose a reason for hiding this comment

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

@corbett5 Can you put an example here and I will fill out the valid combinations?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

@rrsettgast this is not how it's done, but I'll probably try and change it to accept this format.

"explicit": [
  ["CellElementSubRegion", "DamageSpectral<ElasticIsotropic>", "H1_Hexahedron_Lagrange1_GaussLegendre2"],
  ["CellElementSubRegion", "DamageSpectral<ElasticIsotropic>", "H1_Wedge_Lagrange1_Gauss6"]
]

The order of the values should be the same as the order of the vars. In this case this is

"vars": [ "SUBREGION_TYPE", "CONSTITUTIVE_TYPE", "FE_TYPE" ]

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.

5 participants