Fix: Prevent name collision between coords and data variables #7794
Add this suggestion to a batch that can be applied as a single commit. This suggestion is invalid because no changes were made to the code. Suggestions cannot be applied while the pull request is closed. Suggestions cannot be applied while viewing a subset of changes. Only one suggestion per line can be applied in a batch. Add this suggestion to a batch that can be applied as a single commit. Applying suggestions on deleted lines is not supported. You must change the existing code in this line in order to create a valid suggestion. Outdated suggestions cannot be applied. This suggestion has been applied or marked resolved. Suggestions cannot be applied from pending reviews. Suggestions cannot be applied on multi-line comments. Suggestions cannot be applied while the pull request is queued to merge. Suggestion cannot be applied right now. Please check back later.
Fix: Prevent name collision between coords and data variables
Adds checks to prevent you from defining a coordinate with the same name as a data variable, or vice-versa.
This addresses issue #7788, where such name collisions could lead to downstream errors, particularly with
sample_posterior_predictivereturning prior predictive samples instead of posterior predictive samples.The following changes were made:
Model.add_named_variableto check if the proposed variable name already exists as a coordinate name.Model.add_coordto check if the proposed coordinate name already exists as a variable name.tests/model/test_core.pyto verify these checks.📚 Documentation preview 📚: https://pymc--7794.org.readthedocs.build/en/7794/