dkist-processing-cryonirsp 0.0.51rc1__tar.gz → 0.0.52rc1__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.

Files changed (117) hide show
  1. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/CHANGELOG.rst +9 -0
  2. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/PKG-INFO +1 -1
  3. dkist_processing_cryonirsp-0.0.52rc1/changelog/109.misc.rst +1 -0
  4. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/models/parameters.py +11 -0
  5. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/mixin/corrections.py +10 -1
  6. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/conftest.py +2 -1
  7. dkist_processing_cryonirsp-0.0.52rc1/dkist_processing_cryonirsp/tests/test_corrections.py +92 -0
  8. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp.egg-info/PKG-INFO +1 -1
  9. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp.egg-info/SOURCES.txt +2 -1
  10. dkist_processing_cryonirsp-0.0.51rc1/changelog/111.feature.rst +0 -1
  11. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/.gitignore +0 -0
  12. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/.pre-commit-config.yaml +0 -0
  13. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/.readthedocs.yml +0 -0
  14. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/README.rst +0 -0
  15. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/SCIENCE_CHANGELOG.rst +0 -0
  16. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/bitbucket-pipelines.yml +0 -0
  17. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/changelog/.gitempty +0 -0
  18. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/check_changelog_updated.sh +0 -0
  19. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/__init__.py +0 -0
  20. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/models/__init__.py +0 -0
  21. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/models/constants.py +0 -0
  22. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/models/exposure_conditions.py +0 -0
  23. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/models/tags.py +0 -0
  24. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/models/task_name.py +0 -0
  25. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/parsers/__init__.py +0 -0
  26. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/parsers/cryonirsp_l0_fits_access.py +0 -0
  27. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/parsers/cryonirsp_l1_fits_access.py +0 -0
  28. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/parsers/exposure_conditions.py +0 -0
  29. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/parsers/map_repeats.py +0 -0
  30. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/parsers/measurements.py +0 -0
  31. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/parsers/modstates.py +0 -0
  32. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/parsers/optical_density_filters.py +0 -0
  33. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/parsers/polarimetric_check.py +0 -0
  34. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/parsers/scan_step.py +0 -0
  35. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/parsers/time.py +0 -0
  36. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/parsers/wavelength.py +0 -0
  37. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/__init__.py +0 -0
  38. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/assemble_movie.py +0 -0
  39. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/bad_pixel_map.py +0 -0
  40. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/beam_boundaries_base.py +0 -0
  41. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/ci_beam_boundaries.py +0 -0
  42. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/ci_science.py +0 -0
  43. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/cryonirsp_base.py +0 -0
  44. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/dark.py +0 -0
  45. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/gain.py +0 -0
  46. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/instrument_polarization.py +0 -0
  47. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/l1_output_data.py +0 -0
  48. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/linearity_correction.py +0 -0
  49. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/make_movie_frames.py +0 -0
  50. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/mixin/__init__.py +0 -0
  51. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/mixin/beam_access.py +0 -0
  52. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/mixin/intermediate_frame.py +0 -0
  53. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/mixin/linearized_frame.py +0 -0
  54. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/mixin/shift_measurements.py +0 -0
  55. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/parse.py +0 -0
  56. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/quality_metrics.py +0 -0
  57. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/science_base.py +0 -0
  58. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/sp_beam_boundaries.py +0 -0
  59. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/sp_geometric.py +0 -0
  60. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/sp_science.py +0 -0
  61. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/sp_solar_gain.py +0 -0
  62. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/trial_output_data.py +0 -0
  63. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tasks/write_l1.py +0 -0
  64. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/__init__.py +0 -0
  65. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/header_models.py +0 -0
  66. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/local_trial_workflows/__init__.py +0 -0
  67. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/local_trial_workflows/l0_cals_only.py +0 -0
  68. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/local_trial_workflows/l0_to_l1.py +0 -0
  69. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/local_trial_workflows/linearize_only.py +0 -0
  70. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/local_trial_workflows/local_trial_helpers.py +0 -0
  71. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_assemble_movie.py +0 -0
  72. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_bad_pixel_maps.py +0 -0
  73. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_build_quality_report.py +0 -0
  74. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_ci_beam_boundaries.py +0 -0
  75. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_ci_science.py +0 -0
  76. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_cryo_base.py +0 -0
  77. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_cryo_constants.py +0 -0
  78. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_dark.py +0 -0
  79. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_gain.py +0 -0
  80. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_instrument_polarization.py +0 -0
  81. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_linearity_correction.py +0 -0
  82. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_make_movie_frames.py +0 -0
  83. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_parameters.py +0 -0
  84. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_parse.py +0 -0
  85. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_quality.py +0 -0
  86. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_sp_beam_boundaries.py +0 -0
  87. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_sp_geometric.py +0 -0
  88. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_sp_make_movie_frames.py +0 -0
  89. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_sp_science.py +0 -0
  90. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_sp_solar.py +0 -0
  91. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_submit_qualilty.py +0 -0
  92. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_trial_output_data.py +0 -0
  93. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_workflows.py +0 -0
  94. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/tests/test_write_l1.py +0 -0
  95. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/workflows/__init__.py +0 -0
  96. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/workflows/ci_l0_processing.py +0 -0
  97. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/workflows/sp_l0_processing.py +0 -0
  98. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp/workflows/trial_workflows.py +0 -0
  99. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp.egg-info/dependency_links.txt +0 -0
  100. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp.egg-info/requires.txt +0 -0
  101. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/dkist_processing_cryonirsp.egg-info/top_level.txt +0 -0
  102. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/docs/Makefile +0 -0
  103. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/docs/changelog.rst +0 -0
  104. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/docs/conf.py +0 -0
  105. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/docs/index.rst +0 -0
  106. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/docs/l0_to_l1_cryonirsp_ci.rst +0 -0
  107. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/docs/l0_to_l1_cryonirsp_sp.rst +0 -0
  108. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/docs/make.bat +0 -0
  109. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/docs/requirements.txt +0 -0
  110. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/docs/requirements_table.rst +0 -0
  111. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/docs/scientific_changelog.rst +0 -0
  112. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/licenses/LICENSE.rst +0 -0
  113. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/pyproject.toml +0 -0
  114. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/science_towncrier.sh +0 -0
  115. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/setup.cfg +0 -0
  116. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/setup.py +0 -0
  117. {dkist_processing_cryonirsp-0.0.51rc1 → dkist_processing_cryonirsp-0.0.52rc1}/towncrier_science.toml +0 -0
