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

Add abstract base class for channels #98

Merged
merged 38 commits into from
Nov 13, 2024

Conversation

namurphy
Copy link
Contributor

@namurphy namurphy commented Feb 13, 2023

This PR will add a subpackage tentatively called abstractions which will include an abstract base class tentatively called AbstractChannel. This PR is so we can iterate upon the design initiated by @wtbarnes.

This PR comes after a discussion about how aiapy and xrtpy can have a common interface for calculating effective areas and temperature response functions. Having a common interface would be particularly useful for multi-instrument differential emission measures, and for cross-calibration between different instruments. This could potentially also be useful for other instrument packages like irispy.

This idea is a joint effort among @wtbarnes, @joyvelasquez, @nabobalis, @jslavin, and me.

@nabobalis & @wtbarnes: since you're package maintainers (I think), please feel free to edit this directly.

We can follow up on this with separate PRs for things like AbstractSpectralModel, or other things.

TODOs before merging:

@namurphy

This comment was marked as duplicate.

@namurphy
Copy link
Contributor Author

@nabobalis also brought up the idea of Python 3.8+ protocol classes, which would require making this package Python 3.8+ instead of 3.7+.

@dstansby
Copy link
Member

dstansby commented Apr 5, 2023

@nabobalis also brought up the idea of Python 3.8+ protocol classes, which would require making this package Python 3.8+ instead of 3.7+.

It looks like this package is now 3.8+ if you want to take this approach!

@wtbarnes
Copy link
Member

wtbarnes commented Oct 3, 2023

I've made a first pass at a full implementation of the AbstractChannel using the definitions of the terms laid out in #111. This still needs work, especially in terms of documenting each method.

Additionally, I've mixed abstract properties/methods with concrete implementations of several of the methods. I'm not sure if this is the right way to go about doing this? Should this go in a separate BaseChannel class that can then be subclassed?

I've also implemented a fairly simple SourceSpectra class. It uses xarray for the underlying data representation and essentially only exists to provide Quantity objects for the different axes. This should also probably get its own file at least.

Finally, I think this should not be merged until we've come to a consensus on #111.

@wtbarnes wtbarnes force-pushed the add-abstract-channel branch from cfefa60 to f51a009 Compare December 23, 2023 04:51
@wtbarnes
Copy link
Member

This should wait on #98 to be merged such that the appropriate links can be added to the docstrings. This abstract base class should also be tested out in several of the existing instrument packages like aiapy or xrtpy before being merged.

@wtbarnes

This comment was marked as duplicate.

@wtbarnes wtbarnes force-pushed the add-abstract-channel branch from 4774c08 to b1f5541 Compare September 17, 2024 20:51
@wtbarnes
Copy link
Member

wtbarnes commented Sep 17, 2024

I'm not the biggest fan of having an abstractions subpackage though I'm not sure what else to call it. It seems odd to have "abstractions" so high up in the namespace though since this is a feature that will be used by developers of other packages, not users.

Maybe we could have a response subpackage (where potentially some actual instrument responses could go) and then have abstractions.py under that?

@nabobalis
Copy link
Contributor

Maybe we could have a response subpackage (where potentially some actual instrument responses could go) and then have abstractions.py under that?

I like this

@namurphy
Copy link
Contributor Author

I'm not the biggest fan of having an abstractions subpackage though I'm not sure what else to call it. It seems odd to have "abstractions" so high up in the namespace though since this is a feature that will be used by developers of other packages, not users.

Now that you mention it, I agree!

Maybe we could have a response subpackage (where potentially some actual instrument responses could go) and then have abstractions.py under that?

Sounds great to me! Did you want to make that change?

@wtbarnes
Copy link
Member

Sounds great to me! Did you want to make that change?

Yes, I'm happy to. I'm actively working on the branch at the moment anyway.

@wtbarnes wtbarnes force-pushed the add-abstract-channel branch from 44f99a5 to bcfe9ab Compare September 24, 2024 13:27
@wtbarnes
Copy link
Member

The oldest deps build is failing because for some reason it is picking up xarray==0.7.0 which is from 8 years ago! https://github.com/pydata/xarray/releases/tag/v0.7.0

pyproject.toml Outdated Show resolved Hide resolved
Copy link
Member

@hayesla hayesla left a comment

Choose a reason for hiding this comment

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

this looks good!

Just a general comment - what about non-imaging instruments that could also use this type of implementation?

Also it would be good to have an example added here to on how to use this

sunkit_instruments/response/abstractions.py Outdated Show resolved Hide resolved
sunkit_instruments/response/abstractions.py Outdated Show resolved Hide resolved
sunkit_instruments/response/thermal.py Outdated Show resolved Hide resolved
sunkit_instruments/response/thermal.py Outdated Show resolved Hide resolved
sunkit_instruments/response/thermal.py Outdated Show resolved Hide resolved
sunkit_instruments/response/thermal.py Outdated Show resolved Hide resolved
sunkit_instruments/response/thermal.py Outdated Show resolved Hide resolved
"""
Temperature response function for a given instrument channel.

The temperature response function describes the sensitivity of an imaging
Copy link
Member

Choose a reason for hiding this comment

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

maybe just a general question - could this not be extended for non-imaging instruments? i.e. so not per pixel? how is this planned to deal with these cases?

Copy link
Member

Choose a reason for hiding this comment

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

That's a great question. I would hope that yes it could be extended to non-imaging instruments as well. What would the units be in that case? Also, do you have an example of a non-imaging instrument that computes a temperature response? Is it common to compute temperature responses for GOES XRS?

@wtbarnes
Copy link
Member

Just a general comment - what about non-imaging instruments that could also use this type of implementation?

Yes, I think non-imaging instruments should be able to as well. This should presumably be applicable to any imaging instrument and in the context of just the wavelength-resolved effective area, may also be applicable to spectroscopically-resolved data as well. In the case of the temperature response, this should be applicable to any wavelength-integrated instrument primarily observing optically-thin emission.

Also it would be good to have an example added here to on how to use this

We could create a semi-contrived example in the docs. We could also point to how this is done in external packages like aiapy or xrtpy (once that actually happens). I see this as primarily a developer tool rather than a user tool so maybe just a silly contrived example is sufficient.

@wtbarnes
Copy link
Member

We had some discussion about this on the community call today (9/25/24). There is a feeling that this should probably go into the core package (sunpy) at some point as the functionality is quite general and it would be more convenient for users to just depend on sunpy rather than having to depend on sunkit-instruments as well. However, there was some hesitancy about having xarray become a core dependency (even an optional one). Keeping this in sunkit-instruments for now also means we can iterate on it faster as this is still new functionality and the API may change as it gets used in the wild more frequently.

@Cadair
Copy link
Member

Cadair commented Sep 26, 2024

+1 to getting this into core, I think we could have a discussion about the xarray thing when that happens if needed.

@nabobalis
Copy link
Contributor

The plan is to merge this and get an alpha release out we can use to experiment on aiapy and xrtpy.

@nabobalis nabobalis merged commit 91e3c39 into sunpy:main Nov 13, 2024
16 of 18 checks passed
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.

7 participants