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,414 +0,0 @@
|
|
|
1
|
-
import logging
|
|
2
|
-
import socket
|
|
3
|
-
import threading
|
|
4
|
-
from telnetlib import Telnet
|
|
5
|
-
from typing import List
|
|
6
|
-
|
|
7
|
-
import paramiko
|
|
8
|
-
import time
|
|
9
|
-
from time import sleep
|
|
10
|
-
|
|
11
|
-
from egse.device import DeviceTransport
|
|
12
|
-
from egse.settings import Settings
|
|
13
|
-
from egse.system import wait_until
|
|
14
|
-
|
|
15
|
-
logger = logging.getLogger(__name__)
|
|
16
|
-
ctrl_settings = Settings.load("ZONDA Controller")
|
|
17
|
-
|
|
18
|
-
RETURN_CODES = {
|
|
19
|
-
0: "Success.",
|
|
20
|
-
-1: "Undefined error.",
|
|
21
|
-
-10: "Wrong value for parameter at index 0.",
|
|
22
|
-
-11: "Wrong value for parameter at index 1.",
|
|
23
|
-
-12: "Wrong value for parameter at index 2.",
|
|
24
|
-
-13: "Wrong value for parameter at index 3.",
|
|
25
|
-
-14: "Wrong value for parameter at index 4.",
|
|
26
|
-
-15: "Wrong value for parameter at index 5.",
|
|
27
|
-
-16: "Wrong value for parameter at index 6.",
|
|
28
|
-
-17: "Wrong value for parameter at index 7.",
|
|
29
|
-
-18: "Wrong value for parameter at index 8.",
|
|
30
|
-
-19: "Wrong value for parameter at index 9.",
|
|
31
|
-
-20: "Wrong value for parameter at index 10.",
|
|
32
|
-
-21: "Wrong value for parameter at index 11.",
|
|
33
|
-
-22: "Wrong value for parameter at index 12.",
|
|
34
|
-
-23: "Wrong value for parameter at index 13.",
|
|
35
|
-
-24: "Wrong value for parameter at index 14.",
|
|
36
|
-
-25: "Wrong value for parameter at index 15.",
|
|
37
|
-
-26: "Wrong value for parameter at index 16.",
|
|
38
|
-
-27: "Wrong value for parameter at index 17.",
|
|
39
|
-
-28: "Wrong value for parameter at index 18.",
|
|
40
|
-
-29: "Wrong value for parameter at index 19.",
|
|
41
|
-
-30: "Unknown command number.",
|
|
42
|
-
-31: "This configuration command is a 'get' only type.",
|
|
43
|
-
-32: "This configuration command is a 'set' only type.",
|
|
44
|
-
-33: "The axis number do not correspond to an axis defined on the controller.",
|
|
45
|
-
-34: "A stop task is running.",
|
|
46
|
-
-35: "All motors need to be control on.",
|
|
47
|
-
-36: "All motors need to be control off.",
|
|
48
|
-
-37: "Emergency stop is pressed.",
|
|
49
|
-
-38: "A motion task is running.",
|
|
50
|
-
-39: "A home task is running.",
|
|
51
|
-
-40: "Requested move is not feasible.",
|
|
52
|
-
-41: "Power supply of limit switches is off.",
|
|
53
|
-
-42: "Power supply of encoders is off.",
|
|
54
|
-
-43: "A fatal error is present. This type of error needs a controller restart to be removed.",
|
|
55
|
-
-44: "An error is present, error reset is required.",
|
|
56
|
-
-45: "Home is not completed.",
|
|
57
|
-
-46: "Software option not available (can be linked to hardware configuration).",
|
|
58
|
-
-47: "Virtual home: file was created on another controller (different MAC address).",
|
|
59
|
-
-48: "Virtual home: some positions read in file are out of software limits.",
|
|
60
|
-
-49: "Virtual home: file data were stored while hexapod was moving.",
|
|
61
|
-
-50: "Virtual home: no data available.",
|
|
62
|
-
-51: "Command has been rejected because another action is running.",
|
|
63
|
-
-52: "Timeout waiting for home complete status.",
|
|
64
|
-
-53: "Timeout waiting for control on status.",
|
|
65
|
-
-54: "Timeout on motion program start.",
|
|
66
|
-
-55: "Timeout on home task start.",
|
|
67
|
-
-56: "Timeout on virtual home write file task.",
|
|
68
|
-
-57: "Timeout on virtual home delete file task.",
|
|
69
|
-
-58: "Timeout on virtual home read file task.",
|
|
70
|
-
-59: "Timeout on disk access verification task.",
|
|
71
|
-
-60: "Configuration file: save process failed.",
|
|
72
|
-
-61: "Configuration file: loaded file is empty.",
|
|
73
|
-
-62: "Configuration file: loaded data are corrupted.",
|
|
74
|
-
-63: "No access to the memory disk.",
|
|
75
|
-
-64: "File does not exist.",
|
|
76
|
-
-65: "Folder access failed.",
|
|
77
|
-
-66: "Creation of folder tree on the memory disk failed.",
|
|
78
|
-
-67: "Generation or write of the checksum failed.",
|
|
79
|
-
-68: "File read: no data or wrong data size.",
|
|
80
|
-
-69: "File read: no checksum.",
|
|
81
|
-
-70: "File read: incorrect checksum.",
|
|
82
|
-
-71: "File write: failed.",
|
|
83
|
-
-72: "File open: failed.",
|
|
84
|
-
-73: "File delete: failed.",
|
|
85
|
-
-74: "Get MAC address failed.",
|
|
86
|
-
-75: "NaN (Not a Number) or infinite value found.",
|
|
87
|
-
-76: "The coordinate system transformations are not initialized.",
|
|
88
|
-
-77: "A kinematic error is present.",
|
|
89
|
-
-78: "The motor phase process failed (phase search or phase set from position offset).",
|
|
90
|
-
-79: "The motor phase is not found.",
|
|
91
|
-
-80: "Timeout waiting for control off status.",
|
|
92
|
-
-81: "The requested kinematic mode (number) is not defined for the machine.",
|
|
93
|
-
-82: "Timeout waiting for phase found status.",
|
|
94
|
-
-1000: "Internal error: 'RET_Dev_CfS_NaNReturned'.",
|
|
95
|
-
-1001: "Internal error: 'RET_Dev_CfS_FctNotAvailableInKernel'.",
|
|
96
|
-
-1002: "Internal error: 'RET_Dev_CfS_UndefinedCfSType'.",
|
|
97
|
-
-1003: "Internal error: 'RET_Dev_CfS_FIO_UndefinedFioType'.",
|
|
98
|
-
-1004: "Internal error: 'RET_Dev_CfS_FIO_HomeFile_UndefinedAction'.",
|
|
99
|
-
-1005: "Internal error: 'RET_Dev_UndefinedEnumValue'.",
|
|
100
|
-
-1006: "Internal error: 'RET_Dev_LdataCmdStatusIsNegative'.",
|
|
101
|
-
-1007: "Internal error: 'RET_Dev_NumMotorsInCoord_Sup_DEF_aGrQ_SIZE'.",
|
|
102
|
-
-1008: "Internal error: 'RET_Dev_NumMotorsInCoord_WrongNumber'.",
|
|
103
|
-
-1009: "Internal error: 'RET_String_StrCat_DestSizeReached'.",
|
|
104
|
-
-1010: "Internal error: 'RET_String_LengthOverStringSize'.",
|
|
105
|
-
-1011: "Internal error: 'RET_String_AllCharShouldIntBetween_0_255'.",
|
|
106
|
-
-1012: "Internal error: 'RET_String_StrCpy_DestSizeReached'.",
|
|
107
|
-
-1013: "Internal error: 'RET_ErrAction_HomeReset'.",
|
|
108
|
-
-1014: "Internal error: 'RET_Home_StopReceivedWhileRunning'.",
|
|
109
|
-
-1015: "Internal error: 'RET_UndefinedKinAssembly'.",
|
|
110
|
-
-1016: "Internal error: 'RET_WrongPmcConfig'.",
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
class ZondaError(Exception):
|
|
115
|
-
pass
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
class ZondaSSHInterface(object):
|
|
119
|
-
def __init__(self):
|
|
120
|
-
self.client = None
|
|
121
|
-
self.gpascii_client = None
|
|
122
|
-
self.connected = False
|
|
123
|
-
self.ssh_output = None
|
|
124
|
-
self.ssh_error = None
|
|
125
|
-
self.verbose = False
|
|
126
|
-
self.ip = ctrl_settings.IP
|
|
127
|
-
|
|
128
|
-
self.semaphore = threading.Semaphore()
|
|
129
|
-
|
|
130
|
-
self.CommandReturns = RETURN_CODES
|
|
131
|
-
|
|
132
|
-
# Etablish the SSH connection with the controller and open gpascii
|
|
133
|
-
def connect(self, ip):
|
|
134
|
-
try:
|
|
135
|
-
# Paramiko.SSHClient can be used to make connections to the remote server and
|
|
136
|
-
# transfer files
|
|
137
|
-
logger.info("Establishing ssh connection with {}...".format(ip))
|
|
138
|
-
self.client = paramiko.SSHClient()
|
|
139
|
-
# Parsing an instance of the AutoAddPolicy to set_missing_host_key_policy() changes
|
|
140
|
-
# it to allow any host.
|
|
141
|
-
self.client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
|
|
142
|
-
self.client.connect(hostname=ip, port=22, username="root", password="deltatau",
|
|
143
|
-
timeout=5,
|
|
144
|
-
allow_agent=False, look_for_keys=False)
|
|
145
|
-
logger.warning("Connected to the server: {}".format(ip))
|
|
146
|
-
self.connected = True
|
|
147
|
-
except paramiko.AuthenticationException:
|
|
148
|
-
logger.warning("Authentication failed, please verify your credentials.")
|
|
149
|
-
return False
|
|
150
|
-
except paramiko.SSHException as sshException:
|
|
151
|
-
logger.warning("Could not establish SSH connection: %s" % sshException)
|
|
152
|
-
return False
|
|
153
|
-
except socket.timeout as e:
|
|
154
|
-
logger.warning("Connection timed out.")
|
|
155
|
-
return False
|
|
156
|
-
except Exception as e:
|
|
157
|
-
logger.warning("Exception in connecting to the server.")
|
|
158
|
-
logger.warning("Python says:", e)
|
|
159
|
-
self.client.close()
|
|
160
|
-
return False
|
|
161
|
-
|
|
162
|
-
self.gpascii_client = self.client.invoke_shell(term="vt100")
|
|
163
|
-
self.sendcommand("gpascii -2", 0.5)
|
|
164
|
-
self.sendcommand("echo7")
|
|
165
|
-
|
|
166
|
-
def is_connected(self):
|
|
167
|
-
return self.connected
|
|
168
|
-
|
|
169
|
-
# send a command through gpascii
|
|
170
|
-
def sendcommand(self, command, wait=0):
|
|
171
|
-
self.gpascii_client.send(command + "\r\n")
|
|
172
|
-
if self.verbose == True:
|
|
173
|
-
pass # print("Command send: {}".format(command))
|
|
174
|
-
|
|
175
|
-
if wait > 0:
|
|
176
|
-
sleep(wait)
|
|
177
|
-
|
|
178
|
-
# wait for response from gpascii
|
|
179
|
-
step = 0.1
|
|
180
|
-
time = 0
|
|
181
|
-
|
|
182
|
-
while True:
|
|
183
|
-
if self.gpascii_client.recv_ready():
|
|
184
|
-
break
|
|
185
|
-
if time > 2.0:
|
|
186
|
-
logger.warning("Command response timed out!")
|
|
187
|
-
return ""
|
|
188
|
-
sleep(step)
|
|
189
|
-
time += step
|
|
190
|
-
|
|
191
|
-
# get and clean response
|
|
192
|
-
response = self.gpascii_client.recv(2048)
|
|
193
|
-
response = response.decode()
|
|
194
|
-
response = response.replace(command, "")
|
|
195
|
-
response = response.replace("\r", "")
|
|
196
|
-
# response = response.replace("\n"," ")
|
|
197
|
-
response = response.replace("\x06", "")
|
|
198
|
-
|
|
199
|
-
# remove empty elements
|
|
200
|
-
cleaned = ""
|
|
201
|
-
lines = response.split("\n")
|
|
202
|
-
for line in lines:
|
|
203
|
-
if line == "" or line == " ":
|
|
204
|
-
lines.remove(line)
|
|
205
|
-
else:
|
|
206
|
-
cleaned += line + "\n"
|
|
207
|
-
|
|
208
|
-
# if self.verbose is True:
|
|
209
|
-
# print("Command rcv: {}".format(cleaned))
|
|
210
|
-
return cleaned
|
|
211
|
-
|
|
212
|
-
def cmd_decode(self, name, arguments=list()):
|
|
213
|
-
command = ""
|
|
214
|
-
|
|
215
|
-
if "JOG" in name:
|
|
216
|
-
command += "c_ax={} ".format(arguments[0])
|
|
217
|
-
arguments.pop(0)
|
|
218
|
-
|
|
219
|
-
# set cfg part
|
|
220
|
-
cfg = 1
|
|
221
|
-
if "?" in name:
|
|
222
|
-
cfg = 0
|
|
223
|
-
name = name.replace("?", "")
|
|
224
|
-
if "CFG_" in name:
|
|
225
|
-
command += "c_cfg={} ".format(cfg)
|
|
226
|
-
|
|
227
|
-
# create the parameters part of a command using the given arguments
|
|
228
|
-
for index in range(0, len(arguments)):
|
|
229
|
-
command += "c_par({})={} ".format(index, arguments[index])
|
|
230
|
-
|
|
231
|
-
# finish command line
|
|
232
|
-
command += "c_cmd=C_{}".format(name)
|
|
233
|
-
|
|
234
|
-
# logger.debug("command sent: ", command)
|
|
235
|
-
return command
|
|
236
|
-
|
|
237
|
-
def cmd_check(self):
|
|
238
|
-
# sends "c_cmd" and returns the state of the command that has been previously sent.
|
|
239
|
-
Timer = 0
|
|
240
|
-
last = time.process_time()
|
|
241
|
-
|
|
242
|
-
# For a maximum of 5 sec
|
|
243
|
-
while Timer < 5:
|
|
244
|
-
|
|
245
|
-
# wait and count
|
|
246
|
-
time.sleep(0.1)
|
|
247
|
-
Timer += time.process_time() - last
|
|
248
|
-
last = time.process_time()
|
|
249
|
-
|
|
250
|
-
# ask for command state
|
|
251
|
-
response = self.sendcommand("c_cmd")
|
|
252
|
-
response.replace("\n", "")
|
|
253
|
-
|
|
254
|
-
if "=" in response:
|
|
255
|
-
# get value
|
|
256
|
-
elements = response.split("=", 1)
|
|
257
|
-
element = elements[1]
|
|
258
|
-
|
|
259
|
-
# exit if command is completed
|
|
260
|
-
if int(element) <= 0:
|
|
261
|
-
response = element
|
|
262
|
-
|
|
263
|
-
code = int(response)
|
|
264
|
-
|
|
265
|
-
if code < 0:
|
|
266
|
-
message = self.CommandReturns[code]
|
|
267
|
-
logger.warning("Command Error return: {} : {}".format(code, message))
|
|
268
|
-
elif code == 0:
|
|
269
|
-
message = "Command successful: 0, execution time {} sec".format(Timer)
|
|
270
|
-
# logger.info(message)
|
|
271
|
-
return [code, message]
|
|
272
|
-
logger.warning("Error: Order timed out !")
|
|
273
|
-
return [-1, "Error: Order timed out !"]
|
|
274
|
-
|
|
275
|
-
def p_check(self, number=20):
|
|
276
|
-
# ask the value of the command parameters
|
|
277
|
-
command = "c_par(0)"
|
|
278
|
-
if number > 1:
|
|
279
|
-
command += ",{},1".format(number)
|
|
280
|
-
|
|
281
|
-
answer = self.sendcommand(command)
|
|
282
|
-
return answer
|
|
283
|
-
|
|
284
|
-
def disconnect(self):
|
|
285
|
-
try:
|
|
286
|
-
logger.info("Closing ssh connection with {}...")
|
|
287
|
-
self.client.close()
|
|
288
|
-
self.gpascii_client.close()
|
|
289
|
-
self.connected = False
|
|
290
|
-
logger.warning("...disconnected from ssh".format(self.ip))
|
|
291
|
-
except Exception as e_exc:
|
|
292
|
-
raise ZondaError(f"Could not close socket to ") from e_exc
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
class ZondaTelnetInterface(DeviceTransport):
|
|
296
|
-
"""
|
|
297
|
-
The ZONDA Hexapod device interface based on the telnet protocol.
|
|
298
|
-
"""
|
|
299
|
-
|
|
300
|
-
TELNET_TIMEOUT = 0.5
|
|
301
|
-
|
|
302
|
-
def __init__(self):
|
|
303
|
-
self.telnet = Telnet()
|
|
304
|
-
self._is_connected = False
|
|
305
|
-
|
|
306
|
-
def connect(self, hostname: str):
|
|
307
|
-
self.telnet.open(hostname, 23)
|
|
308
|
-
self.telnet.read_until(b"login: ", timeout=self.TELNET_TIMEOUT)
|
|
309
|
-
self.telnet.write(b"root\r\n")
|
|
310
|
-
self.telnet.read_until(b"Password: ", timeout=self.TELNET_TIMEOUT)
|
|
311
|
-
self.telnet.write(b"deltatau\r\n")
|
|
312
|
-
self.telnet.read_until(b"ppmac# ", timeout=self.TELNET_TIMEOUT)
|
|
313
|
-
self.telnet.write(b"gpascii -2\r\n")
|
|
314
|
-
self.telnet.write(b"echo7\r\n")
|
|
315
|
-
self.telnet.read_until(b'\x06', timeout=self.TELNET_TIMEOUT)
|
|
316
|
-
self.telnet.read_very_eager()
|
|
317
|
-
self._is_connected = True
|
|
318
|
-
|
|
319
|
-
def is_connected(self):
|
|
320
|
-
return self._is_connected
|
|
321
|
-
|
|
322
|
-
def disconnect(self):
|
|
323
|
-
self.telnet.read_very_eager()
|
|
324
|
-
self.telnet.close()
|
|
325
|
-
self._is_connected = False
|
|
326
|
-
|
|
327
|
-
def check_command_status(self):
|
|
328
|
-
|
|
329
|
-
if wait_until(lambda: self.trans('c_cmd')[0] == '0', interval=0.01):
|
|
330
|
-
rc = int(self.trans('c_cmd')[0])
|
|
331
|
-
logger.warning(f"Command check: {RETURN_CODES[rc]} [{rc}]")
|
|
332
|
-
else:
|
|
333
|
-
rc = 0
|
|
334
|
-
|
|
335
|
-
return rc, RETURN_CODES[rc]
|
|
336
|
-
|
|
337
|
-
def get_pars(self, count: int = 20):
|
|
338
|
-
# ask the value of the command parameters
|
|
339
|
-
command = "c_par(0)"
|
|
340
|
-
if count > 1:
|
|
341
|
-
command += f",{count},1"
|
|
342
|
-
|
|
343
|
-
return self.trans(command)
|
|
344
|
-
|
|
345
|
-
def trans(self, cmd: str) -> List:
|
|
346
|
-
self.write(cmd)
|
|
347
|
-
response = self.read()
|
|
348
|
-
if response and response[0] == cmd:
|
|
349
|
-
return response[1:]
|
|
350
|
-
else:
|
|
351
|
-
return response
|
|
352
|
-
|
|
353
|
-
def read(self) -> List:
|
|
354
|
-
response = self.telnet.read_until(b'\x06\r\n', timeout=self.TELNET_TIMEOUT)
|
|
355
|
-
response = response.decode()
|
|
356
|
-
parts = response.split("\r\n")
|
|
357
|
-
if len(parts) == 1:
|
|
358
|
-
return []
|
|
359
|
-
if parts[-2] == '\x06':
|
|
360
|
-
return parts[:-2]
|
|
361
|
-
logger.warning("Expected ACK at the end of the response")
|
|
362
|
-
return parts
|
|
363
|
-
|
|
364
|
-
def write(self, cmd: str):
|
|
365
|
-
self.telnet.write(cmd.encode() + b"\r\n")
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
def decode_command(cmd_name: str, *args):
|
|
369
|
-
|
|
370
|
-
args = list(args)
|
|
371
|
-
cmd_name = cmd_name.upper()
|
|
372
|
-
|
|
373
|
-
full_command = ""
|
|
374
|
-
|
|
375
|
-
if "JOG" in cmd_name:
|
|
376
|
-
arg = args.pop(0)
|
|
377
|
-
full_command += f"c_ax={arg} "
|
|
378
|
-
|
|
379
|
-
# set cfg part
|
|
380
|
-
|
|
381
|
-
if "?" in cmd_name:
|
|
382
|
-
cmd_name = cmd_name.replace("?", "")
|
|
383
|
-
cfg = 0
|
|
384
|
-
else:
|
|
385
|
-
cfg = 1
|
|
386
|
-
|
|
387
|
-
if "CFG_" in cmd_name:
|
|
388
|
-
full_command += f"c_cfg={cfg} "
|
|
389
|
-
|
|
390
|
-
# create the parameters part of a full_command using the given arguments
|
|
391
|
-
|
|
392
|
-
for index, arg in enumerate(args):
|
|
393
|
-
full_command += f"c_par({index})={arg} "
|
|
394
|
-
|
|
395
|
-
# finish full_command line
|
|
396
|
-
|
|
397
|
-
full_command += f"c_cmd=C_{cmd_name}"
|
|
398
|
-
|
|
399
|
-
return full_command
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
if __name__ == "__main__":
|
|
403
|
-
import rich
|
|
404
|
-
|
|
405
|
-
zonda = ZondaTelnetInterface()
|
|
406
|
-
zonda.connect("192.168.56.10")
|
|
407
|
-
rich.print(zonda.trans("s_hexa,50,1"))
|
|
408
|
-
rich.print(zonda.trans("s_ax_1,6,1"))
|
|
409
|
-
rich.print(zonda.trans("s_pos_ax_1,6,1"))
|
|
410
|
-
rich.print(zonda.read())
|
|
411
|
-
zonda.disconnect()
|
|
412
|
-
|
|
413
|
-
print(decode_command("CFG_LIMIT?", 0))
|
|
414
|
-
print(decode_command("CFG_LIMIT", 1, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12))
|
|
@@ -1,123 +0,0 @@
|
|
|
1
|
-
import logging
|
|
2
|
-
|
|
3
|
-
from egse.command import ClientServerCommand
|
|
4
|
-
from egse.control import ControlServer
|
|
5
|
-
from egse.hexapod.symetrie.zonda import ZondaController
|
|
6
|
-
from egse.hexapod.symetrie.zonda import ZondaInterface
|
|
7
|
-
from egse.hexapod.symetrie.zonda import ZondaSimulator
|
|
8
|
-
from egse.hk import read_conversion_dict, convert_hk_names
|
|
9
|
-
from egse.metrics import define_metrics
|
|
10
|
-
from egse.protocol import CommandProtocol
|
|
11
|
-
from egse.settings import Settings
|
|
12
|
-
from egse.setup import load_setup
|
|
13
|
-
from egse.system import format_datetime
|
|
14
|
-
from egse.zmq_ser import bind_address
|
|
15
|
-
|
|
16
|
-
logger = logging.getLogger(__name__)
|
|
17
|
-
|
|
18
|
-
ctrl_settings = Settings.load("Hexapod ZONDA Control Server")
|
|
19
|
-
zonda_settings = Settings.load(filename="zonda.yaml")
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
class ZondaCommand(ClientServerCommand):
|
|
23
|
-
pass
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
class ZondaProtocol(CommandProtocol):
|
|
27
|
-
def __init__(self, control_server: ControlServer):
|
|
28
|
-
super().__init__()
|
|
29
|
-
|
|
30
|
-
self.control_server = control_server
|
|
31
|
-
setup = load_setup()
|
|
32
|
-
|
|
33
|
-
self.hk_conversion_table = read_conversion_dict(self.control_server.get_storage_mnemonic(), use_site=True,
|
|
34
|
-
setup=setup)
|
|
35
|
-
|
|
36
|
-
if Settings.simulation_mode():
|
|
37
|
-
self.hexapod = ZondaSimulator()
|
|
38
|
-
else:
|
|
39
|
-
self.hexapod = ZondaController()
|
|
40
|
-
|
|
41
|
-
self.hexapod.connect()
|
|
42
|
-
|
|
43
|
-
self.load_commands(zonda_settings.Commands, ZondaCommand, ZondaInterface)
|
|
44
|
-
|
|
45
|
-
self.build_device_method_lookup_table(self.hexapod)
|
|
46
|
-
|
|
47
|
-
self.metrics = define_metrics("ZONDA", setup=setup)
|
|
48
|
-
|
|
49
|
-
def get_bind_address(self):
|
|
50
|
-
return bind_address(
|
|
51
|
-
self.control_server.get_communication_protocol(),
|
|
52
|
-
self.control_server.get_commanding_port(),
|
|
53
|
-
)
|
|
54
|
-
|
|
55
|
-
def get_status(self):
|
|
56
|
-
|
|
57
|
-
status = super().get_status()
|
|
58
|
-
|
|
59
|
-
mach_positions = self.hexapod.get_machine_positions()
|
|
60
|
-
user_positions = self.hexapod.get_user_positions()
|
|
61
|
-
actuator_length = self.hexapod.get_actuator_length()
|
|
62
|
-
|
|
63
|
-
status.update({"mach": mach_positions, "user": user_positions, "alength": actuator_length})
|
|
64
|
-
|
|
65
|
-
return status
|
|
66
|
-
|
|
67
|
-
def get_housekeeping(self) -> dict:
|
|
68
|
-
|
|
69
|
-
result = dict()
|
|
70
|
-
result["timestamp"] = format_datetime()
|
|
71
|
-
|
|
72
|
-
mach_positions = self.hexapod.get_machine_positions()
|
|
73
|
-
user_positions = self.hexapod.get_user_positions()
|
|
74
|
-
actuator_length = self.hexapod.get_actuator_length()
|
|
75
|
-
actuator_temperature = self.hexapod.get_temperature()
|
|
76
|
-
|
|
77
|
-
# TODO If you change these names, please, also change them in egse.fov.fov_hk!
|
|
78
|
-
for idx, key in enumerate(
|
|
79
|
-
["user_t_x", "user_t_y", "user_t_z", "user_r_x", "user_r_y", "user_r_z"]
|
|
80
|
-
):
|
|
81
|
-
result[key] = user_positions[idx]
|
|
82
|
-
|
|
83
|
-
for idx, key in enumerate(
|
|
84
|
-
["mach_t_x", "mach_t_y", "mach_t_z", "mach_r_x", "mach_r_y", "mach_r_z"]
|
|
85
|
-
):
|
|
86
|
-
result[key] = mach_positions[idx]
|
|
87
|
-
|
|
88
|
-
for idx, key in enumerate(
|
|
89
|
-
["alen_t_x", "alen_t_y", "alen_t_z", "alen_r_x", "alen_r_y", "alen_r_z"]
|
|
90
|
-
):
|
|
91
|
-
result[key] = actuator_length[idx]
|
|
92
|
-
|
|
93
|
-
for idx, key in enumerate(
|
|
94
|
-
["atemp_1", "atemp_2", "atemp_3", "atemp_4", "atemp_5", "atemp_6"]
|
|
95
|
-
):
|
|
96
|
-
result[key] = actuator_temperature[idx]
|
|
97
|
-
|
|
98
|
-
# # TODO:
|
|
99
|
-
# # the get_general_state() method should be refactored as to return a dict instead of a
|
|
100
|
-
# # list. Also, we might want to rethink the usefulness of returning the tuple,
|
|
101
|
-
# # it the first return value ever used?
|
|
102
|
-
#
|
|
103
|
-
# _, _ = self.hexapod.get_general_state()
|
|
104
|
-
#
|
|
105
|
-
result["Homing done"] = self.hexapod.is_homing_done()
|
|
106
|
-
result["In position"] = self.hexapod.is_in_position()
|
|
107
|
-
|
|
108
|
-
hk_dict = convert_hk_names(result, self.hk_conversion_table)
|
|
109
|
-
|
|
110
|
-
for key, value in hk_dict.items():
|
|
111
|
-
if key != "timestamp":
|
|
112
|
-
self.metrics[key].set(value)
|
|
113
|
-
|
|
114
|
-
return hk_dict
|
|
115
|
-
|
|
116
|
-
def is_connected(self):
|
|
117
|
-
# FIXME(rik): There must be another way to check if the socket is still alive...
|
|
118
|
-
# This will send way too many VERSION requests to the controllers.
|
|
119
|
-
# According to SO [https://stackoverflow.com/a/15175067] the best way
|
|
120
|
-
# to check for a connection drop / close is to handle the exceptions
|
|
121
|
-
# properly.... so, no polling for connections by sending it a simple
|
|
122
|
-
# command.
|
|
123
|
-
return self.hexapod.is_connected()
|