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/hexapod/symetrie/puna_ui.py
DELETED
|
@@ -1,433 +0,0 @@
|
|
|
1
|
-
"""
|
|
2
|
-
A Graphical User Interface for monitoring and commanding the Symétrie Hexapod.
|
|
3
|
-
|
|
4
|
-
Start the GUI from your terminal as follows:
|
|
5
|
-
|
|
6
|
-
puna_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
|
-
import sys
|
|
20
|
-
import threading
|
|
21
|
-
from enum import IntEnum
|
|
22
|
-
from pathlib import Path
|
|
23
|
-
|
|
24
|
-
from PyQt5.QtCore import QLockFile
|
|
25
|
-
|
|
26
|
-
from egse.hexapod.symetrie import ControllerFactory
|
|
27
|
-
from egse.hexapod.symetrie import ProxyFactory
|
|
28
|
-
from egse.hexapod.symetrie import get_hexapod_controller_pars
|
|
29
|
-
from egse.hexapod.symetrie.punaplus import PunaPlusController
|
|
30
|
-
from egse.hexapod.symetrie.punaplus import PunaPlusProxy
|
|
31
|
-
|
|
32
|
-
multiprocessing.current_process().name = "puna_ui"
|
|
33
|
-
|
|
34
|
-
from PyQt5.QtGui import QIcon
|
|
35
|
-
from PyQt5.QtWidgets import QApplication, QMessageBox
|
|
36
|
-
from PyQt5.QtWidgets import QFrame
|
|
37
|
-
from PyQt5.QtWidgets import QHBoxLayout
|
|
38
|
-
from PyQt5.QtWidgets import QVBoxLayout
|
|
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.hexapod.symetrie.hexapod_ui import ActuatorStates
|
|
45
|
-
from egse.hexapod.symetrie.hexapod_ui import HexapodUIController
|
|
46
|
-
from egse.hexapod.symetrie.hexapod_ui import HexapodUIModel
|
|
47
|
-
from egse.hexapod.symetrie.hexapod_ui import HexapodUIView
|
|
48
|
-
from egse.hexapod.symetrie.puna import PunaSimulator
|
|
49
|
-
from egse.process import ProcessStatus
|
|
50
|
-
from egse.resource import get_resource
|
|
51
|
-
from egse.settings import Settings
|
|
52
|
-
from egse.system import do_every
|
|
53
|
-
|
|
54
|
-
MODULE_LOGGER = logging.getLogger(__name__)
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
class DeviceControllerType(IntEnum):
|
|
58
|
-
ALPHA = 0
|
|
59
|
-
ALPHA_PLUS = 1
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
DCT = DeviceControllerType
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
# Status LEDs define the number of status leds (length of the list), the description and the
|
|
66
|
-
# default color when the LED is on.
|
|
67
|
-
|
|
68
|
-
STATUS_LEDS_ALPHA = [
|
|
69
|
-
["Error", Indic.RED], # bit 0
|
|
70
|
-
["System Initialized", Indic.GREEN], # bit 1
|
|
71
|
-
["In position", Indic.GREEN], # bit 2
|
|
72
|
-
["Amplifier enabled", Indic.GREEN], # bit 3
|
|
73
|
-
["Homing done", Indic.GREEN], # bit 4
|
|
74
|
-
["Brake on", Indic.GREEN], # bit 5
|
|
75
|
-
["Emergency stop", Indic.ORANGE], # bit 6
|
|
76
|
-
["Warning FE", Indic.ORANGE], # bit 7
|
|
77
|
-
["Fatal FE", Indic.RED], # bit 8
|
|
78
|
-
["Actuator Limit Error", Indic.RED], # bit 9
|
|
79
|
-
["Amplifier Error", Indic.RED], # bit 10
|
|
80
|
-
["Encoder error", Indic.RED], # bit 11
|
|
81
|
-
["Phasing error", Indic.RED], # bit 12
|
|
82
|
-
["Homing error", Indic.RED], # bit 13
|
|
83
|
-
["Kinematic error", Indic.RED], # bit 14
|
|
84
|
-
["Abort input error", Indic.RED], # bit 15
|
|
85
|
-
["R/W memory error", Indic.RED], # bit 16
|
|
86
|
-
["Temperature error", Indic.RED], # bit 17
|
|
87
|
-
["Homing done (virtual)", Indic.ORANGE], # bit 18
|
|
88
|
-
["Encoders power off", Indic.ORANGE], # bit 19
|
|
89
|
-
["Limit switches power off", Indic.ORANGE], # bit 20
|
|
90
|
-
["Reserved", Indic.BLACK], # bit 21
|
|
91
|
-
["Reserved", Indic.BLACK], # bit 22
|
|
92
|
-
["Reserved", Indic.BLACK], # bit 23
|
|
93
|
-
]
|
|
94
|
-
|
|
95
|
-
STATUS_LEDS_ALPHA_PLUS = [
|
|
96
|
-
["Error", Indic.RED], # bit 0
|
|
97
|
-
["System Initialized", Indic.GREEN], # bit 1
|
|
98
|
-
["Control On", Indic.GREEN], # bit 2
|
|
99
|
-
["In Position", Indic.GREEN], # bit 3
|
|
100
|
-
["Motion Task Running", Indic.GREEN], # bit 4
|
|
101
|
-
["Home Task Running", Indic.GREEN], # bit 5
|
|
102
|
-
["Home Complete", Indic.GREEN], # bit 6
|
|
103
|
-
["Home Virtual", Indic.GREEN], # bit 7
|
|
104
|
-
["Phase Found", Indic.GREEN], # bit 8
|
|
105
|
-
["Brake on", Indic.GREEN], # bit 9
|
|
106
|
-
["Motion Restricted", Indic.RED], # bit 10
|
|
107
|
-
["Power on Encoders", Indic.GREEN], # bit 11
|
|
108
|
-
["Power on Limit switches", Indic.GREEN], # bit 12
|
|
109
|
-
["Power on Drives", Indic.GREEN], # bit 13
|
|
110
|
-
["Emergency Stop", Indic.RED], # bit 14
|
|
111
|
-
]
|
|
112
|
-
|
|
113
|
-
STATUS_LEDS = {
|
|
114
|
-
DCT.ALPHA: STATUS_LEDS_ALPHA,
|
|
115
|
-
DCT.ALPHA_PLUS: STATUS_LEDS_ALPHA_PLUS
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
# The index of the Control LED
|
|
119
|
-
|
|
120
|
-
CONTROL_ONOFF = {
|
|
121
|
-
DCT.ALPHA: 3,
|
|
122
|
-
DCT.ALPHA_PLUS: 2
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
ACTUATOR_STATE_LABELS_ALPHA = [
|
|
126
|
-
"In position",
|
|
127
|
-
"Control loop on servo motors active",
|
|
128
|
-
"Homing done",
|
|
129
|
-
"Input “Home switch”",
|
|
130
|
-
"Input “Positive limit switch”",
|
|
131
|
-
"Input “Negative limit switch”",
|
|
132
|
-
"Brake control output",
|
|
133
|
-
"Following error (warning)",
|
|
134
|
-
"Following error",
|
|
135
|
-
"Actuator out of bounds error",
|
|
136
|
-
"Amplifier error",
|
|
137
|
-
"Encoder error",
|
|
138
|
-
"Phasing error (brushless engine only)",
|
|
139
|
-
]
|
|
140
|
-
|
|
141
|
-
ACTUATOR_STATE_LABELS_ALPHA_PLUS = [
|
|
142
|
-
"Error: ",
|
|
143
|
-
"Control On: ",
|
|
144
|
-
"In Position: ",
|
|
145
|
-
"Motion Task Running: ",
|
|
146
|
-
"Home task running: ",
|
|
147
|
-
"Home complete: ",
|
|
148
|
-
"Phase found: ",
|
|
149
|
-
"Brake on: ",
|
|
150
|
-
"Home HW input: ",
|
|
151
|
-
"Negative HW limit switch: ",
|
|
152
|
-
"Positive HW limit switch: ",
|
|
153
|
-
"SW limit reached: ",
|
|
154
|
-
"Following Error: ",
|
|
155
|
-
"Drive fault: ",
|
|
156
|
-
"Encoder error: ",
|
|
157
|
-
]
|
|
158
|
-
|
|
159
|
-
ACTUATOR_STATE_LABELS = {
|
|
160
|
-
DCT.ALPHA: ACTUATOR_STATE_LABELS_ALPHA,
|
|
161
|
-
DCT.ALPHA_PLUS: ACTUATOR_STATE_LABELS_ALPHA_PLUS
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
GUI_SETTINGS = Settings.load("PUNA GUI")
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
class PunaUIView(HexapodUIView):
|
|
168
|
-
def __init__(self, device_controller_type: DCT, device_id: str):
|
|
169
|
-
super().__init__()
|
|
170
|
-
|
|
171
|
-
self.dct = device_controller_type
|
|
172
|
-
|
|
173
|
-
if self.dct == DCT.ALPHA:
|
|
174
|
-
title = f"Hexapod PUNA Controller (Alpha) – {device_id}"
|
|
175
|
-
else:
|
|
176
|
-
title = f"Hexapod PUNA Controller (Alpha+) – {device_id}"
|
|
177
|
-
|
|
178
|
-
self.setWindowTitle(title)
|
|
179
|
-
self.actuator_states = ActuatorStates(labels=ACTUATOR_STATE_LABELS[self.dct])
|
|
180
|
-
|
|
181
|
-
self.init_gui()
|
|
182
|
-
|
|
183
|
-
def init_gui(self):
|
|
184
|
-
|
|
185
|
-
# The main frame in which all the other frames are located, the outer Application frame
|
|
186
|
-
|
|
187
|
-
app_frame = QFrame()
|
|
188
|
-
app_frame.setObjectName("AppFrame")
|
|
189
|
-
|
|
190
|
-
# The left part which shows the states and positions
|
|
191
|
-
|
|
192
|
-
status_frame = QFrame()
|
|
193
|
-
status_frame.setObjectName("StatusFrame")
|
|
194
|
-
|
|
195
|
-
# The right part which has tabs that allow settings, movements, maintenance etc.
|
|
196
|
-
|
|
197
|
-
tabs_frame = QFrame()
|
|
198
|
-
tabs_frame.setObjectName("TabsFrame")
|
|
199
|
-
|
|
200
|
-
# The states of the Hexapod (contains all the leds)
|
|
201
|
-
|
|
202
|
-
states_frame = QFrame()
|
|
203
|
-
states_frame.setObjectName("StatesFrame")
|
|
204
|
-
|
|
205
|
-
# The user, machine positions and actuator lengths
|
|
206
|
-
|
|
207
|
-
positions_frame = QFrame()
|
|
208
|
-
positions_frame.setObjectName("PositionsFrame")
|
|
209
|
-
|
|
210
|
-
hbox = QHBoxLayout()
|
|
211
|
-
vbox_left = QVBoxLayout()
|
|
212
|
-
vbox_right = QVBoxLayout()
|
|
213
|
-
|
|
214
|
-
self.createToolbar()
|
|
215
|
-
self.createStatusBar()
|
|
216
|
-
|
|
217
|
-
self.states = States(STATUS_LEDS[self.dct])
|
|
218
|
-
|
|
219
|
-
user_positions_widget = self.createUserPositionWidget()
|
|
220
|
-
mach_positions_widget = self.createMachinePositionWidget()
|
|
221
|
-
actuator_length_widget = self.createActuatorLengthWidget()
|
|
222
|
-
|
|
223
|
-
vbox_right.addWidget(user_positions_widget)
|
|
224
|
-
vbox_right.addWidget(mach_positions_widget)
|
|
225
|
-
vbox_right.addWidget(actuator_length_widget)
|
|
226
|
-
|
|
227
|
-
positions_frame.setLayout(vbox_right)
|
|
228
|
-
|
|
229
|
-
vbox_left.addWidget(self.states)
|
|
230
|
-
|
|
231
|
-
states_frame.setLayout(vbox_left)
|
|
232
|
-
|
|
233
|
-
hbox.addWidget(states_frame)
|
|
234
|
-
hbox.addWidget(positions_frame)
|
|
235
|
-
|
|
236
|
-
status_frame.setLayout(hbox)
|
|
237
|
-
|
|
238
|
-
tabbed_widget = self.create_tabbed_widget()
|
|
239
|
-
|
|
240
|
-
hbox = QHBoxLayout()
|
|
241
|
-
hbox.addWidget(tabbed_widget)
|
|
242
|
-
tabs_frame.setLayout(hbox)
|
|
243
|
-
|
|
244
|
-
hbox = QHBoxLayout()
|
|
245
|
-
hbox.addWidget(status_frame)
|
|
246
|
-
hbox.addWidget(tabs_frame)
|
|
247
|
-
|
|
248
|
-
app_frame.setLayout(hbox)
|
|
249
|
-
|
|
250
|
-
self.setCentralWidget(app_frame)
|
|
251
|
-
|
|
252
|
-
def update_status_bar(self, message=None, mode=None, timeout=2000):
|
|
253
|
-
if message:
|
|
254
|
-
self.statusBar().showMessage(message, msecs=timeout)
|
|
255
|
-
if mode:
|
|
256
|
-
self.mode_label.setStyleSheet(
|
|
257
|
-
f"border: 0; " f"color: {'red' if 'Simulator' in mode else 'black'};"
|
|
258
|
-
)
|
|
259
|
-
self.mode_label.setText(f"mode: {mode}")
|
|
260
|
-
self.statusBar().repaint()
|
|
261
|
-
|
|
262
|
-
def updatePositions(self, userPositions, machinePositions, actuatorLengths):
|
|
263
|
-
|
|
264
|
-
if userPositions is None:
|
|
265
|
-
MODULE_LOGGER.warning("no userPositions passed into updatePositions(), returning.")
|
|
266
|
-
return
|
|
267
|
-
|
|
268
|
-
for upos in range(len(self.user_positions)):
|
|
269
|
-
try:
|
|
270
|
-
self.user_positions[upos][1].setText(f"{userPositions[upos]:10.4f}")
|
|
271
|
-
except IndexError:
|
|
272
|
-
MODULE_LOGGER.error(f"IndexError in user_positions, upos = {upos}")
|
|
273
|
-
|
|
274
|
-
if machinePositions is None:
|
|
275
|
-
MODULE_LOGGER.warning("no machinePositions passed into updatePositions(), returning.")
|
|
276
|
-
return
|
|
277
|
-
|
|
278
|
-
for mpos in range(len(self.mach_positions)):
|
|
279
|
-
self.mach_positions[mpos][1].setText(f"{machinePositions[mpos]:10.4f}")
|
|
280
|
-
|
|
281
|
-
if actuatorLengths is None:
|
|
282
|
-
MODULE_LOGGER.warning("no actuatorLengths passed into updatePositions(), returning.")
|
|
283
|
-
return
|
|
284
|
-
|
|
285
|
-
for idx, alen in enumerate(self.actuator_lengths):
|
|
286
|
-
alen[1].setText(f"{actuatorLengths[idx]:10.4f}")
|
|
287
|
-
|
|
288
|
-
def updateStates(self, states):
|
|
289
|
-
|
|
290
|
-
if states is None:
|
|
291
|
-
return
|
|
292
|
-
|
|
293
|
-
self.updateControlButton(states[CONTROL_ONOFF[self.dct]])
|
|
294
|
-
self.states.set_states(states)
|
|
295
|
-
|
|
296
|
-
def updateControlButton(self, flag):
|
|
297
|
-
|
|
298
|
-
self.control.set_selected(on=flag)
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
class PunaUIModel(HexapodUIModel):
|
|
302
|
-
def __init__(self, connection_type):
|
|
303
|
-
|
|
304
|
-
hostname, port, dev_id, dev_name, _ = get_hexapod_controller_pars()
|
|
305
|
-
if connection_type == "proxy":
|
|
306
|
-
device = ProxyFactory().create(dev_name, device_id=dev_id)
|
|
307
|
-
elif connection_type == "direct":
|
|
308
|
-
device = ControllerFactory().create(dev_name, device_id=dev_id)
|
|
309
|
-
device.connect()
|
|
310
|
-
elif connection_type == "simulator":
|
|
311
|
-
device = PunaSimulator()
|
|
312
|
-
else:
|
|
313
|
-
raise ValueError(
|
|
314
|
-
f"Unknown type of Hexapod implementation passed into the model: {connection_type}"
|
|
315
|
-
)
|
|
316
|
-
|
|
317
|
-
super().__init__(connection_type, device)
|
|
318
|
-
|
|
319
|
-
self._device_id = dev_id
|
|
320
|
-
|
|
321
|
-
if device is not None:
|
|
322
|
-
MODULE_LOGGER.debug(f"Hexapod initialized as {device.__class__.__name__}")
|
|
323
|
-
|
|
324
|
-
@property
|
|
325
|
-
def device_id(self):
|
|
326
|
-
return self._device_id
|
|
327
|
-
|
|
328
|
-
def get_device_controller_type(self) -> DCT:
|
|
329
|
-
return DCT.ALPHA_PLUS if isinstance(self.device, (PunaPlusProxy, PunaPlusController)) else DCT.ALPHA
|
|
330
|
-
|
|
331
|
-
def get_speed(self):
|
|
332
|
-
vt, vr, vt_min, vr_min, vt_max, vr_max = self.device.get_speed()
|
|
333
|
-
return vt, vr
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
class PunaUIController(HexapodUIController):
|
|
337
|
-
def __init__(self, model: PunaUIModel, view: PunaUIView):
|
|
338
|
-
super().__init__(model, view)
|
|
339
|
-
self.set_help_topic_home("puna_ui")
|
|
340
|
-
|
|
341
|
-
def update_values(self):
|
|
342
|
-
|
|
343
|
-
super().update_values()
|
|
344
|
-
|
|
345
|
-
# Add here any updates to PUNA specific widgets
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
def parse_arguments():
|
|
349
|
-
"""
|
|
350
|
-
Prepare the arguments that are specific for this application.
|
|
351
|
-
"""
|
|
352
|
-
parser = argparse.ArgumentParser()
|
|
353
|
-
parser.add_argument(
|
|
354
|
-
"--type",
|
|
355
|
-
dest="type",
|
|
356
|
-
action="store",
|
|
357
|
-
choices={"proxy", "simulator", "direct"},
|
|
358
|
-
help="Specify Hexapod implementation you want to connect to.",
|
|
359
|
-
default="proxy",
|
|
360
|
-
)
|
|
361
|
-
parser.add_argument(
|
|
362
|
-
"--profile",
|
|
363
|
-
default=False,
|
|
364
|
-
action="store_true",
|
|
365
|
-
help="Enable info logging messages with method profile information.",
|
|
366
|
-
)
|
|
367
|
-
return parser.parse_args()
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
def main():
|
|
371
|
-
lock_file = QLockFile(str(Path("~/puna_ui.app.lock").expanduser()))
|
|
372
|
-
|
|
373
|
-
styles_location = get_resource(":/styles/default.qss")
|
|
374
|
-
app_logo = get_resource(":/icons/logo-puna.svg")
|
|
375
|
-
|
|
376
|
-
args = list(sys.argv)
|
|
377
|
-
args[1:1] = ["-stylesheet", str(styles_location)]
|
|
378
|
-
app = QApplication(args)
|
|
379
|
-
app.setWindowIcon(QIcon(str(app_logo)))
|
|
380
|
-
|
|
381
|
-
if lock_file.tryLock(100):
|
|
382
|
-
|
|
383
|
-
process_status = ProcessStatus()
|
|
384
|
-
|
|
385
|
-
timer_thread = threading.Thread(target=do_every, args=(10, process_status.update))
|
|
386
|
-
timer_thread.daemon = True
|
|
387
|
-
timer_thread.start()
|
|
388
|
-
|
|
389
|
-
start_http_server(GUI_SETTINGS.METRICS_PORT)
|
|
390
|
-
|
|
391
|
-
args = parse_arguments()
|
|
392
|
-
|
|
393
|
-
if args.profile:
|
|
394
|
-
Settings.set_profiling(True)
|
|
395
|
-
|
|
396
|
-
if args.type == "proxy":
|
|
397
|
-
*_, device_id, device_name, _ = get_hexapod_controller_pars()
|
|
398
|
-
factory = ProxyFactory()
|
|
399
|
-
proxy = factory.create(device_name, device_id=device_id)
|
|
400
|
-
if not proxy.ping():
|
|
401
|
-
description = "Could not connect to Hexapod Control Server"
|
|
402
|
-
info_text = (
|
|
403
|
-
"The GUI will start, but the connection button will show a disconnected state. "
|
|
404
|
-
"Please check if the Control Server is running and start the server if needed. "
|
|
405
|
-
"Otherwise, check if the correct HOSTNAME for the control server is set in the "
|
|
406
|
-
"Settings.yaml "
|
|
407
|
-
"configuration file."
|
|
408
|
-
)
|
|
409
|
-
|
|
410
|
-
show_warning_message(description, info_text)
|
|
411
|
-
|
|
412
|
-
model = PunaUIModel(args.type)
|
|
413
|
-
view = PunaUIView(model.get_device_controller_type(), model.device_id)
|
|
414
|
-
PunaUIController(model, view)
|
|
415
|
-
|
|
416
|
-
view.show()
|
|
417
|
-
|
|
418
|
-
return app.exec_()
|
|
419
|
-
else:
|
|
420
|
-
error_message = QMessageBox()
|
|
421
|
-
error_message.setIcon(QMessageBox.Warning)
|
|
422
|
-
error_message.setWindowTitle("Error")
|
|
423
|
-
error_message.setText("The Puna GUI application is already running!")
|
|
424
|
-
error_message.setStandardButtons(QMessageBox.Ok)
|
|
425
|
-
|
|
426
|
-
return error_message.exec()
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
if __name__ == "__main__":
|
|
430
|
-
|
|
431
|
-
logging.basicConfig(level=logging.DEBUG, format=Settings.LOG_FORMAT_FULL)
|
|
432
|
-
|
|
433
|
-
sys.exit(main())
|
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
from egse.hexapod.symetrie import ControllerFactory
|
|
2
|
-
from egse.hexapod.symetrie import ProxyFactory
|
|
3
|
-
from egse.hexapod.symetrie import get_hexapod_controller_pars
|
|
4
|
-
from egse.hexapod.symetrie.dynalpha import AlphaPlusControllerInterface
|
|
5
|
-
from egse.hexapod.symetrie.dynalpha import AlphaPlusTelnetInterface
|
|
6
|
-
from egse.mixin import DynamicCommandMixin
|
|
7
|
-
from egse.proxy import DynamicProxy
|
|
8
|
-
from egse.settings import Settings
|
|
9
|
-
from egse.zmq_ser import connect_address
|
|
10
|
-
|
|
11
|
-
CTRL_SETTINGS = Settings.load("Hexapod PUNA Control Server")
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
class PunaPlusInterface(AlphaPlusControllerInterface):
|
|
15
|
-
"""
|
|
16
|
-
Interface definition for the PunaPlusController and the PunaPlusProxy.
|
|
17
|
-
"""
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
class PunaPlusController(PunaPlusInterface, DynamicCommandMixin):
|
|
21
|
-
def __init__(self, hostname: str = "127.0.0.1", port: int = 23):
|
|
22
|
-
self.transport = self.device = AlphaPlusTelnetInterface(hostname, port)
|
|
23
|
-
self.hostname = hostname
|
|
24
|
-
self.port = port
|
|
25
|
-
|
|
26
|
-
super().__init__()
|
|
27
|
-
|
|
28
|
-
def get_controller_type(self):
|
|
29
|
-
return "ALPHA+"
|
|
30
|
-
|
|
31
|
-
def is_simulator(self):
|
|
32
|
-
return False
|
|
33
|
-
|
|
34
|
-
def is_connected(self):
|
|
35
|
-
return self.device.is_connected()
|
|
36
|
-
|
|
37
|
-
def connect(self):
|
|
38
|
-
self.device.connect()
|
|
39
|
-
|
|
40
|
-
def disconnect(self):
|
|
41
|
-
self.device.disconnect()
|
|
42
|
-
|
|
43
|
-
def reconnect(self):
|
|
44
|
-
if self.is_connected():
|
|
45
|
-
self.disconnect()
|
|
46
|
-
self.connect()
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
class PunaPlusProxy(DynamicProxy, PunaPlusInterface):
|
|
50
|
-
"""
|
|
51
|
-
The PunaPlusProxy class is used to connect to the control server and send commands to the
|
|
52
|
-
Hexapod PUNA remotely. The devce controller for that PUNA hexapod is a Alpha+ controller.
|
|
53
|
-
"""
|
|
54
|
-
|
|
55
|
-
def __init__(
|
|
56
|
-
self,
|
|
57
|
-
protocol=CTRL_SETTINGS.PROTOCOL,
|
|
58
|
-
hostname=CTRL_SETTINGS.HOSTNAME,
|
|
59
|
-
port=CTRL_SETTINGS.COMMANDING_PORT,
|
|
60
|
-
):
|
|
61
|
-
"""
|
|
62
|
-
Args:
|
|
63
|
-
protocol: the transport protocol [default is taken from settings file]
|
|
64
|
-
hostname: location of the control server (IP address) [default is taken from settings
|
|
65
|
-
file]
|
|
66
|
-
port: TCP port on which the control server is listening for commands [default is
|
|
67
|
-
taken from settings file]
|
|
68
|
-
"""
|
|
69
|
-
super().__init__(connect_address(protocol, hostname, port))
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
if __name__ == "__main__":
|
|
73
|
-
|
|
74
|
-
from egse.hexapod.symetrie.puna import PunaProxy
|
|
75
|
-
|
|
76
|
-
# The following imports are needed for the isinstance() to work
|
|
77
|
-
from egse.hexapod.symetrie.punaplus import PunaPlusProxy
|
|
78
|
-
from egse.hexapod.symetrie.punaplus import PunaPlusController
|
|
79
|
-
|
|
80
|
-
print()
|
|
81
|
-
|
|
82
|
-
*_, device_id, device_name, _ = get_hexapod_controller_pars()
|
|
83
|
-
print(f"{device_name = }, {device_id = }")
|
|
84
|
-
|
|
85
|
-
factory = ProxyFactory()
|
|
86
|
-
proxy = factory.create(device_name, device_id="1A")
|
|
87
|
-
assert isinstance(proxy, PunaProxy)
|
|
88
|
-
|
|
89
|
-
proxy = factory.create(device_name, device_id="2B")
|
|
90
|
-
assert isinstance(proxy, PunaPlusProxy)
|
|
91
|
-
|
|
92
|
-
print(proxy.info())
|
|
93
|
-
|
|
94
|
-
factory = ControllerFactory()
|
|
95
|
-
|
|
96
|
-
device = factory.create("PUNA", device_id="H_2B")
|
|
97
|
-
device.connect()
|
|
98
|
-
assert isinstance(device, PunaPlusController)
|
|
99
|
-
|
|
100
|
-
print(device.info())
|
|
101
|
-
|
|
102
|
-
device = factory.create("ZONDA")
|
|
103
|
-
device.connect()
|
|
104
|
-
|
|
105
|
-
print(device.info())
|
|
106
|
-
|
|
107
|
-
device.disconnect()
|