-
Notifications
You must be signed in to change notification settings - Fork 17
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
Entropy stable DG and flux-differencing #306
base: main
Are you sure you want to change the base?
Conversation
dc8d8dc
to
c7457c5
Compare
This is #214 squashed and rebased. Co-authored-by: Andreas Kloeckner <inform@tiker.net>
c7457c5
to
56de20d
Compare
So, as I mentioned on Friday I'm running into some difficulties with applying axis tags to the computations for two-point fluxes (link) / volume flux differencing (link). In the code in the first link, the incoming File "meshmode/array_context.py", line 904, in fuse_same_discretization_entity_loops
knl = _fuse_loops_over_a_discr_entity(knl, DiscretizationDOFAxisTag,
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "meshmode/array_context.py", line 876, in _fuse_loops_over_a_discr_entity
lp.get_kennedy_unweighted_fusion_candidates(
File "loopy/transform/loop_fusion.py", line 762, in get_kennedy_unweighted_fusion_candidates
raise LoopyError(f"'{iname}' and '{conflict_iname}' "
loopy.diagnostic.LoopyError: 'cse_294_dim2' and 'cse_294_dim1' cannot fused be fused as they can be nested within one another. Based on our discussion on Friday it sounds like the fusion pipeline isn't yet smart enough to avoid attempting to fuse loops over the first DOF axis with loops over the second. Previously I had attempted to fix this by creating a new DOF axis tag and applying that to the second DOF axis of the arrays, but this appears to just end up producing duplicate tags once the axis is inferred as a I'm not sure what the next step should be. Question @inducer: Is there a reason that the failure to fuse needs to be an error here vs. just a warning? Would changing that be one way of resolving this, or does that not help? Anything else I can try? |
@inducer Any thoughts on this? |
For the record (and as discussed) this comes from the current transform strategy not into account that there could be more than one axis corresponding to DOFs in an array. Also, it seems to want to materialize the 2D DOF differencing array, which is almost certainly not what we want. |
I'm skeptical if that's true with the newly proposed BatchedEinsumArrayContext as well. The arguments of an einsum node are tagged with |
This is work towards updating #214 for modern-day grudge.
Still many things to do: