cgse 2024.7.0__py3-none-any.whl → 2025.0.2__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (664) hide show
  1. README.md +27 -0
  2. bump.py +85 -0
  3. cgse-2025.0.2.dist-info/METADATA +38 -0
  4. cgse-2025.0.2.dist-info/RECORD +5 -0
  5. {cgse-2024.7.0.dist-info → cgse-2025.0.2.dist-info}/WHEEL +1 -2
  6. cgse-2024.7.0.dist-info/COPYING +0 -674
  7. cgse-2024.7.0.dist-info/COPYING.LESSER +0 -165
  8. cgse-2024.7.0.dist-info/METADATA +0 -144
  9. cgse-2024.7.0.dist-info/RECORD +0 -660
  10. cgse-2024.7.0.dist-info/entry_points.txt +0 -75
  11. cgse-2024.7.0.dist-info/top_level.txt +0 -2
  12. egse/__init__.py +0 -12
  13. egse/__main__.py +0 -32
  14. egse/aeu/aeu.py +0 -5238
  15. egse/aeu/aeu_awg.yaml +0 -265
  16. egse/aeu/aeu_crio.yaml +0 -273
  17. egse/aeu/aeu_cs.py +0 -627
  18. egse/aeu/aeu_devif.py +0 -321
  19. egse/aeu/aeu_main_ui.py +0 -903
  20. egse/aeu/aeu_metrics.py +0 -131
  21. egse/aeu/aeu_protocol.py +0 -463
  22. egse/aeu/aeu_psu.yaml +0 -204
  23. egse/aeu/aeu_ui.py +0 -873
  24. egse/aeu/arbdata/FccdRead.arb +0 -2
  25. egse/aeu/arbdata/FccdRead_min_points.arb +0 -2
  26. egse/aeu/arbdata/HeaterSync_FccdRead.arb +0 -2
  27. egse/aeu/arbdata/HeaterSync_ccdRead25.arb +0 -2
  28. egse/aeu/arbdata/HeaterSync_ccdRead31_25.arb +0 -2
  29. egse/aeu/arbdata/HeaterSync_ccdRead37_50.arb +0 -2
  30. egse/aeu/arbdata/HeaterSync_ccdRead43_75.arb +0 -2
  31. egse/aeu/arbdata/HeaterSync_ccdRead50.arb +0 -2
  32. egse/aeu/arbdata/Heater_FccdRead_min_points.arb +0 -2
  33. egse/aeu/arbdata/ccdRead25.arb +0 -2
  34. egse/aeu/arbdata/ccdRead25_150ms.arb +0 -2
  35. egse/aeu/arbdata/ccdRead31_25.arb +0 -2
  36. egse/aeu/arbdata/ccdRead31_25_150ms.arb +0 -2
  37. egse/aeu/arbdata/ccdRead37_50.arb +0 -2
  38. egse/aeu/arbdata/ccdRead37_50_150ms.arb +0 -2
  39. egse/aeu/arbdata/ccdRead43_75.arb +0 -2
  40. egse/aeu/arbdata/ccdRead43_75_150ms.arb +0 -2
  41. egse/aeu/arbdata/ccdRead50.arb +0 -2
  42. egse/aeu/arbdata/ccdRead50_150ms.arb +0 -2
  43. egse/alert/__init__.py +0 -1049
  44. egse/alert/alertman.yaml +0 -37
  45. egse/alert/alertman_cs.py +0 -233
  46. egse/alert/alertman_ui.py +0 -600
  47. egse/alert/gsm/beaglebone.py +0 -138
  48. egse/alert/gsm/beaglebone.yaml +0 -51
  49. egse/alert/gsm/beaglebone_cs.py +0 -108
  50. egse/alert/gsm/beaglebone_devif.py +0 -122
  51. egse/alert/gsm/beaglebone_protocol.py +0 -46
  52. egse/bits.py +0 -318
  53. egse/camera.py +0 -44
  54. egse/collimator/__init__.py +0 -0
  55. egse/collimator/fcul/__init__.py +0 -0
  56. egse/collimator/fcul/ogse.py +0 -1077
  57. egse/collimator/fcul/ogse.yaml +0 -14
  58. egse/collimator/fcul/ogse_cs.py +0 -154
  59. egse/collimator/fcul/ogse_devif.py +0 -358
  60. egse/collimator/fcul/ogse_protocol.py +0 -132
  61. egse/collimator/fcul/ogse_sim.py +0 -431
  62. egse/collimator/fcul/ogse_ui.py +0 -1108
  63. egse/command.py +0 -699
  64. egse/config.py +0 -410
  65. egse/confman/__init__.py +0 -1058
  66. egse/confman/confman.yaml +0 -70
  67. egse/confman/confman_cs.py +0 -240
  68. egse/confman/confman_ui.py +0 -381
  69. egse/confman/setup_ui.py +0 -565
  70. egse/control.py +0 -632
  71. egse/coordinates/__init__.py +0 -534
  72. egse/coordinates/avoidance.py +0 -100
  73. egse/coordinates/cslmodel.py +0 -127
  74. egse/coordinates/laser_tracker_to_dict.py +0 -122
  75. egse/coordinates/point.py +0 -707
  76. egse/coordinates/pyplot.py +0 -194
  77. egse/coordinates/referenceFrame.py +0 -1279
  78. egse/coordinates/refmodel.py +0 -737
  79. egse/coordinates/rotationMatrix.py +0 -85
  80. egse/coordinates/transform3d_addon.py +0 -419
  81. egse/csl/__init__.py +0 -50
  82. egse/csl/commanding.py +0 -78
  83. egse/csl/icons/hexapod-connected-selected.svg +0 -30
  84. egse/csl/icons/hexapod-connected.svg +0 -30
  85. egse/csl/icons/hexapod-homing-selected.svg +0 -68
  86. egse/csl/icons/hexapod-homing.svg +0 -68
  87. egse/csl/icons/hexapod-retract-selected.svg +0 -56
  88. egse/csl/icons/hexapod-retract.svg +0 -51
  89. egse/csl/icons/hexapod-zero-selected.svg +0 -56
  90. egse/csl/icons/hexapod-zero.svg +0 -56
  91. egse/csl/icons/logo-puna.svg +0 -92
  92. egse/csl/icons/stop.svg +0 -1
  93. egse/csl/initialisation.py +0 -102
  94. egse/csl/mech_pos_settings.yaml +0 -18
  95. egse/das.py +0 -1240
  96. egse/das.yaml +0 -7
  97. egse/data/conf/SETUP_CSL_00000_170620_150000.yaml +0 -5
  98. egse/data/conf/SETUP_CSL_00001_170620_151010.yaml +0 -69
  99. egse/data/conf/SETUP_CSL_00002_170620_151020.yaml +0 -69
  100. egse/data/conf/SETUP_CSL_00003_170620_151030.yaml +0 -69
  101. egse/data/conf/SETUP_CSL_00004_170620_151040.yaml +0 -69
  102. egse/data/conf/SETUP_CSL_00005_170620_151050.yaml +0 -69
  103. egse/data/conf/SETUP_CSL_00006_170620_151060.yaml +0 -69
  104. egse/data/conf/SETUP_CSL_00007_170620_151070.yaml +0 -69
  105. egse/data/conf/SETUP_CSL_00008_170620_151080.yaml +0 -75
  106. egse/data/conf/SETUP_CSL_00010_210308_083016.yaml +0 -138
  107. egse/data/conf/SETUP_INTA_00000_170620_150000.yaml +0 -4
  108. egse/data/conf/SETUP_SRON_00000_170620_150000.yaml +0 -4
  109. egse/decorators.py +0 -514
  110. egse/device.py +0 -269
  111. egse/dpu/__init__.py +0 -2698
  112. egse/dpu/ccd_ui.py +0 -514
  113. egse/dpu/dpu.py +0 -783
  114. egse/dpu/dpu.yaml +0 -153
  115. egse/dpu/dpu_cs.py +0 -272
  116. egse/dpu/dpu_ui.py +0 -671
  117. egse/dpu/fitsgen.py +0 -2096
  118. egse/dpu/fitsgen_ui.py +0 -399
  119. egse/dpu/hdf5_model.py +0 -332
  120. egse/dpu/hdf5_ui.py +0 -277
  121. egse/dpu/hdf5_viewer.py +0 -506
  122. egse/dpu/hk_ui.py +0 -468
  123. egse/dpu_commands.py +0 -81
  124. egse/dsi/__init__.py +0 -33
  125. egse/dsi/_libesl.py +0 -232
  126. egse/dsi/constants.py +0 -296
  127. egse/dsi/esl.py +0 -630
  128. egse/dsi/rmap.py +0 -444
  129. egse/dsi/rmapci.py +0 -39
  130. egse/dsi/spw.py +0 -335
  131. egse/dsi/spw_state.py +0 -29
  132. egse/dummy.py +0 -318
  133. egse/dyndummy.py +0 -179
  134. egse/env.py +0 -278
  135. egse/exceptions.py +0 -88
  136. egse/fdir/__init__.py +0 -26
  137. egse/fdir/fdir_manager.py +0 -85
  138. egse/fdir/fdir_manager.yaml +0 -37
  139. egse/fdir/fdir_manager_controller.py +0 -136
  140. egse/fdir/fdir_manager_cs.py +0 -164
  141. egse/fdir/fdir_manager_interface.py +0 -15
  142. egse/fdir/fdir_remote.py +0 -73
  143. egse/fdir/fdir_remote.yaml +0 -30
  144. egse/fdir/fdir_remote_controller.py +0 -30
  145. egse/fdir/fdir_remote_cs.py +0 -94
  146. egse/fdir/fdir_remote_interface.py +0 -9
  147. egse/fdir/fdir_remote_popup.py +0 -26
  148. egse/fee/__init__.py +0 -106
  149. egse/fee/f_fee_register.yaml +0 -43
  150. egse/fee/feesim.py +0 -914
  151. egse/fee/n_fee_hk.py +0 -768
  152. egse/fee/nfee.py +0 -188
  153. egse/filterwheel/__init__.py +0 -4
  154. egse/filterwheel/eksma/__init__.py +0 -49
  155. egse/filterwheel/eksma/fw8smc4.py +0 -657
  156. egse/filterwheel/eksma/fw8smc4.yaml +0 -121
  157. egse/filterwheel/eksma/fw8smc4_cs.py +0 -144
  158. egse/filterwheel/eksma/fw8smc4_devif.py +0 -473
  159. egse/filterwheel/eksma/fw8smc4_protocol.py +0 -82
  160. egse/filterwheel/eksma/fw8smc4_ui.py +0 -940
  161. egse/filterwheel/eksma/fw8smc5.py +0 -115
  162. egse/filterwheel/eksma/fw8smc5.yaml +0 -105
  163. egse/filterwheel/eksma/fw8smc5_controller.py +0 -307
  164. egse/filterwheel/eksma/fw8smc5_cs.py +0 -141
  165. egse/filterwheel/eksma/fw8smc5_interface.py +0 -65
  166. egse/filterwheel/eksma/fw8smc5_simulator.py +0 -29
  167. egse/filterwheel/eksma/fw8smc5_ui.py +0 -1065
  168. egse/filterwheel/eksma/testpythonfw.py +0 -215
  169. egse/fov/__init__.py +0 -65
  170. egse/fov/fov_hk.py +0 -710
  171. egse/fov/fov_ui.py +0 -859
  172. egse/fov/fov_ui_controller.py +0 -140
  173. egse/fov/fov_ui_model.py +0 -200
  174. egse/fov/fov_ui_view.py +0 -345
  175. egse/gimbal/__init__.py +0 -32
  176. egse/gimbal/symetrie/__init__.py +0 -26
  177. egse/gimbal/symetrie/alpha.py +0 -586
  178. egse/gimbal/symetrie/generic_gimbal_ui.py +0 -1521
  179. egse/gimbal/symetrie/gimbal.py +0 -877
  180. egse/gimbal/symetrie/gimbal.yaml +0 -168
  181. egse/gimbal/symetrie/gimbal_cs.py +0 -183
  182. egse/gimbal/symetrie/gimbal_protocol.py +0 -138
  183. egse/gimbal/symetrie/gimbal_ui.py +0 -361
  184. egse/gimbal/symetrie/pmac.py +0 -1006
  185. egse/gimbal/symetrie/pmac_regex.py +0 -83
  186. egse/graph.py +0 -132
  187. egse/gui/__init__.py +0 -47
  188. egse/gui/buttons.py +0 -378
  189. egse/gui/focalplane.py +0 -1285
  190. egse/gui/formatter.py +0 -10
  191. egse/gui/led.py +0 -162
  192. egse/gui/limitswitch.py +0 -143
  193. egse/gui/mechanisms.py +0 -587
  194. egse/gui/states.py +0 -148
  195. egse/gui/stripchart.py +0 -729
  196. egse/gui/styles.qss +0 -48
  197. egse/gui/switch.py +0 -112
  198. egse/h5.py +0 -274
  199. egse/help/__init__.py +0 -0
  200. egse/help/help_ui.py +0 -126
  201. egse/hexapod/__init__.py +0 -32
  202. egse/hexapod/symetrie/__init__.py +0 -137
  203. egse/hexapod/symetrie/alpha.py +0 -874
  204. egse/hexapod/symetrie/dynalpha.py +0 -1387
  205. egse/hexapod/symetrie/hexapod_ui.py +0 -1516
  206. egse/hexapod/symetrie/pmac.py +0 -1010
  207. egse/hexapod/symetrie/pmac_regex.py +0 -83
  208. egse/hexapod/symetrie/puna.py +0 -1167
  209. egse/hexapod/symetrie/puna.yaml +0 -193
  210. egse/hexapod/symetrie/puna_cs.py +0 -195
  211. egse/hexapod/symetrie/puna_protocol.py +0 -134
  212. egse/hexapod/symetrie/puna_ui.py +0 -433
  213. egse/hexapod/symetrie/punaplus.py +0 -107
  214. egse/hexapod/symetrie/zonda.py +0 -872
  215. egse/hexapod/symetrie/zonda.yaml +0 -337
  216. egse/hexapod/symetrie/zonda_cs.py +0 -172
  217. egse/hexapod/symetrie/zonda_devif.py +0 -414
  218. egse/hexapod/symetrie/zonda_protocol.py +0 -123
  219. egse/hexapod/symetrie/zonda_ui.py +0 -449
  220. egse/hk.py +0 -791
  221. egse/icons/aeu-cs-start.svg +0 -117
  222. egse/icons/aeu-cs-stop.svg +0 -118
  223. egse/icons/aeu-cs.svg +0 -107
  224. egse/icons/aeu_cs-started.svg +0 -112
  225. egse/icons/aeu_cs-stopped.svg +0 -112
  226. egse/icons/aeu_cs.svg +0 -55
  227. egse/icons/alert.svg +0 -1
  228. egse/icons/arrow-double-left.png +0 -0
  229. egse/icons/arrow-double-right.png +0 -0
  230. egse/icons/arrow-up.svg +0 -11
  231. egse/icons/backward.svg +0 -1
  232. egse/icons/busy.svg +0 -1
  233. egse/icons/cleaning.svg +0 -115
  234. egse/icons/color-scheme.svg +0 -1
  235. egse/icons/cs-connected-alert.svg +0 -91
  236. egse/icons/cs-connected-disabled.svg +0 -43
  237. egse/icons/cs-connected.svg +0 -89
  238. egse/icons/cs-not-connected.svg +0 -44
  239. egse/icons/double-left-arrow.svg +0 -1
  240. egse/icons/double-right-arrow.svg +0 -1
  241. egse/icons/erase-disabled.svg +0 -19
  242. egse/icons/erase.svg +0 -59
  243. egse/icons/fitsgen-start.svg +0 -47
  244. egse/icons/fitsgen-stop.svg +0 -48
  245. egse/icons/fitsgen.svg +0 -1
  246. egse/icons/forward.svg +0 -1
  247. egse/icons/fov-hk-start.svg +0 -33
  248. egse/icons/fov-hk-stop.svg +0 -37
  249. egse/icons/fov-hk.svg +0 -1
  250. egse/icons/front-desk.svg +0 -1
  251. egse/icons/home-actioned.svg +0 -15
  252. egse/icons/home-disabled.svg +0 -15
  253. egse/icons/home.svg +0 -13
  254. egse/icons/info.svg +0 -1
  255. egse/icons/invalid.png +0 -0
  256. egse/icons/led-green.svg +0 -20
  257. egse/icons/led-grey.svg +0 -20
  258. egse/icons/led-orange.svg +0 -20
  259. egse/icons/led-red.svg +0 -20
  260. egse/icons/led-square-green.svg +0 -134
  261. egse/icons/led-square-grey.svg +0 -134
  262. egse/icons/led-square-orange.svg +0 -134
  263. egse/icons/led-square-red.svg +0 -134
  264. egse/icons/limit-switch-all-green.svg +0 -115
  265. egse/icons/limit-switch-all-red.svg +0 -117
  266. egse/icons/limit-switch-el+.svg +0 -116
  267. egse/icons/limit-switch-el-.svg +0 -117
  268. egse/icons/location-marker.svg +0 -1
  269. egse/icons/logo-dpu.svg +0 -48
  270. egse/icons/logo-gimbal.svg +0 -112
  271. egse/icons/logo-huber.svg +0 -23
  272. egse/icons/logo-ogse.svg +0 -31
  273. egse/icons/logo-puna.svg +0 -92
  274. egse/icons/logo-tcs.svg +0 -29
  275. egse/icons/logo-zonda.svg +0 -66
  276. egse/icons/maximize.svg +0 -1
  277. egse/icons/meter.svg +0 -1
  278. egse/icons/more.svg +0 -45
  279. egse/icons/n-fee-hk-start.svg +0 -24
  280. egse/icons/n-fee-hk-stop.svg +0 -25
  281. egse/icons/n-fee-hk.svg +0 -83
  282. egse/icons/observing-off.svg +0 -46
  283. egse/icons/observing-on.svg +0 -46
  284. egse/icons/open-document-hdf5.png +0 -0
  285. egse/icons/open-document-hdf5.svg +0 -21
  286. egse/icons/ops-mode.svg +0 -1
  287. egse/icons/play-green.svg +0 -17
  288. egse/icons/plugged-disabled.svg +0 -27
  289. egse/icons/plugged.svg +0 -21
  290. egse/icons/pm_ui.svg +0 -1
  291. egse/icons/power-button-green.svg +0 -27
  292. egse/icons/power-button-red.svg +0 -27
  293. egse/icons/power-button.svg +0 -27
  294. egse/icons/radar.svg +0 -1
  295. egse/icons/radioactive.svg +0 -2
  296. egse/icons/reload.svg +0 -1
  297. egse/icons/remote-control-off.svg +0 -28
  298. egse/icons/remote-control-on.svg +0 -28
  299. egse/icons/repeat-blue.svg +0 -15
  300. egse/icons/repeat.svg +0 -1
  301. egse/icons/settings.svg +0 -1
  302. egse/icons/shrink.svg +0 -1
  303. egse/icons/shutter.svg +0 -1
  304. egse/icons/sign-off.svg +0 -1
  305. egse/icons/sign-on.svg +0 -1
  306. egse/icons/sim-mode.svg +0 -1
  307. egse/icons/small-buttons-go.svg +0 -20
  308. egse/icons/small-buttons-minus.svg +0 -51
  309. egse/icons/small-buttons-plus.svg +0 -51
  310. egse/icons/sponge.svg +0 -220
  311. egse/icons/start-button-disabled.svg +0 -84
  312. egse/icons/start-button.svg +0 -50
  313. egse/icons/stop-button-disabled.svg +0 -84
  314. egse/icons/stop-button.svg +0 -50
  315. egse/icons/stop-red.svg +0 -17
  316. egse/icons/stop.svg +0 -1
  317. egse/icons/switch-disabled-square.svg +0 -87
  318. egse/icons/switch-disabled.svg +0 -15
  319. egse/icons/switch-off-square.svg +0 -87
  320. egse/icons/switch-off.svg +0 -72
  321. egse/icons/switch-on-square.svg +0 -87
  322. egse/icons/switch-on.svg +0 -61
  323. egse/icons/temperature-control.svg +0 -44
  324. egse/icons/th_ui_logo.svg +0 -1
  325. egse/icons/unplugged.svg +0 -23
  326. egse/icons/unvalid.png +0 -0
  327. egse/icons/user-interface.svg +0 -1
  328. egse/icons/vacuum.svg +0 -1
  329. egse/icons/valid.png +0 -0
  330. egse/icons/zoom-to-pixel-dark.svg +0 -64
  331. egse/icons/zoom-to-pixel-white.svg +0 -36
  332. egse/images/big-rotation-stage.png +0 -0
  333. egse/images/connected-100.png +0 -0
  334. egse/images/cross.svg +0 -6
  335. egse/images/disconnected-100.png +0 -0
  336. egse/images/gui-icon.png +0 -0
  337. egse/images/home.svg +0 -6
  338. egse/images/info-icon.png +0 -0
  339. egse/images/led-black.svg +0 -89
  340. egse/images/led-green.svg +0 -85
  341. egse/images/led-orange.svg +0 -85
  342. egse/images/led-red.svg +0 -85
  343. egse/images/load-icon.png +0 -0
  344. egse/images/load-setup.png +0 -0
  345. egse/images/load.png +0 -0
  346. egse/images/pause.png +0 -0
  347. egse/images/play-button.svg +0 -8
  348. egse/images/play.png +0 -0
  349. egse/images/process-status.png +0 -0
  350. egse/images/restart.png +0 -0
  351. egse/images/search.png +0 -0
  352. egse/images/sma.png +0 -0
  353. egse/images/start.png +0 -0
  354. egse/images/stop-button.svg +0 -8
  355. egse/images/stop.png +0 -0
  356. egse/images/switch-off.svg +0 -48
  357. egse/images/switch-on.svg +0 -48
  358. egse/images/undo.png +0 -0
  359. egse/images/update-button.svg +0 -11
  360. egse/imageviewer/exposureselection.py +0 -475
  361. egse/imageviewer/imageviewer.py +0 -198
  362. egse/imageviewer/matchfocalplane.py +0 -179
  363. egse/imageviewer/subfieldposition.py +0 -133
  364. egse/lampcontrol/__init__.py +0 -4
  365. egse/lampcontrol/beaglebone/beaglebone.py +0 -178
  366. egse/lampcontrol/beaglebone/beaglebone.yaml +0 -62
  367. egse/lampcontrol/beaglebone/beaglebone_cs.py +0 -106
  368. egse/lampcontrol/beaglebone/beaglebone_devif.py +0 -150
  369. egse/lampcontrol/beaglebone/beaglebone_protocol.py +0 -73
  370. egse/lampcontrol/energetiq/__init__.py +0 -22
  371. egse/lampcontrol/energetiq/eq99.yaml +0 -98
  372. egse/lampcontrol/energetiq/lampEQ99.py +0 -283
  373. egse/lampcontrol/energetiq/lampEQ99_cs.py +0 -128
  374. egse/lampcontrol/energetiq/lampEQ99_devif.py +0 -158
  375. egse/lampcontrol/energetiq/lampEQ99_encode_decode_errors.py +0 -73
  376. egse/lampcontrol/energetiq/lampEQ99_protocol.py +0 -71
  377. egse/lampcontrol/energetiq/lampEQ99_ui.py +0 -465
  378. egse/lib/CentOS-7/EtherSpaceLink_v34_86.dylib +0 -0
  379. egse/lib/CentOS-8/ESL-RMAP_v34_86.dylib +0 -0
  380. egse/lib/CentOS-8/EtherSpaceLink_v34_86.dylib +0 -0
  381. egse/lib/Debian/ESL-RMAP_v34_86.dylib +0 -0
  382. egse/lib/Debian/EtherSpaceLink_v34_86.dylib +0 -0
  383. egse/lib/Debian/libetherspacelink_v35_21.dylib +0 -0
  384. egse/lib/Linux/ESL-RMAP_v34_86.dylib +0 -0
  385. egse/lib/Linux/EtherSpaceLink_v34_86.dylib +0 -0
  386. egse/lib/Ubuntu-20/ESL-RMAP_v34_86.dylib +0 -0
  387. egse/lib/Ubuntu-20/EtherSpaceLink_v34_86.dylib +0 -0
  388. egse/lib/gssw/python3-gssw_2.2.3+31f63c9f-1_all.deb +0 -0
  389. egse/lib/ximc/__pycache__/pyximc.cpython-38 2.pyc +0 -0
  390. egse/lib/ximc/__pycache__/pyximc.cpython-38.pyc +0 -0
  391. egse/lib/ximc/libximc.framework/Frameworks/libbindy.dylib +0 -0
  392. egse/lib/ximc/libximc.framework/Frameworks/libxiwrapper.dylib +0 -0
  393. egse/lib/ximc/libximc.framework/Headers/ximc.h +0 -5510
  394. egse/lib/ximc/libximc.framework/Resources/Info.plist +0 -42
  395. egse/lib/ximc/libximc.framework/Resources/keyfile.sqlite +0 -0
  396. egse/lib/ximc/libximc.framework/libbindy.so +0 -0
  397. egse/lib/ximc/libximc.framework/libximc +0 -0
  398. egse/lib/ximc/libximc.framework/libximc.so +0 -0
  399. egse/lib/ximc/libximc.framework/libximc.so.7.0.0 +0 -0
  400. egse/lib/ximc/libximc.framework/libxiwrapper.so +0 -0
  401. egse/lib/ximc/pyximc.py +0 -922
  402. egse/listener.py +0 -179
  403. egse/logger/__init__.py +0 -243
  404. egse/logger/log_cs.py +0 -321
  405. egse/metrics.py +0 -102
  406. egse/mixin.py +0 -464
  407. egse/monitoring.py +0 -95
  408. egse/ni/alarms/__init__.py +0 -26
  409. egse/ni/alarms/cdaq9375.py +0 -300
  410. egse/ni/alarms/cdaq9375.yaml +0 -89
  411. egse/ni/alarms/cdaq9375_cs.py +0 -130
  412. egse/ni/alarms/cdaq9375_devif.py +0 -183
  413. egse/ni/alarms/cdaq9375_protocol.py +0 -48
  414. egse/obs_inspection.py +0 -165
  415. egse/observer.py +0 -41
  416. egse/obsid.py +0 -163
  417. egse/powermeter/__init__.py +0 -0
  418. egse/powermeter/ni/__init__.py +0 -38
  419. egse/powermeter/ni/cdaq9184.py +0 -224
  420. egse/powermeter/ni/cdaq9184.yaml +0 -73
  421. egse/powermeter/ni/cdaq9184_cs.py +0 -130
  422. egse/powermeter/ni/cdaq9184_devif.py +0 -201
  423. egse/powermeter/ni/cdaq9184_protocol.py +0 -48
  424. egse/powermeter/ni/cdaq9184_ui.py +0 -544
  425. egse/powermeter/thorlabs/__init__.py +0 -25
  426. egse/powermeter/thorlabs/pm100a.py +0 -380
  427. egse/powermeter/thorlabs/pm100a.yaml +0 -132
  428. egse/powermeter/thorlabs/pm100a_cs.py +0 -136
  429. egse/powermeter/thorlabs/pm100a_devif.py +0 -127
  430. egse/powermeter/thorlabs/pm100a_protocol.py +0 -80
  431. egse/powermeter/thorlabs/pm100a_ui.py +0 -725
  432. egse/process.py +0 -451
  433. egse/procman/__init__.py +0 -834
  434. egse/procman/cannot_start_process_popup.py +0 -43
  435. egse/procman/procman.yaml +0 -49
  436. egse/procman/procman_cs.py +0 -201
  437. egse/procman/procman_ui.py +0 -2081
  438. egse/protocol.py +0 -605
  439. egse/proxy.py +0 -531
  440. egse/randomwalk.py +0 -140
  441. egse/reg.py +0 -585
  442. egse/reload.py +0 -122
  443. egse/reprocess.py +0 -693
  444. egse/resource.py +0 -333
  445. egse/rmap.py +0 -406
  446. egse/rst.py +0 -135
  447. egse/search.py +0 -182
  448. egse/serialdevice.py +0 -190
  449. egse/services.py +0 -247
  450. egse/services.yaml +0 -68
  451. egse/settings.py +0 -379
  452. egse/settings.yaml +0 -980
  453. egse/setup.py +0 -1181
  454. egse/shutter/__init__.py +0 -0
  455. egse/shutter/thorlabs/__init__.py +0 -19
  456. egse/shutter/thorlabs/ksc101.py +0 -205
  457. egse/shutter/thorlabs/ksc101.yaml +0 -105
  458. egse/shutter/thorlabs/ksc101_cs.py +0 -136
  459. egse/shutter/thorlabs/ksc101_devif.py +0 -201
  460. egse/shutter/thorlabs/ksc101_protocol.py +0 -71
  461. egse/shutter/thorlabs/ksc101_ui.py +0 -548
  462. egse/shutter/thorlabs/sc10.py +0 -82
  463. egse/shutter/thorlabs/sc10.yaml +0 -52
  464. egse/shutter/thorlabs/sc10_controller.py +0 -81
  465. egse/shutter/thorlabs/sc10_cs.py +0 -108
  466. egse/shutter/thorlabs/sc10_interface.py +0 -25
  467. egse/shutter/thorlabs/sc10_simulator.py +0 -30
  468. egse/simulator.py +0 -41
  469. egse/slack.py +0 -61
  470. egse/socketdevice.py +0 -218
  471. egse/sockets.py +0 -218
  472. egse/spw.py +0 -1401
  473. egse/stages/__init__.py +0 -12
  474. egse/stages/aerotech/ensemble.py +0 -245
  475. egse/stages/aerotech/ensemble.yaml +0 -205
  476. egse/stages/aerotech/ensemble_controller.py +0 -275
  477. egse/stages/aerotech/ensemble_cs.py +0 -110
  478. egse/stages/aerotech/ensemble_interface.py +0 -132
  479. egse/stages/aerotech/ensemble_parameters.py +0 -433
  480. egse/stages/aerotech/ensemble_simulator.py +0 -27
  481. egse/stages/aerotech/mgse_sim.py +0 -188
  482. egse/stages/arun/smd3.py +0 -110
  483. egse/stages/arun/smd3.yaml +0 -68
  484. egse/stages/arun/smd3_controller.py +0 -470
  485. egse/stages/arun/smd3_cs.py +0 -112
  486. egse/stages/arun/smd3_interface.py +0 -53
  487. egse/stages/arun/smd3_simulator.py +0 -27
  488. egse/stages/arun/smd3_stop.py +0 -16
  489. egse/stages/huber/__init__.py +0 -49
  490. egse/stages/huber/smc9300.py +0 -920
  491. egse/stages/huber/smc9300.yaml +0 -63
  492. egse/stages/huber/smc9300_cs.py +0 -178
  493. egse/stages/huber/smc9300_devif.py +0 -345
  494. egse/stages/huber/smc9300_protocol.py +0 -113
  495. egse/stages/huber/smc9300_sim.py +0 -547
  496. egse/stages/huber/smc9300_ui.py +0 -973
  497. egse/state.py +0 -173
  498. egse/statemachine.py +0 -274
  499. egse/storage/__init__.py +0 -1067
  500. egse/storage/persistence.py +0 -2295
  501. egse/storage/storage.yaml +0 -79
  502. egse/storage/storage_cs.py +0 -231
  503. egse/styles/dark.qss +0 -343
  504. egse/styles/default.qss +0 -48
  505. egse/synoptics/__init__.py +0 -417
  506. egse/synoptics/syn.yaml +0 -9
  507. egse/synoptics/syn_cs.py +0 -195
  508. egse/system.py +0 -1611
  509. egse/tcs/__init__.py +0 -14
  510. egse/tcs/tcs.py +0 -879
  511. egse/tcs/tcs.yaml +0 -14
  512. egse/tcs/tcs_cs.py +0 -202
  513. egse/tcs/tcs_devif.py +0 -292
  514. egse/tcs/tcs_protocol.py +0 -180
  515. egse/tcs/tcs_sim.py +0 -177
  516. egse/tcs/tcs_ui.py +0 -543
  517. egse/tdms.py +0 -171
  518. egse/tempcontrol/__init__.py +0 -23
  519. egse/tempcontrol/agilent/agilent34970.py +0 -109
  520. egse/tempcontrol/agilent/agilent34970.yaml +0 -44
  521. egse/tempcontrol/agilent/agilent34970_cs.py +0 -114
  522. egse/tempcontrol/agilent/agilent34970_devif.py +0 -182
  523. egse/tempcontrol/agilent/agilent34970_protocol.py +0 -96
  524. egse/tempcontrol/agilent/agilent34972.py +0 -111
  525. egse/tempcontrol/agilent/agilent34972.yaml +0 -44
  526. egse/tempcontrol/agilent/agilent34972_cs.py +0 -115
  527. egse/tempcontrol/agilent/agilent34972_devif.py +0 -189
  528. egse/tempcontrol/agilent/agilent34972_protocol.py +0 -98
  529. egse/tempcontrol/beaglebone/beaglebone.py +0 -341
  530. egse/tempcontrol/beaglebone/beaglebone.yaml +0 -110
  531. egse/tempcontrol/beaglebone/beaglebone_cs.py +0 -117
  532. egse/tempcontrol/beaglebone/beaglebone_protocol.py +0 -134
  533. egse/tempcontrol/beaglebone/beaglebone_ui.py +0 -674
  534. egse/tempcontrol/digalox/digalox.py +0 -115
  535. egse/tempcontrol/digalox/digalox.yaml +0 -36
  536. egse/tempcontrol/digalox/digalox_cs.py +0 -108
  537. egse/tempcontrol/digalox/digalox_protocol.py +0 -56
  538. egse/tempcontrol/keithley/__init__.py +0 -33
  539. egse/tempcontrol/keithley/daq6510.py +0 -662
  540. egse/tempcontrol/keithley/daq6510.yaml +0 -105
  541. egse/tempcontrol/keithley/daq6510_cs.py +0 -163
  542. egse/tempcontrol/keithley/daq6510_devif.py +0 -343
  543. egse/tempcontrol/keithley/daq6510_protocol.py +0 -79
  544. egse/tempcontrol/keithley/daq6510_sim.py +0 -186
  545. egse/tempcontrol/lakeshore/__init__.py +0 -33
  546. egse/tempcontrol/lakeshore/lsci.py +0 -361
  547. egse/tempcontrol/lakeshore/lsci.yaml +0 -162
  548. egse/tempcontrol/lakeshore/lsci_cs.py +0 -174
  549. egse/tempcontrol/lakeshore/lsci_devif.py +0 -292
  550. egse/tempcontrol/lakeshore/lsci_protocol.py +0 -76
  551. egse/tempcontrol/lakeshore/lsci_ui.py +0 -387
  552. egse/tempcontrol/ni/__init__.py +0 -0
  553. egse/tempcontrol/spid/spid.py +0 -109
  554. egse/tempcontrol/spid/spid.yaml +0 -81
  555. egse/tempcontrol/spid/spid_controller.py +0 -279
  556. egse/tempcontrol/spid/spid_cs.py +0 -136
  557. egse/tempcontrol/spid/spid_protocol.py +0 -107
  558. egse/tempcontrol/spid/spid_ui.py +0 -723
  559. egse/tempcontrol/srs/__init__.py +0 -22
  560. egse/tempcontrol/srs/ptc10.py +0 -867
  561. egse/tempcontrol/srs/ptc10.yaml +0 -227
  562. egse/tempcontrol/srs/ptc10_cs.py +0 -128
  563. egse/tempcontrol/srs/ptc10_devif.py +0 -116
  564. egse/tempcontrol/srs/ptc10_protocol.py +0 -39
  565. egse/tempcontrol/srs/ptc10_ui.py +0 -906
  566. egse/ups/apc/apc.py +0 -236
  567. egse/ups/apc/apc.yaml +0 -45
  568. egse/ups/apc/apc_cs.py +0 -101
  569. egse/ups/apc/apc_protocol.py +0 -125
  570. egse/user.yaml +0 -7
  571. egse/vacuum/beaglebone/beaglebone.py +0 -149
  572. egse/vacuum/beaglebone/beaglebone.yaml +0 -44
  573. egse/vacuum/beaglebone/beaglebone_cs.py +0 -108
  574. egse/vacuum/beaglebone/beaglebone_devif.py +0 -159
  575. egse/vacuum/beaglebone/beaglebone_protocol.py +0 -192
  576. egse/vacuum/beaglebone/beaglebone_ui.py +0 -638
  577. egse/vacuum/instrutech/igm402.py +0 -91
  578. egse/vacuum/instrutech/igm402.yaml +0 -90
  579. egse/vacuum/instrutech/igm402_controller.py +0 -124
  580. egse/vacuum/instrutech/igm402_cs.py +0 -108
  581. egse/vacuum/instrutech/igm402_interface.py +0 -49
  582. egse/vacuum/instrutech/igm402_simulator.py +0 -36
  583. egse/vacuum/keller/kellerBus.py +0 -256
  584. egse/vacuum/keller/leo3.py +0 -100
  585. egse/vacuum/keller/leo3.yaml +0 -38
  586. egse/vacuum/keller/leo3_controller.py +0 -81
  587. egse/vacuum/keller/leo3_cs.py +0 -101
  588. egse/vacuum/keller/leo3_interface.py +0 -33
  589. egse/vacuum/mks/evision.py +0 -86
  590. egse/vacuum/mks/evision.yaml +0 -75
  591. egse/vacuum/mks/evision_cs.py +0 -101
  592. egse/vacuum/mks/evision_devif.py +0 -313
  593. egse/vacuum/mks/evision_interface.py +0 -60
  594. egse/vacuum/mks/evision_simulator.py +0 -24
  595. egse/vacuum/mks/evision_ui.py +0 -701
  596. egse/vacuum/pfeiffer/acp40.py +0 -87
  597. egse/vacuum/pfeiffer/acp40.yaml +0 -60
  598. egse/vacuum/pfeiffer/acp40_controller.py +0 -117
  599. egse/vacuum/pfeiffer/acp40_cs.py +0 -109
  600. egse/vacuum/pfeiffer/acp40_interface.py +0 -40
  601. egse/vacuum/pfeiffer/acp40_simulator.py +0 -37
  602. egse/vacuum/pfeiffer/tc400.py +0 -87
  603. egse/vacuum/pfeiffer/tc400.yaml +0 -83
  604. egse/vacuum/pfeiffer/tc400_controller.py +0 -136
  605. egse/vacuum/pfeiffer/tc400_cs.py +0 -109
  606. egse/vacuum/pfeiffer/tc400_interface.py +0 -70
  607. egse/vacuum/pfeiffer/tc400_simulator.py +0 -35
  608. egse/vacuum/pfeiffer/tpg261.py +0 -80
  609. egse/vacuum/pfeiffer/tpg261.yaml +0 -66
  610. egse/vacuum/pfeiffer/tpg261_controller.py +0 -150
  611. egse/vacuum/pfeiffer/tpg261_cs.py +0 -109
  612. egse/vacuum/pfeiffer/tpg261_interface.py +0 -59
  613. egse/vacuum/pfeiffer/tpg261_simulator.py +0 -23
  614. egse/version.py +0 -174
  615. egse/visitedpositions.py +0 -398
  616. egse/windowing.py +0 -213
  617. egse/zmq/__init__.py +0 -28
  618. egse/zmq/spw.py +0 -160
  619. egse/zmq_ser.py +0 -41
  620. scripts/alerts/cold.yaml +0 -278
  621. scripts/alerts/example_alerts.yaml +0 -54
  622. scripts/alerts/transition.yaml +0 -14
  623. scripts/alerts/warm.yaml +0 -49
  624. scripts/analyse_n_fee_hk_data.py +0 -52
  625. scripts/check_hdf5_files.py +0 -192
  626. scripts/check_register_sync.py +0 -47
  627. scripts/check_tcs_calib_coef.py +0 -90
  628. scripts/correct_ccd_cold_temperature_cal.py +0 -157
  629. scripts/create_hdf5_report.py +0 -293
  630. scripts/csl_model.py +0 -420
  631. scripts/csl_restore_setup.py +0 -229
  632. scripts/export-grafana-dashboards.py +0 -49
  633. scripts/fdir/cs_recovery/fdir_cs_recovery.py +0 -54
  634. scripts/fdir/fdir_table.yaml +0 -70
  635. scripts/fdir/fdir_test_recovery.py +0 -10
  636. scripts/fdir/hw_recovery/fdir_agilent_hw_recovery.py +0 -73
  637. scripts/fdir/limit_recovery/fdir_agilent_limit.py +0 -61
  638. scripts/fdir/limit_recovery/fdir_bb_heater_limit.py +0 -59
  639. scripts/fdir/limit_recovery/fdir_ensemble_limit.py +0 -33
  640. scripts/fdir/limit_recovery/fdir_pressure_limit_recovery.py +0 -71
  641. scripts/fix_csv.py +0 -80
  642. scripts/ias/correct_ccd_temp_cal_elfique.py +0 -43
  643. scripts/ias/correct_ccd_temp_cal_floreffe.py +0 -43
  644. scripts/ias/correct_trp_swap_achel.py +0 -199
  645. scripts/inta/correct_ccd_temp_cal_duvel.py +0 -43
  646. scripts/inta/correct_ccd_temp_cal_gueuze.py +0 -43
  647. scripts/n_fee_supply_voltage_calculation.py +0 -92
  648. scripts/playground.py +0 -30
  649. scripts/print_hdf5_hk_data.py +0 -68
  650. scripts/print_register_map.py +0 -43
  651. scripts/remove_lines_between_matches.py +0 -188
  652. scripts/sron/commanding/control_heaters.py +0 -44
  653. scripts/sron/commanding/pumpdown.py +0 -46
  654. scripts/sron/commanding/set_pid_setpoint.py +0 -19
  655. scripts/sron/commanding/shutdown_bbb_heaters.py +0 -10
  656. scripts/sron/commanding/shutdown_pumps.py +0 -33
  657. scripts/sron/correct_mgse_coordinates_brigand_chimay.py +0 -272
  658. scripts/sron/correct_trp_swap_brigand.py +0 -204
  659. scripts/sron/gimbal_conversions.py +0 -75
  660. scripts/sron/tm_gen/tm_gen_agilent.py +0 -37
  661. scripts/sron/tm_gen/tm_gen_heaters.py +0 -4
  662. scripts/sron/tm_gen/tm_gen_spid.py +0 -13
  663. scripts/update_operational_cgse.py +0 -268
  664. scripts/update_operational_cgse_old.py +0 -273
@@ -1,737 +0,0 @@
1
- """
2
- The Reference Frame Model is a self-consistent graph of reference frames that are connected by
3
- reference and/or by explicit links.
4
-
5
- The ReferenceFrameModel class will keep the model consistent and self-contained.
6
-
7
- Functionality:
8
-
9
- * Initialization from a list of ReferenceFrames.
10
- * Serialization into a dictionary that can be saved into a YAML file.
11
- * Manipulation of the model
12
- * Move a reference frame (translation, rotation) with respect to another reference frame
13
- * Absolute movement, center of rotation either local or other
14
- * Relative Movement, center of rotation either local or other
15
- * Move a reference frame (translation, rotation) with respect to itself
16
- * Absolute movement
17
- * Relative Movement
18
- * Change the definition of a reference frame in the model
19
- * Inspection of the model
20
- * Get the definition of a reference frame (what should this be? only translation & rotation?)
21
- * Get position of a reference frame
22
- * Get the position of a point in a 'target' reference frame, but defined in a 'source'
23
- reference frame
24
- * Get a string representation of the model.
25
- * Find inconsistencies in the model
26
- * What other information do we need?
27
- * find the path from one reference frame to another reference frame?
28
- * find all reference frames that are affected by a movement or redefinition of a
29
- reference frame?
30
- * ...
31
-
32
- """
33
- import logging
34
- from typing import Dict
35
- from typing import List
36
- from typing import Union
37
-
38
- import matplotlib.pyplot as plt
39
- import numpy as np
40
- from matplotlib.transforms import ScaledTranslation
41
- from mpl_toolkits.mplot3d import Axes3D
42
-
43
- import egse.coordinates.transform3d_addon as t3add
44
- from egse.coordinates import dict_to_ref_model
45
- from egse.coordinates import ref_model_to_dict
46
- from egse.coordinates.referenceFrame import ReferenceFrame
47
- from egse.setup import NavigableDict
48
-
49
- LOGGER = logging.getLogger(__name__)
50
-
51
- # TODO : HANDLING "moving_in_ref" (obusr) in move_absolute_ext and move_relative_ext
52
- # should it be added to the model temporarily ??
53
- # after the move : remove the link and delete that frame
54
- #
55
- # Priority 1
56
- # * access methods to allow for things like is_avoidance_ok(hexsim.cs_user, hexsim.cs_object,
57
- # setup=setup, verbose=True)
58
- #
59
- # Priority 2
60
- # * Move name handling from ReferenceFrame to here (if necessary)
61
-
62
-
63
- class ReferenceFrameModel:
64
- """
65
- A ReferenceFrameModel is a collection of reference frames that are linked to each other to
66
- form a Graph.
67
- """
68
-
69
- _ROT_CONFIG_DEFAULT = "sxyz"
70
- _ACTIVE_DEFAULT = True
71
- _DEGREES_DEFAULT = True
72
-
73
- def __init__(
74
- self,
75
- model: Union[Dict, List[ReferenceFrame]] = None,
76
- rot_config: str = _ROT_CONFIG_DEFAULT,
77
- use_degrees: bool = _DEGREES_DEFAULT,
78
- use_active_movements: bool = _ACTIVE_DEFAULT,
79
- ):
80
- """
81
- When the model_dict is empty or None, a new model is created with a master reference frame.
82
-
83
- Args:
84
- model: a list or a dictionary of reference frames that make up the model
85
- use_degrees: use degrees throughout this model unless explicitly specified in the
86
- function call.
87
- """
88
- self._use_degrees = use_degrees
89
- self._use_active_movements = use_active_movements
90
- self._rot_config = rot_config
91
-
92
- # Keep a dictionary with all reference frames that are part of the model. The keys shall
93
- # be the name of the reference frame. When the model passed is empty, create only a
94
- # master reference frame.
95
-
96
- if isinstance(model, (dict, list)):
97
- self._model = self.deserialize(model)
98
- else:
99
- self._model = NavigableDict({})
100
-
101
- def __str__(self):
102
- return self._model.pretty_str()
103
-
104
- def __len__(self):
105
- return len(self._model)
106
-
107
- def __contains__(self, item):
108
- return item in self._model
109
-
110
- def __iter__(self):
111
- return iter(self._model.values())
112
-
113
- def summary(self):
114
- result = f"Nb of frames: {len(self)}\n"
115
-
116
- for ref in self:
117
- result += (
118
- f"{ref.name:>10}[{ref.ref.name}]" f" --- {[link.name for link in ref.linkedTo]}\n"
119
- )
120
- return result
121
-
122
- @staticmethod
123
- def deserialize(model_dict: dict) -> NavigableDict:
124
- """
125
- Deserialize means you take a serialized representation of a reference frames model and
126
- turn it into a dictionary containing all the reference frames with their links and
127
- references.
128
-
129
- Args:
130
- model_dict: a dictionary of serialized reference frames
131
-
132
- Returns:
133
- A dictionary of ReferenceFrames that make up a model.
134
-
135
- """
136
- return dict_to_ref_model(model_dict)
137
-
138
- def serialize(self) -> NavigableDict:
139
- """
140
- Serialize the model by serializing each of the reference frames into an object that can
141
- easily be saved to a YAML or a JSON file. Return a dictionary with the serialized frames.
142
-
143
- Returns:
144
- A dictionary with all the reference framed serialized.
145
- """
146
-
147
- return ref_model_to_dict(self._model)
148
-
149
- def add_master_frame(self):
150
-
151
- # TODO: First check if there is not already a Master frame in the model
152
-
153
- self._model["Master"] = ReferenceFrame.createMaster()
154
-
155
- def add_frame(
156
- self,
157
- name: str,
158
- *,
159
- translation: List[float] = None,
160
- rotation: List[float] = None,
161
- transformation=None,
162
- ref: str,
163
- ):
164
- """
165
- Add a reference frame to the model.
166
-
167
- .. note::
168
- Only the `name` parameter can be positional, all the other arguments (translation,
169
- rotation, transformation, and ref) must be given as keyword arguments.
170
-
171
- Args:
172
- name: the name for the reference frame. This name is it's identifier within the model.
173
- translation: the translation vector
174
- rotation: the rotation vector
175
- transformation: the transformation vector, if `transformation` is given,
176
- both `translation` and `rotation` are ignored.
177
- ref: the reference frame that is a reference for 'name', i.e. 'name' is defined with
178
- respect to 'ref'.
179
- """
180
-
181
- if name in self._model:
182
- raise KeyError("A reference frame with the name '{name} already exists in the model.")
183
-
184
- ref = self._model[ref]
185
-
186
- if transformation is not None:
187
- self._model[name] = ReferenceFrame(
188
- transformation, ref=ref, name=name, rot_config=self._rot_config,
189
- )
190
- else:
191
- self._model[name] = ReferenceFrame.fromTranslationRotation(
192
- translation,
193
- rotation,
194
- name=name,
195
- ref=ref,
196
- rot_config=self._rot_config,
197
- degrees=self._use_degrees,
198
- active=self._use_active_movements,
199
- )
200
-
201
- def remove_frame(self, name: str):
202
- """
203
- Deletes the reference frame from the model. If the reference frame doesn't exist in the
204
- model, a warning message is logged.
205
-
206
- Args:
207
- name: the name of the reference frame to remove
208
- """
209
-
210
- if name in self._model:
211
-
212
- frame: ReferenceFrame = self._model[name]
213
-
214
- # We need to get the links out in a list because the frame.removeLink() method deletes
215
- # frames from the linkedTo dictionary and that is not allowed in a for loop.
216
-
217
- links = [linked_frame for linked_frame in frame.linkedTo]
218
- for link in links:
219
- frame.removeLink(link)
220
-
221
- del self._model[name]
222
- else:
223
- LOGGER.warning(
224
- f"You tried to remove a non-existing reference frame '{name}' from the model."
225
- )
226
-
227
- def get_frame(self, name: str) -> ReferenceFrame:
228
- """
229
- Returns a frame with the given name.
230
-
231
- .. note::
232
- Use this function with care since this breaks encapsulation and may lead to an
233
- inconsistent model when the frame is changed outside of the scope of the reference
234
- model.
235
-
236
- Args:
237
- name: the name of the requested reference frame
238
-
239
- Returns:
240
- The reference frame with the given name.
241
- """
242
- return self._model[name]
243
-
244
- def add_link(self, source: str, target: str):
245
- """
246
- Add a link between two reference frames. All links are bi-directional.
247
-
248
- Args:
249
- source: the source reference frame
250
- target: the target reference frame
251
-
252
- """
253
- if source not in self._model:
254
- raise KeyError(f"There is no reference frame with the name '{source} in the model.")
255
- if target not in self._model:
256
- raise KeyError(f"There is no reference frame with the name '{target} in the model.")
257
-
258
- source = self._model[source]
259
- target = self._model[target]
260
-
261
- source.addLink(target)
262
-
263
- def remove_link(self, source: str, target: str):
264
- """
265
- Remove a link between two reference frames. All links are bi-directional and this method
266
- removes both links.
267
-
268
- Args:
269
- source: the source reference frame
270
- target: the target reference frame
271
-
272
- """
273
- if source not in self._model:
274
- raise KeyError(f"There is no reference frame with the name '{source} in the model.")
275
- if target not in self._model:
276
- raise KeyError(f"There is no reference frame with the name '{target} in the model.")
277
-
278
- source = self._model[source]
279
- target = self._model[target]
280
-
281
- source.removeLink(target)
282
-
283
- def move_absolute_self(self, frame: str, translation, rotation, degrees=_DEGREES_DEFAULT):
284
- """
285
- Apply an absolute movement to the given ReferenceFrame such that it occupies a given
286
- absolute position wrt "frame_ref" after the movement.
287
-
288
- NO Hexapod equivalent.
289
-
290
- Args:
291
- frame (str): the name of the reference frame to move
292
- """
293
-
294
- frame = self._model[frame]
295
- frame.setTranslationRotation(
296
- translation,
297
- rotation,
298
- rot_config=self._rot_config,
299
- active=self._use_active_movements,
300
- degrees=degrees,
301
- preserveLinks=True,
302
- )
303
-
304
- def move_absolute_in_other(
305
- self, frame: str, other: str, translation, rotation, degrees=_DEGREES_DEFAULT
306
- ):
307
- """
308
- Apply an absolute movement to the ReferenceFrame "frame", such that it occupies
309
- a given absolute position with respect to "other" after the movement.
310
-
311
- EQUIVALENT PunaSimulator.move_absolute, setting hexobj wrt hexusr.
312
-
313
- Args:
314
- frame (str): the name (id) of the reference frame to move
315
- other (str): the name (id) of the reference frame
316
- """
317
-
318
- # TODO:
319
- # There can not be a link between frame and other, not direct and not indirect.
320
- # So, with A-link-B-link-C-link-D, we can not do move_absolute_in_other('A', 'D', ...)
321
-
322
- frame = self._model[frame]
323
- other = self._model[other]
324
-
325
- transformation = other.getActiveTransformationTo(frame)
326
-
327
- moving_in_other = ReferenceFrame(
328
- transformation, rot_config=self._rot_config, ref=other, name="moving_in_other"
329
- )
330
-
331
- moving_in_other.addLink(frame)
332
-
333
- moving_in_other.setTranslationRotation(
334
- translation,
335
- rotation,
336
- rot_config=self._rot_config,
337
- active=self._use_active_movements,
338
- degrees=degrees,
339
- preserveLinks=True,
340
- )
341
-
342
- moving_in_other.removeLink(frame)
343
-
344
- del moving_in_other
345
-
346
- def move_relative_self(self, frame: str, translation, rotation, degrees=_DEGREES_DEFAULT):
347
- """
348
- Apply a relative movement to the given ReferenceFrame assuming the movement is expressed
349
- in that same frame.
350
-
351
- EQUIVALENT PunaSimulator.move_relative_object
352
-
353
- Args:
354
- frame (str): the name of the reference frame to move
355
- """
356
-
357
- frame = self._model[frame]
358
- frame.applyTranslationRotation(
359
- translation,
360
- rotation,
361
- rot_config=self._rot_config,
362
- active=self._use_active_movements,
363
- degrees=degrees,
364
- preserveLinks=True,
365
- )
366
-
367
- def move_relative_other(
368
- self, frame: str, other: str, translation, rotation, degrees=_DEGREES_DEFAULT
369
- ):
370
- """
371
- Apply a relative movement to the ReferenceFrame "frame". The movement is expressed wrt
372
- the axes of another frame, "other".
373
-
374
- The center of rotation is the origin of the reference frame 'other'.
375
-
376
- NO Hexapod equivalent.
377
-
378
- Args:
379
- frame (str): the name (id) of the reference frame to move
380
- other (str): the name (id) of the reference frame
381
- """
382
-
383
- # TODO:
384
- # There can not be a link between frame and other, not direct and not indirect.
385
- # So, with A-link-B-link-C-link-D, we can not do move_absolute_in_other('A', 'D', ...)
386
-
387
- frame = self._model[frame]
388
- other = self._model[other]
389
-
390
- transformation = frame.getActiveTransformationTo(other)
391
-
392
- moving_in_other = ReferenceFrame(
393
- transformation, rot_config=self._rot_config, ref=other, name="moving_in_other"
394
- )
395
-
396
- moving_in_other.addLink(frame)
397
-
398
- moving_in_other.applyTranslationRotation(
399
- translation,
400
- rotation,
401
- rot_config=self._rot_config,
402
- active=self._use_active_movements,
403
- degrees=degrees,
404
- preserveLinks=True,
405
- )
406
-
407
- moving_in_other.removeLink(frame)
408
-
409
- del moving_in_other # not need as local scope
410
-
411
- def move_relative_other_local(
412
- self, frame: str, other: str, translation, rotation, degrees=_DEGREES_DEFAULT
413
- ):
414
- """
415
- Apply a relative movement to the ReferenceFrame "frame".
416
-
417
- The movement is expressed wrt the axes of an external frame "other"
418
-
419
- The center of rotation is the origin of the reference frame 'frame'.
420
-
421
- EQUIVALENT PunaSimulator.move_relative_user
422
-
423
- """
424
-
425
- # TODO:
426
- # There can not be a link between frame and other, not direct and not indirect.
427
- # So, with A-link-B-link-C-link-D, we can not do move_absolute_in_other('A', 'D', ...)
428
-
429
- frame = self._model[frame]
430
- other = self._model[other]
431
-
432
- # Represent the requested movement
433
-
434
- # Derotation of MOVING --> REF (align frame_moving axes on those of frame_ref)
435
-
436
- derotation = frame.getActiveTransformationTo(other)
437
- derotation[:3, 3] = [0, 0, 0]
438
-
439
- # Reverse rotation (record inverse rotation, to restore the frame in the end)
440
-
441
- rerotation = derotation.T
442
-
443
- # Requested translation matrix (already expressed wrt frame_ref)
444
-
445
- translation_ = np.identity(4)
446
- translation_[:3, 3] = translation
447
-
448
- # Requested rotation matrix (already expressed wrt frame_ref)
449
-
450
- zeros = [0, 0, 0]
451
- rotation_ = t3add.translationRotationToTransformation(
452
- zeros, rotation, rot_config=self._rot_config
453
- )
454
-
455
- # All translations and rotations are applied to frame_moving
456
- # ==> a. need for "derotation" before applying the translation
457
- # b. the center or rotation is always the origin of frame_moving
458
- # 1. rotate frame_moving to align it with frame_ref (i.e. render their axes parallel)
459
- # 2. apply the translation in this frame
460
- # 3. restore the original orientation of the moving frame
461
- # 4. apply the requested rotation
462
-
463
- transformation = derotation @ translation_ @ rerotation @ rotation_
464
-
465
- # Apply the requested movement
466
-
467
- frame.applyTransformation(transformation, preserveLinks=True)
468
-
469
-
470
- def plot_ref_model(model: ReferenceFrameModel):
471
-
472
- # figsize is in inch, 6 inch = 15.24 cm, 5 inch = 12.7 cm
473
-
474
- fig = plt.figure(figsize=(6, 5), dpi=100)
475
-
476
- ax = fig.add_subplot(1, 1, 1)
477
-
478
- # Set axes limits in data coordinates
479
-
480
- ax.set_xlim(-10, 10)
481
- ax.set_ylim(-10, 10)
482
- ax.set_xticks(range(-10, 11, 2))
483
- ax.set_yticks(range(-10, 11, 2))
484
- ax.grid(True)
485
-
486
- for frame in model:
487
- draw_frame(ax, frame, plane="xz")
488
-
489
- plt.show()
490
-
491
-
492
- def plot_ref_model_3d(model: ReferenceFrameModel):
493
-
494
- fig = plt.figure(figsize=(8, 8), dpi=100)
495
- ax = Axes3D(fig)
496
- # ax.set_box_aspect([1, 1, 1])
497
-
498
- ax.set_xlabel("x")
499
- ax.set_ylabel("y")
500
- ax.set_zlabel("z")
501
-
502
- def get_fix_mins_maxs(mins, maxs):
503
- deltas = (maxs - mins) / 12.0
504
- mins = mins + deltas / 4.0
505
- maxs = maxs - deltas / 4.0
506
-
507
- return [mins, maxs]
508
-
509
- min_ = -8
510
- max_ = 8
511
- minmax = get_fix_mins_maxs(min_, max_)
512
-
513
- # ax.set_xticks(range(min_, max_, 2))
514
- # ax.set_yticks(range(min_, max_, 2))
515
- # ax.set_zticks(range(min_, max_, 2))
516
-
517
- ax.set_xlim(minmax)
518
- ax.set_ylim(minmax)
519
- ax.set_zlim(minmax)
520
-
521
- delta = 0.1
522
- ax.scatter(
523
- [min_ + delta, max_ - delta],
524
- [min_ + delta, max_ - delta],
525
- [min_ + delta, max_ - delta],
526
- color="k",
527
- marker=".",
528
- )
529
-
530
- for frame in model:
531
- draw_frame_3d(ax, frame)
532
-
533
- # ax.set_proj_type('ortho')
534
- ax.set_proj_type("persp")
535
-
536
- set_axes_equal(ax)
537
- plt.show()
538
-
539
-
540
- # The aspect ration of the plots is not equal by default.
541
- # This solution was given in SO: https://stackoverflow.com/a/63625222/4609203
542
-
543
-
544
- def set_axes_equal(ax: plt.Axes):
545
- """Set 3D plot axes to equal scale.
546
-
547
- Make axes of 3D plot have equal scale so that spheres appear as
548
- spheres and cubes as cubes. Required since `ax.axis('equal')`
549
- and `ax.set_aspect('equal')` don't work on 3D.
550
- """
551
- limits = np.array([ax.get_xlim3d(), ax.get_ylim3d(), ax.get_zlim3d()])
552
- origin = np.mean(limits, axis=1)
553
- radius = 0.5 * np.max(np.abs(limits[:, 1] - limits[:, 0]))
554
- x, y, z = origin
555
- ax.set_xlim3d([x - radius, x + radius])
556
- ax.set_ylim3d([y - radius, y + radius])
557
- ax.set_zlim3d([z - radius, z + radius])
558
-
559
-
560
- def draw_frame_3d(ax: Axes3D, frame: ReferenceFrame, DEFAULT_AXIS_LENGTH=100, **kwargs):
561
-
562
- master = frame.find_master()
563
-
564
- f0 = frame.getOrigin()
565
- fx = frame.getAxis("x", name="fx")
566
- fy = frame.getAxis("y", name="fy")
567
- fz = frame.getAxis("z", name="fz")
568
- f0m = f0.expressIn(master)[:3]
569
- fxm = fx.expressIn(master)[:3]
570
- fym = fy.expressIn(master)[:3]
571
- fzm = fz.expressIn(master)[:3]
572
-
573
- # Origin of the X,Y and Z vectors (x = the 'x' coordinates of the origin of all 3 vectors)
574
- # Every vector independently (--> plot in diff. colors)
575
- x, y, z = np.array([f0m[0]]), np.array([f0m[1]]), np.array([f0m[2]])
576
-
577
- # Orientation of the X,Y and Z vectors
578
- vecxx, vecyx, veczx = (
579
- np.array([fxm[0] - f0m[0]]),
580
- np.array([fym[0] - f0m[0]]),
581
- np.array([fzm[0] - f0m[0]]),
582
- )
583
- vecxy, vecyy, veczy = (
584
- np.array([fxm[1] - f0m[1]]),
585
- np.array([fym[1] - f0m[1]]),
586
- np.array([fzm[1] - f0m[1]]),
587
- )
588
- vecxz, vecyz, veczz = (
589
- np.array([fxm[2] - f0m[2]]),
590
- np.array([fym[2] - f0m[2]]),
591
- np.array([fzm[2] - f0m[2]]),
592
- )
593
-
594
- kwargs.setdefault("length", 2)
595
- kwargs.setdefault("normalize", True)
596
-
597
- ax.quiver(x, y, z, vecxx, vecxy, vecxz, color="r", **kwargs)
598
- ax.quiver(x, y, z, vecyx, vecyy, vecyz, color="g", **kwargs)
599
- ax.quiver(x, y, z, veczx, veczy, veczz, color="b", **kwargs)
600
-
601
- offset = 0.1
602
- ax.text(f0m[0] + offset, f0m[1] + offset, f0m[2] + offset, frame.name)
603
-
604
-
605
- def draw_frame(ax, frame: ReferenceFrame, plane="xz", DEFAULT_AXIS_LENGTH=100):
606
-
607
- fig = ax.get_figure()
608
-
609
- # FC : Figure coordinates (pixels)
610
- # NFC : Normalized figure coordinates (0 → 1)
611
- # DC : Data coordinates (data units)
612
- # NDC : Normalized data coordinates (0 → 1)
613
-
614
- dc2fc = ax.transData.transform
615
- fc2dc = ax.transData.inverted().transform
616
- fc2ndc = ax.transAxes.inverted().transform
617
-
618
- def dc2ndc(x): # better than defining and assigning a lambda function
619
- return fc2ndc(dc2fc(x))
620
-
621
- x_idx, y_idx = {"xz": (0, 2), "xy": (0, 1), "yz": (1, 2)}[plane]
622
-
623
- # Draw the origin
624
-
625
- origin = frame.getOrigin()
626
- origin_in_master = origin.expressIn(frame.find_master())
627
-
628
- ax.scatter([origin_in_master[x_idx]], [origin_in_master[y_idx]], color="k")
629
-
630
- # Draw the axis
631
-
632
- origin_dc = np.array([[origin_in_master[x_idx], origin_in_master[y_idx]]])
633
-
634
- point = dc2fc(origin_dc[0])
635
- point[0] += DEFAULT_AXIS_LENGTH
636
- target_dc = np.append(origin_dc, [fc2dc(point)], axis=0)
637
-
638
- ax.plot(target_dc[:, 0], target_dc[:, 1], color="k")
639
-
640
- point = dc2fc(origin_dc[0])
641
- point[1] += DEFAULT_AXIS_LENGTH
642
- target_dc = np.append(origin_dc, [fc2dc(point)], axis=0)
643
-
644
- ax.plot(target_dc[:, 0], target_dc[:, 1], color="k")
645
-
646
- # Draw the axes label
647
-
648
- dx, dy = 10 / fig.dpi, 10 / fig.dpi
649
- offset = ScaledTranslation(dx, dy, fig.dpi_scale_trans)
650
- point = dc2ndc(origin_dc[0])
651
- plt.text(point[0], point[1], frame.name, transform=ax.transAxes + offset)
652
-
653
-
654
- def define_the_initial_setup():
655
- model = ReferenceFrameModel()
656
-
657
- model.add_master_frame()
658
- model.add_frame("A", translation=[2, 2, 2], rotation=[0, 0, 0], ref="Master")
659
- model.add_frame("B", translation=[-2, 2, 2], rotation=[0, 0, 0], ref="Master")
660
- model.add_frame("C", translation=[2, 2, 5], rotation=[0, 0, 0], ref="A")
661
- model.add_frame("D", translation=[2, 2, 2], rotation=[0, 0, 0], ref="B")
662
-
663
- model.add_link("A", "B")
664
- model.add_link("B", "C")
665
-
666
- print(model.serialize())
667
- plot_ref_model_3d(model)
668
-
669
- return model
670
-
671
-
672
- def get_vectors(rf1, rf2, model):
673
- """
674
- get_vectors(rf1,rf2, model)
675
- :param rf1: string : name of ref. frame "from"
676
- :param rf2: string : name of ref. frame "to"
677
- :param model: CSLReferenceFrameModel containing rf1 and rf2
678
- :return: translation and rotation vectors from rf1 to rf2
679
- """
680
- return model.get_frame(rf1).getActiveTranslationRotationVectorsTo(model.get_frame(rf2))
681
-
682
-
683
- def print_vectors(rf1, rf2, model):
684
- """
685
- :param rf1: string : name of ref. frame "from"
686
- :param rf2: string : name of ref. frame "to"
687
- :param model: CSLReferenceFrameModel containing rf1 and rf2
688
- :return: N.A.
689
- Prints the translation and rotation vectors from rf1 to rf2
690
- """
691
- trans, rot = model.get_frame(rf1).getActiveTranslationRotationVectorsTo(model.get_frame(rf2))
692
- print(f"{rf1:8s} -> {rf2:8s} : Trans [{trans[0]:11.4e}, {trans[1]:11.4e}, {trans[2]:11.4e}] Rot [{rot[0]:11.4e}, {rot[1]:11.4e}, {rot[2]:11.4e}]")
693
- return
694
-
695
-
696
- if __name__ == "__main__":
697
-
698
- logging.basicConfig(level=20)
699
-
700
- model = define_the_initial_setup()
701
-
702
- print(model.summary())
703
-
704
- print("\nMove frame 'A', frames 'B' and 'C' move with it.\n")
705
- model.move_absolute_self("A", [1, 1, 3], [0, 0, 45])
706
- print(model.serialize())
707
- plot_ref_model_3d(model)
708
-
709
- model = define_the_initial_setup()
710
-
711
- print("\nMove frame 'B' with respect to 'Master, frames 'A' and 'C' move with it.\n")
712
- model.move_absolute_in_other("B", "Master", [1, 1, -1], [0, 0, 0])
713
- print(model.serialize())
714
- plot_ref_model_3d(model)
715
-
716
- model = define_the_initial_setup()
717
-
718
- print("\nMove frame 'D' relative to itself, turn 45º\n")
719
- model.move_relative_self("D", [0, 0, 0], [45, 0, 0])
720
- print(model.serialize())
721
- plot_ref_model_3d(model)
722
-
723
- model = define_the_initial_setup()
724
-
725
- print("\nMove frame 'D' relative to 'A', turn 45º around origin of 'A'\n")
726
- model.move_relative_other("D", "A", [0, 0, 0], [0, 45, 0])
727
- print(model.serialize())
728
- plot_ref_model_3d(model)
729
-
730
- model = define_the_initial_setup()
731
-
732
- print("\nMove frame 'D' relative to 'A', turn 45º around origin of 'D'\n")
733
- model.move_relative_other_local("D", "A", [0, 0, 0], [0, 45, 0])
734
- print(model.serialize())
735
- plot_ref_model_3d(model)
736
-
737
- model = define_the_initial_setup()