cgse 2023.38.0__py3-none-any.whl → 2024.1.3__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 (653) hide show
  1. README.md +27 -0
  2. bump.py +77 -0
  3. cgse-2024.1.3.dist-info/METADATA +41 -0
  4. cgse-2024.1.3.dist-info/RECORD +5 -0
  5. {cgse-2023.38.0.dist-info → cgse-2024.1.3.dist-info}/WHEEL +1 -2
  6. cgse-2023.38.0.dist-info/COPYING +0 -674
  7. cgse-2023.38.0.dist-info/COPYING.LESSER +0 -165
  8. cgse-2023.38.0.dist-info/METADATA +0 -144
  9. cgse-2023.38.0.dist-info/RECORD +0 -649
  10. cgse-2023.38.0.dist-info/entry_points.txt +0 -75
  11. cgse-2023.38.0.dist-info/top_level.txt +0 -2
  12. egse/__init__.py +0 -12
  13. egse/__main__.py +0 -32
  14. egse/aeu/aeu.py +0 -5235
  15. egse/aeu/aeu_awg.yaml +0 -265
  16. egse/aeu/aeu_crio.yaml +0 -273
  17. egse/aeu/aeu_cs.py +0 -626
  18. egse/aeu/aeu_devif.py +0 -321
  19. egse/aeu/aeu_main_ui.py +0 -912
  20. egse/aeu/aeu_metrics.py +0 -131
  21. egse/aeu/aeu_protocol.py +0 -463
  22. egse/aeu/aeu_psu.yaml +0 -204
  23. egse/aeu/aeu_ui.py +0 -873
  24. egse/aeu/arbdata/FccdRead.arb +0 -2
  25. egse/aeu/arbdata/FccdRead_min_points.arb +0 -2
  26. egse/aeu/arbdata/HeaterSync_FccdRead.arb +0 -2
  27. egse/aeu/arbdata/HeaterSync_ccdRead25.arb +0 -2
  28. egse/aeu/arbdata/HeaterSync_ccdRead31_25.arb +0 -2
  29. egse/aeu/arbdata/HeaterSync_ccdRead37_50.arb +0 -2
  30. egse/aeu/arbdata/HeaterSync_ccdRead43_75.arb +0 -2
  31. egse/aeu/arbdata/HeaterSync_ccdRead50.arb +0 -2
  32. egse/aeu/arbdata/Heater_FccdRead_min_points.arb +0 -2
  33. egse/aeu/arbdata/ccdRead25.arb +0 -2
  34. egse/aeu/arbdata/ccdRead25_150ms.arb +0 -2
  35. egse/aeu/arbdata/ccdRead31_25.arb +0 -2
  36. egse/aeu/arbdata/ccdRead31_25_150ms.arb +0 -2
  37. egse/aeu/arbdata/ccdRead37_50.arb +0 -2
  38. egse/aeu/arbdata/ccdRead37_50_150ms.arb +0 -2
  39. egse/aeu/arbdata/ccdRead43_75.arb +0 -2
  40. egse/aeu/arbdata/ccdRead43_75_150ms.arb +0 -2
  41. egse/aeu/arbdata/ccdRead50.arb +0 -2
  42. egse/aeu/arbdata/ccdRead50_150ms.arb +0 -2
  43. egse/alert/__init__.py +0 -1049
  44. egse/alert/alertman.yaml +0 -37
  45. egse/alert/alertman_cs.py +0 -234
  46. egse/alert/alertman_ui.py +0 -603
  47. egse/alert/gsm/beaglebone.py +0 -138
  48. egse/alert/gsm/beaglebone.yaml +0 -51
  49. egse/alert/gsm/beaglebone_cs.py +0 -108
  50. egse/alert/gsm/beaglebone_devif.py +0 -130
  51. egse/alert/gsm/beaglebone_protocol.py +0 -48
  52. egse/bits.py +0 -318
  53. egse/camera.py +0 -44
  54. egse/collimator/__init__.py +0 -0
  55. egse/collimator/fcul/__init__.py +0 -0
  56. egse/collimator/fcul/ogse.py +0 -1077
  57. egse/collimator/fcul/ogse.yaml +0 -14
  58. egse/collimator/fcul/ogse_cs.py +0 -154
  59. egse/collimator/fcul/ogse_devif.py +0 -358
  60. egse/collimator/fcul/ogse_protocol.py +0 -129
  61. egse/collimator/fcul/ogse_sim.py +0 -431
  62. egse/collimator/fcul/ogse_ui.py +0 -1108
  63. egse/command.py +0 -699
  64. egse/config.py +0 -410
  65. egse/confman/__init__.py +0 -1015
  66. egse/confman/confman.yaml +0 -67
  67. egse/confman/confman_cs.py +0 -239
  68. egse/confman/confman_ui.py +0 -381
  69. egse/confman/setup_ui.py +0 -565
  70. egse/control.py +0 -442
  71. egse/coordinates/__init__.py +0 -531
  72. egse/coordinates/avoidance.py +0 -103
  73. egse/coordinates/cslmodel.py +0 -127
  74. egse/coordinates/laser_tracker_to_dict.py +0 -120
  75. egse/coordinates/point.py +0 -707
  76. egse/coordinates/pyplot.py +0 -195
  77. egse/coordinates/referenceFrame.py +0 -1279
  78. egse/coordinates/refmodel.py +0 -737
  79. egse/coordinates/rotationMatrix.py +0 -85
  80. egse/coordinates/transform3d_addon.py +0 -419
  81. egse/csl/__init__.py +0 -50
  82. egse/csl/commanding.py +0 -78
  83. egse/csl/icons/hexapod-connected-selected.svg +0 -30
  84. egse/csl/icons/hexapod-connected.svg +0 -30
  85. egse/csl/icons/hexapod-homing-selected.svg +0 -68
  86. egse/csl/icons/hexapod-homing.svg +0 -68
  87. egse/csl/icons/hexapod-retract-selected.svg +0 -56
  88. egse/csl/icons/hexapod-retract.svg +0 -51
  89. egse/csl/icons/hexapod-zero-selected.svg +0 -56
  90. egse/csl/icons/hexapod-zero.svg +0 -56
  91. egse/csl/icons/logo-puna.svg +0 -92
  92. egse/csl/icons/stop.svg +0 -1
  93. egse/csl/initialisation.py +0 -102
  94. egse/csl/mech_pos_settings.yaml +0 -18
  95. egse/das.py +0 -1247
  96. egse/das.yaml +0 -7
  97. egse/data/conf/SETUP_CSL_00000_170620_150000.yaml +0 -5
  98. egse/data/conf/SETUP_CSL_00001_170620_151010.yaml +0 -69
  99. egse/data/conf/SETUP_CSL_00002_170620_151020.yaml +0 -69
  100. egse/data/conf/SETUP_CSL_00003_170620_151030.yaml +0 -69
  101. egse/data/conf/SETUP_CSL_00004_170620_151040.yaml +0 -69
  102. egse/data/conf/SETUP_CSL_00005_170620_151050.yaml +0 -69
  103. egse/data/conf/SETUP_CSL_00006_170620_151060.yaml +0 -69
  104. egse/data/conf/SETUP_CSL_00007_170620_151070.yaml +0 -69
  105. egse/data/conf/SETUP_CSL_00008_170620_151080.yaml +0 -75
  106. egse/data/conf/SETUP_CSL_00010_210308_083016.yaml +0 -138
  107. egse/data/conf/SETUP_INTA_00000_170620_150000.yaml +0 -4
  108. egse/data/conf/SETUP_SRON_00000_170620_150000.yaml +0 -4
  109. egse/decorators.py +0 -415
  110. egse/device.py +0 -269
  111. egse/dpu/__init__.py +0 -2681
  112. egse/dpu/ccd_ui.py +0 -508
  113. egse/dpu/dpu.py +0 -786
  114. egse/dpu/dpu.yaml +0 -153
  115. egse/dpu/dpu_cs.py +0 -272
  116. egse/dpu/dpu_ui.py +0 -668
  117. egse/dpu/fitsgen.py +0 -2077
  118. egse/dpu/fitsgen_test.py +0 -752
  119. egse/dpu/fitsgen_ui.py +0 -399
  120. egse/dpu/hdf5_model.py +0 -332
  121. egse/dpu/hdf5_ui.py +0 -277
  122. egse/dpu/hdf5_viewer.py +0 -506
  123. egse/dpu/hk_ui.py +0 -468
  124. egse/dpu_commands.py +0 -81
  125. egse/dsi/constants.py +0 -220
  126. egse/dsi/esl.py +0 -870
  127. egse/dsi/rmap.py +0 -1042
  128. egse/dsi/rmapci.py +0 -37
  129. egse/dsi/spw.py +0 -154
  130. egse/dsi/spw_state.py +0 -29
  131. egse/dummy.py +0 -258
  132. egse/dyndummy.py +0 -179
  133. egse/env.py +0 -278
  134. egse/exceptions.py +0 -88
  135. egse/fdir/__init__.py +0 -28
  136. egse/fdir/fdir_manager.py +0 -85
  137. egse/fdir/fdir_manager.yaml +0 -51
  138. egse/fdir/fdir_manager_controller.py +0 -228
  139. egse/fdir/fdir_manager_cs.py +0 -164
  140. egse/fdir/fdir_manager_interface.py +0 -25
  141. egse/fdir/fdir_remote.py +0 -73
  142. egse/fdir/fdir_remote.yaml +0 -37
  143. egse/fdir/fdir_remote_controller.py +0 -50
  144. egse/fdir/fdir_remote_cs.py +0 -97
  145. egse/fdir/fdir_remote_interface.py +0 -14
  146. egse/fdir/fdir_remote_popup.py +0 -31
  147. egse/fee/__init__.py +0 -114
  148. egse/fee/f_fee_register.yaml +0 -43
  149. egse/fee/fee.py +0 -631
  150. egse/fee/feesim.py +0 -750
  151. egse/fee/n_fee_hk.py +0 -761
  152. egse/fee/nfee.py +0 -187
  153. egse/filterwheel/__init__.py +0 -4
  154. egse/filterwheel/eksma/__init__.py +0 -24
  155. egse/filterwheel/eksma/fw8smc4.py +0 -661
  156. egse/filterwheel/eksma/fw8smc4.yaml +0 -121
  157. egse/filterwheel/eksma/fw8smc4_cs.py +0 -144
  158. egse/filterwheel/eksma/fw8smc4_devif.py +0 -473
  159. egse/filterwheel/eksma/fw8smc4_protocol.py +0 -81
  160. egse/filterwheel/eksma/fw8smc4_ui.py +0 -940
  161. egse/filterwheel/eksma/fw8smc5.py +0 -111
  162. egse/filterwheel/eksma/fw8smc5.yaml +0 -105
  163. egse/filterwheel/eksma/fw8smc5_controller.py +0 -307
  164. egse/filterwheel/eksma/fw8smc5_cs.py +0 -141
  165. egse/filterwheel/eksma/fw8smc5_interface.py +0 -65
  166. egse/filterwheel/eksma/fw8smc5_simulator.py +0 -29
  167. egse/filterwheel/eksma/fw8smc5_ui.py +0 -1068
  168. egse/filterwheel/eksma/testpythonfw.py +0 -215
  169. egse/fov/__init__.py +0 -65
  170. egse/fov/fov_hk.py +0 -712
  171. egse/fov/fov_ui.py +0 -861
  172. egse/fov/fov_ui_controller.py +0 -140
  173. egse/fov/fov_ui_model.py +0 -200
  174. egse/fov/fov_ui_view.py +0 -345
  175. egse/gimbal/__init__.py +0 -32
  176. egse/gimbal/symetrie/__init__.py +0 -26
  177. egse/gimbal/symetrie/alpha.py +0 -586
  178. egse/gimbal/symetrie/generic_gimbal_ui.py +0 -1521
  179. egse/gimbal/symetrie/gimbal.py +0 -877
  180. egse/gimbal/symetrie/gimbal.yaml +0 -168
  181. egse/gimbal/symetrie/gimbal_cs.py +0 -183
  182. egse/gimbal/symetrie/gimbal_protocol.py +0 -135
  183. egse/gimbal/symetrie/gimbal_ui.py +0 -361
  184. egse/gimbal/symetrie/pmac.py +0 -1006
  185. egse/gimbal/symetrie/pmac_regex.py +0 -83
  186. egse/graph.py +0 -132
  187. egse/gui/__init__.py +0 -47
  188. egse/gui/buttons.py +0 -378
  189. egse/gui/focalplane.py +0 -1281
  190. egse/gui/formatter.py +0 -10
  191. egse/gui/led.py +0 -162
  192. egse/gui/limitswitch.py +0 -143
  193. egse/gui/mechanisms.py +0 -588
  194. egse/gui/states.py +0 -148
  195. egse/gui/stripchart.py +0 -729
  196. egse/gui/switch.py +0 -112
  197. egse/h5.py +0 -274
  198. egse/help/__init__.py +0 -0
  199. egse/help/help_ui.py +0 -126
  200. egse/hexapod/__init__.py +0 -32
  201. egse/hexapod/symetrie/__init__.py +0 -138
  202. egse/hexapod/symetrie/alpha.py +0 -874
  203. egse/hexapod/symetrie/dynalpha.py +0 -1387
  204. egse/hexapod/symetrie/hexapod_ui.py +0 -1516
  205. egse/hexapod/symetrie/pmac.py +0 -1010
  206. egse/hexapod/symetrie/pmac_regex.py +0 -83
  207. egse/hexapod/symetrie/puna.py +0 -1167
  208. egse/hexapod/symetrie/puna.yaml +0 -193
  209. egse/hexapod/symetrie/puna_cs.py +0 -196
  210. egse/hexapod/symetrie/puna_protocol.py +0 -131
  211. egse/hexapod/symetrie/puna_ui.py +0 -434
  212. egse/hexapod/symetrie/punaplus.py +0 -107
  213. egse/hexapod/symetrie/zonda.py +0 -872
  214. egse/hexapod/symetrie/zonda.yaml +0 -337
  215. egse/hexapod/symetrie/zonda_cs.py +0 -172
  216. egse/hexapod/symetrie/zonda_devif.py +0 -415
  217. egse/hexapod/symetrie/zonda_protocol.py +0 -119
  218. egse/hexapod/symetrie/zonda_ui.py +0 -449
  219. egse/hk.py +0 -765
  220. egse/icons/aeu-cs-start.svg +0 -117
  221. egse/icons/aeu-cs-stop.svg +0 -118
  222. egse/icons/aeu-cs.svg +0 -107
  223. egse/icons/aeu_cs-started.svg +0 -112
  224. egse/icons/aeu_cs-stopped.svg +0 -112
  225. egse/icons/aeu_cs.svg +0 -55
  226. egse/icons/alert.svg +0 -1
  227. egse/icons/arrow-double-left.png +0 -0
  228. egse/icons/arrow-double-right.png +0 -0
  229. egse/icons/arrow-up.svg +0 -11
  230. egse/icons/backward.svg +0 -1
  231. egse/icons/busy.svg +0 -1
  232. egse/icons/cleaning.svg +0 -115
  233. egse/icons/color-scheme.svg +0 -1
  234. egse/icons/cs-connected-alert.svg +0 -91
  235. egse/icons/cs-connected-disabled.svg +0 -43
  236. egse/icons/cs-connected.svg +0 -89
  237. egse/icons/cs-not-connected.svg +0 -44
  238. egse/icons/double-left-arrow.svg +0 -1
  239. egse/icons/double-right-arrow.svg +0 -1
  240. egse/icons/erase-disabled.svg +0 -19
  241. egse/icons/erase.svg +0 -59
  242. egse/icons/fitsgen-start.svg +0 -47
  243. egse/icons/fitsgen-stop.svg +0 -48
  244. egse/icons/fitsgen.svg +0 -1
  245. egse/icons/forward.svg +0 -1
  246. egse/icons/fov-hk-start.svg +0 -33
  247. egse/icons/fov-hk-stop.svg +0 -37
  248. egse/icons/fov-hk.svg +0 -1
  249. egse/icons/front-desk.svg +0 -1
  250. egse/icons/home-actioned.svg +0 -15
  251. egse/icons/home-disabled.svg +0 -15
  252. egse/icons/home.svg +0 -13
  253. egse/icons/info.svg +0 -1
  254. egse/icons/invalid.png +0 -0
  255. egse/icons/led-green.svg +0 -20
  256. egse/icons/led-grey.svg +0 -20
  257. egse/icons/led-orange.svg +0 -20
  258. egse/icons/led-red.svg +0 -20
  259. egse/icons/led-square-green.svg +0 -134
  260. egse/icons/led-square-grey.svg +0 -134
  261. egse/icons/led-square-orange.svg +0 -134
  262. egse/icons/led-square-red.svg +0 -134
  263. egse/icons/limit-switch-all-green.svg +0 -115
  264. egse/icons/limit-switch-all-red.svg +0 -117
  265. egse/icons/limit-switch-el+.svg +0 -116
  266. egse/icons/limit-switch-el-.svg +0 -117
  267. egse/icons/location-marker.svg +0 -1
  268. egse/icons/logo-dpu.svg +0 -48
  269. egse/icons/logo-gimbal.svg +0 -112
  270. egse/icons/logo-huber.svg +0 -23
  271. egse/icons/logo-ogse.svg +0 -31
  272. egse/icons/logo-puna.svg +0 -92
  273. egse/icons/logo-tcs.svg +0 -29
  274. egse/icons/logo-zonda.svg +0 -66
  275. egse/icons/maximize.svg +0 -1
  276. egse/icons/meter.svg +0 -1
  277. egse/icons/more.svg +0 -45
  278. egse/icons/n-fee-hk-start.svg +0 -24
  279. egse/icons/n-fee-hk-stop.svg +0 -25
  280. egse/icons/n-fee-hk.svg +0 -83
  281. egse/icons/observing-off.svg +0 -46
  282. egse/icons/observing-on.svg +0 -46
  283. egse/icons/open-document-hdf5.png +0 -0
  284. egse/icons/open-document-hdf5.svg +0 -21
  285. egse/icons/ops-mode.svg +0 -1
  286. egse/icons/play-green.svg +0 -17
  287. egse/icons/plugged-disabled.svg +0 -27
  288. egse/icons/plugged.svg +0 -21
  289. egse/icons/pm_ui.svg +0 -1
  290. egse/icons/power-button-green.svg +0 -27
  291. egse/icons/power-button-red.svg +0 -27
  292. egse/icons/power-button.svg +0 -27
  293. egse/icons/radar.svg +0 -1
  294. egse/icons/radioactive.svg +0 -2
  295. egse/icons/reload.svg +0 -1
  296. egse/icons/remote-control-off.svg +0 -28
  297. egse/icons/remote-control-on.svg +0 -28
  298. egse/icons/repeat-blue.svg +0 -15
  299. egse/icons/repeat.svg +0 -1
  300. egse/icons/settings.svg +0 -1
  301. egse/icons/shrink.svg +0 -1
  302. egse/icons/shutter.svg +0 -1
  303. egse/icons/sign-off.svg +0 -1
  304. egse/icons/sign-on.svg +0 -1
  305. egse/icons/sim-mode.svg +0 -1
  306. egse/icons/small-buttons-go.svg +0 -20
  307. egse/icons/small-buttons-minus.svg +0 -51
  308. egse/icons/small-buttons-plus.svg +0 -51
  309. egse/icons/sponge.svg +0 -220
  310. egse/icons/start-button-disabled.svg +0 -84
  311. egse/icons/start-button.svg +0 -50
  312. egse/icons/stop-button-disabled.svg +0 -84
  313. egse/icons/stop-button.svg +0 -50
  314. egse/icons/stop-red.svg +0 -17
  315. egse/icons/stop.svg +0 -1
  316. egse/icons/switch-disabled-square.svg +0 -87
  317. egse/icons/switch-disabled.svg +0 -15
  318. egse/icons/switch-off-square.svg +0 -87
  319. egse/icons/switch-off.svg +0 -72
  320. egse/icons/switch-on-square.svg +0 -87
  321. egse/icons/switch-on.svg +0 -61
  322. egse/icons/temperature-control.svg +0 -44
  323. egse/icons/th_ui_logo.svg +0 -1
  324. egse/icons/unplugged.svg +0 -23
  325. egse/icons/unvalid.png +0 -0
  326. egse/icons/user-interface.svg +0 -1
  327. egse/icons/vacuum.svg +0 -1
  328. egse/icons/valid.png +0 -0
  329. egse/icons/zoom-to-pixel-dark.svg +0 -64
  330. egse/icons/zoom-to-pixel-white.svg +0 -36
  331. egse/images/big-rotation-stage.png +0 -0
  332. egse/images/connected-100.png +0 -0
  333. egse/images/cross.svg +0 -6
  334. egse/images/disconnected-100.png +0 -0
  335. egse/images/gui-icon.png +0 -0
  336. egse/images/home.svg +0 -6
  337. egse/images/info-icon.png +0 -0
  338. egse/images/led-black.svg +0 -89
  339. egse/images/led-green.svg +0 -85
  340. egse/images/led-orange.svg +0 -85
  341. egse/images/led-red.svg +0 -85
  342. egse/images/load-icon.png +0 -0
  343. egse/images/load-setup.png +0 -0
  344. egse/images/load.png +0 -0
  345. egse/images/pause.png +0 -0
  346. egse/images/play-button.svg +0 -8
  347. egse/images/play.png +0 -0
  348. egse/images/process-status.png +0 -0
  349. egse/images/restart.png +0 -0
  350. egse/images/search.png +0 -0
  351. egse/images/sma.png +0 -0
  352. egse/images/start.png +0 -0
  353. egse/images/stop-button.svg +0 -8
  354. egse/images/stop.png +0 -0
  355. egse/images/switch-off.svg +0 -48
  356. egse/images/switch-on.svg +0 -48
  357. egse/images/undo.png +0 -0
  358. egse/images/update-button.svg +0 -11
  359. egse/imageviewer/exposureselection.py +0 -475
  360. egse/imageviewer/imageviewer.py +0 -198
  361. egse/imageviewer/matchfocalplane.py +0 -179
  362. egse/imageviewer/subfieldposition.py +0 -133
  363. egse/lampcontrol/__init__.py +0 -4
  364. egse/lampcontrol/beaglebone/beaglebone.py +0 -178
  365. egse/lampcontrol/beaglebone/beaglebone.yaml +0 -62
  366. egse/lampcontrol/beaglebone/beaglebone_cs.py +0 -106
  367. egse/lampcontrol/beaglebone/beaglebone_devif.py +0 -150
  368. egse/lampcontrol/beaglebone/beaglebone_protocol.py +0 -73
  369. egse/lampcontrol/energetiq/__init__.py +0 -22
  370. egse/lampcontrol/energetiq/eq99.yaml +0 -98
  371. egse/lampcontrol/energetiq/lampEQ99.py +0 -283
  372. egse/lampcontrol/energetiq/lampEQ99_cs.py +0 -128
  373. egse/lampcontrol/energetiq/lampEQ99_devif.py +0 -158
  374. egse/lampcontrol/energetiq/lampEQ99_encode_decode_errors.py +0 -73
  375. egse/lampcontrol/energetiq/lampEQ99_protocol.py +0 -69
  376. egse/lampcontrol/energetiq/lampEQ99_ui.py +0 -465
  377. egse/lib/CentOS-7/EtherSpaceLink_v34_86.dylib +0 -0
  378. egse/lib/CentOS-8/ESL-RMAP_v34_86.dylib +0 -0
  379. egse/lib/CentOS-8/EtherSpaceLink_v34_86.dylib +0 -0
  380. egse/lib/Debian/ESL-RMAP_v34_86.dylib +0 -0
  381. egse/lib/Debian/EtherSpaceLink_v34_86.dylib +0 -0
  382. egse/lib/Debian/libetherspacelink_v35_21.dylib +0 -0
  383. egse/lib/Linux/ESL-RMAP_v34_86.dylib +0 -0
  384. egse/lib/Linux/EtherSpaceLink_v34_86.dylib +0 -0
  385. egse/lib/Ubuntu-20/ESL-RMAP_v34_86.dylib +0 -0
  386. egse/lib/Ubuntu-20/EtherSpaceLink_v34_86.dylib +0 -0
  387. egse/lib/gssw/python3-gssw_2.2.3+31f63c9f-1_all.deb +0 -0
  388. egse/lib/macOS/ESL-RMAP_v34_86.dylib +0 -0
  389. egse/lib/macOS/EtherSpaceLink_v34_86.dylib +0 -0
  390. egse/lib/ximc/__pycache__/pyximc.cpython-38 2.pyc +0 -0
  391. egse/lib/ximc/__pycache__/pyximc.cpython-38.pyc +0 -0
  392. egse/lib/ximc/libximc.framework/Frameworks/libbindy.dylib +0 -0
  393. egse/lib/ximc/libximc.framework/Frameworks/libxiwrapper.dylib +0 -0
  394. egse/lib/ximc/libximc.framework/Headers/ximc.h +0 -5510
  395. egse/lib/ximc/libximc.framework/Resources/Info.plist +0 -42
  396. egse/lib/ximc/libximc.framework/Resources/keyfile.sqlite +0 -0
  397. egse/lib/ximc/libximc.framework/libbindy.so +0 -0
  398. egse/lib/ximc/libximc.framework/libximc +0 -0
  399. egse/lib/ximc/libximc.framework/libximc.so +0 -0
  400. egse/lib/ximc/libximc.framework/libximc.so.7.0.0 +0 -0
  401. egse/lib/ximc/libximc.framework/libxiwrapper.so +0 -0
  402. egse/lib/ximc/pyximc.py +0 -922
  403. egse/listener.py +0 -73
  404. egse/logger/__init__.py +0 -243
  405. egse/logger/log_cs.py +0 -321
  406. egse/metrics.py +0 -98
  407. egse/mixin.py +0 -464
  408. egse/monitoring.py +0 -95
  409. egse/ni/alarms/__init__.py +0 -26
  410. egse/ni/alarms/cdaq9375.py +0 -300
  411. egse/ni/alarms/cdaq9375.yaml +0 -89
  412. egse/ni/alarms/cdaq9375_cs.py +0 -130
  413. egse/ni/alarms/cdaq9375_devif.py +0 -183
  414. egse/ni/alarms/cdaq9375_protocol.py +0 -48
  415. egse/obs_inspection.py +0 -163
  416. egse/observer.py +0 -41
  417. egse/obsid.py +0 -163
  418. egse/powermeter/__init__.py +0 -0
  419. egse/powermeter/ni/__init__.py +0 -38
  420. egse/powermeter/ni/cdaq9184.py +0 -224
  421. egse/powermeter/ni/cdaq9184.yaml +0 -73
  422. egse/powermeter/ni/cdaq9184_cs.py +0 -130
  423. egse/powermeter/ni/cdaq9184_devif.py +0 -201
  424. egse/powermeter/ni/cdaq9184_protocol.py +0 -48
  425. egse/powermeter/ni/cdaq9184_ui.py +0 -544
  426. egse/powermeter/thorlabs/__init__.py +0 -25
  427. egse/powermeter/thorlabs/pm100a.py +0 -380
  428. egse/powermeter/thorlabs/pm100a.yaml +0 -132
  429. egse/powermeter/thorlabs/pm100a_cs.py +0 -136
  430. egse/powermeter/thorlabs/pm100a_devif.py +0 -127
  431. egse/powermeter/thorlabs/pm100a_protocol.py +0 -80
  432. egse/powermeter/thorlabs/pm100a_ui.py +0 -725
  433. egse/process.py +0 -451
  434. egse/procman/__init__.py +0 -811
  435. egse/procman/cannot_start_process_popup.py +0 -43
  436. egse/procman/procman.yaml +0 -49
  437. egse/procman/procman_cs.py +0 -201
  438. egse/procman/procman_ui.py +0 -2081
  439. egse/protocol.py +0 -603
  440. egse/proxy.py +0 -522
  441. egse/randomwalk.py +0 -140
  442. egse/reg.py +0 -585
  443. egse/reload.py +0 -122
  444. egse/reprocess.py +0 -675
  445. egse/resource.py +0 -333
  446. egse/rst.py +0 -135
  447. egse/search.py +0 -182
  448. egse/serialdevice.py +0 -190
  449. egse/services.py +0 -212
  450. egse/services.yaml +0 -51
  451. egse/settings.py +0 -379
  452. egse/settings.yaml +0 -980
  453. egse/setup.py +0 -1180
  454. egse/shutter/__init__.py +0 -0
  455. egse/shutter/thorlabs/__init__.py +0 -19
  456. egse/shutter/thorlabs/ksc101.py +0 -205
  457. egse/shutter/thorlabs/ksc101.yaml +0 -105
  458. egse/shutter/thorlabs/ksc101_cs.py +0 -136
  459. egse/shutter/thorlabs/ksc101_devif.py +0 -201
  460. egse/shutter/thorlabs/ksc101_protocol.py +0 -69
  461. egse/shutter/thorlabs/ksc101_ui.py +0 -548
  462. egse/shutter/thorlabs/sc10.py +0 -82
  463. egse/shutter/thorlabs/sc10.yaml +0 -52
  464. egse/shutter/thorlabs/sc10_controller.py +0 -81
  465. egse/shutter/thorlabs/sc10_cs.py +0 -108
  466. egse/shutter/thorlabs/sc10_interface.py +0 -25
  467. egse/shutter/thorlabs/sc10_simulator.py +0 -30
  468. egse/simulator.py +0 -41
  469. egse/slack.py +0 -61
  470. egse/socketdevice.py +0 -218
  471. egse/sockets.py +0 -218
  472. egse/spw.py +0 -1479
  473. egse/stages/__init__.py +0 -12
  474. egse/stages/aerotech/ensemble.py +0 -247
  475. egse/stages/aerotech/ensemble.yaml +0 -205
  476. egse/stages/aerotech/ensemble_controller.py +0 -275
  477. egse/stages/aerotech/ensemble_cs.py +0 -110
  478. egse/stages/aerotech/ensemble_interface.py +0 -132
  479. egse/stages/aerotech/ensemble_parameters.py +0 -433
  480. egse/stages/aerotech/ensemble_simulator.py +0 -27
  481. egse/stages/aerotech/mgse_sim.py +0 -193
  482. egse/stages/arun/smd3.py +0 -111
  483. egse/stages/arun/smd3.yaml +0 -68
  484. egse/stages/arun/smd3_controller.py +0 -472
  485. egse/stages/arun/smd3_cs.py +0 -112
  486. egse/stages/arun/smd3_interface.py +0 -53
  487. egse/stages/arun/smd3_simulator.py +0 -27
  488. egse/stages/arun/smd3_stop.py +0 -16
  489. egse/stages/huber/__init__.py +0 -49
  490. egse/stages/huber/smc9300.py +0 -904
  491. egse/stages/huber/smc9300.yaml +0 -63
  492. egse/stages/huber/smc9300_cs.py +0 -178
  493. egse/stages/huber/smc9300_devif.py +0 -345
  494. egse/stages/huber/smc9300_protocol.py +0 -111
  495. egse/stages/huber/smc9300_sim.py +0 -547
  496. egse/stages/huber/smc9300_ui.py +0 -973
  497. egse/state.py +0 -173
  498. egse/statemachine.py +0 -274
  499. egse/storage/__init__.py +0 -1004
  500. egse/storage/persistence.py +0 -2295
  501. egse/storage/storage.yaml +0 -72
  502. egse/storage/storage_cs.py +0 -214
  503. egse/styles/dark.qss +0 -343
  504. egse/styles/default.qss +0 -48
  505. egse/synoptics/__init__.py +0 -412
  506. egse/synoptics/syn.yaml +0 -9
  507. egse/synoptics/syn_cs.py +0 -195
  508. egse/system.py +0 -1408
  509. egse/tcs/__init__.py +0 -14
  510. egse/tcs/tcs.py +0 -874
  511. egse/tcs/tcs.yaml +0 -14
  512. egse/tcs/tcs_cs.py +0 -202
  513. egse/tcs/tcs_devif.py +0 -292
  514. egse/tcs/tcs_protocol.py +0 -177
  515. egse/tcs/tcs_sim.py +0 -177
  516. egse/tcs/tcs_ui.py +0 -543
  517. egse/tdms.py +0 -171
  518. egse/tempcontrol/__init__.py +0 -23
  519. egse/tempcontrol/agilent/agilent34970.py +0 -109
  520. egse/tempcontrol/agilent/agilent34970.yaml +0 -44
  521. egse/tempcontrol/agilent/agilent34970_cs.py +0 -116
  522. egse/tempcontrol/agilent/agilent34970_devif.py +0 -182
  523. egse/tempcontrol/agilent/agilent34970_protocol.py +0 -99
  524. egse/tempcontrol/agilent/agilent34972.py +0 -111
  525. egse/tempcontrol/agilent/agilent34972.yaml +0 -44
  526. egse/tempcontrol/agilent/agilent34972_cs.py +0 -117
  527. egse/tempcontrol/agilent/agilent34972_devif.py +0 -189
  528. egse/tempcontrol/agilent/agilent34972_protocol.py +0 -101
  529. egse/tempcontrol/beaglebone/beaglebone.py +0 -342
  530. egse/tempcontrol/beaglebone/beaglebone.yaml +0 -110
  531. egse/tempcontrol/beaglebone/beaglebone_cs.py +0 -117
  532. egse/tempcontrol/beaglebone/beaglebone_protocol.py +0 -135
  533. egse/tempcontrol/beaglebone/beaglebone_ui.py +0 -681
  534. egse/tempcontrol/digalox/digalox.py +0 -107
  535. egse/tempcontrol/digalox/digalox.yaml +0 -36
  536. egse/tempcontrol/digalox/digalox_cs.py +0 -112
  537. egse/tempcontrol/digalox/digalox_protocol.py +0 -55
  538. egse/tempcontrol/keithley/__init__.py +0 -33
  539. egse/tempcontrol/keithley/daq6510.py +0 -662
  540. egse/tempcontrol/keithley/daq6510.yaml +0 -105
  541. egse/tempcontrol/keithley/daq6510_cs.py +0 -163
  542. egse/tempcontrol/keithley/daq6510_devif.py +0 -343
  543. egse/tempcontrol/keithley/daq6510_protocol.py +0 -78
  544. egse/tempcontrol/keithley/daq6510_sim.py +0 -186
  545. egse/tempcontrol/lakeshore/__init__.py +0 -33
  546. egse/tempcontrol/lakeshore/lsci.py +0 -361
  547. egse/tempcontrol/lakeshore/lsci.yaml +0 -162
  548. egse/tempcontrol/lakeshore/lsci_cs.py +0 -174
  549. egse/tempcontrol/lakeshore/lsci_devif.py +0 -292
  550. egse/tempcontrol/lakeshore/lsci_protocol.py +0 -73
  551. egse/tempcontrol/lakeshore/lsci_ui.py +0 -389
  552. egse/tempcontrol/ni/__init__.py +0 -0
  553. egse/tempcontrol/spid/spid.py +0 -109
  554. egse/tempcontrol/spid/spid.yaml +0 -81
  555. egse/tempcontrol/spid/spid_controller.py +0 -279
  556. egse/tempcontrol/spid/spid_cs.py +0 -136
  557. egse/tempcontrol/spid/spid_protocol.py +0 -107
  558. egse/tempcontrol/spid/spid_ui.py +0 -727
  559. egse/tempcontrol/srs/__init__.py +0 -22
  560. egse/tempcontrol/srs/ptc10.py +0 -875
  561. egse/tempcontrol/srs/ptc10.yaml +0 -227
  562. egse/tempcontrol/srs/ptc10_cs.py +0 -128
  563. egse/tempcontrol/srs/ptc10_devif.py +0 -118
  564. egse/tempcontrol/srs/ptc10_protocol.py +0 -42
  565. egse/tempcontrol/srs/ptc10_ui.py +0 -906
  566. egse/ups/apc/apc.py +0 -236
  567. egse/ups/apc/apc.yaml +0 -45
  568. egse/ups/apc/apc_cs.py +0 -101
  569. egse/ups/apc/apc_protocol.py +0 -125
  570. egse/user.yaml +0 -7
  571. egse/vacuum/beaglebone/beaglebone.py +0 -149
  572. egse/vacuum/beaglebone/beaglebone.yaml +0 -44
  573. egse/vacuum/beaglebone/beaglebone_cs.py +0 -108
  574. egse/vacuum/beaglebone/beaglebone_devif.py +0 -164
  575. egse/vacuum/beaglebone/beaglebone_protocol.py +0 -193
  576. egse/vacuum/beaglebone/beaglebone_ui.py +0 -638
  577. egse/vacuum/instrutech/igm402.py +0 -92
  578. egse/vacuum/instrutech/igm402.yaml +0 -90
  579. egse/vacuum/instrutech/igm402_controller.py +0 -128
  580. egse/vacuum/instrutech/igm402_cs.py +0 -108
  581. egse/vacuum/instrutech/igm402_interface.py +0 -49
  582. egse/vacuum/instrutech/igm402_simulator.py +0 -36
  583. egse/vacuum/keller/kellerBus.py +0 -256
  584. egse/vacuum/keller/leo3.py +0 -102
  585. egse/vacuum/keller/leo3.yaml +0 -38
  586. egse/vacuum/keller/leo3_controller.py +0 -83
  587. egse/vacuum/keller/leo3_cs.py +0 -101
  588. egse/vacuum/keller/leo3_interface.py +0 -33
  589. egse/vacuum/mks/evision.py +0 -86
  590. egse/vacuum/mks/evision.yaml +0 -75
  591. egse/vacuum/mks/evision_cs.py +0 -101
  592. egse/vacuum/mks/evision_devif.py +0 -316
  593. egse/vacuum/mks/evision_interface.py +0 -60
  594. egse/vacuum/mks/evision_simulator.py +0 -24
  595. egse/vacuum/mks/evision_ui.py +0 -704
  596. egse/vacuum/pfeiffer/acp40.py +0 -87
  597. egse/vacuum/pfeiffer/acp40.yaml +0 -60
  598. egse/vacuum/pfeiffer/acp40_controller.py +0 -117
  599. egse/vacuum/pfeiffer/acp40_cs.py +0 -109
  600. egse/vacuum/pfeiffer/acp40_interface.py +0 -40
  601. egse/vacuum/pfeiffer/acp40_simulator.py +0 -39
  602. egse/vacuum/pfeiffer/tc400.py +0 -113
  603. egse/vacuum/pfeiffer/tc400.yaml +0 -83
  604. egse/vacuum/pfeiffer/tc400_controller.py +0 -140
  605. egse/vacuum/pfeiffer/tc400_cs.py +0 -109
  606. egse/vacuum/pfeiffer/tc400_interface.py +0 -70
  607. egse/vacuum/pfeiffer/tc400_simulator.py +0 -24
  608. egse/vacuum/pfeiffer/tpg261.py +0 -81
  609. egse/vacuum/pfeiffer/tpg261.yaml +0 -66
  610. egse/vacuum/pfeiffer/tpg261_controller.py +0 -150
  611. egse/vacuum/pfeiffer/tpg261_cs.py +0 -109
  612. egse/vacuum/pfeiffer/tpg261_interface.py +0 -60
  613. egse/vacuum/pfeiffer/tpg261_simulator.py +0 -24
  614. egse/version.py +0 -174
  615. egse/visitedpositions.py +0 -398
  616. egse/windowing.py +0 -213
  617. egse/zmq/__init__.py +0 -28
  618. egse/zmq/spw.py +0 -160
  619. egse/zmq_ser.py +0 -41
  620. scripts/alerts/cold.yaml +0 -278
  621. scripts/alerts/example_alerts.yaml +0 -54
  622. scripts/alerts/transition.yaml +0 -14
  623. scripts/alerts/warm.yaml +0 -49
  624. scripts/analyse_n_fee_hk_data.py +0 -44
  625. scripts/check_hdf5_files.py +0 -192
  626. scripts/check_register_sync.py +0 -47
  627. scripts/create_hdf5_report.py +0 -295
  628. scripts/csl_model.py +0 -436
  629. scripts/csl_restore_setup.py +0 -230
  630. scripts/export-grafana-dashboards.py +0 -50
  631. scripts/fdir/cs_recovery/fdir_cs_recovery.py +0 -59
  632. scripts/fdir/fdir_table.yaml +0 -70
  633. scripts/fdir/fdir_test_recovery.py +0 -11
  634. scripts/fdir/hw_recovery/fdir_agilent_hw_recovery.py +0 -73
  635. scripts/fdir/limit_recovery/fdir_agilent_limit.py +0 -64
  636. scripts/fdir/limit_recovery/fdir_bb_heater_limit.py +0 -61
  637. scripts/fdir/limit_recovery/fdir_ensemble_limit.py +0 -33
  638. scripts/fdir/limit_recovery/fdir_pressure_limit_recovery.py +0 -71
  639. scripts/fix_csv.py +0 -80
  640. scripts/n_fee_supply_voltage_calculation.py +0 -92
  641. scripts/playground.py +0 -30
  642. scripts/print_hdf5_hk_data.py +0 -68
  643. scripts/print_register_map.py +0 -43
  644. scripts/sron/commanding/control_heaters.py +0 -44
  645. scripts/sron/commanding/pumpdown.py +0 -46
  646. scripts/sron/commanding/set_pid_setpoint.py +0 -19
  647. scripts/sron/commanding/shutdown_bbb_heaters.py +0 -10
  648. scripts/sron/commanding/shutdown_pumps.py +0 -33
  649. scripts/sron/tm_gen/tm_gen_agilent.py +0 -38
  650. scripts/sron/tm_gen/tm_gen_heaters.py +0 -4
  651. scripts/sron/tm_gen/tm_gen_spid.py +0 -13
  652. scripts/update_operational_cgse.py +0 -268
  653. scripts/update_operational_cgse_old.py +0 -273
