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
egse/metrics.py DELETED
@@ -1,98 +0,0 @@
1
- import logging
2
-
3
- import numpy as np
4
- from prometheus_client import Gauge
5
-
6
- from egse.hk import TmDictionaryColumns
7
- from egse.settings import Settings
8
- from egse.setup import SetupError
9
- from egse.state import GlobalState
10
-
11
- LOGGER = logging.getLogger(__name__)
12
- SITE_ID = Settings.load("SITE").ID
13
-
14
-
15
- def define_metrics(origin: str, dashboard: str = None, use_site: bool = False) -> dict:
16
- """
17
- Create a metrics dictionary from the TM dictionary.
18
-
19
- Read the metric names and their descriptions from the TM dictionary, and create Prometheus
20
- gauges based on this information.
21
-
22
- If `dashboard` is not provided, all telemetry parameters for the given origin will be returned.
23
-
24
- Args:
25
- origin: the storage mnemonics for the requested metrics
26
- dashboard: restrict the metrics selection to those that are defined for the given dashboard.
27
- You can select all dashboards with `dashboard='*'`.
28
- use_site: Indicate whether the prefixes of the new HK names are TH-specific
29
- Returns:
30
- Dictionary with all Prometheus gauges for the given origin and dashboard.
31
- """
32
-
33
- try:
34
- hk_info_table = GlobalState.setup.telemetry.dictionary
35
- except AttributeError:
36
- raise SetupError("Version of the telemetry dictionary not specified in the current setup")
37
-
38
- hk_info_table = hk_info_table.replace(np.nan, "")
39
-
40
- storage_mnemonic = hk_info_table[TmDictionaryColumns.STORAGE_MNEMONIC].values
41
- hk_names = hk_info_table[TmDictionaryColumns.CORRECT_HK_NAMES].values
42
- descriptions = hk_info_table[TmDictionaryColumns.DESCRIPTION].values
43
- mon_screen = hk_info_table[TmDictionaryColumns.DASHBOARD].values
44
-
45
- condition = storage_mnemonic == origin.upper()
46
- if dashboard is not None:
47
- if dashboard == "*":
48
- extra_condition = mon_screen != ""
49
- else:
50
- extra_condition = mon_screen == dashboard.upper()
51
- condition = np.all((condition, extra_condition), axis=0)
52
-
53
- selection = np.where(condition)
54
-
55
- syn_names = hk_names[selection]
56
- descriptions = descriptions[selection]
57
-
58
- if not use_site:
59
- return {
60
- syn_name: Gauge(syn_name, description)
61
- for syn_name, description in zip(syn_names, descriptions)
62
- }
63
-
64
- th_prefix = f"G{SITE_ID}_"
65
-
66
- th_syn_names = []
67
- th_descriptions = []
68
- for syn_name, description in zip(syn_names, descriptions):
69
- if syn_name.startswith(th_prefix):
70
- th_syn_names.append(syn_name)
71
- th_descriptions.append(description)
72
-
73
- return {
74
- syn_name: Gauge(syn_name, description)
75
- for syn_name, description in zip(th_syn_names, th_descriptions)
76
- }
77
-
78
-
79
- def update_metrics(metrics: dict, updates: dict):
80
- """
81
- Updates the metrics parameters with the values from the updates dictionary.
82
- Only the metrics parameters for which the names are keys in the given updates dict are actually updated. Other
83
- metrics remain untouched.
84
-
85
- The functions logs a warning when the updates dict contains a name which is not known as a metrics parameter.
86
-
87
- Args:
88
- metrics: the metrics dictionary previously defined with the define_metrics function
89
- updates: a dictionary with key=metrics name and value is the to-be-updated value
90
- """
91
- for metric_name, value in updates.items():
92
- try:
93
- if value is None:
94
- metrics[metric_name].set(float('nan'))
95
- else:
96
- metrics[metric_name].set(float(value))
97
- except KeyError as exc:
98
- LOGGER.warning(f"Unknown metric name: {metric_name=}")
egse/mixin.py DELETED
@@ -1,464 +0,0 @@
1
- """
2
- This module defines Mixin classes that can be used for adding methods and properties to
3
- classes without strict inheritance.
4
-
5
- Be careful, some of the Mixin classes require certain attributes to be defined in the
6
- outer sub-class. Read the docstrings carefully to understand what is needed.
7
- """
8
-
9
- import contextlib
10
- import enum
11
- import functools
12
- import inspect
13
- import logging
14
- import string
15
- from typing import Callable
16
- from typing import Dict
17
-
18
- from egse.command import ClientServerCommand
19
- from egse.command import CommandError
20
- from egse.command import CommandExecution
21
- from egse.protocol import DynamicCommandProtocol
22
- from egse.protocol import get_function
23
-
24
- LOGGER = logging.getLogger(__name__)
25
-
26
- __all__ = [
27
- "add_lf",
28
- "add_cr_lf",
29
- "dynamic_command",
30
- "DynamicCommandMixin",
31
- ]
32
-
33
- # ----- Mixin for dynamic commanding ---------------------------------------------------------------
34
-
35
- COMMAND_TYPES = {
36
- "read": "__read_command",
37
- "write": "__write_command",
38
- "query": "__query_command",
39
- "transaction": "__transaction_command",
40
- }
41
- STX = "\x02" # start-of-text
42
- ETX = "\x03" # end-of-text
43
- EOT = "\x04" # end-of-transmission
44
- LINE_FEED = "\x0A"
45
- CARRIAGE_RETURN = "\x0D"
46
-
47
-
48
- def add_etx(cmd_string: str):
49
- """
50
- Add an end-of-text ETX (ASCII code 0x03) to the command string.
51
-
52
- Args:
53
- cmd_string: the unprocessed command string
54
-
55
- Returns:
56
- The command string with the ETX character appended.
57
- """
58
- return cmd_string if cmd_string.endswith(ETX) else cmd_string + ETX
59
-
60
-
61
- def add_eot(cmd_string: str):
62
- """
63
- Add an end-of-transmission EOT (ASCII code 0x04) to the command string.
64
-
65
- Args:
66
- cmd_string: the unprocessed command string
67
-
68
- Returns:
69
- The command string with the EOT character appended.
70
- """
71
- return cmd_string if cmd_string.endswith(EOT) else cmd_string + EOT
72
-
73
-
74
- def add_lf(cmd_string: str):
75
- """ Add a line feed to the given command string, if not added yet.
76
-
77
- Args:
78
- - cmd_string: Command string.
79
-
80
- Returns: Given command string with a line feed appended (if not present yet).
81
- """
82
-
83
- if not cmd_string.endswith(LINE_FEED):
84
-
85
- cmd_string += LINE_FEED
86
-
87
- return cmd_string
88
-
89
-
90
- def add_cr_lf(cmd_string: str):
91
- """ Add a carriage return and line feed to the given command string, if not added yet.
92
-
93
- Args:
94
- - cmd_string: Command string.
95
-
96
- Returns: Given command string with a carriage return and line feed appended (if not present yet).
97
- """
98
-
99
- if not cmd_string.endswith(CARRIAGE_RETURN + LINE_FEED):
100
-
101
- cmd_string += CARRIAGE_RETURN + LINE_FEED
102
-
103
- return cmd_string
104
-
105
-
106
- def expand_kwargs(kwargs: Dict):
107
- """Expand keyword arguments and their values as 'key=value' separated by spaces."""
108
- return " ".join(f"{k}={v}" for k, v in kwargs.items())
109
-
110
-
111
- def dynamic_command(
112
- *,
113
- cmd_type: str, # required keyword-only argument
114
- cmd_string: str = None,
115
- process_response: Callable = None,
116
- process_cmd_string: Callable = None,
117
- process_kwargs: Callable = None,
118
- use_format: bool = False,
119
- pre_cmd: Callable = None,
120
- post_cmd: Callable = None,
121
- ):
122
- """Convert an interface method into a dynamic command.
123
-
124
- The arguments define the type of command and how the response shall be processed.
125
-
126
- The command types 'write', 'query', and 'transaction' must be accompanied by a `cmd_string`
127
- argument that defines the formatting of the eventual command string that will be passed to
128
- the transport functions. The `cmd_string` is a template string that contains `$`-based
129
- substitutions for the function arguments. When you specify the `use_format=True` keyword,
130
- the `cmd_string` will be formatted using the format() function instead of the template
131
- substitution. The format option is less secure, but provides the functionality to format
132
- the arguments.
133
-
134
- A template string looks like:
135
-
136
- cmd_string="CREATE:SENS:TEMP ${name} ${type} default=${default}"
137
-
138
- The same `cmd_string` as a format option:
139
-
140
- cmd_string="CREATE:SENS:TEMP {name} {type} default={default:0.4f}"
141
- use_format=True
142
-
143
- The process_response and process_cmd_string keywords allow you to specify a pure function to
144
- process the response before it is returned, and to process the cmd_string before it is sent
145
- to the transport function.
146
-
147
- The `pre_cmd` and `post_cmd` keywords specify a callable/function to be executed before and/or
148
- after the actual command was executed (i.e. send to the device). These functions are called
149
- with specific keyword arguments that allow additional device interaction and response processing.
150
- The `pre_cmd` function is called with the keyword argument `transport=` which passes the device
151
- transport. This allows the function to interact with the device again through the methods defined
152
- by the DeviceTransport interface. The `pre_cmd` function must not return anything.
153
- The `post_cmd` function is called with the keyword arguments `transport=` and `response=`.
154
- The response argument contains the response from the command that was previously sent to the
155
- device. The `post_cmd` function can use this response to parse its content and act against
156
- this content, although possible, it is usually not a good idea to alter the content of the
157
- response argument. The `post_cmd` function shall return (i.e. pass through) the response.
158
-
159
- This decorator can add the following static attributes to the method:
160
-
161
- * __dynamic_interface
162
- * __read_command, __write_command, __query_command, __transaction_command
163
- * __cmd_string
164
- * __process_response
165
- * __process_cmd_string
166
- * __use_format
167
- * __pre_cmd
168
- * __post_cmd
169
-
170
- Args:
171
- cmd_type (str): one of 'read', 'write', 'query', or 'transaction' [required keyword]
172
- cmd_string (str): format string for the generation of the instrument command
173
- process_response (Callable): function to process the response
174
- process_cmd_string (Callable): function to process the command string after substitution
175
- process_kwargs (Callable): function to expand the kwargs after substitution
176
- use_format (bool): use string formatting instead of string templates
177
- pre_cmd (Callable): the function to execute before the command is executed
178
- post_cmd (Callable): the function to execute after the command is executed
179
- """
180
-
181
- # Perform some checks on required arguments
182
-
183
- if cmd_type not in COMMAND_TYPES:
184
- raise ValueError(f"Unknown type passed into dynamic command decorator: {type=}")
185
-
186
- if cmd_type in ('write', 'query', 'transaction') and cmd_string is None:
187
- raise ValueError(f"No cmd_string was provided for {cmd_type=}.")
188
-
189
- def func_wrapper(func: Callable):
190
- """Adds the different static attributes."""
191
-
192
- setattr(func, "__dynamic_interface", True)
193
-
194
- setattr(func, COMMAND_TYPES[cmd_type], True)
195
-
196
- if cmd_string is not None:
197
- setattr(func, "__cmd_string", cmd_string)
198
-
199
- if process_response is not None:
200
- setattr(func, "__process_response", process_response)
201
-
202
- if process_cmd_string is not None:
203
- setattr(func, "__process_cmd_string", process_cmd_string)
204
-
205
- if process_kwargs is not None:
206
- setattr(func, "__process_kwargs", process_kwargs)
207
-
208
- if use_format:
209
- setattr(func, "__use_format", True)
210
-
211
- if pre_cmd is not None:
212
- setattr(func, "__pre_cmd", pre_cmd)
213
-
214
- if post_cmd is not None:
215
- setattr(func, "__post_cmd", post_cmd)
216
-
217
- return func
218
-
219
- return func_wrapper
220
-
221
-
222
- class DynamicCommandMixin:
223
- """
224
- This Mixin class defines the functionality to dynamically call specific instrument commands
225
- from methods that are defined in the Interface classes for device Controllers.
226
-
227
- The mixin uses the `self.transport` instance variables that shall be defined by the
228
- Controller sub-class. The `self.transport` shall be a DeviceTransport object providing the
229
- methods to read, write, and query an instrument.
230
-
231
- !!! note
232
- This mixin overrides the `__getattribute__` method!
233
-
234
- !!! note
235
- This mixin class shall only be inherited from a Controller class that defines the
236
- `self.transport` attribute.
237
- """
238
-
239
- def __init__(self):
240
- if not hasattr(self, "transport"):
241
- raise AttributeError("Transport was not defined in sub-class of DynamicInterfaceMixin")
242
-
243
- @staticmethod
244
- def create_command_string(func: Callable, template_str: str, *args, **kwargs):
245
- """
246
- Creates a command string that is understood by the instrument. This can be an SCPI
247
- command or a specific proprietary command string. The `cmd_str` can contain placeholders
248
- similar to what is used in string formatting.
249
-
250
- As an example, we have a function with two positional arguments 'a', and 'b' and one keyword
251
- argument flag:
252
-
253
- def func(a, b, flag=True):
254
- pass
255
-
256
- We have the following template string: `CREATE:FUN:${a} ${b} [${flag}]`.
257
-
258
- When we call the function as follows: `func("TEMP", 23)`, we would then expect
259
- the returned string to be "CREATE:FUN:TEMP 23 [True]"
260
-
261
- DynamicCommandMixin.create_command_string(func, template, "TEMP", 23)
262
-
263
- Args:
264
- func (Callable): a function or method that provides the signature
265
- template_str (str): a template for the command
266
- args (tuple): positional arguments that will be used in the command string
267
- kwargs (dict): keywords arguments that will be used in the command string
268
- """
269
- try:
270
- process_kwargs = getattr(func, "__process_kwargs")
271
- except AttributeError:
272
- process_kwargs = expand_kwargs
273
-
274
- template = string.Template(template_str)
275
-
276
- sig = inspect.signature(func)
277
- try:
278
- bound = sig.bind(*args, **kwargs)
279
- except TypeError as exc:
280
- raise CommandError(
281
- f"Arguments {args}, {kwargs} do not match function signature for "
282
- f"{func.__name__}{sig}") from exc
283
-
284
- variables = {}
285
- for idx, par in enumerate(sig.parameters.values()):
286
- # if the argument is of signature '**kwargs' then expand the kwargs
287
- if par.kind == inspect.Parameter.VAR_KEYWORD:
288
- variables[par.name] = process_kwargs(bound.arguments[par.name])
289
- continue
290
-
291
- # otherwise, use the argument value or the default
292
- try:
293
- variables[par.name] = bound.arguments[par.name]
294
- except KeyError:
295
- variables[par.name] = par.default
296
-
297
- if hasattr(func, "__use_format"):
298
- cmd_string = template_str.format(**variables)
299
- else:
300
- variables = {
301
- k: v.value if isinstance(v, enum.Enum) else v
302
- for k, v in variables.items()
303
- }
304
- cmd_string = template.safe_substitute(variables)
305
-
306
- try:
307
- process_cmd_string = getattr(func, "__process_cmd_string")
308
- cmd_string = process_cmd_string(cmd_string)
309
- except AttributeError:
310
- pass
311
-
312
- return cmd_string
313
-
314
- def handle_dynamic_command(self, attr):
315
- """
316
- Creates a command wrapper calling the appropriate transport methods that are associated
317
- with the interface definition as passed into this method with the attr argument.
318
-
319
- Args:
320
- attr: The interface method that is decorated as a dynamic_command.
321
-
322
- Returns:
323
- Command wrapper with the read or write command, depending on the decorators used
324
- for that method in the corresponding Interface class.
325
-
326
- Raises:
327
- AttributeError: If the command is not listed in the YAML file and/or
328
- has not been listed.
329
- """
330
-
331
- @functools.wraps(attr)
332
- def command_wrapper(*args, **kwargs):
333
- """Generates command strings and executes the transport functions."""
334
- try:
335
- cmd_str = getattr(attr, "__cmd_string")
336
- cmd_str = self.create_command_string(attr, cmd_str, *args, **kwargs)
337
- except AttributeError:
338
- cmd_str = None
339
-
340
- response = None
341
-
342
- with contextlib.suppress(AttributeError):
343
- getattr(attr, "__pre_cmd")(transport=self.transport,
344
- function_name=attr.__name__, cmd_str=cmd_str, args=args, kwargs=kwargs)
345
-
346
- if hasattr(attr, "__write_command"):
347
- self.transport.write(cmd_str)
348
- elif hasattr(attr, "__read_command"):
349
- response = self.transport.read()
350
- elif hasattr(attr, "__query_command"):
351
- response = self.transport.query(cmd_str)
352
- elif hasattr(attr, "__transaction_command"):
353
- response = self.transport.trans(cmd_str)
354
- else:
355
- raise CommandError(f"Interface method '{attr.__name__}' shall be decorated with "
356
- f"a command type decorator.")
357
-
358
- with contextlib.suppress(AttributeError):
359
- response = getattr(attr, "__post_cmd")(transport=self.transport, response=response)
360
-
361
- with contextlib.suppress(AttributeError):
362
- process_response = getattr(attr, "__process_response")
363
- response = process_response(response=response)
364
-
365
- return response
366
-
367
- # Add a hook to identify the command_wrapper function as a method, instead of a function.
368
-
369
- setattr(command_wrapper, "__method_wrapper", True)
370
-
371
- # Add the docstring of the interface method
372
-
373
- command_wrapper.__doc__ = attr.__doc__
374
-
375
- return command_wrapper
376
-
377
- def __getattribute__(self, item):
378
- """
379
- The function __getattribute__() is called unconditionally when calling a method or accessing
380
- an instance variable. This override of `__getattribute__` additionally checks if the
381
- attribute is a method which has the `__dynamic_interface` defined and then calls a specific
382
- function to handle the command dynamically.
383
-
384
- Check if item exists:
385
- - if `item` exists and has the __dynamic_interface attribute then let the function
386
- handle_dynamic_command() handle this, i.e. call the instrument command.
387
- - else: the method has been defined in the Controller class, and we should just call
388
- that method (because it is overridden).
389
- """
390
-
391
- # If item is not known, an AttributeError will be raised and __getattr__() will be called.
392
-
393
- attr = object.__getattribute__(self, item)
394
-
395
- if hasattr(attr, "__dynamic_interface"):
396
-
397
- # We come here when the method is defined in the Interface class (where it is
398
- # decorated with the @dynamic_interface), but not in the sub-class. So, the method
399
- # is not overridden. We let the handle_dynamic_command() method handle this.
400
-
401
- attr = self.handle_dynamic_command(attr)
402
-
403
- return attr
404
-
405
-
406
- class DynamicClientCommandMixin:
407
- """
408
- This mixin class contains functionality to forward a device command from a client Proxy class
409
- to its control server.
410
-
411
- !!! note
412
- This mixin overrides the `__getattribute__` method!
413
-
414
- """
415
- def __getattribute__(self, item):
416
- # If item is not known, an AttributeError will be raised and __getattr__() will be called.
417
-
418
- attr = object.__getattribute__(self, item)
419
-
420
- if hasattr(attr, "__dynamic_interface"):
421
-
422
- # We come here when the method is defined in the Interface class (where it is
423
- # decorated with the @dynamic_interface), but not in the sub-class. So, the method
424
- # is not overridden. We let the handle_dynamic_command() method handle this.
425
-
426
- attr = self.handle_dynamic_command(attr)
427
-
428
- return attr
429
-
430
- def handle_dynamic_command(self, attr):
431
-
432
- @functools.wraps(attr)
433
- def command_wrapper(*args, **kwargs):
434
-
435
- attr_name = getattr(attr, "__name__")
436
-
437
- # This will ensure that the function is called with the proper arguments
438
-
439
- try:
440
- inspect.signature(attr).bind(*args, **kwargs)
441
- except TypeError as exc:
442
- LOGGER.error(f"Arguments do not match the signature of the function '{attr_name}': {exc}")
443
- return None
444
-
445
- # Create a command execution to pass the commanded function and the given arguments
446
- # to the control server for execution.
447
-
448
- device_method = get_function(self.__class__, attr_name)
449
- cmd = ClientServerCommand(name=attr_name,
450
- cmd=getattr(attr, "__cmd_string", ""),
451
- response=DynamicCommandProtocol.handle_device_method,
452
- device_method=device_method)
453
- ce = CommandExecution(cmd, *args, **kwargs)
454
-
455
- # Send the command to the control server for execution
456
-
457
- rc = self.send(ce)
458
- return rc
459
-
460
- # rewrite the proper signature for the called function
461
-
462
- command_wrapper.__signature__ = inspect.signature(attr)
463
-
464
- return command_wrapper
egse/monitoring.py DELETED
@@ -1,95 +0,0 @@
1
- import logging
2
- import multiprocessing
3
- import pickle
4
-
5
- import click
6
- import rich
7
- import zmq
8
-
9
- from egse.control import ControlServer
10
- from egse.protocol import CommandProtocol
11
- from egse.system import format_datetime
12
- from egse.zmq import MessageIdentifier
13
- from egse.zmq_ser import bind_address
14
-
15
- logger = logging.getLogger("egse.monitoring")
16
-
17
- class MonitoringProtocol(CommandProtocol):
18
- def __init__(self, control_server: ControlServer):
19
- super().__init__()
20
- self.control_server = control_server
21
-
22
- def get_bind_address(self):
23
- return bind_address(self.control_server.get_communication_protocol(), self.control_server.get_monitoring_port())
24
-
25
- def get_status(self):
26
- return {
27
- 'timestamp': format_datetime(),
28
- }
29
-
30
- def send_status(self, status):
31
- self.send(status)
32
-
33
- def get_housekeeping(self) -> dict:
34
- return {
35
- 'timestamp': format_datetime(),
36
- }
37
-
38
-
39
-
40
- @click.command()
41
- @click.argument('hostname')
42
- @click.argument('port')
43
- @click.option('--subscribe', '-s', default=('ALL',), multiple=True,
44
- help="subscribe to a sync identifier, can appear multiple times")
45
- @click.option('--multipart', '-m', is_flag=True, default=False, help="use multipart messages")
46
- @click.option('--pickle/--no-pickle', 'use_pickle', default=True)
47
- def monitoring(hostname: str, port: int, subscribe: str, multipart: bool, use_pickle: bool):
48
- """Monitor the status of a control server on hostname:port.
49
-
50
- The port number shall correspond to the port number on which the control server is publishing
51
- status information.
52
- """
53
- context = zmq.Context()
54
-
55
- receiver = context.socket(zmq.SUB)
56
- receiver.connect(f"tcp://{hostname}:{port}")
57
-
58
- for item in subscribe:
59
- sync_id = 0
60
- try:
61
- sync_id = MessageIdentifier[item.upper()]
62
- except KeyError:
63
- rich.print(f"[red]ERROR: incorrect subscribe identifier, "
64
- f"use one of {[x.name for x in MessageIdentifier]}")
65
- ctx = click.get_current_context()
66
- rich.print(ctx.get_help())
67
- ctx.exit()
68
-
69
- if sync_id == MessageIdentifier.ALL:
70
- subscribe_string = b''
71
- else:
72
- subscribe_string = sync_id.to_bytes(1, byteorder='big')
73
-
74
- receiver.subscribe(subscribe_string)
75
-
76
- while True:
77
- try:
78
- if multipart:
79
- sync_id, message = receiver.recv_multipart()
80
- sync_id = int.from_bytes(sync_id, byteorder='big')
81
- else:
82
- sync_id = MessageIdentifier.ALL
83
- message = receiver.recv()
84
- response = pickle.loads(message) if use_pickle else message
85
- rich.print(f"{MessageIdentifier(sync_id).name}, {response}", flush=True)
86
- except KeyboardInterrupt:
87
- logger.info("KeyboardInterrupt caught!")
88
- break
89
-
90
- receiver.close(linger=0)
91
- context.term()
92
-
93
- if __name__ == "__main__":
94
- multiprocessing.current_process().name = "Monitoring"
95
- monitoring()
@@ -1,26 +0,0 @@
1
- """
2
- Device control for the NI cdaq9375 that will be used at IAS for alarm manager.
3
-
4
- This package contains the classes and modules to work with the Labview code running on Windows Keynes dealing with
5
- CDAQ9375 .
6
-
7
- The main entry point for the user of this package is through the `cdaq9375Proxy` class:
8
-
9
- ```python
10
- >>> from egse.ni.alarms.cdaq9375 import cdaq9375Proxy
11
- ```
12
-
13
- This class will connect to the control server of the CDAQ 9375 Controller and provides all
14
- commands to
15
- get alarms from the 2 EGSE UPS and from TVAC and send EGSE alarms to TVAC. The control server is a small
16
- server application
17
- that is started as shown below. The control server directly connects to the cdaq9375 readout Controller
18
- through an Ethernet
19
- interface. When you have no hardware available, the control server can be started in simulator
20
- mode by appending the
21
- `--sim` string to the command below.
22
-
23
- ```bash
24
- $ python -m egse.ni.alarms.cdaq9375_cs
25
- ```
26
- """