-
-
Notifications
You must be signed in to change notification settings - Fork 20
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
Refactor MeasurableElemwise
and its use
#208
Refactor MeasurableElemwise
and its use
#208
Conversation
Codecov ReportBase: 95.08% // Head: 95.15% // Increases project coverage by
Additional details and impacted files@@ Coverage Diff @@
## main #208 +/- ##
==========================================
+ Coverage 95.08% 95.15% +0.06%
==========================================
Files 12 12
Lines 1974 2023 +49
Branches 258 253 -5
==========================================
+ Hits 1877 1925 +48
- Misses 55 56 +1
Partials 42 42
Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here. ☔ View full report at Codecov. |
30c7521
to
3833828
Compare
This looks great, and now that it's cleaned up it looks more obvious to me what can be further improved. Do you want to also go ahead and include the changes in #184 or do you want to leave it for future work? More general commentI am not convinced that in the simple situations AePPL currently supports we need to rewrite the graph at all, although it could be useful to have a "canonicalization" phase where we could rewrite transforms of
However, pushed a little further, rewriting the graph could be very interesting for AeMCMC. We would need to replace every random and observed variable in the graph by their corresponding measure, including their domain and logdensity graph. That means starting from the known measures and pushing them through the transforms, thus getting a graph of Measures; transforms are then irrelevant if we also keep track of the relation between value variables in parallel. This is probably what we should be aiming for in these rewrites, instead of replacing Aesara operators with |
These changes make it possible for users to extend coverage of measurable `Elemwise` transforms. They also put these rewrites under the management of Aesara's rewrite system, which means they can be applied more efficiently and their use can customized and tracked with more granularity. `sub`, `neg`, and `true_div` support is added, as well.
3833828
to
369b835
Compare
Let's do that one in a follow-up.
Yes, there's a lot to rework here. I'm going to merge this one so that—in the meantime—our existing functionality is preserved and better designed. At the very least, it should be a lot easier to rewrite/redesign in this form compared to the current. |
This PR refactors the design of
MeasurableElemwise
and the rewrites that use it (i.e. the changes mostly introduced by #26).These changes make it easier for others to extend the coverage of measurable
Elemwise
transforms using basic rewrite DB registration. They also put each transformation rewrite under the management of Aesara's rewrite system independently, which means that they can be applied more efficiently (e.g. hash-based lookups on distinctOp
instances) and their application can be enabled/disabled and tracked with more granularity—among other things.The additions in #144 have also been added.
Closes #170