SigClip
SigClip(
sigma=(3.0, 3.0),
maxiters=5,
cenfunc='median',
clip_cen=None,
stdfunc='std',
ddof=0,
nkeep=1,
maxrej=None,
revert_on_nkeep=True,
grow=None,
)Iterative sigma-clipping rejection.
Parameters
sigma : float or tuple of float = (3.0, 3.0)-
User-supplied clipping multiplier, not the measured data spread itself. Values are clipped when their residual from the clipping center exceeds
sigma * spread. A scalar applies the same multiplier to both tails; a 2-tuple(sigma_lower, sigma_upper)clips asymmetrically. Thresholds must be finite and non-negative. maxiters : int = 5-
Maximum number of clipping iterations per pixel.
ddof : int = 0-
Delta degrees of freedom for the per-pixel spread estimator.
nkeep : int = 1-
Minimum number of unmasked values to preserve at each pixel. An iteration that would drop below this count is reverted in full. The default,
1, prevents clipping from rejecting every finite sample in a per-output stack. Set0only when all samples may be rejected. maxrej : int or None = None-
Maximum number of values that may be rejected at each pixel.
Nonemeans no limit. cenfunc : ('median', 'lmedian', 'mean') = "median"-
Center estimator used each iteration.
lmedianaccepts the aliaslmedand uses the lower of the two middle samples for even valid counts. clip_cen : ('median', 'lmedian', 'mean') = "median"-
Center used when computing the spread for iterative rejection.
Noneuses the same center ascenfunc;lmedianalso acceptslmed. revert_on_nkeep : bool = True-
If
True, an iteration that would leave fewer thannkeepusable samples at a pixel is reverted in full for that pixel. Input masks, threshold masks, and non-finite samples remain excluded. The default isTrue. IfFalse, clipping is strict and may leave fewer thannkeepsamples. stdfunc : ('std', 'mad') = "std"-
Spread estimator used by sigma clipping.
"std"uses the standard deviation."mad"uses1.4826 * median(abs(x - clip_cen))as a robust sigma estimate; whenddof > 0, this estimate is multiplied bysqrt(nvalid / (nvalid - ddof))and pixels withnvalid <= ddofreturnNaNspread diagnostics. grow : float or None = None-
Optional radius in pixels used to grow
mask_rejspatially after rejection. Axis 0 is the stack axis and is never grown across.Nonedisables growth and skips the extra calculation.
Attributes
| Name | Description |
|---|---|
| cenfunc | str(object=’’) -> str |
| ddof | int([x]) -> integer |
| maxiters | int([x]) -> integer |
| nkeep | int([x]) -> integer |
| revert_on_nkeep | bool(x) -> bool |
| sigma | Built-in immutable sequence. |
| stdfunc | str(object=’’) -> str |
Methods
| Name | Description |
|---|---|
| apply | Apply SigClip to an image stack. |
apply
SigClip.apply(arr, mask=None, *, validate=True)Apply SigClip to an image stack.
Parameters
arr : (ndarray, shape(N, *spatial))-
Image stack. Inputs with more than 3 dimensions are flattened internally; output shapes match the trailing spatial dimensions of the input.
mask : ndarray of bool = None-
Input mask;
Truemeans already masked. Must have the same shape asarrbefore any internal flattening. validate : bool = True-
If
True, validate inputs before calling the kernel.
Returns
: mask_rej, std, low, upp, nit, output_flags : tuple of ndarray-
Rejection mask and diagnostics from :func:
imcombiners.kernels.sigclip.stdis the per-pixel spread used by sigma/CCD clipping andNonefor rejection algorithms without a spread diagnostic.