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
|
@@ -1,449 +0,0 @@
|
|
|
1
|
-
"""
|
|
2
|
-
A Graphical User Interface for monitoring and commanding the Symétrie ZONDA Hexapod.
|
|
3
|
-
|
|
4
|
-
Start the GUI from your terminal as follows:
|
|
5
|
-
|
|
6
|
-
zonda_ui [--type proxy|direct|simulator]
|
|
7
|
-
|
|
8
|
-
This GUI is based on the SYM_positioning application from Symétrie. The intent
|
|
9
|
-
is to provide operators a user interface which is platform independent, but
|
|
10
|
-
familiar.
|
|
11
|
-
|
|
12
|
-
The application is completely written in Python/Qt5 and can therefore run on any
|
|
13
|
-
platform that supports Python and Qt5.
|
|
14
|
-
|
|
15
|
-
"""
|
|
16
|
-
import argparse
|
|
17
|
-
import logging
|
|
18
|
-
import multiprocessing
|
|
19
|
-
from pathlib import Path
|
|
20
|
-
|
|
21
|
-
import sys
|
|
22
|
-
import threading
|
|
23
|
-
from typing import List
|
|
24
|
-
|
|
25
|
-
multiprocessing.current_process().name = "zonda_ui"
|
|
26
|
-
|
|
27
|
-
import pyqtgraph as pg
|
|
28
|
-
from PyQt5.QtCore import QDateTime, QLockFile
|
|
29
|
-
from PyQt5.QtCore import Qt
|
|
30
|
-
from PyQt5.QtGui import QIcon
|
|
31
|
-
from PyQt5.QtWidgets import QApplication, QMessageBox
|
|
32
|
-
from PyQt5.QtWidgets import QFrame
|
|
33
|
-
from PyQt5.QtWidgets import QGroupBox
|
|
34
|
-
from PyQt5.QtWidgets import QHBoxLayout
|
|
35
|
-
from PyQt5.QtWidgets import QLabel
|
|
36
|
-
from PyQt5.QtWidgets import QLineEdit
|
|
37
|
-
from PyQt5.QtWidgets import QVBoxLayout
|
|
38
|
-
from PyQt5.QtWidgets import QWidget
|
|
39
|
-
from prometheus_client import start_http_server
|
|
40
|
-
|
|
41
|
-
from egse.gui import show_warning_message
|
|
42
|
-
from egse.gui.led import Indic
|
|
43
|
-
from egse.gui.states import States
|
|
44
|
-
from egse.gui.stripchart import StripChart
|
|
45
|
-
from egse.hexapod.symetrie.hexapod_ui import ActuatorStates
|
|
46
|
-
from egse.hexapod.symetrie.hexapod_ui import HexapodUIController
|
|
47
|
-
from egse.hexapod.symetrie.hexapod_ui import HexapodUIModel
|
|
48
|
-
from egse.hexapod.symetrie.hexapod_ui import HexapodUIView
|
|
49
|
-
from egse.hexapod.symetrie.zonda import ZondaController
|
|
50
|
-
from egse.hexapod.symetrie.zonda import ZondaProxy
|
|
51
|
-
from egse.hexapod.symetrie.zonda import ZondaSimulator
|
|
52
|
-
from egse.process import ProcessStatus
|
|
53
|
-
from egse.resource import get_resource
|
|
54
|
-
from egse.settings import Settings
|
|
55
|
-
from egse.system import do_every
|
|
56
|
-
|
|
57
|
-
MODULE_LOGGER = logging.getLogger(__name__)
|
|
58
|
-
|
|
59
|
-
# Status LEDs define the number of status leds (length of the list), the description and the
|
|
60
|
-
# default color when the LED is on.
|
|
61
|
-
|
|
62
|
-
STATUS_LEDS = [
|
|
63
|
-
["Error", Indic.RED], # bit 0
|
|
64
|
-
["System Initialized", Indic.GREEN], # bit 1
|
|
65
|
-
["Control On", Indic.GREEN], # bit 2
|
|
66
|
-
["In Position", Indic.GREEN], # bit 3
|
|
67
|
-
["Motion Task Running", Indic.GREEN], # bit 4
|
|
68
|
-
["Home Task Running", Indic.GREEN], # bit 5
|
|
69
|
-
["Home Complete", Indic.GREEN], # bit 6
|
|
70
|
-
["Home Virtual", Indic.GREEN], # bit 7
|
|
71
|
-
["Phase Found", Indic.GREEN], # bit 8
|
|
72
|
-
["Brake on", Indic.GREEN], # bit 9
|
|
73
|
-
["Motion Restricted", Indic.RED], # bit 10
|
|
74
|
-
["Power on Encoders", Indic.GREEN], # bit 11
|
|
75
|
-
["Power on Limit switches", Indic.GREEN], # bit 12
|
|
76
|
-
["Power on Drives", Indic.GREEN], # bit 13
|
|
77
|
-
["Emergency Stop", Indic.RED], # bit 14
|
|
78
|
-
]
|
|
79
|
-
|
|
80
|
-
# The index of the Control LED
|
|
81
|
-
|
|
82
|
-
CONTROL_ONOFF = 2
|
|
83
|
-
|
|
84
|
-
ACTUATOR_STATE_LABELS = [
|
|
85
|
-
"Error: ",
|
|
86
|
-
"Control On: ",
|
|
87
|
-
"In Position: ",
|
|
88
|
-
"Motion Task Running: ",
|
|
89
|
-
"Home task running: ",
|
|
90
|
-
"Home complete: ",
|
|
91
|
-
"Phase found: ",
|
|
92
|
-
"Brake on: ",
|
|
93
|
-
"Home HW input: ",
|
|
94
|
-
"Negative HW limit switch: ",
|
|
95
|
-
"Positive HW limit switch: ",
|
|
96
|
-
"SW limit reached: ",
|
|
97
|
-
"Following Error: ",
|
|
98
|
-
"Drive fault: ",
|
|
99
|
-
"Encoder error: ",
|
|
100
|
-
]
|
|
101
|
-
|
|
102
|
-
SPECIFIC_POSITIONS = ["Position ZERO", "Position RETRACTED"]
|
|
103
|
-
|
|
104
|
-
GUI_SETTINGS = Settings.load("ZONDA GUI")
|
|
105
|
-
|
|
106
|
-
class TemperatureLog(QWidget):
|
|
107
|
-
"""This Widget allows to view the temperature value of all six actuators."""
|
|
108
|
-
def __init__(self, temp: List[str] = None):
|
|
109
|
-
super().__init__()
|
|
110
|
-
|
|
111
|
-
self.stripchart = None
|
|
112
|
-
|
|
113
|
-
self.temperatures = temp
|
|
114
|
-
|
|
115
|
-
# Switch to using white background and black foreground for pyqtgraph stripcharts
|
|
116
|
-
|
|
117
|
-
pg.setConfigOption("background", "w")
|
|
118
|
-
pg.setConfigOption("foreground", "k")
|
|
119
|
-
|
|
120
|
-
vbox = QVBoxLayout()
|
|
121
|
-
vbox.addWidget(QLabel("Temperature values in C"))
|
|
122
|
-
vbox.setAlignment(Qt.AlignTop | Qt.AlignLeft)
|
|
123
|
-
|
|
124
|
-
self.create_temperature_stripchart_widget = self.create_temperature_stripchart()
|
|
125
|
-
vbox.addWidget(self.create_temperature_stripchart_widget)
|
|
126
|
-
|
|
127
|
-
self.create_temperature_box_widget = self.create_temperature_box()
|
|
128
|
-
vbox.addWidget(self.create_temperature_box_widget)
|
|
129
|
-
|
|
130
|
-
self.setLayout(vbox)
|
|
131
|
-
|
|
132
|
-
def create_temperature_box(self):
|
|
133
|
-
vbox = QVBoxLayout()
|
|
134
|
-
vbox.setSpacing(0)
|
|
135
|
-
|
|
136
|
-
for box in range(6):
|
|
137
|
-
wbox = QHBoxLayout()
|
|
138
|
-
wbox.setSpacing(0)
|
|
139
|
-
wbox.addWidget(QLabel(f"Temp.{box + 1}: "))
|
|
140
|
-
wbox.setSpacing(0)
|
|
141
|
-
editbox = QLineEdit()
|
|
142
|
-
editbox.setReadOnly(True)
|
|
143
|
-
editbox.setFixedSize(80, 20)
|
|
144
|
-
wbox.setSpacing(0)
|
|
145
|
-
wbox.addWidget(editbox)
|
|
146
|
-
wbox.setSpacing(0)
|
|
147
|
-
vbox.addLayout(wbox)
|
|
148
|
-
vbox.setSpacing(0)
|
|
149
|
-
|
|
150
|
-
create_temperature_box = QGroupBox()
|
|
151
|
-
create_temperature_box.setLayout(vbox)
|
|
152
|
-
|
|
153
|
-
return create_temperature_box
|
|
154
|
-
|
|
155
|
-
def create_temperature_stripchart(self):
|
|
156
|
-
self.stripchart = StripChart(
|
|
157
|
-
labels={"left": ("measure", "C"), "bottom": ("Time", "d hh:mm:ss")}
|
|
158
|
-
)
|
|
159
|
-
self.stripchart.setInterval(60 * 60 * 12) # 12h of data
|
|
160
|
-
self.stripchart.set_yrange(0, 40)
|
|
161
|
-
|
|
162
|
-
vbox = QVBoxLayout()
|
|
163
|
-
vbox.addStretch(1)
|
|
164
|
-
vbox.addWidget(self.stripchart)
|
|
165
|
-
|
|
166
|
-
create_temperature_stripchart = QGroupBox()
|
|
167
|
-
create_temperature_stripchart.setLayout(vbox)
|
|
168
|
-
|
|
169
|
-
return create_temperature_stripchart
|
|
170
|
-
|
|
171
|
-
class ZondaUIView(HexapodUIView):
|
|
172
|
-
def __init__(self):
|
|
173
|
-
super().__init__()
|
|
174
|
-
|
|
175
|
-
self.setWindowTitle("Hexapod ZONDA Controller")
|
|
176
|
-
|
|
177
|
-
self.actuator_states = ActuatorStates(labels=ACTUATOR_STATE_LABELS)
|
|
178
|
-
|
|
179
|
-
self.temperature_log = TemperatureLog()
|
|
180
|
-
|
|
181
|
-
self.temperature_values = self.temperature_log.create_temperature_box_widget
|
|
182
|
-
self.temperature_values = self.temperature_values.findChildren(QLineEdit)
|
|
183
|
-
for temp in range(len(self.temperature_values)):
|
|
184
|
-
self.temperature_values[temp].setText("0.00")
|
|
185
|
-
|
|
186
|
-
self.temperature_stripchart = self.temperature_log.create_temperature_stripchart_widget
|
|
187
|
-
self.temperature_stripchart = self.temperature_stripchart.findChildren(StripChart)
|
|
188
|
-
self.temperature_stripchart = self.temperature_stripchart[0]
|
|
189
|
-
|
|
190
|
-
self.init_gui()
|
|
191
|
-
|
|
192
|
-
def init_gui(self):
|
|
193
|
-
|
|
194
|
-
# The main frame in which all the other frames are located, the outer Application frame
|
|
195
|
-
|
|
196
|
-
app_frame = QFrame()
|
|
197
|
-
app_frame.setObjectName("AppFrame")
|
|
198
|
-
|
|
199
|
-
# The left part which shows the states and positions
|
|
200
|
-
|
|
201
|
-
status_frame = QFrame()
|
|
202
|
-
status_frame.setObjectName("StatusFrame")
|
|
203
|
-
|
|
204
|
-
# The right part which has tabs that allow settings, movements, maintenance etc.
|
|
205
|
-
|
|
206
|
-
tabs_frame = QFrame()
|
|
207
|
-
tabs_frame.setObjectName("TabsFrame")
|
|
208
|
-
|
|
209
|
-
# The states of the Hexapod (contains all the leds)
|
|
210
|
-
|
|
211
|
-
states_frame = QFrame()
|
|
212
|
-
states_frame.setObjectName("StatesFrame")
|
|
213
|
-
|
|
214
|
-
# The user, machine positions and actuator lengths
|
|
215
|
-
|
|
216
|
-
positions_frame = QFrame()
|
|
217
|
-
positions_frame.setObjectName("PositionsFrame")
|
|
218
|
-
|
|
219
|
-
hbox = QHBoxLayout()
|
|
220
|
-
vbox_left = QVBoxLayout()
|
|
221
|
-
vbox_right = QVBoxLayout()
|
|
222
|
-
|
|
223
|
-
self.createToolbar()
|
|
224
|
-
self.createStatusBar()
|
|
225
|
-
|
|
226
|
-
self.states = States(STATUS_LEDS)
|
|
227
|
-
|
|
228
|
-
user_positions_widget = self.createUserPositionWidget()
|
|
229
|
-
mach_positions_widget = self.createMachinePositionWidget()
|
|
230
|
-
actuator_length_widget = self.createActuatorLengthWidget()
|
|
231
|
-
|
|
232
|
-
vbox_right.addWidget(user_positions_widget)
|
|
233
|
-
vbox_right.addWidget(mach_positions_widget)
|
|
234
|
-
vbox_right.addWidget(actuator_length_widget)
|
|
235
|
-
|
|
236
|
-
positions_frame.setLayout(vbox_right)
|
|
237
|
-
|
|
238
|
-
vbox_left.addWidget(self.states)
|
|
239
|
-
|
|
240
|
-
states_frame.setLayout(vbox_left)
|
|
241
|
-
|
|
242
|
-
hbox.addWidget(states_frame)
|
|
243
|
-
hbox.addWidget(positions_frame)
|
|
244
|
-
|
|
245
|
-
status_frame.setLayout(hbox)
|
|
246
|
-
|
|
247
|
-
tabbed_widget = self.create_tabbed_widget()
|
|
248
|
-
|
|
249
|
-
hbox = QHBoxLayout()
|
|
250
|
-
hbox.addWidget(tabbed_widget)
|
|
251
|
-
tabs_frame.setLayout(hbox)
|
|
252
|
-
|
|
253
|
-
hbox = QHBoxLayout()
|
|
254
|
-
hbox.addWidget(status_frame)
|
|
255
|
-
hbox.addWidget(tabs_frame)
|
|
256
|
-
|
|
257
|
-
app_frame.setLayout(hbox)
|
|
258
|
-
|
|
259
|
-
self.setCentralWidget(app_frame)
|
|
260
|
-
|
|
261
|
-
def update_status_bar(self, message=None, mode=None, timeout=2000):
|
|
262
|
-
if message:
|
|
263
|
-
self.statusBar().showMessage(message, msecs=timeout)
|
|
264
|
-
if mode:
|
|
265
|
-
self.mode_label.setStyleSheet(
|
|
266
|
-
f"border: 0; " f"color: {'red' if 'Simulator' in mode else 'black'};"
|
|
267
|
-
)
|
|
268
|
-
|
|
269
|
-
self.mode_label.setText(f"mode: {mode}")
|
|
270
|
-
self.statusBar().repaint()
|
|
271
|
-
|
|
272
|
-
def updatePositions(self, userPositions, machinePositions, actuatorLengths):
|
|
273
|
-
|
|
274
|
-
if userPositions is None:
|
|
275
|
-
MODULE_LOGGER.warning("no userPositions passed into updatePositions(), returning.")
|
|
276
|
-
return
|
|
277
|
-
|
|
278
|
-
for upos in range(len(self.user_positions)):
|
|
279
|
-
try:
|
|
280
|
-
self.user_positions[upos][1].setText(f"{userPositions[upos]:10.4f}")
|
|
281
|
-
except IndexError:
|
|
282
|
-
MODULE_LOGGER.error(f"IndexError in user_positions, upos = {upos}")
|
|
283
|
-
|
|
284
|
-
if machinePositions is None:
|
|
285
|
-
MODULE_LOGGER.warning("no machinePositions passed into updatePositions(), returning.")
|
|
286
|
-
return
|
|
287
|
-
|
|
288
|
-
for mpos in range(len(self.mach_positions)):
|
|
289
|
-
self.mach_positions[mpos][1].setText(f"{machinePositions[mpos]:10.4f}")
|
|
290
|
-
|
|
291
|
-
if actuatorLengths is None:
|
|
292
|
-
MODULE_LOGGER.warning("no actuatorLengths passed into updatePositions(), returning.")
|
|
293
|
-
return
|
|
294
|
-
|
|
295
|
-
for idx, alen in enumerate(self.actuator_lengths):
|
|
296
|
-
alen[1].setText(f"{actuatorLengths[idx]:10.4f}")
|
|
297
|
-
|
|
298
|
-
def updateStates(self, states):
|
|
299
|
-
|
|
300
|
-
if states is None:
|
|
301
|
-
return
|
|
302
|
-
|
|
303
|
-
self.updateControlButton(states[CONTROL_ONOFF])
|
|
304
|
-
self.states.set_states(states)
|
|
305
|
-
|
|
306
|
-
def updateControlButton(self, flag):
|
|
307
|
-
|
|
308
|
-
self.control.set_selected(on=flag)
|
|
309
|
-
|
|
310
|
-
def updateTemperature(self, temp):
|
|
311
|
-
if temp is None:
|
|
312
|
-
MODULE_LOGGER.warning("no temperature passed into updateTemperature(), returning.")
|
|
313
|
-
return
|
|
314
|
-
else:
|
|
315
|
-
#TODO: How to add the 6 temperature values to the stripchart?
|
|
316
|
-
value = temp[0]
|
|
317
|
-
self.temperature_stripchart.update(QDateTime.currentMSecsSinceEpoch(), value)
|
|
318
|
-
for t in range(len(self.temperature_values)):
|
|
319
|
-
self.temperature_values[t].setText(f"{temp[t]:10.4f}")
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
class ZondaUIModel(HexapodUIModel):
|
|
323
|
-
def __init__(self, connection_type):
|
|
324
|
-
|
|
325
|
-
if connection_type == "proxy":
|
|
326
|
-
device = ZondaProxy()
|
|
327
|
-
elif connection_type == "direct":
|
|
328
|
-
device = ZondaController()
|
|
329
|
-
device.connect()
|
|
330
|
-
elif connection_type == "simulator":
|
|
331
|
-
device = ZondaSimulator()
|
|
332
|
-
else:
|
|
333
|
-
raise ValueError(
|
|
334
|
-
f"Unknown type of Hexapod implementation passed into the model: {connection_type}"
|
|
335
|
-
)
|
|
336
|
-
|
|
337
|
-
super().__init__(connection_type, device)
|
|
338
|
-
|
|
339
|
-
if device is not None:
|
|
340
|
-
MODULE_LOGGER.debug(f"Hexapod initialized as {device.__class__.__name__}")
|
|
341
|
-
|
|
342
|
-
def get_speed(self):
|
|
343
|
-
speed_settings = self.device.get_speed()
|
|
344
|
-
return speed_settings["vt"], speed_settings["vr"]
|
|
345
|
-
|
|
346
|
-
def get_temperature(self):
|
|
347
|
-
temp = self.device.get_temperature()
|
|
348
|
-
return temp
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
class ZondaUIController(HexapodUIController):
|
|
352
|
-
def __init__(self, model: ZondaUIModel, view: ZondaUIView):
|
|
353
|
-
super().__init__(model, view)
|
|
354
|
-
self.set_help_topic_home("zonda_ui")
|
|
355
|
-
|
|
356
|
-
def update_values(self):
|
|
357
|
-
|
|
358
|
-
super().update_values()
|
|
359
|
-
|
|
360
|
-
# Add here any updates to ZONDA specific widgets
|
|
361
|
-
|
|
362
|
-
temp = self.model.get_temperature()
|
|
363
|
-
self.view.updateTemperature(temp)
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
def parse_arguments():
|
|
367
|
-
"""
|
|
368
|
-
Prepare the arguments that are specific for this application.
|
|
369
|
-
"""
|
|
370
|
-
parser = argparse.ArgumentParser()
|
|
371
|
-
parser.add_argument(
|
|
372
|
-
"--type",
|
|
373
|
-
dest="type",
|
|
374
|
-
action="store",
|
|
375
|
-
choices={"proxy", "simulator", "direct"},
|
|
376
|
-
help="Specify Hexapod implementation you want to connect to.",
|
|
377
|
-
default="proxy",
|
|
378
|
-
)
|
|
379
|
-
parser.add_argument(
|
|
380
|
-
"--profile",
|
|
381
|
-
default=False,
|
|
382
|
-
action="store_true",
|
|
383
|
-
help="Enable info logging messages with method profile information.",
|
|
384
|
-
)
|
|
385
|
-
return parser.parse_args()
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
def main():
|
|
389
|
-
lock_file = QLockFile(str(Path("~/zonda_ui.app.lock").expanduser()))
|
|
390
|
-
|
|
391
|
-
styles_location = get_resource(":/styles/default.qss")
|
|
392
|
-
app_logo = get_resource(":/icons/logo-zonda.svg")
|
|
393
|
-
|
|
394
|
-
args = list(sys.argv)
|
|
395
|
-
args[1:1] = ["-stylesheet", str(styles_location)]
|
|
396
|
-
app = QApplication(args)
|
|
397
|
-
app.setWindowIcon(QIcon(str(app_logo)))
|
|
398
|
-
|
|
399
|
-
if lock_file.tryLock(100):
|
|
400
|
-
|
|
401
|
-
process_status = ProcessStatus()
|
|
402
|
-
|
|
403
|
-
timer_thread = threading.Thread(target=do_every, args=(10, process_status.update))
|
|
404
|
-
timer_thread.daemon = True
|
|
405
|
-
timer_thread.start()
|
|
406
|
-
|
|
407
|
-
start_http_server(GUI_SETTINGS.METRICS_PORT)
|
|
408
|
-
|
|
409
|
-
args = parse_arguments()
|
|
410
|
-
|
|
411
|
-
if args.profile:
|
|
412
|
-
Settings.set_profiling(True)
|
|
413
|
-
|
|
414
|
-
if args.type == "proxy":
|
|
415
|
-
proxy = ZondaProxy()
|
|
416
|
-
if not proxy.ping():
|
|
417
|
-
description = "Could not connect to Hexapod Control Server"
|
|
418
|
-
info_text = (
|
|
419
|
-
"The GUI will start, but the connection button will show a disconnected state. "
|
|
420
|
-
"Please check if the Control Server is running and start the server if needed. "
|
|
421
|
-
"Otherwise, check if the correct HOSTNAME for the control server is set in the "
|
|
422
|
-
"Settings.yaml "
|
|
423
|
-
"configuration file."
|
|
424
|
-
)
|
|
425
|
-
|
|
426
|
-
show_warning_message(description, info_text)
|
|
427
|
-
|
|
428
|
-
view = ZondaUIView()
|
|
429
|
-
model = ZondaUIModel(args.type)
|
|
430
|
-
ZondaUIController(model, view)
|
|
431
|
-
|
|
432
|
-
view.show()
|
|
433
|
-
|
|
434
|
-
return app.exec_()
|
|
435
|
-
else:
|
|
436
|
-
error_message = QMessageBox()
|
|
437
|
-
error_message.setIcon(QMessageBox.Warning)
|
|
438
|
-
error_message.setWindowTitle("Error")
|
|
439
|
-
error_message.setText("The Zonda GUI application is already running!")
|
|
440
|
-
error_message.setStandardButtons(QMessageBox.Ok)
|
|
441
|
-
|
|
442
|
-
return error_message.exec()
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
if __name__ == "__main__":
|
|
446
|
-
|
|
447
|
-
logging.basicConfig(level=logging.DEBUG, format=Settings.LOG_FORMAT_FULL)
|
|
448
|
-
|
|
449
|
-
sys.exit(main())
|