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/proxy.py DELETED
@@ -1,522 +0,0 @@
1
- """
2
- The Proxy module provides the base class for the Proxy objects for each device
3
- controller.
4
-
5
- The module also provides the connection state interface and classes for
6
- maintaining the state of the Proxy connection to the control server.
7
- """
8
- import logging
9
- import pickle
10
- import types
11
- from types import MethodType
12
-
13
- import zmq
14
-
15
- from egse.decorators import dynamic_interface
16
- from egse.mixin import DynamicClientCommandMixin
17
- from egse.system import AttributeDict
18
- from egse.zmq_ser import split_address
19
-
20
-
21
- def set_docstring(func, cmd):
22
- """Decorator to set the docstring of the command on the dynamic method / function."""
23
-
24
- def wrap_func(*args, **kwargs):
25
- return func(*args, **kwargs)
26
-
27
- wrap_func.__doc__ = cmd.__doc__
28
- wrap_func.__name__ = f"{cmd.get_name()}"
29
- return wrap_func
30
-
31
-
32
- REQUEST_TIMEOUT = 6250
33
- REQUEST_RETRIES = 0
34
-
35
-
36
- class ControlServerConnectionInterface:
37
- """This interface defines the connection commands for control servers.
38
-
39
- This interface shall be implemented by the Proxy class and guarantees that connection commands
40
- do not interfere with the commands defined in the `DeviceConnectionInterface` (which will be
41
- loaded from the control server).
42
- """
43
-
44
- def __enter__(self):
45
- self.connect_cs()
46
- return self
47
-
48
- def __exit__(self, exc_type, exc_val, exc_tb):
49
- self.disconnect_cs()
50
-
51
- @dynamic_interface
52
- def connect_cs(self):
53
- """Connect to the control server.
54
-
55
- Raises:
56
- ConnectionError: when the connection can not be established.
57
- """
58
- raise NotImplementedError
59
-
60
- @dynamic_interface
61
- def reconnect_cs(self):
62
- """Reconnect the control server after it has been disconnected.
63
-
64
- Raises:
65
- ConnectionError: when the connection can not be established.
66
- """
67
- raise NotImplementedError
68
-
69
- @dynamic_interface
70
- def disconnect_cs(self):
71
- """Disconnect from the control server.
72
-
73
- Raises:
74
- ConnectionError: when the connection can not be closed.
75
- """
76
- raise NotImplementedError
77
-
78
- @dynamic_interface
79
- def reset_cs_connection(self):
80
- """Resets the connection to the control server."""
81
- raise NotImplementedError
82
-
83
- @dynamic_interface
84
- def is_cs_connected(self) -> bool:
85
- """Check if the control server is connected.
86
-
87
- Returns:
88
- True if the device is connected and responds to a command, False otherwise.
89
- """
90
- raise NotImplementedError
91
-
92
-
93
- class BaseProxy(ControlServerConnectionInterface):
94
- def __init__(self, endpoint, timeout: int = REQUEST_TIMEOUT):
95
- """
96
- The `timeout` argument specifies the number of milliseconds to wait for a reply from the
97
- control server.
98
- """
99
-
100
- self._logger = logging.getLogger(self.__class__.__name__)
101
-
102
- self._ctx = zmq.Context.instance()
103
- self._poller = zmq.Poller()
104
- self._socket = None
105
- self._endpoint = endpoint
106
- self._timeout = timeout
107
-
108
- self.connect_cs()
109
-
110
- def __enter__(self):
111
- if not self.ping():
112
- raise ConnectionError(f"Proxy is not connected to endpoint ({self._endpoint}) when entering the context.")
113
-
114
- return self
115
-
116
- def __exit__(self, exc_type, exc_val, exc_tb):
117
- if not self._socket.closed:
118
- self.disconnect_cs()
119
-
120
- def connect_cs(self):
121
- self._logger.log(0, f"Trying to connect {self.__class__.__name__} to {self._endpoint}")
122
-
123
- self._socket = self._ctx.socket(zmq.REQ)
124
- self._socket.connect(self._endpoint)
125
- self._poller.register(self._socket, zmq.POLLIN)
126
-
127
- def disconnect_cs(self):
128
- self._socket.setsockopt(zmq.LINGER, 0)
129
- self._socket.close()
130
- self._poller.unregister(self._socket)
131
-
132
- def reconnect_cs(self):
133
- self._logger.log(20, f"Trying to reconnect {self.__class__.__name__} to {self._endpoint}")
134
-
135
- if not self._socket.closed:
136
- self._socket.close(linger=0)
137
-
138
- self._socket = self._ctx.socket(zmq.REQ)
139
- self._socket.connect(self._endpoint)
140
- self._poller.register(self._socket, zmq.POLLIN)
141
-
142
- def reset_cs_connection(self):
143
- self._logger.log(
144
- 10, f"Trying to reset the connection from {self.__class__.__name__} to {self._endpoint}"
145
- )
146
-
147
- self.disconnect_cs()
148
- self.connect_cs()
149
-
150
- def is_cs_connected(self) -> bool:
151
- return self.ping()
152
-
153
- def send(self, data, retries: int = REQUEST_RETRIES, timeout: int = None):
154
- """
155
- Sends a command to the control server and waits for a response.
156
-
157
- When not connected to the control server or when a timeout occurs, the
158
- ``send()`` command retries a number of times to send the command.
159
-
160
- The number of retries is hardcoded and currently set to '2', the request
161
- timeout is set to 2.5 seconds.
162
-
163
- The command data will be pickled before sending. Make sure the ``data``
164
- argument can be dumped by pickle.
165
-
166
- Args:
167
- data (str): the command that is sent to the control server, usually a
168
- string, but that is not enforced.
169
- timeout (int): the time to wait for a reply [in milliseconds]
170
- retries (int): the number of time we should retry to send the message
171
-
172
- Returns:
173
- response: the response from the control server or ``None`` when there was
174
- a problem or a timeout.
175
- """
176
- timeout = timeout or self._timeout
177
-
178
- pickle_string = pickle.dumps(data)
179
-
180
- retries_left = retries
181
-
182
- # When we enter this method, we assume the Proxy has been connected. It
183
- # might be the server is not responding, but that is handled by the
184
- # algorithm below where we have a number of retries to receive the response
185
- # of the sent command. Remember that we are using ZeroMQ where the connect
186
- # method returns gracefully even when no server is available.
187
-
188
- if self._socket.closed:
189
- self.reconnect_cs()
190
-
191
- self._logger.log(0, f"Sending '{data}'")
192
- self._socket.send(pickle_string)
193
-
194
- while True:
195
- socks = dict(self._poller.poll(timeout))
196
-
197
- if self._socket in socks and socks[self._socket] == zmq.POLLIN:
198
- pickle_string = self._socket.recv()
199
- if not pickle_string:
200
- break
201
- response = pickle.loads(pickle_string)
202
- self._logger.log(0, f"Receiving response: {response}")
203
- return response
204
- else:
205
- # timeout - server unavailable
206
-
207
- # We should disconnect here because socket is possibly confused.
208
- # Close the socket and remove from the poller.
209
-
210
- self.disconnect_cs()
211
-
212
- if retries_left == 0:
213
- self._logger.critical("Control Server seems to be off-line, abandoning")
214
- return None
215
- retries_left -= 1
216
-
217
- self._logger.log(logging.CRITICAL, f"Reconnecting {self.__class__.__name__}, {retries_left=}")
218
-
219
- self.reconnect_cs()
220
-
221
- # Now try to send the request again
222
-
223
- self._socket.send(pickle_string)
224
-
225
- def ping(self):
226
- return_code = self.send("Ping", retries=0, timeout=1000)
227
- self._logger.log(0, f"Check if control server is available: Ping - {return_code}")
228
- return return_code == "Pong"
229
-
230
- def get_endpoint(self):
231
- """ Returns the endpoint."""
232
- return self._endpoint
233
-
234
- def get_monitoring_port(self) -> int:
235
- """ Returns the monitoring port. """
236
- return self.send("get_monitoring_port")
237
-
238
- def get_commanding_port(self) -> int:
239
- """ Returns the commanding port."""
240
- return self.send("get_commanding_port")
241
-
242
- def get_service_port(self) -> int:
243
- """ Returns the service port. """
244
- return self.send("get_service_port")
245
-
246
- def get_ip_address(self) -> int:
247
- """ Returns the hostname of the control server."""
248
- return self.send("get_ip_address")
249
-
250
- def get_service_proxy(self):
251
- """Return a ServiceProxy for the control server of this proxy object."""
252
- from egse.services import ServiceProxy # prevent circular import problem
253
-
254
- transport, address, _ = split_address(self._endpoint)
255
-
256
- port = self.send("get_service_port")
257
-
258
- return ServiceProxy(
259
- AttributeDict({"PROTOCOL": transport, "HOSTNAME": address, "SERVICE_PORT": port})
260
- )
261
-
262
-
263
- class DynamicProxy(BaseProxy, DynamicClientCommandMixin):
264
- def __init__(self, *args, **kwargs):
265
- super().__init__(*args, **kwargs)
266
-
267
-
268
- # TODO (rik): remove all methods from Proxy that are also define in the BaseProxy
269
-
270
- class Proxy(BaseProxy, ControlServerConnectionInterface):
271
- """
272
- A Proxy object will forward CommandExecutions to the connected control server
273
- and wait for a response. When the Proxy can not connect to its control server
274
- during initialization, a ConnectionError will be raised.
275
- """
276
-
277
- def __init__(self, endpoint, timeout: int = REQUEST_TIMEOUT):
278
- """
279
- During initialization, the Proxy will connect to the control server and send a
280
- handshaking `Ping` command. When that succeeds the Proxy will request and load the
281
- available commands from the control server. When the connection with the control server
282
- fails, no commands are loaded and the Proxy is left in a 'disconnected' state. The caller
283
- can fix the problem with the control server and call `connect_cs()`, followed by a call to
284
- `load_commands()`.
285
-
286
- The `timeout` argument specifies the number of milliseconds
287
- """
288
-
289
- super().__init__(endpoint, timeout)
290
-
291
- self._commands = {}
292
-
293
- if self.ping():
294
- self.load_commands()
295
- else:
296
- self._logger.warning(
297
- f"{self.__class__.__name__} could not connect to its control server at {endpoint}. "
298
- f"No commands have been loaded."
299
- )
300
-
301
- def __enter__(self):
302
- if not self.ping():
303
- raise ConnectionError("Proxy is not connected when entering the context.")
304
-
305
- # The following check is here because a CS might have come alive between the __init__
306
- # and __enter__ calls, and while the ping() will reconnect, the Proxy will have no
307
- # commands loaded.
308
-
309
- if not self.has_commands():
310
- self.load_commands()
311
-
312
- return self
313
-
314
- def __exit__(self, exc_type, exc_val, exc_tb):
315
- if not self._socket.closed:
316
- self.disconnect_cs()
317
-
318
- def connect_cs(self):
319
- self._logger.log(0, f"Trying to connect {self.__class__.__name__} to {self._endpoint}")
320
-
321
- self._socket = self._ctx.socket(zmq.REQ)
322
- self._socket.connect(self._endpoint)
323
- self._poller.register(self._socket, zmq.POLLIN)
324
-
325
- def disconnect_cs(self):
326
- self._socket.setsockopt(zmq.LINGER, 0)
327
- self._socket.close()
328
- self._poller.unregister(self._socket)
329
-
330
- def reconnect_cs(self):
331
- self._logger.log(20, f"Trying to reconnect {self.__class__.__name__} to {self._endpoint}")
332
-
333
- if not self._socket.closed:
334
- self._socket.close(linger=0)
335
-
336
- self._socket = self._ctx.socket(zmq.REQ)
337
- self._socket.connect(self._endpoint)
338
- self._poller.register(self._socket, zmq.POLLIN)
339
-
340
- def reset_cs_connection(self):
341
- self._logger.log(
342
- 10, f"Trying to reset the connection from {self.__class__.__name__} to {self._endpoint}"
343
- )
344
-
345
- self.disconnect_cs()
346
- self.connect_cs()
347
-
348
- def is_cs_connected(self) -> bool:
349
- return self.ping()
350
-
351
- def send(self, data, retries: int = REQUEST_RETRIES, timeout: int = None):
352
- """
353
- Sends a command to the control server and waits for a response.
354
-
355
- When not connected to the control server or when a timeout occurs, the
356
- ``send()`` command retries a number of times to send the command.
357
-
358
- The number of retries is hardcoded and currently set to '2', the request
359
- timeout is set to 2.5 seconds.
360
-
361
- The command data will be pickled before sending. Make sure the ``data``
362
- argument can be dumped by pickle.
363
-
364
- Args:
365
- data (str): the command that is sent to the control server, usually a
366
- string, but that is not enforced.
367
- timeout (int): the time to wait for a reply [in milliseconds]
368
- retries (int): the number of time we should retry to send the message
369
-
370
- Returns:
371
- response: the response from the control server or ``None`` when there was
372
- a problem or a timeout.
373
- """
374
- timeout = timeout or self._timeout
375
-
376
- pickle_string = pickle.dumps(data)
377
-
378
- retries_left = retries
379
-
380
- # When we enter this method, we assume the Proxy has been connected. It
381
- # might be the server is not responding, but that is handled by the
382
- # algorithm below where we have a number of retries to receive the response
383
- # of the sent command. Remember that we are using ZeroMQ where the connect
384
- # method returns gracefully even when no server is available.
385
-
386
- if self._socket.closed:
387
- self.reconnect_cs()
388
-
389
- self._logger.log(0, f"Sending '{data}'")
390
- self._socket.send(pickle_string)
391
-
392
- while True:
393
- socks = dict(self._poller.poll(timeout))
394
-
395
- if self._socket in socks and socks[self._socket] == zmq.POLLIN:
396
- pickle_string = self._socket.recv()
397
- if not pickle_string:
398
- break
399
- response = pickle.loads(pickle_string)
400
- self._logger.log(0, f"Receiving response: {response}")
401
- return response
402
- else:
403
- # timeout - server unavailable
404
-
405
- # We should disconnect here because socket is possibly confused.
406
- # Close the socket and remove from the poller.
407
-
408
- self.disconnect_cs()
409
-
410
- if retries_left == 0:
411
- self._logger.critical(f"Control Server seems to be off-line, abandoning ({data})")
412
- return None
413
- retries_left -= 1
414
-
415
- self._logger.log(logging.CRITICAL, f"Reconnecting {self.__class__.__name__}, {retries_left=}")
416
-
417
- self.reconnect_cs()
418
-
419
- # Now try to send the request again
420
-
421
- self._socket.send(pickle_string)
422
-
423
- def _request_commands(self):
424
- self._commands = self.send("send_commands")
425
-
426
- def _add_commands(self):
427
- for key in self._commands:
428
- if hasattr(self, key):
429
- attribute = getattr(self, key)
430
- if isinstance(attribute, types.MethodType) and not hasattr(
431
- attribute, "__dynamic_interface"
432
- ):
433
- self._logger.warning(
434
- f"{self.__class__.__name__} already has an attribute '{key}', "
435
- f"not overwriting."
436
- )
437
- continue
438
- command = self._commands[key]
439
- new_method = MethodType(command.client_call, self)
440
- new_method = set_docstring(new_method, command)
441
- setattr(self, key, new_method)
442
-
443
- def get_service_proxy(self):
444
- """Return a ServiceProxy for the control server of this proxy object."""
445
- from egse.services import ServiceProxy # prevent circular import problem
446
-
447
- transport, address, _ = split_address(self._endpoint)
448
-
449
- port = self.send("get_service_port")
450
-
451
- return ServiceProxy(
452
- AttributeDict({"PROTOCOL": transport, "HOSTNAME": address, "SERVICE_PORT": port})
453
- )
454
-
455
- def load_commands(self):
456
- """
457
- Requests all available commands from the control server and adds them to
458
- the Proxy public interface, i.e. each command will become a method for
459
- this Proxy.
460
-
461
- A warning will be issued when a command will overwrite an existing method
462
- of the Proxy class. The original method will not be overwritten and the
463
- behavior of the Proxy command will not be what is expected.
464
- """
465
- # bind the client_call method from each Command to this Proxy object
466
- # TODO(rik): what will happen when the _request_commands() fails?
467
- if self.is_cs_connected():
468
- self._request_commands()
469
- self._add_commands()
470
- return True
471
- else:
472
- self._logger.warning(f"{self.__class__.__name__} is not connected, try to reconnect.")
473
- return False
474
-
475
- def get_commands(self):
476
- """
477
- Returns a list of command names that can be send to the device or the
478
- control server.
479
-
480
- The commands are defined in the YAML settings file of the device.
481
- Special commands are available for the ServiceProxy which configure and
482
- control the control servers.
483
- """
484
- return list(self._commands.keys())
485
-
486
- def has_commands(self):
487
- """Return `True` if commands have been loaded."""
488
- return bool(self._commands)
489
-
490
- def ping(self):
491
- return_code = self.send("Ping", retries=0, timeout=1000)
492
- self._logger.log(0, f"Check if control server is available: Ping - {return_code}")
493
- return return_code == "Pong"
494
-
495
- def get_endpoint(self):
496
- """ Returns the endpoint.
497
-
498
- Returns:
499
- - Endpoint.
500
- """
501
-
502
- return self._endpoint
503
-
504
- def get_monitoring_port(self) -> int:
505
- """ Returns the monitoring port. """
506
-
507
- return self.send("get_monitoring_port")
508
-
509
- def get_commanding_port(self) -> int:
510
- """ Returns the commanding port."""
511
-
512
- return self.send("get_commanding_port")
513
-
514
- def get_service_port(self) -> int:
515
- """ Returns the service port. """
516
-
517
- return self.send("get_service_port")
518
-
519
- def get_ip_address(self) -> int:
520
- """ Returns the hostname of the control server."""
521
-
522
- return self.send("get_ip_address")
egse/randomwalk.py DELETED
@@ -1,140 +0,0 @@
1
- """
2
- This module implements a random walk that can be used in simulators for devices like temperature sensors or power meter.
3
- """
4
- from __future__ import annotations
5
-
6
- import random
7
- import sys
8
- from typing import Optional
9
-
10
-
11
- # Re-implement based on:
12
- #
13
- # 1. https://isquared.digital/blog/2020-04-12-random-walk/
14
- # 2. https://isquared.digital/blog/2020-04-16-brownian-motion/
15
- # 3. https://isquared.digital/blog/2020-05-01-drifted-brownian-motion/
16
-
17
- class RandomWalk:
18
- """
19
- This class implements a random walk.
20
-
21
- The RandomWalk is an iterator which can be used in a for loop:
22
-
23
- ```Python
24
- import matplotlib.pyplot as plt
25
- values = [value for value in RandomWalk(start=15.0, boundary=(-100, 25), scale=0.01, count=10000)]
26
- plt.plot(values)
27
- plt.show()
28
- ```
29
-
30
- The code above will create a plot like below, where 10000 values are plot in a random walk between -100 and 25,
31
- starting at 15:
32
-
33
- ![Random Walk example](../../img/screenshot-randomwalk.png)
34
-
35
- When you need a random walk that will return values infinitely, set count = 0.
36
-
37
- By default, the returned values will represent a random walk between -1.0 and 1.0 in a step of 1.0.
38
- """
39
- def __init__(self, start: float = 0.0, boundary: tuple = (-1.0, 1.0), threshold: tuple | float = 0.5,
40
- scale: float = 1.0, count: int = 1000, seed: Optional[int] = None):
41
- """
42
-
43
- Args:
44
- start: the start value for the random walk [default = 0.0]
45
- boundary: the lower and upper boundaries [default = (-1.0, 1.0)]
46
- threshold: the probability to move up or down [default = 0.5]
47
- scale: scale the step size [default = 1.0]
48
- count: the number of iterations, when <= 0 count will be basically infinite [default = 1000]
49
- seed: seed for the initialization of the random generator [default = None]
50
- """
51
- self._threshold_up = threshold[1] if isinstance(threshold, tuple) else threshold
52
- self._threshold_down = threshold[0] if isinstance(threshold, tuple) else threshold
53
- self._boundary = boundary
54
- self._min_value, self._max_value = boundary
55
- self._count = count if count > 0 else sys.maxsize
56
- self._start = start
57
- self._last = start
58
- self._scale = scale
59
- self._seed = seed
60
- self._random = random.Random()
61
-
62
- if seed is not None:
63
- self._random.seed(seed)
64
-
65
- def __iter__(self):
66
- return self
67
-
68
- def __next__(self):
69
- if self._count > 0:
70
- probability = self._random.random()
71
- if probability > self._threshold_up:
72
- value = self._last + self._scale
73
- value = min(value, self._max_value)
74
- elif probability < self._threshold_down:
75
- value = self._last - self._scale
76
- value = max(value, self._min_value)
77
- else:
78
- value = self._last
79
- self._last = value
80
- self._count -= 1
81
- return value
82
- raise StopIteration
83
-
84
-
85
- if __name__ == "__main__":
86
-
87
- # https://towardsdatascience.com/generating-synthetic-time-series-data-with-random-walks-8701bb9a56a8
88
-
89
- import matplotlib.pyplot as plt
90
-
91
- # Random Walk, each time a different seed by default
92
-
93
- y1 = RandomWalk(start=50.0, boundary=(0, 100), threshold=(0.25, 0.70), scale=1, count=1000)
94
- # y2 = RandomWalk(start=50.0, boundary=(0, 100), threshold=0.49, scale=0.05, count=100000, seed=0)
95
- # y3 = RandomWalk(start=50.0, boundary=(0, 100), threshold=0.48, scale=0.01, count=100000, seed=0)
96
- # plt.plot(list(zip(y1, y2, y3)))
97
- plt.plot(list(y1))
98
- plt.show()
99
-
100
- y1 = RandomWalk(start=50.0, boundary=(0, 100), threshold=0.5, scale=0.2, count=100000, seed=0)
101
- y2 = RandomWalk(start=50.0, boundary=(0, 100), threshold=0.51, scale=0.2, count=100000, seed=0)
102
- y3 = RandomWalk(start=50.0, boundary=(0, 100), threshold=0.52, scale=0.2, count=100000, seed=0)
103
- plt.plot(list(zip(y1, y2, y3)))
104
- plt.show()
105
-
106
- y1 = RandomWalk(start=75.0, boundary=(0, 100), threshold=0.5, scale=0.2, count=100000, seed=0)
107
- y2 = RandomWalk(start=50.0, boundary=(0, 100), threshold=0.5, scale=0.2, count=100000, seed=0)
108
- y3 = RandomWalk(start=25.0, boundary=(0, 100), threshold=0.5, scale=0.2, count=100000, seed=0)
109
- plt.plot(list(zip(y1, y2, y3)))
110
- plt.show()
111
-
112
- # Three random walks, two of them are fixed and reproducible
113
-
114
- rng1 = RandomWalk(start=15.0, boundary=(-20, 25), scale=0.8, count=10000, seed=1)
115
- rng2 = RandomWalk(start=15.0, boundary=(-20, 25), scale=0.5, count=10000, seed=1)
116
- rng3 = RandomWalk(start=15.0, boundary=(-20, 25), scale=0.3, count=10000, seed=1)
117
-
118
- values = list(zip(rng1, rng2, rng3))
119
- plt.plot(values)
120
- plt.ylim(-20, 25)
121
- plt.show()
122
-
123
- # Example 1:
124
-
125
- rw = RandomWalk(start=25.0, boundary=(-100, 100), scale=0.2, count=0, seed=42)
126
- values = [next(rw) for _ in range(1000000)]
127
- plt.plot(values)
128
- plt.show()
129
-
130
- # Example 2: should give the same output as example 1
131
-
132
- plt.plot(
133
- list(RandomWalk(start=25.0, boundary=(-100, 100), scale=0.2, count=1000000, seed=42,))
134
- )
135
- plt.show()
136
-
137
- # Example 3:
138
-
139
- for i, value in enumerate(RandomWalk(start=25.0, boundary=(-100, 100), threshold=0.5, scale=2, count=20)):
140
- print(f"{i}, {value}")