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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (653) hide show
  1. README.md +27 -0
  2. bump.py +77 -0
  3. cgse-2024.1.3.dist-info/METADATA +41 -0
  4. cgse-2024.1.3.dist-info/RECORD +5 -0
  5. {cgse-2023.38.0.dist-info → cgse-2024.1.3.dist-info}/WHEEL +1 -2
  6. cgse-2023.38.0.dist-info/COPYING +0 -674
  7. cgse-2023.38.0.dist-info/COPYING.LESSER +0 -165
  8. cgse-2023.38.0.dist-info/METADATA +0 -144
  9. cgse-2023.38.0.dist-info/RECORD +0 -649
  10. cgse-2023.38.0.dist-info/entry_points.txt +0 -75
  11. cgse-2023.38.0.dist-info/top_level.txt +0 -2
  12. egse/__init__.py +0 -12
  13. egse/__main__.py +0 -32
  14. egse/aeu/aeu.py +0 -5235
  15. egse/aeu/aeu_awg.yaml +0 -265
  16. egse/aeu/aeu_crio.yaml +0 -273
  17. egse/aeu/aeu_cs.py +0 -626
  18. egse/aeu/aeu_devif.py +0 -321
  19. egse/aeu/aeu_main_ui.py +0 -912
  20. egse/aeu/aeu_metrics.py +0 -131
  21. egse/aeu/aeu_protocol.py +0 -463
  22. egse/aeu/aeu_psu.yaml +0 -204
  23. egse/aeu/aeu_ui.py +0 -873
  24. egse/aeu/arbdata/FccdRead.arb +0 -2
  25. egse/aeu/arbdata/FccdRead_min_points.arb +0 -2
  26. egse/aeu/arbdata/HeaterSync_FccdRead.arb +0 -2
  27. egse/aeu/arbdata/HeaterSync_ccdRead25.arb +0 -2
  28. egse/aeu/arbdata/HeaterSync_ccdRead31_25.arb +0 -2
  29. egse/aeu/arbdata/HeaterSync_ccdRead37_50.arb +0 -2
  30. egse/aeu/arbdata/HeaterSync_ccdRead43_75.arb +0 -2
  31. egse/aeu/arbdata/HeaterSync_ccdRead50.arb +0 -2
  32. egse/aeu/arbdata/Heater_FccdRead_min_points.arb +0 -2
  33. egse/aeu/arbdata/ccdRead25.arb +0 -2
  34. egse/aeu/arbdata/ccdRead25_150ms.arb +0 -2
  35. egse/aeu/arbdata/ccdRead31_25.arb +0 -2
  36. egse/aeu/arbdata/ccdRead31_25_150ms.arb +0 -2
  37. egse/aeu/arbdata/ccdRead37_50.arb +0 -2
  38. egse/aeu/arbdata/ccdRead37_50_150ms.arb +0 -2
  39. egse/aeu/arbdata/ccdRead43_75.arb +0 -2
  40. egse/aeu/arbdata/ccdRead43_75_150ms.arb +0 -2
  41. egse/aeu/arbdata/ccdRead50.arb +0 -2
  42. egse/aeu/arbdata/ccdRead50_150ms.arb +0 -2
  43. egse/alert/__init__.py +0 -1049
  44. egse/alert/alertman.yaml +0 -37
  45. egse/alert/alertman_cs.py +0 -234
  46. egse/alert/alertman_ui.py +0 -603
  47. egse/alert/gsm/beaglebone.py +0 -138
  48. egse/alert/gsm/beaglebone.yaml +0 -51
  49. egse/alert/gsm/beaglebone_cs.py +0 -108
  50. egse/alert/gsm/beaglebone_devif.py +0 -130
  51. egse/alert/gsm/beaglebone_protocol.py +0 -48
  52. egse/bits.py +0 -318
  53. egse/camera.py +0 -44
  54. egse/collimator/__init__.py +0 -0
  55. egse/collimator/fcul/__init__.py +0 -0
  56. egse/collimator/fcul/ogse.py +0 -1077
  57. egse/collimator/fcul/ogse.yaml +0 -14
  58. egse/collimator/fcul/ogse_cs.py +0 -154
  59. egse/collimator/fcul/ogse_devif.py +0 -358
  60. egse/collimator/fcul/ogse_protocol.py +0 -129
  61. egse/collimator/fcul/ogse_sim.py +0 -431
  62. egse/collimator/fcul/ogse_ui.py +0 -1108
  63. egse/command.py +0 -699
  64. egse/config.py +0 -410
  65. egse/confman/__init__.py +0 -1015
  66. egse/confman/confman.yaml +0 -67
  67. egse/confman/confman_cs.py +0 -239
  68. egse/confman/confman_ui.py +0 -381
  69. egse/confman/setup_ui.py +0 -565
  70. egse/control.py +0 -442
  71. egse/coordinates/__init__.py +0 -531
  72. egse/coordinates/avoidance.py +0 -103
  73. egse/coordinates/cslmodel.py +0 -127
  74. egse/coordinates/laser_tracker_to_dict.py +0 -120
  75. egse/coordinates/point.py +0 -707
  76. egse/coordinates/pyplot.py +0 -195
  77. egse/coordinates/referenceFrame.py +0 -1279
  78. egse/coordinates/refmodel.py +0 -737
  79. egse/coordinates/rotationMatrix.py +0 -85
  80. egse/coordinates/transform3d_addon.py +0 -419
  81. egse/csl/__init__.py +0 -50
  82. egse/csl/commanding.py +0 -78
  83. egse/csl/icons/hexapod-connected-selected.svg +0 -30
  84. egse/csl/icons/hexapod-connected.svg +0 -30
  85. egse/csl/icons/hexapod-homing-selected.svg +0 -68
  86. egse/csl/icons/hexapod-homing.svg +0 -68
  87. egse/csl/icons/hexapod-retract-selected.svg +0 -56
  88. egse/csl/icons/hexapod-retract.svg +0 -51
  89. egse/csl/icons/hexapod-zero-selected.svg +0 -56
  90. egse/csl/icons/hexapod-zero.svg +0 -56
  91. egse/csl/icons/logo-puna.svg +0 -92
  92. egse/csl/icons/stop.svg +0 -1
  93. egse/csl/initialisation.py +0 -102
  94. egse/csl/mech_pos_settings.yaml +0 -18
  95. egse/das.py +0 -1247
  96. egse/das.yaml +0 -7
  97. egse/data/conf/SETUP_CSL_00000_170620_150000.yaml +0 -5
  98. egse/data/conf/SETUP_CSL_00001_170620_151010.yaml +0 -69
  99. egse/data/conf/SETUP_CSL_00002_170620_151020.yaml +0 -69
  100. egse/data/conf/SETUP_CSL_00003_170620_151030.yaml +0 -69
  101. egse/data/conf/SETUP_CSL_00004_170620_151040.yaml +0 -69
  102. egse/data/conf/SETUP_CSL_00005_170620_151050.yaml +0 -69
  103. egse/data/conf/SETUP_CSL_00006_170620_151060.yaml +0 -69
  104. egse/data/conf/SETUP_CSL_00007_170620_151070.yaml +0 -69
  105. egse/data/conf/SETUP_CSL_00008_170620_151080.yaml +0 -75
  106. egse/data/conf/SETUP_CSL_00010_210308_083016.yaml +0 -138
  107. egse/data/conf/SETUP_INTA_00000_170620_150000.yaml +0 -4
  108. egse/data/conf/SETUP_SRON_00000_170620_150000.yaml +0 -4
  109. egse/decorators.py +0 -415
  110. egse/device.py +0 -269
  111. egse/dpu/__init__.py +0 -2681
  112. egse/dpu/ccd_ui.py +0 -508
  113. egse/dpu/dpu.py +0 -786
  114. egse/dpu/dpu.yaml +0 -153
  115. egse/dpu/dpu_cs.py +0 -272
  116. egse/dpu/dpu_ui.py +0 -668
  117. egse/dpu/fitsgen.py +0 -2077
  118. egse/dpu/fitsgen_test.py +0 -752
  119. egse/dpu/fitsgen_ui.py +0 -399
  120. egse/dpu/hdf5_model.py +0 -332
  121. egse/dpu/hdf5_ui.py +0 -277
  122. egse/dpu/hdf5_viewer.py +0 -506
  123. egse/dpu/hk_ui.py +0 -468
  124. egse/dpu_commands.py +0 -81
  125. egse/dsi/constants.py +0 -220
  126. egse/dsi/esl.py +0 -870
  127. egse/dsi/rmap.py +0 -1042
  128. egse/dsi/rmapci.py +0 -37
  129. egse/dsi/spw.py +0 -154
  130. egse/dsi/spw_state.py +0 -29
  131. egse/dummy.py +0 -258
  132. egse/dyndummy.py +0 -179
  133. egse/env.py +0 -278
  134. egse/exceptions.py +0 -88
  135. egse/fdir/__init__.py +0 -28
  136. egse/fdir/fdir_manager.py +0 -85
  137. egse/fdir/fdir_manager.yaml +0 -51
  138. egse/fdir/fdir_manager_controller.py +0 -228
  139. egse/fdir/fdir_manager_cs.py +0 -164
  140. egse/fdir/fdir_manager_interface.py +0 -25
  141. egse/fdir/fdir_remote.py +0 -73
  142. egse/fdir/fdir_remote.yaml +0 -37
  143. egse/fdir/fdir_remote_controller.py +0 -50
  144. egse/fdir/fdir_remote_cs.py +0 -97
  145. egse/fdir/fdir_remote_interface.py +0 -14
  146. egse/fdir/fdir_remote_popup.py +0 -31
  147. egse/fee/__init__.py +0 -114
  148. egse/fee/f_fee_register.yaml +0 -43
  149. egse/fee/fee.py +0 -631
  150. egse/fee/feesim.py +0 -750
  151. egse/fee/n_fee_hk.py +0 -761
  152. egse/fee/nfee.py +0 -187
  153. egse/filterwheel/__init__.py +0 -4
  154. egse/filterwheel/eksma/__init__.py +0 -24
  155. egse/filterwheel/eksma/fw8smc4.py +0 -661
  156. egse/filterwheel/eksma/fw8smc4.yaml +0 -121
  157. egse/filterwheel/eksma/fw8smc4_cs.py +0 -144
  158. egse/filterwheel/eksma/fw8smc4_devif.py +0 -473
  159. egse/filterwheel/eksma/fw8smc4_protocol.py +0 -81
  160. egse/filterwheel/eksma/fw8smc4_ui.py +0 -940
  161. egse/filterwheel/eksma/fw8smc5.py +0 -111
  162. egse/filterwheel/eksma/fw8smc5.yaml +0 -105
  163. egse/filterwheel/eksma/fw8smc5_controller.py +0 -307
  164. egse/filterwheel/eksma/fw8smc5_cs.py +0 -141
  165. egse/filterwheel/eksma/fw8smc5_interface.py +0 -65
  166. egse/filterwheel/eksma/fw8smc5_simulator.py +0 -29
  167. egse/filterwheel/eksma/fw8smc5_ui.py +0 -1068
  168. egse/filterwheel/eksma/testpythonfw.py +0 -215
  169. egse/fov/__init__.py +0 -65
  170. egse/fov/fov_hk.py +0 -712
  171. egse/fov/fov_ui.py +0 -861
  172. egse/fov/fov_ui_controller.py +0 -140
  173. egse/fov/fov_ui_model.py +0 -200
  174. egse/fov/fov_ui_view.py +0 -345
  175. egse/gimbal/__init__.py +0 -32
  176. egse/gimbal/symetrie/__init__.py +0 -26
  177. egse/gimbal/symetrie/alpha.py +0 -586
  178. egse/gimbal/symetrie/generic_gimbal_ui.py +0 -1521
  179. egse/gimbal/symetrie/gimbal.py +0 -877
  180. egse/gimbal/symetrie/gimbal.yaml +0 -168
  181. egse/gimbal/symetrie/gimbal_cs.py +0 -183
  182. egse/gimbal/symetrie/gimbal_protocol.py +0 -135
  183. egse/gimbal/symetrie/gimbal_ui.py +0 -361
  184. egse/gimbal/symetrie/pmac.py +0 -1006
  185. egse/gimbal/symetrie/pmac_regex.py +0 -83
  186. egse/graph.py +0 -132
  187. egse/gui/__init__.py +0 -47
  188. egse/gui/buttons.py +0 -378
  189. egse/gui/focalplane.py +0 -1281
  190. egse/gui/formatter.py +0 -10
  191. egse/gui/led.py +0 -162
  192. egse/gui/limitswitch.py +0 -143
  193. egse/gui/mechanisms.py +0 -588
  194. egse/gui/states.py +0 -148
  195. egse/gui/stripchart.py +0 -729
  196. egse/gui/switch.py +0 -112
  197. egse/h5.py +0 -274
  198. egse/help/__init__.py +0 -0
  199. egse/help/help_ui.py +0 -126
  200. egse/hexapod/__init__.py +0 -32
  201. egse/hexapod/symetrie/__init__.py +0 -138
  202. egse/hexapod/symetrie/alpha.py +0 -874
  203. egse/hexapod/symetrie/dynalpha.py +0 -1387
  204. egse/hexapod/symetrie/hexapod_ui.py +0 -1516
  205. egse/hexapod/symetrie/pmac.py +0 -1010
  206. egse/hexapod/symetrie/pmac_regex.py +0 -83
  207. egse/hexapod/symetrie/puna.py +0 -1167
  208. egse/hexapod/symetrie/puna.yaml +0 -193
  209. egse/hexapod/symetrie/puna_cs.py +0 -196
  210. egse/hexapod/symetrie/puna_protocol.py +0 -131
  211. egse/hexapod/symetrie/puna_ui.py +0 -434
  212. egse/hexapod/symetrie/punaplus.py +0 -107
  213. egse/hexapod/symetrie/zonda.py +0 -872
  214. egse/hexapod/symetrie/zonda.yaml +0 -337
  215. egse/hexapod/symetrie/zonda_cs.py +0 -172
  216. egse/hexapod/symetrie/zonda_devif.py +0 -415
  217. egse/hexapod/symetrie/zonda_protocol.py +0 -119
  218. egse/hexapod/symetrie/zonda_ui.py +0 -449
  219. egse/hk.py +0 -765
  220. egse/icons/aeu-cs-start.svg +0 -117
  221. egse/icons/aeu-cs-stop.svg +0 -118
  222. egse/icons/aeu-cs.svg +0 -107
  223. egse/icons/aeu_cs-started.svg +0 -112
  224. egse/icons/aeu_cs-stopped.svg +0 -112
  225. egse/icons/aeu_cs.svg +0 -55
  226. egse/icons/alert.svg +0 -1
  227. egse/icons/arrow-double-left.png +0 -0
  228. egse/icons/arrow-double-right.png +0 -0
  229. egse/icons/arrow-up.svg +0 -11
  230. egse/icons/backward.svg +0 -1
  231. egse/icons/busy.svg +0 -1
  232. egse/icons/cleaning.svg +0 -115
  233. egse/icons/color-scheme.svg +0 -1
  234. egse/icons/cs-connected-alert.svg +0 -91
  235. egse/icons/cs-connected-disabled.svg +0 -43
  236. egse/icons/cs-connected.svg +0 -89
  237. egse/icons/cs-not-connected.svg +0 -44
  238. egse/icons/double-left-arrow.svg +0 -1
  239. egse/icons/double-right-arrow.svg +0 -1
  240. egse/icons/erase-disabled.svg +0 -19
  241. egse/icons/erase.svg +0 -59
  242. egse/icons/fitsgen-start.svg +0 -47
  243. egse/icons/fitsgen-stop.svg +0 -48
  244. egse/icons/fitsgen.svg +0 -1
  245. egse/icons/forward.svg +0 -1
  246. egse/icons/fov-hk-start.svg +0 -33
  247. egse/icons/fov-hk-stop.svg +0 -37
  248. egse/icons/fov-hk.svg +0 -1
  249. egse/icons/front-desk.svg +0 -1
  250. egse/icons/home-actioned.svg +0 -15
  251. egse/icons/home-disabled.svg +0 -15
  252. egse/icons/home.svg +0 -13
  253. egse/icons/info.svg +0 -1
  254. egse/icons/invalid.png +0 -0
  255. egse/icons/led-green.svg +0 -20
  256. egse/icons/led-grey.svg +0 -20
  257. egse/icons/led-orange.svg +0 -20
  258. egse/icons/led-red.svg +0 -20
  259. egse/icons/led-square-green.svg +0 -134
  260. egse/icons/led-square-grey.svg +0 -134
  261. egse/icons/led-square-orange.svg +0 -134
  262. egse/icons/led-square-red.svg +0 -134
  263. egse/icons/limit-switch-all-green.svg +0 -115
  264. egse/icons/limit-switch-all-red.svg +0 -117
  265. egse/icons/limit-switch-el+.svg +0 -116
  266. egse/icons/limit-switch-el-.svg +0 -117
  267. egse/icons/location-marker.svg +0 -1
  268. egse/icons/logo-dpu.svg +0 -48
  269. egse/icons/logo-gimbal.svg +0 -112
  270. egse/icons/logo-huber.svg +0 -23
  271. egse/icons/logo-ogse.svg +0 -31
  272. egse/icons/logo-puna.svg +0 -92
  273. egse/icons/logo-tcs.svg +0 -29
  274. egse/icons/logo-zonda.svg +0 -66
  275. egse/icons/maximize.svg +0 -1
  276. egse/icons/meter.svg +0 -1
  277. egse/icons/more.svg +0 -45
  278. egse/icons/n-fee-hk-start.svg +0 -24
  279. egse/icons/n-fee-hk-stop.svg +0 -25
  280. egse/icons/n-fee-hk.svg +0 -83
  281. egse/icons/observing-off.svg +0 -46
  282. egse/icons/observing-on.svg +0 -46
  283. egse/icons/open-document-hdf5.png +0 -0
  284. egse/icons/open-document-hdf5.svg +0 -21
  285. egse/icons/ops-mode.svg +0 -1
  286. egse/icons/play-green.svg +0 -17
  287. egse/icons/plugged-disabled.svg +0 -27
  288. egse/icons/plugged.svg +0 -21
  289. egse/icons/pm_ui.svg +0 -1
  290. egse/icons/power-button-green.svg +0 -27
  291. egse/icons/power-button-red.svg +0 -27
  292. egse/icons/power-button.svg +0 -27
  293. egse/icons/radar.svg +0 -1
  294. egse/icons/radioactive.svg +0 -2
  295. egse/icons/reload.svg +0 -1
  296. egse/icons/remote-control-off.svg +0 -28
  297. egse/icons/remote-control-on.svg +0 -28
  298. egse/icons/repeat-blue.svg +0 -15
  299. egse/icons/repeat.svg +0 -1
  300. egse/icons/settings.svg +0 -1
  301. egse/icons/shrink.svg +0 -1
  302. egse/icons/shutter.svg +0 -1
  303. egse/icons/sign-off.svg +0 -1
  304. egse/icons/sign-on.svg +0 -1
  305. egse/icons/sim-mode.svg +0 -1
  306. egse/icons/small-buttons-go.svg +0 -20
  307. egse/icons/small-buttons-minus.svg +0 -51
  308. egse/icons/small-buttons-plus.svg +0 -51
  309. egse/icons/sponge.svg +0 -220
  310. egse/icons/start-button-disabled.svg +0 -84
  311. egse/icons/start-button.svg +0 -50
  312. egse/icons/stop-button-disabled.svg +0 -84
  313. egse/icons/stop-button.svg +0 -50
  314. egse/icons/stop-red.svg +0 -17
  315. egse/icons/stop.svg +0 -1
  316. egse/icons/switch-disabled-square.svg +0 -87
  317. egse/icons/switch-disabled.svg +0 -15
  318. egse/icons/switch-off-square.svg +0 -87
  319. egse/icons/switch-off.svg +0 -72
  320. egse/icons/switch-on-square.svg +0 -87
  321. egse/icons/switch-on.svg +0 -61
  322. egse/icons/temperature-control.svg +0 -44
  323. egse/icons/th_ui_logo.svg +0 -1
  324. egse/icons/unplugged.svg +0 -23
  325. egse/icons/unvalid.png +0 -0
  326. egse/icons/user-interface.svg +0 -1
  327. egse/icons/vacuum.svg +0 -1
  328. egse/icons/valid.png +0 -0
  329. egse/icons/zoom-to-pixel-dark.svg +0 -64
  330. egse/icons/zoom-to-pixel-white.svg +0 -36
  331. egse/images/big-rotation-stage.png +0 -0
  332. egse/images/connected-100.png +0 -0
  333. egse/images/cross.svg +0 -6
  334. egse/images/disconnected-100.png +0 -0
  335. egse/images/gui-icon.png +0 -0
  336. egse/images/home.svg +0 -6
  337. egse/images/info-icon.png +0 -0
  338. egse/images/led-black.svg +0 -89
  339. egse/images/led-green.svg +0 -85
  340. egse/images/led-orange.svg +0 -85
  341. egse/images/led-red.svg +0 -85
  342. egse/images/load-icon.png +0 -0
  343. egse/images/load-setup.png +0 -0
  344. egse/images/load.png +0 -0
  345. egse/images/pause.png +0 -0
  346. egse/images/play-button.svg +0 -8
  347. egse/images/play.png +0 -0
  348. egse/images/process-status.png +0 -0
  349. egse/images/restart.png +0 -0
  350. egse/images/search.png +0 -0
  351. egse/images/sma.png +0 -0
  352. egse/images/start.png +0 -0
  353. egse/images/stop-button.svg +0 -8
  354. egse/images/stop.png +0 -0
  355. egse/images/switch-off.svg +0 -48
  356. egse/images/switch-on.svg +0 -48
  357. egse/images/undo.png +0 -0
  358. egse/images/update-button.svg +0 -11
  359. egse/imageviewer/exposureselection.py +0 -475
  360. egse/imageviewer/imageviewer.py +0 -198
  361. egse/imageviewer/matchfocalplane.py +0 -179
  362. egse/imageviewer/subfieldposition.py +0 -133
  363. egse/lampcontrol/__init__.py +0 -4
  364. egse/lampcontrol/beaglebone/beaglebone.py +0 -178
  365. egse/lampcontrol/beaglebone/beaglebone.yaml +0 -62
  366. egse/lampcontrol/beaglebone/beaglebone_cs.py +0 -106
  367. egse/lampcontrol/beaglebone/beaglebone_devif.py +0 -150
  368. egse/lampcontrol/beaglebone/beaglebone_protocol.py +0 -73
  369. egse/lampcontrol/energetiq/__init__.py +0 -22
  370. egse/lampcontrol/energetiq/eq99.yaml +0 -98
  371. egse/lampcontrol/energetiq/lampEQ99.py +0 -283
  372. egse/lampcontrol/energetiq/lampEQ99_cs.py +0 -128
  373. egse/lampcontrol/energetiq/lampEQ99_devif.py +0 -158
  374. egse/lampcontrol/energetiq/lampEQ99_encode_decode_errors.py +0 -73
  375. egse/lampcontrol/energetiq/lampEQ99_protocol.py +0 -69
  376. egse/lampcontrol/energetiq/lampEQ99_ui.py +0 -465
  377. egse/lib/CentOS-7/EtherSpaceLink_v34_86.dylib +0 -0
  378. egse/lib/CentOS-8/ESL-RMAP_v34_86.dylib +0 -0
  379. egse/lib/CentOS-8/EtherSpaceLink_v34_86.dylib +0 -0
  380. egse/lib/Debian/ESL-RMAP_v34_86.dylib +0 -0
  381. egse/lib/Debian/EtherSpaceLink_v34_86.dylib +0 -0
  382. egse/lib/Debian/libetherspacelink_v35_21.dylib +0 -0
  383. egse/lib/Linux/ESL-RMAP_v34_86.dylib +0 -0
  384. egse/lib/Linux/EtherSpaceLink_v34_86.dylib +0 -0
  385. egse/lib/Ubuntu-20/ESL-RMAP_v34_86.dylib +0 -0
  386. egse/lib/Ubuntu-20/EtherSpaceLink_v34_86.dylib +0 -0
  387. egse/lib/gssw/python3-gssw_2.2.3+31f63c9f-1_all.deb +0 -0
  388. egse/lib/macOS/ESL-RMAP_v34_86.dylib +0 -0
  389. egse/lib/macOS/EtherSpaceLink_v34_86.dylib +0 -0
  390. egse/lib/ximc/__pycache__/pyximc.cpython-38 2.pyc +0 -0
  391. egse/lib/ximc/__pycache__/pyximc.cpython-38.pyc +0 -0
  392. egse/lib/ximc/libximc.framework/Frameworks/libbindy.dylib +0 -0
  393. egse/lib/ximc/libximc.framework/Frameworks/libxiwrapper.dylib +0 -0
  394. egse/lib/ximc/libximc.framework/Headers/ximc.h +0 -5510
  395. egse/lib/ximc/libximc.framework/Resources/Info.plist +0 -42
  396. egse/lib/ximc/libximc.framework/Resources/keyfile.sqlite +0 -0
  397. egse/lib/ximc/libximc.framework/libbindy.so +0 -0
  398. egse/lib/ximc/libximc.framework/libximc +0 -0
  399. egse/lib/ximc/libximc.framework/libximc.so +0 -0
  400. egse/lib/ximc/libximc.framework/libximc.so.7.0.0 +0 -0
  401. egse/lib/ximc/libximc.framework/libxiwrapper.so +0 -0
  402. egse/lib/ximc/pyximc.py +0 -922
  403. egse/listener.py +0 -73
  404. egse/logger/__init__.py +0 -243
  405. egse/logger/log_cs.py +0 -321
  406. egse/metrics.py +0 -98
  407. egse/mixin.py +0 -464
  408. egse/monitoring.py +0 -95
  409. egse/ni/alarms/__init__.py +0 -26
  410. egse/ni/alarms/cdaq9375.py +0 -300
  411. egse/ni/alarms/cdaq9375.yaml +0 -89
  412. egse/ni/alarms/cdaq9375_cs.py +0 -130
  413. egse/ni/alarms/cdaq9375_devif.py +0 -183
  414. egse/ni/alarms/cdaq9375_protocol.py +0 -48
  415. egse/obs_inspection.py +0 -163
  416. egse/observer.py +0 -41
  417. egse/obsid.py +0 -163
  418. egse/powermeter/__init__.py +0 -0
  419. egse/powermeter/ni/__init__.py +0 -38
  420. egse/powermeter/ni/cdaq9184.py +0 -224
  421. egse/powermeter/ni/cdaq9184.yaml +0 -73
  422. egse/powermeter/ni/cdaq9184_cs.py +0 -130
  423. egse/powermeter/ni/cdaq9184_devif.py +0 -201
  424. egse/powermeter/ni/cdaq9184_protocol.py +0 -48
  425. egse/powermeter/ni/cdaq9184_ui.py +0 -544
  426. egse/powermeter/thorlabs/__init__.py +0 -25
  427. egse/powermeter/thorlabs/pm100a.py +0 -380
  428. egse/powermeter/thorlabs/pm100a.yaml +0 -132
  429. egse/powermeter/thorlabs/pm100a_cs.py +0 -136
  430. egse/powermeter/thorlabs/pm100a_devif.py +0 -127
  431. egse/powermeter/thorlabs/pm100a_protocol.py +0 -80
  432. egse/powermeter/thorlabs/pm100a_ui.py +0 -725
  433. egse/process.py +0 -451
  434. egse/procman/__init__.py +0 -811
  435. egse/procman/cannot_start_process_popup.py +0 -43
  436. egse/procman/procman.yaml +0 -49
  437. egse/procman/procman_cs.py +0 -201
  438. egse/procman/procman_ui.py +0 -2081
  439. egse/protocol.py +0 -603
  440. egse/proxy.py +0 -522
  441. egse/randomwalk.py +0 -140
  442. egse/reg.py +0 -585
  443. egse/reload.py +0 -122
  444. egse/reprocess.py +0 -675
  445. egse/resource.py +0 -333
  446. egse/rst.py +0 -135
  447. egse/search.py +0 -182
  448. egse/serialdevice.py +0 -190
  449. egse/services.py +0 -212
  450. egse/services.yaml +0 -51
  451. egse/settings.py +0 -379
  452. egse/settings.yaml +0 -980
  453. egse/setup.py +0 -1180
  454. egse/shutter/__init__.py +0 -0
  455. egse/shutter/thorlabs/__init__.py +0 -19
  456. egse/shutter/thorlabs/ksc101.py +0 -205
  457. egse/shutter/thorlabs/ksc101.yaml +0 -105
  458. egse/shutter/thorlabs/ksc101_cs.py +0 -136
  459. egse/shutter/thorlabs/ksc101_devif.py +0 -201
  460. egse/shutter/thorlabs/ksc101_protocol.py +0 -69
  461. egse/shutter/thorlabs/ksc101_ui.py +0 -548
  462. egse/shutter/thorlabs/sc10.py +0 -82
  463. egse/shutter/thorlabs/sc10.yaml +0 -52
  464. egse/shutter/thorlabs/sc10_controller.py +0 -81
  465. egse/shutter/thorlabs/sc10_cs.py +0 -108
  466. egse/shutter/thorlabs/sc10_interface.py +0 -25
  467. egse/shutter/thorlabs/sc10_simulator.py +0 -30
  468. egse/simulator.py +0 -41
  469. egse/slack.py +0 -61
  470. egse/socketdevice.py +0 -218
  471. egse/sockets.py +0 -218
  472. egse/spw.py +0 -1479
  473. egse/stages/__init__.py +0 -12
  474. egse/stages/aerotech/ensemble.py +0 -247
  475. egse/stages/aerotech/ensemble.yaml +0 -205
  476. egse/stages/aerotech/ensemble_controller.py +0 -275
  477. egse/stages/aerotech/ensemble_cs.py +0 -110
  478. egse/stages/aerotech/ensemble_interface.py +0 -132
  479. egse/stages/aerotech/ensemble_parameters.py +0 -433
  480. egse/stages/aerotech/ensemble_simulator.py +0 -27
  481. egse/stages/aerotech/mgse_sim.py +0 -193
  482. egse/stages/arun/smd3.py +0 -111
  483. egse/stages/arun/smd3.yaml +0 -68
  484. egse/stages/arun/smd3_controller.py +0 -472
  485. egse/stages/arun/smd3_cs.py +0 -112
  486. egse/stages/arun/smd3_interface.py +0 -53
  487. egse/stages/arun/smd3_simulator.py +0 -27
  488. egse/stages/arun/smd3_stop.py +0 -16
  489. egse/stages/huber/__init__.py +0 -49
  490. egse/stages/huber/smc9300.py +0 -904
  491. egse/stages/huber/smc9300.yaml +0 -63
  492. egse/stages/huber/smc9300_cs.py +0 -178
  493. egse/stages/huber/smc9300_devif.py +0 -345
  494. egse/stages/huber/smc9300_protocol.py +0 -111
  495. egse/stages/huber/smc9300_sim.py +0 -547
  496. egse/stages/huber/smc9300_ui.py +0 -973
  497. egse/state.py +0 -173
  498. egse/statemachine.py +0 -274
  499. egse/storage/__init__.py +0 -1004
  500. egse/storage/persistence.py +0 -2295
  501. egse/storage/storage.yaml +0 -72
  502. egse/storage/storage_cs.py +0 -214
  503. egse/styles/dark.qss +0 -343
  504. egse/styles/default.qss +0 -48
  505. egse/synoptics/__init__.py +0 -412
  506. egse/synoptics/syn.yaml +0 -9
  507. egse/synoptics/syn_cs.py +0 -195
  508. egse/system.py +0 -1408
  509. egse/tcs/__init__.py +0 -14
  510. egse/tcs/tcs.py +0 -874
  511. egse/tcs/tcs.yaml +0 -14
  512. egse/tcs/tcs_cs.py +0 -202
  513. egse/tcs/tcs_devif.py +0 -292
  514. egse/tcs/tcs_protocol.py +0 -177
  515. egse/tcs/tcs_sim.py +0 -177
  516. egse/tcs/tcs_ui.py +0 -543
  517. egse/tdms.py +0 -171
  518. egse/tempcontrol/__init__.py +0 -23
  519. egse/tempcontrol/agilent/agilent34970.py +0 -109
  520. egse/tempcontrol/agilent/agilent34970.yaml +0 -44
  521. egse/tempcontrol/agilent/agilent34970_cs.py +0 -116
  522. egse/tempcontrol/agilent/agilent34970_devif.py +0 -182
  523. egse/tempcontrol/agilent/agilent34970_protocol.py +0 -99
  524. egse/tempcontrol/agilent/agilent34972.py +0 -111
  525. egse/tempcontrol/agilent/agilent34972.yaml +0 -44
  526. egse/tempcontrol/agilent/agilent34972_cs.py +0 -117
  527. egse/tempcontrol/agilent/agilent34972_devif.py +0 -189
  528. egse/tempcontrol/agilent/agilent34972_protocol.py +0 -101
  529. egse/tempcontrol/beaglebone/beaglebone.py +0 -342
  530. egse/tempcontrol/beaglebone/beaglebone.yaml +0 -110
  531. egse/tempcontrol/beaglebone/beaglebone_cs.py +0 -117
  532. egse/tempcontrol/beaglebone/beaglebone_protocol.py +0 -135
  533. egse/tempcontrol/beaglebone/beaglebone_ui.py +0 -681
  534. egse/tempcontrol/digalox/digalox.py +0 -107
  535. egse/tempcontrol/digalox/digalox.yaml +0 -36
  536. egse/tempcontrol/digalox/digalox_cs.py +0 -112
  537. egse/tempcontrol/digalox/digalox_protocol.py +0 -55
  538. egse/tempcontrol/keithley/__init__.py +0 -33
  539. egse/tempcontrol/keithley/daq6510.py +0 -662
  540. egse/tempcontrol/keithley/daq6510.yaml +0 -105
  541. egse/tempcontrol/keithley/daq6510_cs.py +0 -163
  542. egse/tempcontrol/keithley/daq6510_devif.py +0 -343
  543. egse/tempcontrol/keithley/daq6510_protocol.py +0 -78
  544. egse/tempcontrol/keithley/daq6510_sim.py +0 -186
  545. egse/tempcontrol/lakeshore/__init__.py +0 -33
  546. egse/tempcontrol/lakeshore/lsci.py +0 -361
  547. egse/tempcontrol/lakeshore/lsci.yaml +0 -162
  548. egse/tempcontrol/lakeshore/lsci_cs.py +0 -174
  549. egse/tempcontrol/lakeshore/lsci_devif.py +0 -292
  550. egse/tempcontrol/lakeshore/lsci_protocol.py +0 -73
  551. egse/tempcontrol/lakeshore/lsci_ui.py +0 -389
  552. egse/tempcontrol/ni/__init__.py +0 -0
  553. egse/tempcontrol/spid/spid.py +0 -109
  554. egse/tempcontrol/spid/spid.yaml +0 -81
  555. egse/tempcontrol/spid/spid_controller.py +0 -279
  556. egse/tempcontrol/spid/spid_cs.py +0 -136
  557. egse/tempcontrol/spid/spid_protocol.py +0 -107
  558. egse/tempcontrol/spid/spid_ui.py +0 -727
  559. egse/tempcontrol/srs/__init__.py +0 -22
  560. egse/tempcontrol/srs/ptc10.py +0 -875
  561. egse/tempcontrol/srs/ptc10.yaml +0 -227
  562. egse/tempcontrol/srs/ptc10_cs.py +0 -128
  563. egse/tempcontrol/srs/ptc10_devif.py +0 -118
  564. egse/tempcontrol/srs/ptc10_protocol.py +0 -42
  565. egse/tempcontrol/srs/ptc10_ui.py +0 -906
  566. egse/ups/apc/apc.py +0 -236
  567. egse/ups/apc/apc.yaml +0 -45
  568. egse/ups/apc/apc_cs.py +0 -101
  569. egse/ups/apc/apc_protocol.py +0 -125
  570. egse/user.yaml +0 -7
  571. egse/vacuum/beaglebone/beaglebone.py +0 -149
  572. egse/vacuum/beaglebone/beaglebone.yaml +0 -44
  573. egse/vacuum/beaglebone/beaglebone_cs.py +0 -108
  574. egse/vacuum/beaglebone/beaglebone_devif.py +0 -164
  575. egse/vacuum/beaglebone/beaglebone_protocol.py +0 -193
  576. egse/vacuum/beaglebone/beaglebone_ui.py +0 -638
  577. egse/vacuum/instrutech/igm402.py +0 -92
  578. egse/vacuum/instrutech/igm402.yaml +0 -90
  579. egse/vacuum/instrutech/igm402_controller.py +0 -128
  580. egse/vacuum/instrutech/igm402_cs.py +0 -108
  581. egse/vacuum/instrutech/igm402_interface.py +0 -49
  582. egse/vacuum/instrutech/igm402_simulator.py +0 -36
  583. egse/vacuum/keller/kellerBus.py +0 -256
  584. egse/vacuum/keller/leo3.py +0 -102
  585. egse/vacuum/keller/leo3.yaml +0 -38
  586. egse/vacuum/keller/leo3_controller.py +0 -83
  587. egse/vacuum/keller/leo3_cs.py +0 -101
  588. egse/vacuum/keller/leo3_interface.py +0 -33
  589. egse/vacuum/mks/evision.py +0 -86
  590. egse/vacuum/mks/evision.yaml +0 -75
  591. egse/vacuum/mks/evision_cs.py +0 -101
  592. egse/vacuum/mks/evision_devif.py +0 -316
  593. egse/vacuum/mks/evision_interface.py +0 -60
  594. egse/vacuum/mks/evision_simulator.py +0 -24
  595. egse/vacuum/mks/evision_ui.py +0 -704
  596. egse/vacuum/pfeiffer/acp40.py +0 -87
  597. egse/vacuum/pfeiffer/acp40.yaml +0 -60
  598. egse/vacuum/pfeiffer/acp40_controller.py +0 -117
  599. egse/vacuum/pfeiffer/acp40_cs.py +0 -109
  600. egse/vacuum/pfeiffer/acp40_interface.py +0 -40
  601. egse/vacuum/pfeiffer/acp40_simulator.py +0 -39
  602. egse/vacuum/pfeiffer/tc400.py +0 -113
  603. egse/vacuum/pfeiffer/tc400.yaml +0 -83
  604. egse/vacuum/pfeiffer/tc400_controller.py +0 -140
  605. egse/vacuum/pfeiffer/tc400_cs.py +0 -109
  606. egse/vacuum/pfeiffer/tc400_interface.py +0 -70
  607. egse/vacuum/pfeiffer/tc400_simulator.py +0 -24
  608. egse/vacuum/pfeiffer/tpg261.py +0 -81
  609. egse/vacuum/pfeiffer/tpg261.yaml +0 -66
  610. egse/vacuum/pfeiffer/tpg261_controller.py +0 -150
  611. egse/vacuum/pfeiffer/tpg261_cs.py +0 -109
  612. egse/vacuum/pfeiffer/tpg261_interface.py +0 -60
  613. egse/vacuum/pfeiffer/tpg261_simulator.py +0 -24
  614. egse/version.py +0 -174
  615. egse/visitedpositions.py +0 -398
  616. egse/windowing.py +0 -213
  617. egse/zmq/__init__.py +0 -28
  618. egse/zmq/spw.py +0 -160
  619. egse/zmq_ser.py +0 -41
  620. scripts/alerts/cold.yaml +0 -278
  621. scripts/alerts/example_alerts.yaml +0 -54
  622. scripts/alerts/transition.yaml +0 -14
  623. scripts/alerts/warm.yaml +0 -49
  624. scripts/analyse_n_fee_hk_data.py +0 -44
  625. scripts/check_hdf5_files.py +0 -192
  626. scripts/check_register_sync.py +0 -47
  627. scripts/create_hdf5_report.py +0 -295
  628. scripts/csl_model.py +0 -436
  629. scripts/csl_restore_setup.py +0 -230
  630. scripts/export-grafana-dashboards.py +0 -50
  631. scripts/fdir/cs_recovery/fdir_cs_recovery.py +0 -59
  632. scripts/fdir/fdir_table.yaml +0 -70
  633. scripts/fdir/fdir_test_recovery.py +0 -11
  634. scripts/fdir/hw_recovery/fdir_agilent_hw_recovery.py +0 -73
  635. scripts/fdir/limit_recovery/fdir_agilent_limit.py +0 -64
  636. scripts/fdir/limit_recovery/fdir_bb_heater_limit.py +0 -61
  637. scripts/fdir/limit_recovery/fdir_ensemble_limit.py +0 -33
  638. scripts/fdir/limit_recovery/fdir_pressure_limit_recovery.py +0 -71
  639. scripts/fix_csv.py +0 -80
  640. scripts/n_fee_supply_voltage_calculation.py +0 -92
  641. scripts/playground.py +0 -30
  642. scripts/print_hdf5_hk_data.py +0 -68
  643. scripts/print_register_map.py +0 -43
  644. scripts/sron/commanding/control_heaters.py +0 -44
  645. scripts/sron/commanding/pumpdown.py +0 -46
  646. scripts/sron/commanding/set_pid_setpoint.py +0 -19
  647. scripts/sron/commanding/shutdown_bbb_heaters.py +0 -10
  648. scripts/sron/commanding/shutdown_pumps.py +0 -33
  649. scripts/sron/tm_gen/tm_gen_agilent.py +0 -38
  650. scripts/sron/tm_gen/tm_gen_heaters.py +0 -4
  651. scripts/sron/tm_gen/tm_gen_spid.py +0 -13
  652. scripts/update_operational_cgse.py +0 -268
  653. scripts/update_operational_cgse_old.py +0 -273