@@ -1,192 +0,0 @@
1
- import glob
2
- import logging
3
- from pathlib import Path
4
- from typing import Optional
5
- from typing import Union
6
-
7
- import click
8
- import rich
9
- from h5py import File
10
- from rich.progress import track
11
-
12
- from egse import h5
13
- from egse.bits import beautify_binary
14
- from egse.fee import n_fee_mode
15
- from egse.fee.nfee import HousekeepingData
16
- from egse.reg import RegisterMap
17
- from egse.spw import SpaceWirePacket
18
-
19
- MODULE_LOGGER = logging.getLogger("egse.check_hdf5_file")
20
-
21
-
22
- def check_if_top_level_groups_complete(hdf5_file: File, indent: str) -> (str, bool):
23
-
24
- msg = ""
25
- error = False
26
-
27
- # Check for internal or external sync
28
-
29
- if "/register" in hdf5_file:
30
- reg_data = h5.get_data(hdf5_file["/register"])
31
- reg_map = RegisterMap("N-FEE", memory_map=reg_data)
32
- sync_sel = reg_map["sync_sel"]
33
- if sync_sel and ("/1" in hdf5_file or "/2" in hdf5_file or "/3" in hdf5_file):
34
- msg += indent + (
35
- "[bold red]ERROR[/]: internal sync contains more than one readout period\n")
36
- error = True
37
- if not sync_sel and (
38
- missing := [idx for idx in range(4) if f"/{idx}" not in hdf5_file]
39
- ):
40
- msg += indent + f"[bold red]ERROR[/]: missing readouts for external sync {missing}\n"
41
- error = True
42
-
43
- return msg, error
44
-
45
-
46
- def check_hdf5_file(filename: Union[str, Path], requested_obsid: Union[int, str], error_flags_only=False, errors_only=False):
47
-
48
- filename = Path(filename)
49
-
50
- if filename.exists():
51
- try:
52
-
53
- with h5.get_file(filename, mode='r') as hdf5_file:
54
-
55
- has_error = False
56
- indent = " "
57
- full_msg = f"Analysing {filename!s}\n"
58
- full_msg += indent + f"Top level groups: {list(hdf5_file.keys())}\n"
59
- error_msg = ""
60
- obsid = ''
61
-
62
- msg, error = check_if_top_level_groups_complete(hdf5_file, indent)
63
- full_msg += msg
64
- has_error = error or has_error
65
-
66
- if "/obsid" in hdf5_file:
67
- obsid = h5.get_data(hdf5_file["/obsid"]).item().decode()
68
- if obsid == 'None':
69
- full_msg += indent + "no observation running\n"
70
- else:
71
- full_msg += indent + f"OBSID = {obsid}\n"
72
-
73
- if requested_obsid is not None and str(requested_obsid) not in obsid:
74
- return
75
-
76
- if "/0/timecode" in hdf5_file:
77
- timecode = h5.get_data(hdf5_file["/0/timecode"])
78
- timestamp = h5.get_attribute_value(hdf5_file["/0/timecode"], "timestamp")
79
- full_msg += indent + f"{timecode=!s}, {timestamp=}\n"
80
-
81
- if "/register" in hdf5_file:
82
- reg_data = h5.get_data(hdf5_file["/register"])
83
- reg_map = RegisterMap("N-FEE", memory_map=reg_data)
84
- v_start = reg_map['v_start']
85
- v_end = reg_map['v_end']
86
- digitise_en = reg_map['digitise_en']
87
- dg_en = reg_map['DG_en']
88
- sync_sel = reg_map['sync_sel']
89
- try:
90
- mode = n_fee_mode(reg_map['ccd_mode_config']).name
91
- except ValueError:
92
- mode = f"[bold red]INVALID ({reg_map['ccd_mode_config']})[/]"
93
- has_error = True
94
- full_msg += indent + f"register: {v_start=}, {v_end=}, {digitise_en=}, {dg_en=}, {sync_sel=}, {mode=}\n"
95
- else:
96
- full_msg += indent + '[red]no register map in this HDF5 file[/red]\n'
97
- has_error = True
98
-
99
- if "/0/data" in hdf5_file and h5.has_attributes(hdf5_file['/0/data']):
100
- v_start = h5.get_attribute_value(hdf5_file['/0/data'], "v_start")
101
- v_end = h5.get_attribute_value(hdf5_file['/0/data'], "v_end")
102
- full_msg += indent + f"data: {v_start=}, {v_end=}\n"
103
-
104
- for count in range(4):
105
- if f"/{count}/hk" in hdf5_file:
106
- hk_packet = SpaceWirePacket.create_packet(hdf5_file[f"/{count}/hk"][...])
107
- full_msg += indent + f"hk: {hk_packet.type} {beautify_binary(hk_packet.type.value)}\n"
108
- error_flags = HousekeepingData(hk_packet.data)['error_flags']
109
- if error_flags:
110
- msg = indent + (
111
- f"Frame {count}: [red]One or more of the error flags are ON: "
112
- f"{beautify_binary(error_flags, group=4, size=12)}[/red]\n"
113
- )
114
- full_msg += msg
115
- error_msg += msg
116
- has_error = True
117
- for count in range(4):
118
- if f"/{count}/commands" in hdf5_file:
119
- for idx in hdf5_file[f"/{count}/commands/"]:
120
- full_msg += indent + f"command in frame {count}: {h5.get_data(hdf5_file[f'/{count}/commands/{idx}'])}\n"
121
-
122
- if error_flags_only and error_msg:
123
- rich.print(f"{filename.name=}, size={filename.stat().st_size}")
124
- rich.print(error_msg)
125
- if not error_flags_only:
126
- if errors_only and has_error:
127
- rich.print(full_msg)
128
- if not errors_only:
129
- rich.print(full_msg)
130
-
131
- except OSError as exc:
132
- rich.print(f"{filename=!s}, {exc}")
133
- else:
134
- rich.print(f"no such file {filename!s}")
135
-
136
-
137
- def find_hdf5_for_obsid(files: list, requested_obsid: Union[int, str]):
138
- new_files = []
139
-
140
- for filename in sorted(files):
141
- try:
142
- with h5.get_file(filename, mode='r') as hdf5_file:
143
- if "/obsid" in hdf5_file:
144
- obsid = h5.get_data(hdf5_file["/obsid"]).item().decode()
145
-
146
- if str(requested_obsid) in obsid:
147
- new_files.append(filename)
148
- except OSError as exc:
149
- MODULE_LOGGER.error(f"Couldn't open {filename} ({exc=})")
150
- return new_files
151
-
152
-
153
- @click.command()
154
- @click.argument('root')
155
- @click.argument('filename_t')
156
- @click.option("--obsid", help="The full OBSID, e.g. SRON_00058_02380 or only the TEST-ID, e.g. 2380")
157
- @click.option("--error-flags-only", is_flag=True, help="Print only the filename and error information")
158
- @click.option("--errors-only", is_flag=True, help="Print only the filename and error information")
159
- def cli(obsid, error_flags_only, errors_only, root, filename_t):
160
- """Script to inspect the HDF5 files generated by the DPU Processor.
161
-
162
- * ROOT - the root folder that contains the HDF5 files to be checked
163
-
164
- * FILENAME_T - a file name template accepted by glob()
165
- """
166
- root = Path(root)
167
-
168
- files = glob.glob(str(root / filename_t))
169
- if obsid is not None:
170
- files = find_hdf5_for_obsid(files, obsid)
171
- n_files = len(files)
172
-
173
- rich.print(f"Number of files: {n_files}")
174
-
175
- print(" ".join([Path(file).name for file in files]))
176
-
177
- answer = input("So, you want to continue [Y/n]")
178
- print(answer)
179
- if answer.lower() in ['n', 'no']:
180
- return
181
-
182
- for filename in track(sorted(files), description=f"Checking {n_files} files"):
183
- # for filename in sorted(files):
184
- try:
185
- check_hdf5_file(filename, obsid, error_flags_only, errors_only)
186
- except Exception as exc:
187
- rich.print(f"[red]ERROR[/]: {Path(filename).name}: {exc!s}")
188
- MODULE_LOGGER.debug(f"{exc!s}", exc_info=True)
189
-
190
-
191
- if __name__ == "__main__":
192
- cli()
@@ -1,47 +0,0 @@
1
- """
2
- This module contains commands and strategies to test the synchronisation of the Register Map
3
- between the DPU Processor and the N-FEE.
4
-
5
- The reason for this test is that the DPU Processor seems to be out of sync with the N-FEE at some
6
- points in time:
7
-
8
- * When the N-FEE is power-cycled and the DPU CS is not restarted, the register map is not
9
- refreshed from the newly pwoered N-FEE
10
-
11
- * ...
12
-
13
- The DPU CS has a few commands available to fix this:
14
-
15
- * dpu.n_fee_sync_register_map() — reads the register map from the N-FEE, updates the DPU internal
16
- register map and returns the register map.
17
-
18
- * dpu.reset() — sets a special register in the N-FEE ccd_mode_config which commands the N-FEE to
19
- resets its register map to its default state.
20
-
21
- """
22
-
23
- from egse.dpu import DPUProxy
24
- from egse.reg import compare_register_maps
25
-
26
- dpu_proxy = DPUProxy()
27
-
28
-
29
- reg_1 = dpu_proxy.n_fee_sync_register_map()
30
-
31
- # Put the N-FEE in DUMP mode
32
-
33
- dpu_proxy.n_fee_set_dump_mode(
34
- dict(v_start=0, v_end=2000, ccd_readout_order=0b11111111, n_final_dump=4510))
35
-
36
- reg_2 = dpu_proxy.n_fee_sync_register_map()
37
-
38
- # Put the N-FEE back into its default mode (same as after a power cycle?)
39
-
40
- dpu_proxy.n_fee_reset()
41
-
42
- reg_3 = dpu_proxy.n_fee_sync_register_map()
43
-
44
-
45
- compare_register_maps(reg_1, reg_2)
46
- compare_register_maps(reg_2, reg_3)
47
- compare_register_maps(reg_1, reg_3)
@@ -1,295 +0,0 @@
1
- #! /usr/bin/env python3
2
-
3
- import glob
4
- import logging
5
- import os
6
- from datetime import datetime
7
- from enum import IntEnum
8
- from pathlib import Path
9
- from typing import List
10
-
11
- import click
12
- import pandas as pd
13
- from pandas import DataFrame
14
- from rich import print
15
- from rich.console import Console
16
- from rich.progress import track
17
- from rich.table import Table
18
-
19
- from egse import h5
20
- from egse.setup import load_setup
21
- from egse.bits import beautify_binary
22
- from egse.fee import convert_ccd_order_value
23
- from egse.fee import n_fee_mode
24
- from egse.fee.nfee import HousekeepingData
25
- from egse.reg import RegisterMap
26
- from egse.spw import SpaceWirePacket
27
- from egse.storage.persistence import CSV2
28
-
29
- MODULE_LOGGER = logging.getLogger("egse.create_hdf5_report")
30
-
31
- df_awg2: DataFrame
32
- """Holds the AEU AWG2 HK data to determine external sync period."""
33
-
34
- sync_mode = {0: 'ext', 1: 'int'}
35
- """Decodes N-FEE internal or external sync mode."""
36
-
37
- reg_map = RegisterMap("N-FEE")
38
- """Holds the register map of the N-FEE."""
39
-
40
- setup = load_setup()
41
- sensor_sel = setup.camera.fee.sensor_sel.enum
42
- """Decodes N-FEE E-side and F-side information."""
43
-
44
- def load_aeu_awg2_data(location: Path):
45
- try:
46
- awg_fn = glob.glob(str(location / '*_AEU-AWG2.csv'))[0]
47
- except IndexError as exc:
48
- raise FileNotFoundError(
49
- "The AEU AWG2 CSV file is not found, cannot determine correct external sync period."
50
- ) from exc
51
-
52
- print(f"Loading {awg_fn}...")
53
- converters = {
54
- "timestamp": lambda x: datetime.strptime(x, "%Y-%m-%dT%H:%M:%S.%f+0000"),
55
- }
56
- return pd.read_csv(location / awg_fn, index_col="timestamp", converters=converters)
57
-
58
-
59
- def get_external_sync_period(timestamp: str):
60
- if timestamp == 'N/A':
61
- return float('nan')
62
- dt = datetime.strptime(timestamp, "%Y-%m-%dT%H:%M:%S.%f+0000")
63
- try:
64
- idx = df_awg2.index.get_loc(dt, method="nearest")
65
- except AttributeError:
66
- return 0.0
67
- return df_awg2.iloc[idx]['GAEU_EXT_CYCLE_TIME']
68
-
69
-
70
- def extract_register_values(filename: Path):
71
- with h5.get_file(filename, mode='r', locking=False) as hdf5_file:
72
-
73
- if "/obsid" in hdf5_file:
74
- obsid = h5.get_data(hdf5_file["/obsid"]).item().decode()
75
- else:
76
- obsid = ''
77
-
78
- if "/0/timecode" in hdf5_file:
79
- timecode = h5.get_data(hdf5_file["/0/timecode"])
80
- timestamp = h5.get_attribute_value(hdf5_file["/0/timecode"], "timestamp")
81
- else:
82
- timestamp = 'N/A'
83
-
84
- if "/register" not in hdf5_file:
85
- raise RuntimeError(f'no register map in this HDF5 file ({filename.name})')
86
-
87
- reg_data = h5.get_data(hdf5_file["/register"])
88
- reg_map.set_data(0x0000_0000, bytearray(reg_data.tobytes()), 0x800)
89
- v_start = reg_map['v_start']
90
- v_end = reg_map['v_end']
91
- digitise_en = reg_map['digitise_en']
92
- dg_en = reg_map['DG_en']
93
- n_final_dump = reg_map['n_final_dump']
94
- sync_sel = sync_mode[reg_map['sync_sel']]
95
- if sync_sel == 'ext':
96
- sync_period = get_external_sync_period(timestamp)
97
- n_frames = 4
98
- else:
99
- sync_period = reg_map['int_sync_period'] / 1000.0
100
- n_frames = 1
101
- sensor = sensor_sel(reg_map['sensor_sel']).name
102
- ccd_readout_order = convert_ccd_order_value(reg_map['ccd_readout_order'])
103
-
104
- charge_injection_en = reg_map['charge_injection_en'] or ''
105
- charge_inject_width = reg_map['charge_injection_width'] if charge_injection_en else ''
106
- charge_inject_gap = reg_map['charge_injection_gap'] if charge_injection_en else ''
107
-
108
- ccd_vgd_config_19 = reg_map[('reg_19_config', 'ccd_vgd_config')]
109
- ccd_vgd_config_20 = reg_map[('reg_20_config', 'ccd_vgd_config')]
110
- ccd_vgd_config = (ccd_vgd_config_20 << 4) + ccd_vgd_config_19
111
-
112
- try:
113
- mode = n_fee_mode(reg_map['ccd_mode_config']).name
114
- except ValueError:
115
- mode = f"[bold red]INVALID ({reg_map['ccd_mode_config']})[/]"
116
-
117
- has_error_flags = ''
118
- all_error_flags_value = [0, 0, 0, 0]
119
- all_error_flags_str = [" "*5, " "*5, " "*5, " "*5]
120
-
121
- for count in range(n_frames):
122
- if f"/{count}/hk_data" in hdf5_file:
123
- hk_data = hdf5_file[f"/{count}/hk_data"][...]
124
- elif f"/{count}/hk" in hdf5_file:
125
- hk_packet = SpaceWirePacket.create_packet(hdf5_file[f"/{count}/hk"][...])
126
- hk_data = hk_packet.data
127
- else:
128
- continue
129
- if error_flags := HousekeepingData(hk_data)['error_flags']:
130
- all_error_flags_value[count] = error_flags
131
- # error_flags = beautify_binary(error_flags, group=4, size=12)
132
- error_flags = f"0x{error_flags:03X}"
133
- all_error_flags_str[count] = error_flags
134
- has_error_flags = 'x'
135
-
136
- # Since Rich Table cannot render a List, convert it to a string
137
- all_error_flags_str = ", ".join(all_error_flags_str) if has_error_flags else ''
138
-
139
- return (
140
- obsid,
141
- timestamp[:19],
142
- filename.name,
143
- str(v_start),
144
- str(v_end),
145
- str(n_final_dump),
146
- str(digitise_en),
147
- str(dg_en),
148
- sync_sel,
149
- f"{sync_period:.3f}",
150
- mode,
151
- sensor,
152
- str(ccd_readout_order),
153
- str(charge_injection_en),
154
- str(charge_inject_width),
155
- str(charge_inject_gap),
156
- hex(ccd_vgd_config),
157
- str(all_error_flags_value),
158
- all_error_flags_str,
159
- has_error_flags,
160
- )
161
-
162
-
163
- @click.command()
164
- @click.argument('location')
165
- @click.option('--output-file', '-o', help="full path name for the report file")
166
- @click.option('--csv-format', is_flag=True, help="output format in CVS instead of TXT")
167
- def cli(location, output_file, csv_format):
168
- """
169
- Script to extract parameter values from the register map in the HDF5 files that are
170
- generated by the DPU Processor.
171
-
172
- * location - the folder that contains the HDF5 files to be checked
173
-
174
- """
175
- global df_awg2
176
-
177
- location = Path(location)
178
- output_file = output_file or ("report.csv" if csv_format else "report.txt")
179
-
180
- files = glob.glob(str(location / '*_SPW_*.hdf5'))
181
- n_files = len(files)
182
-
183
- # Read the AEU AWG2 data file to determine the external sync period
184
-
185
- try:
186
- df_awg2 = load_aeu_awg2_data(location)
187
- except FileNotFoundError:
188
- df_awg2 = None
189
-
190
- # Extract all the parameters from the HDF5 register map
191
-
192
- data = []
193
- errors = []
194
-
195
- print(f"Number of files: {n_files}")
196
-
197
- for filename in track(sorted(files), description=f"Extracting register from {n_files} files"):
198
- # for filename in sorted(files):
199
- try:
200
- row = extract_register_values(Path(filename))
201
- data.append(list(row))
202
- if row[-1] == 'x': # the last element is the has_error_flags, the first is the OBSID
203
- errors.append(row[0])
204
- except Exception as exc:
205
- print(f"[red]ERROR[/]: {Path(filename).name}: {exc!s}")
206
- MODULE_LOGGER.error(f"{exc!s}", exc_info=True)
207
-
208
- if csv_format:
209
- print_csv(output_file, data, errors)
210
- else:
211
- print_table(output_file, data, errors)
212
-
213
- def exclude_items(*indices):
214
- """
215
- Returns a function that excludes the items of its operand at the given indices and returns a tuple
216
- containing the other elements of the operand using the `__getitem__` method of the operand.
217
-
218
- Args:
219
- *indices: indices of items that shall be excluded, can be a negative index also.
220
-
221
- """
222
- def func(obj):
223
- size = len(obj)
224
- pos_indices = [idx if idx > 0 else size + idx for idx in indices]
225
- return tuple(obj[idx] for idx in range(size) if idx not in pos_indices)
226
- return func
227
-
228
- def print_csv(output_file: str, data: List, errors: List):
229
- header = [
230
- "obsid",
231
- "timestamp",
232
- "HDF5 filename",
233
- "v_start",
234
- "v_end",
235
- "n_final_dump",
236
- "digitise",
237
- "DG",
238
- "sync",
239
- "sync period",
240
- "mode",
241
- "sensor",
242
- "CCD order",
243
- "CI",
244
- "CI width",
245
- "CI gap",
246
- "VGD",
247
- "error_flags",
248
- ]
249
-
250
- prep = {"column_names": header, "mode": 'w', "quote_char": '\"'}
251
- with CSV2(output_file, prep=prep) as csv:
252
- for row in data:
253
- csv.create(row[:-2]) # remove last two values, i.e. all_error_flags_str and has_error_flags
254
-
255
-
256
- def print_table(output_file: str, data: List, errors: List):
257
- table = Table(title="HDF5 & Register Map", min_width=180)
258
-
259
- table.add_column("obsid")
260
- table.add_column("timestamp", width=20)
261
- table.add_column("HDF5 filename", no_wrap=True)
262
- table.add_column("v_start", justify="right")
263
- table.add_column("v_end", justify="right")
264
- table.add_column("n_final_dump", justify="right")
265
- table.add_column("digitise", justify="right")
266
- table.add_column("DG", justify="right")
267
- table.add_column("sync")
268
- table.add_column("sync period")
269
- table.add_column("mode")
270
- table.add_column("sensor")
271
- table.add_column("CCD order")
272
- table.add_column("CI")
273
- table.add_column("CI width")
274
- table.add_column("CI gap")
275
- table.add_column("VGD")
276
- table.add_column("error_flags")
277
-
278
- # We don't need the error_flags-by-value, we need the error_flags-by-str/bin
279
- # and, do not use the last element which is the has_error_flags. So, all rows
280
- # should exclude element -3 and -1
281
- snip = exclude_items(-1, -3)
282
-
283
- for row in data:
284
- table.add_row(*snip(row))
285
-
286
- with Console().status("Saving report...", spinner='clock'):
287
- with open(output_file, "wt") as report_file:
288
- console = Console(file=report_file, width=300)
289
- if errors:
290
- console.print(f"Observations with N-FEE errors: {', '.join(set(errors))}")
291
- console.print(table)
292
-
293
-
294
- if __name__ == "__main__":
295
- cli()