cgse 2023.38.0__py3-none-any.whl → 2024.1.3__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (653) hide show
  1. README.md +27 -0
  2. bump.py +77 -0
  3. cgse-2024.1.3.dist-info/METADATA +41 -0
  4. cgse-2024.1.3.dist-info/RECORD +5 -0
  5. {cgse-2023.38.0.dist-info → cgse-2024.1.3.dist-info}/WHEEL +1 -2
  6. cgse-2023.38.0.dist-info/COPYING +0 -674
  7. cgse-2023.38.0.dist-info/COPYING.LESSER +0 -165
  8. cgse-2023.38.0.dist-info/METADATA +0 -144
  9. cgse-2023.38.0.dist-info/RECORD +0 -649
  10. cgse-2023.38.0.dist-info/entry_points.txt +0 -75
  11. cgse-2023.38.0.dist-info/top_level.txt +0 -2
  12. egse/__init__.py +0 -12
  13. egse/__main__.py +0 -32
  14. egse/aeu/aeu.py +0 -5235
  15. egse/aeu/aeu_awg.yaml +0 -265
  16. egse/aeu/aeu_crio.yaml +0 -273
  17. egse/aeu/aeu_cs.py +0 -626
  18. egse/aeu/aeu_devif.py +0 -321
  19. egse/aeu/aeu_main_ui.py +0 -912
  20. egse/aeu/aeu_metrics.py +0 -131
  21. egse/aeu/aeu_protocol.py +0 -463
  22. egse/aeu/aeu_psu.yaml +0 -204
  23. egse/aeu/aeu_ui.py +0 -873
  24. egse/aeu/arbdata/FccdRead.arb +0 -2
  25. egse/aeu/arbdata/FccdRead_min_points.arb +0 -2
  26. egse/aeu/arbdata/HeaterSync_FccdRead.arb +0 -2
  27. egse/aeu/arbdata/HeaterSync_ccdRead25.arb +0 -2
  28. egse/aeu/arbdata/HeaterSync_ccdRead31_25.arb +0 -2
  29. egse/aeu/arbdata/HeaterSync_ccdRead37_50.arb +0 -2
  30. egse/aeu/arbdata/HeaterSync_ccdRead43_75.arb +0 -2
  31. egse/aeu/arbdata/HeaterSync_ccdRead50.arb +0 -2
  32. egse/aeu/arbdata/Heater_FccdRead_min_points.arb +0 -2
  33. egse/aeu/arbdata/ccdRead25.arb +0 -2
  34. egse/aeu/arbdata/ccdRead25_150ms.arb +0 -2
  35. egse/aeu/arbdata/ccdRead31_25.arb +0 -2
  36. egse/aeu/arbdata/ccdRead31_25_150ms.arb +0 -2
  37. egse/aeu/arbdata/ccdRead37_50.arb +0 -2
  38. egse/aeu/arbdata/ccdRead37_50_150ms.arb +0 -2
  39. egse/aeu/arbdata/ccdRead43_75.arb +0 -2
  40. egse/aeu/arbdata/ccdRead43_75_150ms.arb +0 -2
  41. egse/aeu/arbdata/ccdRead50.arb +0 -2
  42. egse/aeu/arbdata/ccdRead50_150ms.arb +0 -2
  43. egse/alert/__init__.py +0 -1049
  44. egse/alert/alertman.yaml +0 -37
  45. egse/alert/alertman_cs.py +0 -234
  46. egse/alert/alertman_ui.py +0 -603
  47. egse/alert/gsm/beaglebone.py +0 -138
  48. egse/alert/gsm/beaglebone.yaml +0 -51
  49. egse/alert/gsm/beaglebone_cs.py +0 -108
  50. egse/alert/gsm/beaglebone_devif.py +0 -130
  51. egse/alert/gsm/beaglebone_protocol.py +0 -48
  52. egse/bits.py +0 -318
  53. egse/camera.py +0 -44
  54. egse/collimator/__init__.py +0 -0
  55. egse/collimator/fcul/__init__.py +0 -0
  56. egse/collimator/fcul/ogse.py +0 -1077
  57. egse/collimator/fcul/ogse.yaml +0 -14
  58. egse/collimator/fcul/ogse_cs.py +0 -154
  59. egse/collimator/fcul/ogse_devif.py +0 -358
  60. egse/collimator/fcul/ogse_protocol.py +0 -129
  61. egse/collimator/fcul/ogse_sim.py +0 -431
  62. egse/collimator/fcul/ogse_ui.py +0 -1108
  63. egse/command.py +0 -699
  64. egse/config.py +0 -410
  65. egse/confman/__init__.py +0 -1015
  66. egse/confman/confman.yaml +0 -67
  67. egse/confman/confman_cs.py +0 -239
  68. egse/confman/confman_ui.py +0 -381
  69. egse/confman/setup_ui.py +0 -565
  70. egse/control.py +0 -442
  71. egse/coordinates/__init__.py +0 -531
  72. egse/coordinates/avoidance.py +0 -103
  73. egse/coordinates/cslmodel.py +0 -127
  74. egse/coordinates/laser_tracker_to_dict.py +0 -120
  75. egse/coordinates/point.py +0 -707
  76. egse/coordinates/pyplot.py +0 -195
  77. egse/coordinates/referenceFrame.py +0 -1279
  78. egse/coordinates/refmodel.py +0 -737
  79. egse/coordinates/rotationMatrix.py +0 -85
  80. egse/coordinates/transform3d_addon.py +0 -419
  81. egse/csl/__init__.py +0 -50
  82. egse/csl/commanding.py +0 -78
  83. egse/csl/icons/hexapod-connected-selected.svg +0 -30
  84. egse/csl/icons/hexapod-connected.svg +0 -30
  85. egse/csl/icons/hexapod-homing-selected.svg +0 -68
  86. egse/csl/icons/hexapod-homing.svg +0 -68
  87. egse/csl/icons/hexapod-retract-selected.svg +0 -56
  88. egse/csl/icons/hexapod-retract.svg +0 -51
  89. egse/csl/icons/hexapod-zero-selected.svg +0 -56
  90. egse/csl/icons/hexapod-zero.svg +0 -56
  91. egse/csl/icons/logo-puna.svg +0 -92
  92. egse/csl/icons/stop.svg +0 -1
  93. egse/csl/initialisation.py +0 -102
  94. egse/csl/mech_pos_settings.yaml +0 -18
  95. egse/das.py +0 -1247
  96. egse/das.yaml +0 -7
  97. egse/data/conf/SETUP_CSL_00000_170620_150000.yaml +0 -5
  98. egse/data/conf/SETUP_CSL_00001_170620_151010.yaml +0 -69
  99. egse/data/conf/SETUP_CSL_00002_170620_151020.yaml +0 -69
  100. egse/data/conf/SETUP_CSL_00003_170620_151030.yaml +0 -69
  101. egse/data/conf/SETUP_CSL_00004_170620_151040.yaml +0 -69
  102. egse/data/conf/SETUP_CSL_00005_170620_151050.yaml +0 -69
  103. egse/data/conf/SETUP_CSL_00006_170620_151060.yaml +0 -69
  104. egse/data/conf/SETUP_CSL_00007_170620_151070.yaml +0 -69
  105. egse/data/conf/SETUP_CSL_00008_170620_151080.yaml +0 -75
  106. egse/data/conf/SETUP_CSL_00010_210308_083016.yaml +0 -138
  107. egse/data/conf/SETUP_INTA_00000_170620_150000.yaml +0 -4
  108. egse/data/conf/SETUP_SRON_00000_170620_150000.yaml +0 -4
  109. egse/decorators.py +0 -415
  110. egse/device.py +0 -269
  111. egse/dpu/__init__.py +0 -2681
  112. egse/dpu/ccd_ui.py +0 -508
  113. egse/dpu/dpu.py +0 -786
  114. egse/dpu/dpu.yaml +0 -153
  115. egse/dpu/dpu_cs.py +0 -272
  116. egse/dpu/dpu_ui.py +0 -668
  117. egse/dpu/fitsgen.py +0 -2077
  118. egse/dpu/fitsgen_test.py +0 -752
  119. egse/dpu/fitsgen_ui.py +0 -399
  120. egse/dpu/hdf5_model.py +0 -332
  121. egse/dpu/hdf5_ui.py +0 -277
  122. egse/dpu/hdf5_viewer.py +0 -506
  123. egse/dpu/hk_ui.py +0 -468
  124. egse/dpu_commands.py +0 -81
  125. egse/dsi/constants.py +0 -220
  126. egse/dsi/esl.py +0 -870
  127. egse/dsi/rmap.py +0 -1042
  128. egse/dsi/rmapci.py +0 -37
  129. egse/dsi/spw.py +0 -154
  130. egse/dsi/spw_state.py +0 -29
  131. egse/dummy.py +0 -258
  132. egse/dyndummy.py +0 -179
  133. egse/env.py +0 -278
  134. egse/exceptions.py +0 -88
  135. egse/fdir/__init__.py +0 -28
  136. egse/fdir/fdir_manager.py +0 -85
  137. egse/fdir/fdir_manager.yaml +0 -51
  138. egse/fdir/fdir_manager_controller.py +0 -228
  139. egse/fdir/fdir_manager_cs.py +0 -164
  140. egse/fdir/fdir_manager_interface.py +0 -25
  141. egse/fdir/fdir_remote.py +0 -73
  142. egse/fdir/fdir_remote.yaml +0 -37
  143. egse/fdir/fdir_remote_controller.py +0 -50
  144. egse/fdir/fdir_remote_cs.py +0 -97
  145. egse/fdir/fdir_remote_interface.py +0 -14
  146. egse/fdir/fdir_remote_popup.py +0 -31
  147. egse/fee/__init__.py +0 -114
  148. egse/fee/f_fee_register.yaml +0 -43
  149. egse/fee/fee.py +0 -631
  150. egse/fee/feesim.py +0 -750
  151. egse/fee/n_fee_hk.py +0 -761
  152. egse/fee/nfee.py +0 -187
  153. egse/filterwheel/__init__.py +0 -4
  154. egse/filterwheel/eksma/__init__.py +0 -24
  155. egse/filterwheel/eksma/fw8smc4.py +0 -661
  156. egse/filterwheel/eksma/fw8smc4.yaml +0 -121
  157. egse/filterwheel/eksma/fw8smc4_cs.py +0 -144
  158. egse/filterwheel/eksma/fw8smc4_devif.py +0 -473
  159. egse/filterwheel/eksma/fw8smc4_protocol.py +0 -81
  160. egse/filterwheel/eksma/fw8smc4_ui.py +0 -940
  161. egse/filterwheel/eksma/fw8smc5.py +0 -111
  162. egse/filterwheel/eksma/fw8smc5.yaml +0 -105
  163. egse/filterwheel/eksma/fw8smc5_controller.py +0 -307
  164. egse/filterwheel/eksma/fw8smc5_cs.py +0 -141
  165. egse/filterwheel/eksma/fw8smc5_interface.py +0 -65
  166. egse/filterwheel/eksma/fw8smc5_simulator.py +0 -29
  167. egse/filterwheel/eksma/fw8smc5_ui.py +0 -1068
  168. egse/filterwheel/eksma/testpythonfw.py +0 -215
  169. egse/fov/__init__.py +0 -65
  170. egse/fov/fov_hk.py +0 -712
  171. egse/fov/fov_ui.py +0 -861
  172. egse/fov/fov_ui_controller.py +0 -140
  173. egse/fov/fov_ui_model.py +0 -200
  174. egse/fov/fov_ui_view.py +0 -345
  175. egse/gimbal/__init__.py +0 -32
  176. egse/gimbal/symetrie/__init__.py +0 -26
  177. egse/gimbal/symetrie/alpha.py +0 -586
  178. egse/gimbal/symetrie/generic_gimbal_ui.py +0 -1521
  179. egse/gimbal/symetrie/gimbal.py +0 -877
  180. egse/gimbal/symetrie/gimbal.yaml +0 -168
  181. egse/gimbal/symetrie/gimbal_cs.py +0 -183
  182. egse/gimbal/symetrie/gimbal_protocol.py +0 -135
  183. egse/gimbal/symetrie/gimbal_ui.py +0 -361
  184. egse/gimbal/symetrie/pmac.py +0 -1006
  185. egse/gimbal/symetrie/pmac_regex.py +0 -83
  186. egse/graph.py +0 -132
  187. egse/gui/__init__.py +0 -47
  188. egse/gui/buttons.py +0 -378
  189. egse/gui/focalplane.py +0 -1281
  190. egse/gui/formatter.py +0 -10
  191. egse/gui/led.py +0 -162
  192. egse/gui/limitswitch.py +0 -143
  193. egse/gui/mechanisms.py +0 -588
  194. egse/gui/states.py +0 -148
  195. egse/gui/stripchart.py +0 -729
  196. egse/gui/switch.py +0 -112
  197. egse/h5.py +0 -274
  198. egse/help/__init__.py +0 -0
  199. egse/help/help_ui.py +0 -126
  200. egse/hexapod/__init__.py +0 -32
  201. egse/hexapod/symetrie/__init__.py +0 -138
  202. egse/hexapod/symetrie/alpha.py +0 -874
  203. egse/hexapod/symetrie/dynalpha.py +0 -1387
  204. egse/hexapod/symetrie/hexapod_ui.py +0 -1516
  205. egse/hexapod/symetrie/pmac.py +0 -1010
  206. egse/hexapod/symetrie/pmac_regex.py +0 -83
  207. egse/hexapod/symetrie/puna.py +0 -1167
  208. egse/hexapod/symetrie/puna.yaml +0 -193
  209. egse/hexapod/symetrie/puna_cs.py +0 -196
  210. egse/hexapod/symetrie/puna_protocol.py +0 -131
  211. egse/hexapod/symetrie/puna_ui.py +0 -434
  212. egse/hexapod/symetrie/punaplus.py +0 -107
  213. egse/hexapod/symetrie/zonda.py +0 -872
  214. egse/hexapod/symetrie/zonda.yaml +0 -337
  215. egse/hexapod/symetrie/zonda_cs.py +0 -172
  216. egse/hexapod/symetrie/zonda_devif.py +0 -415
  217. egse/hexapod/symetrie/zonda_protocol.py +0 -119
  218. egse/hexapod/symetrie/zonda_ui.py +0 -449
  219. egse/hk.py +0 -765
  220. egse/icons/aeu-cs-start.svg +0 -117
  221. egse/icons/aeu-cs-stop.svg +0 -118
  222. egse/icons/aeu-cs.svg +0 -107
  223. egse/icons/aeu_cs-started.svg +0 -112
  224. egse/icons/aeu_cs-stopped.svg +0 -112
  225. egse/icons/aeu_cs.svg +0 -55
  226. egse/icons/alert.svg +0 -1
  227. egse/icons/arrow-double-left.png +0 -0
  228. egse/icons/arrow-double-right.png +0 -0
  229. egse/icons/arrow-up.svg +0 -11
  230. egse/icons/backward.svg +0 -1
  231. egse/icons/busy.svg +0 -1
  232. egse/icons/cleaning.svg +0 -115
  233. egse/icons/color-scheme.svg +0 -1
  234. egse/icons/cs-connected-alert.svg +0 -91
  235. egse/icons/cs-connected-disabled.svg +0 -43
  236. egse/icons/cs-connected.svg +0 -89
  237. egse/icons/cs-not-connected.svg +0 -44
  238. egse/icons/double-left-arrow.svg +0 -1
  239. egse/icons/double-right-arrow.svg +0 -1
  240. egse/icons/erase-disabled.svg +0 -19
  241. egse/icons/erase.svg +0 -59
  242. egse/icons/fitsgen-start.svg +0 -47
  243. egse/icons/fitsgen-stop.svg +0 -48
  244. egse/icons/fitsgen.svg +0 -1
  245. egse/icons/forward.svg +0 -1
  246. egse/icons/fov-hk-start.svg +0 -33
  247. egse/icons/fov-hk-stop.svg +0 -37
  248. egse/icons/fov-hk.svg +0 -1
  249. egse/icons/front-desk.svg +0 -1
  250. egse/icons/home-actioned.svg +0 -15
  251. egse/icons/home-disabled.svg +0 -15
  252. egse/icons/home.svg +0 -13
  253. egse/icons/info.svg +0 -1
  254. egse/icons/invalid.png +0 -0
  255. egse/icons/led-green.svg +0 -20
  256. egse/icons/led-grey.svg +0 -20
  257. egse/icons/led-orange.svg +0 -20
  258. egse/icons/led-red.svg +0 -20
  259. egse/icons/led-square-green.svg +0 -134
  260. egse/icons/led-square-grey.svg +0 -134
  261. egse/icons/led-square-orange.svg +0 -134
  262. egse/icons/led-square-red.svg +0 -134
  263. egse/icons/limit-switch-all-green.svg +0 -115
  264. egse/icons/limit-switch-all-red.svg +0 -117
  265. egse/icons/limit-switch-el+.svg +0 -116
  266. egse/icons/limit-switch-el-.svg +0 -117
  267. egse/icons/location-marker.svg +0 -1
  268. egse/icons/logo-dpu.svg +0 -48
  269. egse/icons/logo-gimbal.svg +0 -112
  270. egse/icons/logo-huber.svg +0 -23
  271. egse/icons/logo-ogse.svg +0 -31
  272. egse/icons/logo-puna.svg +0 -92
  273. egse/icons/logo-tcs.svg +0 -29
  274. egse/icons/logo-zonda.svg +0 -66
  275. egse/icons/maximize.svg +0 -1
  276. egse/icons/meter.svg +0 -1
  277. egse/icons/more.svg +0 -45
  278. egse/icons/n-fee-hk-start.svg +0 -24
  279. egse/icons/n-fee-hk-stop.svg +0 -25
  280. egse/icons/n-fee-hk.svg +0 -83
  281. egse/icons/observing-off.svg +0 -46
  282. egse/icons/observing-on.svg +0 -46
  283. egse/icons/open-document-hdf5.png +0 -0
  284. egse/icons/open-document-hdf5.svg +0 -21
  285. egse/icons/ops-mode.svg +0 -1
  286. egse/icons/play-green.svg +0 -17
  287. egse/icons/plugged-disabled.svg +0 -27
  288. egse/icons/plugged.svg +0 -21
  289. egse/icons/pm_ui.svg +0 -1
  290. egse/icons/power-button-green.svg +0 -27
  291. egse/icons/power-button-red.svg +0 -27
  292. egse/icons/power-button.svg +0 -27
  293. egse/icons/radar.svg +0 -1
  294. egse/icons/radioactive.svg +0 -2
  295. egse/icons/reload.svg +0 -1
  296. egse/icons/remote-control-off.svg +0 -28
  297. egse/icons/remote-control-on.svg +0 -28
  298. egse/icons/repeat-blue.svg +0 -15
  299. egse/icons/repeat.svg +0 -1
  300. egse/icons/settings.svg +0 -1
  301. egse/icons/shrink.svg +0 -1
  302. egse/icons/shutter.svg +0 -1
  303. egse/icons/sign-off.svg +0 -1
  304. egse/icons/sign-on.svg +0 -1
  305. egse/icons/sim-mode.svg +0 -1
  306. egse/icons/small-buttons-go.svg +0 -20
  307. egse/icons/small-buttons-minus.svg +0 -51
  308. egse/icons/small-buttons-plus.svg +0 -51
  309. egse/icons/sponge.svg +0 -220
  310. egse/icons/start-button-disabled.svg +0 -84
  311. egse/icons/start-button.svg +0 -50
  312. egse/icons/stop-button-disabled.svg +0 -84
  313. egse/icons/stop-button.svg +0 -50
  314. egse/icons/stop-red.svg +0 -17
  315. egse/icons/stop.svg +0 -1
  316. egse/icons/switch-disabled-square.svg +0 -87
  317. egse/icons/switch-disabled.svg +0 -15
  318. egse/icons/switch-off-square.svg +0 -87
  319. egse/icons/switch-off.svg +0 -72
  320. egse/icons/switch-on-square.svg +0 -87
  321. egse/icons/switch-on.svg +0 -61
  322. egse/icons/temperature-control.svg +0 -44
  323. egse/icons/th_ui_logo.svg +0 -1
  324. egse/icons/unplugged.svg +0 -23
  325. egse/icons/unvalid.png +0 -0
  326. egse/icons/user-interface.svg +0 -1
  327. egse/icons/vacuum.svg +0 -1
  328. egse/icons/valid.png +0 -0
  329. egse/icons/zoom-to-pixel-dark.svg +0 -64
  330. egse/icons/zoom-to-pixel-white.svg +0 -36
  331. egse/images/big-rotation-stage.png +0 -0
  332. egse/images/connected-100.png +0 -0
  333. egse/images/cross.svg +0 -6
  334. egse/images/disconnected-100.png +0 -0
  335. egse/images/gui-icon.png +0 -0
  336. egse/images/home.svg +0 -6
  337. egse/images/info-icon.png +0 -0
  338. egse/images/led-black.svg +0 -89
  339. egse/images/led-green.svg +0 -85
  340. egse/images/led-orange.svg +0 -85
  341. egse/images/led-red.svg +0 -85
  342. egse/images/load-icon.png +0 -0
  343. egse/images/load-setup.png +0 -0
  344. egse/images/load.png +0 -0
  345. egse/images/pause.png +0 -0
  346. egse/images/play-button.svg +0 -8
  347. egse/images/play.png +0 -0
  348. egse/images/process-status.png +0 -0
  349. egse/images/restart.png +0 -0
  350. egse/images/search.png +0 -0
  351. egse/images/sma.png +0 -0
  352. egse/images/start.png +0 -0
  353. egse/images/stop-button.svg +0 -8
  354. egse/images/stop.png +0 -0
  355. egse/images/switch-off.svg +0 -48
  356. egse/images/switch-on.svg +0 -48
  357. egse/images/undo.png +0 -0
  358. egse/images/update-button.svg +0 -11
  359. egse/imageviewer/exposureselection.py +0 -475
  360. egse/imageviewer/imageviewer.py +0 -198
  361. egse/imageviewer/matchfocalplane.py +0 -179
  362. egse/imageviewer/subfieldposition.py +0 -133
  363. egse/lampcontrol/__init__.py +0 -4
  364. egse/lampcontrol/beaglebone/beaglebone.py +0 -178
  365. egse/lampcontrol/beaglebone/beaglebone.yaml +0 -62
  366. egse/lampcontrol/beaglebone/beaglebone_cs.py +0 -106
  367. egse/lampcontrol/beaglebone/beaglebone_devif.py +0 -150
  368. egse/lampcontrol/beaglebone/beaglebone_protocol.py +0 -73
  369. egse/lampcontrol/energetiq/__init__.py +0 -22
  370. egse/lampcontrol/energetiq/eq99.yaml +0 -98
  371. egse/lampcontrol/energetiq/lampEQ99.py +0 -283
  372. egse/lampcontrol/energetiq/lampEQ99_cs.py +0 -128
  373. egse/lampcontrol/energetiq/lampEQ99_devif.py +0 -158
  374. egse/lampcontrol/energetiq/lampEQ99_encode_decode_errors.py +0 -73
  375. egse/lampcontrol/energetiq/lampEQ99_protocol.py +0 -69
  376. egse/lampcontrol/energetiq/lampEQ99_ui.py +0 -465
  377. egse/lib/CentOS-7/EtherSpaceLink_v34_86.dylib +0 -0
  378. egse/lib/CentOS-8/ESL-RMAP_v34_86.dylib +0 -0
  379. egse/lib/CentOS-8/EtherSpaceLink_v34_86.dylib +0 -0
  380. egse/lib/Debian/ESL-RMAP_v34_86.dylib +0 -0
  381. egse/lib/Debian/EtherSpaceLink_v34_86.dylib +0 -0
  382. egse/lib/Debian/libetherspacelink_v35_21.dylib +0 -0
  383. egse/lib/Linux/ESL-RMAP_v34_86.dylib +0 -0
  384. egse/lib/Linux/EtherSpaceLink_v34_86.dylib +0 -0
  385. egse/lib/Ubuntu-20/ESL-RMAP_v34_86.dylib +0 -0
  386. egse/lib/Ubuntu-20/EtherSpaceLink_v34_86.dylib +0 -0
  387. egse/lib/gssw/python3-gssw_2.2.3+31f63c9f-1_all.deb +0 -0
  388. egse/lib/macOS/ESL-RMAP_v34_86.dylib +0 -0
  389. egse/lib/macOS/EtherSpaceLink_v34_86.dylib +0 -0
  390. egse/lib/ximc/__pycache__/pyximc.cpython-38 2.pyc +0 -0
  391. egse/lib/ximc/__pycache__/pyximc.cpython-38.pyc +0 -0
  392. egse/lib/ximc/libximc.framework/Frameworks/libbindy.dylib +0 -0
  393. egse/lib/ximc/libximc.framework/Frameworks/libxiwrapper.dylib +0 -0
  394. egse/lib/ximc/libximc.framework/Headers/ximc.h +0 -5510
  395. egse/lib/ximc/libximc.framework/Resources/Info.plist +0 -42
  396. egse/lib/ximc/libximc.framework/Resources/keyfile.sqlite +0 -0
  397. egse/lib/ximc/libximc.framework/libbindy.so +0 -0
  398. egse/lib/ximc/libximc.framework/libximc +0 -0
  399. egse/lib/ximc/libximc.framework/libximc.so +0 -0
  400. egse/lib/ximc/libximc.framework/libximc.so.7.0.0 +0 -0
  401. egse/lib/ximc/libximc.framework/libxiwrapper.so +0 -0
  402. egse/lib/ximc/pyximc.py +0 -922
  403. egse/listener.py +0 -73
  404. egse/logger/__init__.py +0 -243
  405. egse/logger/log_cs.py +0 -321
  406. egse/metrics.py +0 -98
  407. egse/mixin.py +0 -464
  408. egse/monitoring.py +0 -95
  409. egse/ni/alarms/__init__.py +0 -26
  410. egse/ni/alarms/cdaq9375.py +0 -300
  411. egse/ni/alarms/cdaq9375.yaml +0 -89
  412. egse/ni/alarms/cdaq9375_cs.py +0 -130
  413. egse/ni/alarms/cdaq9375_devif.py +0 -183
  414. egse/ni/alarms/cdaq9375_protocol.py +0 -48
  415. egse/obs_inspection.py +0 -163
  416. egse/observer.py +0 -41
  417. egse/obsid.py +0 -163
  418. egse/powermeter/__init__.py +0 -0
  419. egse/powermeter/ni/__init__.py +0 -38
  420. egse/powermeter/ni/cdaq9184.py +0 -224
  421. egse/powermeter/ni/cdaq9184.yaml +0 -73
  422. egse/powermeter/ni/cdaq9184_cs.py +0 -130
  423. egse/powermeter/ni/cdaq9184_devif.py +0 -201
  424. egse/powermeter/ni/cdaq9184_protocol.py +0 -48
  425. egse/powermeter/ni/cdaq9184_ui.py +0 -544
  426. egse/powermeter/thorlabs/__init__.py +0 -25
  427. egse/powermeter/thorlabs/pm100a.py +0 -380
  428. egse/powermeter/thorlabs/pm100a.yaml +0 -132
  429. egse/powermeter/thorlabs/pm100a_cs.py +0 -136
  430. egse/powermeter/thorlabs/pm100a_devif.py +0 -127
  431. egse/powermeter/thorlabs/pm100a_protocol.py +0 -80
  432. egse/powermeter/thorlabs/pm100a_ui.py +0 -725
  433. egse/process.py +0 -451
  434. egse/procman/__init__.py +0 -811
  435. egse/procman/cannot_start_process_popup.py +0 -43
  436. egse/procman/procman.yaml +0 -49
  437. egse/procman/procman_cs.py +0 -201
  438. egse/procman/procman_ui.py +0 -2081
  439. egse/protocol.py +0 -603
  440. egse/proxy.py +0 -522
  441. egse/randomwalk.py +0 -140
  442. egse/reg.py +0 -585
  443. egse/reload.py +0 -122
  444. egse/reprocess.py +0 -675
  445. egse/resource.py +0 -333
  446. egse/rst.py +0 -135
  447. egse/search.py +0 -182
  448. egse/serialdevice.py +0 -190
  449. egse/services.py +0 -212
  450. egse/services.yaml +0 -51
  451. egse/settings.py +0 -379
  452. egse/settings.yaml +0 -980
  453. egse/setup.py +0 -1180
  454. egse/shutter/__init__.py +0 -0
  455. egse/shutter/thorlabs/__init__.py +0 -19
  456. egse/shutter/thorlabs/ksc101.py +0 -205
  457. egse/shutter/thorlabs/ksc101.yaml +0 -105
  458. egse/shutter/thorlabs/ksc101_cs.py +0 -136
  459. egse/shutter/thorlabs/ksc101_devif.py +0 -201
  460. egse/shutter/thorlabs/ksc101_protocol.py +0 -69
  461. egse/shutter/thorlabs/ksc101_ui.py +0 -548
  462. egse/shutter/thorlabs/sc10.py +0 -82
  463. egse/shutter/thorlabs/sc10.yaml +0 -52
  464. egse/shutter/thorlabs/sc10_controller.py +0 -81
  465. egse/shutter/thorlabs/sc10_cs.py +0 -108
  466. egse/shutter/thorlabs/sc10_interface.py +0 -25
  467. egse/shutter/thorlabs/sc10_simulator.py +0 -30
  468. egse/simulator.py +0 -41
  469. egse/slack.py +0 -61
  470. egse/socketdevice.py +0 -218
  471. egse/sockets.py +0 -218
  472. egse/spw.py +0 -1479
  473. egse/stages/__init__.py +0 -12
  474. egse/stages/aerotech/ensemble.py +0 -247
  475. egse/stages/aerotech/ensemble.yaml +0 -205
  476. egse/stages/aerotech/ensemble_controller.py +0 -275
  477. egse/stages/aerotech/ensemble_cs.py +0 -110
  478. egse/stages/aerotech/ensemble_interface.py +0 -132
  479. egse/stages/aerotech/ensemble_parameters.py +0 -433
  480. egse/stages/aerotech/ensemble_simulator.py +0 -27
  481. egse/stages/aerotech/mgse_sim.py +0 -193
  482. egse/stages/arun/smd3.py +0 -111
  483. egse/stages/arun/smd3.yaml +0 -68
  484. egse/stages/arun/smd3_controller.py +0 -472
  485. egse/stages/arun/smd3_cs.py +0 -112
  486. egse/stages/arun/smd3_interface.py +0 -53
  487. egse/stages/arun/smd3_simulator.py +0 -27
  488. egse/stages/arun/smd3_stop.py +0 -16
  489. egse/stages/huber/__init__.py +0 -49
  490. egse/stages/huber/smc9300.py +0 -904
  491. egse/stages/huber/smc9300.yaml +0 -63
  492. egse/stages/huber/smc9300_cs.py +0 -178
  493. egse/stages/huber/smc9300_devif.py +0 -345
  494. egse/stages/huber/smc9300_protocol.py +0 -111
  495. egse/stages/huber/smc9300_sim.py +0 -547
  496. egse/stages/huber/smc9300_ui.py +0 -973
  497. egse/state.py +0 -173
  498. egse/statemachine.py +0 -274
  499. egse/storage/__init__.py +0 -1004
  500. egse/storage/persistence.py +0 -2295
  501. egse/storage/storage.yaml +0 -72
  502. egse/storage/storage_cs.py +0 -214
  503. egse/styles/dark.qss +0 -343
  504. egse/styles/default.qss +0 -48
  505. egse/synoptics/__init__.py +0 -412
  506. egse/synoptics/syn.yaml +0 -9
  507. egse/synoptics/syn_cs.py +0 -195
  508. egse/system.py +0 -1408
  509. egse/tcs/__init__.py +0 -14
  510. egse/tcs/tcs.py +0 -874
  511. egse/tcs/tcs.yaml +0 -14
  512. egse/tcs/tcs_cs.py +0 -202
  513. egse/tcs/tcs_devif.py +0 -292
  514. egse/tcs/tcs_protocol.py +0 -177
  515. egse/tcs/tcs_sim.py +0 -177
  516. egse/tcs/tcs_ui.py +0 -543
  517. egse/tdms.py +0 -171
  518. egse/tempcontrol/__init__.py +0 -23
  519. egse/tempcontrol/agilent/agilent34970.py +0 -109
  520. egse/tempcontrol/agilent/agilent34970.yaml +0 -44
  521. egse/tempcontrol/agilent/agilent34970_cs.py +0 -116
  522. egse/tempcontrol/agilent/agilent34970_devif.py +0 -182
  523. egse/tempcontrol/agilent/agilent34970_protocol.py +0 -99
  524. egse/tempcontrol/agilent/agilent34972.py +0 -111
  525. egse/tempcontrol/agilent/agilent34972.yaml +0 -44
  526. egse/tempcontrol/agilent/agilent34972_cs.py +0 -117
  527. egse/tempcontrol/agilent/agilent34972_devif.py +0 -189
  528. egse/tempcontrol/agilent/agilent34972_protocol.py +0 -101
  529. egse/tempcontrol/beaglebone/beaglebone.py +0 -342
  530. egse/tempcontrol/beaglebone/beaglebone.yaml +0 -110
  531. egse/tempcontrol/beaglebone/beaglebone_cs.py +0 -117
  532. egse/tempcontrol/beaglebone/beaglebone_protocol.py +0 -135
  533. egse/tempcontrol/beaglebone/beaglebone_ui.py +0 -681
  534. egse/tempcontrol/digalox/digalox.py +0 -107
  535. egse/tempcontrol/digalox/digalox.yaml +0 -36
  536. egse/tempcontrol/digalox/digalox_cs.py +0 -112
  537. egse/tempcontrol/digalox/digalox_protocol.py +0 -55
  538. egse/tempcontrol/keithley/__init__.py +0 -33
  539. egse/tempcontrol/keithley/daq6510.py +0 -662
  540. egse/tempcontrol/keithley/daq6510.yaml +0 -105
  541. egse/tempcontrol/keithley/daq6510_cs.py +0 -163
  542. egse/tempcontrol/keithley/daq6510_devif.py +0 -343
  543. egse/tempcontrol/keithley/daq6510_protocol.py +0 -78
  544. egse/tempcontrol/keithley/daq6510_sim.py +0 -186
  545. egse/tempcontrol/lakeshore/__init__.py +0 -33
  546. egse/tempcontrol/lakeshore/lsci.py +0 -361
  547. egse/tempcontrol/lakeshore/lsci.yaml +0 -162
  548. egse/tempcontrol/lakeshore/lsci_cs.py +0 -174
  549. egse/tempcontrol/lakeshore/lsci_devif.py +0 -292
  550. egse/tempcontrol/lakeshore/lsci_protocol.py +0 -73
  551. egse/tempcontrol/lakeshore/lsci_ui.py +0 -389
  552. egse/tempcontrol/ni/__init__.py +0 -0
  553. egse/tempcontrol/spid/spid.py +0 -109
  554. egse/tempcontrol/spid/spid.yaml +0 -81
  555. egse/tempcontrol/spid/spid_controller.py +0 -279
  556. egse/tempcontrol/spid/spid_cs.py +0 -136
  557. egse/tempcontrol/spid/spid_protocol.py +0 -107
  558. egse/tempcontrol/spid/spid_ui.py +0 -727
  559. egse/tempcontrol/srs/__init__.py +0 -22
  560. egse/tempcontrol/srs/ptc10.py +0 -875
  561. egse/tempcontrol/srs/ptc10.yaml +0 -227
  562. egse/tempcontrol/srs/ptc10_cs.py +0 -128
  563. egse/tempcontrol/srs/ptc10_devif.py +0 -118
  564. egse/tempcontrol/srs/ptc10_protocol.py +0 -42
  565. egse/tempcontrol/srs/ptc10_ui.py +0 -906
  566. egse/ups/apc/apc.py +0 -236
  567. egse/ups/apc/apc.yaml +0 -45
  568. egse/ups/apc/apc_cs.py +0 -101
  569. egse/ups/apc/apc_protocol.py +0 -125
  570. egse/user.yaml +0 -7
  571. egse/vacuum/beaglebone/beaglebone.py +0 -149
  572. egse/vacuum/beaglebone/beaglebone.yaml +0 -44
  573. egse/vacuum/beaglebone/beaglebone_cs.py +0 -108
  574. egse/vacuum/beaglebone/beaglebone_devif.py +0 -164
  575. egse/vacuum/beaglebone/beaglebone_protocol.py +0 -193
  576. egse/vacuum/beaglebone/beaglebone_ui.py +0 -638
  577. egse/vacuum/instrutech/igm402.py +0 -92
  578. egse/vacuum/instrutech/igm402.yaml +0 -90
  579. egse/vacuum/instrutech/igm402_controller.py +0 -128
  580. egse/vacuum/instrutech/igm402_cs.py +0 -108
  581. egse/vacuum/instrutech/igm402_interface.py +0 -49
  582. egse/vacuum/instrutech/igm402_simulator.py +0 -36
  583. egse/vacuum/keller/kellerBus.py +0 -256
  584. egse/vacuum/keller/leo3.py +0 -102
  585. egse/vacuum/keller/leo3.yaml +0 -38
  586. egse/vacuum/keller/leo3_controller.py +0 -83
  587. egse/vacuum/keller/leo3_cs.py +0 -101
  588. egse/vacuum/keller/leo3_interface.py +0 -33
  589. egse/vacuum/mks/evision.py +0 -86
  590. egse/vacuum/mks/evision.yaml +0 -75
  591. egse/vacuum/mks/evision_cs.py +0 -101
  592. egse/vacuum/mks/evision_devif.py +0 -316
  593. egse/vacuum/mks/evision_interface.py +0 -60
  594. egse/vacuum/mks/evision_simulator.py +0 -24
  595. egse/vacuum/mks/evision_ui.py +0 -704
  596. egse/vacuum/pfeiffer/acp40.py +0 -87
  597. egse/vacuum/pfeiffer/acp40.yaml +0 -60
  598. egse/vacuum/pfeiffer/acp40_controller.py +0 -117
  599. egse/vacuum/pfeiffer/acp40_cs.py +0 -109
  600. egse/vacuum/pfeiffer/acp40_interface.py +0 -40
  601. egse/vacuum/pfeiffer/acp40_simulator.py +0 -39
  602. egse/vacuum/pfeiffer/tc400.py +0 -113
  603. egse/vacuum/pfeiffer/tc400.yaml +0 -83
  604. egse/vacuum/pfeiffer/tc400_controller.py +0 -140
  605. egse/vacuum/pfeiffer/tc400_cs.py +0 -109
  606. egse/vacuum/pfeiffer/tc400_interface.py +0 -70
  607. egse/vacuum/pfeiffer/tc400_simulator.py +0 -24
  608. egse/vacuum/pfeiffer/tpg261.py +0 -81
  609. egse/vacuum/pfeiffer/tpg261.yaml +0 -66
  610. egse/vacuum/pfeiffer/tpg261_controller.py +0 -150
  611. egse/vacuum/pfeiffer/tpg261_cs.py +0 -109
  612. egse/vacuum/pfeiffer/tpg261_interface.py +0 -60
  613. egse/vacuum/pfeiffer/tpg261_simulator.py +0 -24
  614. egse/version.py +0 -174
  615. egse/visitedpositions.py +0 -398
  616. egse/windowing.py +0 -213
  617. egse/zmq/__init__.py +0 -28
  618. egse/zmq/spw.py +0 -160
  619. egse/zmq_ser.py +0 -41
  620. scripts/alerts/cold.yaml +0 -278
  621. scripts/alerts/example_alerts.yaml +0 -54
  622. scripts/alerts/transition.yaml +0 -14
  623. scripts/alerts/warm.yaml +0 -49
  624. scripts/analyse_n_fee_hk_data.py +0 -44
  625. scripts/check_hdf5_files.py +0 -192
  626. scripts/check_register_sync.py +0 -47
  627. scripts/create_hdf5_report.py +0 -295
  628. scripts/csl_model.py +0 -436
  629. scripts/csl_restore_setup.py +0 -230
  630. scripts/export-grafana-dashboards.py +0 -50
  631. scripts/fdir/cs_recovery/fdir_cs_recovery.py +0 -59
  632. scripts/fdir/fdir_table.yaml +0 -70
  633. scripts/fdir/fdir_test_recovery.py +0 -11
  634. scripts/fdir/hw_recovery/fdir_agilent_hw_recovery.py +0 -73
  635. scripts/fdir/limit_recovery/fdir_agilent_limit.py +0 -64
  636. scripts/fdir/limit_recovery/fdir_bb_heater_limit.py +0 -61
  637. scripts/fdir/limit_recovery/fdir_ensemble_limit.py +0 -33
  638. scripts/fdir/limit_recovery/fdir_pressure_limit_recovery.py +0 -71
  639. scripts/fix_csv.py +0 -80
  640. scripts/n_fee_supply_voltage_calculation.py +0 -92
  641. scripts/playground.py +0 -30
  642. scripts/print_hdf5_hk_data.py +0 -68
  643. scripts/print_register_map.py +0 -43
  644. scripts/sron/commanding/control_heaters.py +0 -44
  645. scripts/sron/commanding/pumpdown.py +0 -46
  646. scripts/sron/commanding/set_pid_setpoint.py +0 -19
  647. scripts/sron/commanding/shutdown_bbb_heaters.py +0 -10
  648. scripts/sron/commanding/shutdown_pumps.py +0 -33
  649. scripts/sron/tm_gen/tm_gen_agilent.py +0 -38
  650. scripts/sron/tm_gen/tm_gen_heaters.py +0 -4
  651. scripts/sron/tm_gen/tm_gen_spid.py +0 -13
  652. scripts/update_operational_cgse.py +0 -268
  653. scripts/update_operational_cgse_old.py +0 -273
@@ -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>