egse/gui/focalplane.py DELETED
@@ -1,1281 +0,0 @@
1
- """
2
- This modules yields to widgets in which the focal plane is visualised. The combobox
3
- below the plot can be used to choose the coordinate system used in the plot: focal-plane
4
- coordinates, pixel coordinates, and field angles. A blue cirle denotes the edge of the
5
- FOV.
6
- """
7
- import logging
8
- from math import atan
9
- from math import degrees
10
- from math import radians
11
-
12
- import matplotlib.pyplot as plt
13
- import matplotlib.ticker as ticker
14
- import numpy as np
15
- from PyQt5.QtGui import QFont
16
- from PyQt5.QtWidgets import QComboBox
17
- from PyQt5.QtWidgets import QGridLayout
18
- from PyQt5.QtWidgets import QGroupBox
19
- from PyQt5.QtWidgets import QLabel
20
- from PyQt5.QtWidgets import QSizePolicy
21
- from matplotlib.backends.backend_qt5agg import FigureCanvasQTAgg as FigureCanvas
22
- from matplotlib.figure import Figure
23
-
24
- from egse.coordinates import ccd_to_focal_plane_coordinates
25
- from egse.coordinates import focal_plane_coordinates_to_angles
26
- from egse.gui.formatter import degree_formatter
27
- from egse.settings import Settings
28
- from egse.state import GlobalState
29
-
30
- FONT = QFont("Helvetica", 18)
31
-
32
- FOV_SETTINGS = Settings.load("Field-Of-View")
33
- MODULE_LOGGER = logging.getLogger(__name__)
34
-
35
- COORDINATE_SYSTEMS = {
36
- "Focal plane": "Focal-plane coordinates [mm]",
37
- "Pixels": "Pixel coordinates",
38
- "Angles": "Angles"
39
- }
40
-
41
- PIXEL_SIZE = CCD_SETTINGS = Settings.load("CCD").PIXEL_SIZE / 1000 # Pixel size [mm]
42
- ZEROPOINT = Settings.load("CCD").ZEROPOINT # CCD zeropoint (x, y) [mm]
43
- NUM_ROWS = Settings.load("CCD").NUM_ROWS
44
- NUM_COLUMNS = Settings.load("CCD").NUM_COLUMNS
45
-
46
-
47
- class FocalPlane(FigureCanvas):
48
-
49
- """
50
- FigureCanvas showing the focal plane, with a blue circle indicating the field-of-view.
51
- The available coordinate systems are:
52
- - pixel coordinates [pixels],
53
- - focal-plane coordinates [mm],
54
- - and field angles [degrees].
55
- """
56
-
57
- def __init__(self, parent=None, dpi=100):
58
-
59
- """
60
- Initialisation of a plot of the focal plane, with a blue circle indicating the
61
- field-of-view.
62
- """
63
- self.fee_side = GlobalState.setup.camera.fee.ccd_sides.enum
64
- self.ccd_id = GlobalState.setup.camera.fee.ccd_numbering.CCD_ID
65
-
66
- self.figure = Figure()
67
- self.ax = self.figure.add_subplot(111)
68
-
69
- FigureCanvas.__init__(self, self.figure)
70
- self.setParent(parent)
71
-
72
- FigureCanvas.setSizePolicy(
73
- self, QSizePolicy.Expanding, QSizePolicy.Expanding)
74
- FigureCanvas.updateGeometry(self)
75
-
76
- def change_to_focal_plane_coordinates(self):
77
-
78
- """
79
- Preparation of the plot to show the source position in focal-plane coordinates:
80
-
81
- - clear the plot;
82
- - draw a blue circle, indicating the size of the field-of view;
83
- - configure the axes and grid lines;
84
- - draw the CCDs and their readout registers;
85
- - add the CCD codes.
86
-
87
- The draw() method should be called in the sub-classes.
88
- """
89
-
90
- self.coordinate_system = COORDINATE_SYSTEMS["Focal plane"]
91
-
92
- self.figure.delaxes(self.ax)
93
- self.ax = self.figure.add_subplot(111)
94
- self.ax.set_aspect(1)
95
-
96
- # Circle indicating the size of the FOV [mm]
97
-
98
- self.circle = plt.Circle(
99
- (0, 0), FOV_SETTINGS.RADIUS_MM, color='b', fill=False, label="FOV", linewidth=1)
100
- self.ax.add_artist(self.circle)
101
-
102
- # Range
103
-
104
- limit = 85
105
- self.ax.set_xlim([-limit, limit])
106
- self.ax.set_ylim([-limit, limit])
107
-
108
- self.ax.set_xlabel("$x_{FP} [mm]$", fontsize=10)
109
- self.ax.xaxis.set_label_coords(1.085, 0.45)
110
- self.ax.set_ylabel("$y_{FP} [mm]$", fontsize=10, rotation=0)
111
- self.ax.yaxis.set_label_coords(0.47, 1.05)
112
-
113
- # Make sure the axes cross at the origin
114
-
115
- self.ax.axvline(x=0, color="k", linewidth=1)
116
- self.ax.axhline(y=0, color="k", linewidth=1)
117
-
118
- self.ax.spines['left'].set_position('center')
119
- self.ax.spines['bottom'].set_position('center')
120
- self.ax.spines['right'].set_color('none')
121
- self.ax.spines['top'].set_color('none')
122
-
123
- xmin, xmax = self.ax.get_xlim()
124
- ymin, ymax = self.ax.get_ylim()
125
-
126
- self.ax.arrow(xmin, 0, xmax-xmin+7, 0., fc='k', ec='k', lw=1,
127
- head_width=3, head_length=5, overhang=0.3,
128
- length_includes_head=True, clip_on=False)
129
-
130
- self.ax.arrow(0, ymin, 0., ymax-ymin+7, fc='k', ec='k', lw=1,
131
- head_width=3, head_length=5, overhang=0.3,
132
- length_includes_head=True, clip_on=False)
133
-
134
- # Readout registers
135
-
136
- self.ax.plot([-ZEROPOINT[0], ZEROPOINT[1]], [-ZEROPOINT[1], -
137
- ZEROPOINT[1]], color="k", linewidth=3) # Upper left CCD
138
- self.ax.plot([ZEROPOINT[1], ZEROPOINT[1]], [-ZEROPOINT[0],
139
- ZEROPOINT[1]], color="k", linewidth=3) # Lower left CCD
140
- self.ax.plot([ZEROPOINT[0], -ZEROPOINT[1]], [ZEROPOINT[1],
141
- ZEROPOINT[1]], color="k", linewidth=3) # Lower right CCD
142
- self.ax.plot([-ZEROPOINT[1], -ZEROPOINT[1]], [ZEROPOINT[0], -
143
- ZEROPOINT[1]], color="k", linewidth=3) # Upper right CCD
144
-
145
- # CCD middle
146
-
147
- self.ax.plot([ZEROPOINT[0] - NUM_COLUMNS / 2 * PIXEL_SIZE, ZEROPOINT[0] - NUM_COLUMNS / 2 * PIXEL_SIZE],
148
- [-ZEROPOINT[0], ZEROPOINT[1]], color="k", linewidth=1,
149
- linestyle="dotted") # Upper left CCD
150
- self.ax.plot([-ZEROPOINT[1], ZEROPOINT[0]],
151
- [ZEROPOINT[0] - NUM_COLUMNS / 2 * PIXEL_SIZE, ZEROPOINT[0] - NUM_COLUMNS / 2 * PIXEL_SIZE],
152
- color="k", linewidth=1, linestyle="dotted") # Lower left CCD
153
- self.ax.plot([-ZEROPOINT[0] + NUM_COLUMNS / 2 * PIXEL_SIZE, -ZEROPOINT[0] + NUM_COLUMNS / 2 * PIXEL_SIZE],
154
- [-ZEROPOINT[1], ZEROPOINT[0]], color="k", linewidth=1,
155
- linestyle="dotted") # Lower right CCD
156
- self.ax.plot([-ZEROPOINT[0], ZEROPOINT[1]],
157
- [-ZEROPOINT[0] + NUM_COLUMNS / 2 * PIXEL_SIZE, -ZEROPOINT[0] + NUM_COLUMNS / 2 * PIXEL_SIZE],
158
- color="k", linewidth=1, linestyle="dotted") # Upper right CCD
159
-
160
- # CCD codes
161
-
162
- self.ax.text(-80, 70, self.ccd_id[2]) # Upper left CCD
163
- self.ax.text(-80, -75, self.ccd_id[3]) # Lower left CCD
164
- self.ax.text(60, -75, self.ccd_id[0]) # Lower right CCD
165
- self.ax.text(60, 70, self.ccd_id[1]) # Upper right CCD
166
-
167
- self.ax.text(-30, 10, self.fee_side.LEFT_SIDE.name, rotation=180) # Upper leftCCD, left side
168
- self.ax.text(-75, 10, self.fee_side.RIGHT_SIDE.name, rotation=180) # Upper left CCD, right side
169
- self.ax.text(-20, -15, self.fee_side.LEFT_SIDE.name, rotation=-90) # Lower left CCD, left side
170
- self.ax.text(-20, -75, self.fee_side.RIGHT_SIDE.name, rotation=-90) # Lower left CCD, right side
171
- self.ax.text(10, -15, self.fee_side.LEFT_SIDE.name) # Lower right CCD, left side
172
- self.ax.text(50, -15, self.fee_side.RIGHT_SIDE.name) # Lower right CCD, right side
173
- self.ax.text(10, 10, self.fee_side.LEFT_SIDE.name, rotation=90) # Upper right CCD, left side
174
- self.ax.text(10, 50, self.fee_side.RIGHT_SIDE.name, rotation=90) # Upper right CCD, right side
175
-
176
- self.ax.plot([-ZEROPOINT[0], ZEROPOINT[1], ZEROPOINT[1], -ZEROPOINT[0], -ZEROPOINT[0]],
177
- [ZEROPOINT[0], ZEROPOINT[0], -ZEROPOINT[1], -ZEROPOINT[1], ZEROPOINT[0]],
178
- color="k", linewidth=1) # Upper left CCD
179
- self.ax.plot([-ZEROPOINT[0], ZEROPOINT[1], ZEROPOINT[1], -ZEROPOINT[0], -ZEROPOINT[0]],
180
- [-ZEROPOINT[0], - ZEROPOINT[0], ZEROPOINT[1], ZEROPOINT[1], -ZEROPOINT[0]],
181
- color="k", linewidth=1) # Lower left CCD
182
- self.ax.plot([-ZEROPOINT[1], ZEROPOINT[0], ZEROPOINT[0], -ZEROPOINT[1], -ZEROPOINT[1]],
183
- [-ZEROPOINT[0], - ZEROPOINT[0], ZEROPOINT[1], ZEROPOINT[1], -ZEROPOINT[0]],
184
- color="k", linewidth=1) # Lower right CCD
185
- self.ax.plot([-ZEROPOINT[1], ZEROPOINT[0], ZEROPOINT[0], -ZEROPOINT[1], -ZEROPOINT[1]],
186
- [ZEROPOINT[0], ZEROPOINT[0], -ZEROPOINT[1], -ZEROPOINT[1], ZEROPOINT[0]],
187
- color="k", linewidth=1) # Upper right CCD
188
-
189
- # Grid lines
190
-
191
- self.ax.grid(color="lightgray", linewidth=0.5)
192
-
193
- ticks = np.arange(-80, 90, 20)
194
- ticks = np.delete(ticks, 4)
195
- self.ax.set_xticks(ticks)
196
- self.ax.set_yticks(ticks)
197
-
198
- def change_to_pixel_coordinates(self):
199
-
200
- """
201
- Preparation of the plot to show the source position in pixel coordinates:
202
-
203
- - clear the plot;
204
- - draw a blue circle, indicating the size of the field-of view;
205
- - configure the axes and grid lines;
206
- - draw the CCDs and their readout registers;
207
- - add the CCD codes.
208
-
209
- The draw() method should be called in the sub-classes.
210
- """
211
-
212
- self.coordinate_system = COORDINATE_SYSTEMS["Pixels"]
213
-
214
- self.figure.delaxes(self.ax)
215
- self.ax = self.figure.add_subplot(111)
216
- self.ax.set_aspect(1)
217
-
218
- # Circle indicating the size of the FOV [mm]
219
-
220
- self.circle = plt.Circle(
221
- (0, 0), FOV_SETTINGS.RADIUS_PIXELS, color='b', fill=False, label="FOV", linewidth=1)
222
- self.ax.add_artist(self.circle)
223
-
224
- # Range
225
- # If we do it like this, the circle will have the same size on screen when
226
- # switching between coordinate systems
227
-
228
- limit = 85 / PIXEL_SIZE
229
- self.ax.set_xlim([-limit, limit])
230
- self.ax.set_ylim([-limit, limit])
231
-
232
- self.ax.set_xlabel("$x_{CCD} [pixels]$", fontsize=10)
233
- self.ax.xaxis.set_label_coords(1.085, 0.45)
234
- self.ax.set_ylabel("$y_{CCD} [pixels]$", fontsize=10, rotation=0)
235
- self.ax.yaxis.set_label_coords(0.47, 1.05)
236
-
237
- # Make sure the axes cross at the origin
238
-
239
- self.ax.axvline(x=0, color="k", linewidth=1)
240
- self.ax.axhline(y=0, color="k", linewidth=1)
241
-
242
- self.ax.spines['left'].set_position('center')
243
- self.ax.spines['bottom'].set_position('center')
244
- self.ax.spines['right'].set_color('none')
245
- self.ax.spines['top'].set_color('none')
246
-
247
- xmin, xmax = self.ax.get_xlim()
248
- ymin, ymax = self.ax.get_ylim()
249
-
250
- self.ax.arrow(xmin, 0, xmax-xmin+7/PIXEL_SIZE, 0., fc='k', ec='k', lw=1,
251
- head_width=3/PIXEL_SIZE, head_length=5/PIXEL_SIZE,
252
- length_includes_head=True, clip_on=False)
253
-
254
- self.ax.arrow(0, ymin, 0., ymax-ymin+7/PIXEL_SIZE, fc='k', ec='k', lw=1,
255
- head_width=3/PIXEL_SIZE, head_length=5/PIXEL_SIZE, overhang=0.3,
256
- length_includes_head=True, clip_on=False)
257
-
258
- # Readout registers
259
-
260
- self.ax.plot([-ZEROPOINT[0] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE],
261
- [-ZEROPOINT[1] / PIXEL_SIZE, -ZEROPOINT[1] / PIXEL_SIZE],
262
- color="k", linewidth=3) # Upper left CCD
263
- self.ax.plot([ZEROPOINT[1] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE],
264
- [-ZEROPOINT[0] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE],
265
- color="k", linewidth=3) # Lower left CCD
266
- self.ax.plot([ZEROPOINT[0] / PIXEL_SIZE, -ZEROPOINT[1] / PIXEL_SIZE],
267
- [ZEROPOINT[1] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE],
268
- color="k", linewidth=3) # Lower right CCD
269
- self.ax.plot([-ZEROPOINT[1] / PIXEL_SIZE, -ZEROPOINT[1] / PIXEL_SIZE],
270
- [ZEROPOINT[0] / PIXEL_SIZE, -ZEROPOINT[1] / PIXEL_SIZE],
271
- color="k", linewidth=3) # Upper right CCD
272
-
273
- # CCD middle
274
-
275
- self.ax.plot([ZEROPOINT[0] / PIXEL_SIZE - NUM_COLUMNS / 2, ZEROPOINT[0] / PIXEL_SIZE - NUM_COLUMNS / 2],
276
- [-ZEROPOINT[0] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE],
277
- color="k", linewidth=1, linestyle="dotted") # Upper left CCD
278
- self.ax.plot([-ZEROPOINT[1] / PIXEL_SIZE, ZEROPOINT[0] / PIXEL_SIZE],
279
- [ZEROPOINT[0] / PIXEL_SIZE - NUM_COLUMNS / 2, ZEROPOINT[0] / PIXEL_SIZE - NUM_COLUMNS / 2],
280
- color="k", linewidth=1, linestyle="dotted") # Lower left CCD
281
- self.ax.plot([-ZEROPOINT[0] / PIXEL_SIZE + NUM_COLUMNS / 2, -ZEROPOINT[0] / PIXEL_SIZE + NUM_COLUMNS / 2],
282
- [-ZEROPOINT[1] / PIXEL_SIZE, ZEROPOINT[0] / PIXEL_SIZE],
283
- color="k", linewidth=1, linestyle="dotted") # Lower right CCD
284
- self.ax.plot([-ZEROPOINT[0] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE],
285
- [-ZEROPOINT[0] / PIXEL_SIZE + NUM_COLUMNS / 2, -ZEROPOINT[0] / PIXEL_SIZE + NUM_COLUMNS / 2],
286
- color="k", linewidth=1, linestyle="dotted") # Upper right CCD
287
-
288
- # CCD codes
289
-
290
- self.ax.text(-80 / PIXEL_SIZE, 70 / PIXEL_SIZE, self.ccd_id[2]) # Upper left CCD
291
- self.ax.text(-80 / PIXEL_SIZE, -75 / PIXEL_SIZE, self.ccd_id[3]) # Lower left CCD
292
- self.ax.text(60 / PIXEL_SIZE, -75 / PIXEL_SIZE, self.ccd_id[0]) # Lower right CCD
293
- self.ax.text(60 / PIXEL_SIZE, 70 / PIXEL_SIZE, self.ccd_id[1]) # Upper right CCD
294
-
295
- self.ax.text(-30 / PIXEL_SIZE, 10 / PIXEL_SIZE, self.fee_side.LEFT_SIDE.name, rotation=180) # Upper left CCD, left side
296
- self.ax.text(-75 / PIXEL_SIZE, 10 / PIXEL_SIZE, self.fee_side.RIGHT_SIDE.name, rotation=180) # Upper left CCD, right side
297
- self.ax.text(-20 / PIXEL_SIZE, -15 / PIXEL_SIZE, self.fee_side.LEFT_SIDE.name, rotation=-90) # Lower left CCD, left side
298
- self.ax.text(-20 / PIXEL_SIZE, -75 / PIXEL_SIZE, self.fee_side.RIGHT_SIDE.name, rotation=-90) # Lower left CCD, right side
299
- self.ax.text(10 / PIXEL_SIZE, -15 / PIXEL_SIZE, self.fee_side.LEFT_SIDE.name) # Lower right CCD, left side
300
- self.ax.text(50 / PIXEL_SIZE, -15 / PIXEL_SIZE, self.fee_side.RIGHT_SIDE.name) # Lower right CCD, right side
301
- self.ax.text(10 / PIXEL_SIZE, 10 / PIXEL_SIZE, self.fee_side.LEFT_SIDE.name, rotation=90) # Upper right CCD, left side
302
- self.ax.text(10 / PIXEL_SIZE, 50 / PIXEL_SIZE, self.fee_side.RIGHT_SIDE.name, rotation=90) # Upper right CCD, right side
303
-
304
- self.ax.plot([-ZEROPOINT[0] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE, -ZEROPOINT[0] / PIXEL_SIZE, -ZEROPOINT[0] / PIXEL_SIZE],
305
- [ZEROPOINT[0] / PIXEL_SIZE, ZEROPOINT[0] / PIXEL_SIZE, -ZEROPOINT[1] / PIXEL_SIZE, -ZEROPOINT[1] / PIXEL_SIZE, ZEROPOINT[0] / PIXEL_SIZE],
306
- color="k", linewidth=1) # Upper left CCD
307
- self.ax.plot([-ZEROPOINT[0] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE, -ZEROPOINT[0] / PIXEL_SIZE, -ZEROPOINT[0] / PIXEL_SIZE],
308
- [-ZEROPOINT[0] / PIXEL_SIZE, -ZEROPOINT[0] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE, -ZEROPOINT[0] / PIXEL_SIZE],
309
- color="k", linewidth=1) # Lower left CCD
310
- self.ax.plot([-ZEROPOINT[1] / PIXEL_SIZE, ZEROPOINT[0] / PIXEL_SIZE, ZEROPOINT[0] / PIXEL_SIZE, -ZEROPOINT[1] / PIXEL_SIZE, -ZEROPOINT[1] / PIXEL_SIZE],
311
- [-ZEROPOINT[0] / PIXEL_SIZE, -ZEROPOINT[0] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE, ZEROPOINT[1] / PIXEL_SIZE, -ZEROPOINT[0] / PIXEL_SIZE],
312
- color="k", linewidth=1) # Lower right CCD
313
- self.ax.plot([-ZEROPOINT[1] / PIXEL_SIZE, ZEROPOINT[0] / PIXEL_SIZE, ZEROPOINT[0] / PIXEL_SIZE, -ZEROPOINT[1] / PIXEL_SIZE, -ZEROPOINT[1] / PIXEL_SIZE],
314
- [ZEROPOINT[0] / PIXEL_SIZE, ZEROPOINT[0] / PIXEL_SIZE, -ZEROPOINT[1] / PIXEL_SIZE, -ZEROPOINT[1] / PIXEL_SIZE, ZEROPOINT[0] / PIXEL_SIZE],
315
- color="k", linewidth=1) # Upper right CCD
316
-
317
- # Grid lines
318
-
319
- ticks = np.arange(-4000, 5000, 1000)
320
- ticks = np.delete(ticks, 4)
321
- self.ax.set_xticks(ticks)
322
- self.ax.set_yticks(ticks)
323
- self.ax.grid(color="lightgray", linewidth=0.5)
324
-
325
- def change_to_angle_coordinates(self):
326
-
327
- """
328
- Preparation of the plot to show the source position in angle coordinates:
329
-
330
- - clear the plot;
331
- - draw a blue circle, indicating the size of the field-of view;
332
- - configure the axes and grid lines;
333
- - draw the CCDs and their readout registers;
334
- - add the CCD codes.
335
-
336
- The draw() method should be called in the sub-classes.
337
- """
338
-
339
- self.coordinate_system = COORDINATE_SYSTEMS["Angles"]
340
-
341
- self.figure.delaxes(self.ax)
342
- self.ax = self.figure.add_subplot(111, projection="polar")
343
- self.ax.set_aspect(1)
344
-
345
- # Circle indicating the size of the FOV [mm]
346
-
347
- self.circle = plt.Circle(
348
- (0, 0), FOV_SETTINGS.RADIUS_DEGREES, color='b', fill=False, label="FOV", linewidth=1,
349
- transform=self.ax.transData._b)
350
- self.ax.add_artist(self.circle)
351
-
352
- # Range
353
- # If we do it like this, the circle will have the same size on screen when
354
- # switching between coordinate systems
355
-
356
- limit = degrees(atan(85 / FOV_SETTINGS.FOCAL_LENGTH))
357
-
358
- self.ax.set_rlim([0, limit])
359
-
360
- # CCD codes
361
-
362
- theta, phi = focal_plane_coordinates_to_angles(-30, 10)
363
- self.ax.text(radians(phi), theta, self.fee_side.LEFT_SIDE.name, rotation=180) # Upper left CCD, left side
364
- theta, phi = focal_plane_coordinates_to_angles(-75, 10)
365
- self.ax.text(radians(phi), theta, self.fee_side.RIGHT_SIDE.name, rotation=180) # Upper left CCD, right side
366
- theta, phi = focal_plane_coordinates_to_angles(-20, -15)
367
- self.ax.text(radians(phi), theta, self.fee_side.LEFT_SIDE.name, rotation=-90) # Lower left CCD, left side
368
- theta, phi = focal_plane_coordinates_to_angles(-20, -75)
369
- self.ax.text(radians(phi), theta, self.fee_side.RIGHT_SIDE.name, rotation=-90) # Lower left CCD, right side
370
- theta, phi = focal_plane_coordinates_to_angles(10, -15)
371
- self.ax.text(radians(phi), theta, self.fee_side.LEFT_SIDE.name) # Lower right CCD, left side
372
- theta, phi = focal_plane_coordinates_to_angles(50, -15)
373
- self.ax.text(radians(phi), theta, self.fee_side.RIGHT_SIDE.name) # Lower right CCD, right side
374
- theta, phi = focal_plane_coordinates_to_angles(10, 10)
375
- self.ax.text(radians(phi), theta, self.fee_side.LEFT_SIDE.name, rotation=90) # Upper right CCD, left side
376
- theta, phi = focal_plane_coordinates_to_angles(10, 50)
377
- self.ax.text(radians(phi), theta, self.fee_side.RIGHT_SIDE.name, rotation=90) # Upper right CCD, right side
378
-
379
- self.ax.text(radians(135), 22, self.ccd_id[2], ha="center") # Upper left CCD
380
- self.ax.text(radians(-135), 22, self.ccd_id[3], ha="center", va="top") # Lower left CCD
381
- self.ax.text(radians(-45), 22, self.ccd_id[0], ha="center", va="top") # Lower right CCD
382
- self.ax.text(radians(45), 22, self.ccd_id[1], ha="center") # Upper right CCD
383
-
384
- (theta1_ccd1, phi1_ccd1) = focal_plane_coordinates_to_angles(-ZEROPOINT[0], -ZEROPOINT[1])
385
- (theta2_ccd1, phi2_ccd1) = focal_plane_coordinates_to_angles(ZEROPOINT[1], -ZEROPOINT[1])
386
- (theta3_ccd1, phi3_ccd1) = focal_plane_coordinates_to_angles(ZEROPOINT[1], ZEROPOINT[0])
387
- (theta4_ccd1, phi4_ccd1) = focal_plane_coordinates_to_angles(-ZEROPOINT[0], ZEROPOINT[0])
388
-
389
- phi1_ccd1 = radians(phi1_ccd1)
390
- phi2_ccd1 = radians(phi2_ccd1)
391
- phi3_ccd1 = radians(phi3_ccd1)
392
- phi4_ccd1 = radians(phi4_ccd1)
393
-
394
- self.ax.plot([phi1_ccd1, phi2_ccd1], [theta1_ccd1, theta2_ccd1], color="k", linewidth=3)
395
- self.ax.plot([phi1_ccd1, phi2_ccd1, phi3_ccd1, phi4_ccd1, phi1_ccd1],
396
- [theta1_ccd1, theta2_ccd1, theta3_ccd1, theta4_ccd1, theta1_ccd1], color="k", linewidth=1)
397
-
398
- (theta1_ccd2, phi1_ccd2) = focal_plane_coordinates_to_angles(ZEROPOINT[1], -ZEROPOINT[0])
399
- (theta2_ccd2, phi2_ccd2) = focal_plane_coordinates_to_angles(ZEROPOINT[1], ZEROPOINT[1])
400
- (theta3_ccd2, phi3_ccd2) = focal_plane_coordinates_to_angles(-ZEROPOINT[0], ZEROPOINT[1])
401
- (theta4_ccd2, phi4_ccd2) = focal_plane_coordinates_to_angles(-ZEROPOINT[0], -ZEROPOINT[0])
402
-
403
- phi1_ccd2 = radians(phi1_ccd2)
404
- phi2_ccd2 = radians(phi2_ccd2)
405
- phi3_ccd2 = radians(phi3_ccd2)
406
- phi4_ccd2 = radians(phi4_ccd2)
407
-
408
- self.ax.plot([phi1_ccd2, phi2_ccd2], [theta1_ccd2, theta2_ccd2], color="k", linewidth=3)
409
- self.ax.plot([phi1_ccd2, phi2_ccd2, phi3_ccd2, phi4_ccd2, phi1_ccd2],
410
- [theta1_ccd2, theta2_ccd2, theta3_ccd2, theta4_ccd2, theta1_ccd2], color="k", linewidth=1)
411
-
412
- (theta1_ccd3, phi1_ccd3) = focal_plane_coordinates_to_angles(ZEROPOINT[0], ZEROPOINT[1])
413
- (theta2_ccd3, phi2_ccd3) = focal_plane_coordinates_to_angles(-ZEROPOINT[1], ZEROPOINT[1])
414
- (theta3_ccd3, phi3_ccd3) = focal_plane_coordinates_to_angles(-ZEROPOINT[1], -ZEROPOINT[0])
415
- (theta4_ccd3, phi4_ccd3) = focal_plane_coordinates_to_angles(ZEROPOINT[0], -ZEROPOINT[0])
416
-
417
- phi1_ccd3 = radians(phi1_ccd3)
418
- phi2_ccd3 = radians(phi2_ccd3)
419
- phi3_ccd3 = radians(phi3_ccd3)
420
- phi4_ccd3 = radians(phi4_ccd3)
421
-
422
- self.ax.plot([phi1_ccd3, phi2_ccd3], [theta1_ccd3, theta2_ccd3], color="k", linewidth=3)
423
- self.ax.plot([phi1_ccd3, phi2_ccd3, phi3_ccd3, phi4_ccd3, phi1_ccd3],
424
- [theta1_ccd3, theta2_ccd3, theta3_ccd3, theta4_ccd3, theta1_ccd3], color="k", linewidth=1)
425
-
426
- (theta1_ccd4, phi1_ccd4) = focal_plane_coordinates_to_angles(-ZEROPOINT[1], ZEROPOINT[0])
427
- (theta2_ccd4, phi2_ccd4) = focal_plane_coordinates_to_angles(-ZEROPOINT[1], -ZEROPOINT[1])
428
- (theta3_ccd4, phi3_ccd4) = focal_plane_coordinates_to_angles(ZEROPOINT[0], -ZEROPOINT[1])
429
- (theta4_ccd4, phi4_ccd4) = focal_plane_coordinates_to_angles(ZEROPOINT[0], ZEROPOINT[0])
430
-
431
- phi1_ccd4 = radians(phi1_ccd4)
432
- phi2_ccd4 = radians(phi2_ccd4)
433
- phi3_ccd4 = radians(phi3_ccd4)
434
- phi4_ccd4 = radians(phi4_ccd4)
435
-
436
- self.ax.plot([phi1_ccd4, phi2_ccd4], [theta1_ccd4, theta2_ccd4], color="k", linewidth=3)
437
- self.ax.plot([phi1_ccd4, phi2_ccd4, phi3_ccd4, phi4_ccd4, phi1_ccd4],
438
- [theta1_ccd4, theta2_ccd4, theta3_ccd4, theta4_ccd4, theta1_ccd4], color="k", linewidth=1)
439
-
440
- # CCD middle
441
-
442
- (theta1, phi1) = focal_plane_coordinates_to_angles((ZEROPOINT[1] - ZEROPOINT[0]) / 2, -ZEROPOINT[1])
443
- (theta2, phi2) = focal_plane_coordinates_to_angles((ZEROPOINT[1] - ZEROPOINT[0]) / 2, ZEROPOINT[0])
444
- phi1 = radians(phi1)
445
- phi2 = radians(phi2)
446
- self.ax.plot([phi1, phi2], [theta1, theta2], color="k", linewidth=1, linestyle="dotted") # Upper left CCD
447
-
448
- (theta1, phi1) = focal_plane_coordinates_to_angles(ZEROPOINT[0], -(ZEROPOINT[1] - ZEROPOINT[0]) / 2)
449
- (theta2, phi2) = focal_plane_coordinates_to_angles(-ZEROPOINT[1], -(ZEROPOINT[1] - ZEROPOINT[0]) / 2)
450
- phi1 = radians(phi1)
451
- phi2 = radians(phi2)
452
- self.ax.plot([phi1, phi2], [theta1, theta2], color="k", linewidth=1, linestyle="dotted") # Lower left CCD
453
-
454
- (theta1, phi1) = focal_plane_coordinates_to_angles(-(ZEROPOINT[1] - ZEROPOINT[0]) / 2, ZEROPOINT[1])
455
- (theta2, phi2) = focal_plane_coordinates_to_angles(-(ZEROPOINT[1] - ZEROPOINT[0]) / 2, -ZEROPOINT[0])
456
- phi1 = radians(phi1)
457
- phi2 = radians(phi2)
458
- self.ax.plot([phi1, phi2], [theta1, theta2], color="k", linewidth=1, linestyle="dotted") # Lower right CCD
459
-
460
- (theta1, phi1) = focal_plane_coordinates_to_angles(-ZEROPOINT[0], (ZEROPOINT[1] - ZEROPOINT[0]) / 2)
461
- (theta2, phi2) = focal_plane_coordinates_to_angles(ZEROPOINT[1], (ZEROPOINT[1] - ZEROPOINT[0]) / 2)
462
- phi1 = radians(phi1)
463
- phi2 = radians(phi2)
464
- self.ax.plot([phi1, phi2], [theta1, theta2], color="k", linewidth=1, linestyle="dotted") # Uoper right CCD
465
-
466
- # Grid lines
467
-
468
- tick = [self.ax.get_rmax(), self.ax.get_rmax() * 0.]
469
- for t in np.deg2rad(np.arange(0, 360, 15)):
470
- self.ax.plot([t, t], tick, lw=0.72, color="lightgray")
471
-
472
- tick = [self.ax.get_rmax(), self.ax.get_rmax() * 0.]
473
- for t in np.deg2rad(np.arange(0, 360, 45)):
474
- self.ax.plot([t, t], tick, lw=0.72, color="k")
475
-
476
- ticks = np.arange(2, 20, 2)
477
- self.ax.set_rticks(ticks)
478
-
479
- self.ax.yaxis.set_major_formatter(
480
- ticker.FuncFormatter(degree_formatter))
481
-
482
-
483
- class FocalPlaneWithSubField(FocalPlane):
484
-
485
- """
486
- FigureCanvas showing the focal plane, with a blue circle indicating the field-of-view.
487
- The available coordinate systems are:
488
- - pixel coordinates [pixels],
489
- - focal-plane coordinates [mm],
490
- - and field angles [degrees].
491
-
492
- Possibility to draw the position of the sub-field on the focal plane.
493
- """
494
-
495
- def __init__(self):
496
-
497
- """
498
- Initialisation of a plot of the focal plane, with a blue circle indicating the
499
- field-of-view.
500
- """
501
-
502
- super(FocalPlaneWithSubField, self).__init__()
503
-
504
- self.subfield_is_drawn = False
505
- self.ccd_code = None
506
- self.zeropoint_row = None
507
- self.zeropoint_column = None
508
- self.num_rows = None
509
- self.num_columns = None
510
-
511
- self.change_to_pixel_coordinates()
512
-
513
- def set_subfield(self, ccd_code=None, zeropoint_row=None, zeropoint_column=None, num_rows=None, num_columns=None):
514
-
515
- """
516
- First-time drawing of the sub-field (in pixel coordinates). All information is stored in
517
- variables and the sub-field is shown as a red rectangle on the focal plane.
518
-
519
- :param ccd_code: Code of the CCD on which the sub-field is located.
520
-
521
- :param zeropoint_row: Row coordinate of the origin of the sub-field in the CCD coordinate system
522
- of the given CCD [pixels].
523
-
524
- :param zeropoint_column: Column coordinate of the origin of the sub-field in the CCD coordinate system
525
- of the given CCD [pixels].
526
-
527
- :param num_rows: Number of rows in the sub-field [pixels].
528
-
529
- :param num_columns: Number of columns in the sub-field [pixels].
530
- """
531
-
532
- self.ccd_code = ccd_code
533
- self.zeropoint_row = zeropoint_row
534
- self.zeropoint_column = zeropoint_column
535
- self.num_rows = num_rows
536
- self.num_columns = num_columns
537
-
538
- if self.coordinate_system == COORDINATE_SYSTEMS["Focal plane"]:
539
- self.change_to_focal_plane_coordinates
540
- elif self.coordinate_system == COORDINATE_SYSTEMS["Pixels"]:
541
- self.change_to_pixel_coordinates()
542
- elif self.coordinate_system == COORDINATE_SYSTEMS["Angles"]:
543
- self.change_to_angle_coordinates()
544
-
545
- def change_to_pixel_coordinates(self):
546
-
547
- """
548
- Preparation of the plot to show the source position in pixel coordinates:
549
-
550
- - clear the plot;
551
- - draw a blue circle, indicating the size of the field-of view;
552
- - configure the axes and grid lines;
553
- - draw the CCDs and their readout registers;
554
- - add the CCD codes;
555
-
556
- and re-draw the sub-field (if any).
557
- """
558
-
559
- super().change_to_pixel_coordinates()
560
- self.subfield_is_drawn = False
561
-
562
- self.update_subfield()
563
-
564
- self.draw()
565
-
566
- def change_to_focal_plane_coordinates(self):
567
-
568
- """
569
- Preparation of the plot to show the source position in focal-plane coordinates:
570
-
571
- - clear the plot;
572
- - draw a blue circle, indicating the size of the field-of view;
573
- - configure the axes and grid lines;
574
- - draw the CCDs and their readout registers;
575
- - add the CCD codes;
576
-
577
- and re-draw the sub-field (if any).
578
- """
579
-
580
- super().change_to_focal_plane_coordinates()
581
- self.subfield_is_drawn = False
582
-
583
- self.update_subfield()
584
-
585
- self.draw()
586
-
587
- def change_to_angle_coordinates(self):
588
-
589
- """
590
- Preparation of the plot to show the source position in angle coordinates:
591
-
592
- - clear the plot;
593
- - draw a blue circle, indicating the size of the field-of view;
594
- - configure the axes and grid lines;
595
- - draw the CCDs and their readout registers;
596
- - add the CCD codes;
597
-
598
- and re-draw the sub-field (if any).
599
- """
600
-
601
- super().change_to_angle_coordinates()
602
- self.subfield_is_drawn = False
603
-
604
- self.update_subfield()
605
-
606
- self.draw()
607
-
608
- def update_subfield(self):
609
-
610
- # Remove the sub-field (if needed)
611
-
612
- if self.subfield_is_drawn:
613
-
614
- del self.ax.lines[-1]
615
- self.subfield_is_drawn = False
616
-
617
- if self.ccd_code is None:
618
- self.draw()
619
- return
620
-
621
- # Draw the sub-field
622
-
623
- (x_fp_1, y_fp_1) = ccd_to_focal_plane_coordinates(
624
- self.zeropoint_row, self.zeropoint_column, self.ccd_code)
625
- (x_fp_2, y_fp_2) = ccd_to_focal_plane_coordinates(
626
- self.zeropoint_row + self.num_rows, self.zeropoint_column, self.ccd_code)
627
- (x_fp_3, y_fp_3) = ccd_to_focal_plane_coordinates(
628
- self.zeropoint_row + self.num_rows, self.zeropoint_column + self.num_columns, self.ccd_code)
629
- (x_fp_4, y_fp_4) = ccd_to_focal_plane_coordinates(
630
- self.zeropoint_row, self.zeropoint_column + self.num_columns, self.ccd_code)
631
-
632
- if self.coordinate_system == COORDINATE_SYSTEMS["Focal plane"]:
633
-
634
- self.ax.plot([x_fp_1, x_fp_2], [y_fp_1, y_fp_2], "r-")
635
- self.ax.plot([x_fp_2, x_fp_3], [y_fp_2, y_fp_3], "r-")
636
- self.ax.plot([x_fp_3, x_fp_4], [y_fp_3, y_fp_4], "r-")
637
- self.ax.plot([x_fp_4, x_fp_1], [y_fp_4, y_fp_1], "r-")
638
-
639
- elif self.coordinate_system == COORDINATE_SYSTEMS["Pixels"]:
640
-
641
- self.ax.plot([x_fp_1 / PIXEL_SIZE, x_fp_2 / PIXEL_SIZE], [y_fp_1 / PIXEL_SIZE, y_fp_2 / PIXEL_SIZE], "r-")
642
- self.ax.plot([x_fp_2 / PIXEL_SIZE, x_fp_3 / PIXEL_SIZE], [y_fp_2 / PIXEL_SIZE, y_fp_3 / PIXEL_SIZE], "r-")
643
- self.ax.plot([x_fp_3 / PIXEL_SIZE, x_fp_4 / PIXEL_SIZE], [y_fp_3 / PIXEL_SIZE, y_fp_4 / PIXEL_SIZE], "r-")
644
- self.ax.plot([x_fp_4 / PIXEL_SIZE, x_fp_1 / PIXEL_SIZE], [y_fp_4 / PIXEL_SIZE, y_fp_1 / PIXEL_SIZE], "r-")
645
-
646
- elif self.coordinate_system == COORDINATE_SYSTEMS["Angles"]:
647
-
648
- (theta1, phi1) = focal_plane_coordinates_to_angles(x_fp_1, y_fp_1)
649
- (theta2, phi2) = focal_plane_coordinates_to_angles(x_fp_2, y_fp_2)
650
- (theta3, phi3) = focal_plane_coordinates_to_angles(x_fp_3, y_fp_3)
651
- (theta4, phi4) = focal_plane_coordinates_to_angles(x_fp_4, y_fp_4)
652
-
653
- phi1 = radians(phi1)
654
- phi2 = radians(phi2)
655
- phi3 = radians(phi3)
656
- phi4 = radians(phi4)
657
-
658
- self.ax.plot([phi1, phi2], [theta1, theta2], "r-")
659
- self.ax.plot([phi2, phi3], [theta2, theta3], "r-")
660
- self.ax.plot([phi3, phi4], [theta3, theta4], "r-")
661
- self.ax.plot([phi4, phi1], [theta4, theta1], "r-")
662
-
663
- self.subfield_is_drawn = True
664
-
665
- self.draw()
666
-
667
-
668
- class FocalPlaneWithSourcePosition(FocalPlane):
669
-
670
- """
671
- FigureCanvas showing the focal plane, with a blue circle indicating the field-of-view.
672
- The available coordinate systems are:
673
- - pixel coordinates [pixels],
674
- - focal-plane coordinates [mm],
675
- - and field angles [degrees].
676
-
677
- Possibility to draw the source position on the focal plane.
678
- """
679
-
680
- def __init__(self):
681
-
682
- """
683
- Initialisation of a plot of the focal plane, with a blue circle indicating the
684
- field-of-view.
685
- """
686
-
687
- super(FocalPlaneWithSourcePosition, self).__init__()
688
-
689
- self.source_position_is_drawn = False
690
- self.x_fp = None
691
- self.y_fp = None
692
-
693
- self.change_to_pixel_coordinates()
694
-
695
- def change_to_pixel_coordinates(self):
696
-
697
- """
698
- Preparation of the plot to show the source position in pixel coordinates:
699
-
700
- - clear the plot;
701
- - draw a blue circle, indicating the size of the field-of view;
702
- - configure the axes and grid lines;
703
- - draw the CCDs and their readout registers;
704
- - add the CCD codes;
705
-
706
- and re-draw the source position (if any).
707
- """
708
-
709
- super().change_to_pixel_coordinates()
710
- self.source_position_is_drawn = False
711
-
712
- self.update_source_position(self.x_fp, self.y_fp)
713
-
714
- self.draw()
715
-
716
- def change_to_focal_plane_coordinates(self):
717
-
718
- """
719
- Preparation of the plot to show the source position in focal-plane coordinates:
720
-
721
- - clear the plot;
722
- - draw a blue circle, indicating the size of the field-of view;
723
- - configure the axes and grid lines;
724
- - draw the CCDs and their readout registers;
725
- - add the CCD codes;
726
-
727
- and re-draw the source position (if any).
728
- """
729
-
730
- super().change_to_focal_plane_coordinates()
731
- self.source_position_is_drawn = False
732
-
733
- self.update_source_position(self.x_fp, self.y_fp)
734
-
735
- self.draw()
736
-
737
- def change_to_angle_coordinates(self):
738
-
739
- """
740
- Preparation of the plot to show the source position in angle coordinates:
741
-
742
- - clear the plot;
743
- - draw a blue circle, indicating the size of the field-of view;
744
- - configure the axes and grid lines;
745
- - draw the CCDs and their readout registers;
746
- - add the CCD codes;
747
-
748
- and re-draw the source position (if any).
749
- """
750
-
751
- super().change_to_angle_coordinates()
752
- self.source_position_is_drawn = False
753
-
754
- self.update_source_position(self.x_fp, self.y_fp)
755
-
756
- self.draw()
757
-
758
- def update_source_position(self, x_fp, y_fp):
759
-
760
- """
761
- Add a red dot at the position with the given focal-plane coordinates. In case
762
- a source position had been marked before, that red dot must be removed first.
763
-
764
- :param x_fp: Focal-plane x-coordinate of the new source position [mm].
765
-
766
- :param y_fp: Focal-plane y-coordinate of the new source position [mm].
767
- """
768
-
769
- # Remove the previously visited location (if needed)
770
-
771
- if self.source_position_is_drawn:
772
-
773
- del self.ax.lines[-1]
774
- self.source_position_is_drawn = False
775
-
776
- if (x_fp is None) or (y_fp is None):
777
- return
778
-
779
- # Outside the FOV
780
-
781
- if abs(x_fp) > FOV_SETTINGS.RADIUS_MM and abs(y_fp) > FOV_SETTINGS.RADIUS_MM:
782
-
783
- self.ax.plot([0], [0], color="white")
784
-
785
- # Put a red dot at the new source position
786
-
787
- if self.coordinate_system == COORDINATE_SYSTEMS["Focal plane"]:
788
-
789
- self.ax.plot([x_fp], [y_fp], "ro")
790
-
791
- elif self.coordinate_system == COORDINATE_SYSTEMS["Pixels"]:
792
-
793
- self.ax.plot([x_fp / PIXEL_SIZE], [y_fp / PIXEL_SIZE], "ro")
794
-
795
- elif self.coordinate_system == COORDINATE_SYSTEMS["Angles"]:
796
-
797
- (theta, phi) = focal_plane_coordinates_to_angles(x_fp, y_fp)
798
-
799
- self.ax.plot([radians(phi)], [theta], "ro")
800
-
801
- self.source_position_is_drawn = True
802
- self.x_fp = x_fp
803
- self.y_fp = y_fp
804
-
805
- self.draw()
806
-
807
-
808
- class FocalPlaneWithVisitedPositions(FocalPlane):
809
-
810
- """
811
- FigureCanvas showing the focal plane, with a blue circle indicating the field-of-view.
812
- The available coordinate systems are:
813
- - pixel coordinates [pixels],
814
- - focal-plane coordinates [mm],
815
- - and field angles [degrees].
816
-
817
- Possibility to draw the visited positions of the sub-field on the focal plane.
818
- """
819
-
820
- def __init__(self):
821
-
822
- """
823
- Initialisation of a plot of the focal plane, with a blue circle indicating the
824
- field-of-view.
825
- """
826
-
827
- super(FocalPlaneWithVisitedPositions, self).__init__()
828
-
829
- self.visited_x_fp = np.array([])
830
- self.visited_y_fp = np.array([])
831
-
832
- self.change_to_pixel_coordinates()
833
-
834
- def change_to_pixel_coordinates(self):
835
-
836
- """
837
- Preparation of the plot to show the source position in pixel coordinates:
838
-
839
- - clear the plot;
840
- - draw a blue circle, indicating the size of the field-of view;
841
- - configure the axes and grid lines;
842
- - draw the CCDs and their readout registers;
843
- - add the CCD codes;
844
-
845
- and re-draw the visited positions (if any).
846
- """
847
-
848
- super().change_to_pixel_coordinates()
849
-
850
- # Re-draw the visited positions in the new coordinate system
851
-
852
- self.redraw_visited_positions()
853
-
854
- self.draw()
855
-
856
- def change_to_focal_plane_coordinates(self):
857
-
858
- """
859
- Preparation of the plot to show the source position in focal-plane coordinates:
860
-
861
- - clear the plot;
862
- - draw a blue circle, indicating the size of the field-of view;
863
- - configure the axes and grid lines;
864
- - draw the CCDs and their readout registers;
865
- - add the CCD codes;
866
-
867
- and re-draw the visited postiions (if any).
868
- """
869
-
870
- super().change_to_focal_plane_coordinates()
871
-
872
- # Re-draw the visited positions in the new coordinate system
873
-
874
- self.redraw_visited_positions()
875
-
876
- self.draw()
877
-
878
- def change_to_angle_coordinates(self):
879
-
880
- """
881
- Preparation of the plot to show the source position in angle coordinates:
882
-
883
- - clear the plot;
884
- - draw a blue circle, indicating the size of the field-of view;
885
- - configure the axes and grid lines;
886
- - draw the CCDs and their readout registers;
887
- - add the CCD codes;
888
-
889
- and re-draw the visited positions (if any).
890
- """
891
-
892
- super().change_to_angle_coordinates()
893
-
894
- # Re-draw the visited positions in the new coordinate system
895
-
896
- self.redraw_visited_positions()
897
-
898
- self.draw()
899
-
900
- def visit_position(self, x_fp, y_fp, redraw=False):
901
-
902
- """
903
- Add a red dot at the position with the given focal-plane coordinates. If you are not
904
- in re-drawing mode, keep track of this new position in the list of visited positions.
905
-
906
- :param x: Focal-plane x-coordinate of the new visited position [mm].
907
-
908
- :param y: Focal-plane y-coordinate of the new visited position [mm].
909
-
910
- :param redraw: If False, the given position should not be added to the list of visited
911
- positions (as it is already in there); otherwise, the list of visited
912
- positions must be expanded with the given position.
913
- """
914
-
915
- if len(self.visited_x_fp) > 0:
916
-
917
- self.ax.lines[-1].set_color("blue")
918
-
919
- # Outside the FOV
920
-
921
- if abs(x_fp) > FOV_SETTINGS.RADIUS_MM and abs(y_fp) > FOV_SETTINGS.RADIUS_MM:
922
-
923
- self.ax.plot([0], [0], color="white")
924
-
925
- # Put a red dot at the new source position
926
-
927
- if self.coordinate_system == COORDINATE_SYSTEMS["Focal plane"]:
928
-
929
- self.ax.plot([x_fp], [y_fp], "ro")
930
-
931
- elif self.coordinate_system == COORDINATE_SYSTEMS["Pixels"]:
932
-
933
- self.ax.plot([x_fp / PIXEL_SIZE], [y_fp / PIXEL_SIZE], "ro")
934
-
935
- elif self.coordinate_system == COORDINATE_SYSTEMS["Angles"]:
936
-
937
- (theta, phi) = focal_plane_coordinates_to_angles(x_fp, y_fp)
938
-
939
- self.ax.plot([radians(phi)], [theta], "ro")
940
-
941
- if not redraw:
942
-
943
- self.visited_x_fp = np.append(self.visited_x_fp, x_fp)
944
- self.visited_y_fp = np.append(self.visited_y_fp, y_fp)
945
-
946
- self.draw()
947
-
948
- def redraw_visited_positions(self):
949
-
950
- """
951
- Re-draw the visited positions in the current coordinate system.
952
- """
953
-
954
- for (x_fp, y_fp) in zip(self.visited_x_fp, self.visited_y_fp):
955
- self.visit_position(x_fp, y_fp, redraw=True)
956
-
957
- def clear_visited_positions(self):
958
- """ Clear all visited positions."""
959
-
960
- num_points = len(self.visited_x_fp)
961
- while num_points > 0:
962
- del self.ax.lines[-1]
963
- num_points -= 1
964
-
965
- self.visited_x_fp = np.array([])
966
- self.visited_y_fp = np.array([])
967
-
968
- self.draw()
969
- ############################################
970
- # Focal plane + combobox (coordinate system)
971
- ############################################
972
-
973
-
974
- class FocalPlaneWidget(QGroupBox):
975
-
976
- """
977
- Widget with a FigureCanvas (plot window) showing the focal plane, with a blue circle
978
- indicating the field-of-view. Below the plot window, you can find a combobox to choose
979
- the coordinate system to use in the plot. The available coordinate systems are:
980
- - pixel coordinates [pixels],
981
- - focal-plane coordinates [mm],
982
- - and field angles [degrees].
983
- """
984
-
985
- def __init__(self):
986
-
987
- """
988
- Initialisation of a plot of the focal plane, with a blue circle indicating the
989
- field-of-view. Below the plot you can find a spinner to choose the coordinate
990
- system to be used in the plot.
991
- """
992
-
993
- super(FocalPlaneWidget, self).__init__("Focal Plane")
994
-
995
- self.setFont(FONT)
996
-
997
- layout = QGridLayout()
998
-
999
- # Focal plane
1000
-
1001
- self.focal_plane = self.get_focal_plane()
1002
-
1003
- # Combobox (coordinate system)
1004
-
1005
- coordinate_system_combobox = QComboBox(self)
1006
- coordinate_system_combobox.setFont(FONT)
1007
- coordinate_system_combobox.addItem(COORDINATE_SYSTEMS["Pixels"])
1008
- coordinate_system_combobox.addItem(COORDINATE_SYSTEMS["Angles"])
1009
- coordinate_system_combobox.addItem(COORDINATE_SYSTEMS["Focal plane"])
1010
- coordinate_system_combobox.currentTextChanged.connect(self.update_coordinate_system)
1011
-
1012
- coordinate_label = QLabel("Coordinate system")
1013
- coordinate_label.setFont(FONT)
1014
- coordinate_label.setStatusTip("Coordinate system to use in the plot")
1015
-
1016
- # Putting everything together
1017
-
1018
- layout.addWidget(self.focal_plane)
1019
- layout.addWidget(coordinate_label)
1020
- layout.addWidget(coordinate_system_combobox)
1021
-
1022
- self.setLayout(layout)
1023
-
1024
- def update_coordinate_system(self, value):
1025
-
1026
- """
1027
- Switch to the given coordinate system to use in the plot. Currently implemented are
1028
- focal-plane coordinates, pixel coordinates, and field angles. This means that the plot
1029
- needs to be cleared and re-built in the specified coordinate system.
1030
-
1031
- :param value: Name of the coordinate system to switch to.
1032
- """
1033
-
1034
- # Focal-plane coordinates
1035
-
1036
- if value == COORDINATE_SYSTEMS["Focal plane"]:
1037
-
1038
- self.focal_plane.change_to_focal_plane_coordinates()
1039
-
1040
- # Field angles
1041
-
1042
- elif value == COORDINATE_SYSTEMS["Angles"]:
1043
-
1044
- self.focal_plane.change_to_angle_coordinates()
1045
-
1046
- # Pixel coordinates
1047
-
1048
- elif value == COORDINATE_SYSTEMS["Pixels"]:
1049
-
1050
- self.focal_plane.change_to_pixel_coordinates()
1051
-
1052
- def get_focal_plane(self):
1053
-
1054
- """
1055
- Returns the widget with the focal plane only (so without the combobox to
1056
- choose the coordinate system).
1057
-
1058
- :return: Widget with the focal plane only (so without the combobox to
1059
- choose the coordinate system).
1060
- """
1061
-
1062
- return None
1063
-
1064
- def change_to_focal_plane_coordinates(self):
1065
-
1066
- """
1067
- Preparation of the plot to show the source position in focal-plane coordinates:
1068
-
1069
- - clear the plot;
1070
- - draw a blue circle, indicating the size of the field-of view;
1071
- - configure the axes and grid lines;
1072
- - draw the CCDs and their readout registers;
1073
- - add the CCD codes.
1074
- """
1075
-
1076
- self.focal_plane.change_to_focal_plane_coordinates()
1077
-
1078
- def change_to_pixel_coordinates(self):
1079
-
1080
- """
1081
- Preparation of the plot to show the source position in pixel coordinates:
1082
-
1083
- - clear the plot;
1084
- - draw a blue circle, indicating the size of the field-of view;
1085
- - configure the axes and grid lines;
1086
- - draw the CCDs and their readout registers;
1087
- - add the CCD codes.
1088
- """
1089
-
1090
- self.focal_plane.change_to_pixel_coordinates()
1091
-
1092
- def change_to_angle_coordinates(self):
1093
-
1094
- """
1095
- Preparation of the plot to show the source position in angle coordinates:
1096
-
1097
- - clear the plot;
1098
- - draw a blue circle, indicating the size of the field-of view;
1099
- - configure the axes and grid lines;
1100
- - draw the CCDs and their readout registers;
1101
- - add the CCD codes.
1102
- """
1103
-
1104
- self.focal_plane.change_to_angle_coordinates()
1105
-
1106
- def get_widget(self):
1107
-
1108
- """
1109
- Returns the widget itself.
1110
-
1111
- :return: Widget itself.
1112
- """
1113
-
1114
- return self
1115
-
1116
-
1117
- class FocalPlaneWidgetWithSubField(FocalPlaneWidget):
1118
-
1119
- """
1120
- Widget with a FigureCanvas (plot window) showing the focal plane, with a blue circle
1121
- indicating the field-of-view. Below the plot window, you can find a combobox to choose
1122
- the coordinate system to use in the plot. The available coordinate systems are:
1123
- - pixel coordinates [pixels],
1124
- - focal-plane coordinates [mm],
1125
- - and field angles [degrees].
1126
-
1127
- Possibility to draw the position of the sub-field on the focal plane.
1128
- """
1129
-
1130
- def __init__(self, ccd_code=None, zeropoint_row=None, zeropoint_column=None, num_rows=None, num_columns=None):
1131
-
1132
- """
1133
- Initialisation of a plot of the focal plane, with a blue circle indicating the
1134
- field-of-view. Below the plot you can find a spinner to choose the coordinate
1135
- system to be used in the plot.
1136
-
1137
- In the plot window, the position of tbe sub-field will be plotted.
1138
-
1139
- :param ccd_code: Code of the CCD on which the sub-field is located.
1140
-
1141
- :param zeropoint_row: Row coordinate of the origin of the sub-field in the CCD coordinate system
1142
- of the given CCD [pixels].
1143
-
1144
- :param zeropoint_column: Column coordinate of the origin of the sub-field in the CCD coordinate system
1145
- of the given CCD [pixels].
1146
-
1147
- :param num_rows: Number of rows in the sub-field [pixels].
1148
-
1149
- :param num_columns: Number of columns in the sub-field [pixels].
1150
- """
1151
-
1152
- super(FocalPlaneWidgetWithSubField, self).__init__()
1153
-
1154
- self.setStatusTip(
1155
- "Position of the sub-field on the focal plane, based on the FITS header")
1156
-
1157
- self.focal_plane.set_subfield(ccd_code=ccd_code, zeropoint_row=zeropoint_row,
1158
- zeropoint_column=zeropoint_column, num_rows=num_rows, num_columns=num_columns)
1159
-
1160
-
1161
- def get_focal_plane(self):
1162
-
1163
- """
1164
- Returns the widget with the focal plane only (so without the combobox to
1165
- choose the coordinate system).
1166
-
1167
- :return: Widget with the focal plane only (so without the combobox to
1168
- choose the coordinate system).
1169
- """
1170
-
1171
- return FocalPlaneWithSubField()
1172
-
1173
-
1174
- class FocalPlaneWidgetWithSourcePosition(FocalPlaneWidget):
1175
-
1176
- """
1177
- Widget with a FigureCanvas (plot window) showing the focal plane, with a blue circle
1178
- indicating the field-of-view. Below the plot window, you can find a combobox to choose
1179
- the coordinate system to use in the plot. The available coordinate systems are:
1180
- - pixel coordinates [pixels],
1181
- - focal-plane coordinates [mm],
1182
- - and field angles [degrees].
1183
-
1184
- Possibility to draw the source position on the focal plane.
1185
- """
1186
-
1187
- def __init__(self):
1188
-
1189
- """
1190
- Initialisation of a plot of the focal plane, with a blue circle indicating the
1191
- field-of-view. Below the plot you can find a spinner to choose the coordinate
1192
- system to be used in the plot.
1193
-
1194
- In the plot window, the position of tbe sub-field will be plotted.
1195
- """
1196
-
1197
- super(FocalPlaneWidgetWithSourcePosition, self).__init__()
1198
-
1199
- self.setStatusTip(
1200
- "Position of the source on the focal plane, based on the position of the mechanisms")
1201
-
1202
- def update_source_position(self, x_fp, y_fp):
1203
-
1204
- """
1205
- Add a red dot at the position with the given focal-plane coordinates. In case
1206
- a source position had been marked before, that red dot must be removed first.
1207
-
1208
- :param x_fp: Focal-plane x-coordinate of the new source position [mm].
1209
-
1210
- :param y_fp: Focal-plane y-coordinate of the new source position [mm].
1211
- """
1212
-
1213
- self.focal_plane.update_source_position(x_fp, y_fp)
1214
-
1215
- def get_focal_plane(self):
1216
- """
1217
- Returns the widget with the focal plane only (so without the combobox to
1218
- choose the coordinate system).
1219
-
1220
- :return: Widget with the focal plane only (so without the combobox to
1221
- choose the coordinate system).
1222
- """
1223
-
1224
- return FocalPlaneWithSourcePosition()
1225
-
1226
-
1227
- class FocalPlaneWidgetWithVisitedPositions(FocalPlaneWidget):
1228
-
1229
- """
1230
- Widget with a FigureCanvas (plot window) showing the focal plane, with a blue circle
1231
- indicating the field-of-view. Below the plot window, you can find a combobox to choose
1232
- the coordinate system to use in the plot. The available coordinate systems are:
1233
- - pixel coordinates [pixels],
1234
- - focal-plane coordinates [mm],
1235
- - and field angles [degrees].
1236
-
1237
- Possibility to draw the visited positions on the focal plane.
1238
- """
1239
-
1240
- def __init__(self):
1241
-
1242
- """
1243
- Initialisation of a plot of the focal plane, with a blue circle indicating the
1244
- field-of-view. Below the plot you can find a spinner to choose the coordinate
1245
- system to be used in the plot.
1246
-
1247
- In the plot window, the visited positions will be plotted.
1248
- """
1249
-
1250
- super(FocalPlaneWidgetWithVisitedPositions, self).__init__()
1251
-
1252
- self.setToolTip("Visited positions")
1253
-
1254
- def visit_position(self, x_fp, y_fp):
1255
-
1256
- """
1257
- Add a red dot at the position with the given focal-plane coordinates.
1258
-
1259
- :param x: Focal-plane x-coordinate of the new visited position [mm].
1260
-
1261
- :param y: Focal-plane y-coordinate of the new visited position [mm].
1262
- """
1263
-
1264
- self.focal_plane.visit_position(x_fp, y_fp)
1265
-
1266
- def get_focal_plane(self):
1267
-
1268
- """
1269
- Returns the widget with the focal plane only (so without the combobox to
1270
- choose the coordinate system).
1271
-
1272
- :return: Widget with the focal plane only (so without the combobox to
1273
- choose the coordinate system).
1274
- """
1275
-
1276
- return FocalPlaneWithVisitedPositions()
1277
-
1278
- def clear_visited_positions(self):
1279
- """ Clear all visited positions."""
1280
-
1281
- self.focal_plane.clear_visited_positions()