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

Evaluate usage of SourceModelContainer and remove it if possible #8742

Closed
stscijgbot-jp opened this issue Aug 30, 2024 · 2 comments · Fixed by #8915
Closed

Evaluate usage of SourceModelContainer and remove it if possible #8742

stscijgbot-jp opened this issue Aug 30, 2024 · 2 comments · Fixed by #8915

Comments

@stscijgbot-jp
Copy link
Collaborator

Issue JP-3725 was created on JIRA by Ned Molter:

SourceModelContainer is a data structure that's used to make a MultiExposureModel look like a ModelContainer so that those data could be processed through certain steps in calwebb_spec3, namely exp_to_source and extract_1d.  With the likely changes to ModelContainer in this epic, we need to take another look at whether SourceModelContainer is still useful and whether it should be modified or removed entirely from the pipeline.

@stscijgbot-jp
Copy link
Collaborator Author

Comment by Ned Molter on JIRA:

Since we decided to retain ModelContainer in JP-3721, there's seemingly nothing wrong with retaining SourceModelContainer as a convenient way to make MultiExposureModels process through the pipeline where ModelContainer is the expected input type.  The class is pretty minimal already, just allowing conversion from/to a MultiExposureModel and saving as a MultiExposureModel.  Plus, this class is only used internally by the pipeline, unlike ModelContainer (which is the default container for asn-type input for stdatamodels.jwst.datamodels.open).

Therefore, this ticket is being de-scoped, and now covers the removal of the DefaultOrderedDict class from exp_to_source.py.  The DefaultOrderedDict was only used when turning MultiExposureModels into SourceModelContainers, which is why it's relevant to re-evaluating of SourceModelContainer.  This class is no longer necessary as of Python 3.7, which specified that the default dict preserves order; the builtin collections.defaultdict can be used instead.  

@stscijgbot-jp
Copy link
Collaborator Author

Comment by Ned Molter on JIRA:

Mostly withdrawn, small change that removed unnecessary DefaultOrderedDict class in #8915 

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

1 participant