LSST Applications  21.0.0+04719a4bac,21.0.0-1-ga51b5d4+f5e6047307,21.0.0-11-g2b59f77+a9c1acf22d,21.0.0-11-ga42c5b2+86977b0b17,21.0.0-12-gf4ce030+76814010d2,21.0.0-13-g1721dae+760e7a6536,21.0.0-13-g3a573fe+768d78a30a,21.0.0-15-g5a7caf0+f21cbc5713,21.0.0-16-g0fb55c1+b60e2d390c,21.0.0-19-g4cded4ca+71a93a33c0,21.0.0-2-g103fe59+bb20972958,21.0.0-2-g45278ab+04719a4bac,21.0.0-2-g5242d73+3ad5d60fb1,21.0.0-2-g7f82c8f+8babb168e8,21.0.0-2-g8f08a60+06509c8b61,21.0.0-2-g8faa9b5+616205b9df,21.0.0-2-ga326454+8babb168e8,21.0.0-2-gde069b7+5e4aea9c2f,21.0.0-2-gecfae73+1d3a86e577,21.0.0-2-gfc62afb+3ad5d60fb1,21.0.0-25-g1d57be3cd+e73869a214,21.0.0-3-g357aad2+ed88757d29,21.0.0-3-g4a4ce7f+3ad5d60fb1,21.0.0-3-g4be5c26+3ad5d60fb1,21.0.0-3-g65f322c+e0b24896a3,21.0.0-3-g7d9da8d+616205b9df,21.0.0-3-ge02ed75+a9c1acf22d,21.0.0-4-g591bb35+a9c1acf22d,21.0.0-4-g65b4814+b60e2d390c,21.0.0-4-gccdca77+0de219a2bc,21.0.0-4-ge8a399c+6c55c39e83,21.0.0-5-gd00fb1e+05fce91b99,21.0.0-6-gc675373+3ad5d60fb1,21.0.0-64-g1122c245+4fb2b8f86e,21.0.0-7-g04766d7+cd19d05db2,21.0.0-7-gdf92d54+04719a4bac,21.0.0-8-g5674e7b+d1bd76f71f,master-gac4afde19b+a9c1acf22d,w.2021.13
LSST Data Management Base Package
Public Member Functions | Static Public Attributes | List of all members
lsst.ip.isr.linearize.LinearizeLookupTable Class Reference
Inheritance diagram for lsst.ip.isr.linearize.LinearizeLookupTable:
lsst.ip.isr.linearize.LinearizeBase

Public Member Functions

def __call__ (self, image, **kwargs)
 

Static Public Attributes

string LinearityType = "LookupTable"
 

Detailed Description

Correct non-linearity with a persisted lookup table.

The lookup table consists of entries such that given
"coefficients" c0, c1:

for each i,j of image:
    rowInd = int(c0)
    colInd = int(c1 + uncorrImage[i,j])
    corrImage[i,j] = uncorrImage[i,j] + table[rowInd, colInd]

- c0: row index; used to identify which row of the table to use
        (typically one per amplifier, though one can have multiple
        amplifiers use the same table)
- c1: column index offset; added to the uncorrected image value
        before truncation; this supports tables that can handle
        negative image values; also, if the c1 ends with .5 then
        the nearest index is used instead of truncating to the
        next smaller index

Definition at line 520 of file linearize.py.

Member Function Documentation

◆ __call__()

def lsst.ip.isr.linearize.LinearizeLookupTable.__call__ (   self,
  image,
**  kwargs 
)
Correct for non-linearity.

Parameters
----------
image : `lsst.afw.image.Image`
    Image to be corrected
kwargs : `dict`
    Dictionary of parameter keywords:
    ``"coeffs"``
        Columnation vector (`list` or `numpy.array`).
    ``"table"``
        Lookup table data (`numpy.array`).
    ``"log"``
        Logger to handle messages (`lsst.log.Log`).

Returns
-------
output : `tuple` [`bool`, `int`]
    If true, a correction was applied successfully.  The
    integer indicates the number of pixels that were
    uncorrectable by being out of range.

Raises
------
RuntimeError:
    Raised if the requested row index is out of the table
    bounds.

Reimplemented from lsst.ip.isr.linearize.LinearizeBase.

Definition at line 542 of file linearize.py.

542  def __call__(self, image, **kwargs):
543  """Correct for non-linearity.
544 
545  Parameters
546  ----------
547  image : `lsst.afw.image.Image`
548  Image to be corrected
549  kwargs : `dict`
550  Dictionary of parameter keywords:
551  ``"coeffs"``
552  Columnation vector (`list` or `numpy.array`).
553  ``"table"``
554  Lookup table data (`numpy.array`).
555  ``"log"``
556  Logger to handle messages (`lsst.log.Log`).
557 
558  Returns
559  -------
560  output : `tuple` [`bool`, `int`]
561  If true, a correction was applied successfully. The
562  integer indicates the number of pixels that were
563  uncorrectable by being out of range.
564 
565  Raises
566  ------
567  RuntimeError:
568  Raised if the requested row index is out of the table
569  bounds.
570  """
571  numOutOfRange = 0
572 
573  rowInd, colIndOffset = kwargs['coeffs'][0:2]
574  table = kwargs['table']
575  log = kwargs['log']
576 
577  numTableRows = table.shape[0]
578  rowInd = int(rowInd)
579  if rowInd < 0 or rowInd > numTableRows:
580  raise RuntimeError("LinearizeLookupTable rowInd=%s not in range[0, %s)" %
581  (rowInd, numTableRows))
582  tableRow = np.array(table[rowInd, :], dtype=image.getArray().dtype)
583 
584  numOutOfRange += applyLookupTable(image, tableRow, colIndOffset)
585 
586  if numOutOfRange > 0 and log is not None:
587  log.warn("%s pixels were out of range of the linearization table",
588  numOutOfRange)
589  if numOutOfRange < image.getArray().size:
590  return True, numOutOfRange
591  else:
592  return False, numOutOfRange
593 
594 

Member Data Documentation

◆ LinearityType

string lsst.ip.isr.linearize.LinearizeLookupTable.LinearityType = "LookupTable"
static

Definition at line 540 of file linearize.py.


The documentation for this class was generated from the following file: