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,85 +0,0 @@
1
- """
2
- The RotationMatrix provides a number of convenience methods to define and apply rotations.
3
-
4
- @author: pierre
5
- """
6
-
7
- import transforms3d as t3
8
- import numpy as np
9
-
10
- class RotationMatrix():
11
- """
12
- RotationMatrix(angle1, angle2, angle3, rot_config="sxyz", active=True)
13
-
14
- The ``angle`` parameters provide the amplitude of rotation around an axis
15
- according to the order of rotations corresponding to the ``rot_config`` parameter.
16
-
17
- The ``rot_config`` parameter is a string that consists of four letter
18
- indicating the rotation system and the order of applying the rotations. The default
19
- for this parameter is ``"rxyz"`` where the first character can be 'r' or 's' and
20
- the next three characters define the axes of rotation in the order specified, here 'xyz'.
21
-
22
- * 'r' stands for rotating system (intrinsic rotations)
23
- * 's' stands for static system (extrinsic rotations)
24
- * "rxyz" imposes angle1 describes the rotation around X
25
- * even if two angles = 0, the match between angle orders and rot_config is still critical
26
-
27
- :param str rot_config: otation system to be used, 4 characters. Default = "sxyz"
28
-
29
- :param float angle1: amplitude of rotations around the first axis
30
-
31
- :param float angle2: amplitude of rotations around the second axis
32
-
33
- :param float angle3: amplitude of rotations around the third axis
34
-
35
- :param bool active: when True the object rotates **in** a fixed coord system,
36
- when False the coord system rotates **around** a fixed object
37
- The default for the transform3d.euleur package is to represent movements
38
- of the coordinate system itself --> **around** the object <==> passive
39
- """
40
- _ROT_CONFIG_DEFAULT = 'sxyz'
41
-
42
- def __init__(self,angle1,angle2,angle3,rot_config=_ROT_CONFIG_DEFAULT,active=True):
43
- R = t3.euler.euler2mat(angle1,angle2,angle3,rot_config)
44
- if active:
45
- self.R = R
46
- else:
47
- self.R = R.T
48
- rot_config_array = np.array(list(rot_config[1:]))
49
- angles_array = np.array([angle1,angle2,angle3])
50
- self.angles_hash = {}
51
- for axis in ['x','y','z']:
52
- self.angles_hash[axis] = angles_array[np.where(rot_config_array==axis)[0][0]]
53
- self.active=active
54
-
55
-
56
- def getRotationMatrix(self):
57
- '''Return the Rotation Matrix'''
58
- return self.R
59
-
60
-
61
- def trace(self):
62
- return np.sum([self.R[i,i] for i in range(3)])
63
-
64
-
65
- def getAngle(self, axis):
66
- """
67
- Returns the angle
68
-
69
- :param str axis: 'x', 'y', 'z'
70
-
71
- :return: the angle
72
- """
73
- return self.angles_hash[axis]
74
-
75
-
76
- def apply(self, vectors):
77
- """
78
- if self = active, the output = the coords of these vectors after rotation
79
-
80
- if self = passive, the ouput = the coords of these vectors after transformation to the rotated coordinate system
81
-
82
- :param vectors: an array of shape [3,N] gathering a set of vectors along its columns
83
- """
84
- return np.dot(self.R, vectors)
85
-
@@ -1,419 +0,0 @@
1
- #!/usr/bin/env python3
2
- # -*- coding: utf-8 -*-
3
- """
4
- Created on Mon Jun 25 16:25:33 2018
5
-
6
- @author: pierre
7
- """
8
- import numpy
9
- import numpy as np
10
- import math
11
- import transforms3d as t3
12
-
13
- from egse.coordinates.rotationMatrix import RotationMatrix
14
-
15
- def affine_isEuclidian(matrix):
16
- """
17
- Tests if a matrix is a pure solid-body euclidian rotation + translation (no shear or scaling)
18
-
19
- We only need to check that
20
- . the rotation part is orthogonal : R @ R.T = I
21
- . the det(R) = 1 (=> this is not a reflexion)
22
- """
23
- rotation = matrix[:3,:3]
24
- return np.allclose((rotation @ rotation.T),np.identity(3)) & np.allclose(np.linalg.det(matrix),1)
25
-
26
- def affine_inverse(matrix):
27
- """
28
- affine_inverse(matrix)
29
-
30
- WARNING:
31
- This is NOT a generic inversion of an affine transformation matrix
32
-
33
- This returns the affine transformation inverting that produced by the input matrix,
34
-
35
- ASSSUMING that only rotation and translation were involved
36
- in the affine transformation, no zoom, no shear!
37
-
38
- That preserves the fact that the orthogonal property of the part of the input matrix
39
- corresponding to rotation => the inverse is simply the transpose.
40
-
41
- Pierre Royer
42
- """
43
- #import numpy as np
44
-
45
- # Extract Rotation matrix and translation vector from input affine transformation
46
- R = matrix[:3,:3]
47
- t = matrix[:3,3]
48
- #
49
- # Invert the rotation and the translation
50
- Rinv = R.T
51
- tinv = -t
52
- #
53
- # The inverse affine is composed from R^-1 for the rotation and -(R^-1 . t) for the translation
54
- result = np.identity(4)
55
- result[:3,:3] = Rinv
56
- result[:3,3] = np.dot(Rinv,tinv)
57
-
58
- if affine_isEuclidian(result):
59
- return result
60
- else:
61
- print("WARNING: This is not a rigid-body transformation matrix")
62
- #print(f"R.T-based (.6f) = \n {np.round(result,6)}")
63
- #print(f"np.inverse (.6f) = \n {np.round(np.linalg.inv(matrix),6)}")
64
- return np.linalg.inv(matrix)
65
-
66
- def affine_matrix_from_points(v0, v1, shear=False, scale=False, usesvd=True):
67
- """affine_matrix_from_points(v0, v1, shear=False, scale=False, usesvd=True)
68
- Return affine transform matrix to register two point sets.
69
-
70
- v0 and v1 are shape (ndims, \*) arrays of at least ndims non-homogeneous
71
- coordinates, where ndims is the dimensionality of the coordinate space.
72
-
73
- If shear is False, a similarity transformation matrix is returned.
74
- If also scale is False, a rigid/Euclidean transformation matrix
75
- is returned.
76
-
77
- By default the algorithm by Hartley and Zissermann [15] is used.
78
- If usesvd is True, similarity and Euclidean transformation matrices
79
- are calculated by minimizing the weighted sum of squared deviations
80
- (RMSD) according to the algorithm by Kabsch [8].
81
- Otherwise, and if ndims is 3, the quaternion based algorithm by Horn [9]
82
- is used, which is slower when using this Python implementation.
83
-
84
- The returned matrix performs rotation, translation and uniform scaling
85
- (if specified).
86
-
87
- >>> v0 = [[0, 1031, 1031, 0], [0, 0, 1600, 1600]]
88
- >>> v1 = [[675, 826, 826, 677], [55, 52, 281, 277]]
89
- >>> affine_matrix_from_points(v0, v1)
90
- array([[ 0.14549, 0.00062, 675.50008],
91
- [ 0.00048, 0.14094, 53.24971],
92
- [ 0. , 0. , 1. ]])
93
- >>> T = translation_matrix(numpy.random.random(3)-0.5)
94
- >>> R = random_rotation_matrix(numpy.random.random(3))
95
- >>> S = scale_matrix(random.random())
96
- >>> M = concatenate_matrices(T, R, S)
97
- >>> v0 = (numpy.random.rand(4, 100) - 0.5) * 20
98
- >>> v0[3] = 1
99
- >>> v1 = numpy.dot(M, v0)
100
- >>> v0[:3] += numpy.random.normal(0, 1e-8, 300).reshape(3, -1)
101
- >>> M = affine_matrix_from_points(v0[:3], v1[:3])
102
- >>> numpy.allclose(v1, numpy.dot(M, v0))
103
- True
104
-
105
- More examples in superimposition_matrix()
106
-
107
- Author: this function was extracted from the original transformations.py
108
- written by Christoph Golke:
109
- https://www.lfd.uci.edu/~gohlke/code/transformations.py.html
110
-
111
- usesvd controls the use of a method based on Singular Value Decomposition (SVD)
112
- --> when True, it is equivalent to rigid_transform_3D (see below)
113
-
114
- """
115
- import numpy
116
- v0 = numpy.array(v0, dtype=numpy.float64, copy=True)
117
- v1 = numpy.array(v1, dtype=numpy.float64, copy=True)
118
-
119
- ndims = v0.shape[0]
120
- if ndims < 2 or v0.shape[1] < ndims or v0.shape != v1.shape:
121
- print(f"ndims {ndims} v0/1.shape {v0.shape} {v1.shape} v0/1 class {v0.__class__} {v1.__class__}")
122
- raise ValueError('input arrays are of wrong shape or type')
123
-
124
- # move centroids to origin
125
- t0 = -numpy.mean(v0, axis=1)
126
- M0 = numpy.identity(ndims+1)
127
- M0[:ndims, ndims] = t0
128
- v0 += t0.reshape(ndims, 1)
129
- t1 = -numpy.mean(v1, axis=1)
130
- M1 = numpy.identity(ndims+1)
131
- M1[:ndims, ndims] = t1
132
- v1 += t1.reshape(ndims, 1)
133
-
134
- if shear:
135
- # Affine transformation
136
- A = numpy.concatenate((v0, v1), axis=0)
137
- u, s, vh = numpy.linalg.svd(A.T)
138
- vh = vh[:ndims].T
139
- B = vh[:ndims]
140
- C = vh[ndims:2*ndims]
141
- t = numpy.dot(C, numpy.linalg.pinv(B))
142
- t = numpy.concatenate((t, numpy.zeros((ndims, 1))), axis=1)
143
- M = numpy.vstack((t, ((0.0,)*ndims) + (1.0,)))
144
- elif usesvd or ndims != 3:
145
- # Rigid transformation via SVD of covariance matrix
146
- u, s, vh = numpy.linalg.svd(numpy.dot(v1, v0.T))
147
- # rotation matrix from SVD orthonormal bases
148
- R = numpy.dot(u, vh)
149
- if numpy.linalg.det(R) < 0.0:
150
- # R does not constitute right handed system
151
- R -= numpy.outer(u[:, ndims-1], vh[ndims-1, :]*2.0)
152
- s[-1] *= -1.0
153
- # homogeneous transformation matrix
154
- M = numpy.identity(ndims+1)
155
- M[:ndims, :ndims] = R
156
- else:
157
- # Rigid transformation matrix via quaternion
158
- # compute symmetric matrix N
159
- xx, yy, zz = numpy.sum(v0 * v1, axis=1)
160
- xy, yz, zx = numpy.sum(v0 * numpy.roll(v1, -1, axis=0), axis=1)
161
- xz, yx, zy = numpy.sum(v0 * numpy.roll(v1, -2, axis=0), axis=1)
162
- N = [[xx+yy+zz, 0.0, 0.0, 0.0],
163
- [yz-zy, xx-yy-zz, 0.0, 0.0],
164
- [zx-xz, xy+yx, yy-xx-zz, 0.0],
165
- [xy-yx, zx+xz, yz+zy, zz-xx-yy]]
166
- # quaternion: eigenvector corresponding to most positive eigenvalue
167
- w, V = numpy.linalg.eigh(N)
168
- q = V[:, numpy.argmax(w)]
169
- q /= _vector_norm(q) # unit quaternion
170
- # homogeneous transformation matrix
171
- M = _quaternion_matrix(q)
172
-
173
- if scale and not shear:
174
- # Affine transformation; scale is ratio of RMS deviations from centroid
175
- v0 *= v0
176
- v1 *= v1
177
- M[:ndims, :ndims] *= math.sqrt(numpy.sum(v1) / numpy.sum(v0))
178
-
179
- # move centroids back
180
- M = numpy.dot(numpy.linalg.inv(M1), numpy.dot(M, M0))
181
- M /= M[ndims, ndims]
182
- return M
183
-
184
-
185
- def _vector_norm(data, axis=None, out=None):
186
- """Return length, i.e. Euclidean norm, of ndarray along axis.
187
-
188
- >>> v = numpy.random.random(3)
189
- >>> n = vector_norm(v)
190
- >>> numpy.allclose(n, numpy.linalg.norm(v))
191
- True
192
- >>> v = numpy.random.rand(6, 5, 3)
193
- >>> n = vector_norm(v, axis=-1)
194
- >>> numpy.allclose(n, numpy.sqrt(numpy.sum(v*v, axis=2)))
195
- True
196
- >>> n = vector_norm(v, axis=1)
197
- >>> numpy.allclose(n, numpy.sqrt(numpy.sum(v*v, axis=1)))
198
- True
199
- >>> v = numpy.random.rand(5, 4, 3)
200
- >>> n = numpy.empty((5, 3))
201
- >>> vector_norm(v, axis=1, out=n)
202
- >>> numpy.allclose(n, numpy.sqrt(numpy.sum(v*v, axis=1)))
203
- True
204
- >>> vector_norm([])
205
- 0.0
206
- >>> vector_norm([1])
207
- 1.0
208
-
209
- This function is called by affine_matrix_from_points when usesvd=False
210
-
211
- Author: this function was extracted from the original transformations.py
212
- written by Christoph Golke:
213
- https://www.lfd.uci.edu/~gohlke/code/transformations.py.html
214
-
215
- """
216
- data = numpy.array(data, dtype=numpy.float64, copy=True)
217
- if out is None:
218
- if data.ndim == 1:
219
- return math.sqrt(numpy.dot(data, data))
220
- data *= data
221
- out = numpy.atleast_1d(numpy.sum(data, axis=axis))
222
- numpy.sqrt(out, out)
223
- return out
224
- else:
225
- data *= data
226
- numpy.sum(data, axis=axis, out=out)
227
- numpy.sqrt(out, out)
228
-
229
-
230
- def _quaternion_matrix(quaternion):
231
- """Return homogeneous rotation matrix from quaternion.
232
-
233
- >>> M = quaternion_matrix([0.99810947, 0.06146124, 0, 0])
234
- >>> numpy.allclose(M, rotation_matrix(0.123, [1, 0, 0]))
235
- True
236
- >>> M = quaternion_matrix([1, 0, 0, 0])
237
- >>> numpy.allclose(M, numpy.identity(4))
238
- True
239
- >>> M = quaternion_matrix([0, 1, 0, 0])
240
- >>> numpy.allclose(M, numpy.diag([1, -1, -1, 1]))
241
- True
242
-
243
- This function is called by affine_matrix_from_points when usesvd=False
244
-
245
- Author: this function was extracted from the original transformations.py
246
- written by Christoph Golke:
247
- https://www.lfd.uci.edu/~gohlke/code/transformations.py.html
248
- """
249
- _EPS = np.finfo(float).eps * 5
250
-
251
- q = numpy.array(quaternion, dtype=numpy.float64, copy=True)
252
- n = numpy.dot(q, q)
253
- if n < _EPS:
254
- return numpy.identity(4)
255
- q *= math.sqrt(2.0 / n)
256
- q = numpy.outer(q, q)
257
- return numpy.array([
258
- [1.0-q[2, 2]-q[3, 3], q[1, 2]-q[3, 0], q[1, 3]+q[2, 0], 0.0],
259
- [ q[1, 2]+q[3, 0], 1.0-q[1, 1]-q[3, 3], q[2, 3]-q[1, 0], 0.0],
260
- [ q[1, 3]-q[2, 0], q[2, 3]+q[1, 0], 1.0-q[1, 1]-q[2, 2], 0.0],
261
- [ 0.0, 0.0, 0.0, 1.0]])
262
-
263
-
264
- def rigid_transform_3D(fromA, toB, verbose=True):
265
- """rigid_transform_3D(fromA, toB, verbose=True)
266
-
267
- INPUT
268
- Afrom, Bto 3xn arrays = xyz coords of n points to be registered
269
-
270
- OUTPUT
271
- Rotation + translation transformation matrix registering fromA into toB
272
-
273
- Author : Nghia Ho - 2013 - http://nghiaho.com/?page_id=671
274
- "Finding optimal rotation and translation between corresponding 3D points"
275
- Based on "A Method for Registration of 3-D Shapes", by Besl and McKay, 1992.
276
-
277
- This is based on Singular Value Decomposition (SVD)
278
- --> it is equivalent to affine_matrix_from_points with parameter usesvd=True
279
- """
280
- A = fromA.T
281
- B = toB.T
282
-
283
- assert len(A) == len(B)
284
-
285
- N = A.shape[0]; # total points
286
-
287
- centroid_A = np.mean(A, axis=0)
288
- centroid_B = np.mean(B, axis=0)
289
-
290
- # centre the points
291
- AA = A - np.tile(centroid_A, (N, 1))
292
- BB = B - np.tile(centroid_B, (N, 1))
293
-
294
- # @ is matrix multiplication for array
295
- H = np.transpose(AA) @ BB
296
-
297
- U, S, Vt = np.linalg.svd(H)
298
-
299
- R = Vt.T @ U.T
300
-
301
- # special reflection case
302
- if np.linalg.det(R) < 0:
303
- print ("Reflection detected")
304
- Vt[2,:] *= -1
305
- R = Vt.T @ U.T
306
-
307
- t = -R @ centroid_A.T + centroid_B.T
308
-
309
- result = np.identity(4)
310
- result[:3,:3] = R
311
- result[:3,3] = t
312
-
313
- return result
314
-
315
-
316
- def translationRotationToTransformation(translation,rotation,rot_config="sxyz",active=True,degrees=True,translationFirst=False):
317
- """
318
- translationRotationToTransformation(translation,rotation,rot_config="sxyz",active=True,degrees=True,translationFirst=False)
319
-
320
- translationFirst : translation first
321
- False first 3 rows of transformation matrix = (R t) [usual convention and default here]
322
- True first 3 rows of transformation matrix = (R Rt) [used in the hexapod]
323
- """
324
- import transforms3d as t3
325
- import numpy as np
326
- # Zoom - unit
327
- zdef = np.array([1,1,1])
328
- # Shear
329
- sdef = np.array([0,0,0])
330
- translation = np.array(translation)
331
- #if degrees: rotation = np.deg2rad(np.array(rotation))
332
- if degrees: rotation = np.array([np.deg2rad(item) for item in rotation])
333
- rotx,roty,rotz = rotation
334
- rmat = RotationMatrix(rotx,roty,rotz,rot_config=rot_config,active=active)
335
- #
336
- if translationFirst:
337
- result = np.identity(4)
338
- result[:3,:3] = rmat.R
339
- result[:3,3] = rmat.R @ translation
340
- else:
341
- result = t3.affines.compose(translation,rmat.R,Z=zdef,S=sdef)
342
- return result
343
-
344
- def translationRotationFromTransformation(transformation,rot_config="sxyz",active=True,degrees=True,translationFirst=False):
345
- """
346
- translationRotationFromTransformation(transformation,rot_config="sxyz",active=True,degrees=True,translationFirst=False)
347
-
348
- translationFirst : translation first
349
- False first 3 rows of transformation matrix = (R t) [usual convention and default here]
350
- True first 3 rows of transformation matrix = (R Rt) [used in the hexapod]
351
- """
352
- translation = transformation[:3,3]
353
- rotation = t3.euler.mat2euler(transformation,axes=rot_config)
354
- if degrees: rotation = np.array([np.rad2deg(item) for item in rotation])
355
- if translationFirst:
356
- translation = transformation[:3,:3].T @ translation
357
- return translation,rotation
358
-
359
- tr2T = translationRotationToTransformation
360
- T2tr = translationRotationFromTransformation
361
-
362
-
363
- def vectorPlaneIntersection(pt, frame, epsilon=1.e-6):
364
- """
365
- return the coordinates of the intersection of a vector with a plane.
366
-
367
- pt = input vector. Point object, expressing the vector
368
- vector origin = pt.ref.getOrigin().coordinates[:3]
369
- vector direction = pt.coordinates[:3]
370
- frame = input plane. ReferenceFrame object whose x-y plane is the target plane for intersection
371
-
372
- If the vector's own reference frame is 'frame', the problem is trivial
373
-
374
- In all cases, the coordinates of the interesection point are provided as a Point object, in "frame" coordinates
375
-
376
- Ref:
377
- https://stackoverflow.com/questions/5666222/3d-line-plane-intersection
378
- """
379
-
380
- from egse.coordinates.point import Point
381
-
382
- if pt.ref == frame:
383
- # The point is defined in frame => the origin of the vector is the origin of the target plane.
384
- return np.array([0,0,0])
385
- else:
386
- # Express all inputs in 'frame'
387
-
388
- # Vector Origin (p0)
389
- vec_orig = Point(pt.ref.getOrigin().coordinates[:3],ref=pt.ref, name='ptorig').expressIn(frame)[:3]
390
- # Vector End (p1)
391
- vec_end = pt.expressIn(frame)[:3]
392
- # Vector (u)
393
- vec = vec_end - vec_orig
394
-
395
- # A point in Plane (pco)
396
- #plane_orig = np.array([0,0,0],dtype=float)
397
- plane_orig = frame.getOrigin().coordinates[:3]
398
- # Normal to the plane (pno)
399
- plane_normal = frame.getAxis('z').coordinates[:3]
400
-
401
- # Vector to normal 'angle'
402
- vec_x_normal = np.dot(vec, plane_normal)
403
-
404
- # Test if there is an intersection (and if it's unique)
405
- # --> input vector and normal mustn't be perpendicular, else the vector is // to the plane or inside it
406
- #
407
- if (np.allclose(vec_x_normal, 0., atol=epsilon)):
408
- print('The input vector is // to the plane normal (or inside the plane)')
409
- print('--> there exists no intersection (or an infinity of them)')
410
- return None
411
- else:
412
- # Vector from the point in the plane to the origin of the vector (w)
413
- plane_to_vec = vec_orig - plane_orig
414
-
415
- # Solution ("how many 'vectors' away is the interesection ?")
416
- vec_multiplicator = - np.dot(plane_normal, plane_to_vec) / vec_x_normal
417
-
418
- return Point(vec_orig + (vec * vec_multiplicator), ref=frame)
419
-
egse/csl/__init__.py DELETED
@@ -1,50 +0,0 @@
1
- from enum import Enum
2
- from pathlib import Path
3
- from executor import ExternalCommand
4
- from gui_executor.utils import read_id
5
-
6
- from egse.settings import Settings
7
-
8
- HERE = Path(__file__).parent.resolve()
9
- HOME_DIR = Path('~').expanduser()
10
- ID_FILE = HOME_DIR / "hexapod_id.txt"
11
-
12
- HEXAPODS = Settings.load(location=HOME_DIR,
13
- filename="mech_pos_settings.yaml",
14
- group_name="Hexapod",
15
- add_local_settings=False)
16
-
17
-
18
- class HexapodID(str, Enum):
19
- H_1A = "1A"
20
- H_1B = "1B"
21
- H_2A = "2A"
22
- H_2B = "2B"
23
-
24
-
25
- def get_endpoint_hexapod(hexapod_id: str = None):
26
- """Returns the hostname and port number for the Hexapod."""
27
-
28
- hexapod_id = hexapod_id or read_id(ID_FILE)
29
-
30
- hostname = HEXAPODS[f"H_{hexapod_id}"]["HOSTNAME"]
31
- port = HEXAPODS[f"H_{hexapod_id}"]["PORT"]
32
-
33
- print(f"{hexapod_id=}, {hostname=}, {port=}")
34
-
35
- return "PUNA", hexapod_id, hostname, port
36
-
37
-
38
- def mechanical_position_ui():
39
- """ Definition of the UI for the mechanical position at CSL.
40
-
41
- This UI is built using the gui-executor code, and uses the definitions from this module.
42
- """
43
- logo_path = HERE / "icons/logo-puna.svg"
44
- cmd = ExternalCommand(
45
- f"gui-executor --module-path egse.csl --logo {logo_path} --single "
46
- f"--kernel-name plato-common-egse "
47
- f"--app-name 'CSL Operator GUI (M-position)'",
48
- asynchronous=True
49
- )
50
- cmd.start()
egse/csl/commanding.py DELETED
@@ -1,78 +0,0 @@
1
- """ Content of the UI for the mechanical position at CSL. This basically needs two buttons to command the hexapod:
2
- - a button to go to the home position;
3
- - a button to go to the retracted position.
4
- """
5
- from pathlib import Path
6
-
7
- from gui_executor.exec import exec_ui
8
-
9
- from egse.csl import get_endpoint_hexapod
10
- from egse.hexapod.symetrie.puna import PunaController
11
-
12
- UI_MODULE_DISPLAY_NAME = "2 - Commanding"
13
-
14
- ID_FILE = Path('~').expanduser() / "id.txt"
15
-
16
- HERE = Path(__file__).parent.resolve()
17
-
18
-
19
- @exec_ui(display_name="Zero position",
20
- icons=(HERE/"icons/hexapod-zero.svg", HERE/"icons/hexapod-zero-selected.svg"))
21
- def goto_zero_position():
22
- """ Move the hexapod to the zero position."""
23
-
24
- hexapod = None
25
- hexapod_name, hexapod_id, hostname, port = get_endpoint_hexapod()
26
- try:
27
- from egse.hexapod.symetrie import ControllerFactory
28
- factory = ControllerFactory()
29
- hexapod = factory.create(hexapod_name, device_id=hexapod_id)
30
- hexapod.connect()
31
- hexapod.goto_zero_position()
32
- except ConnectionError as exc:
33
- print("[red]Couldn't connect to the Hexapod Controller. "
34
- "Check if the Controller is switched on and no error is reported on the front panel of the controller.[/]")
35
- finally:
36
- if hexapod is not None:
37
- hexapod.disconnect()
38
-
39
-
40
- @exec_ui(display_name="Retracted position",
41
- icons=(HERE/"icons/hexapod-retract.svg", HERE/"icons/hexapod-retract-selected.svg"))
42
- def goto_retracted_position():
43
- """ Move the hexapod to the retracted position."""
44
-
45
- hexapod = None
46
- hexapod_name, hexapod_id, hostname, port = get_endpoint_hexapod()
47
- try:
48
- from egse.hexapod.symetrie import ControllerFactory
49
- factory = ControllerFactory()
50
- hexapod = factory.create(hexapod_name, device_id=hexapod_id)
51
- hexapod.connect()
52
- hexapod.goto_retracted_position()
53
- except ConnectionError as exc:
54
- print("[red]Couldn't connect to the Hexapod Controller. "
55
- "Check if the Controller is switched on and no error is reported on the front panel of the controller.[/]")
56
- finally:
57
- if hexapod is not None:
58
- hexapod.disconnect()
59
-
60
-
61
- @exec_ui(display_name="Emergency stop", icons=(HERE / "icons/stop.svg", HERE / "icons/stop.svg"), immediate_run=True)
62
- def emergency_stop():
63
- """ Emergency stop of the hexapod."""
64
-
65
- hexapod = None
66
- hexapod_name, hexapod_id, hostname, port = get_endpoint_hexapod()
67
- try:
68
- from egse.hexapod.symetrie import ControllerFactory
69
- factory = ControllerFactory()
70
- hexapod = factory.create(hexapod_name, device_id=hexapod_id)
71
- hexapod.connect()
72
- hexapod.stop()
73
- except ConnectionError as exc:
74
- print("[red]Couldn't connect to the Hexapod Controller. "
75
- "Check if the Controller is switched on and no error is reported on the front panel of the controller.[/]")
76
- finally:
77
- if hexapod is not None:
78
- hexapod.disconnect()
@@ -1,30 +0,0 @@
1
- <?xml version="1.0" encoding="UTF-8"?>
2
- <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
3
- <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0" y="0" width="512.004" height="512.004" viewBox="0, 0, 512.004, 512.004">
4
- <g id="connected-selected">
5
- <path d="M481.539,52.376 L458.251,29.089 C455.051,25.889 449.385,25.889 446.185,29.089 L376.314,98.96 C372.978,102.296 372.978,107.69 376.314,111.026 L399.601,134.313 C401.197,135.917 403.373,136.813 405.634,136.813 C407.895,136.813 410.063,135.917 411.667,134.313 L481.538,64.442 C484.875,61.106 484.875,55.713 481.539,52.376 z M405.635,116.214 L394.414,104.993 L452.219,47.188 L463.44,58.409 L405.635,116.214 z" fill="#126EFF"/>
6
- <path d="M417.07,127.657 L382.971,93.558 C372.987,83.574 356.757,83.574 346.773,93.558 L335.543,104.779 C333.939,106.375 333.043,108.542 333.043,110.812 C333.043,113.073 333.939,115.241 335.543,116.845 L393.775,175.076 C395.371,176.68 397.547,177.576 399.808,177.576 C402.078,177.576 404.245,176.671 405.85,175.076 L417.071,163.855 C427.054,153.871 427.054,137.641 417.07,127.657 z M404.995,151.781 L399.807,156.969 L353.65,110.804 L358.838,105.616 C362.166,102.305 367.576,102.288 370.904,105.616 L404.995,139.715 C408.323,143.043 408.323,148.453 404.995,151.781 z" fill="#126EFF"/>
7
- <path d="M410.192,167.354 L343.257,100.419 C330.363,87.525 313.228,80.425 294.992,80.425 C276.765,80.425 259.63,87.525 246.736,100.419 L195.801,151.354 C194.197,152.95 193.301,155.117 193.301,157.387 C193.301,159.657 194.197,161.816 195.801,163.42 L347.191,314.818 C348.855,316.482 351.04,317.318 353.224,317.318 C355.409,317.318 357.593,316.482 359.257,314.818 L410.192,263.883 C436.799,237.268 436.799,193.961 410.192,167.354 z M398.126,251.817 L353.224,296.719 L213.899,157.387 L258.801,112.493 C268.469,102.825 281.32,97.5 294.991,97.5 C308.67,97.5 321.521,102.825 331.189,112.493 L398.124,179.428 C418.076,199.38 418.076,231.858 398.126,251.817 z" fill="#126EFF"/>
8
- <path d="M398.061,251.81 L353.159,296.712 L213.834,157.38 L258.736,112.486 C268.404,102.818 281.255,97.493 294.926,97.493 C308.605,97.493 321.456,102.818 331.124,112.486 L398.059,179.421 C418.011,199.373 418.011,231.851 398.061,251.81 z" fill="#E29AFF"/>
9
- <path d="M341.797,145.543 L318.501,122.238 C305.539,109.284 284.47,109.284 271.517,122.238 L248.221,145.543 C244.884,148.88 244.884,154.273 248.221,157.609 C251.558,160.945 256.959,160.945 260.287,157.609 L283.583,134.304 C289.889,128.006 300.138,128.006 306.435,134.304 L329.731,157.609 C331.395,159.273 333.58,160.109 335.764,160.109 C337.94,160.109 340.124,159.273 341.797,157.609 C345.133,154.273 345.133,148.879 341.797,145.543 z" fill="#126EFF"/>
10
- <path d="M134.093,400.187 L110.806,376.9 C109.21,375.296 107.034,374.4 104.773,374.4 C102.512,374.4 100.344,375.296 98.74,376.9 L28.868,446.771 C25.532,450.108 25.532,455.501 28.868,458.837 L52.155,482.124 C53.751,483.728 55.927,484.624 58.188,484.624 C60.458,484.624 62.625,483.728 64.221,482.124 L134.092,412.253 C137.429,408.917 137.429,403.524 134.093,400.187 z M58.189,464.025 L46.968,452.804 L104.773,394.999 L115.994,406.22 L58.189,464.025 z" fill="#126EFF"/>
11
- <path d="M174.848,394.376 L116.617,336.145 C115.021,334.541 112.845,333.645 110.584,333.645 C108.323,333.645 106.155,334.541 104.551,336.145 L93.33,347.366 C83.346,357.35 83.346,373.58 93.33,383.564 L127.429,417.663 C132.421,422.655 138.975,425.147 145.528,425.147 C152.081,425.147 158.635,422.655 163.619,417.663 L174.849,406.442 C176.453,404.846 177.349,402.679 177.349,400.409 C177.348,398.148 176.452,395.981 174.848,394.376 z M151.578,405.589 C148.25,408.9 142.84,408.917 139.512,405.589 L105.413,371.49 C102.085,368.162 102.085,362.752 105.413,359.424 L110.601,354.236 L156.766,400.401 L151.578,405.589 z" fill="#126EFF"/>
12
- <path d="M326.247,336.128 L174.857,184.738 C171.657,181.538 165.991,181.538 162.791,184.738 L100.208,247.321 C73.601,273.936 73.601,317.243 100.208,343.85 L167.143,410.785 C180.037,423.679 197.172,430.779 215.408,430.779 C233.644,430.779 250.779,423.679 263.673,410.777 L326.248,348.194 C329.583,344.857 329.583,339.464 326.247,336.128 z M251.597,398.72 C241.929,408.388 229.078,413.713 215.407,413.713 C201.728,413.713 188.877,408.388 179.209,398.72 L112.274,331.785 C92.323,311.834 92.323,279.356 112.274,259.397 L168.824,202.847 L308.139,342.171 L251.597,398.72 z" fill="#126EFF"/>
13
- <path d="M251.597,398.72 C241.929,408.388 229.078,413.713 215.407,413.713 C201.728,413.713 188.877,408.388 179.209,398.72 L112.274,331.785 C92.323,311.834 92.323,279.356 112.274,259.397 L168.824,202.847 L308.139,342.171 L251.597,398.72 z" fill="#E29AFF"/>
14
- <path d="M279.663,336.136 L174.857,231.33 C171.521,227.993 166.127,227.993 162.791,231.33 L116.208,277.913 C112.871,281.25 112.871,286.643 116.208,289.979 L221.023,394.785 C222.687,396.449 224.872,397.285 227.056,397.285 C229.232,397.285 231.417,396.449 233.081,394.785 L279.664,348.202 C283,344.866 283,339.473 279.663,336.136 z M227.047,376.687 L134.307,283.947 L168.824,249.43 L261.564,342.17 L227.047,376.687 z" fill="#126EFF"/>
15
- <path d="M231.44,314.497 L196.505,279.553 C193.168,276.217 187.775,276.216 184.439,279.553 C181.103,282.89 181.103,288.283 184.439,291.619 L219.374,326.563 C221.038,328.227 223.223,329.063 225.407,329.063 C227.591,329.063 229.776,328.227 231.44,326.563 C234.777,323.226 234.777,317.833 231.44,314.497 z" fill="#126EFF"/>
16
- </g>
17
- <g id="connected" display="none">
18
- <path d="M481.539,52.376 L458.251,29.089 C455.051,25.889 449.385,25.889 446.185,29.089 L376.314,98.96 C372.978,102.296 372.978,107.69 376.314,111.026 L399.601,134.313 C401.197,135.917 403.373,136.813 405.634,136.813 C407.895,136.813 410.063,135.917 411.667,134.313 L481.538,64.442 C484.875,61.106 484.875,55.713 481.539,52.376 z M405.635,116.214 L394.414,104.993 L452.219,47.188 L463.44,58.409 L405.635,116.214 z" fill="#126EFF"/>
19
- <path d="M417.07,127.657 L382.971,93.558 C372.987,83.574 356.757,83.574 346.773,93.558 L335.543,104.779 C333.939,106.375 333.043,108.542 333.043,110.812 C333.043,113.073 333.939,115.241 335.543,116.845 L393.775,175.076 C395.371,176.68 397.547,177.576 399.808,177.576 C402.078,177.576 404.245,176.671 405.85,175.076 L417.071,163.855 C427.054,153.871 427.054,137.641 417.07,127.657 z M404.995,151.781 L399.807,156.969 L353.65,110.804 L358.838,105.616 C362.166,102.305 367.576,102.288 370.904,105.616 L404.995,139.715 C408.323,143.043 408.323,148.453 404.995,151.781 z" fill="#126EFF"/>
20
- <path d="M410.192,167.354 L343.257,100.419 C330.363,87.525 313.228,80.425 294.992,80.425 C276.765,80.425 259.63,87.525 246.736,100.419 L195.801,151.354 C194.197,152.95 193.301,155.117 193.301,157.387 C193.301,159.657 194.197,161.816 195.801,163.42 L347.191,314.818 C348.855,316.482 351.04,317.318 353.224,317.318 C355.409,317.318 357.593,316.482 359.257,314.818 L410.192,263.883 C436.799,237.268 436.799,193.961 410.192,167.354 z M398.126,251.817 L353.224,296.719 L213.899,157.387 L258.801,112.493 C268.469,102.825 281.32,97.5 294.991,97.5 C308.67,97.5 321.521,102.825 331.189,112.493 L398.124,179.428 C418.076,199.38 418.076,231.858 398.126,251.817 z" fill="#126EFF"/>
21
- <path d="M398.061,251.81 L353.159,296.712 L213.834,157.38 L258.736,112.486 C268.404,102.818 281.255,97.493 294.926,97.493 C308.605,97.493 321.456,102.818 331.124,112.486 L398.059,179.421 C418.011,199.373 418.011,231.851 398.061,251.81 z" fill="#A5CBFF"/>
22
- <path d="M341.797,145.543 L318.501,122.238 C305.539,109.284 284.47,109.284 271.517,122.238 L248.221,145.543 C244.884,148.88 244.884,154.273 248.221,157.609 C251.558,160.945 256.959,160.945 260.287,157.609 L283.583,134.304 C289.889,128.006 300.138,128.006 306.435,134.304 L329.731,157.609 C331.395,159.273 333.58,160.109 335.764,160.109 C337.94,160.109 340.124,159.273 341.797,157.609 C345.133,154.273 345.133,148.879 341.797,145.543 z" fill="#126EFF"/>
23
- <path d="M134.093,400.187 L110.806,376.9 C109.21,375.296 107.034,374.4 104.773,374.4 C102.512,374.4 100.344,375.296 98.74,376.9 L28.868,446.771 C25.532,450.108 25.532,455.501 28.868,458.837 L52.155,482.124 C53.751,483.728 55.927,484.624 58.188,484.624 C60.458,484.624 62.625,483.728 64.221,482.124 L134.092,412.253 C137.429,408.917 137.429,403.524 134.093,400.187 z M58.189,464.025 L46.968,452.804 L104.773,394.999 L115.994,406.22 L58.189,464.025 z" fill="#126EFF"/>
24
- <path d="M174.848,394.376 L116.617,336.145 C115.021,334.541 112.845,333.645 110.584,333.645 C108.323,333.645 106.155,334.541 104.551,336.145 L93.33,347.366 C83.346,357.35 83.346,373.58 93.33,383.564 L127.429,417.663 C132.421,422.655 138.975,425.147 145.528,425.147 C152.081,425.147 158.635,422.655 163.619,417.663 L174.849,406.442 C176.453,404.846 177.349,402.679 177.349,400.409 C177.348,398.148 176.452,395.981 174.848,394.376 z M151.578,405.589 C148.25,408.9 142.84,408.917 139.512,405.589 L105.413,371.49 C102.085,368.162 102.085,362.752 105.413,359.424 L110.601,354.236 L156.766,400.401 L151.578,405.589 z" fill="#126EFF"/>
25
- <path d="M326.247,336.128 L174.857,184.738 C171.657,181.538 165.991,181.538 162.791,184.738 L100.208,247.321 C73.601,273.936 73.601,317.243 100.208,343.85 L167.143,410.785 C180.037,423.679 197.172,430.779 215.408,430.779 C233.644,430.779 250.779,423.679 263.673,410.777 L326.248,348.194 C329.583,344.857 329.583,339.464 326.247,336.128 z M251.597,398.72 C241.929,408.388 229.078,413.713 215.407,413.713 C201.728,413.713 188.877,408.388 179.209,398.72 L112.274,331.785 C92.323,311.834 92.323,279.356 112.274,259.397 L168.824,202.847 L308.139,342.171 L251.597,398.72 z" fill="#126EFF"/>
26
- <path d="M251.597,398.72 C241.929,408.388 229.078,413.713 215.407,413.713 C201.728,413.713 188.877,408.388 179.209,398.72 L112.274,331.785 C92.323,311.834 92.323,279.356 112.274,259.397 L168.824,202.847 L308.139,342.171 L251.597,398.72 z" fill="#A5CBFF"/>
27
- <path d="M279.663,336.136 L174.857,231.33 C171.521,227.993 166.127,227.993 162.791,231.33 L116.208,277.913 C112.871,281.25 112.871,286.643 116.208,289.979 L221.023,394.785 C222.687,396.449 224.872,397.285 227.056,397.285 C229.232,397.285 231.417,396.449 233.081,394.785 L279.664,348.202 C283,344.866 283,339.473 279.663,336.136 z M227.047,376.687 L134.307,283.947 L168.824,249.43 L261.564,342.17 L227.047,376.687 z" fill="#126EFF"/>
28
- <path d="M231.44,314.497 L196.505,279.553 C193.168,276.217 187.775,276.216 184.439,279.553 C181.103,282.89 181.103,288.283 184.439,291.619 L219.374,326.563 C221.038,328.227 223.223,329.063 225.407,329.063 C227.591,329.063 229.776,328.227 231.44,326.563 C234.777,323.226 234.777,317.833 231.44,314.497 z" fill="#126EFF"/>
29
- </g>
30
- </svg>