dkist-processing-cryonirsp 0.0.51__tar.gz → 0.0.52__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of dkist-processing-cryonirsp might be problematic. Click here for more details.
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/CHANGELOG.rst +9 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/PKG-INFO +1 -1
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/models/parameters.py +11 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/mixin/corrections.py +10 -1
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/conftest.py +2 -1
- dkist_processing_cryonirsp-0.0.52/dkist_processing_cryonirsp/tests/test_corrections.py +92 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp.egg-info/PKG-INFO +1 -1
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp.egg-info/SOURCES.txt +1 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/.gitignore +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/.pre-commit-config.yaml +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/.readthedocs.yml +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/README.rst +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/SCIENCE_CHANGELOG.rst +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/bitbucket-pipelines.yml +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/changelog/.gitempty +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/check_changelog_updated.sh +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/__init__.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/models/__init__.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/models/constants.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/models/exposure_conditions.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/models/tags.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/models/task_name.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/parsers/__init__.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/parsers/cryonirsp_l0_fits_access.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/parsers/cryonirsp_l1_fits_access.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/parsers/exposure_conditions.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/parsers/map_repeats.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/parsers/measurements.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/parsers/modstates.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/parsers/optical_density_filters.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/parsers/polarimetric_check.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/parsers/scan_step.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/parsers/time.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/parsers/wavelength.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/__init__.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/assemble_movie.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/bad_pixel_map.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/beam_boundaries_base.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/ci_beam_boundaries.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/ci_science.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/cryonirsp_base.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/dark.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/gain.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/instrument_polarization.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/l1_output_data.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/linearity_correction.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/make_movie_frames.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/mixin/__init__.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/mixin/beam_access.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/mixin/intermediate_frame.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/mixin/linearized_frame.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/mixin/shift_measurements.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/parse.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/quality_metrics.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/science_base.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/sp_beam_boundaries.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/sp_geometric.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/sp_science.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/sp_solar_gain.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/trial_output_data.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tasks/write_l1.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/__init__.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/header_models.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/local_trial_workflows/__init__.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/local_trial_workflows/l0_cals_only.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/local_trial_workflows/l0_to_l1.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/local_trial_workflows/linearize_only.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/local_trial_workflows/local_trial_helpers.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_assemble_movie.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_bad_pixel_maps.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_build_quality_report.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_ci_beam_boundaries.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_ci_science.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_cryo_base.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_cryo_constants.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_dark.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_gain.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_instrument_polarization.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_linearity_correction.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_make_movie_frames.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_parameters.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_parse.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_quality.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_sp_beam_boundaries.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_sp_geometric.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_sp_make_movie_frames.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_sp_science.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_sp_solar.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_submit_qualilty.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_trial_output_data.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_workflows.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/tests/test_write_l1.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/workflows/__init__.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/workflows/ci_l0_processing.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/workflows/sp_l0_processing.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp/workflows/trial_workflows.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp.egg-info/dependency_links.txt +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp.egg-info/requires.txt +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/dkist_processing_cryonirsp.egg-info/top_level.txt +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/docs/Makefile +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/docs/changelog.rst +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/docs/conf.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/docs/index.rst +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/docs/l0_to_l1_cryonirsp_ci.rst +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/docs/l0_to_l1_cryonirsp_sp.rst +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/docs/make.bat +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/docs/requirements.txt +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/docs/requirements_table.rst +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/docs/scientific_changelog.rst +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/licenses/LICENSE.rst +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/pyproject.toml +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/science_towncrier.sh +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/setup.cfg +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/setup.py +0 -0
- {dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/towncrier_science.toml +0 -0
|
@@ -1,3 +1,12 @@
|
|
|
1
|
+
v0.0.52 (2024-04-02)
|
|
2
|
+
====================
|
|
3
|
+
|
|
4
|
+
Misc
|
|
5
|
+
----
|
|
6
|
+
|
|
7
|
+
- Update bad pixel correction method such that if more than a given fraction of the frame is impacted, a faster and more general algorithm is used. This reduces processing time in cases where the data has readout problems or other large scale issues. (`#109 <https://bitbucket.org/dkistdc/dkist-processing-cryonirsp/pull-requests/109>`__)
|
|
8
|
+
|
|
9
|
+
|
|
1
10
|
v0.0.51 (2024-03-27)
|
|
2
11
|
====================
|
|
3
12
|
|
|
@@ -127,6 +127,17 @@ class CryonirspParameters(ParameterBase):
|
|
|
127
127
|
"cryonirsp_corrections_bad_pixel_median_filter_size"
|
|
128
128
|
)
|
|
129
129
|
|
|
130
|
+
@cached_property
|
|
131
|
+
def corrections_bad_pixel_fraction_threshold(self) -> float:
|
|
132
|
+
"""
|
|
133
|
+
Return the fraction of the bad pixel mask.
|
|
134
|
+
|
|
135
|
+
If exceeded, will cause the fallback to a faster but worse algorithm.
|
|
136
|
+
"""
|
|
137
|
+
return self._find_most_recent_past_value(
|
|
138
|
+
"cryonirsp_corrections_bad_pixel_fraction_threshold"
|
|
139
|
+
)
|
|
140
|
+
|
|
130
141
|
@cached_property
|
|
131
142
|
def linearization_thresholds(self) -> np.ndarray:
|
|
132
143
|
"""Name of parameter associated with the linearization thresholds."""
|
|
@@ -129,7 +129,10 @@ class CorrectionsMixin:
|
|
|
129
129
|
"""
|
|
130
130
|
Correct bad pixels in an array using a median filter.
|
|
131
131
|
|
|
132
|
-
Corrects only the bad pixels identified by the bad pixel map
|
|
132
|
+
Corrects only the bad pixels identified by the bad pixel map.
|
|
133
|
+
|
|
134
|
+
If enough pixels are found to suggest readout errors (> a given fraction of the array),
|
|
135
|
+
a global replacement value is used instead.
|
|
133
136
|
|
|
134
137
|
Parameters
|
|
135
138
|
----------
|
|
@@ -145,6 +148,12 @@ class CorrectionsMixin:
|
|
|
145
148
|
ndarray
|
|
146
149
|
The corrected array
|
|
147
150
|
"""
|
|
151
|
+
bad_pixel_fraction = np.sum(bad_pixel_map) / bad_pixel_map.size
|
|
152
|
+
if bad_pixel_fraction > self.parameters.corrections_bad_pixel_fraction_threshold:
|
|
153
|
+
global_median = np.nanmedian(array_to_fix)
|
|
154
|
+
array_to_fix[bad_pixel_map == 1] = global_median
|
|
155
|
+
return array_to_fix
|
|
156
|
+
|
|
148
157
|
kernel_size = self.parameters.corrections_bad_pixel_median_filter_size
|
|
149
158
|
half_kernel_size = kernel_size // 2
|
|
150
159
|
|
|
@@ -294,7 +294,7 @@ def cryonirsp_testing_parameters_factory(
|
|
|
294
294
|
cryonirsp_geo_strip_short_axis_size_fraction: float = 0.1
|
|
295
295
|
cryonirsp_geo_strip_spectral_offset_size_fraction: float = 0.25
|
|
296
296
|
cryonirsp_solar_characteristic_spatial_normalization_percentile: float = 80.0
|
|
297
|
-
cryonirsp_max_cs_step_time_sec: float =
|
|
297
|
+
cryonirsp_max_cs_step_time_sec: float = 180.0
|
|
298
298
|
cryonirsp_beam_boundaries_smoothing_disk_size: int = 3
|
|
299
299
|
cryonirsp_beam_boundaries_upsample_factor: int = 10
|
|
300
300
|
cryonirsp_beam_boundaries_sp_beam_transition_region_size_fraction: float = 0.05
|
|
@@ -306,6 +306,7 @@ def cryonirsp_testing_parameters_factory(
|
|
|
306
306
|
)
|
|
307
307
|
cryonirsp_bad_pixel_map_threshold_factor: float = 5.0
|
|
308
308
|
cryonirsp_corrections_bad_pixel_median_filter_size: int = 8
|
|
309
|
+
cryonirsp_corrections_bad_pixel_fraction_threshold: float = 0.03
|
|
309
310
|
cryonirsp_fringe_correction_on: bool = True
|
|
310
311
|
cryonirsp_fringe_correction_spectral_filter_size: list[int] = field(
|
|
311
312
|
default_factory=lambda: [1, 20]
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import numpy as np
|
|
2
|
+
import pytest
|
|
3
|
+
from dkist_processing_common._util.scratch import WorkflowFileSystem
|
|
4
|
+
from dkist_processing_common.tasks import WorkflowTaskBase
|
|
5
|
+
from dkist_processing_common.tasks.mixin.input_dataset import InputDatasetMixin
|
|
6
|
+
from dkist_processing_common.tests.conftest import FakeGQLClient
|
|
7
|
+
|
|
8
|
+
from dkist_processing_cryonirsp.models.constants import CryonirspConstants
|
|
9
|
+
from dkist_processing_cryonirsp.tasks.mixin.corrections import CorrectionsMixin
|
|
10
|
+
from dkist_processing_cryonirsp.tests.conftest import cryonirsp_testing_parameters_factory
|
|
11
|
+
from dkist_processing_cryonirsp.tests.conftest import CryonirspConstantsDb
|
|
12
|
+
|
|
13
|
+
base_bad_pixel_map = np.zeros(shape=(10, 10))
|
|
14
|
+
|
|
15
|
+
normal_bad_pixel_map = base_bad_pixel_map.copy()
|
|
16
|
+
normal_bad_pixel_map[1, 6] = 1
|
|
17
|
+
|
|
18
|
+
column_error_bad_pixel_map = base_bad_pixel_map.copy()
|
|
19
|
+
column_error_bad_pixel_map[:, 6] = 1
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
class BadPixelMapTask(WorkflowTaskBase, CorrectionsMixin, InputDatasetMixin):
|
|
23
|
+
constants: CryonirspConstants
|
|
24
|
+
|
|
25
|
+
@property
|
|
26
|
+
def constants_model_class(self):
|
|
27
|
+
"""Get CryoNIRSP pipeline constants."""
|
|
28
|
+
return CryonirspConstants
|
|
29
|
+
|
|
30
|
+
def run(self):
|
|
31
|
+
pass
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
@pytest.fixture(params=["CI", "SP"])
|
|
35
|
+
def bad_pixel_mask_task(
|
|
36
|
+
tmp_path,
|
|
37
|
+
recipe_run_id,
|
|
38
|
+
assign_input_dataset_doc_to_task,
|
|
39
|
+
mocker,
|
|
40
|
+
request,
|
|
41
|
+
init_cryonirsp_constants_db,
|
|
42
|
+
):
|
|
43
|
+
mocker.patch(
|
|
44
|
+
"dkist_processing_common.tasks.mixin.metadata_store.GraphQLClient", new=FakeGQLClient
|
|
45
|
+
)
|
|
46
|
+
constants_db = CryonirspConstantsDb(
|
|
47
|
+
ARM_ID=request.param,
|
|
48
|
+
)
|
|
49
|
+
init_cryonirsp_constants_db(recipe_run_id, constants_db)
|
|
50
|
+
with BadPixelMapTask(
|
|
51
|
+
recipe_run_id=recipe_run_id,
|
|
52
|
+
workflow_name="bad_pixel_mask",
|
|
53
|
+
workflow_version="VX.Y",
|
|
54
|
+
) as task:
|
|
55
|
+
try: # This try... block is here to make sure the dbs get cleaned up if there's a failure in the fixture
|
|
56
|
+
task.scratch = WorkflowFileSystem(
|
|
57
|
+
scratch_base_path=tmp_path, recipe_run_id=recipe_run_id
|
|
58
|
+
)
|
|
59
|
+
param_class = cryonirsp_testing_parameters_factory(param_path=tmp_path)
|
|
60
|
+
assign_input_dataset_doc_to_task(task, param_class())
|
|
61
|
+
yield task
|
|
62
|
+
finally:
|
|
63
|
+
task._purge()
|
|
64
|
+
|
|
65
|
+
|
|
66
|
+
@pytest.mark.parametrize(
|
|
67
|
+
"bad_pixel_map, algorithm_type",
|
|
68
|
+
[
|
|
69
|
+
pytest.param(normal_bad_pixel_map, "normal", id="normal algorithm"),
|
|
70
|
+
pytest.param(column_error_bad_pixel_map, "fast", id="fast algorithm"),
|
|
71
|
+
],
|
|
72
|
+
)
|
|
73
|
+
def test_corrections_correct_bad_pixels(bad_pixel_map, algorithm_type, bad_pixel_mask_task):
|
|
74
|
+
t = bad_pixel_mask_task
|
|
75
|
+
bad_pixel_x = 1
|
|
76
|
+
bad_pixel_y = 6
|
|
77
|
+
array_to_fix = np.random.random(size=(10, 10))
|
|
78
|
+
# Assign a single bad pixel to check against
|
|
79
|
+
array_to_fix[bad_pixel_x, bad_pixel_y] = 0
|
|
80
|
+
corrected_array = t.corrections_correct_bad_pixels(
|
|
81
|
+
array_to_fix=array_to_fix, bad_pixel_map=bad_pixel_map
|
|
82
|
+
)
|
|
83
|
+
if algorithm_type == "fast":
|
|
84
|
+
for val in corrected_array[:, bad_pixel_y]:
|
|
85
|
+
assert val == np.nanmedian(array_to_fix)
|
|
86
|
+
assert corrected_array[bad_pixel_x, bad_pixel_y] != 0
|
|
87
|
+
if algorithm_type == "normal":
|
|
88
|
+
x, y = np.meshgrid(np.arange(10), np.arange(10))
|
|
89
|
+
idx = np.where((x != bad_pixel_x) | (y != bad_pixel_y))
|
|
90
|
+
np.testing.assert_array_equal(corrected_array[idx], array_to_fix[idx])
|
|
91
|
+
assert corrected_array[bad_pixel_x, bad_pixel_y] != np.nanmedian(array_to_fix)
|
|
92
|
+
assert corrected_array[bad_pixel_x, bad_pixel_y] != 0
|
|
@@ -72,6 +72,7 @@ dkist_processing_cryonirsp/tests/test_bad_pixel_maps.py
|
|
|
72
72
|
dkist_processing_cryonirsp/tests/test_build_quality_report.py
|
|
73
73
|
dkist_processing_cryonirsp/tests/test_ci_beam_boundaries.py
|
|
74
74
|
dkist_processing_cryonirsp/tests/test_ci_science.py
|
|
75
|
+
dkist_processing_cryonirsp/tests/test_corrections.py
|
|
75
76
|
dkist_processing_cryonirsp/tests/test_cryo_base.py
|
|
76
77
|
dkist_processing_cryonirsp/tests/test_cryo_constants.py
|
|
77
78
|
dkist_processing_cryonirsp/tests/test_dark.py
|
|
File without changes
|
{dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/.pre-commit-config.yaml
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/SCIENCE_CHANGELOG.rst
RENAMED
|
File without changes
|
{dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/bitbucket-pipelines.yml
RENAMED
|
File without changes
|
|
File without changes
|
{dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/check_changelog_updated.sh
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/docs/requirements.txt
RENAMED
|
File without changes
|
{dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/docs/requirements_table.rst
RENAMED
|
File without changes
|
|
File without changes
|
{dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/licenses/LICENSE.rst
RENAMED
|
File without changes
|
|
File without changes
|
{dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/science_towncrier.sh
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{dkist_processing_cryonirsp-0.0.51 → dkist_processing_cryonirsp-0.0.52}/towncrier_science.toml
RENAMED
|
File without changes
|