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

NIRISS SOSS Background Correction Implementation #9018

Open
stscijgbot-jp opened this issue Dec 18, 2024 · 2 comments
Open

NIRISS SOSS Background Correction Implementation #9018

stscijgbot-jp opened this issue Dec 18, 2024 · 2 comments

Comments

@stscijgbot-jp
Copy link
Collaborator

Issue JP-3825 was created on JIRA by Aarynn Carter:

Context: NIRISS SOSS observations exhibit a spatially varying background that must be subtracted prior to spectral extraction to maximize the achievable precision. Thus far, a single "template" background measured from on-sky observations has been used for this, although my understanding is that this correction is not actually applied in the pipeline. In reality, we have found that the background has significant variability as a function of sky position and time, and a single template background is not sufficient for an optimal correction. As such the NIRISS SOSS team has observed and collated a small library of background observations to be used for background subtraction purposes. I have attached a gif of subarray rate images to give you a visual idea of what the background looks like, note the sharp increase at x~700 and it's gradual dimming to later columns. 

Implementation: We would like to implement a background correction for NIRISS SOSS observations, using the library of backgrounds we have produced. However, we think this will require a somewhat careful implementation due to interactions with the column-wise 1/f noise. Ideally, we would like to retain the capability for a group-level 1/f correction without negatively impacting the background correction, and if possible within the framework of the likelihood-based jump detection and ramp fitting routines. My expectation is that this will break the standard flow of the pipeline, but my current best guess for how this would work is:

  1. Process the images to a rate level image.

  2. Fit and determine a best matching background model.

  3. Return to the group-level images and produce a set of background subtracted images. 

  4. Use these images to estimate a group-level 1/f noise correction.

  5. Apply this correction to the original (not background subtracted) group-level images.

  6. Process the 1/f corrected images to the integration level. 

  7. Potentially repeat the background model fitting and subtract the background from the integration level images. 

Throughout this process, I would also like to retain some flexibility for users in being able to provide their own background model, instead of relying entirely on our library. This will also future-proof things for us in the event that we develop new background fitting methods. 

As you can see things are quite intertwined, so I am interested in having a broader discussion about how best to move forward. Nominally, it would be great to implement this in what I'm assuming will be the 11.4 build. But, given the complexity, we thought it was worth giving you as much of a heads up as possible so that we can figure out a best path forward together. 

Note that this connects heavily with #⁠277 

@stscijgbot-jp
Copy link
Collaborator Author

Comment by Aarynn Carter on JIRA:

This was discussed further in the weekly SOSS meeting and we would also be open to considering a solution where the correction is applied at Stage 2, as it may be possible for us to measure the 1/f noise more straightforwardly by subtracting a rolling median of successive integrations prior to ramp fitting. What isn't clear to us is how that interacts with the 1/f and ramp fitting routines, and whether it is actually preferable over the method outlined above. In any event, it would still require computing a best matching background model on the highest SNR, integration-stacked, data. 

@stscijgbot-jp
Copy link
Collaborator Author

Comment by David Law on JIRA:

Following up on this with a few questions:

  • Right now it looks like a SOSS spec2 parameter reference file skips the bkg_subtract step, but even forcing the step to run it doesn't do anything.  Likely this is because the step is intended to subtract a background exposure listed in the input association file for everything except WFSS data (which looks in CRDS to find a background image).
  • What's the reason for the uptick in background values around X=700?  Is this due to straylight from the source signal?
  • Similarly, what's the underlying cause of the background variations overall?  From the image above it looks mostly like different manifestations of the 1/f noise; is there an underlying change in the normalization and/or slope of the zodi background?  If so how does the amplitude of this compare to the 1/f noise in DN/s?
  • Why does the 1/f correction and background subtraction need to be iterative, instead of performing 1/f correction at the group stage on the science data and then subtracting off the 1/f-corrected background data?

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

No branches or pull requests

1 participant