cgse 2024.7.0__py3-none-any.whl → 2025.0.1__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 (664) hide show
  1. README.md +27 -0
  2. bump.py +85 -0
  3. cgse-2025.0.1.dist-info/METADATA +38 -0
  4. cgse-2025.0.1.dist-info/RECORD +5 -0
  5. {cgse-2024.7.0.dist-info → cgse-2025.0.1.dist-info}/WHEEL +1 -2
  6. cgse-2024.7.0.dist-info/COPYING +0 -674
  7. cgse-2024.7.0.dist-info/COPYING.LESSER +0 -165
  8. cgse-2024.7.0.dist-info/METADATA +0 -144
  9. cgse-2024.7.0.dist-info/RECORD +0 -660
  10. cgse-2024.7.0.dist-info/entry_points.txt +0 -75
  11. cgse-2024.7.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 -5238
  15. egse/aeu/aeu_awg.yaml +0 -265
  16. egse/aeu/aeu_crio.yaml +0 -273
  17. egse/aeu/aeu_cs.py +0 -627
  18. egse/aeu/aeu_devif.py +0 -321
  19. egse/aeu/aeu_main_ui.py +0 -903
  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 -233
  46. egse/alert/alertman_ui.py +0 -600
  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 -122
  51. egse/alert/gsm/beaglebone_protocol.py +0 -46
  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 -132
  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 -1058
  66. egse/confman/confman.yaml +0 -70
  67. egse/confman/confman_cs.py +0 -240
  68. egse/confman/confman_ui.py +0 -381
  69. egse/confman/setup_ui.py +0 -565
  70. egse/control.py +0 -632
  71. egse/coordinates/__init__.py +0 -534
  72. egse/coordinates/avoidance.py +0 -100
  73. egse/coordinates/cslmodel.py +0 -127
  74. egse/coordinates/laser_tracker_to_dict.py +0 -122
  75. egse/coordinates/point.py +0 -707
  76. egse/coordinates/pyplot.py +0 -194
  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 -1240
  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 -514
  110. egse/device.py +0 -269
  111. egse/dpu/__init__.py +0 -2698
  112. egse/dpu/ccd_ui.py +0 -514
  113. egse/dpu/dpu.py +0 -783
  114. egse/dpu/dpu.yaml +0 -153
  115. egse/dpu/dpu_cs.py +0 -272
  116. egse/dpu/dpu_ui.py +0 -671
  117. egse/dpu/fitsgen.py +0 -2096
  118. egse/dpu/fitsgen_ui.py +0 -399
  119. egse/dpu/hdf5_model.py +0 -332
  120. egse/dpu/hdf5_ui.py +0 -277
  121. egse/dpu/hdf5_viewer.py +0 -506
  122. egse/dpu/hk_ui.py +0 -468
  123. egse/dpu_commands.py +0 -81
  124. egse/dsi/__init__.py +0 -33
  125. egse/dsi/_libesl.py +0 -232
  126. egse/dsi/constants.py +0 -296
  127. egse/dsi/esl.py +0 -630
  128. egse/dsi/rmap.py +0 -444
  129. egse/dsi/rmapci.py +0 -39
  130. egse/dsi/spw.py +0 -335
  131. egse/dsi/spw_state.py +0 -29
  132. egse/dummy.py +0 -318
  133. egse/dyndummy.py +0 -179
  134. egse/env.py +0 -278
  135. egse/exceptions.py +0 -88
  136. egse/fdir/__init__.py +0 -26
  137. egse/fdir/fdir_manager.py +0 -85
  138. egse/fdir/fdir_manager.yaml +0 -37
  139. egse/fdir/fdir_manager_controller.py +0 -136
  140. egse/fdir/fdir_manager_cs.py +0 -164
  141. egse/fdir/fdir_manager_interface.py +0 -15
  142. egse/fdir/fdir_remote.py +0 -73
  143. egse/fdir/fdir_remote.yaml +0 -30
  144. egse/fdir/fdir_remote_controller.py +0 -30
  145. egse/fdir/fdir_remote_cs.py +0 -94
  146. egse/fdir/fdir_remote_interface.py +0 -9
  147. egse/fdir/fdir_remote_popup.py +0 -26
  148. egse/fee/__init__.py +0 -106
  149. egse/fee/f_fee_register.yaml +0 -43
  150. egse/fee/feesim.py +0 -914
  151. egse/fee/n_fee_hk.py +0 -768
  152. egse/fee/nfee.py +0 -188
  153. egse/filterwheel/__init__.py +0 -4
  154. egse/filterwheel/eksma/__init__.py +0 -49
  155. egse/filterwheel/eksma/fw8smc4.py +0 -657
  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 -82
  160. egse/filterwheel/eksma/fw8smc4_ui.py +0 -940
  161. egse/filterwheel/eksma/fw8smc5.py +0 -115
  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 -1065
  168. egse/filterwheel/eksma/testpythonfw.py +0 -215
  169. egse/fov/__init__.py +0 -65
  170. egse/fov/fov_hk.py +0 -710
  171. egse/fov/fov_ui.py +0 -859
  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 -138
  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 -1285
  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 -587
  194. egse/gui/states.py +0 -148
  195. egse/gui/stripchart.py +0 -729
  196. egse/gui/styles.qss +0 -48
  197. egse/gui/switch.py +0 -112
  198. egse/h5.py +0 -274
  199. egse/help/__init__.py +0 -0
  200. egse/help/help_ui.py +0 -126
  201. egse/hexapod/__init__.py +0 -32
  202. egse/hexapod/symetrie/__init__.py +0 -137
  203. egse/hexapod/symetrie/alpha.py +0 -874
  204. egse/hexapod/symetrie/dynalpha.py +0 -1387
  205. egse/hexapod/symetrie/hexapod_ui.py +0 -1516
  206. egse/hexapod/symetrie/pmac.py +0 -1010
  207. egse/hexapod/symetrie/pmac_regex.py +0 -83
  208. egse/hexapod/symetrie/puna.py +0 -1167
  209. egse/hexapod/symetrie/puna.yaml +0 -193
  210. egse/hexapod/symetrie/puna_cs.py +0 -195
  211. egse/hexapod/symetrie/puna_protocol.py +0 -134
  212. egse/hexapod/symetrie/puna_ui.py +0 -433
  213. egse/hexapod/symetrie/punaplus.py +0 -107
  214. egse/hexapod/symetrie/zonda.py +0 -872
  215. egse/hexapod/symetrie/zonda.yaml +0 -337
  216. egse/hexapod/symetrie/zonda_cs.py +0 -172
  217. egse/hexapod/symetrie/zonda_devif.py +0 -414
  218. egse/hexapod/symetrie/zonda_protocol.py +0 -123
  219. egse/hexapod/symetrie/zonda_ui.py +0 -449
  220. egse/hk.py +0 -791
  221. egse/icons/aeu-cs-start.svg +0 -117
  222. egse/icons/aeu-cs-stop.svg +0 -118
  223. egse/icons/aeu-cs.svg +0 -107
  224. egse/icons/aeu_cs-started.svg +0 -112
  225. egse/icons/aeu_cs-stopped.svg +0 -112
  226. egse/icons/aeu_cs.svg +0 -55
  227. egse/icons/alert.svg +0 -1
  228. egse/icons/arrow-double-left.png +0 -0
  229. egse/icons/arrow-double-right.png +0 -0
  230. egse/icons/arrow-up.svg +0 -11
  231. egse/icons/backward.svg +0 -1
  232. egse/icons/busy.svg +0 -1
  233. egse/icons/cleaning.svg +0 -115
  234. egse/icons/color-scheme.svg +0 -1
  235. egse/icons/cs-connected-alert.svg +0 -91
  236. egse/icons/cs-connected-disabled.svg +0 -43
  237. egse/icons/cs-connected.svg +0 -89
  238. egse/icons/cs-not-connected.svg +0 -44
  239. egse/icons/double-left-arrow.svg +0 -1
  240. egse/icons/double-right-arrow.svg +0 -1
  241. egse/icons/erase-disabled.svg +0 -19
  242. egse/icons/erase.svg +0 -59
  243. egse/icons/fitsgen-start.svg +0 -47
  244. egse/icons/fitsgen-stop.svg +0 -48
  245. egse/icons/fitsgen.svg +0 -1
  246. egse/icons/forward.svg +0 -1
  247. egse/icons/fov-hk-start.svg +0 -33
  248. egse/icons/fov-hk-stop.svg +0 -37
  249. egse/icons/fov-hk.svg +0 -1
  250. egse/icons/front-desk.svg +0 -1
  251. egse/icons/home-actioned.svg +0 -15
  252. egse/icons/home-disabled.svg +0 -15
  253. egse/icons/home.svg +0 -13
  254. egse/icons/info.svg +0 -1
  255. egse/icons/invalid.png +0 -0
  256. egse/icons/led-green.svg +0 -20
  257. egse/icons/led-grey.svg +0 -20
  258. egse/icons/led-orange.svg +0 -20
  259. egse/icons/led-red.svg +0 -20
  260. egse/icons/led-square-green.svg +0 -134
  261. egse/icons/led-square-grey.svg +0 -134
  262. egse/icons/led-square-orange.svg +0 -134
  263. egse/icons/led-square-red.svg +0 -134
  264. egse/icons/limit-switch-all-green.svg +0 -115
  265. egse/icons/limit-switch-all-red.svg +0 -117
  266. egse/icons/limit-switch-el+.svg +0 -116
  267. egse/icons/limit-switch-el-.svg +0 -117
  268. egse/icons/location-marker.svg +0 -1
  269. egse/icons/logo-dpu.svg +0 -48
  270. egse/icons/logo-gimbal.svg +0 -112
  271. egse/icons/logo-huber.svg +0 -23
  272. egse/icons/logo-ogse.svg +0 -31
  273. egse/icons/logo-puna.svg +0 -92
  274. egse/icons/logo-tcs.svg +0 -29
  275. egse/icons/logo-zonda.svg +0 -66
  276. egse/icons/maximize.svg +0 -1
  277. egse/icons/meter.svg +0 -1
  278. egse/icons/more.svg +0 -45
  279. egse/icons/n-fee-hk-start.svg +0 -24
  280. egse/icons/n-fee-hk-stop.svg +0 -25
  281. egse/icons/n-fee-hk.svg +0 -83
  282. egse/icons/observing-off.svg +0 -46
  283. egse/icons/observing-on.svg +0 -46
  284. egse/icons/open-document-hdf5.png +0 -0
  285. egse/icons/open-document-hdf5.svg +0 -21
  286. egse/icons/ops-mode.svg +0 -1
  287. egse/icons/play-green.svg +0 -17
  288. egse/icons/plugged-disabled.svg +0 -27
  289. egse/icons/plugged.svg +0 -21
  290. egse/icons/pm_ui.svg +0 -1
  291. egse/icons/power-button-green.svg +0 -27
  292. egse/icons/power-button-red.svg +0 -27
  293. egse/icons/power-button.svg +0 -27
  294. egse/icons/radar.svg +0 -1
  295. egse/icons/radioactive.svg +0 -2
  296. egse/icons/reload.svg +0 -1
  297. egse/icons/remote-control-off.svg +0 -28
  298. egse/icons/remote-control-on.svg +0 -28
  299. egse/icons/repeat-blue.svg +0 -15
  300. egse/icons/repeat.svg +0 -1
  301. egse/icons/settings.svg +0 -1
  302. egse/icons/shrink.svg +0 -1
  303. egse/icons/shutter.svg +0 -1
  304. egse/icons/sign-off.svg +0 -1
  305. egse/icons/sign-on.svg +0 -1
  306. egse/icons/sim-mode.svg +0 -1
  307. egse/icons/small-buttons-go.svg +0 -20
  308. egse/icons/small-buttons-minus.svg +0 -51
  309. egse/icons/small-buttons-plus.svg +0 -51
  310. egse/icons/sponge.svg +0 -220
  311. egse/icons/start-button-disabled.svg +0 -84
  312. egse/icons/start-button.svg +0 -50
  313. egse/icons/stop-button-disabled.svg +0 -84
  314. egse/icons/stop-button.svg +0 -50
  315. egse/icons/stop-red.svg +0 -17
  316. egse/icons/stop.svg +0 -1
  317. egse/icons/switch-disabled-square.svg +0 -87
  318. egse/icons/switch-disabled.svg +0 -15
  319. egse/icons/switch-off-square.svg +0 -87
  320. egse/icons/switch-off.svg +0 -72
  321. egse/icons/switch-on-square.svg +0 -87
  322. egse/icons/switch-on.svg +0 -61
  323. egse/icons/temperature-control.svg +0 -44
  324. egse/icons/th_ui_logo.svg +0 -1
  325. egse/icons/unplugged.svg +0 -23
  326. egse/icons/unvalid.png +0 -0
  327. egse/icons/user-interface.svg +0 -1
  328. egse/icons/vacuum.svg +0 -1
  329. egse/icons/valid.png +0 -0
  330. egse/icons/zoom-to-pixel-dark.svg +0 -64
  331. egse/icons/zoom-to-pixel-white.svg +0 -36
  332. egse/images/big-rotation-stage.png +0 -0
  333. egse/images/connected-100.png +0 -0
  334. egse/images/cross.svg +0 -6
  335. egse/images/disconnected-100.png +0 -0
  336. egse/images/gui-icon.png +0 -0
  337. egse/images/home.svg +0 -6
  338. egse/images/info-icon.png +0 -0
  339. egse/images/led-black.svg +0 -89
  340. egse/images/led-green.svg +0 -85
  341. egse/images/led-orange.svg +0 -85
  342. egse/images/led-red.svg +0 -85
  343. egse/images/load-icon.png +0 -0
  344. egse/images/load-setup.png +0 -0
  345. egse/images/load.png +0 -0
  346. egse/images/pause.png +0 -0
  347. egse/images/play-button.svg +0 -8
  348. egse/images/play.png +0 -0
  349. egse/images/process-status.png +0 -0
  350. egse/images/restart.png +0 -0
  351. egse/images/search.png +0 -0
  352. egse/images/sma.png +0 -0
  353. egse/images/start.png +0 -0
  354. egse/images/stop-button.svg +0 -8
  355. egse/images/stop.png +0 -0
  356. egse/images/switch-off.svg +0 -48
  357. egse/images/switch-on.svg +0 -48
  358. egse/images/undo.png +0 -0
  359. egse/images/update-button.svg +0 -11
  360. egse/imageviewer/exposureselection.py +0 -475
  361. egse/imageviewer/imageviewer.py +0 -198
  362. egse/imageviewer/matchfocalplane.py +0 -179
  363. egse/imageviewer/subfieldposition.py +0 -133
  364. egse/lampcontrol/__init__.py +0 -4
  365. egse/lampcontrol/beaglebone/beaglebone.py +0 -178
  366. egse/lampcontrol/beaglebone/beaglebone.yaml +0 -62
  367. egse/lampcontrol/beaglebone/beaglebone_cs.py +0 -106
  368. egse/lampcontrol/beaglebone/beaglebone_devif.py +0 -150
  369. egse/lampcontrol/beaglebone/beaglebone_protocol.py +0 -73
  370. egse/lampcontrol/energetiq/__init__.py +0 -22
  371. egse/lampcontrol/energetiq/eq99.yaml +0 -98
  372. egse/lampcontrol/energetiq/lampEQ99.py +0 -283
  373. egse/lampcontrol/energetiq/lampEQ99_cs.py +0 -128
  374. egse/lampcontrol/energetiq/lampEQ99_devif.py +0 -158
  375. egse/lampcontrol/energetiq/lampEQ99_encode_decode_errors.py +0 -73
  376. egse/lampcontrol/energetiq/lampEQ99_protocol.py +0 -71
  377. egse/lampcontrol/energetiq/lampEQ99_ui.py +0 -465
  378. egse/lib/CentOS-7/EtherSpaceLink_v34_86.dylib +0 -0
  379. egse/lib/CentOS-8/ESL-RMAP_v34_86.dylib +0 -0
  380. egse/lib/CentOS-8/EtherSpaceLink_v34_86.dylib +0 -0
  381. egse/lib/Debian/ESL-RMAP_v34_86.dylib +0 -0
  382. egse/lib/Debian/EtherSpaceLink_v34_86.dylib +0 -0
  383. egse/lib/Debian/libetherspacelink_v35_21.dylib +0 -0
  384. egse/lib/Linux/ESL-RMAP_v34_86.dylib +0 -0
  385. egse/lib/Linux/EtherSpaceLink_v34_86.dylib +0 -0
  386. egse/lib/Ubuntu-20/ESL-RMAP_v34_86.dylib +0 -0
  387. egse/lib/Ubuntu-20/EtherSpaceLink_v34_86.dylib +0 -0
  388. egse/lib/gssw/python3-gssw_2.2.3+31f63c9f-1_all.deb +0 -0
  389. egse/lib/ximc/__pycache__/pyximc.cpython-38 2.pyc +0 -0
  390. egse/lib/ximc/__pycache__/pyximc.cpython-38.pyc +0 -0
  391. egse/lib/ximc/libximc.framework/Frameworks/libbindy.dylib +0 -0
  392. egse/lib/ximc/libximc.framework/Frameworks/libxiwrapper.dylib +0 -0
  393. egse/lib/ximc/libximc.framework/Headers/ximc.h +0 -5510
  394. egse/lib/ximc/libximc.framework/Resources/Info.plist +0 -42
  395. egse/lib/ximc/libximc.framework/Resources/keyfile.sqlite +0 -0
  396. egse/lib/ximc/libximc.framework/libbindy.so +0 -0
  397. egse/lib/ximc/libximc.framework/libximc +0 -0
  398. egse/lib/ximc/libximc.framework/libximc.so +0 -0
  399. egse/lib/ximc/libximc.framework/libximc.so.7.0.0 +0 -0
  400. egse/lib/ximc/libximc.framework/libxiwrapper.so +0 -0
  401. egse/lib/ximc/pyximc.py +0 -922
  402. egse/listener.py +0 -179
  403. egse/logger/__init__.py +0 -243
  404. egse/logger/log_cs.py +0 -321
  405. egse/metrics.py +0 -102
  406. egse/mixin.py +0 -464
  407. egse/monitoring.py +0 -95
  408. egse/ni/alarms/__init__.py +0 -26
  409. egse/ni/alarms/cdaq9375.py +0 -300
  410. egse/ni/alarms/cdaq9375.yaml +0 -89
  411. egse/ni/alarms/cdaq9375_cs.py +0 -130
  412. egse/ni/alarms/cdaq9375_devif.py +0 -183
  413. egse/ni/alarms/cdaq9375_protocol.py +0 -48
  414. egse/obs_inspection.py +0 -165
  415. egse/observer.py +0 -41
  416. egse/obsid.py +0 -163
  417. egse/powermeter/__init__.py +0 -0
  418. egse/powermeter/ni/__init__.py +0 -38
  419. egse/powermeter/ni/cdaq9184.py +0 -224
  420. egse/powermeter/ni/cdaq9184.yaml +0 -73
  421. egse/powermeter/ni/cdaq9184_cs.py +0 -130
  422. egse/powermeter/ni/cdaq9184_devif.py +0 -201
  423. egse/powermeter/ni/cdaq9184_protocol.py +0 -48
  424. egse/powermeter/ni/cdaq9184_ui.py +0 -544
  425. egse/powermeter/thorlabs/__init__.py +0 -25
  426. egse/powermeter/thorlabs/pm100a.py +0 -380
  427. egse/powermeter/thorlabs/pm100a.yaml +0 -132
  428. egse/powermeter/thorlabs/pm100a_cs.py +0 -136
  429. egse/powermeter/thorlabs/pm100a_devif.py +0 -127
  430. egse/powermeter/thorlabs/pm100a_protocol.py +0 -80
  431. egse/powermeter/thorlabs/pm100a_ui.py +0 -725
  432. egse/process.py +0 -451
  433. egse/procman/__init__.py +0 -834
  434. egse/procman/cannot_start_process_popup.py +0 -43
  435. egse/procman/procman.yaml +0 -49
  436. egse/procman/procman_cs.py +0 -201
  437. egse/procman/procman_ui.py +0 -2081
  438. egse/protocol.py +0 -605
  439. egse/proxy.py +0 -531
  440. egse/randomwalk.py +0 -140
  441. egse/reg.py +0 -585
  442. egse/reload.py +0 -122
  443. egse/reprocess.py +0 -693
  444. egse/resource.py +0 -333
  445. egse/rmap.py +0 -406
  446. egse/rst.py +0 -135
  447. egse/search.py +0 -182
  448. egse/serialdevice.py +0 -190
  449. egse/services.py +0 -247
  450. egse/services.yaml +0 -68
  451. egse/settings.py +0 -379
  452. egse/settings.yaml +0 -980
  453. egse/setup.py +0 -1181
  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 -71
  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 -1401
  473. egse/stages/__init__.py +0 -12
  474. egse/stages/aerotech/ensemble.py +0 -245
  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 -188
  482. egse/stages/arun/smd3.py +0 -110
  483. egse/stages/arun/smd3.yaml +0 -68
  484. egse/stages/arun/smd3_controller.py +0 -470
  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 -920
  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 -113
  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 -1067
  500. egse/storage/persistence.py +0 -2295
  501. egse/storage/storage.yaml +0 -79
  502. egse/storage/storage_cs.py +0 -231
  503. egse/styles/dark.qss +0 -343
  504. egse/styles/default.qss +0 -48
  505. egse/synoptics/__init__.py +0 -417
  506. egse/synoptics/syn.yaml +0 -9
  507. egse/synoptics/syn_cs.py +0 -195
  508. egse/system.py +0 -1611
  509. egse/tcs/__init__.py +0 -14
  510. egse/tcs/tcs.py +0 -879
  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 -180
  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 -114
  522. egse/tempcontrol/agilent/agilent34970_devif.py +0 -182
  523. egse/tempcontrol/agilent/agilent34970_protocol.py +0 -96
  524. egse/tempcontrol/agilent/agilent34972.py +0 -111
  525. egse/tempcontrol/agilent/agilent34972.yaml +0 -44
  526. egse/tempcontrol/agilent/agilent34972_cs.py +0 -115
  527. egse/tempcontrol/agilent/agilent34972_devif.py +0 -189
  528. egse/tempcontrol/agilent/agilent34972_protocol.py +0 -98
  529. egse/tempcontrol/beaglebone/beaglebone.py +0 -341
  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 -134
  533. egse/tempcontrol/beaglebone/beaglebone_ui.py +0 -674
  534. egse/tempcontrol/digalox/digalox.py +0 -115
  535. egse/tempcontrol/digalox/digalox.yaml +0 -36
  536. egse/tempcontrol/digalox/digalox_cs.py +0 -108
  537. egse/tempcontrol/digalox/digalox_protocol.py +0 -56
  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 -79
  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 -76
  551. egse/tempcontrol/lakeshore/lsci_ui.py +0 -387
  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 -723
  559. egse/tempcontrol/srs/__init__.py +0 -22
  560. egse/tempcontrol/srs/ptc10.py +0 -867
  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 -116
  564. egse/tempcontrol/srs/ptc10_protocol.py +0 -39
  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 -159
  575. egse/vacuum/beaglebone/beaglebone_protocol.py +0 -192
  576. egse/vacuum/beaglebone/beaglebone_ui.py +0 -638
  577. egse/vacuum/instrutech/igm402.py +0 -91
  578. egse/vacuum/instrutech/igm402.yaml +0 -90
  579. egse/vacuum/instrutech/igm402_controller.py +0 -124
  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 -100
  585. egse/vacuum/keller/leo3.yaml +0 -38
  586. egse/vacuum/keller/leo3_controller.py +0 -81
  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 -313
  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 -701
  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 -37
  602. egse/vacuum/pfeiffer/tc400.py +0 -87
  603. egse/vacuum/pfeiffer/tc400.yaml +0 -83
  604. egse/vacuum/pfeiffer/tc400_controller.py +0 -136
  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 -35
  608. egse/vacuum/pfeiffer/tpg261.py +0 -80
  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 -59
  613. egse/vacuum/pfeiffer/tpg261_simulator.py +0 -23
  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 -52
  625. scripts/check_hdf5_files.py +0 -192
  626. scripts/check_register_sync.py +0 -47
  627. scripts/check_tcs_calib_coef.py +0 -90
  628. scripts/correct_ccd_cold_temperature_cal.py +0 -157
  629. scripts/create_hdf5_report.py +0 -293
  630. scripts/csl_model.py +0 -420
  631. scripts/csl_restore_setup.py +0 -229
  632. scripts/export-grafana-dashboards.py +0 -49
  633. scripts/fdir/cs_recovery/fdir_cs_recovery.py +0 -54
  634. scripts/fdir/fdir_table.yaml +0 -70
  635. scripts/fdir/fdir_test_recovery.py +0 -10
  636. scripts/fdir/hw_recovery/fdir_agilent_hw_recovery.py +0 -73
  637. scripts/fdir/limit_recovery/fdir_agilent_limit.py +0 -61
  638. scripts/fdir/limit_recovery/fdir_bb_heater_limit.py +0 -59
  639. scripts/fdir/limit_recovery/fdir_ensemble_limit.py +0 -33
  640. scripts/fdir/limit_recovery/fdir_pressure_limit_recovery.py +0 -71
  641. scripts/fix_csv.py +0 -80
  642. scripts/ias/correct_ccd_temp_cal_elfique.py +0 -43
  643. scripts/ias/correct_ccd_temp_cal_floreffe.py +0 -43
  644. scripts/ias/correct_trp_swap_achel.py +0 -199
  645. scripts/inta/correct_ccd_temp_cal_duvel.py +0 -43
  646. scripts/inta/correct_ccd_temp_cal_gueuze.py +0 -43
  647. scripts/n_fee_supply_voltage_calculation.py +0 -92
  648. scripts/playground.py +0 -30
  649. scripts/print_hdf5_hk_data.py +0 -68
  650. scripts/print_register_map.py +0 -43
  651. scripts/remove_lines_between_matches.py +0 -188
  652. scripts/sron/commanding/control_heaters.py +0 -44
  653. scripts/sron/commanding/pumpdown.py +0 -46
  654. scripts/sron/commanding/set_pid_setpoint.py +0 -19
  655. scripts/sron/commanding/shutdown_bbb_heaters.py +0 -10
  656. scripts/sron/commanding/shutdown_pumps.py +0 -33
  657. scripts/sron/correct_mgse_coordinates_brigand_chimay.py +0 -272
  658. scripts/sron/correct_trp_swap_brigand.py +0 -204
  659. scripts/sron/gimbal_conversions.py +0 -75
  660. scripts/sron/tm_gen/tm_gen_agilent.py +0 -37
  661. scripts/sron/tm_gen/tm_gen_heaters.py +0 -4
  662. scripts/sron/tm_gen/tm_gen_spid.py +0 -13
  663. scripts/update_operational_cgse.py +0 -268
  664. scripts/update_operational_cgse_old.py +0 -273
