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,531 +0,0 @@
1
- import ast
2
- import logging
3
- import re
4
- from math import atan
5
- from math import atan2
6
- from math import cos
7
- from math import degrees
8
- from math import pow
9
- from math import radians
10
- from math import sin
11
- from math import sqrt
12
- from math import tan
13
- from typing import Dict
14
- from typing import List
15
- from typing import Optional
16
- from typing import Union
17
-
18
- import numpy as np
19
- from numpy.polynomial import Polynomial
20
-
21
- from egse.coordinates.referenceFrame import ReferenceFrame
22
- from egse.settings import Settings
23
- from egse.state import GlobalState
24
- from egse.setup import NavigableDict
25
-
26
- logger = logging.getLogger(__name__)
27
-
28
- FOV_SETTINGS = Settings.load("Field-Of-View")
29
- CCD_SETTINGS = Settings.load("CCD")
30
-
31
-
32
- def undistorted_to_distorted_focal_plane_coordinates(
33
- x_undistorted, y_undistorted, distortion_coefficients, focal_length
34
- ):
35
- """
36
- Conversion from undistorted to distorted focal-plane coordinates. The distortion is a
37
- radial effect and is defined as the difference in radial distance to the optical axis
38
- between the distorted and undistorted coordinates, and can be expressed in terms of the
39
- undistorted radial distance r as follows:
40
-
41
- Δr = r * [(k1 * r**2) + (k2 * r**4) + (k3 * r**6)],
42
-
43
- where the distortion and r are expressed in normalised focal-plane coordinates (i.e. divided
44
- by the focal length, expressed in the same unit), and (k1, k2, k3) are the distortion
45
- coefficients.
46
-
47
- Args:
48
- x_undistorted: Undistorted x-coordinate on the focal plane [mm].
49
- y_undistorted: Undistorted y-coordinate on the focal plane [mm].
50
- distortion_coefficients: List of polynomial coefficients for the field distortion.
51
- focal_length: Focal length [mm].
52
- Returns:
53
- x_distorted: Distorted x-coordinate on the focal plane [mm].
54
- y_distorted: Distorted y-coordinate on the focal plane [mm].
55
- """
56
-
57
- # Distortion coefficients -> (0, 0, 0, k1, 0, k2, 0, k3)
58
-
59
- coefficients = [
60
- 0,
61
- 0,
62
- 0,
63
- distortion_coefficients[0],
64
- 0,
65
- distortion_coefficients[1],
66
- 0,
67
- distortion_coefficients[2],
68
- ]
69
- distortion_polynomial = Polynomial(coefficients)
70
-
71
- # Position on the focal plane:
72
- # - field angle [radians]
73
- # - radial distance from the optical axis [normalised pixels]
74
-
75
- angle = atan2(y_undistorted, x_undistorted)
76
- distance_undistorted = sqrt(pow(x_undistorted, 2) + pow(y_undistorted, 2)) / focal_length
77
-
78
- # Distortion [mm]
79
- # Source moves away from the optical axis (radially)
80
-
81
- distortion = distortion_polynomial(distance_undistorted) * focal_length
82
-
83
- # The field angle remains the same
84
-
85
- x_distorted = x_undistorted + cos(angle) * distortion
86
- y_distorted = y_undistorted + sin(angle) * distortion
87
-
88
- return x_distorted, y_distorted
89
-
90
-
91
- def distorted_to_undistorted_focal_plane_coordinates(
92
- x_distorted, y_distorted, inverse_distortion_coefficients, focal_length
93
- ):
94
- """
95
- Conversion from distorted to undistorted focal-plane coordinates. The inverse distortion is a
96
- radial effect and is defined as the difference in radial distance to the optical axis
97
- between the distorted and undistorted coordinates, and can be expressed in terms of the
98
- undistorted radial distance r as follows:
99
-
100
- Δr = r * [(k1 * r**2) + (k2 * r**4) + (k3 * r**6)],
101
-
102
- where the inverse distortion and r are expressed in normalised focal-plane coordinates (i.e. divided
103
- by the focal length, expressed in the same unit), and (k1, k2, k3) are the inverse distortion
104
- coefficients.
105
-
106
- Args:
107
- x_distorted: Distorted x-coordinate on the focal plane [mm].
108
- y_distorted: Distorted y-coordinate on the focal plane [mm].
109
- inverse_distortion_coefficients: List of polynomial coefficients for the inverse field distortion.
110
- focal_length: Focal length [mm].
111
- Returns:
112
- x_undistorted: Undistorted x-coordinate on the focal plane [mm].
113
- y_undistorted: Undistorted y-coordinate on the focal plane [mm].
114
- """
115
-
116
- # Inverse distortion coefficients -> (0, 0, 0, k1, 0, k2, 0, k3)
117
-
118
- coefficients = [
119
- 0,
120
- 0,
121
- 0,
122
- inverse_distortion_coefficients[0],
123
- 0,
124
- inverse_distortion_coefficients[1],
125
- 0,
126
- inverse_distortion_coefficients[2],
127
- ]
128
- inverse_distortion_polynomial = Polynomial(coefficients)
129
-
130
- # Position on the focal plane:
131
- # - field angle [radians]
132
- # - radial distance from the optical axis [normalised pixels]
133
-
134
- angle = atan2(y_distorted, x_distorted)
135
- distance_distorted = sqrt(pow(x_distorted, 2) + pow(y_distorted, 2)) / focal_length
136
-
137
- # Inverse distortion [mm]
138
- # Source moves towards the optical axis (radially) -> negative!
139
-
140
- inverse_distortion = inverse_distortion_polynomial(distance_distorted) * focal_length
141
-
142
- # The field angle remains the same
143
-
144
- x_undistorted = x_distorted + cos(angle) * inverse_distortion
145
- y_undistorted = y_distorted + sin(angle) * inverse_distortion
146
-
147
- return x_undistorted, y_undistorted
148
-
149
-
150
- def focal_plane_to_ccd_coordinates(x_fp, y_fp):
151
- """
152
- Conversion from focal-plane to pixel coordinates on the appropriate CCD.
153
-
154
- Args:
155
- x_fp: Focal-plane x-coordinate [mm].
156
- y_fp: Focal-plane y-coordinate [mm].
157
- Returns:
158
- Pixel coordinates (row, column) and the corresponding CCD. If the given
159
- focal-plane coordinates do not fall on any CCD, (None, None, None) is
160
- returned.
161
- """
162
- setup = GlobalState.setup
163
-
164
- if setup is not None:
165
- num_rows = setup.camera.ccd.num_rows
166
- num_cols = setup.camera.ccd.num_column
167
- else:
168
- num_rows = CCD_SETTINGS.NUM_ROWS
169
- num_cols = CCD_SETTINGS.NUM_COLUMNS
170
-
171
- for ccd_code in range(1, 5):
172
-
173
- (row, column) = __focal_plane_to_ccd_coordinates__(x_fp, y_fp, ccd_code)
174
-
175
- if (row < 0) or (column < 0):
176
- continue
177
-
178
- if (row >= num_rows) or (column >= num_cols):
179
- continue
180
-
181
- return row, column, ccd_code
182
-
183
- return None, None, None
184
-
185
-
186
- def __focal_plane_to_ccd_coordinates__(x_fp, y_fp, ccd_code):
187
- """
188
- Conversion from focal-plane coordinates to pixel coordinates on the given CCD.
189
-
190
- Args:
191
- x_fp: Focal-plane x-coordinate [mm].
192
- y_fp: Focal-plane y-coordinate [mm].
193
- ccd_code: Code of the CCD for which to calculate the pixel coordinates [1, 2, 3, 4].
194
- Returns:
195
- Pixel coordinates (row, column) on the given CCD.
196
- """
197
-
198
- setup = GlobalState.setup
199
-
200
- if setup is not None:
201
- ccd_orientation = setup.camera.ccd.orientation[int(ccd_code) - 1]
202
- pixel_size = setup.camera.ccd.pixel_size / 1000.0 # [mm]
203
- ccd_origin_x = GlobalState.setup.camera.ccd.origin_offset_x[int(ccd_code) - 1]
204
- ccd_origin_y = GlobalState.setup.camera.ccd.origin_offset_y[int(ccd_code) - 1]
205
- else:
206
- ccd_orientation = CCD_SETTINGS.ORIENTATION[int(ccd_code) - 1]
207
- pixel_size = CCD_SETTINGS.PIXEL_SIZE / 1000 # Pixel size [mm]
208
- ccd_origin_x = CCD_SETTINGS.ZEROPOINT[0]
209
- ccd_origin_y = CCD_SETTINGS.ZEROPOINT[1]
210
-
211
- ccd_angle = radians(ccd_orientation)
212
-
213
- # CCD coordinates [mm]
214
-
215
- row = ccd_origin_y - x_fp * sin(ccd_angle) + y_fp * cos(ccd_angle)
216
- column = ccd_origin_x + x_fp * cos(ccd_angle) + y_fp * sin(ccd_angle)
217
-
218
- row /= pixel_size
219
- column /= pixel_size
220
-
221
- return row, column
222
-
223
-
224
- def focal_plane_coordinates_to_angles(x_fp, y_fp):
225
- """
226
- Conversion from focal-plane coordinates to the gnomonic distance from the optical axis and
227
- the in-field angle.
228
-
229
- Args:
230
- x_fp: Focal-plane x-coordinate [mm].
231
- y_fp: Focal-plane y-coordinate [mm].
232
- Returns:
233
- Gnomonic distance from the optical axis and in-field angle [degrees].
234
- """
235
-
236
- setup = GlobalState.setup
237
-
238
- if setup is not None:
239
- focal_length_mm = GlobalState.setup.camera.fov.focal_length_mm
240
- else:
241
- focal_length_mm = FOV_SETTINGS.FOCAL_LENGTH
242
-
243
- theta = degrees(atan(sqrt(pow(x_fp, 2) + pow(y_fp, 2)) / focal_length_mm))
244
- phi = degrees(atan2(y_fp, x_fp))
245
-
246
- return theta, phi
247
-
248
-
249
- def ccd_to_focal_plane_coordinates(row, column, ccd_code):
250
- """
251
- Conversion from pixel-coordinates on the given CCD to focal-plane coordinates.
252
-
253
- Args:
254
- row: Row coordinate [pixels].
255
- column: Column coordinate [pixels].
256
- ccd_code: Code of the CCD for which the pixel coordinates are given.
257
- Returns:
258
- Focal-plane coordinates (x, y) [mm].
259
- """
260
-
261
- setup = GlobalState.setup
262
-
263
- if setup is not None:
264
- ccd_orientation = setup.camera.ccd.orientation[int(ccd_code) - 1]
265
- pixel_size_mm = setup.camera.ccd.pixel_size / 1000.0 # [mm]
266
- ccd_origin_x = GlobalState.setup.camera.ccd.origin_offset_x[int(ccd_code) - 1]
267
- ccd_origin_y = GlobalState.setup.camera.ccd.origin_offset_y[int(ccd_code) - 1]
268
- else:
269
- ccd_orientation = CCD_SETTINGS.ORIENTATION[int(ccd_code) - 1]
270
- pixel_size_mm = CCD_SETTINGS.PIXEL_SIZE / 1000 # Pixel size [mm]
271
- ccd_origin_x = CCD_SETTINGS.ZEROPOINT[0]
272
- ccd_origin_y = CCD_SETTINGS.ZEROPOINT[1]
273
-
274
- # Convert the pixel coordinates into [mm] coordinates
275
-
276
- row_mm = row * pixel_size_mm
277
- column_mm = column * pixel_size_mm
278
-
279
- # Convert the CCD coordinates into FP coordinates [mm]
280
-
281
- ccd_angle = radians(ccd_orientation)
282
-
283
- x_fp = (column_mm - ccd_origin_x) * cos(ccd_angle) - (row_mm - ccd_origin_y) * sin(ccd_angle)
284
- y_fp = (column_mm - ccd_origin_x) * sin(ccd_angle) + (row_mm - ccd_origin_y) * cos(ccd_angle)
285
-
286
- # That's it
287
-
288
- return x_fp, y_fp
289
-
290
- def angles_to_focal_plane_coordinates(theta, phi):
291
- """
292
- Conversion from the gnomonic distance from the optical axis and
293
- the in-field angle to focal-plane coordinates.
294
-
295
- Args:
296
- theta: Gnomonic distance from the optical axis [degrees].
297
- phi: In-field angle [degrees].
298
- Returns:
299
- Focal-plane coordinates (x, y) [mm].
300
- """
301
-
302
- setup = GlobalState.setup
303
-
304
- if setup is not None:
305
- focal_length_mm = GlobalState.setup.camera.fov.focal_length_mm
306
- else:
307
- focal_length_mm = FOV_SETTINGS.FOCAL_LENGTH
308
-
309
- distance = focal_length_mm * tan(radians(theta)) # [mm]
310
-
311
- phi_radians = radians(phi)
312
-
313
- x_fp = distance * cos(phi_radians)
314
- y_fp = distance * sin(phi_radians)
315
-
316
- return x_fp, y_fp
317
-
318
-
319
- def dict_to_ref_model(model_def: Union[Dict, List]) -> NavigableDict:
320
- """
321
- Creates a reference frames model from a dictionary or list of reference frame definitions.
322
-
323
- When a list is provided, the items in the list must be ReferenceFrames.
324
-
325
- The reference frame definitions are usually read from a YAML file or returned by a Setup,
326
- but can also be just ReferenceFrame objects.
327
-
328
- ReferenceFrame definitions have the following format:
329
-
330
- ```
331
- ReferenceFrame://(<definition>)
332
- ```
333
- where `<definition>` has the following elements, separated by '` | `':
334
- * a translation matrix
335
- * a rotation matrix
336
- * the name of the reference frame
337
- * the name of the reference for this reference frame
338
- * a dictionary of links
339
-
340
- Args:
341
- model_def (dict or list): the definition of the reference model
342
-
343
- Returns:
344
- A dictionary representing the reference frames model.
345
- """
346
-
347
- ref_model = NavigableDict({})
348
- ref_links = {}
349
-
350
- def create_ref_frame(name, data) -> Union[ReferenceFrame, str]:
351
-
352
- # This is a recursive function that creates a reference frame based on the given data.
353
- # * When the data is already a ReferenceFrame, it just returns data
354
- # * When data starts with the special string `ReferenceFrame//`, the data string is parsed
355
- # and a corresponding ReferenceFrame is returned
356
- # * When there is no match, the data is returned unaltered.
357
- #
358
- # SIDE EFFECT:
359
- # * In the process, the outer ref-model and ref_links are updated.
360
-
361
- if isinstance(data, ReferenceFrame):
362
- return data
363
-
364
- match = re.match(r"ReferenceFrame//\((.*)\)$", data)
365
- if not match:
366
- return data
367
-
368
- translation, rotation, name, ref_name, links = match[1].split(" | ")
369
-
370
- # all links are processed later..
371
-
372
- ref_links[name] = ast.literal_eval(links)
373
-
374
- if ref_name == name == "Master":
375
- ref_model.add(ref_name, ReferenceFrame.createMaster())
376
- return ref_model["Master"]
377
-
378
- if ref_name not in ref_model:
379
- ref_model.add(ref_name, create_ref_frame(ref_name, model_def[ref_name]))
380
-
381
- ref_frame = ReferenceFrame.fromTranslationRotation(
382
- deserialize_array(translation),
383
- deserialize_array(rotation),
384
- name=name,
385
- ref=ref_model[ref_name],
386
- )
387
-
388
- return ref_frame
389
-
390
- # if the given model_def is a list, turn it into a dict
391
-
392
- if isinstance(model_def, list):
393
- model_def = {frame.name: frame for frame in model_def}
394
-
395
- for key, value in model_def.items():
396
- if key not in ref_model:
397
- ref_model.add(key, create_ref_frame(key, value))
398
-
399
- # Process all the links
400
-
401
- for ref_name, link_names in ref_links.items():
402
- ref = ref_model[ref_name]
403
- for link_name in link_names:
404
- if link_name not in ref.linkedTo:
405
- ref.addLink(ref_model[link_name])
406
-
407
- return ref_model
408
-
409
-
410
- def ref_model_to_dict(ref_model) -> NavigableDict:
411
- """Creates a dictionary with reference frames definitions that define a reference model.
412
-
413
- Args:
414
- ref_model: A dictionary representing the reference frames model or a list of reference
415
- frames.
416
- Returns:
417
- A dictionary of reference frame definitions.
418
- """
419
-
420
- if isinstance(ref_model, dict):
421
- ref_model = ref_model.values()
422
-
423
- # take each key (which is a reference frame) and serialize it
424
-
425
- model_def = {}
426
-
427
- for ref in ref_model:
428
- translation, rotation = ref.getTranslationRotationVectors()
429
- links = [ref.name for ref in ref.linkedTo]
430
- model_def[ref.name] = (
431
- f"ReferenceFrame//("
432
- f"{serialize_array(translation, precision=6)} | "
433
- f"{serialize_array(rotation, precision=6)} | "
434
- f"{ref.name} | "
435
- f"{ref.ref.name} | "
436
- f"{links})"
437
- )
438
-
439
- return NavigableDict(model_def)
440
-
441
-
442
- def serialize_array(arr: Union[np.ndarray, list], precision: int = 4) -> str:
443
- """Returns a string representation of a numpy array.
444
-
445
- >>> serialize_array([1,2,3])
446
- '[1, 2, 3]'
447
- >>> serialize_array([[1,2,3], [4,5,6]])
448
- '[[1, 2, 3], [4, 5, 6]]'
449
- >>> serialize_array([[1,2.2,3], [4.3,5,6]])
450
- '[[1.0000, 2.2000, 3.0000], [4.3000, 5.0000, 6.0000]]'
451
- >>> serialize_array([[1,2.2,3], [4.3,5,6]], precision=2)
452
- '[[1.00, 2.20, 3.00], [4.30, 5.00, 6.00]]'
453
-
454
- Args:
455
- arr: a one or two dimensional numpy array or list.
456
- precision (int): number of digits of precision
457
- Returns:
458
- A string representing the input array.
459
- """
460
- if isinstance(arr, list):
461
- arr = np.array(arr)
462
- msg = np.array2string(
463
- arr,
464
- separator=", ",
465
- suppress_small=True,
466
- formatter={"float_kind": lambda x: f"{x:.{precision}f}"},
467
- ).replace("\n", "")
468
- return msg
469
-
470
-
471
- def deserialize_array(arr_str: str) -> Optional[np.ndarray]:
472
- """Returns a numpy array from the given string.
473
-
474
- The input string is interpreted as a one or two-dimensional array, with commas or spaces
475
- separating the columns, and semi-colons separating the rows.
476
-
477
- >>> deserialize_array('1,2,3')
478
- array([1, 2, 3])
479
- >>> deserialize_array('1 2 3')
480
- array([1, 2, 3])
481
- >>> deserialize_array('1,2,3;4,5,6')
482
- array([[1, 2, 3],
483
- [4, 5, 6]])
484
- >>> deserialize_array("[[1,2,3], [4,5,6]]")
485
- array([[1, 2, 3],
486
- [4, 5, 6]])
487
-
488
- Args:
489
- arr_str: string representation of a numpy array
490
- Returns:
491
- A one or two-dimensional numpy array or `None` when input string cannot be parsed into a
492
- numpy array.
493
- """
494
-
495
- import re
496
-
497
- arr_str = re.sub(r"\],\s*\[", "];[", arr_str)
498
- try:
499
- arr = np.array(_convert_from_string(arr_str))
500
- return arr if ";" in arr_str else arr.flatten()
501
- except ValueError as exc:
502
- logger.error(f"Input string could not be parsed into a numpy array: {exc}")
503
- return None
504
-
505
-
506
- def _convert_from_string(data):
507
-
508
- # This function was copied from:
509
- # https://github.com/numpy/numpy/blob/v1.19.0/numpy/matrixlib/defmatrix.py#L14
510
- # We include the function here because the np.matrix class is deprecated and will be removed.
511
- # This function is what we actually needed from np.matrix.
512
-
513
- for char in "[]":
514
- data = data.replace(char, "")
515
-
516
- rows = data.split(";")
517
- new_data = []
518
- count = 0
519
- for row in rows:
520
- trow = row.split(",")
521
- new_row = []
522
- for col in trow:
523
- temp = col.split()
524
- new_row.extend(map(ast.literal_eval, temp))
525
- if count == 0:
526
- n_cols = len(new_row)
527
- elif len(new_row) != n_cols:
528
- raise ValueError("Rows not the same size.")
529
- count += 1
530
- new_data.append(new_row)
531
- return new_data
@@ -1,103 +0,0 @@
1
- #!/usr/bin/env python3
2
- # -*- coding: utf-8 -*-
3
- """
4
- Created on Wed Sep 9 17:19:47 2020
5
-
6
- @author: pierre
7
- """
8
- import numpy as np
9
- from egse.state import GlobalState
10
- from egse.coordinates.point import Points
11
-
12
-
13
- def is_avoidance_ok(hexusr,hexobj,setup=None,verbose=False):
14
- """
15
- is_avoidance_ok(hexusr,hexobj,setup=None)
16
-
17
- INPUT
18
- hexusr : ReferenceFrame
19
- xy plane = maximal height of the FPA_SEN
20
- z axis pointing away from the FPA
21
-
22
- hexobj : ReferenceFrame
23
- xy plane = FPA_SEN
24
- z axis pointing towards L6
25
-
26
- setup : GlobalSetup.setup, optional
27
- if not provided, GlobalState.setup is used
28
-
29
-
30
- OUTPUT : Boolean indicating wheather or not the FPA is outside of the avoidance volume around L6
31
- """
32
-
33
- if setup is None:
34
- setup = GlobalState.setup
35
-
36
- """
37
- A. HORIZONTAL AVOIDANCE
38
- Ensure that the center of L6, materialised by HEX_USR (incl. z-direction security wrt TOU_L6)
39
- stays within a given radius of the origin of FPA_SEN
40
- """
41
-
42
- # Clearance = the tolerance in every horizontal direction (3 mm; PLATO-KUL-PL-ICD-0001 v1.2)
43
- clearance_xy = setup.camera.fpa.avoidance.clearance_xy
44
-
45
- # l6xy = the projection of the origin of HEX_USR on the X-Y plane of FPA_SEN
46
- l6xy = hexusr.getOrigin().expressIn(hexobj)[:2]
47
-
48
- # !! This is a verification of the current situation --> need to replace by a simulation of the forthcoming movement in the building block
49
- horizontal_check = ((l6xy[0]**2.+l6xy[1]**2.) < clearance_xy*clearance_xy)
50
-
51
-
52
- """
53
- B. VERTICAL AVOIDANCE
54
- Ensure that the CCD never hits L6.
55
- The definition of HEX_USR includes a tolerance below L6 (1.65 mm)
56
- We include a tolerance above FPA_SEN here (0.3 mm)
57
- We define a collection of points to act at the vertices of the avoidance volume above the FPA
58
- """
59
-
60
- # Clearance = vertical uncertainty on the CCD location (0.3 mm; PLATO-KUL-PL-ICD-0001 v1.2)
61
- clearance_z = setup.camera.fpa.avoidance.clearance_z
62
-
63
- # Vertices = Points representing the vertices of the avoidance volume above the FPA (60)
64
- vertices_nb = setup.camera.fpa.avoidance.vertices_nb
65
- # All vertices are on a circle of radius 'vertices_radius' (100 mm)
66
- vertices_radius = setup.camera.fpa.avoidance.vertices_radius
67
-
68
- angles = np.linspace(0,np.pi * 2,vertices_nb,endpoint=False)
69
- vertices_x = np.cos(angles) * vertices_radius
70
- vertices_y = np.sin(angles) * vertices_radius
71
- vertices_z = np.ones_like(angles) * clearance_z
72
-
73
- # The collection of Points defining the avoidance volume around FPA_SEN
74
- vert_obj = Points(coordinates=np.array([vertices_x,vertices_y,vertices_z]),ref=hexobj,name="vert_obj")
75
-
76
- # Their coordinates in HEX_USR
77
- # NB: vert_obj is a Points, vert_usr is an array
78
- vert_usr = vert_obj.expressIn(hexusr)
79
-
80
-
81
- # !! Same as above : this is verifying the current situation, not the one after a planned movement
82
- # Verify that all vertices ("protecting" FPA_SEN) are below the x-y plane of HEX_USR ("protecting" L6)
83
- vertical_check = (np.all(vert_usr[2,:] < 0.))
84
-
85
- if verbose:
86
- printdict = {True:"OK", False:"NOT OK"}
87
- print(f"HORIZONTAL AVOIDANCE: {printdict[horizontal_check]}")
88
- print(f" VERTICAL AVOIDANCE: {printdict[vertical_check]}")
89
-
90
- if verbose > 1:
91
- print(f"Points Coordinates")
92
- coobj = vert_obj.coordinates
93
- for i in range(vertices_nb):
94
- print(f"{i} OBJ {np.round(coobj[:3,i],6)} --> USR {np.round(vert_usr[:3,i],6)}")
95
- vert_z = vert_usr[2,:]
96
- vert_zi = np.where(vert_z==np.max(vert_z))
97
- print(f"#vertices at max z : {len(vert_zi[0])}")
98
- print(f"First one: vertex {vert_zi[0][0]} : {np.round(vert_usr[:3,vert_zi[0][0]],6)}")
99
-
100
- return horizontal_check and vertical_check
101
-
102
-
103
-