@@ -1,3 +1,12 @@
1
+ v0.0.51 (2024-03-27)
2
+ ====================
3
+
4
+ Features
5
+ --------
6
+
7
+ - Wavelength range of CI data is now determined using header keys containing the filter central wavelength and full width half maximum. (`#111 <https://bitbucket.org/dkistdc/dkist-processing-cryonirsp/pull-requests/111>`__)
8
+
9
+
1
10
  v0.0.50 (2024-03-26)
2
11
  ====================
3
12
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: dkist_processing_cryonirsp
3
- Version: 0.0.51rc1
3
+ Version: 0.0.52rc1
4
4
  Summary: Science processing code for the Cryo-NIRSP instrument on DKIST
5
5
  Home-page: https://bitbucket.org/dkistdc/dkist_processing_cryonirsp/src/main/
6
6
  Author: NSO / AURA
@@ -0,0 +1 @@
1
+ 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.
@@ -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 = 160.0
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
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: dkist-processing-cryonirsp
3
- Version: 0.0.51rc1
3
+ Version: 0.0.52rc1
4
4
  Summary: Science processing code for the Cryo-NIRSP instrument on DKIST
5
5
  Home-page: https://bitbucket.org/dkistdc/dkist_processing_cryonirsp/src/main/
6
6
  Author: NSO / AURA
@@ -12,7 +12,7 @@ setup.cfg
12
12
  setup.py
13
13
  towncrier_science.toml
14
14
  changelog/.gitempty
15
- changelog/111.feature.rst
15
+ changelog/109.misc.rst
16
16
  dkist_processing_cryonirsp/__init__.py
17
17
  dkist_processing_cryonirsp.egg-info/PKG-INFO
18
18
  dkist_processing_cryonirsp.egg-info/SOURCES.txt
@@ -73,6 +73,7 @@ dkist_processing_cryonirsp/tests/test_bad_pixel_maps.py
73
73
  dkist_processing_cryonirsp/tests/test_build_quality_report.py
74
74
  dkist_processing_cryonirsp/tests/test_ci_beam_boundaries.py
75
75
  dkist_processing_cryonirsp/tests/test_ci_science.py
76
+ dkist_processing_cryonirsp/tests/test_corrections.py
76
77
  dkist_processing_cryonirsp/tests/test_cryo_base.py
77
78
  dkist_processing_cryonirsp/tests/test_cryo_constants.py
78
79
  dkist_processing_cryonirsp/tests/test_dark.py
@@ -1 +0,0 @@
1
- Wavelength range of CI data is now determined using header keys containing the filter central wavelength and full width half maximum.