egse/reg.py DELETED
@@ -1,585 +0,0 @@
1
- """
2
- This module defines classes and methods for working with the register
3
- as defined in the N-FEE and the F-FEE. The register is basically a memory
4
- map that is 32-bit aligned and contains configuration values for the
5
- front-end electronics (FEE) of the PLATO cameras.
6
-
7
- The class RegisterMap has all definitions of the registers as they are
8
- defined for the two cameras in PLATO.
9
-
10
- The class Register is basically a set of RegisterValue objects and defines
11
- all the parameters for this registry in the registry map. A Registry is
12
- a 32-bit field in the registry map.
13
-
14
- The class RegisterValue is the definition of one value or parameter in
15
- the register map and contains all the information needed to encode and
16
- decode the register value.
17
-
18
- The RegisterMap is initialized from a YAML configuration file that
19
- is loaded for the N-FEE or F-FEE. The name of the configuration file is
20
- read from the general Settings configuration file, i.e. the REGISTER_MAP
21
- for the N-FEE and the F-FEE settings.
22
-
23
- Examples:
24
- ```
25
- reg_map: RegisterMap = RegisterMap('N-FEE')
26
-
27
- # get window size for CCD#1
28
-
29
- x_size = reg_map.get_value('reg_8_config', 'ccd1_win_size_x')
30
- y_size = reg_map.get_value('reg_8_config', 'ccd1_win_size_y')
31
- ```
32
- You can also use the shortcut and only specify the variable name as a key. This works as long
33
- as the variable name is unique for the whole register map.
34
- ```
35
- x_size = reg_map["ccd1_win_size_x"]
36
- y_size = reg_map["ccd1_win_size_y"]
37
- ```
38
- """
39
- import logging
40
- from typing import List
41
- from typing import Union
42
-
43
- import numpy as np
44
- from rich.table import Table
45
-
46
- from egse.bits import beautify_binary
47
- from egse.bits import clear_bit
48
- from egse.bits import set_bit
49
- from egse.bits import set_bits
50
- from egse.settings import Settings
51
- from egse.setup import SetupError
52
- from egse.state import GlobalState
53
-
54
- n_fee_settings = Settings.load("N-FEE")
55
-
56
- LOGGER = logging.getLogger(__name__)
57
-
58
-
59
- def decode_ccd_order(ccd_order: int) -> str:
60
- """
61
- The readout order of the CCDs for the N-FEE. The `ccd_order` is the value that is returned when
62
- reading the variable from the RegisterMap.
63
-
64
- Example:
65
- >>> decode_ccd_order(0x4E) # new convention
66
- 'ccd_order=0b01001110 ( 78) CCD1 -> CCD2 -> CCD3 -> CCD4'
67
-
68
- Args:
69
- ccd_order: 8-bit field decoded CCD order
70
-
71
- Returns:
72
- A string representing the readout order of the CCDs.
73
- """
74
- msg = f"ccd_order=0b{ccd_order:08b} ({ccd_order:3d}) "
75
-
76
- try:
77
- ccd_id = GlobalState.setup.camera.fee.ccd_numbering.CCD_ID
78
- except AttributeError:
79
- raise SetupError("No entry in the setup for camera.fee.ccd_numbering.CCD_ID")
80
-
81
- order = [f"{ccd_id[(ccd_order >> idx * 2) & 0b11]}" for idx in range(4)]
82
- msg += " -> ".join(order)
83
- return msg
84
-
85
-
86
- def encode_ccd_order(ccd_order: List = None) -> int:
87
- """
88
- Given a list of strings that represent the CCD ID, return the encoded ccd_order that can be
89
- stored in the RegisterMap.
90
-
91
- CCD IDs are "CCD1", "CCD2", "CCD3", "CCD4".
92
-
93
- Example:
94
- >>> encode_ccd_order(["CCD1", "CCD2", "CCD3", "CCD4"])
95
- '0b1001110'
96
-
97
- Args:
98
- ccd_order: a list with strings that represent the CCD order
99
-
100
- Returns:
101
- The decoded value (int) of the CCD order.
102
- """
103
-
104
- try:
105
- ccd_id = GlobalState.setup.camera.fee.ccd_numbering.CCD_ID
106
- except AttributeError:
107
- raise SetupError("No entry in the setup for camera.fee.ccd_numbering.CCD_ID")
108
-
109
- order = 0
110
- keys_list = list(ccd_id.keys())
111
- values_list = list(ccd_id.values())
112
- for idx, name in enumerate(ccd_order):
113
- ccd_id = keys_list[values_list.index(name)]
114
- order |= ccd_id << idx * 2
115
-
116
- return order
117
-
118
-
119
- class Register:
120
- """
121
- Represents a memory register as defined in the front-end electronics (FEE).
122
-
123
- A Register is a 32-bit field in the FEE memory map and consists of a number
124
- of sub-registers or RegisterValues.
125
- """
126
-
127
- def __init__(self, name: str, address: int):
128
- """
129
- Args:
130
- name (str): the name of this register
131
- address (int): the memory address of the register in the FEE memory map
132
- (shall be 32-bit aligned)
133
- Raises:
134
- ValueError when address is not 32-bit aligned.
135
- """
136
- if address & 0x03:
137
- raise ValueError(f"The given memory address is not 4-byte (32-bit) aligned. "
138
- f"[address=0x{address:02x}]")
139
- self._name = name
140
- self._address = address
141
- self._values = {}
142
-
143
- @property
144
- def name(self):
145
- """The name of the 32-bit register."""
146
- return self._name
147
-
148
- @property
149
- def address(self):
150
- """The memory address of the register in the N-FEE memory map."""
151
- return self._address
152
-
153
- def values(self):
154
- """Returns a view on the values in the register. This view is iterable."""
155
- return self._values.values()
156
-
157
- def keys(self):
158
- """Returns the top-level keys, i.e. register names."""
159
- return self._values.keys()
160
-
161
- def items(self):
162
- """Returns the keys-value pairs of the registers from this RegisterMap."""
163
- return self._values.items()
164
-
165
- def __setitem__(self, key, value):
166
- self._values[key] = value
167
-
168
- def __getitem__(self, key):
169
- return self._values[key]
170
-
171
-
172
- class RegisterValue:
173
- """
174
- Represents one value from a memory register as used by the front-end electronics (FEE).
175
-
176
- A register value can be a bit-field or an n-bit integer. A bit-field needs to be decoded
177
- separately and is treated here as an integer.
178
- """
179
-
180
- def __init__(self, register: Register, name: str, offset: int, width: int, default: int):
181
- """
182
- Args:
183
- register (Register): the register to which this value belongs (back reference)
184
- name (str): the name of this register value
185
- offset (int): the offset for the value in the 32-bit register [number of bits]
186
- width (int): the width of the register value [number of bits]
187
- default (int): the default register value
188
- """
189
- self._register = register
190
- self._name = name
191
- self._offset = offset
192
- self._width = width
193
- self._default = default
194
-
195
- def __repr__(self):
196
- return (
197
- f"Register('{self.register.name}', '{self.name}', "
198
- f"0x{self.register.address:0X}, {self.offset}, {self.width}, {self.default})"
199
- )
200
-
201
- @property
202
- def register(self):
203
- return self._register
204
-
205
- @property
206
- def name(self):
207
- return self._name
208
-
209
- @property
210
- def offset(self):
211
- return self._offset
212
-
213
- @property
214
- def width(self):
215
- return self._width
216
-
217
- @property
218
- def default(self):
219
- return self._default
220
-
221
- def get_value(self, data: bytes) -> int:
222
- """Read the value of this register variable from the given data.
223
-
224
- The data argument shall be at least 4 bytes long. The register value is assumed to fall
225
- within the first 32-bits of the data argument.
226
-
227
- This method is usually used when a register has been read from the memory map and a
228
- register value needs to be extracted. Alternatively, you can use the
229
- `get_value(reg_name, var_name)` method of the RegisterMap class.
230
-
231
- Args:
232
- data (bytes): a register data field
233
-
234
- Returns:
235
- value: the value of the given register variable.
236
- """
237
- data = int.from_bytes(data[:4], "big")
238
- value = (data >> self.offset) & set_bits(0x0, (0, self.width))
239
- return value
240
-
241
-
242
- class RegisterMap:
243
- """
244
- The RegisterMap keeps track of the complete register map of the front-end electronics.
245
-
246
- When the given name argument is 'N-FEE' or 'F-FEE' the register map will be loaded from
247
- the corresponding configuration file and the memory map will be initialized with the
248
- default values. All other names will create an empty register map.
249
-
250
- When no name is given, or another name than 'N-FEE' or 'F-FEE', an empty register is created
251
- with the given name and the memory map will be initialised to zero.
252
-
253
- The RegisterMap only contains the critical, general and housekeeping areas. The windowing
254
- area is treated differently. That means the register map is 0x0800 (2048) bytes. The windowing
255
- area is 0x0080_0000 bytes (8MB) in size.
256
-
257
- """
258
-
259
- def __init__(self,
260
- name: str = None, *,
261
- size: int = 0,
262
- memory_map: Union[bytearray, np.ndarray] = None):
263
- """
264
- Note: size and memory_map are keyword-only arguments, i.e. these arguments
265
- must be specified using the keyword.
266
-
267
- Args:
268
- name (str): the name for the register map.
269
- size (int): the size of the memory buffer in bytes (32-bit aligned!)
270
- memory_map: the memory map to be used for initialising the RegisterMap.
271
- The type of the memory_map can be a bytearray or a Numpy ndarray.
272
- """
273
- size = size or 0x0000_0800
274
- self._memory_map = bytearray(size)
275
- if name in ("N-FEE", "F-FEE"):
276
- self._name = name.upper()
277
- self._register_map = self._load_register_map()
278
- if isinstance(memory_map, np.ndarray):
279
- memory_map = bytearray(memory_map.tobytes())
280
- self._init_memory_map(memory_map)
281
- else:
282
- self._name = name
283
- self._register_map = {}
284
-
285
- def __iter__(self):
286
- return self._register_map.__iter__()
287
-
288
- def __str__(self):
289
- msg = f"Register Map for {self._name}\n"
290
- for reg_name in self:
291
- reg = self.get_register(reg_name)
292
- msg += f"{reg_name}:\n"
293
- for var_name in reg.keys():
294
- msg += f" {var_name}={self.get_value(reg.name, var_name)}\n"
295
- return msg
296
-
297
- def __rich__(self):
298
-
299
- # Create a table with — for each HK parameter — the HEX value, the binary, the decimal, and the
300
- # calibrated value.
301
- #
302
- # To calibrate a value:
303
- # * get the list of parameter names for temperatures from
304
- # We don't want this!!!
305
- # supply_voltage_calibration = GlobalState.setup.camera.fee.calibration.supply_voltages
306
- # temperature_calibration = GlobalState.setup.camera.fee.calibration.temperatures
307
-
308
- table = Table("Register", "Parameter", "Value (int)", "Value (hex)")
309
-
310
- for reg_name in self:
311
- reg = self.get_register(reg_name)
312
- for var_name in reg.keys():
313
- value = self.get_value(reg.name, var_name)
314
- table.add_row(reg_name, var_name, str(value), hex(value))
315
-
316
- return table
317
-
318
- def get_memory_map_as_ndarray(self) -> np.ndarray:
319
- """
320
- Returns the memory map of the RegisterMap object. This memory map represents the memory
321
- area that is used in the N-FEE to store the configuration variables.
322
-
323
- Returns:
324
- A Numpy array of `dtype=uint8`.
325
- """
326
- return np.frombuffer(self._memory_map.copy(), dtype=np.uint8)
327
-
328
- def _init_memory_map(self, memory_map: bytearray = None):
329
- if memory_map is None:
330
- for reg in self._register_map.values():
331
- for var in reg.values():
332
- self.set_value(reg.name, var.name, var.default)
333
- else:
334
- self._memory_map = memory_map
335
-
336
-
337
- def _load_register_map(self) -> dict:
338
-
339
- # This is not a good idea, the RegisterMap is not really instantiated in a critical context,
340
- # but this might happen. Instantiation of this class should be fast.
341
-
342
- fee_reg = GlobalState.setup.camera.fee.register_map
343
-
344
- register_map = {}
345
-
346
- for reg_name in fee_reg:
347
- # each register has the 'reg_address' as a mandatory field
348
- reg = Register(reg_name, fee_reg[reg_name]["reg_address"])
349
- for var_name in fee_reg[reg_name]:
350
- if var_name == "reg_address":
351
- continue
352
- offset, width, default = fee_reg[reg_name][var_name]
353
- reg[var_name] = RegisterValue(reg, var_name, offset, width, default)
354
- register_map[reg_name] = reg
355
-
356
- return register_map
357
-
358
- def get_value(self, reg_name: str, var_name: str) -> int:
359
- """
360
- Return the current value for the given register variable name.
361
-
362
- This is equivalent to:
363
-
364
- ```value = reg_map[(reg_name, var_name)]```
365
-
366
- Args:
367
- reg_name (str): the name of the register
368
- var_name (str): the name of the sub-register, i.e. the name of the value
369
-
370
- Returns:
371
- value: the value of the variable from the register map.
372
-
373
- Raises:
374
- KeyError: when the var_name doesn't match a RegisterValue in the Register for reg_name.
375
- """
376
- reg: Register = self._register_map[reg_name]
377
- var: RegisterValue = reg[var_name]
378
-
379
- data = self._memory_map[reg.address : reg.address + 4]
380
- value = int.from_bytes(data, "big")
381
- value = (value >> var.offset) & set_bits(0x0, (0, var.width))
382
-
383
- return value
384
-
385
- def set_value(self, reg_name: str, var_name: str, value: int) -> None:
386
- """
387
- Set the value for the given register variable name.
388
-
389
- This is equivalent to:
390
-
391
- ```reg_map[(reg_name, var_name)] = value```
392
-
393
- Args:
394
- reg_name (str): the name of the register
395
- var_name (str): the name of the sub-register, i.e. the name of the value
396
- value (int): the new register value
397
-
398
- Raises:
399
- KeyError: when the var_name doesn't match a RegisterValue in the Register for reg_name.
400
- """
401
- reg: Register = self._register_map[reg_name]
402
- var: RegisterValue = reg[var_name]
403
-
404
- orig_value = temp = int.from_bytes(self._memory_map[reg.address : reg.address + 4], "big")
405
- start = var.offset
406
- for bit in range(var.width):
407
- temp = (
408
- set_bit(temp, start + bit) if value & (1 << bit) else clear_bit(temp, start + bit)
409
- )
410
- self._memory_map[reg.address : reg.address + 4] = temp.to_bytes(4, "big")
411
- if temp != orig_value:
412
- LOGGER.debug(
413
- f"set new value for register {reg_name}:{var_name}: "
414
- f"0b{beautify_binary(temp, size=32)} (was 0b{beautify_binary(orig_value, size=32)})"
415
- )
416
-
417
- def add_register(self, reg: Register):
418
- """
419
- Add a new Register to the register map and set the default values for all its variables.
420
- """
421
- self._register_map[reg.name] = reg
422
- for var in reg.values():
423
- self.set_value(reg.name, var.name, var.default)
424
-
425
- def get_register(self, reg_name: str) -> Register:
426
- """Returns the Register for the given name.
427
-
428
- Args:
429
- reg_name (str): the name of a Register in the RegisterMap
430
-
431
- Returns:
432
- register: the Register for the given name.
433
-
434
- Raises:
435
- KeyError: when no Register with the given name exists in the RegisterMap
436
- """
437
-
438
- # FIXME:
439
- # This exposes a Register that is part of the RegisterMap and allows to make changes
440
- # that can potentially invalidate the RegisterMap!
441
- # Should we return a copy of the Register?
442
- return self._register_map[reg_name]
443
-
444
- def get_register_data(self, reg_name: str) -> bytes:
445
- """Returns the value of the register variable. A 32-bit bytes array."""
446
- reg: Register = self._register_map[reg_name]
447
- return self._memory_map[reg.address : reg.address + 4]
448
-
449
- def set_register_data(self, reg_name: str, data: bytes) -> None:
450
- """Writes the register data into the memory map."""
451
- reg: Register = self._register_map[reg_name]
452
- self._memory_map[reg.address : reg.address + 4] = data
453
-
454
- def get_data(self, address: int, length: int) -> bytes:
455
- """
456
- Read a range of bytes from the FEE memory map.
457
-
458
- Args:
459
- address: start address from where to start reading
460
- length: the number of bytes to read
461
-
462
- Returns:
463
- bytes from the requested address range.
464
-
465
- Raises:
466
- IndexError: when the address range falls out of the allowed range.
467
- """
468
- size = len(self._memory_map)
469
- if 0x0000_0000 <= address <= size - length:
470
- return self._memory_map[address : address + length]
471
- else:
472
- raise IndexError(
473
- f"The given address + length ({address} + {length} = {address+length}) fall out "
474
- f"of the addressable range of the memory map."
475
- )
476
-
477
- def set_data(self, address: int, data: bytes, length: int = 4) -> None:
478
- """
479
- Writes the register data into the memory map.
480
-
481
- This method can be used to replace single register values or even the complete register.
482
- By default, one single register will be set, i.e. 4 bytes.
483
-
484
- Args:
485
- address (int): start address from where to start writing (32-bit aligned)
486
- data (bytes): the data to write to the memory map
487
- length (int): the length of the data [default=4 bytes]
488
-
489
- Raises:
490
- ValueError when address is not 32-bit aligned.
491
- """
492
- if address & 0x03:
493
- raise ValueError(
494
- f"The given memory address is not 4-byte (32-bit) aligned. "
495
- f"[address=0x{address:02x}]"
496
- )
497
- self._memory_map[address : address + length] = data[:length]
498
-
499
- def __getitem__(self, item):
500
- """Return the current value for the given register variable.
501
- This equivalent to ``value = reg_map[reg_name, var_name]``.
502
- """
503
- if isinstance(item, str):
504
- return self._get_unambiguous_value(item)
505
- if not isinstance(item, (tuple, list)):
506
- raise KeyError(f"Expected a tuple or list with register name and variable name.")
507
- return self.get_value(item[0], item[1])
508
-
509
- def __setitem__(self, key, value):
510
- """Set the value for the given register variable.
511
- This equivalent to ``reg_map[reg_name, var_name] = value``.
512
- """
513
- if not isinstance(key, (tuple, list)):
514
- raise KeyError(
515
- f"Expected the 'key' argument to be a tuple or list with the register name "
516
- f"and the variable name as elements.")
517
- self.set_value(key[0], key[1], value)
518
-
519
- def _get_unambiguous_value(self, item):
520
- value = [self.get_value(reg_name, key)
521
- for reg_name in self
522
- for key in self.get_register(reg_name).keys()
523
- if key == item]
524
-
525
- if len(value) == 0:
526
- raise KeyError(f"'{item}' is not a valid variable name in this Register map.")
527
- if len(value) > 1:
528
- raise KeyError(f"'{item}' is ambiguous and used in {len(value)} registers. Use the 'get_value()' method.")
529
-
530
- return value[0]
531
-
532
- def as_dict(self, flatten: bool = False):
533
- """
534
- Returns the RegisterMap as a dictionary. The register map is a nested data structure where
535
- each register contains a number of variables. When represented as a dictionary, the first
536
- level keys are the register names, the seconds level are the variable names and their
537
- values. When the registered map is returned as a flattened dict, the keys are constructed
538
- from the register name and the variable name, separated by a colon.
539
-
540
- Args:
541
- flatten (bool): return the RegisterMap as a flattened dictionary
542
- Returns:
543
- The RegisterMap as an (optionally flattened) dictionary.
544
- """
545
- _dict = {}
546
- if flatten:
547
- for reg in self._register_map.values():
548
- for var in reg.values():
549
- value = self.get_value(reg.name, var.name)
550
- _dict[f"{reg.name}:{var.name}"] = value
551
- else:
552
- for reg in self._register_map.values():
553
- vars_dict = {}
554
- for var in reg.values():
555
- value = self.get_value(reg.name, var.name)
556
- vars_dict[var.name] = value
557
- _dict[reg.name] = vars_dict
558
-
559
- return _dict
560
-
561
-
562
- def compare_register_maps(reg_map_1: RegisterMap, reg_map_2: RegisterMap):
563
- """
564
- Compare two Register maps by content and variable names. The Register map is iterated over all
565
- registers and variables in registers and their names and values are compared element wise.
566
-
567
- When you only need to check the content, it might be better to use the
568
- `get_memory_map_as_ndarray()` method and compare the numpy arrays element wise, e.g.
569
-
570
- Args:
571
- reg_map_1 (RegisterMap): a register map
572
- reg_map_2 (RegisterMap): anothe register map
573
-
574
- Returns:
575
- A list with a description of the changes for each difference.
576
- """
577
- d1 = reg_map_1.as_dict(flatten=True)
578
- d2 = reg_map_2.as_dict(flatten=True)
579
-
580
- diff = [
581
- f"{k}: 0x{d1[k]:02x} -> 0x{d2[k]:02x}"
582
- for k, _ in set(d2.items()) - set(d1.items())
583
- ]
584
-
585
- return sorted(diff)
egse/reload.py DELETED
@@ -1,122 +0,0 @@
1
- """
2
- A slightly better approach to reloading modules and function than the standard importlib.reload()
3
- function. The functions in this modules are for interactive used in a Python REPL.
4
-
5
- * reload_module(module): reloads the given module and all its parent modules
6
- * reload_function(func): reloads and returns the given function
7
-
8
- NOTE: It might be possible that after the module or function has been reloaded that an extra
9
- import is needed to import the proper module attributes in your namespace.
10
-
11
- Module dependency
12
-
13
- When you make a change in a module or function that you are not calling directly, but call
14
- through another function from another module, you need to reload the module where you made
15
- the change and, after that, reload the function that calls that module.
16
-
17
- Example:
18
-
19
- * module x.a contains function func_a
20
- * module x.b contains function func_b which calls func_a
21
-
22
- when you make a change in func_a you have to relaod the module x.a and then reload
23
- the function func_b:
24
-
25
- >>> from x.b import func_b
26
- >>> func_b()
27
- # make some changes in func_a
28
- >>> reload_module('x.a')
29
- >>> func_b = reload_function(func_b)
30
- >>> func_b() # will show the changes done in func_a
31
-
32
- """
33
- import importlib
34
- import itertools
35
- import typing
36
- import types
37
-
38
- import rich
39
-
40
- from egse.exceptions import Abort
41
-
42
-
43
- def reload_module(module: typing.Union[types.ModuleType, str], walk: bool = True):
44
- """
45
- Reloads the given module and all its parent modules. The modules will be reloaded starting
46
- from their top-level module. Reloading the 'egse.hexapod.symetry.puna' module will reload
47
- 'egse', 'egse.hexapod', 'egse.hexapod.symetry', and 'egse.hexapod.symetry.puna' in that order.
48
-
49
- NOTE: If you pass the module argument as a module, make sure the top level module is
50
- imported in your session or you will get a NameError. To prevent this (if you don't want
51
- to import the top-level module, pass the module as a string.
52
-
53
- Usage:
54
- >>> import egse
55
- >>> reload_module(egse.system)
56
- or
57
- >>> reload_module('egse.system')
58
-
59
- Args:
60
- module: The module that needs to be reloaded
61
- walk: walk up the module hierarchy and import all modules [default=True]
62
-
63
- """
64
- full_module_name = module.__name__ if isinstance(module, types.ModuleType) else module
65
-
66
- module_names = itertools.accumulate(full_module_name.split('.'),
67
- lambda x, y: f"{x}.{y}") if walk else [full_module_name]
68
-
69
- for module_name in module_names:
70
- try:
71
- module = importlib.import_module(module_name)
72
- importlib.reload(module)
73
- except (Exception,) as exc:
74
- rich.print(f'[red]Failed to reload {module_name}[/red], {exc=}')
75
-
76
-
77
- def reload_function(func: types.FunctionType):
78
- """
79
- Reloads and returns the given function. In order for this to work, you should catch the
80
- return value to replace the given function with its reloaded counterpart.
81
-
82
- This will also work if you import the function again instead of catching it.
83
-
84
- NOTE: that this mechanism doesn't work for functions that were defined in the __main__ module.
85
-
86
- Usage:
87
- func = reload_function(func)
88
-
89
- reload_function(func)
90
- from egse.some_module import func
91
-
92
- Args:
93
- func: the function that needs to be reloaded
94
-
95
- Returns:
96
- The reloaded function.
97
-
98
- Raises:
99
- An Abort when the function is not the proper type or when the function is define
100
- in the __main__ module.
101
- """
102
-
103
- # Why do I raise an Abort instead of just printing a message and returning?
104
- #
105
- # The function is usually called catching the return value and replacing the same function with
106
- # its reloaded counterpart. If we would just return (None) when an error occurs, the original
107
- # function will be overwritten with None. Raising an Exception leaves the original as it was
108
- # before the call.
109
-
110
- if not isinstance(func, types.FunctionType):
111
- raise Abort(f"The 'func' argument shall be a function, not {type(func)}")
112
-
113
- module_name = func.__module__
114
- func_name = func.__name__
115
-
116
- if module_name == '__main__':
117
- raise Abort("Cannot reload a function that is defined in the __main__ module.")
118
-
119
- reload_module(module_name)
120
-
121
- module = __import__(module_name, fromlist=[func_name])
122
- return getattr(module, func_name)