optixstuff.disperser#
Disperser hardware descriptors for integral field spectrographs.
optixstuff owns the descriptor: the interface plus a cheap closed-form scalar/ETC face. The heavy render logic (building the forward operator) lives in coronachrome. This mirrors the coronagraph split, so jaxedith and yield tools can read IFS hardware info without importing the render engine.
Classes#
Interface for a dispersing IFS element (lenslet array, slicer, MSA). |
|
Lenslet-array IFS disperser (CRISPY heritage). |
Functions#
|
Evaluate the derivative of a descending-order polynomial at x. |
Module Contents#
- class optixstuff.disperser.AbstractDisperser[source]#
Bases:
equinox.ModuleInterface for a dispersing IFS element (lenslet array, slicer, MSA).
Only the scalar/ETC face is defined here. Render geometry lives in coronachrome and dispatches on the concrete descriptor type.
- abstractmethod spectral_resolution(wavelength_nm)[source]#
Resolving power R = lambda / dlambda at the given wavelength.
- optixstuff.disperser._polyval_deriv(coeffs, x)[source]#
Evaluate the derivative of a descending-order polynomial at x.
- class optixstuff.disperser.LensletDisperser[source]#
Bases:
AbstractDisperserLenslet-array IFS disperser (CRISPY heritage).
Config only. The render geometry (IR build) is performed by coronachrome, which reads these fields. Scalar/ETC methods derive from
dispersion_coeffs+pix_per_reseltso the dispersion model is the single source of truth.- spectral_resolution(wavelength_nm)[source]#
R = (local px per unit log-lambda) / pixels-per-resolution-element.