imap-processing 0.6.0__py3-none-any.whl

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.
Files changed (398) hide show
  1. imap_processing/__init__.py +34 -0
  2. imap_processing/_version.py +3 -0
  3. imap_processing/ccsds/__init__.py +0 -0
  4. imap_processing/ccsds/ccsds_data.py +55 -0
  5. imap_processing/ccsds/excel_to_xtce.py +477 -0
  6. imap_processing/cdf/__init__.py +0 -0
  7. imap_processing/cdf/cdf_attribute_manager.py +322 -0
  8. imap_processing/cdf/config/imap_codice_global_cdf_attrs.yaml +212 -0
  9. imap_processing/cdf/config/imap_codice_l1a_variable_attrs.yaml +1358 -0
  10. imap_processing/cdf/config/imap_codice_l1b_variable_attrs.yaml +391 -0
  11. imap_processing/cdf/config/imap_constant_attrs.yaml +33 -0
  12. imap_processing/cdf/config/imap_default_global_cdf_attrs.yaml +17 -0
  13. imap_processing/cdf/config/imap_glows_global_cdf_attrs.yaml +41 -0
  14. imap_processing/cdf/config/imap_glows_l1a_variable_attrs.yaml +499 -0
  15. imap_processing/cdf/config/imap_glows_l1b_variable_attrs.yaml +334 -0
  16. imap_processing/cdf/config/imap_hi_global_cdf_attrs.yaml +51 -0
  17. imap_processing/cdf/config/imap_hi_variable_attrs.yaml +435 -0
  18. imap_processing/cdf/config/imap_hit_global_cdf_attrs.yaml +27 -0
  19. imap_processing/cdf/config/imap_hit_l1a_variable_attrs.yaml +493 -0
  20. imap_processing/cdf/config/imap_hit_l1b_variable_attrs.yaml +564 -0
  21. imap_processing/cdf/config/imap_idex_global_cdf_attrs.yaml +24 -0
  22. imap_processing/cdf/config/imap_idex_l1a_variable_attrs.yaml +426 -0
  23. imap_processing/cdf/config/imap_lo_global_cdf_attrs.yaml +90 -0
  24. imap_processing/cdf/config/imap_lo_l1a_variable_attrs.yaml +487 -0
  25. imap_processing/cdf/config/imap_lo_l1b_variable_attrs.yaml +121 -0
  26. imap_processing/cdf/config/imap_lo_l1c_variable_attrs.yaml +179 -0
  27. imap_processing/cdf/config/imap_mag_global_cdf_attrs.yaml +97 -0
  28. imap_processing/cdf/config/imap_mag_l1_variable_attrs.yaml +201 -0
  29. imap_processing/cdf/config/imap_swapi_global_cdf_attrs.yaml +33 -0
  30. imap_processing/cdf/config/imap_swapi_variable_attrs.yaml +137 -0
  31. imap_processing/cdf/config/imap_swe_global_cdf_attrs.yaml +24 -0
  32. imap_processing/cdf/config/imap_swe_l1a_variable_attrs.yaml +234 -0
  33. imap_processing/cdf/config/imap_swe_l1b_variable_attrs.yaml +273 -0
  34. imap_processing/cdf/config/imap_ultra_global_cdf_attrs.yaml +100 -0
  35. imap_processing/cdf/config/imap_ultra_l1a_variable_attrs.yaml +52 -0
  36. imap_processing/cdf/config/imap_ultra_l1b_variable_attrs.yaml +297 -0
  37. imap_processing/cdf/config/imap_ultra_l1c_variable_attrs.yaml +121 -0
  38. imap_processing/cdf/config/shared/default_global_cdf_attrs_schema.yaml +246 -0
  39. imap_processing/cdf/config/shared/default_variable_cdf_attrs_schema.yaml +466 -0
  40. imap_processing/cdf/imap_cdf_manager.py +64 -0
  41. imap_processing/cdf/utils.py +147 -0
  42. imap_processing/cli.py +863 -0
  43. imap_processing/codice/__init__.py +1 -0
  44. imap_processing/codice/codice_l0.py +54 -0
  45. imap_processing/codice/codice_l1a.py +558 -0
  46. imap_processing/codice/codice_l1b.py +194 -0
  47. imap_processing/codice/constants.py +986 -0
  48. imap_processing/codice/data/esa_sweep_values.csv +257 -0
  49. imap_processing/codice/data/lo_stepping_values.csv +129 -0
  50. imap_processing/codice/decompress.py +142 -0
  51. imap_processing/codice/packet_definitions/P_COD_NHK.xml +618 -0
  52. imap_processing/codice/packet_definitions/codice_packet_definition.xml +5073 -0
  53. imap_processing/codice/utils.py +95 -0
  54. imap_processing/decom.py +40 -0
  55. imap_processing/glows/__init__.py +1 -0
  56. imap_processing/glows/ancillary/l1b_conversion_table_v001.json +42 -0
  57. imap_processing/glows/l0/__init__.py +0 -0
  58. imap_processing/glows/l0/decom_glows.py +91 -0
  59. imap_processing/glows/l0/glows_l0_data.py +194 -0
  60. imap_processing/glows/l1a/glows_l1a.py +424 -0
  61. imap_processing/glows/l1a/glows_l1a_data.py +555 -0
  62. imap_processing/glows/l1b/glows_l1b.py +270 -0
  63. imap_processing/glows/l1b/glows_l1b_data.py +583 -0
  64. imap_processing/glows/packet_definitions/GLX_COMBINED.xml +254 -0
  65. imap_processing/glows/packet_definitions/P_GLX_TMSCDE.xml +97 -0
  66. imap_processing/glows/packet_definitions/P_GLX_TMSCHIST.xml +215 -0
  67. imap_processing/glows/utils/__init__.py +0 -0
  68. imap_processing/glows/utils/constants.py +105 -0
  69. imap_processing/hi/__init__.py +1 -0
  70. imap_processing/hi/l0/__init__.py +0 -0
  71. imap_processing/hi/l0/decom_hi.py +24 -0
  72. imap_processing/hi/l1a/__init__.py +0 -0
  73. imap_processing/hi/l1a/hi_l1a.py +73 -0
  74. imap_processing/hi/l1a/histogram.py +142 -0
  75. imap_processing/hi/l1a/housekeeping.py +27 -0
  76. imap_processing/hi/l1a/science_direct_event.py +341 -0
  77. imap_processing/hi/l1b/__init__.py +0 -0
  78. imap_processing/hi/l1b/hi_eng_unit_convert_table.csv +154 -0
  79. imap_processing/hi/l1b/hi_l1b.py +127 -0
  80. imap_processing/hi/l1c/__init__.py +0 -0
  81. imap_processing/hi/l1c/hi_l1c.py +228 -0
  82. imap_processing/hi/packet_definitions/__init__.py +0 -0
  83. imap_processing/hi/packet_definitions/hi_packet_definition.xml +482 -0
  84. imap_processing/hi/utils.py +27 -0
  85. imap_processing/hit/__init__.py +1 -0
  86. imap_processing/hit/l0/__init__.py +0 -0
  87. imap_processing/hit/l0/data_classes/housekeeping.py +240 -0
  88. imap_processing/hit/l0/data_classes/science_packet.py +259 -0
  89. imap_processing/hit/l0/decom_hit.py +467 -0
  90. imap_processing/hit/l0/utils/hit_base.py +57 -0
  91. imap_processing/hit/l1a/__init__.py +0 -0
  92. imap_processing/hit/l1a/hit_l1a.py +254 -0
  93. imap_processing/hit/l1b/hit_l1b.py +179 -0
  94. imap_processing/hit/packet_definitions/hit_packet_definitions.xml +1276 -0
  95. imap_processing/ialirt/__init__.py +0 -0
  96. imap_processing/ialirt/l0/__init__.py +0 -0
  97. imap_processing/ialirt/l0/process_hit.py +220 -0
  98. imap_processing/ialirt/packet_definitions/__init__.py +0 -0
  99. imap_processing/ialirt/packet_definitions/ialirt.xml +778 -0
  100. imap_processing/ialirt/packet_definitions/ialirt_hit.xml +186 -0
  101. imap_processing/idex/__init__.py +2 -0
  102. imap_processing/idex/idex_constants.py +27 -0
  103. imap_processing/idex/idex_l0.py +31 -0
  104. imap_processing/idex/idex_l1a.py +631 -0
  105. imap_processing/idex/packet_definitions/idex_packet_definition.xml +3162 -0
  106. imap_processing/lo/__init__.py +1 -0
  107. imap_processing/lo/l0/__init__.py +0 -0
  108. imap_processing/lo/l0/data_classes/science_direct_events.py +215 -0
  109. imap_processing/lo/l0/data_classes/star_sensor.py +98 -0
  110. imap_processing/lo/l0/decompression_tables/12_to_16_bit.csv +4097 -0
  111. imap_processing/lo/l0/decompression_tables/8_to_12_bit.csv +257 -0
  112. imap_processing/lo/l0/decompression_tables/8_to_16_bit.csv +257 -0
  113. imap_processing/lo/l0/decompression_tables/decompression_tables.py +75 -0
  114. imap_processing/lo/l0/lo_apid.py +15 -0
  115. imap_processing/lo/l0/lo_science.py +150 -0
  116. imap_processing/lo/l0/utils/binary_string.py +59 -0
  117. imap_processing/lo/l0/utils/bit_decompression.py +62 -0
  118. imap_processing/lo/l0/utils/lo_base.py +57 -0
  119. imap_processing/lo/l1a/__init__.py +0 -0
  120. imap_processing/lo/l1a/lo_l1a.py +157 -0
  121. imap_processing/lo/l1b/lo_l1b.py +160 -0
  122. imap_processing/lo/l1c/lo_l1c.py +180 -0
  123. imap_processing/lo/packet_definitions/lo_xtce.xml +3541 -0
  124. imap_processing/mag/__init__.py +2 -0
  125. imap_processing/mag/constants.py +108 -0
  126. imap_processing/mag/l0/decom_mag.py +170 -0
  127. imap_processing/mag/l0/mag_l0_data.py +118 -0
  128. imap_processing/mag/l1a/mag_l1a.py +317 -0
  129. imap_processing/mag/l1a/mag_l1a_data.py +1007 -0
  130. imap_processing/mag/l1b/__init__.py +0 -0
  131. imap_processing/mag/l1b/imap_calibration_mag_20240229_v01.cdf +0 -0
  132. imap_processing/mag/l1b/mag_l1b.py +125 -0
  133. imap_processing/mag/l1c/mag_l1c.py +57 -0
  134. imap_processing/mag/packet_definitions/MAG_SCI_COMBINED.xml +235 -0
  135. imap_processing/quality_flags.py +91 -0
  136. imap_processing/spice/__init__.py +1 -0
  137. imap_processing/spice/geometry.py +322 -0
  138. imap_processing/spice/kernels.py +459 -0
  139. imap_processing/spice/time.py +72 -0
  140. imap_processing/swapi/__init__.py +1 -0
  141. imap_processing/swapi/l1/__init__.py +0 -0
  142. imap_processing/swapi/l1/swapi_l1.py +685 -0
  143. imap_processing/swapi/l2/__init__.py +0 -0
  144. imap_processing/swapi/l2/swapi_l2.py +107 -0
  145. imap_processing/swapi/packet_definitions/__init__.py +0 -0
  146. imap_processing/swapi/packet_definitions/swapi_packet_definition.xml +708 -0
  147. imap_processing/swapi/swapi_utils.py +25 -0
  148. imap_processing/swe/__init__.py +1 -0
  149. imap_processing/swe/l1a/__init__.py +0 -0
  150. imap_processing/swe/l1a/swe_l1a.py +48 -0
  151. imap_processing/swe/l1a/swe_science.py +223 -0
  152. imap_processing/swe/l1b/engineering_unit_convert_table.csv +65 -0
  153. imap_processing/swe/l1b/swe_esa_lookup_table.csv +1441 -0
  154. imap_processing/swe/l1b/swe_l1b.py +49 -0
  155. imap_processing/swe/l1b/swe_l1b_science.py +557 -0
  156. imap_processing/swe/packet_definitions/__init__.py +0 -0
  157. imap_processing/swe/packet_definitions/swe_packet_definition.xml +303 -0
  158. imap_processing/swe/utils/__init__.py +0 -0
  159. imap_processing/swe/utils/swe_utils.py +9 -0
  160. imap_processing/tests/__init__.py +0 -0
  161. imap_processing/tests/ccsds/test_data/expected_output.xml +171 -0
  162. imap_processing/tests/ccsds/test_excel_to_xtce.py +285 -0
  163. imap_processing/tests/cdf/__init__.py +0 -0
  164. imap_processing/tests/cdf/imap_default_global_cdf_attrs.yaml +8 -0
  165. imap_processing/tests/cdf/shared/default_global_cdf_attrs_schema.yaml +246 -0
  166. imap_processing/tests/cdf/shared/default_variable_cdf_attrs_schema.yaml +466 -0
  167. imap_processing/tests/cdf/test_cdf_attribute_manager.py +353 -0
  168. imap_processing/tests/cdf/test_data/imap_default_global_test_cdf_attrs.yaml +7 -0
  169. imap_processing/tests/cdf/test_data/imap_instrument1_global_cdf_attrs.yaml +14 -0
  170. imap_processing/tests/cdf/test_data/imap_instrument1_level1_variable_attrs.yaml +23 -0
  171. imap_processing/tests/cdf/test_data/imap_instrument2_global_cdf_attrs.yaml +23 -0
  172. imap_processing/tests/cdf/test_data/imap_instrument2_level2_variable_attrs.yaml +30 -0
  173. imap_processing/tests/cdf/test_data/imap_test_global.yaml +26 -0
  174. imap_processing/tests/cdf/test_data/imap_test_variable.yaml +41 -0
  175. imap_processing/tests/cdf/test_imap_cdf_manager.py +62 -0
  176. imap_processing/tests/cdf/test_utils.py +109 -0
  177. imap_processing/tests/codice/__init__.py +0 -0
  178. imap_processing/tests/codice/conftest.py +56 -0
  179. imap_processing/tests/codice/data/eu_unit_lookup_table.csv +101 -0
  180. imap_processing/tests/codice/data/idle_export_eu.COD_NHK_20230822_122700 2.csv +100 -0
  181. imap_processing/tests/codice/data/idle_export_raw.COD_NHK_20230822_122700.csv +100 -0
  182. imap_processing/tests/codice/data/imap_codice_l0_hi-counters-aggregated_20240429_v001.pkts +0 -0
  183. imap_processing/tests/codice/data/imap_codice_l0_hi-counters-singles_20240429_v001.pkts +0 -0
  184. imap_processing/tests/codice/data/imap_codice_l0_hi-omni_20240429_v001.pkts +0 -0
  185. imap_processing/tests/codice/data/imap_codice_l0_hi-pha_20240429_v001.pkts +0 -0
  186. imap_processing/tests/codice/data/imap_codice_l0_hi-sectored_20240429_v001.pkts +0 -0
  187. imap_processing/tests/codice/data/imap_codice_l0_hskp_20100101_v001.pkts +0 -0
  188. imap_processing/tests/codice/data/imap_codice_l0_lo-counters-aggregated_20240429_v001.pkts +0 -0
  189. imap_processing/tests/codice/data/imap_codice_l0_lo-counters-singles_20240429_v001.pkts +0 -0
  190. imap_processing/tests/codice/data/imap_codice_l0_lo-nsw-angular_20240429_v001.pkts +0 -0
  191. imap_processing/tests/codice/data/imap_codice_l0_lo-nsw-priority_20240429_v001.pkts +0 -0
  192. imap_processing/tests/codice/data/imap_codice_l0_lo-nsw-species_20240429_v001.pkts +0 -0
  193. imap_processing/tests/codice/data/imap_codice_l0_lo-pha_20240429_v001.pkts +0 -0
  194. imap_processing/tests/codice/data/imap_codice_l0_lo-sw-angular_20240429_v001.pkts +0 -0
  195. imap_processing/tests/codice/data/imap_codice_l0_lo-sw-priority_20240429_v001.pkts +0 -0
  196. imap_processing/tests/codice/data/imap_codice_l0_lo-sw-species_20240429_v001.pkts +0 -0
  197. imap_processing/tests/codice/data/imap_codice_l1a_hi-counters-aggregated_20240429_v001.cdf +0 -0
  198. imap_processing/tests/codice/data/imap_codice_l1a_hi-counters-singles_20240429_v001.cdf +0 -0
  199. imap_processing/tests/codice/data/imap_codice_l1a_hi-omni_20240429_v001.cdf +0 -0
  200. imap_processing/tests/codice/data/imap_codice_l1a_hi-sectored_20240429_v001.cdf +0 -0
  201. imap_processing/tests/codice/data/imap_codice_l1a_hskp_20100101_v001.cdf +0 -0
  202. imap_processing/tests/codice/data/imap_codice_l1a_lo-counters-aggregated_20240429_v001.cdf +0 -0
  203. imap_processing/tests/codice/data/imap_codice_l1a_lo-counters-singles_20240429_v001.cdf +0 -0
  204. imap_processing/tests/codice/data/imap_codice_l1a_lo-nsw-angular_20240429_v001.cdf +0 -0
  205. imap_processing/tests/codice/data/imap_codice_l1a_lo-nsw-priority_20240429_v001.cdf +0 -0
  206. imap_processing/tests/codice/data/imap_codice_l1a_lo-nsw-species_20240429_v001.cdf +0 -0
  207. imap_processing/tests/codice/data/imap_codice_l1a_lo-sw-angular_20240429_v001.cdf +0 -0
  208. imap_processing/tests/codice/data/imap_codice_l1a_lo-sw-priority_20240429_v001.cdf +0 -0
  209. imap_processing/tests/codice/data/imap_codice_l1a_lo-sw-species_20240429_v001.cdf +0 -0
  210. imap_processing/tests/codice/data/imap_codice_l1b_hi-counters-aggregated_20240429_v001.cdf +0 -0
  211. imap_processing/tests/codice/data/imap_codice_l1b_hi-counters-singles_20240429_v001.cdf +0 -0
  212. imap_processing/tests/codice/data/imap_codice_l1b_hi-omni_20240429_v001.cdf +0 -0
  213. imap_processing/tests/codice/data/imap_codice_l1b_hi-sectored_20240429_v001.cdf +0 -0
  214. imap_processing/tests/codice/data/imap_codice_l1b_hskp_20100101_v001.cdf +0 -0
  215. imap_processing/tests/codice/data/imap_codice_l1b_lo-counters-aggregated_20240429_v001.cdf +0 -0
  216. imap_processing/tests/codice/data/imap_codice_l1b_lo-counters-singles_20240429_v001.cdf +0 -0
  217. imap_processing/tests/codice/data/imap_codice_l1b_lo-nsw-angular_20240429_v001.cdf +0 -0
  218. imap_processing/tests/codice/data/imap_codice_l1b_lo-nsw-priority_20240429_v001.cdf +0 -0
  219. imap_processing/tests/codice/data/imap_codice_l1b_lo-nsw-species_20240429_v001.cdf +0 -0
  220. imap_processing/tests/codice/data/imap_codice_l1b_lo-sw-angular_20240429_v001.cdf +0 -0
  221. imap_processing/tests/codice/data/imap_codice_l1b_lo-sw-priority_20240429_v001.cdf +0 -0
  222. imap_processing/tests/codice/data/imap_codice_l1b_lo-sw-species_20240429_v001.cdf +0 -0
  223. imap_processing/tests/codice/test_codice_l0.py +144 -0
  224. imap_processing/tests/codice/test_codice_l1a.py +187 -0
  225. imap_processing/tests/codice/test_codice_l1b.py +60 -0
  226. imap_processing/tests/codice/test_decompress.py +50 -0
  227. imap_processing/tests/conftest.py +372 -0
  228. imap_processing/tests/glows/direct_events_validation_data_l1a.csv +5704 -0
  229. imap_processing/tests/glows/glows_test_packet_20110921_v01.pkts +0 -0
  230. imap_processing/tests/glows/test_glows_decom.py +133 -0
  231. imap_processing/tests/glows/test_glows_l1a_cdf.py +85 -0
  232. imap_processing/tests/glows/test_glows_l1a_data.py +510 -0
  233. imap_processing/tests/glows/test_glows_l1b.py +348 -0
  234. imap_processing/tests/glows/test_glows_l1b_data.py +70 -0
  235. imap_processing/tests/hi/__init__.py +0 -0
  236. imap_processing/tests/hi/conftest.py +133 -0
  237. imap_processing/tests/hi/test_data/l0/20231030_H45_APP_NHK.bin +0 -0
  238. imap_processing/tests/hi/test_data/l0/20231030_H45_APP_NHK.csv +201 -0
  239. imap_processing/tests/hi/test_data/l0/20231030_H45_SCI_CNT.bin +0 -0
  240. imap_processing/tests/hi/test_data/l0/20231030_H45_SCI_DE.bin +0 -0
  241. imap_processing/tests/hi/test_data/l0/README.txt +54 -0
  242. imap_processing/tests/hi/test_decom.py +55 -0
  243. imap_processing/tests/hi/test_hi_l1b.py +31 -0
  244. imap_processing/tests/hi/test_hi_l1c.py +69 -0
  245. imap_processing/tests/hi/test_l1a.py +96 -0
  246. imap_processing/tests/hi/test_l1a_sci_de.py +72 -0
  247. imap_processing/tests/hi/test_utils.py +15 -0
  248. imap_processing/tests/hit/PREFLIGHT_raw_record_2023_256_15_59_04_apid1251.pkts +0 -0
  249. imap_processing/tests/hit/PREFLIGHT_raw_record_2023_256_15_59_04_apid1252.pkts +0 -0
  250. imap_processing/tests/hit/__init__.py +0 -0
  251. imap_processing/tests/hit/test_data/imap_hit_l0_hk_20100105_v001.pkts +0 -0
  252. imap_processing/tests/hit/test_data/sci_sample.ccsds +0 -0
  253. imap_processing/tests/hit/test_hit_decom.py +230 -0
  254. imap_processing/tests/hit/test_hit_l1a.py +224 -0
  255. imap_processing/tests/hit/test_hit_l1b.py +52 -0
  256. imap_processing/tests/hit/validation_data/hskp_sample_raw.csv +88 -0
  257. imap_processing/tests/ialirt/__init__.py +0 -0
  258. imap_processing/tests/ialirt/test_data/l0/IALiRT Raw Packet Telemetry.txt +33 -0
  259. imap_processing/tests/ialirt/test_data/l0/hit_ialirt_sample.ccsds +0 -0
  260. imap_processing/tests/ialirt/test_data/l0/hit_ialirt_sample.csv +1001 -0
  261. imap_processing/tests/ialirt/unit/__init__.py +0 -0
  262. imap_processing/tests/ialirt/unit/test_decom_ialirt.py +94 -0
  263. imap_processing/tests/ialirt/unit/test_process_hit.py +226 -0
  264. imap_processing/tests/idex/__init__.py +0 -0
  265. imap_processing/tests/idex/conftest.py +22 -0
  266. imap_processing/tests/idex/imap_idex_l0_raw_20230725_v001.pkts +0 -0
  267. imap_processing/tests/idex/impact_14_tof_high_data.txt +8189 -0
  268. imap_processing/tests/idex/test_idex_l0.py +45 -0
  269. imap_processing/tests/idex/test_idex_l1a.py +91 -0
  270. imap_processing/tests/lo/__init__.py +0 -0
  271. imap_processing/tests/lo/test_binary_string.py +21 -0
  272. imap_processing/tests/lo/test_bit_decompression.py +39 -0
  273. imap_processing/tests/lo/test_cdfs/imap_lo_l0_raw_20240627_v001.pkts +0 -0
  274. imap_processing/tests/lo/test_cdfs/imap_lo_l1a_de_20100101_v001.cdf +0 -0
  275. imap_processing/tests/lo/test_cdfs/imap_lo_l1a_spin_20100101_v001.cdf +0 -0
  276. imap_processing/tests/lo/test_cdfs/imap_lo_l1b_de_20100101_v001.cdf +0 -0
  277. imap_processing/tests/lo/test_lo_l1a.py +66 -0
  278. imap_processing/tests/lo/test_lo_l1b.py +74 -0
  279. imap_processing/tests/lo/test_lo_l1c.py +66 -0
  280. imap_processing/tests/lo/test_science_counts.py +41 -0
  281. imap_processing/tests/lo/test_science_direct_events.py +209 -0
  282. imap_processing/tests/lo/test_star_sensor.py +35 -0
  283. imap_processing/tests/mag/imap_mag_l1a_burst-magi_20231025_v001.cdf +0 -0
  284. imap_processing/tests/mag/mag_l0_test_data.pkts +0 -0
  285. imap_processing/tests/mag/mag_l0_test_output.csv +37 -0
  286. imap_processing/tests/mag/mag_l1_test_data.pkts +0 -0
  287. imap_processing/tests/mag/mag_l1a_test_output.csv +97 -0
  288. imap_processing/tests/mag/test_mag_decom.py +117 -0
  289. imap_processing/tests/mag/test_mag_l1a.py +856 -0
  290. imap_processing/tests/mag/test_mag_l1b.py +77 -0
  291. imap_processing/tests/mag/test_mag_l1c.py +40 -0
  292. imap_processing/tests/spice/__init__.py +0 -0
  293. imap_processing/tests/spice/test_data/imap_ena_sim_metakernel.template +4 -0
  294. imap_processing/tests/spice/test_data/imap_science_0001.tf +171 -0
  295. imap_processing/tests/spice/test_data/imap_sclk_0000.tsc +156 -0
  296. imap_processing/tests/spice/test_data/imap_sim_ck_2hr_2secsampling_with_nutation.bc +0 -0
  297. imap_processing/tests/spice/test_data/imap_simple_metakernel.template +3 -0
  298. imap_processing/tests/spice/test_data/imap_spk_demo.bsp +0 -0
  299. imap_processing/tests/spice/test_data/imap_wkcp.tf +1806 -0
  300. imap_processing/tests/spice/test_data/naif0012.tls +150 -0
  301. imap_processing/tests/spice/test_data/sim_1yr_imap_attitude.bc +0 -0
  302. imap_processing/tests/spice/test_data/sim_1yr_imap_pointing_frame.bc +0 -0
  303. imap_processing/tests/spice/test_geometry.py +214 -0
  304. imap_processing/tests/spice/test_kernels.py +272 -0
  305. imap_processing/tests/spice/test_time.py +35 -0
  306. imap_processing/tests/swapi/__init__.py +0 -0
  307. imap_processing/tests/swapi/conftest.py +16 -0
  308. imap_processing/tests/swapi/l0_data/__init__.py +0 -0
  309. imap_processing/tests/swapi/l0_data/imap_swapi_l0_raw_20231012_v001.pkts +0 -0
  310. imap_processing/tests/swapi/l0_validation_data/__init__.py +0 -0
  311. imap_processing/tests/swapi/l0_validation_data/idle_export_eu.SWP_AUT_20231012_125245.csv +124 -0
  312. imap_processing/tests/swapi/l0_validation_data/idle_export_eu.SWP_HK_20231012_125245.csv +98 -0
  313. imap_processing/tests/swapi/l0_validation_data/idle_export_eu.SWP_MG_20231012_125245.csv +9 -0
  314. imap_processing/tests/swapi/l0_validation_data/idle_export_eu.SWP_SCI_20231012_125245.csv +72 -0
  315. imap_processing/tests/swapi/l0_validation_data/idle_export_raw.SWP_AUT_20231012_125245.csv +124 -0
  316. imap_processing/tests/swapi/l0_validation_data/idle_export_raw.SWP_HK_20231012_125245.csv +98 -0
  317. imap_processing/tests/swapi/l0_validation_data/idle_export_raw.SWP_MG_20231012_125245.csv +9 -0
  318. imap_processing/tests/swapi/l0_validation_data/idle_export_raw.SWP_SCI_20231012_125245.csv +72 -0
  319. imap_processing/tests/swapi/test_swapi_decom.py +135 -0
  320. imap_processing/tests/swapi/test_swapi_l1.py +354 -0
  321. imap_processing/tests/swapi/test_swapi_l2.py +21 -0
  322. imap_processing/tests/swe/__init__.py +0 -0
  323. imap_processing/tests/swe/conftest.py +35 -0
  324. imap_processing/tests/swe/decompressed/20230927173238_4th_quarter_decompressed.csv +181 -0
  325. imap_processing/tests/swe/decompressed/20230927173253_1st_quarter_decompressed.csv +181 -0
  326. imap_processing/tests/swe/decompressed/20230927173308_2nd_quarter_decompressed.csv +181 -0
  327. imap_processing/tests/swe/decompressed/20230927173323_3rd_quarter_decompressed.csv +181 -0
  328. imap_processing/tests/swe/l0_data/2024051010_SWE_SCIENCE_packet.bin +0 -0
  329. imap_processing/tests/swe/l0_validation_data/idle_export_eu.SWE_SCIENCE_20240510_092742.csv +544 -0
  330. imap_processing/tests/swe/l0_validation_data/idle_export_raw.SWE_SCIENCE_20240510_092742.csv +363 -0
  331. imap_processing/tests/swe/test_swe_l1a.py +12 -0
  332. imap_processing/tests/swe/test_swe_l1a_science.py +129 -0
  333. imap_processing/tests/swe/test_swe_l1b.py +61 -0
  334. imap_processing/tests/swe/test_swe_l1b_science.py +65 -0
  335. imap_processing/tests/test_cli.py +229 -0
  336. imap_processing/tests/test_decom.py +66 -0
  337. imap_processing/tests/test_quality_flags.py +71 -0
  338. imap_processing/tests/test_utils.py +107 -0
  339. imap_processing/tests/ultra/__init__.py +0 -0
  340. imap_processing/tests/ultra/test_data/l0/FM45_40P_Phi28p5_BeamCal_LinearScan_phi28.50_theta-0.00_20240207T102740.CCSDS +0 -0
  341. imap_processing/tests/ultra/test_data/l0/FM45_7P_Phi0.0_BeamCal_LinearScan_phi0.04_theta-0.01_20230821T121304.CCSDS +0 -0
  342. imap_processing/tests/ultra/test_data/l0/FM45_TV_Cycle6_Hot_Ops_Front212_20240124T063837.CCSDS +0 -0
  343. imap_processing/tests/ultra/test_data/l0/Ultra45_EM_SwRI_Cal_Run7_ThetaScan_20220530T225054.CCSDS +0 -0
  344. imap_processing/tests/ultra/test_data/l0/ultra45_raw_sc_auxdata_Ultra45_EM_SwRI_Cal_Run7_ThetaScan_20220530T225054.csv +24 -0
  345. imap_processing/tests/ultra/test_data/l0/ultra45_raw_sc_enaphxtofhangimg_FM45_TV_Cycle6_Hot_Ops_Front212_20240124T063837.csv +105 -0
  346. imap_processing/tests/ultra/test_data/l0/ultra45_raw_sc_ultraimgrates_Ultra45_EM_SwRI_Cal_Run7_ThetaScan_20220530T225054.csv +24 -0
  347. imap_processing/tests/ultra/test_data/l0/ultra45_raw_sc_ultrarawimg_withFSWcalcs_FM45_40P_Phi28p5_BeamCal_LinearScan_phi2850_theta-000_20240207T102740.csv +3314 -0
  348. imap_processing/tests/ultra/test_data/l0/ultra45_raw_sc_ultrarawimgevent_FM45_7P_Phi00_BeamCal_LinearScan_phi004_theta-001_20230821T121304.csv +702 -0
  349. imap_processing/tests/ultra/unit/__init__.py +0 -0
  350. imap_processing/tests/ultra/unit/conftest.py +210 -0
  351. imap_processing/tests/ultra/unit/test_decom_apid_880.py +98 -0
  352. imap_processing/tests/ultra/unit/test_decom_apid_881.py +50 -0
  353. imap_processing/tests/ultra/unit/test_decom_apid_883.py +44 -0
  354. imap_processing/tests/ultra/unit/test_decom_apid_896.py +104 -0
  355. imap_processing/tests/ultra/unit/test_lookup_utils.py +68 -0
  356. imap_processing/tests/ultra/unit/test_ultra_l1a.py +338 -0
  357. imap_processing/tests/ultra/unit/test_ultra_l1b.py +122 -0
  358. imap_processing/tests/ultra/unit/test_ultra_l1b_annotated.py +57 -0
  359. imap_processing/tests/ultra/unit/test_ultra_l1b_extended.py +342 -0
  360. imap_processing/tests/ultra/unit/test_ultra_l1c.py +104 -0
  361. imap_processing/tests/ultra/unit/test_ultra_l1c_pset_bins.py +35 -0
  362. imap_processing/ultra/__init__.py +1 -0
  363. imap_processing/ultra/constants.py +60 -0
  364. imap_processing/ultra/l0/__init__.py +0 -0
  365. imap_processing/ultra/l0/decom_tools.py +281 -0
  366. imap_processing/ultra/l0/decom_ultra.py +278 -0
  367. imap_processing/ultra/l0/ultra_utils.py +326 -0
  368. imap_processing/ultra/l1a/__init__.py +0 -0
  369. imap_processing/ultra/l1a/ultra_l1a.py +319 -0
  370. imap_processing/ultra/l1b/badtimes.py +26 -0
  371. imap_processing/ultra/l1b/cullingmask.py +26 -0
  372. imap_processing/ultra/l1b/de.py +59 -0
  373. imap_processing/ultra/l1b/extendedspin.py +45 -0
  374. imap_processing/ultra/l1b/lookup_utils.py +165 -0
  375. imap_processing/ultra/l1b/ultra_l1b.py +65 -0
  376. imap_processing/ultra/l1b/ultra_l1b_annotated.py +54 -0
  377. imap_processing/ultra/l1b/ultra_l1b_extended.py +764 -0
  378. imap_processing/ultra/l1c/histogram.py +36 -0
  379. imap_processing/ultra/l1c/pset.py +36 -0
  380. imap_processing/ultra/l1c/ultra_l1c.py +52 -0
  381. imap_processing/ultra/l1c/ultra_l1c_pset_bins.py +54 -0
  382. imap_processing/ultra/lookup_tables/EgyNorm.mem.csv +32769 -0
  383. imap_processing/ultra/lookup_tables/FM45_Startup1_ULTRA_IMGPARAMS_20240719.csv +2 -0
  384. imap_processing/ultra/lookup_tables/ultra45_back-pos-luts.csv +4097 -0
  385. imap_processing/ultra/lookup_tables/ultra45_tdc_norm.csv +2050 -0
  386. imap_processing/ultra/lookup_tables/ultra90_back-pos-luts.csv +4097 -0
  387. imap_processing/ultra/lookup_tables/ultra90_tdc_norm.csv +2050 -0
  388. imap_processing/ultra/lookup_tables/yadjust.csv +257 -0
  389. imap_processing/ultra/packet_definitions/ULTRA_SCI_COMBINED.xml +547 -0
  390. imap_processing/ultra/packet_definitions/__init__.py +0 -0
  391. imap_processing/ultra/utils/__init__.py +0 -0
  392. imap_processing/ultra/utils/ultra_l1_utils.py +50 -0
  393. imap_processing/utils.py +413 -0
  394. imap_processing-0.6.0.dist-info/LICENSE +21 -0
  395. imap_processing-0.6.0.dist-info/METADATA +107 -0
  396. imap_processing-0.6.0.dist-info/RECORD +398 -0
  397. imap_processing-0.6.0.dist-info/WHEEL +4 -0
  398. imap_processing-0.6.0.dist-info/entry_points.txt +4 -0
