Source code for jwst.superbias.superbias_step

from stdatamodels.jwst import datamodels

from ..stpipe import Step
from . import bias_sub

__all__ = ["SuperBiasStep"]


[docs] class SuperBiasStep(Step): """ SuperBiasStep: Performs super-bias subtraction by subtracting super-bias reference data from the input science data model. """ class_alias = "superbias" spec = """ """ reference_file_types = ['superbias']
[docs] def process(self, input): # Open the input data model with datamodels.RampModel(input) as input_model: # Get the name of the superbias reference file to use self.bias_name = self.get_reference_file(input_model, 'superbias') self.log.info('Using SUPERBIAS reference file %s', self.bias_name) # Check for a valid reference file if self.bias_name == 'N/A': self.log.warning('No SUPERBIAS reference file found') self.log.warning('Superbias step will be skipped') result = input_model.copy() result.meta.cal_step.superbias = 'SKIPPED' return result # Open the superbias ref file data model bias_model = datamodels.SuperBiasModel(self.bias_name) # Do the bias subtraction result = bias_sub.do_correction(input_model, bias_model) # Close the superbias reference file model and # set the step status to complete bias_model.close() result.meta.cal_step.superbias = 'COMPLETE' return result