cgse 2024.7.0__py3-none-any.whl → 2025.0.2__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- README.md +27 -0
- bump.py +85 -0
- cgse-2025.0.2.dist-info/METADATA +38 -0
- cgse-2025.0.2.dist-info/RECORD +5 -0
- {cgse-2024.7.0.dist-info → cgse-2025.0.2.dist-info}/WHEEL +1 -2
- cgse-2024.7.0.dist-info/COPYING +0 -674
- cgse-2024.7.0.dist-info/COPYING.LESSER +0 -165
- cgse-2024.7.0.dist-info/METADATA +0 -144
- cgse-2024.7.0.dist-info/RECORD +0 -660
- cgse-2024.7.0.dist-info/entry_points.txt +0 -75
- cgse-2024.7.0.dist-info/top_level.txt +0 -2
- egse/__init__.py +0 -12
- egse/__main__.py +0 -32
- egse/aeu/aeu.py +0 -5238
- egse/aeu/aeu_awg.yaml +0 -265
- egse/aeu/aeu_crio.yaml +0 -273
- egse/aeu/aeu_cs.py +0 -627
- egse/aeu/aeu_devif.py +0 -321
- egse/aeu/aeu_main_ui.py +0 -903
- egse/aeu/aeu_metrics.py +0 -131
- egse/aeu/aeu_protocol.py +0 -463
- egse/aeu/aeu_psu.yaml +0 -204
- egse/aeu/aeu_ui.py +0 -873
- egse/aeu/arbdata/FccdRead.arb +0 -2
- egse/aeu/arbdata/FccdRead_min_points.arb +0 -2
- egse/aeu/arbdata/HeaterSync_FccdRead.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead25.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead31_25.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead37_50.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead43_75.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead50.arb +0 -2
- egse/aeu/arbdata/Heater_FccdRead_min_points.arb +0 -2
- egse/aeu/arbdata/ccdRead25.arb +0 -2
- egse/aeu/arbdata/ccdRead25_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead31_25.arb +0 -2
- egse/aeu/arbdata/ccdRead31_25_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead37_50.arb +0 -2
- egse/aeu/arbdata/ccdRead37_50_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead43_75.arb +0 -2
- egse/aeu/arbdata/ccdRead43_75_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead50.arb +0 -2
- egse/aeu/arbdata/ccdRead50_150ms.arb +0 -2
- egse/alert/__init__.py +0 -1049
- egse/alert/alertman.yaml +0 -37
- egse/alert/alertman_cs.py +0 -233
- egse/alert/alertman_ui.py +0 -600
- egse/alert/gsm/beaglebone.py +0 -138
- egse/alert/gsm/beaglebone.yaml +0 -51
- egse/alert/gsm/beaglebone_cs.py +0 -108
- egse/alert/gsm/beaglebone_devif.py +0 -122
- egse/alert/gsm/beaglebone_protocol.py +0 -46
- egse/bits.py +0 -318
- egse/camera.py +0 -44
- egse/collimator/__init__.py +0 -0
- egse/collimator/fcul/__init__.py +0 -0
- egse/collimator/fcul/ogse.py +0 -1077
- egse/collimator/fcul/ogse.yaml +0 -14
- egse/collimator/fcul/ogse_cs.py +0 -154
- egse/collimator/fcul/ogse_devif.py +0 -358
- egse/collimator/fcul/ogse_protocol.py +0 -132
- egse/collimator/fcul/ogse_sim.py +0 -431
- egse/collimator/fcul/ogse_ui.py +0 -1108
- egse/command.py +0 -699
- egse/config.py +0 -410
- egse/confman/__init__.py +0 -1058
- egse/confman/confman.yaml +0 -70
- egse/confman/confman_cs.py +0 -240
- egse/confman/confman_ui.py +0 -381
- egse/confman/setup_ui.py +0 -565
- egse/control.py +0 -632
- egse/coordinates/__init__.py +0 -534
- egse/coordinates/avoidance.py +0 -100
- egse/coordinates/cslmodel.py +0 -127
- egse/coordinates/laser_tracker_to_dict.py +0 -122
- egse/coordinates/point.py +0 -707
- egse/coordinates/pyplot.py +0 -194
- egse/coordinates/referenceFrame.py +0 -1279
- egse/coordinates/refmodel.py +0 -737
- egse/coordinates/rotationMatrix.py +0 -85
- egse/coordinates/transform3d_addon.py +0 -419
- egse/csl/__init__.py +0 -50
- egse/csl/commanding.py +0 -78
- egse/csl/icons/hexapod-connected-selected.svg +0 -30
- egse/csl/icons/hexapod-connected.svg +0 -30
- egse/csl/icons/hexapod-homing-selected.svg +0 -68
- egse/csl/icons/hexapod-homing.svg +0 -68
- egse/csl/icons/hexapod-retract-selected.svg +0 -56
- egse/csl/icons/hexapod-retract.svg +0 -51
- egse/csl/icons/hexapod-zero-selected.svg +0 -56
- egse/csl/icons/hexapod-zero.svg +0 -56
- egse/csl/icons/logo-puna.svg +0 -92
- egse/csl/icons/stop.svg +0 -1
- egse/csl/initialisation.py +0 -102
- egse/csl/mech_pos_settings.yaml +0 -18
- egse/das.py +0 -1240
- egse/das.yaml +0 -7
- egse/data/conf/SETUP_CSL_00000_170620_150000.yaml +0 -5
- egse/data/conf/SETUP_CSL_00001_170620_151010.yaml +0 -69
- egse/data/conf/SETUP_CSL_00002_170620_151020.yaml +0 -69
- egse/data/conf/SETUP_CSL_00003_170620_151030.yaml +0 -69
- egse/data/conf/SETUP_CSL_00004_170620_151040.yaml +0 -69
- egse/data/conf/SETUP_CSL_00005_170620_151050.yaml +0 -69
- egse/data/conf/SETUP_CSL_00006_170620_151060.yaml +0 -69
- egse/data/conf/SETUP_CSL_00007_170620_151070.yaml +0 -69
- egse/data/conf/SETUP_CSL_00008_170620_151080.yaml +0 -75
- egse/data/conf/SETUP_CSL_00010_210308_083016.yaml +0 -138
- egse/data/conf/SETUP_INTA_00000_170620_150000.yaml +0 -4
- egse/data/conf/SETUP_SRON_00000_170620_150000.yaml +0 -4
- egse/decorators.py +0 -514
- egse/device.py +0 -269
- egse/dpu/__init__.py +0 -2698
- egse/dpu/ccd_ui.py +0 -514
- egse/dpu/dpu.py +0 -783
- egse/dpu/dpu.yaml +0 -153
- egse/dpu/dpu_cs.py +0 -272
- egse/dpu/dpu_ui.py +0 -671
- egse/dpu/fitsgen.py +0 -2096
- egse/dpu/fitsgen_ui.py +0 -399
- egse/dpu/hdf5_model.py +0 -332
- egse/dpu/hdf5_ui.py +0 -277
- egse/dpu/hdf5_viewer.py +0 -506
- egse/dpu/hk_ui.py +0 -468
- egse/dpu_commands.py +0 -81
- egse/dsi/__init__.py +0 -33
- egse/dsi/_libesl.py +0 -232
- egse/dsi/constants.py +0 -296
- egse/dsi/esl.py +0 -630
- egse/dsi/rmap.py +0 -444
- egse/dsi/rmapci.py +0 -39
- egse/dsi/spw.py +0 -335
- egse/dsi/spw_state.py +0 -29
- egse/dummy.py +0 -318
- egse/dyndummy.py +0 -179
- egse/env.py +0 -278
- egse/exceptions.py +0 -88
- egse/fdir/__init__.py +0 -26
- egse/fdir/fdir_manager.py +0 -85
- egse/fdir/fdir_manager.yaml +0 -37
- egse/fdir/fdir_manager_controller.py +0 -136
- egse/fdir/fdir_manager_cs.py +0 -164
- egse/fdir/fdir_manager_interface.py +0 -15
- egse/fdir/fdir_remote.py +0 -73
- egse/fdir/fdir_remote.yaml +0 -30
- egse/fdir/fdir_remote_controller.py +0 -30
- egse/fdir/fdir_remote_cs.py +0 -94
- egse/fdir/fdir_remote_interface.py +0 -9
- egse/fdir/fdir_remote_popup.py +0 -26
- egse/fee/__init__.py +0 -106
- egse/fee/f_fee_register.yaml +0 -43
- egse/fee/feesim.py +0 -914
- egse/fee/n_fee_hk.py +0 -768
- egse/fee/nfee.py +0 -188
- egse/filterwheel/__init__.py +0 -4
- egse/filterwheel/eksma/__init__.py +0 -49
- egse/filterwheel/eksma/fw8smc4.py +0 -657
- egse/filterwheel/eksma/fw8smc4.yaml +0 -121
- egse/filterwheel/eksma/fw8smc4_cs.py +0 -144
- egse/filterwheel/eksma/fw8smc4_devif.py +0 -473
- egse/filterwheel/eksma/fw8smc4_protocol.py +0 -82
- egse/filterwheel/eksma/fw8smc4_ui.py +0 -940
- egse/filterwheel/eksma/fw8smc5.py +0 -115
- egse/filterwheel/eksma/fw8smc5.yaml +0 -105
- egse/filterwheel/eksma/fw8smc5_controller.py +0 -307
- egse/filterwheel/eksma/fw8smc5_cs.py +0 -141
- egse/filterwheel/eksma/fw8smc5_interface.py +0 -65
- egse/filterwheel/eksma/fw8smc5_simulator.py +0 -29
- egse/filterwheel/eksma/fw8smc5_ui.py +0 -1065
- egse/filterwheel/eksma/testpythonfw.py +0 -215
- egse/fov/__init__.py +0 -65
- egse/fov/fov_hk.py +0 -710
- egse/fov/fov_ui.py +0 -859
- egse/fov/fov_ui_controller.py +0 -140
- egse/fov/fov_ui_model.py +0 -200
- egse/fov/fov_ui_view.py +0 -345
- egse/gimbal/__init__.py +0 -32
- egse/gimbal/symetrie/__init__.py +0 -26
- egse/gimbal/symetrie/alpha.py +0 -586
- egse/gimbal/symetrie/generic_gimbal_ui.py +0 -1521
- egse/gimbal/symetrie/gimbal.py +0 -877
- egse/gimbal/symetrie/gimbal.yaml +0 -168
- egse/gimbal/symetrie/gimbal_cs.py +0 -183
- egse/gimbal/symetrie/gimbal_protocol.py +0 -138
- egse/gimbal/symetrie/gimbal_ui.py +0 -361
- egse/gimbal/symetrie/pmac.py +0 -1006
- egse/gimbal/symetrie/pmac_regex.py +0 -83
- egse/graph.py +0 -132
- egse/gui/__init__.py +0 -47
- egse/gui/buttons.py +0 -378
- egse/gui/focalplane.py +0 -1285
- egse/gui/formatter.py +0 -10
- egse/gui/led.py +0 -162
- egse/gui/limitswitch.py +0 -143
- egse/gui/mechanisms.py +0 -587
- egse/gui/states.py +0 -148
- egse/gui/stripchart.py +0 -729
- egse/gui/styles.qss +0 -48
- egse/gui/switch.py +0 -112
- egse/h5.py +0 -274
- egse/help/__init__.py +0 -0
- egse/help/help_ui.py +0 -126
- egse/hexapod/__init__.py +0 -32
- egse/hexapod/symetrie/__init__.py +0 -137
- egse/hexapod/symetrie/alpha.py +0 -874
- egse/hexapod/symetrie/dynalpha.py +0 -1387
- egse/hexapod/symetrie/hexapod_ui.py +0 -1516
- egse/hexapod/symetrie/pmac.py +0 -1010
- egse/hexapod/symetrie/pmac_regex.py +0 -83
- egse/hexapod/symetrie/puna.py +0 -1167
- egse/hexapod/symetrie/puna.yaml +0 -193
- egse/hexapod/symetrie/puna_cs.py +0 -195
- egse/hexapod/symetrie/puna_protocol.py +0 -134
- egse/hexapod/symetrie/puna_ui.py +0 -433
- egse/hexapod/symetrie/punaplus.py +0 -107
- egse/hexapod/symetrie/zonda.py +0 -872
- egse/hexapod/symetrie/zonda.yaml +0 -337
- egse/hexapod/symetrie/zonda_cs.py +0 -172
- egse/hexapod/symetrie/zonda_devif.py +0 -414
- egse/hexapod/symetrie/zonda_protocol.py +0 -123
- egse/hexapod/symetrie/zonda_ui.py +0 -449
- egse/hk.py +0 -791
- egse/icons/aeu-cs-start.svg +0 -117
- egse/icons/aeu-cs-stop.svg +0 -118
- egse/icons/aeu-cs.svg +0 -107
- egse/icons/aeu_cs-started.svg +0 -112
- egse/icons/aeu_cs-stopped.svg +0 -112
- egse/icons/aeu_cs.svg +0 -55
- egse/icons/alert.svg +0 -1
- egse/icons/arrow-double-left.png +0 -0
- egse/icons/arrow-double-right.png +0 -0
- egse/icons/arrow-up.svg +0 -11
- egse/icons/backward.svg +0 -1
- egse/icons/busy.svg +0 -1
- egse/icons/cleaning.svg +0 -115
- egse/icons/color-scheme.svg +0 -1
- egse/icons/cs-connected-alert.svg +0 -91
- egse/icons/cs-connected-disabled.svg +0 -43
- egse/icons/cs-connected.svg +0 -89
- egse/icons/cs-not-connected.svg +0 -44
- egse/icons/double-left-arrow.svg +0 -1
- egse/icons/double-right-arrow.svg +0 -1
- egse/icons/erase-disabled.svg +0 -19
- egse/icons/erase.svg +0 -59
- egse/icons/fitsgen-start.svg +0 -47
- egse/icons/fitsgen-stop.svg +0 -48
- egse/icons/fitsgen.svg +0 -1
- egse/icons/forward.svg +0 -1
- egse/icons/fov-hk-start.svg +0 -33
- egse/icons/fov-hk-stop.svg +0 -37
- egse/icons/fov-hk.svg +0 -1
- egse/icons/front-desk.svg +0 -1
- egse/icons/home-actioned.svg +0 -15
- egse/icons/home-disabled.svg +0 -15
- egse/icons/home.svg +0 -13
- egse/icons/info.svg +0 -1
- egse/icons/invalid.png +0 -0
- egse/icons/led-green.svg +0 -20
- egse/icons/led-grey.svg +0 -20
- egse/icons/led-orange.svg +0 -20
- egse/icons/led-red.svg +0 -20
- egse/icons/led-square-green.svg +0 -134
- egse/icons/led-square-grey.svg +0 -134
- egse/icons/led-square-orange.svg +0 -134
- egse/icons/led-square-red.svg +0 -134
- egse/icons/limit-switch-all-green.svg +0 -115
- egse/icons/limit-switch-all-red.svg +0 -117
- egse/icons/limit-switch-el+.svg +0 -116
- egse/icons/limit-switch-el-.svg +0 -117
- egse/icons/location-marker.svg +0 -1
- egse/icons/logo-dpu.svg +0 -48
- egse/icons/logo-gimbal.svg +0 -112
- egse/icons/logo-huber.svg +0 -23
- egse/icons/logo-ogse.svg +0 -31
- egse/icons/logo-puna.svg +0 -92
- egse/icons/logo-tcs.svg +0 -29
- egse/icons/logo-zonda.svg +0 -66
- egse/icons/maximize.svg +0 -1
- egse/icons/meter.svg +0 -1
- egse/icons/more.svg +0 -45
- egse/icons/n-fee-hk-start.svg +0 -24
- egse/icons/n-fee-hk-stop.svg +0 -25
- egse/icons/n-fee-hk.svg +0 -83
- egse/icons/observing-off.svg +0 -46
- egse/icons/observing-on.svg +0 -46
- egse/icons/open-document-hdf5.png +0 -0
- egse/icons/open-document-hdf5.svg +0 -21
- egse/icons/ops-mode.svg +0 -1
- egse/icons/play-green.svg +0 -17
- egse/icons/plugged-disabled.svg +0 -27
- egse/icons/plugged.svg +0 -21
- egse/icons/pm_ui.svg +0 -1
- egse/icons/power-button-green.svg +0 -27
- egse/icons/power-button-red.svg +0 -27
- egse/icons/power-button.svg +0 -27
- egse/icons/radar.svg +0 -1
- egse/icons/radioactive.svg +0 -2
- egse/icons/reload.svg +0 -1
- egse/icons/remote-control-off.svg +0 -28
- egse/icons/remote-control-on.svg +0 -28
- egse/icons/repeat-blue.svg +0 -15
- egse/icons/repeat.svg +0 -1
- egse/icons/settings.svg +0 -1
- egse/icons/shrink.svg +0 -1
- egse/icons/shutter.svg +0 -1
- egse/icons/sign-off.svg +0 -1
- egse/icons/sign-on.svg +0 -1
- egse/icons/sim-mode.svg +0 -1
- egse/icons/small-buttons-go.svg +0 -20
- egse/icons/small-buttons-minus.svg +0 -51
- egse/icons/small-buttons-plus.svg +0 -51
- egse/icons/sponge.svg +0 -220
- egse/icons/start-button-disabled.svg +0 -84
- egse/icons/start-button.svg +0 -50
- egse/icons/stop-button-disabled.svg +0 -84
- egse/icons/stop-button.svg +0 -50
- egse/icons/stop-red.svg +0 -17
- egse/icons/stop.svg +0 -1
- egse/icons/switch-disabled-square.svg +0 -87
- egse/icons/switch-disabled.svg +0 -15
- egse/icons/switch-off-square.svg +0 -87
- egse/icons/switch-off.svg +0 -72
- egse/icons/switch-on-square.svg +0 -87
- egse/icons/switch-on.svg +0 -61
- egse/icons/temperature-control.svg +0 -44
- egse/icons/th_ui_logo.svg +0 -1
- egse/icons/unplugged.svg +0 -23
- egse/icons/unvalid.png +0 -0
- egse/icons/user-interface.svg +0 -1
- egse/icons/vacuum.svg +0 -1
- egse/icons/valid.png +0 -0
- egse/icons/zoom-to-pixel-dark.svg +0 -64
- egse/icons/zoom-to-pixel-white.svg +0 -36
- egse/images/big-rotation-stage.png +0 -0
- egse/images/connected-100.png +0 -0
- egse/images/cross.svg +0 -6
- egse/images/disconnected-100.png +0 -0
- egse/images/gui-icon.png +0 -0
- egse/images/home.svg +0 -6
- egse/images/info-icon.png +0 -0
- egse/images/led-black.svg +0 -89
- egse/images/led-green.svg +0 -85
- egse/images/led-orange.svg +0 -85
- egse/images/led-red.svg +0 -85
- egse/images/load-icon.png +0 -0
- egse/images/load-setup.png +0 -0
- egse/images/load.png +0 -0
- egse/images/pause.png +0 -0
- egse/images/play-button.svg +0 -8
- egse/images/play.png +0 -0
- egse/images/process-status.png +0 -0
- egse/images/restart.png +0 -0
- egse/images/search.png +0 -0
- egse/images/sma.png +0 -0
- egse/images/start.png +0 -0
- egse/images/stop-button.svg +0 -8
- egse/images/stop.png +0 -0
- egse/images/switch-off.svg +0 -48
- egse/images/switch-on.svg +0 -48
- egse/images/undo.png +0 -0
- egse/images/update-button.svg +0 -11
- egse/imageviewer/exposureselection.py +0 -475
- egse/imageviewer/imageviewer.py +0 -198
- egse/imageviewer/matchfocalplane.py +0 -179
- egse/imageviewer/subfieldposition.py +0 -133
- egse/lampcontrol/__init__.py +0 -4
- egse/lampcontrol/beaglebone/beaglebone.py +0 -178
- egse/lampcontrol/beaglebone/beaglebone.yaml +0 -62
- egse/lampcontrol/beaglebone/beaglebone_cs.py +0 -106
- egse/lampcontrol/beaglebone/beaglebone_devif.py +0 -150
- egse/lampcontrol/beaglebone/beaglebone_protocol.py +0 -73
- egse/lampcontrol/energetiq/__init__.py +0 -22
- egse/lampcontrol/energetiq/eq99.yaml +0 -98
- egse/lampcontrol/energetiq/lampEQ99.py +0 -283
- egse/lampcontrol/energetiq/lampEQ99_cs.py +0 -128
- egse/lampcontrol/energetiq/lampEQ99_devif.py +0 -158
- egse/lampcontrol/energetiq/lampEQ99_encode_decode_errors.py +0 -73
- egse/lampcontrol/energetiq/lampEQ99_protocol.py +0 -71
- egse/lampcontrol/energetiq/lampEQ99_ui.py +0 -465
- egse/lib/CentOS-7/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/CentOS-8/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/CentOS-8/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/Debian/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/Debian/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/Debian/libetherspacelink_v35_21.dylib +0 -0
- egse/lib/Linux/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/Linux/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/Ubuntu-20/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/Ubuntu-20/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/gssw/python3-gssw_2.2.3+31f63c9f-1_all.deb +0 -0
- egse/lib/ximc/__pycache__/pyximc.cpython-38 2.pyc +0 -0
- egse/lib/ximc/__pycache__/pyximc.cpython-38.pyc +0 -0
- egse/lib/ximc/libximc.framework/Frameworks/libbindy.dylib +0 -0
- egse/lib/ximc/libximc.framework/Frameworks/libxiwrapper.dylib +0 -0
- egse/lib/ximc/libximc.framework/Headers/ximc.h +0 -5510
- egse/lib/ximc/libximc.framework/Resources/Info.plist +0 -42
- egse/lib/ximc/libximc.framework/Resources/keyfile.sqlite +0 -0
- egse/lib/ximc/libximc.framework/libbindy.so +0 -0
- egse/lib/ximc/libximc.framework/libximc +0 -0
- egse/lib/ximc/libximc.framework/libximc.so +0 -0
- egse/lib/ximc/libximc.framework/libximc.so.7.0.0 +0 -0
- egse/lib/ximc/libximc.framework/libxiwrapper.so +0 -0
- egse/lib/ximc/pyximc.py +0 -922
- egse/listener.py +0 -179
- egse/logger/__init__.py +0 -243
- egse/logger/log_cs.py +0 -321
- egse/metrics.py +0 -102
- egse/mixin.py +0 -464
- egse/monitoring.py +0 -95
- egse/ni/alarms/__init__.py +0 -26
- egse/ni/alarms/cdaq9375.py +0 -300
- egse/ni/alarms/cdaq9375.yaml +0 -89
- egse/ni/alarms/cdaq9375_cs.py +0 -130
- egse/ni/alarms/cdaq9375_devif.py +0 -183
- egse/ni/alarms/cdaq9375_protocol.py +0 -48
- egse/obs_inspection.py +0 -165
- egse/observer.py +0 -41
- egse/obsid.py +0 -163
- egse/powermeter/__init__.py +0 -0
- egse/powermeter/ni/__init__.py +0 -38
- egse/powermeter/ni/cdaq9184.py +0 -224
- egse/powermeter/ni/cdaq9184.yaml +0 -73
- egse/powermeter/ni/cdaq9184_cs.py +0 -130
- egse/powermeter/ni/cdaq9184_devif.py +0 -201
- egse/powermeter/ni/cdaq9184_protocol.py +0 -48
- egse/powermeter/ni/cdaq9184_ui.py +0 -544
- egse/powermeter/thorlabs/__init__.py +0 -25
- egse/powermeter/thorlabs/pm100a.py +0 -380
- egse/powermeter/thorlabs/pm100a.yaml +0 -132
- egse/powermeter/thorlabs/pm100a_cs.py +0 -136
- egse/powermeter/thorlabs/pm100a_devif.py +0 -127
- egse/powermeter/thorlabs/pm100a_protocol.py +0 -80
- egse/powermeter/thorlabs/pm100a_ui.py +0 -725
- egse/process.py +0 -451
- egse/procman/__init__.py +0 -834
- egse/procman/cannot_start_process_popup.py +0 -43
- egse/procman/procman.yaml +0 -49
- egse/procman/procman_cs.py +0 -201
- egse/procman/procman_ui.py +0 -2081
- egse/protocol.py +0 -605
- egse/proxy.py +0 -531
- egse/randomwalk.py +0 -140
- egse/reg.py +0 -585
- egse/reload.py +0 -122
- egse/reprocess.py +0 -693
- egse/resource.py +0 -333
- egse/rmap.py +0 -406
- egse/rst.py +0 -135
- egse/search.py +0 -182
- egse/serialdevice.py +0 -190
- egse/services.py +0 -247
- egse/services.yaml +0 -68
- egse/settings.py +0 -379
- egse/settings.yaml +0 -980
- egse/setup.py +0 -1181
- egse/shutter/__init__.py +0 -0
- egse/shutter/thorlabs/__init__.py +0 -19
- egse/shutter/thorlabs/ksc101.py +0 -205
- egse/shutter/thorlabs/ksc101.yaml +0 -105
- egse/shutter/thorlabs/ksc101_cs.py +0 -136
- egse/shutter/thorlabs/ksc101_devif.py +0 -201
- egse/shutter/thorlabs/ksc101_protocol.py +0 -71
- egse/shutter/thorlabs/ksc101_ui.py +0 -548
- egse/shutter/thorlabs/sc10.py +0 -82
- egse/shutter/thorlabs/sc10.yaml +0 -52
- egse/shutter/thorlabs/sc10_controller.py +0 -81
- egse/shutter/thorlabs/sc10_cs.py +0 -108
- egse/shutter/thorlabs/sc10_interface.py +0 -25
- egse/shutter/thorlabs/sc10_simulator.py +0 -30
- egse/simulator.py +0 -41
- egse/slack.py +0 -61
- egse/socketdevice.py +0 -218
- egse/sockets.py +0 -218
- egse/spw.py +0 -1401
- egse/stages/__init__.py +0 -12
- egse/stages/aerotech/ensemble.py +0 -245
- egse/stages/aerotech/ensemble.yaml +0 -205
- egse/stages/aerotech/ensemble_controller.py +0 -275
- egse/stages/aerotech/ensemble_cs.py +0 -110
- egse/stages/aerotech/ensemble_interface.py +0 -132
- egse/stages/aerotech/ensemble_parameters.py +0 -433
- egse/stages/aerotech/ensemble_simulator.py +0 -27
- egse/stages/aerotech/mgse_sim.py +0 -188
- egse/stages/arun/smd3.py +0 -110
- egse/stages/arun/smd3.yaml +0 -68
- egse/stages/arun/smd3_controller.py +0 -470
- egse/stages/arun/smd3_cs.py +0 -112
- egse/stages/arun/smd3_interface.py +0 -53
- egse/stages/arun/smd3_simulator.py +0 -27
- egse/stages/arun/smd3_stop.py +0 -16
- egse/stages/huber/__init__.py +0 -49
- egse/stages/huber/smc9300.py +0 -920
- egse/stages/huber/smc9300.yaml +0 -63
- egse/stages/huber/smc9300_cs.py +0 -178
- egse/stages/huber/smc9300_devif.py +0 -345
- egse/stages/huber/smc9300_protocol.py +0 -113
- egse/stages/huber/smc9300_sim.py +0 -547
- egse/stages/huber/smc9300_ui.py +0 -973
- egse/state.py +0 -173
- egse/statemachine.py +0 -274
- egse/storage/__init__.py +0 -1067
- egse/storage/persistence.py +0 -2295
- egse/storage/storage.yaml +0 -79
- egse/storage/storage_cs.py +0 -231
- egse/styles/dark.qss +0 -343
- egse/styles/default.qss +0 -48
- egse/synoptics/__init__.py +0 -417
- egse/synoptics/syn.yaml +0 -9
- egse/synoptics/syn_cs.py +0 -195
- egse/system.py +0 -1611
- egse/tcs/__init__.py +0 -14
- egse/tcs/tcs.py +0 -879
- egse/tcs/tcs.yaml +0 -14
- egse/tcs/tcs_cs.py +0 -202
- egse/tcs/tcs_devif.py +0 -292
- egse/tcs/tcs_protocol.py +0 -180
- egse/tcs/tcs_sim.py +0 -177
- egse/tcs/tcs_ui.py +0 -543
- egse/tdms.py +0 -171
- egse/tempcontrol/__init__.py +0 -23
- egse/tempcontrol/agilent/agilent34970.py +0 -109
- egse/tempcontrol/agilent/agilent34970.yaml +0 -44
- egse/tempcontrol/agilent/agilent34970_cs.py +0 -114
- egse/tempcontrol/agilent/agilent34970_devif.py +0 -182
- egse/tempcontrol/agilent/agilent34970_protocol.py +0 -96
- egse/tempcontrol/agilent/agilent34972.py +0 -111
- egse/tempcontrol/agilent/agilent34972.yaml +0 -44
- egse/tempcontrol/agilent/agilent34972_cs.py +0 -115
- egse/tempcontrol/agilent/agilent34972_devif.py +0 -189
- egse/tempcontrol/agilent/agilent34972_protocol.py +0 -98
- egse/tempcontrol/beaglebone/beaglebone.py +0 -341
- egse/tempcontrol/beaglebone/beaglebone.yaml +0 -110
- egse/tempcontrol/beaglebone/beaglebone_cs.py +0 -117
- egse/tempcontrol/beaglebone/beaglebone_protocol.py +0 -134
- egse/tempcontrol/beaglebone/beaglebone_ui.py +0 -674
- egse/tempcontrol/digalox/digalox.py +0 -115
- egse/tempcontrol/digalox/digalox.yaml +0 -36
- egse/tempcontrol/digalox/digalox_cs.py +0 -108
- egse/tempcontrol/digalox/digalox_protocol.py +0 -56
- egse/tempcontrol/keithley/__init__.py +0 -33
- egse/tempcontrol/keithley/daq6510.py +0 -662
- egse/tempcontrol/keithley/daq6510.yaml +0 -105
- egse/tempcontrol/keithley/daq6510_cs.py +0 -163
- egse/tempcontrol/keithley/daq6510_devif.py +0 -343
- egse/tempcontrol/keithley/daq6510_protocol.py +0 -79
- egse/tempcontrol/keithley/daq6510_sim.py +0 -186
- egse/tempcontrol/lakeshore/__init__.py +0 -33
- egse/tempcontrol/lakeshore/lsci.py +0 -361
- egse/tempcontrol/lakeshore/lsci.yaml +0 -162
- egse/tempcontrol/lakeshore/lsci_cs.py +0 -174
- egse/tempcontrol/lakeshore/lsci_devif.py +0 -292
- egse/tempcontrol/lakeshore/lsci_protocol.py +0 -76
- egse/tempcontrol/lakeshore/lsci_ui.py +0 -387
- egse/tempcontrol/ni/__init__.py +0 -0
- egse/tempcontrol/spid/spid.py +0 -109
- egse/tempcontrol/spid/spid.yaml +0 -81
- egse/tempcontrol/spid/spid_controller.py +0 -279
- egse/tempcontrol/spid/spid_cs.py +0 -136
- egse/tempcontrol/spid/spid_protocol.py +0 -107
- egse/tempcontrol/spid/spid_ui.py +0 -723
- egse/tempcontrol/srs/__init__.py +0 -22
- egse/tempcontrol/srs/ptc10.py +0 -867
- egse/tempcontrol/srs/ptc10.yaml +0 -227
- egse/tempcontrol/srs/ptc10_cs.py +0 -128
- egse/tempcontrol/srs/ptc10_devif.py +0 -116
- egse/tempcontrol/srs/ptc10_protocol.py +0 -39
- egse/tempcontrol/srs/ptc10_ui.py +0 -906
- egse/ups/apc/apc.py +0 -236
- egse/ups/apc/apc.yaml +0 -45
- egse/ups/apc/apc_cs.py +0 -101
- egse/ups/apc/apc_protocol.py +0 -125
- egse/user.yaml +0 -7
- egse/vacuum/beaglebone/beaglebone.py +0 -149
- egse/vacuum/beaglebone/beaglebone.yaml +0 -44
- egse/vacuum/beaglebone/beaglebone_cs.py +0 -108
- egse/vacuum/beaglebone/beaglebone_devif.py +0 -159
- egse/vacuum/beaglebone/beaglebone_protocol.py +0 -192
- egse/vacuum/beaglebone/beaglebone_ui.py +0 -638
- egse/vacuum/instrutech/igm402.py +0 -91
- egse/vacuum/instrutech/igm402.yaml +0 -90
- egse/vacuum/instrutech/igm402_controller.py +0 -124
- egse/vacuum/instrutech/igm402_cs.py +0 -108
- egse/vacuum/instrutech/igm402_interface.py +0 -49
- egse/vacuum/instrutech/igm402_simulator.py +0 -36
- egse/vacuum/keller/kellerBus.py +0 -256
- egse/vacuum/keller/leo3.py +0 -100
- egse/vacuum/keller/leo3.yaml +0 -38
- egse/vacuum/keller/leo3_controller.py +0 -81
- egse/vacuum/keller/leo3_cs.py +0 -101
- egse/vacuum/keller/leo3_interface.py +0 -33
- egse/vacuum/mks/evision.py +0 -86
- egse/vacuum/mks/evision.yaml +0 -75
- egse/vacuum/mks/evision_cs.py +0 -101
- egse/vacuum/mks/evision_devif.py +0 -313
- egse/vacuum/mks/evision_interface.py +0 -60
- egse/vacuum/mks/evision_simulator.py +0 -24
- egse/vacuum/mks/evision_ui.py +0 -701
- egse/vacuum/pfeiffer/acp40.py +0 -87
- egse/vacuum/pfeiffer/acp40.yaml +0 -60
- egse/vacuum/pfeiffer/acp40_controller.py +0 -117
- egse/vacuum/pfeiffer/acp40_cs.py +0 -109
- egse/vacuum/pfeiffer/acp40_interface.py +0 -40
- egse/vacuum/pfeiffer/acp40_simulator.py +0 -37
- egse/vacuum/pfeiffer/tc400.py +0 -87
- egse/vacuum/pfeiffer/tc400.yaml +0 -83
- egse/vacuum/pfeiffer/tc400_controller.py +0 -136
- egse/vacuum/pfeiffer/tc400_cs.py +0 -109
- egse/vacuum/pfeiffer/tc400_interface.py +0 -70
- egse/vacuum/pfeiffer/tc400_simulator.py +0 -35
- egse/vacuum/pfeiffer/tpg261.py +0 -80
- egse/vacuum/pfeiffer/tpg261.yaml +0 -66
- egse/vacuum/pfeiffer/tpg261_controller.py +0 -150
- egse/vacuum/pfeiffer/tpg261_cs.py +0 -109
- egse/vacuum/pfeiffer/tpg261_interface.py +0 -59
- egse/vacuum/pfeiffer/tpg261_simulator.py +0 -23
- egse/version.py +0 -174
- egse/visitedpositions.py +0 -398
- egse/windowing.py +0 -213
- egse/zmq/__init__.py +0 -28
- egse/zmq/spw.py +0 -160
- egse/zmq_ser.py +0 -41
- scripts/alerts/cold.yaml +0 -278
- scripts/alerts/example_alerts.yaml +0 -54
- scripts/alerts/transition.yaml +0 -14
- scripts/alerts/warm.yaml +0 -49
- scripts/analyse_n_fee_hk_data.py +0 -52
- scripts/check_hdf5_files.py +0 -192
- scripts/check_register_sync.py +0 -47
- scripts/check_tcs_calib_coef.py +0 -90
- scripts/correct_ccd_cold_temperature_cal.py +0 -157
- scripts/create_hdf5_report.py +0 -293
- scripts/csl_model.py +0 -420
- scripts/csl_restore_setup.py +0 -229
- scripts/export-grafana-dashboards.py +0 -49
- scripts/fdir/cs_recovery/fdir_cs_recovery.py +0 -54
- scripts/fdir/fdir_table.yaml +0 -70
- scripts/fdir/fdir_test_recovery.py +0 -10
- scripts/fdir/hw_recovery/fdir_agilent_hw_recovery.py +0 -73
- scripts/fdir/limit_recovery/fdir_agilent_limit.py +0 -61
- scripts/fdir/limit_recovery/fdir_bb_heater_limit.py +0 -59
- scripts/fdir/limit_recovery/fdir_ensemble_limit.py +0 -33
- scripts/fdir/limit_recovery/fdir_pressure_limit_recovery.py +0 -71
- scripts/fix_csv.py +0 -80
- scripts/ias/correct_ccd_temp_cal_elfique.py +0 -43
- scripts/ias/correct_ccd_temp_cal_floreffe.py +0 -43
- scripts/ias/correct_trp_swap_achel.py +0 -199
- scripts/inta/correct_ccd_temp_cal_duvel.py +0 -43
- scripts/inta/correct_ccd_temp_cal_gueuze.py +0 -43
- scripts/n_fee_supply_voltage_calculation.py +0 -92
- scripts/playground.py +0 -30
- scripts/print_hdf5_hk_data.py +0 -68
- scripts/print_register_map.py +0 -43
- scripts/remove_lines_between_matches.py +0 -188
- scripts/sron/commanding/control_heaters.py +0 -44
- scripts/sron/commanding/pumpdown.py +0 -46
- scripts/sron/commanding/set_pid_setpoint.py +0 -19
- scripts/sron/commanding/shutdown_bbb_heaters.py +0 -10
- scripts/sron/commanding/shutdown_pumps.py +0 -33
- scripts/sron/correct_mgse_coordinates_brigand_chimay.py +0 -272
- scripts/sron/correct_trp_swap_brigand.py +0 -204
- scripts/sron/gimbal_conversions.py +0 -75
- scripts/sron/tm_gen/tm_gen_agilent.py +0 -37
- scripts/sron/tm_gen/tm_gen_heaters.py +0 -4
- scripts/sron/tm_gen/tm_gen_spid.py +0 -13
- scripts/update_operational_cgse.py +0 -268
- scripts/update_operational_cgse_old.py +0 -273
egse/aeu/aeu_ui.py
DELETED
|
@@ -1,873 +0,0 @@
|
|
|
1
|
-
import argparse
|
|
2
|
-
import logging
|
|
3
|
-
import pickle
|
|
4
|
-
from pathlib import Path
|
|
5
|
-
|
|
6
|
-
import sys
|
|
7
|
-
import zmq
|
|
8
|
-
from PyQt5.QtCore import QThread, QObject, pyqtSignal, pyqtSlot, QLockFile
|
|
9
|
-
from PyQt5.QtGui import QCloseEvent, QPixmap, QIcon
|
|
10
|
-
from PyQt5.QtWidgets import QMainWindow, QApplication, QLabel, QFrame, QHBoxLayout, QVBoxLayout, QGroupBox, QGridLayout, \
|
|
11
|
-
QAction, QMessageBox
|
|
12
|
-
from deepdiff import DeepDiff
|
|
13
|
-
from zmq import ZMQError
|
|
14
|
-
|
|
15
|
-
from egse.aeu.aeu import CRIOProxy, CRIOController, CRIOSimulator
|
|
16
|
-
from egse.aeu.aeu import CTRL_SETTINGS
|
|
17
|
-
from egse.config import find_file
|
|
18
|
-
from egse.gui.led import Led, Indic
|
|
19
|
-
from egse.observer import Observer, Observable
|
|
20
|
-
from egse.resource import get_resource
|
|
21
|
-
from egse.settings import Settings
|
|
22
|
-
from egse.zmq_ser import connect_address
|
|
23
|
-
|
|
24
|
-
MODULE_LOGGER = logging.getLogger(__name__)
|
|
25
|
-
|
|
26
|
-
# Leds that always have to be shown (no matter which camera has been selected)
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
RELEVANT_COMMON_KEYS = {
|
|
30
|
-
"Standby": "Stand-by", "Selftest": "Self-test", "FC_TVAC": "Functional check & TVAC", "Alignment": "Alignment",
|
|
31
|
-
"N-CAM": "N-CAM", "F-CAM": "F-CAM", "V_CCD": "V_CCD", "V_CLK": "V_CLK", "V_AN1": "V_AN1", "V_AN2": "V_AN2",
|
|
32
|
-
"V_AN3": "V_AN3", "V_DIG": "V_DIG", "S_voltage_oor": "Secondary voltage generation out-of-range",
|
|
33
|
-
"S_current_oor": "Secondary current generation out-of-range", "Sync_gf": "Synchronisation generator failure",
|
|
34
|
-
"Clk_TCS_50MHz_nom": "Clk_TCS_50MHz_nom", "Clk_TCS_50MHz_red": "Clk_TCS_50MHz_red",
|
|
35
|
-
"Clk_heater_nom": "Clk_heater_nom", "Clk_heater_red": "Clk_heater_red", "TestPort": "Test port"
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
# Leds that have to be shown only if the N-CAM has been selected
|
|
39
|
-
|
|
40
|
-
RELEVANT_N_CAM_KEYS = ["Clk_N_50MHz", "Clk_N_ccdread"]
|
|
41
|
-
|
|
42
|
-
# Leds that have to be shown only if the F-CAM has been selected
|
|
43
|
-
|
|
44
|
-
RELEVANT_F_CAM_KEYS = ["Clk_F_50MHz_nom", "Clk_F_50MHz_red", "Clk_F_ccdread_nom", "Clk_F_ccdread_red"]
|
|
45
|
-
|
|
46
|
-
GUI_SETTINGS = Settings.load("AEU GUI")
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
class MonitoringWorker(QObject):
|
|
50
|
-
""" Worker for monitoring the led status of the AEU cRIO. """
|
|
51
|
-
|
|
52
|
-
# The worker will send a signal with the AEU cRIO led status
|
|
53
|
-
|
|
54
|
-
common_led_status_signal = pyqtSignal(dict)
|
|
55
|
-
hide_clk_signal = pyqtSignal()
|
|
56
|
-
n_cam_clk_led_status_signal = pyqtSignal(dict)
|
|
57
|
-
f_cam_clk_led_status_signal = pyqtSignal(dict)
|
|
58
|
-
|
|
59
|
-
def __init__(self):
|
|
60
|
-
""" Initialisation of a monitoring worker.
|
|
61
|
-
|
|
62
|
-
This worker keeps on eye on the monitoring port of the AEU cRIO. When a changed in (relevant) monitoring
|
|
63
|
-
information occurs, a signal will be emitted. These signals will be used to update the GUI.
|
|
64
|
-
"""
|
|
65
|
-
|
|
66
|
-
super(MonitoringWorker, self).__init__()
|
|
67
|
-
|
|
68
|
-
self.active = False
|
|
69
|
-
self.just_reconnected = True
|
|
70
|
-
|
|
71
|
-
self.monitoring_socket = None
|
|
72
|
-
self.is_socket_connected = True
|
|
73
|
-
self.monitoring_timeout = 0.5 # [s]
|
|
74
|
-
|
|
75
|
-
self.connect_socket()
|
|
76
|
-
|
|
77
|
-
# Keep track of the previous led status, so we only have to send a signal when the led status has changed
|
|
78
|
-
|
|
79
|
-
self.previous_common_led_status = {}
|
|
80
|
-
self.previous_n_cam_clk_led_status = {}
|
|
81
|
-
self.previous_f_cam_clk_led_status = {}
|
|
82
|
-
|
|
83
|
-
def connect_socket(self):
|
|
84
|
-
""" Create a socket and connect to the monitoring port.
|
|
85
|
-
"""
|
|
86
|
-
|
|
87
|
-
try:
|
|
88
|
-
|
|
89
|
-
transport = CTRL_SETTINGS.PROTOCOL
|
|
90
|
-
hostname = CTRL_SETTINGS.HOSTNAME
|
|
91
|
-
# commanding_port = CTRL_SETTINGS.CRIO["COMMANDING_PORT"]
|
|
92
|
-
monitoring_port = CTRL_SETTINGS.CRIO["MONITORING_PORT"]
|
|
93
|
-
|
|
94
|
-
monitoring_address = connect_address(transport, hostname, monitoring_port)
|
|
95
|
-
|
|
96
|
-
self.monitoring_socket = zmq.Context().socket(zmq.SUB)
|
|
97
|
-
self.monitoring_socket.connect(monitoring_address)
|
|
98
|
-
self.monitoring_socket.setsockopt_string(zmq.SUBSCRIBE, "")
|
|
99
|
-
|
|
100
|
-
self.monitoring_timeout = 0.5 # [s]
|
|
101
|
-
|
|
102
|
-
# Address of the commanding port
|
|
103
|
-
# This is needed when checking whether or not the CS is active
|
|
104
|
-
# TODO
|
|
105
|
-
|
|
106
|
-
self.is_socket_connected = True
|
|
107
|
-
|
|
108
|
-
except AttributeError:
|
|
109
|
-
|
|
110
|
-
self.is_socket_connected = False
|
|
111
|
-
|
|
112
|
-
def stop(self):
|
|
113
|
-
|
|
114
|
-
""" Stop the monitoring worker.
|
|
115
|
-
|
|
116
|
-
The monitoring socket is disconnected from the monitoring port and is then closed immediately.
|
|
117
|
-
"""
|
|
118
|
-
|
|
119
|
-
self.monitoring_socket.close()
|
|
120
|
-
self.is_socket_connected = False
|
|
121
|
-
|
|
122
|
-
self.active = False
|
|
123
|
-
|
|
124
|
-
def start_process(self):
|
|
125
|
-
""" Start updating the led status of the AEU cRIO."""
|
|
126
|
-
|
|
127
|
-
self.run()
|
|
128
|
-
|
|
129
|
-
@pyqtSlot()
|
|
130
|
-
def run(self):
|
|
131
|
-
""" Keep on checking whether the led status of the AEU cRIO has changed.
|
|
132
|
-
|
|
133
|
-
If the led status of the AEU cRIO has changed, update it in the GUI.
|
|
134
|
-
"""
|
|
135
|
-
|
|
136
|
-
self.active = True
|
|
137
|
-
|
|
138
|
-
while self.is_socket_connected and self.active:
|
|
139
|
-
|
|
140
|
-
try:
|
|
141
|
-
|
|
142
|
-
socket_list, _, _ = zmq.select([self.monitoring_socket], [], [], timeout=self.monitoring_timeout)
|
|
143
|
-
|
|
144
|
-
# Monitoring information was received (before timeout)
|
|
145
|
-
|
|
146
|
-
if self.monitoring_socket in socket_list:
|
|
147
|
-
|
|
148
|
-
pickle_string = self.monitoring_socket.recv()
|
|
149
|
-
monitoring_info = pickle.loads(pickle_string)
|
|
150
|
-
|
|
151
|
-
# Select the monitoring information that is relevant for the GUI
|
|
152
|
-
|
|
153
|
-
common_led_status = {key: monitoring_info[key] for key in RELEVANT_COMMON_KEYS.keys()}
|
|
154
|
-
|
|
155
|
-
n_cam_clk_led_status = {}
|
|
156
|
-
f_cam_clk_led_status = {}
|
|
157
|
-
|
|
158
|
-
n_cam_powered = common_led_status["N-CAM"]
|
|
159
|
-
f_cam_powered = common_led_status["F-CAM"]
|
|
160
|
-
|
|
161
|
-
if n_cam_powered:
|
|
162
|
-
n_cam_clk_led_status = {key: monitoring_info[key] for key in RELEVANT_N_CAM_KEYS}
|
|
163
|
-
elif f_cam_powered:
|
|
164
|
-
f_cam_clk_led_status = {key: monitoring_info[key] for key in RELEVANT_F_CAM_KEYS}
|
|
165
|
-
|
|
166
|
-
diff_common = DeepDiff(common_led_status, self.previous_common_led_status)
|
|
167
|
-
diff_n_cam_clk = DeepDiff(n_cam_clk_led_status, self.previous_n_cam_clk_led_status)
|
|
168
|
-
diff_f_cam_clk = DeepDiff(f_cam_clk_led_status, self.previous_f_cam_clk_led_status)
|
|
169
|
-
|
|
170
|
-
error_detected = monitoring_info["S_voltage_oor"] or monitoring_info["S_current_oor"] \
|
|
171
|
-
or monitoring_info["Sync_gf"]
|
|
172
|
-
|
|
173
|
-
# Change in common led status
|
|
174
|
-
|
|
175
|
-
if self.just_reconnected:
|
|
176
|
-
|
|
177
|
-
if error_detected or not (n_cam_powered or f_cam_powered):
|
|
178
|
-
|
|
179
|
-
self.hide_clk_signal.emit()
|
|
180
|
-
|
|
181
|
-
if len(diff_common) != 0 or self.just_reconnected:
|
|
182
|
-
|
|
183
|
-
self.previous_common_led_status = common_led_status
|
|
184
|
-
self.common_led_status_signal.emit(common_led_status)
|
|
185
|
-
|
|
186
|
-
if error_detected:
|
|
187
|
-
|
|
188
|
-
self.hide_clk_signal.emit()
|
|
189
|
-
|
|
190
|
-
# Change in N-CAM led status
|
|
191
|
-
|
|
192
|
-
elif len(diff_n_cam_clk) != 0:
|
|
193
|
-
|
|
194
|
-
self.previous_n_cam_clk_led_status = n_cam_clk_led_status
|
|
195
|
-
self.n_cam_clk_led_status_signal.emit(n_cam_clk_led_status)
|
|
196
|
-
|
|
197
|
-
# Change in F-CAM led status
|
|
198
|
-
|
|
199
|
-
elif len(diff_f_cam_clk) != 0:
|
|
200
|
-
|
|
201
|
-
self.previous_f_cam_clk_led_status = f_cam_clk_led_status
|
|
202
|
-
self.f_cam_clk_led_status_signal.emit(f_cam_clk_led_status)
|
|
203
|
-
|
|
204
|
-
self.just_reconnected = False
|
|
205
|
-
|
|
206
|
-
except ZMQError:
|
|
207
|
-
|
|
208
|
-
pass
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
class LedWidget(QGroupBox):
|
|
212
|
-
|
|
213
|
-
def __init__(self, name: str, on_color=Indic.GREEN):
|
|
214
|
-
""" Widget with a name and led.
|
|
215
|
-
|
|
216
|
-
Args:
|
|
217
|
-
- name: Text for the label.
|
|
218
|
-
- on_color: Colour the led should have if turned on.
|
|
219
|
-
"""
|
|
220
|
-
|
|
221
|
-
super().__init__()
|
|
222
|
-
|
|
223
|
-
label = QLabel(name)
|
|
224
|
-
self.led = Led(self)
|
|
225
|
-
self.on_color = on_color
|
|
226
|
-
self.set_led_color(False)
|
|
227
|
-
|
|
228
|
-
layout = QHBoxLayout()
|
|
229
|
-
|
|
230
|
-
layout.addWidget(label)
|
|
231
|
-
layout.addWidget(self.led)
|
|
232
|
-
|
|
233
|
-
self.setLayout(layout)
|
|
234
|
-
|
|
235
|
-
def set_on_color(self, on_color: Indic):
|
|
236
|
-
""" Set the colour that the led should have when turned on.
|
|
237
|
-
|
|
238
|
-
Args:
|
|
239
|
-
- on_color: Colour the led should have when turned on.
|
|
240
|
-
"""
|
|
241
|
-
|
|
242
|
-
self.on_color = on_color
|
|
243
|
-
|
|
244
|
-
def set_led_color(self, status: bool):
|
|
245
|
-
""" Change the colour of the led.
|
|
246
|
-
|
|
247
|
-
Args:
|
|
248
|
-
- status: Indicates whether the led should be turned on.
|
|
249
|
-
"""
|
|
250
|
-
|
|
251
|
-
if status:
|
|
252
|
-
|
|
253
|
-
self.led.set_color(self.on_color)
|
|
254
|
-
|
|
255
|
-
else:
|
|
256
|
-
|
|
257
|
-
self.led.set_color(Indic.BLACK)
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
class AEUUIView(QMainWindow, Observable):
|
|
261
|
-
|
|
262
|
-
def __init__(self):
|
|
263
|
-
""" Initialisation of the AEU GUI.
|
|
264
|
-
|
|
265
|
-
In the current implementation, the GUI reflects the front panel of the UI, showing the following status
|
|
266
|
-
information:
|
|
267
|
-
|
|
268
|
-
- EGSE (operating) mode;
|
|
269
|
-
- camera selection: N-CAM vs. F-CAM;
|
|
270
|
-
- output status of the the six power lines (V_CCD, V_CLK, V_AN1, V_AN2, V_AN3, and V_DIG);
|
|
271
|
-
- error detection: secondary voltage/current out-of-range & synchronisation generator failure;
|
|
272
|
-
- Clk signals selection: Clk_N_50MHz, Clk_N_ccdread, Clk_F_50MHz_nom, Clk_F_50MHz_red, Clk_F_ccdread_nom,
|
|
273
|
-
Clk_F_ccdread_red, Clk_TCS_50MHz_nom, Clk_TCS_50MHz_red, Clk_heater_nom, Clk_heater_red, and test port.
|
|
274
|
-
"""
|
|
275
|
-
|
|
276
|
-
super().__init__()
|
|
277
|
-
|
|
278
|
-
self.setGeometry(300, 300, 300, 200)
|
|
279
|
-
self.setWindowTitle("Ancillary Electrical Units (AEU)")
|
|
280
|
-
|
|
281
|
-
self.widgets = {}
|
|
282
|
-
self.connected_pix, self.disconnected_pix, self.connection_status_icon = None, None, None
|
|
283
|
-
|
|
284
|
-
self.monitoring_thread = QThread(self)
|
|
285
|
-
self.monitoring_worker = MonitoringWorker()
|
|
286
|
-
self.monitoring_worker.moveToThread(self.monitoring_thread)
|
|
287
|
-
|
|
288
|
-
self.monitoring_worker.common_led_status_signal.connect(self.on_common_led_status_changed_signal)
|
|
289
|
-
self.monitoring_worker.hide_clk_signal.connect(self.on_hide_clk_signal)
|
|
290
|
-
self.monitoring_worker.n_cam_clk_led_status_signal.connect(self.on_n_cam_clk_led_status_changed_signal)
|
|
291
|
-
self.monitoring_worker.f_cam_clk_led_status_signal.connect(self.on_f_cam_clk_led_status_changed_signal)
|
|
292
|
-
|
|
293
|
-
self.monitoring_thread.started.connect(self.monitoring_worker.start_process)
|
|
294
|
-
self.monitoring_thread.start()
|
|
295
|
-
|
|
296
|
-
self.reconnect_action = None
|
|
297
|
-
self.n_cam_clk_signals_selection_widget = QGroupBox("", self)
|
|
298
|
-
self.f_cam_clk_signals_selection_widget = QGroupBox("", self)
|
|
299
|
-
self.tcs_clk_signals_selection_widget = QGroupBox("", self)
|
|
300
|
-
|
|
301
|
-
self.init_ui()
|
|
302
|
-
|
|
303
|
-
def init_ui(self):
|
|
304
|
-
""" Put the components in the GUI window.
|
|
305
|
-
|
|
306
|
-
The GUI comprises the following components:
|
|
307
|
-
|
|
308
|
-
- leds representing the EGSE mode;
|
|
309
|
-
- leds representing the camera selection;
|
|
310
|
-
- leds representing the power lines:
|
|
311
|
-
- leds representing the error detection;
|
|
312
|
-
- leds representing the Clk signals selection.
|
|
313
|
-
"""
|
|
314
|
-
|
|
315
|
-
app_frame = QFrame()
|
|
316
|
-
app_frame.setObjectName("AppFrame")
|
|
317
|
-
|
|
318
|
-
self.create_toolbar()
|
|
319
|
-
|
|
320
|
-
# self.widgets = {}
|
|
321
|
-
|
|
322
|
-
for key, label in RELEVANT_COMMON_KEYS.items():
|
|
323
|
-
|
|
324
|
-
self.widgets[key] = LedWidget(label)
|
|
325
|
-
self.widgets[key].setFixedHeight(50)
|
|
326
|
-
|
|
327
|
-
for key in RELEVANT_N_CAM_KEYS + RELEVANT_F_CAM_KEYS:
|
|
328
|
-
|
|
329
|
-
self.widgets[key] = LedWidget(key)
|
|
330
|
-
self.widgets[key].setFixedHeight(50)
|
|
331
|
-
|
|
332
|
-
self.widgets["S_voltage_oor"].set_on_color(Indic.RED)
|
|
333
|
-
self.widgets["S_current_oor"].set_on_color(Indic.RED)
|
|
334
|
-
self.widgets["Sync_gf"].set_on_color(Indic.RED)
|
|
335
|
-
|
|
336
|
-
layout = QHBoxLayout()
|
|
337
|
-
|
|
338
|
-
# EGSE mode
|
|
339
|
-
|
|
340
|
-
egse_mode_layout = QVBoxLayout()
|
|
341
|
-
egse_mode_widget = QGroupBox("EGSE mode", self)
|
|
342
|
-
|
|
343
|
-
egse_mode_layout.addWidget(self.widgets["Standby"])
|
|
344
|
-
egse_mode_layout.addWidget(self.widgets["Selftest"])
|
|
345
|
-
egse_mode_layout.addWidget(self.widgets["FC_TVAC"])
|
|
346
|
-
egse_mode_layout.addWidget(self.widgets["Alignment"])
|
|
347
|
-
|
|
348
|
-
egse_mode_widget.setLayout(egse_mode_layout)
|
|
349
|
-
|
|
350
|
-
# Camera selection
|
|
351
|
-
|
|
352
|
-
cam_selection_layout = QVBoxLayout()
|
|
353
|
-
cam_selection_widget = QGroupBox("Camera selection", self)
|
|
354
|
-
|
|
355
|
-
cam_selection_layout.addWidget(self.widgets["N-CAM"])
|
|
356
|
-
cam_selection_layout.addWidget(self.widgets["F-CAM"])
|
|
357
|
-
|
|
358
|
-
cam_selection_widget.setLayout(cam_selection_layout)
|
|
359
|
-
|
|
360
|
-
# Power lines
|
|
361
|
-
|
|
362
|
-
power_lines_layout = QGridLayout()
|
|
363
|
-
power_lines_widget = QGroupBox("Power lines", self)
|
|
364
|
-
|
|
365
|
-
power_lines_layout.addWidget(self.widgets["V_CCD"], 0, 0)
|
|
366
|
-
power_lines_layout.addWidget(self.widgets["V_CLK"], 1, 0)
|
|
367
|
-
power_lines_layout.addWidget(self.widgets["V_AN1"], 2, 0)
|
|
368
|
-
power_lines_layout.addWidget(self.widgets["V_AN2"], 0, 1)
|
|
369
|
-
power_lines_layout.addWidget(self.widgets["V_AN3"], 1, 1)
|
|
370
|
-
power_lines_layout.addWidget(self.widgets["V_DIG"], 2, 1)
|
|
371
|
-
|
|
372
|
-
power_lines_widget.setLayout(power_lines_layout)
|
|
373
|
-
|
|
374
|
-
# Error detection
|
|
375
|
-
|
|
376
|
-
error_detection_layout = QVBoxLayout()
|
|
377
|
-
error_detection_widget = QGroupBox("Error detection", self)
|
|
378
|
-
|
|
379
|
-
error_detection_layout.addWidget(self.widgets["S_voltage_oor"])
|
|
380
|
-
error_detection_layout.addWidget(self.widgets["S_current_oor"])
|
|
381
|
-
error_detection_layout.addWidget(self.widgets["Sync_gf"])
|
|
382
|
-
|
|
383
|
-
error_detection_widget.setLayout(error_detection_layout)
|
|
384
|
-
|
|
385
|
-
# Clk signals selection
|
|
386
|
-
|
|
387
|
-
clk_signals_selection_layout = QVBoxLayout()
|
|
388
|
-
clk_signals_selection_widget = QGroupBox("Clk signals selection", self)
|
|
389
|
-
|
|
390
|
-
n_cam_clk_signals_selection_layout = QHBoxLayout()
|
|
391
|
-
f_cam_clk_signals_selection_layout = QGridLayout()
|
|
392
|
-
tcs_clk_signals_selection_layout = QGridLayout()
|
|
393
|
-
|
|
394
|
-
n_cam_clk_signals_selection_layout.addWidget(self.widgets["Clk_N_50MHz"])
|
|
395
|
-
n_cam_clk_signals_selection_layout.addWidget(self.widgets["Clk_N_ccdread"])
|
|
396
|
-
|
|
397
|
-
f_cam_clk_signals_selection_layout.addWidget(self.widgets["Clk_F_50MHz_nom"], 0, 0)
|
|
398
|
-
f_cam_clk_signals_selection_layout.addWidget(self.widgets["Clk_F_50MHz_red"], 0, 1)
|
|
399
|
-
f_cam_clk_signals_selection_layout.addWidget(self.widgets["Clk_F_ccdread_nom"], 1, 0)
|
|
400
|
-
f_cam_clk_signals_selection_layout.addWidget(self.widgets["Clk_F_ccdread_red"], 1, 1)
|
|
401
|
-
|
|
402
|
-
tcs_clk_signals_selection_layout.addWidget(self.widgets["Clk_TCS_50MHz_nom"], 0, 0)
|
|
403
|
-
tcs_clk_signals_selection_layout.addWidget(self.widgets["Clk_TCS_50MHz_red"], 0, 1)
|
|
404
|
-
tcs_clk_signals_selection_layout.addWidget(self.widgets["Clk_heater_nom"], 1, 0)
|
|
405
|
-
tcs_clk_signals_selection_layout.addWidget(self.widgets["Clk_heater_red"], 1, 1)
|
|
406
|
-
|
|
407
|
-
self.n_cam_clk_signals_selection_widget.setLayout(n_cam_clk_signals_selection_layout)
|
|
408
|
-
self.f_cam_clk_signals_selection_widget.setLayout(f_cam_clk_signals_selection_layout)
|
|
409
|
-
self.tcs_clk_signals_selection_widget.setLayout(tcs_clk_signals_selection_layout)
|
|
410
|
-
|
|
411
|
-
clk_signals_selection_layout.addWidget(self.n_cam_clk_signals_selection_widget)
|
|
412
|
-
clk_signals_selection_layout.addWidget(self.f_cam_clk_signals_selection_widget)
|
|
413
|
-
clk_signals_selection_layout.addWidget(self.tcs_clk_signals_selection_widget)
|
|
414
|
-
|
|
415
|
-
self.n_cam_clk_signals_selection_widget.setVisible(False)
|
|
416
|
-
self.f_cam_clk_signals_selection_widget.setVisible(False)
|
|
417
|
-
self.tcs_clk_signals_selection_widget.setVisible(False)
|
|
418
|
-
|
|
419
|
-
clk_signals_selection_layout.addWidget(self.widgets["TestPort"])
|
|
420
|
-
|
|
421
|
-
clk_signals_selection_widget.setLayout(clk_signals_selection_layout)
|
|
422
|
-
|
|
423
|
-
egse_mode_layout.addStretch(True)
|
|
424
|
-
cam_selection_layout.addStretch(True)
|
|
425
|
-
power_lines_layout.setRowStretch(3, 2)
|
|
426
|
-
error_detection_layout.addStretch(True)
|
|
427
|
-
clk_signals_selection_layout.addStretch(True)
|
|
428
|
-
|
|
429
|
-
layout.addWidget(egse_mode_widget)
|
|
430
|
-
layout.addWidget(cam_selection_widget)
|
|
431
|
-
layout.addWidget(power_lines_widget)
|
|
432
|
-
layout.addWidget(error_detection_widget)
|
|
433
|
-
layout.addWidget(clk_signals_selection_widget)
|
|
434
|
-
|
|
435
|
-
app_frame.setLayout(layout)
|
|
436
|
-
|
|
437
|
-
self.setCentralWidget(app_frame)
|
|
438
|
-
|
|
439
|
-
def create_toolbar(self):
|
|
440
|
-
""" Create toolbar showing the state of the connection with the device."""
|
|
441
|
-
|
|
442
|
-
connected_pix = QPixmap(str(find_file("connected-100.png", in_dir="images")))
|
|
443
|
-
disconnected_pix = QPixmap(str(find_file("disconnected-100.png", in_dir="images")))
|
|
444
|
-
reconnect_icon = QIcon()
|
|
445
|
-
reconnect_icon.addPixmap(connected_pix, QIcon.Normal, QIcon.On)
|
|
446
|
-
reconnect_icon.addPixmap(disconnected_pix, QIcon.Normal, QIcon.Off)
|
|
447
|
-
|
|
448
|
-
self.reconnect_action = QAction(reconnect_icon, "Reconnect", self)
|
|
449
|
-
self.reconnect_action.setToolTip("Reconnect")
|
|
450
|
-
self.reconnect_action.setCheckable(True)
|
|
451
|
-
self.reconnect_action.triggered.connect(self.on_click)
|
|
452
|
-
|
|
453
|
-
toolbar = self.addToolBar("MainToolbar")
|
|
454
|
-
toolbar.addAction(self.reconnect_action)
|
|
455
|
-
|
|
456
|
-
def on_common_led_status_changed_signal(self, monitoring_info: dict):
|
|
457
|
-
""" Update the status of the leds in case the common led status has changed.
|
|
458
|
-
|
|
459
|
-
Args:
|
|
460
|
-
- monitoring_info: Monitoring information regarding the EGSE mode, camera selection, power lines, and
|
|
461
|
-
error detection.
|
|
462
|
-
"""
|
|
463
|
-
|
|
464
|
-
if not self.reconnect_action.isChecked():
|
|
465
|
-
|
|
466
|
-
return
|
|
467
|
-
|
|
468
|
-
for name, status in monitoring_info.items():
|
|
469
|
-
|
|
470
|
-
self.widgets[name].set_led_color(status)
|
|
471
|
-
|
|
472
|
-
# self.set_connection_state(True)
|
|
473
|
-
|
|
474
|
-
def on_hide_clk_signal(self):
|
|
475
|
-
""" Hide the information about the clocks."""
|
|
476
|
-
|
|
477
|
-
if not self.reconnect_action.isChecked():
|
|
478
|
-
|
|
479
|
-
return
|
|
480
|
-
|
|
481
|
-
self.n_cam_clk_signals_selection_widget.setVisible(False)
|
|
482
|
-
self.f_cam_clk_signals_selection_widget.setVisible(False)
|
|
483
|
-
self.tcs_clk_signals_selection_widget.setVisible(False)
|
|
484
|
-
|
|
485
|
-
# self.set_connection_state(True)
|
|
486
|
-
|
|
487
|
-
def on_n_cam_clk_led_status_changed_signal(self, monitoring_info: dict):
|
|
488
|
-
""" Update the status of the leds in case the N-CAM Clk led status has changed.
|
|
489
|
-
|
|
490
|
-
When the given monitoring information is empty, the status of the N-CAM Clk is hidden.
|
|
491
|
-
|
|
492
|
-
Args:
|
|
493
|
-
- monitoring_info: Monitoring information regarding the N-CAM Clk signal selection. Empty when the N-CAM is
|
|
494
|
-
not selected.
|
|
495
|
-
"""
|
|
496
|
-
|
|
497
|
-
if not self.reconnect_action.isChecked():
|
|
498
|
-
|
|
499
|
-
return
|
|
500
|
-
|
|
501
|
-
if len(monitoring_info) == 0:
|
|
502
|
-
|
|
503
|
-
self.n_cam_clk_signals_selection_widget.setVisible(False)
|
|
504
|
-
self.tcs_clk_signals_selection_widget.setVisible(False)
|
|
505
|
-
|
|
506
|
-
else:
|
|
507
|
-
|
|
508
|
-
self.n_cam_clk_signals_selection_widget.setVisible(True)
|
|
509
|
-
self.tcs_clk_signals_selection_widget.setVisible(True)
|
|
510
|
-
|
|
511
|
-
for name, status in monitoring_info.items():
|
|
512
|
-
|
|
513
|
-
self.widgets[name].set_led_color(status)
|
|
514
|
-
|
|
515
|
-
# self.set_connection_state(True)
|
|
516
|
-
|
|
517
|
-
def on_f_cam_clk_led_status_changed_signal(self, monitoring_info: dict):
|
|
518
|
-
""" Update the status of the leds in case the F-CAM Clk led status has changed.
|
|
519
|
-
|
|
520
|
-
When the given monitoring information is empty, the status of the F-CAM Clk is hidden
|
|
521
|
-
|
|
522
|
-
Args:
|
|
523
|
-
- monitoring_info: Monitoring information regarding the F-CAM Clk signal selection. Empty when the F-CAM is
|
|
524
|
-
not selected.
|
|
525
|
-
"""
|
|
526
|
-
|
|
527
|
-
if not self.reconnect_action.isChecked():
|
|
528
|
-
|
|
529
|
-
return
|
|
530
|
-
|
|
531
|
-
if len(monitoring_info) == 0:
|
|
532
|
-
|
|
533
|
-
self.f_cam_clk_signals_selection_widget.setVisible(False)
|
|
534
|
-
self.tcs_clk_signals_selection_widget.setVisible(False)
|
|
535
|
-
|
|
536
|
-
else:
|
|
537
|
-
|
|
538
|
-
self.f_cam_clk_signals_selection_widget.setVisible(True)
|
|
539
|
-
self.tcs_clk_signals_selection_widget.setVisible(True)
|
|
540
|
-
|
|
541
|
-
for name, status in monitoring_info.items():
|
|
542
|
-
|
|
543
|
-
self.widgets[name].set_led_color(status)
|
|
544
|
-
|
|
545
|
-
# self.set_connection_state(True)
|
|
546
|
-
|
|
547
|
-
# def on_connection_lost_signal(self):
|
|
548
|
-
# """ Switch off all leds when the connection to the cRIO is lost."""
|
|
549
|
-
#
|
|
550
|
-
# print("Connection lost")
|
|
551
|
-
#
|
|
552
|
-
# self.disable_leds()
|
|
553
|
-
#
|
|
554
|
-
# # self.set_connection_state(False)
|
|
555
|
-
|
|
556
|
-
def disable_leds(self):
|
|
557
|
-
""" Disable all the leds."""
|
|
558
|
-
|
|
559
|
-
for led in self.widgets.values():
|
|
560
|
-
|
|
561
|
-
led.set_led_color(0)
|
|
562
|
-
|
|
563
|
-
def on_click(self):
|
|
564
|
-
""" Notify the observers in case of a click."""
|
|
565
|
-
sender = self.sender()
|
|
566
|
-
|
|
567
|
-
MODULE_LOGGER.log(0, f"sender.text() = {sender.text()}")
|
|
568
|
-
MODULE_LOGGER.log(0, f"sender.isChecked() = {sender.isChecked()}")
|
|
569
|
-
|
|
570
|
-
self.notifyObservers(sender)
|
|
571
|
-
|
|
572
|
-
def set_connection_state(self, is_connected):
|
|
573
|
-
""" Update the connection state in the toolbar.
|
|
574
|
-
|
|
575
|
-
Args:
|
|
576
|
-
- is_connected: Connection status to show.
|
|
577
|
-
"""
|
|
578
|
-
if is_connected:
|
|
579
|
-
|
|
580
|
-
self.reconnect_action.setChecked(True)
|
|
581
|
-
self.monitoring_worker.just_reconnected = True
|
|
582
|
-
|
|
583
|
-
elif not is_connected:
|
|
584
|
-
|
|
585
|
-
self.reconnect_action.setChecked(False)
|
|
586
|
-
self.disable_leds()
|
|
587
|
-
|
|
588
|
-
def closeEvent(self, close_event: QCloseEvent) -> None:
|
|
589
|
-
""" Make sure that all threads are stopped when the GUI is closed.
|
|
590
|
-
|
|
591
|
-
Args:
|
|
592
|
-
- close_event: Close event received when the GUI is closed.
|
|
593
|
-
"""
|
|
594
|
-
|
|
595
|
-
self.monitoring_worker.stop()
|
|
596
|
-
|
|
597
|
-
self.monitoring_thread.quit()
|
|
598
|
-
self.monitoring_thread.wait()
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
class AEUUIModel:
|
|
602
|
-
|
|
603
|
-
def __init__(self, aeu_type: str):
|
|
604
|
-
""" Initialisation of the mode, based on the given AEU cRIO type.
|
|
605
|
-
|
|
606
|
-
Allowed values are:
|
|
607
|
-
|
|
608
|
-
- proxy: to use the CRIOProxy;
|
|
609
|
-
- crio: to use the CRIOController;
|
|
610
|
-
- simulator: to use the CRIOSimulator.
|
|
611
|
-
|
|
612
|
-
Args:
|
|
613
|
-
- aeu_type: Type of AEU cRIO to use as UI model.
|
|
614
|
-
"""
|
|
615
|
-
|
|
616
|
-
self.type = aeu_type
|
|
617
|
-
|
|
618
|
-
# Proxy
|
|
619
|
-
|
|
620
|
-
if self.type == "proxy":
|
|
621
|
-
|
|
622
|
-
self.crio = CRIOProxy()
|
|
623
|
-
|
|
624
|
-
# Controller
|
|
625
|
-
|
|
626
|
-
elif self.type == "crio":
|
|
627
|
-
|
|
628
|
-
self.crio = CRIOController()
|
|
629
|
-
self.crio.connect()
|
|
630
|
-
|
|
631
|
-
# Simulator
|
|
632
|
-
|
|
633
|
-
elif self.type == "simulator":
|
|
634
|
-
|
|
635
|
-
self.crio = CRIOSimulator()
|
|
636
|
-
|
|
637
|
-
else:
|
|
638
|
-
|
|
639
|
-
raise ValueError(f"Unknown type of AEU cRIO implementation passed into the model: {type}")
|
|
640
|
-
|
|
641
|
-
if self.crio is not None:
|
|
642
|
-
|
|
643
|
-
MODULE_LOGGER.debug(f"AEU cRIO Controller initialized as {self.crio.__class__.__name__}")
|
|
644
|
-
|
|
645
|
-
def has_commands(self):
|
|
646
|
-
""" Check whether the AEU cRIO has commands.
|
|
647
|
-
|
|
648
|
-
Returns: True if the AEU cRIO has commands; False otherwise.
|
|
649
|
-
"""
|
|
650
|
-
|
|
651
|
-
if self.type == "proxy":
|
|
652
|
-
|
|
653
|
-
return self.crio.has_commands()
|
|
654
|
-
|
|
655
|
-
return True
|
|
656
|
-
|
|
657
|
-
def load_commands(self):
|
|
658
|
-
""" Load the commands for the CRIOProxy."""
|
|
659
|
-
|
|
660
|
-
if self.type == "proxy":
|
|
661
|
-
|
|
662
|
-
self.crio.load_commands()
|
|
663
|
-
|
|
664
|
-
def is_simulator(self):
|
|
665
|
-
""" Checks whether the AEU cRIO is a simulator.
|
|
666
|
-
|
|
667
|
-
Returns: True if the AEU cRIO is a simulator; False otherwise.
|
|
668
|
-
"""
|
|
669
|
-
|
|
670
|
-
return self.crio.is_simulator()
|
|
671
|
-
|
|
672
|
-
def is_connected(self):
|
|
673
|
-
""" Check whether the AEU cRIO is connected.
|
|
674
|
-
|
|
675
|
-
Returns: True if the AEU cRIO is connected; False otherwise.
|
|
676
|
-
"""
|
|
677
|
-
|
|
678
|
-
if self.type == "proxy":
|
|
679
|
-
|
|
680
|
-
return self.crio.is_cs_connected()
|
|
681
|
-
|
|
682
|
-
else:
|
|
683
|
-
|
|
684
|
-
return self.crio.is_connected()
|
|
685
|
-
|
|
686
|
-
def reconnect(self):
|
|
687
|
-
""" Reconnect the AEU cRIO.
|
|
688
|
-
|
|
689
|
-
Returns: True if the connection could be established; False otherwise.
|
|
690
|
-
"""
|
|
691
|
-
|
|
692
|
-
if self.type == "proxy":
|
|
693
|
-
|
|
694
|
-
self.crio.reconnect_cs()
|
|
695
|
-
|
|
696
|
-
return self.crio.is_cs_connected()
|
|
697
|
-
|
|
698
|
-
else:
|
|
699
|
-
|
|
700
|
-
self.crio.reconnect()
|
|
701
|
-
|
|
702
|
-
return self.crio.is_connected()
|
|
703
|
-
|
|
704
|
-
return False
|
|
705
|
-
|
|
706
|
-
def disconnect(self):
|
|
707
|
-
""" Disconnect the AEU cRIO Control Server."""
|
|
708
|
-
|
|
709
|
-
if self.type == "proxy":
|
|
710
|
-
|
|
711
|
-
self.crio.disconnect_cs()
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
class AEUUIController(Observer):
|
|
715
|
-
|
|
716
|
-
def __init__(self, model: AEUUIModel, view: AEUUIView):
|
|
717
|
-
|
|
718
|
-
self.model = model
|
|
719
|
-
self.view = view
|
|
720
|
-
self.view.addObserver(self)
|
|
721
|
-
|
|
722
|
-
# self.states_capture_timer = None
|
|
723
|
-
# self.timer_interval = 200
|
|
724
|
-
# self.create_timer()
|
|
725
|
-
|
|
726
|
-
if self.model.is_connected():
|
|
727
|
-
|
|
728
|
-
self.view.set_connection_state(True)
|
|
729
|
-
# self.start_timer()
|
|
730
|
-
|
|
731
|
-
else:
|
|
732
|
-
|
|
733
|
-
self.view.set_connection_state(False)
|
|
734
|
-
# self.stop_timer()
|
|
735
|
-
|
|
736
|
-
# def create_timer(self):
|
|
737
|
-
#
|
|
738
|
-
# print("Create timer")
|
|
739
|
-
# """Create a Timer that will update the States every second."""
|
|
740
|
-
#
|
|
741
|
-
# self.states_capture_timer = QTimer()
|
|
742
|
-
# # This is only needed when the Timer needs to run in another Thread
|
|
743
|
-
# # self.states_capture_timer.moveToThread(self)
|
|
744
|
-
# self.states_capture_timer.timeout.connect(self.update_connection_state)
|
|
745
|
-
# self.states_capture_timer.setInterval(self.timer_interval)
|
|
746
|
-
#
|
|
747
|
-
# def start_timer(self):
|
|
748
|
-
# print("Start timer")
|
|
749
|
-
# self.states_capture_timer.start()
|
|
750
|
-
#
|
|
751
|
-
# def stop_timer(self):
|
|
752
|
-
# print("Stop timer")
|
|
753
|
-
# self.states_capture_timer.stop()
|
|
754
|
-
#
|
|
755
|
-
# def update_connection_state(self):
|
|
756
|
-
# """Updates the common view widgets."""
|
|
757
|
-
#
|
|
758
|
-
# if not self.model.is_connected():
|
|
759
|
-
#
|
|
760
|
-
# self.view.set_connection_state(False)
|
|
761
|
-
|
|
762
|
-
def update(self, changed_object):
|
|
763
|
-
|
|
764
|
-
text = changed_object.text()
|
|
765
|
-
|
|
766
|
-
if text == "Reconnect":
|
|
767
|
-
|
|
768
|
-
if changed_object.isChecked():
|
|
769
|
-
|
|
770
|
-
MODULE_LOGGER.debug("Reconnecting the AEU model.")
|
|
771
|
-
|
|
772
|
-
if self.model.reconnect():
|
|
773
|
-
|
|
774
|
-
self.view.set_connection_state(True)
|
|
775
|
-
|
|
776
|
-
if not self.model.has_commands():
|
|
777
|
-
|
|
778
|
-
self.model.load_commands()
|
|
779
|
-
|
|
780
|
-
else:
|
|
781
|
-
self.view.reconnect_action.setChecked(False)
|
|
782
|
-
else:
|
|
783
|
-
|
|
784
|
-
MODULE_LOGGER.debug("Disconnecting the AEU model.")
|
|
785
|
-
self.model.disconnect()
|
|
786
|
-
self.view.set_connection_state(False)
|
|
787
|
-
|
|
788
|
-
return
|
|
789
|
-
|
|
790
|
-
def do(self):
|
|
791
|
-
|
|
792
|
-
pass
|
|
793
|
-
|
|
794
|
-
def parse_arguments():
|
|
795
|
-
"""
|
|
796
|
-
Prepare the arguments that are specific for this application.
|
|
797
|
-
"""
|
|
798
|
-
parser = argparse.ArgumentParser()
|
|
799
|
-
parser.add_argument(
|
|
800
|
-
"--type",
|
|
801
|
-
dest="type",
|
|
802
|
-
action="store",
|
|
803
|
-
choices={"proxy", "simulator", "crio"},
|
|
804
|
-
help="Specify AEU cRIO implementation you want to connect to.",
|
|
805
|
-
default="proxy",
|
|
806
|
-
)
|
|
807
|
-
parser.add_argument(
|
|
808
|
-
"--profile",
|
|
809
|
-
default=False,
|
|
810
|
-
action="store_true",
|
|
811
|
-
help="Enable info logging messages with method profile information.",
|
|
812
|
-
)
|
|
813
|
-
args = parser.parse_args()
|
|
814
|
-
return args
|
|
815
|
-
|
|
816
|
-
|
|
817
|
-
def main():
|
|
818
|
-
""" Main method to launch the AEU GUI."""
|
|
819
|
-
lock_file = QLockFile(str(Path("~/aeu_ui.app.lock").expanduser()))
|
|
820
|
-
|
|
821
|
-
args = list(sys.argv)
|
|
822
|
-
app = QApplication(args)
|
|
823
|
-
app.setWindowIcon(QIcon(str(get_resource(":/icons/aeu-cs.svg"))))
|
|
824
|
-
|
|
825
|
-
if lock_file.tryLock(100):
|
|
826
|
-
|
|
827
|
-
# process_status = ProcessStatus()
|
|
828
|
-
#
|
|
829
|
-
# timer_thread = threading.Thread(target=do_every, args=(10, process_status.update))
|
|
830
|
-
# timer_thread.daemon = True
|
|
831
|
-
# timer_thread.start()
|
|
832
|
-
#
|
|
833
|
-
# start_http_server(8541)
|
|
834
|
-
|
|
835
|
-
args = parse_arguments()
|
|
836
|
-
|
|
837
|
-
if args.profile:
|
|
838
|
-
Settings.set_profiling(True)
|
|
839
|
-
|
|
840
|
-
if args.type == "proxy":
|
|
841
|
-
proxy = CRIOProxy()
|
|
842
|
-
# if not proxy.ping():
|
|
843
|
-
# description = "Could not connect to Stages Control Server"
|
|
844
|
-
# info_text = (
|
|
845
|
-
# "The GUI will start, but the connection button will show a disconnected state. "
|
|
846
|
-
# "Please check if the Control Server is running and start the server if needed. "
|
|
847
|
-
# "Otherwise, check if the correct HOSTNAME for the control server is set in the "
|
|
848
|
-
# "Settings.yaml "
|
|
849
|
-
# "configuration file."
|
|
850
|
-
# )
|
|
851
|
-
#
|
|
852
|
-
# show_warning_message(description, info_text)
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
view = AEUUIView()
|
|
856
|
-
model = AEUUIModel(args.type)
|
|
857
|
-
controller = AEUUIController(model, view)
|
|
858
|
-
|
|
859
|
-
view.show()
|
|
860
|
-
sys.exit(app.exec_())
|
|
861
|
-
else:
|
|
862
|
-
error_message = QMessageBox()
|
|
863
|
-
error_message.setIcon(QMessageBox.Warning)
|
|
864
|
-
error_message.setWindowTitle("Error")
|
|
865
|
-
error_message.setText("The AEU GUI application is already running!")
|
|
866
|
-
error_message.setStandardButtons(QMessageBox.Ok)
|
|
867
|
-
|
|
868
|
-
return error_message.exec()
|
|
869
|
-
|
|
870
|
-
|
|
871
|
-
if __name__ == "__main__":
|
|
872
|
-
|
|
873
|
-
main()
|