@@ -0,0 +1,354 @@
1
+ import numpy as np
2
+ import pytest
3
+ import xarray as xr
4
+
5
+ from imap_processing import imap_module_directory
6
+ from imap_processing.cdf.utils import write_cdf
7
+ from imap_processing.spice.time import met_to_j2000ns
8
+ from imap_processing.swapi.l1.swapi_l1 import (
9
+ SWAPIAPID,
10
+ decompress_count,
11
+ filter_good_data,
12
+ find_sweep_starts,
13
+ get_indices_of_full_sweep,
14
+ process_swapi_science,
15
+ process_sweep_data,
16
+ swapi_l1,
17
+ )
18
+ from imap_processing.swapi.swapi_utils import SWAPIMODE
19
+ from imap_processing.utils import packet_file_to_datasets
20
+
21
+
22
+ @pytest.fixture(scope="session")
23
+ def decom_test_data(swapi_l0_test_data_path):
24
+ """Read test data from file"""
25
+ test_file = "imap_swapi_l0_raw_20231012_v001.pkts"
26
+ packet_files = imap_module_directory / swapi_l0_test_data_path / test_file
27
+ packet_definition = (
28
+ f"{imap_module_directory}/swapi/packet_definitions/swapi_packet_definition.xml"
29
+ )
30
+ return packet_file_to_datasets(
31
+ packet_files, packet_definition, use_derived_value=False
32
+ )
33
+
34
+
35
+ def test_filter_good_data():
36
+ """Test for bad data"""
37
+ # create test data for this test
38
+ total_sweeps = 3
39
+ ds = xr.Dataset(
40
+ {
41
+ "plan_id_science": xr.DataArray(np.full((total_sweeps * 12), 1)),
42
+ "sweep_table": xr.DataArray(np.repeat(np.arange(total_sweeps), 12)),
43
+ "mode": xr.DataArray(np.full((total_sweeps * 12), SWAPIMODE.HVENG.value)),
44
+ },
45
+ coords={"epoch": np.arange(total_sweeps * 12)},
46
+ )
47
+
48
+ # Check for no bad data
49
+ bad_data_indices = filter_good_data(ds)
50
+ assert len(bad_data_indices) == 36
51
+
52
+ # Check for bad MODE data, only HVENG is "good"
53
+ # TODO: update test when we update MODE from HVENG to HVSCI
54
+ ds["mode"] = xr.DataArray(
55
+ np.repeat(
56
+ [SWAPIMODE.LVENG.value, SWAPIMODE.LVSCI.value, SWAPIMODE.HVENG.value], 12
57
+ )
58
+ )
59
+ bad_data_indices = filter_good_data(ds)
60
+ np.testing.assert_array_equal(bad_data_indices, np.arange(24, 36))
61
+
62
+ # Check for bad sweep_table data.
63
+ # Reset MODE data and create first sweep to be mixed value
64
+ ds["mode"] = xr.DataArray(np.full((total_sweeps * 12), SWAPIMODE.HVENG.value))
65
+ ds["sweep_table"][:12] = np.arange(0, 12)
66
+ np.testing.assert_array_equal(filter_good_data(ds), np.arange(12, 36))
67
+
68
+ ds["sweep_table"][24:] = np.arange(0, 12)
69
+ expected = [12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23]
70
+ np.testing.assert_array_equal(filter_good_data(ds), expected)
71
+
72
+ # Check for bad plan_id_science data.
73
+ ds["sweep_table"] = xr.DataArray(np.repeat(np.arange(total_sweeps), 12))
74
+ ds["plan_id_science"][24 : total_sweeps * 12] = np.arange(0, 12)
75
+ np.testing.assert_array_equal(filter_good_data(ds), np.arange(0, 24))
76
+
77
+
78
+ def test_decompress_count():
79
+ """Test for decompress count"""
80
+ # compressed + no-overflow, compressed + overflow, no compression
81
+ raw_values = np.array([[12, 0xFFFF, 12]])
82
+ compression_flag = np.array([[1, 1, 0]])
83
+ expected = np.array([[12 * 16, np.iinfo(np.int32).max, 12]], dtype=np.int32)
84
+ returned_value = decompress_count(raw_values, compression_flag)
85
+ np.testing.assert_array_equal(returned_value, expected)
86
+
87
+
88
+ def test_find_sweep_starts():
89
+ """Test for find sweep starts"""
90
+ time = np.arange(26)
91
+ sequence_number = time % 12
92
+ ds = xr.Dataset(
93
+ {"seq_number": sequence_number, "shcoarse": np.arange(1, 27, 1)},
94
+ coords={"epoch": met_to_j2000ns(time)},
95
+ )
96
+
97
+ start_indices = find_sweep_starts(ds)
98
+ np.testing.assert_array_equal(start_indices, [0, 12])
99
+
100
+ ds["seq_number"].data[:12] = np.arange(3, 15)
101
+ start_indices = find_sweep_starts(ds)
102
+ np.testing.assert_array_equal(start_indices, [12])
103
+
104
+ # Creating test data that doesn't have start sequence.
105
+ # Sequence number range is 0-11.
106
+ ds["seq_number"] = np.arange(3, 29)
107
+ start_indices = find_sweep_starts(ds)
108
+ np.testing.assert_array_equal(start_indices, [])
109
+
110
+
111
+ def test_get_full_indices():
112
+ """Test for correct full sweep indices"""
113
+ time = np.arange(26)
114
+ sequence_number = time % 12
115
+ ds = xr.Dataset(
116
+ {"seq_number": sequence_number, "shcoarse": np.arange(1, 27, 1)},
117
+ coords={"epoch": met_to_j2000ns(time)},
118
+ )
119
+
120
+ sweep_indices = get_indices_of_full_sweep(ds)
121
+ np.testing.assert_array_equal(sweep_indices, np.arange(0, 24))
122
+
123
+
124
+ def test_swapi_algorithm(decom_test_data):
125
+ """Test SWAPI L1 algorithm"""
126
+ ds_data = decom_test_data[SWAPIAPID.SWP_SCI]
127
+ full_sweep_indices = get_indices_of_full_sweep(ds_data)
128
+ full_sweep_sci = ds_data.isel({"epoch": full_sweep_indices})
129
+ total_packets = len(full_sweep_sci["seq_number"].data)
130
+ # It takes 12 sequence data to make one full sweep
131
+ total_sequence = 12
132
+ total_full_sweeps = total_packets // total_sequence
133
+ pcem_counts = process_sweep_data(full_sweep_sci, "pcem_cnt")
134
+ # check that return value has correct shape
135
+ assert pcem_counts.shape == (total_full_sweeps, 72)
136
+ expected_count = [
137
+ 0,
138
+ 0,
139
+ 0,
140
+ 1,
141
+ 2,
142
+ 3,
143
+ 4,
144
+ 5,
145
+ 6,
146
+ 7,
147
+ 8,
148
+ 9,
149
+ 10,
150
+ 11,
151
+ 12,
152
+ 13,
153
+ 14,
154
+ 15,
155
+ 16,
156
+ 17,
157
+ 18,
158
+ 19,
159
+ 20,
160
+ 21,
161
+ 22,
162
+ 23,
163
+ 24,
164
+ 25,
165
+ 26,
166
+ 27,
167
+ 28,
168
+ 29,
169
+ 30,
170
+ 31,
171
+ 32,
172
+ 31,
173
+ 30,
174
+ 29,
175
+ 28,
176
+ 27,
177
+ 26,
178
+ 25,
179
+ 24,
180
+ 23,
181
+ 22,
182
+ 21,
183
+ 20,
184
+ 19,
185
+ 18,
186
+ 17,
187
+ 16,
188
+ 15,
189
+ 14,
190
+ 13,
191
+ 12,
192
+ 11,
193
+ 10,
194
+ 9,
195
+ 8,
196
+ 7,
197
+ 6,
198
+ 5,
199
+ 4,
200
+ 18,
201
+ 20,
202
+ 22,
203
+ 24,
204
+ 26,
205
+ 28,
206
+ 30,
207
+ 32,
208
+ 34,
209
+ ]
210
+
211
+ np.testing.assert_array_equal(pcem_counts[0], expected_count)
212
+
213
+
214
+ def test_process_swapi_science(decom_test_data):
215
+ """Test process swapi science"""
216
+ ds_data = decom_test_data[SWAPIAPID.SWP_SCI]
217
+ processed_data = process_swapi_science(
218
+ ds_data, decom_test_data[SWAPIAPID.SWP_HK], data_version="001"
219
+ )
220
+
221
+ # Test dataset dimensions
222
+ assert processed_data.sizes == {
223
+ "epoch": 3,
224
+ "energy": 72,
225
+ "energy_label": 72,
226
+ }
227
+ # Test epoch data is correct
228
+ expected_epoch_datetime = met_to_j2000ns([48, 60, 72])
229
+ np.testing.assert_array_equal(processed_data["epoch"].data, expected_epoch_datetime)
230
+
231
+ expected_count = [
232
+ 0,
233
+ 0,
234
+ 0,
235
+ 1,
236
+ 2,
237
+ 3,
238
+ 4,
239
+ 5,
240
+ 6,
241
+ 7,
242
+ 8,
243
+ 9,
244
+ 10,
245
+ 11,
246
+ 12,
247
+ 13,
248
+ 14,
249
+ 15,
250
+ 16,
251
+ 17,
252
+ 18,
253
+ 19,
254
+ 20,
255
+ 21,
256
+ 22,
257
+ 23,
258
+ 24,
259
+ 25,
260
+ 26,
261
+ 27,
262
+ 28,
263
+ 29,
264
+ 30,
265
+ 31,
266
+ 32,
267
+ 31,
268
+ 30,
269
+ 29,
270
+ 28,
271
+ 27,
272
+ 26,
273
+ 25,
274
+ 24,
275
+ 23,
276
+ 22,
277
+ 21,
278
+ 20,
279
+ 19,
280
+ 18,
281
+ 17,
282
+ 16,
283
+ 15,
284
+ 14,
285
+ 13,
286
+ 12,
287
+ 11,
288
+ 10,
289
+ 9,
290
+ 8,
291
+ 7,
292
+ 6,
293
+ 5,
294
+ 4,
295
+ 18,
296
+ 20,
297
+ 22,
298
+ 24,
299
+ 26,
300
+ 28,
301
+ 30,
302
+ 32,
303
+ 34,
304
+ ]
305
+ # Test that we got expected counts and datashape
306
+ np.testing.assert_array_equal(processed_data["swp_pcem_counts"][0], expected_count)
307
+ assert processed_data["swp_pcem_counts"].shape == (3, 72)
308
+ # Test that we calculated uncertainty correctly
309
+ np.testing.assert_allclose(
310
+ np.sqrt(processed_data["swp_pcem_counts"][0]),
311
+ processed_data["swp_pcem_err_plus"][0],
312
+ )
313
+
314
+ # make PLAN_ID data incorrect
315
+ ds_data["plan_id_science"][:12] = np.arange(12)
316
+ processed_data = process_swapi_science(
317
+ ds_data, decom_test_data[SWAPIAPID.SWP_HK], data_version="001"
318
+ )
319
+
320
+ # Test dataset dimensions
321
+ assert processed_data.sizes == {
322
+ "epoch": 2,
323
+ "energy": 72,
324
+ "energy_label": 72,
325
+ }
326
+
327
+ # Test CDF File
328
+ # This time mismatch is because of sample data. Sample data has
329
+ # SHCOARSE time as 48, 60, 72. That's why time is different.
330
+ cdf_filename = "imap_swapi_l1_sci_20100101_v001.cdf"
331
+ cdf_path = write_cdf(processed_data)
332
+ assert cdf_path.name == cdf_filename
333
+
334
+
335
+ def test_swapi_l1_cdf(swapi_l0_test_data_path):
336
+ """Test housekeeping processing and CDF file creation"""
337
+ test_packet_file = swapi_l0_test_data_path / "imap_swapi_l0_raw_20231012_v001.pkts"
338
+ processed_data = swapi_l1(test_packet_file, data_version="v001")
339
+
340
+ assert processed_data[0].attrs["Apid"] == f"{SWAPIAPID.SWP_SCI}"
341
+ assert processed_data[0].attrs["Plan_id"] == "0"
342
+ assert processed_data[0].attrs["Sweep_table"] == "0"
343
+
344
+ # Test CDF File
345
+ # sci cdf file
346
+ cdf_filename = "imap_swapi_l1_sci_20100101_v001.cdf"
347
+ cdf_path = write_cdf(processed_data[0])
348
+ assert cdf_path.name == cdf_filename
349
+
350
+ # hk cdf file
351
+ cdf_filename = "imap_swapi_l1_hk_20100101_v001.cdf"
352
+ # Ignore ISTP checks for HK data
353
+ cdf_path = write_cdf(processed_data[1], istp=False)
354
+ assert cdf_path.name == cdf_filename
@@ -0,0 +1,21 @@
1
+ import numpy as np
2
+
3
+ from imap_processing.cdf.utils import write_cdf
4
+ from imap_processing.swapi.l1.swapi_l1 import swapi_l1
5
+ from imap_processing.swapi.l2.swapi_l2 import TIME_PER_BIN, swapi_l2
6
+
7
+
8
+ def test_swapi_l2_cdf(swapi_l0_test_data_path):
9
+ """Test housekeeping processing and CDF file creation"""
10
+ l0_data_path = swapi_l0_test_data_path / "imap_swapi_l0_raw_20231012_v001.pkts"
11
+ processed_data = swapi_l1(l0_data_path, data_version="v001")
12
+ l1_dataset = processed_data[0]
13
+
14
+ l2_dataset = swapi_l2(l1_dataset, data_version="v001")
15
+ l2_cdf = write_cdf(l2_dataset)
16
+ assert l2_cdf.name == "imap_swapi_l2_sci_20100101_v001.cdf"
17
+
18
+ # Test uncertainty variables are as expected
19
+ np.testing.assert_array_equal(
20
+ l2_dataset["swp_pcem_unc_plus"], l1_dataset["swp_pcem_err_plus"] / TIME_PER_BIN
21
+ )
File without changes
@@ -0,0 +1,35 @@
1
+ import pytest
2
+
3
+ from imap_processing import imap_module_directory
4
+ from imap_processing.swe.utils.swe_utils import SWEAPID
5
+ from imap_processing.utils import packet_file_to_datasets
6
+
7
+
8
+ @pytest.fixture(scope="session")
9
+ def decom_test_data():
10
+ """Read test data from file"""
11
+ packet_file = (
12
+ imap_module_directory / "tests/swe/l0_data/2024051010_SWE_SCIENCE_packet.bin"
13
+ )
14
+ xtce_document = (
15
+ imap_module_directory / "swe/packet_definitions/swe_packet_definition.xml"
16
+ )
17
+ datasets_by_apid = packet_file_to_datasets(
18
+ packet_file, xtce_document, use_derived_value=False
19
+ )
20
+ return datasets_by_apid[SWEAPID.SWE_SCIENCE]
21
+
22
+
23
+ @pytest.fixture(scope="session")
24
+ def decom_test_data_derived():
25
+ """Read test data from file"""
26
+ packet_file = (
27
+ imap_module_directory / "tests/swe/l0_data/2024051010_SWE_SCIENCE_packet.bin"
28
+ )
29
+ xtce_document = (
30
+ imap_module_directory / "swe/packet_definitions/swe_packet_definition.xml"
31
+ )
32
+ datasets_by_apid = packet_file_to_datasets(
33
+ packet_file, xtce_document, use_derived_value=True
34
+ )
35
+ return datasets_by_apid[SWEAPID.SWE_SCIENCE]
@@ -0,0 +1,181 @@
1
+ Index,CEM 1,CEM 2,CEM 3,CEM 4,CEM 5,CEM 6,CEM 7
2
+ 0,0,40959,0,40959,0,40959,935
3
+ 1,407,407,407,407,407,407,3519
4
+ 2,407,407,407,407,407,407,263
5
+ 3,407,407,407,407,407,407,1015
6
+ 4,407,407,407,407,407,407,3775
7
+ 5,407,407,407,407,407,407,1967
8
+ 6,407,407,407,407,407,407,519
9
+ 7,407,407,407,407,407,407,139
10
+ 8,407,407,407,407,407,407,1839
11
+ 9,407,407,407,407,407,407,487
12
+ 10,407,407,407,407,407,407,131
13
+ 11,407,407,407,407,407,407,251
14
+ 12,407,407,407,407,407,407,935
15
+ 13,407,407,407,407,407,407,3519
16
+ 14,407,407,407,407,407,407,263
17
+ 15,407,407,407,407,407,407,1015
18
+ 16,407,407,407,407,407,407,3775
19
+ 17,407,407,407,407,407,407,1967
20
+ 18,407,407,407,407,407,407,519
21
+ 19,407,407,407,407,407,407,139
22
+ 20,407,407,407,407,407,407,1839
23
+ 21,407,407,407,407,407,407,487
24
+ 22,407,407,407,407,407,407,131
25
+ 23,407,407,407,407,407,407,251
26
+ 24,407,407,407,407,407,407,935
27
+ 25,407,407,407,407,407,407,3519
28
+ 26,407,407,407,407,407,407,263
29
+ 27,407,407,407,407,407,407,1015
30
+ 28,407,407,407,407,407,407,3775
31
+ 29,407,407,407,407,407,407,1967
32
+ 30,407,407,407,407,407,407,519
33
+ 31,4031,4031,4031,4031,4031,4031,139
34
+ 32,4031,4031,4031,4031,4031,4031,1839
35
+ 33,4031,4031,4031,4031,4031,4031,487
36
+ 34,4031,4031,4031,4031,4031,4031,131
37
+ 35,4031,4031,4031,4031,4031,4031,251
38
+ 36,4031,4031,4031,4031,4031,4031,935
39
+ 37,4031,4031,4031,4031,4031,4031,3519
40
+ 38,4031,4031,4031,4031,4031,4031,263
41
+ 39,4031,4031,4031,4031,4031,4031,1015
42
+ 40,4031,4031,4031,4031,4031,4031,3775
43
+ 41,4031,4031,4031,4031,4031,4031,1967
44
+ 42,4031,4031,4031,4031,4031,4031,519
45
+ 43,4031,4031,4031,4031,4031,4031,139
46
+ 44,4031,4031,4031,4031,4031,4031,1839
47
+ 45,4031,4031,4031,4031,4031,4031,487
48
+ 46,4031,4031,4031,4031,4031,4031,131
49
+ 47,4031,4031,4031,4031,4031,4031,251
50
+ 48,4031,4031,4031,4031,4031,4031,935
51
+ 49,4031,4031,4031,4031,4031,4031,3519
52
+ 50,4031,4031,4031,4031,4031,4031,263
53
+ 51,4031,4031,4031,4031,4031,4031,1015
54
+ 52,4031,4031,4031,4031,4031,4031,3775
55
+ 53,4031,4031,4031,4031,4031,4031,1967
56
+ 54,4031,4031,4031,4031,4031,4031,519
57
+ 55,4031,4031,4031,4031,4031,4031,139
58
+ 56,4031,4031,4031,4031,4031,4031,1839
59
+ 57,4031,4031,4031,4031,4031,4031,487
60
+ 58,4031,4031,4031,4031,4031,4031,131
61
+ 59,4031,4031,4031,4031,4031,4031,251
62
+ 60,4031,4031,4031,4031,4031,4031,935
63
+ 61,8063,0,8063,0,8063,0,3519
64
+ 62,8063,0,8063,0,8063,0,263
65
+ 63,8063,0,8063,0,8063,0,1015
66
+ 64,8063,0,8063,0,8063,0,3775
67
+ 65,8063,0,8063,0,8063,0,1967
68
+ 66,8063,0,8063,0,8063,0,519
69
+ 67,8063,0,8063,0,8063,0,139
70
+ 68,8063,0,8063,0,8063,0,1839
71
+ 69,8063,0,8063,0,8063,0,487
72
+ 70,8063,0,8063,0,8063,0,131
73
+ 71,8063,0,8063,0,8063,0,251
74
+ 72,8063,0,8063,0,8063,0,935
75
+ 73,8063,0,8063,0,8063,0,3519
76
+ 74,8063,0,8063,0,8063,0,263
77
+ 75,8063,0,8063,0,8063,0,1015
78
+ 76,8063,0,8063,0,8063,0,3775
79
+ 77,8063,0,8063,0,8063,0,1967
80
+ 78,8063,0,8063,0,8063,0,519
81
+ 79,8063,0,8063,0,8063,0,139
82
+ 80,8063,0,8063,0,8063,0,1839
83
+ 81,8063,0,8063,0,8063,0,487
84
+ 82,8063,0,8063,0,8063,0,131
85
+ 83,8063,0,8063,0,8063,0,251
86
+ 84,8063,0,8063,0,8063,0,935
87
+ 85,8063,0,8063,0,8063,0,3519
88
+ 86,8063,0,8063,0,8063,0,263
89
+ 87,8063,0,8063,0,8063,0,1015
90
+ 88,8063,0,8063,0,8063,0,3775
91
+ 89,8063,0,8063,0,8063,0,1967
92
+ 90,8063,0,8063,0,8063,0,519
93
+ 91,407,0,407,0,407,0,139
94
+ 92,407,0,407,0,407,0,1839
95
+ 93,407,0,407,0,407,0,487
96
+ 94,407,0,407,0,407,0,131
97
+ 95,407,0,407,0,407,0,251
98
+ 96,407,0,407,0,407,0,935
99
+ 97,407,0,407,0,407,0,3519
100
+ 98,407,0,407,0,407,0,263
101
+ 99,407,0,407,0,407,0,1015
102
+ 100,407,0,407,0,407,0,3775
103
+ 101,407,0,407,0,407,0,1967
104
+ 102,407,0,407,0,407,0,519
105
+ 103,407,0,407,0,407,0,139
106
+ 104,407,0,407,0,407,0,1839
107
+ 105,407,0,407,0,407,0,487
108
+ 106,407,0,407,0,407,0,131
109
+ 107,407,0,407,0,407,0,251
110
+ 108,407,0,407,0,407,0,935
111
+ 109,407,0,407,0,407,0,3519
112
+ 110,407,0,407,0,407,0,263
113
+ 111,407,0,407,0,407,0,1015
114
+ 112,407,0,407,0,407,0,3775
115
+ 113,407,0,407,0,407,0,1967
116
+ 114,407,0,407,0,407,0,519
117
+ 115,407,0,407,0,407,0,139
118
+ 116,407,0,407,0,407,0,1839
119
+ 117,407,0,407,0,407,0,487
120
+ 118,407,0,407,0,407,0,131
121
+ 119,407,0,407,0,407,0,251
122
+ 120,407,0,407,0,407,0,935
123
+ 121,0,19967,0,19967,0,19967,3519
124
+ 122,0,19967,0,19967,0,19967,263
125
+ 123,0,19967,0,19967,0,19967,1015
126
+ 124,0,19967,0,19967,0,19967,3775
127
+ 125,0,19967,0,19967,0,19967,1967
128
+ 126,0,19967,0,19967,0,19967,519
129
+ 127,0,19967,0,19967,0,19967,139
130
+ 128,0,19967,0,19967,0,19967,1839
131
+ 129,0,19967,0,19967,0,19967,487
132
+ 130,0,19967,0,19967,0,19967,131
133
+ 131,0,19967,0,19967,0,19967,251
134
+ 132,0,19967,0,19967,0,19967,935
135
+ 133,0,19967,0,19967,0,19967,3519
136
+ 134,0,19967,0,19967,0,19967,263
137
+ 135,0,19967,0,19967,0,19967,1015
138
+ 136,0,19967,0,19967,0,19967,3775
139
+ 137,0,19967,0,19967,0,19967,1967
140
+ 138,0,19967,0,19967,0,19967,519
141
+ 139,0,19967,0,19967,0,19967,139
142
+ 140,0,19967,0,19967,0,19967,1839
143
+ 141,0,19967,0,19967,0,19967,487
144
+ 142,0,19967,0,19967,0,19967,131
145
+ 143,0,19967,0,19967,0,19967,251
146
+ 144,0,19967,0,19967,0,19967,935
147
+ 145,0,19967,0,19967,0,19967,3519
148
+ 146,0,19967,0,19967,0,19967,263
149
+ 147,0,19967,0,19967,0,19967,1015
150
+ 148,0,19967,0,19967,0,19967,3775
151
+ 149,0,19967,0,19967,0,19967,1967
152
+ 150,0,19967,0,19967,0,19967,519
153
+ 151,0,40959,0,40959,0,40959,139
154
+ 152,0,40959,0,40959,0,40959,1839
155
+ 153,0,40959,0,40959,0,40959,487
156
+ 154,0,40959,0,40959,0,40959,131
157
+ 155,0,40959,0,40959,0,40959,251
158
+ 156,0,40959,0,40959,0,40959,935
159
+ 157,0,40959,0,40959,0,40959,3519
160
+ 158,0,40959,0,40959,0,40959,263
161
+ 159,0,40959,0,40959,0,40959,1015
162
+ 160,0,40959,0,40959,0,40959,3775
163
+ 161,0,40959,0,40959,0,40959,1967
164
+ 162,0,40959,0,40959,0,40959,519
165
+ 163,0,40959,0,40959,0,40959,139
166
+ 164,0,40959,0,40959,0,40959,1839
167
+ 165,0,40959,0,40959,0,40959,487
168
+ 166,0,40959,0,40959,0,40959,131
169
+ 167,0,40959,0,40959,0,40959,251
170
+ 168,0,40959,0,40959,0,40959,935
171
+ 169,0,40959,0,40959,0,40959,3519
172
+ 170,0,40959,0,40959,0,40959,263
173
+ 171,0,40959,0,40959,0,40959,1015
174
+ 172,0,40959,0,40959,0,40959,3775
175
+ 173,0,40959,0,40959,0,40959,1967
176
+ 174,0,40959,0,40959,0,40959,519
177
+ 175,0,40959,0,40959,0,40959,139
178
+ 176,0,40959,0,40959,0,40959,1839
179
+ 177,0,40959,0,40959,0,40959,487
180
+ 178,0,40959,0,40959,0,40959,131
181
+ 179,0,40959,0,40959,0,40959,93