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

Deterministic Type Hierarchy #378

Open
GabrielKS opened this issue Jun 12, 2024 · 2 comments
Open

Deterministic Type Hierarchy #378

GabrielKS opened this issue Jun 12, 2024 · 2 comments

Comments

@GabrielKS
Copy link
Contributor

GabrielKS commented Jun 12, 2024

I don't love how we special-case that Deterministic, a concrete type, sometimes also refers to DeterministicSingleTimeSeries, a different concrete type. I don't know about the typical user, but this definitely confused me before it was explained to me. We would have to think about how to resolve this without breaking existing code. For now we'll keep it as-is but at some point restore the behavior that you can pass abstract types to get_time_series; when that is done, there is a change that can be reverted in PSY. See #349 (comment). Broken out of #356.

@GabrielKS GabrielKS changed the title I don't love how we special-case (in this PR and in existing code) that Deterministic, a concrete type, sometimes also refers to DeterministicSingleTimeSeries, a different concrete type. I don't know about the typical user, but this definitely confused me before it was explained to me. We would have to think about how to resolve this without breaking existing code. For now we'll keep it as-is but at some point restore the behavior that you can pass abstract types to get_time_series; when that is done, there is a change that can be reverted in PSY. Deterministic Type Hierarchy Jun 12, 2024
@GabrielKS
Copy link
Contributor Author

GabrielKS commented Jun 12, 2024

We've resolved to not make any backwards-incompatible changes due to this right now, but for the next major version, here is my proposal:


Currently we have this type hierarchy:

AbstractDeterministic
  |- Deterministic  # this one is a "real" forecast
  |- DeterministicSingleTimeSeries  # this one is a "fake" forecast

and these behaviors:

  1. AbstractDeterministic doesn't ever get referred to by the user
  2. When the user says Deterministic, it means the Deterministic time series of that name, if there is none then the DeterministicSingleTimeSeries of that name, if there is none then error

I propose to make the following renames:

AbstractDeterministic RENAME TO Deterministic
  |- Deterministic RENAME TO DeterministicTrueForecast  # or something else, not wedded to this
  |- DeterministicSingleTimeSeries NO RENAME

and have the following behaviors:

  1. When the user wants to refer to something that behaves like a deterministic forecast regardless of whether the underlying data is really forecast data or not, they say Deterministic, which is now an abstract type. Queries on Deterministic return the DeterministicTrueForecast or DeterministicSingleTimeSeries with that name if there is only one, error if there are both, in which case the user has to specify a subtype to clear up the ambiguity.
    • In fact, this works for all abstract types, e.g., queries on Forecast return the Forecast with that name no matter its concrete type if there is only one, error if there are multiple
  2. If we want to minimize required user code changes at the expense of abuse of notation, create an alias of the DeterministicTrueForecast constructor called Deterministic. I would prefer my proposal without this, but I think my proposal with this is still better than the status quo

This proposal ends the abuse of the type hierarchy and the hard-coding that requires. The cost in change to the user interface is either practically zero, if the constructor alias is created, or small if it is not. The benefit is in more elegant and maintainable code and an intuitive connection between the type hierarchy and the time series query matching spec.

@GabrielKS
Copy link
Contributor Author

New resolution: for now, we keep the current behavior, which is that if you pass in Deterministic, it may sometimes return DeterministicSingleTimeSeries. In the next major version, we break this: whenever you pass in a concrete type, you will only get that concrete type back. We may also support the behavior that when you pass in an abstract type (AbstractDeterministic), you get all its concrete subtypes back.

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

No branches or pull requests

1 participant