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.yaml
DELETED
|
@@ -1,193 +0,0 @@
|
|
|
1
|
-
BaseClass:
|
|
2
|
-
egse.hexapod.symmetrie.PunaInterface
|
|
3
|
-
|
|
4
|
-
ProxyClass:
|
|
5
|
-
egse.hexapod.symetrie.PunaProxy
|
|
6
|
-
|
|
7
|
-
ControlServerClass:
|
|
8
|
-
egse.hexapod.symetrie.PunaControlServer
|
|
9
|
-
|
|
10
|
-
ControlServer:
|
|
11
|
-
egse.hexapod.symetrie.puna_cs
|
|
12
|
-
|
|
13
|
-
UserInterface:
|
|
14
|
-
egse.hexapod.symetrie.puna_ui
|
|
15
|
-
|
|
16
|
-
Commands:
|
|
17
|
-
|
|
18
|
-
# Each of these groups is parsed and used on both the server and the client side.
|
|
19
|
-
#
|
|
20
|
-
# The group name (e.g. is_simulator) will be monkey patched in the Proxy class for the device
|
|
21
|
-
# or service.
|
|
22
|
-
#
|
|
23
|
-
# The other field are:
|
|
24
|
-
# description: Used by the doc_string method to generate a help string
|
|
25
|
-
# cmd: Command string that will eventually be send to the hardware controller for
|
|
26
|
-
# the device. This cmd string is also used at the client side to parse and
|
|
27
|
-
# validate the arguments.
|
|
28
|
-
# device_method: The name of the method to be called on the device class.
|
|
29
|
-
# These should all be defined by the interface class for the device, i.e.
|
|
30
|
-
# PunaInterface in this case.
|
|
31
|
-
# When the device_method is the same as the group name, it can be omitted.
|
|
32
|
-
# response: The name of the method to be called from the device protocol.
|
|
33
|
-
# This method should exist in the subclass of the CommandProtocol base class,
|
|
34
|
-
# i.e. in this case it will be the PunaProtocol class.
|
|
35
|
-
# The default (when no response is given) is 'handle_device_method'.
|
|
36
|
-
|
|
37
|
-
# Definition of the the DeviceInterface
|
|
38
|
-
|
|
39
|
-
is_simulator:
|
|
40
|
-
description: Ask if the connected class is a simulator instead of the real device Controller class.
|
|
41
|
-
returns: bool | True if the far end is a simulator instead of the real hardware
|
|
42
|
-
|
|
43
|
-
is_connected:
|
|
44
|
-
description: Check if the Hexapod hardware controller is connected.
|
|
45
|
-
|
|
46
|
-
connect:
|
|
47
|
-
description: Connect the Hexapod hardware controller
|
|
48
|
-
|
|
49
|
-
reconnect:
|
|
50
|
-
description: Reconnect the Hexapod hardware controller.
|
|
51
|
-
|
|
52
|
-
This command will force a disconnect and then try to re-connect to the controller.
|
|
53
|
-
|
|
54
|
-
disconnect:
|
|
55
|
-
description: Disconnect from the hexapod controller.
|
|
56
|
-
|
|
57
|
-
This command will be send to the Hexapod Control Server which will then
|
|
58
|
-
disconnect from the hardware controller.
|
|
59
|
-
|
|
60
|
-
This command does not affect the ZeroMQ connection of the Proxy to the
|
|
61
|
-
control server. Use the service command `disconnect_cs()` to disconnect
|
|
62
|
-
from the control server.
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
# Definition of the device commands
|
|
66
|
-
|
|
67
|
-
is_in_position:
|
|
68
|
-
description: Returns True when the actuators are in position.
|
|
69
|
-
|
|
70
|
-
info:
|
|
71
|
-
description: Retrieve basic information about the Hexapod and the Controller.
|
|
72
|
-
|
|
73
|
-
reset:
|
|
74
|
-
description: Completely resets the Hexapod controller with the standard boot cycle.
|
|
75
|
-
cmd: "$$$"
|
|
76
|
-
|
|
77
|
-
stop:
|
|
78
|
-
description: Stop the current motion.
|
|
79
|
-
cmd: "&2 Q20=2"
|
|
80
|
-
|
|
81
|
-
homing:
|
|
82
|
-
description: Start the homing cycle for the Hexapod.
|
|
83
|
-
cmd: "&2 Q20=1"
|
|
84
|
-
|
|
85
|
-
is_homing_done:
|
|
86
|
-
description: Check if Homing is done.
|
|
87
|
-
|
|
88
|
-
set_virtual_homing:
|
|
89
|
-
description: Starts the virtual homing cycle on the hexapod.
|
|
90
|
-
|
|
91
|
-
This command uses the position given in parameters to initialize the hexapod position.
|
|
92
|
-
No movements of the hexapod are performed during this homing cycle. Please note that the
|
|
93
|
-
position specified in parameters must match the absolute position of the Object coordinate
|
|
94
|
-
system in the User coordinate system (see description in the manual chapter 2 on coordinates
|
|
95
|
-
systems). This position correspond to the answer of the command `get_user_positions()`.
|
|
96
|
-
During this operation, it is important to have the same hexapod position as those defined
|
|
97
|
-
during the record of the position. Otherwise, the system initialization will be incorrect.
|
|
98
|
-
|
|
99
|
-
cmd: "&2 Q71={tx} Q72={ty} Q73={tz} Q74={rx} Q75={ry} Q76={rz} Q20=42"
|
|
100
|
-
|
|
101
|
-
clear_error:
|
|
102
|
-
description: Clear all errors in the controller software.
|
|
103
|
-
cmd: "&2 Q20=15"
|
|
104
|
-
|
|
105
|
-
activate_control_loop:
|
|
106
|
-
description: Activates the control loop on motors.
|
|
107
|
-
cmd: "&2 Q20=3"
|
|
108
|
-
|
|
109
|
-
deactivate_control_loop:
|
|
110
|
-
description: Disables the control loop on the servo motors.
|
|
111
|
-
cmd: "&2 Q20=4"
|
|
112
|
-
|
|
113
|
-
configure_coordinates_systems:
|
|
114
|
-
description: Change the definition of the User Coordinate System and the Object Coordinate System.
|
|
115
|
-
cmd: "&2 Q80={tx_u} Q81={ty_u} Q82={tz_u} Q83={rx_u} Q84={ry_u} Q85={rz_u} Q86={tx_o} Q87={ty_o} Q88={tz_o} Q89={rx_o} Q90={ry_o} Q91={rz_o} Q20=21"
|
|
116
|
-
|
|
117
|
-
get_coordinates_systems:
|
|
118
|
-
description: Retrieve the definition of the User Coordinate System and the Object Coordinate System.
|
|
119
|
-
cmd: "&2 Q20=31"
|
|
120
|
-
query: "&2 Q20 Q80,12,1"
|
|
121
|
-
|
|
122
|
-
get_general_state:
|
|
123
|
-
description: Retreive general state information of the hexapod.
|
|
124
|
-
|
|
125
|
-
get_user_positions:
|
|
126
|
-
description: Retreive the position of the Object Coordinate System in the User Coordinate System.
|
|
127
|
-
cmd: "&2 Q53,6,1"
|
|
128
|
-
|
|
129
|
-
get_machine_positions:
|
|
130
|
-
description: Retreive the position of the Platform Coordinate System in the Machine Coordinate System.
|
|
131
|
-
cmd: "&2 Q47,6,1"
|
|
132
|
-
|
|
133
|
-
get_actuator_length:
|
|
134
|
-
description: Retreive the current length of the hexapod actuators.
|
|
135
|
-
cmd: "&2 Q41,6,1"
|
|
136
|
-
|
|
137
|
-
get_actuator_state:
|
|
138
|
-
description: Returns the general state of the actuators.
|
|
139
|
-
|
|
140
|
-
move_absolute:
|
|
141
|
-
description: Move/define the Object Coordinate System position and orientation expressed in the invariant user coordinate system.
|
|
142
|
-
|
|
143
|
-
The rotation centre coincides with the Object Coordinates System origin and
|
|
144
|
-
the movements are controlled with translation components at first (Tx, Ty, tZ)
|
|
145
|
-
and then the rotation components (Rx, Ry, Rz).
|
|
146
|
-
cmd: "&2 Q70=0 Q71={tx:.6f} Q72={ty:.6f} Q73={tz:.6f} Q74={rx:.6f} Q75={ry:.6f} Q76={rz:.6f} Q20=11"
|
|
147
|
-
|
|
148
|
-
move_relative_object:
|
|
149
|
-
description: Move the object relative to its current object position and orientation.
|
|
150
|
-
cmd: "&2 Q70=1 Q71={tx:.6f} Q72={ty:.6f} Q73={tz:.6f} Q74={rx:.6f} Q75={ry:.6f} Q76={rz:.6f} Q20=11"
|
|
151
|
-
|
|
152
|
-
move_relative_user:
|
|
153
|
-
description: Move the object relative to its current object position and orientation.
|
|
154
|
-
cmd: "&2 Q70=2 Q71={tx:.6f} Q72={ty:.6f} Q73={tz:.6f} Q74={rx:.6f} Q75={ry:.6f} Q76={rz:.6f} Q20=11"
|
|
155
|
-
|
|
156
|
-
check_absolute_movement:
|
|
157
|
-
description: Check if the requested object movement is valid.
|
|
158
|
-
cmd: "&2 Q70=0 Q71={tx} Q72={ty} Q73={tz} Q74={rx} Q75={ry} Q76={rz} Q20=10"
|
|
159
|
-
|
|
160
|
-
check_relative_object_movement:
|
|
161
|
-
description: Check if the requested object movement is valid.
|
|
162
|
-
cmd: "&2 Q70=1 Q71={tx} Q72={ty} Q73={tz} Q74={rx} Q75={ry} Q76={rz} Q20=10"
|
|
163
|
-
|
|
164
|
-
check_relative_user_movement:
|
|
165
|
-
description: Check if the requested object movement is valid.
|
|
166
|
-
cmd: "&2 Q70=2i Q71={tx} Q72={ty} Q73={tz} Q74={rx} Q75={ry} Q76={rz} Q20=10"
|
|
167
|
-
|
|
168
|
-
goto_zero_position:
|
|
169
|
-
cmd: "&2 Q80=1 Q20=13"
|
|
170
|
-
|
|
171
|
-
goto_retracted_position:
|
|
172
|
-
cmd: "&2 Q80=2 Q20=13"
|
|
173
|
-
|
|
174
|
-
goto_specific_position:
|
|
175
|
-
cmd: "&2 Q80={pos} Q20=13"
|
|
176
|
-
|
|
177
|
-
perform_maintenance:
|
|
178
|
-
description: Ask the controller to perform the maintenance cycle which consists to
|
|
179
|
-
travel the full range on one axis. Full range corresponds to the Hexapod
|
|
180
|
-
machine limts (defined by the manufacturer), and the movement is
|
|
181
|
-
performed in Machine coordinate system.
|
|
182
|
-
cmd: "{axis}"
|
|
183
|
-
|
|
184
|
-
get_speed:
|
|
185
|
-
description: Returns the movement speed. Translation speed is expressed in mm per
|
|
186
|
-
second, the angular speed is expressed in degrees per second.
|
|
187
|
-
|
|
188
|
-
set_speed:
|
|
189
|
-
description: Sets the speed of movements.
|
|
190
|
-
cmd: "&2 Q80={vt} Q81={vr} Q20=25"
|
|
191
|
-
|
|
192
|
-
get_debug_info:
|
|
193
|
-
description: Returns debugging status information.
|
egse/hexapod/symetrie/puna_cs.py
DELETED
|
@@ -1,195 +0,0 @@
|
|
|
1
|
-
"""
|
|
2
|
-
The Control Server that connects to the Hexapod PUNA Hardware Controller.
|
|
3
|
-
|
|
4
|
-
Start the control server from the terminal as follows:
|
|
5
|
-
|
|
6
|
-
$ puna_cs start-bg
|
|
7
|
-
|
|
8
|
-
or when you don't have the device available, start the control server in simulator mode. That
|
|
9
|
-
will make the control server connect to a device software simulator:
|
|
10
|
-
|
|
11
|
-
$ puna_cs start --sim
|
|
12
|
-
|
|
13
|
-
Please note that software simulators are intended for simple test purposes and will not simulate
|
|
14
|
-
all device behavior correctly, e.g. timing, error conditions, etc.
|
|
15
|
-
|
|
16
|
-
"""
|
|
17
|
-
import logging
|
|
18
|
-
|
|
19
|
-
from egse.hexapod.symetrie import ProxyFactory
|
|
20
|
-
from egse.hexapod.symetrie import get_hexapod_controller_pars
|
|
21
|
-
|
|
22
|
-
if __name__ != "__main__":
|
|
23
|
-
import multiprocessing
|
|
24
|
-
multiprocessing.current_process().name = "puna_cs"
|
|
25
|
-
|
|
26
|
-
import sys
|
|
27
|
-
|
|
28
|
-
import click
|
|
29
|
-
import invoke
|
|
30
|
-
import rich
|
|
31
|
-
import zmq
|
|
32
|
-
|
|
33
|
-
from egse.control import is_control_server_active
|
|
34
|
-
from egse.zmq_ser import connect_address
|
|
35
|
-
|
|
36
|
-
from prometheus_client import start_http_server
|
|
37
|
-
|
|
38
|
-
from egse.control import ControlServer
|
|
39
|
-
from egse.hexapod.symetrie.puna_protocol import PunaProtocol
|
|
40
|
-
from egse.settings import Settings
|
|
41
|
-
|
|
42
|
-
logger = logging.getLogger(__name__)
|
|
43
|
-
|
|
44
|
-
CTRL_SETTINGS = Settings.load("Hexapod PUNA Control Server")
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
class PunaControlServer(ControlServer):
|
|
48
|
-
"""PunaControlServer - Command and monitor the Hexapod PUNA hardware.
|
|
49
|
-
|
|
50
|
-
This class works as a command and monitoring server to control the Symétrie Hexapod PUNA.
|
|
51
|
-
This control server shall be used as the single point access for controlling the hardware
|
|
52
|
-
device. Monitoring access should be done preferably through this control server also,
|
|
53
|
-
but can be done with a direct connection through the PunaController if needed.
|
|
54
|
-
|
|
55
|
-
The sever binds to the following ZeroMQ sockets:
|
|
56
|
-
|
|
57
|
-
* a REQ-REP socket that can be used as a command server. Any client can connect and
|
|
58
|
-
send a command to the Hexapod.
|
|
59
|
-
|
|
60
|
-
* a PUB-SUP socket that serves as a monitoring server. It will send out Hexapod status
|
|
61
|
-
information to all the connected clients every five seconds.
|
|
62
|
-
|
|
63
|
-
"""
|
|
64
|
-
|
|
65
|
-
def __init__(self):
|
|
66
|
-
super().__init__()
|
|
67
|
-
|
|
68
|
-
self.device_protocol = PunaProtocol(self)
|
|
69
|
-
|
|
70
|
-
self.logger.info(f"Binding ZeroMQ socket to {self.device_protocol.get_bind_address()}")
|
|
71
|
-
|
|
72
|
-
self.device_protocol.bind(self.dev_ctrl_cmd_sock)
|
|
73
|
-
|
|
74
|
-
self.poller.register(self.dev_ctrl_cmd_sock, zmq.POLLIN)
|
|
75
|
-
|
|
76
|
-
def get_communication_protocol(self):
|
|
77
|
-
return CTRL_SETTINGS.PROTOCOL
|
|
78
|
-
|
|
79
|
-
def get_commanding_port(self):
|
|
80
|
-
return CTRL_SETTINGS.COMMANDING_PORT
|
|
81
|
-
|
|
82
|
-
def get_service_port(self):
|
|
83
|
-
return CTRL_SETTINGS.SERVICE_PORT
|
|
84
|
-
|
|
85
|
-
def get_monitoring_port(self):
|
|
86
|
-
return CTRL_SETTINGS.MONITORING_PORT
|
|
87
|
-
|
|
88
|
-
def get_storage_mnemonic(self):
|
|
89
|
-
try:
|
|
90
|
-
return CTRL_SETTINGS.STORAGE_MNEMONIC
|
|
91
|
-
except AttributeError:
|
|
92
|
-
return "PUNA"
|
|
93
|
-
|
|
94
|
-
def before_serve(self):
|
|
95
|
-
start_http_server(CTRL_SETTINGS.METRICS_PORT)
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
@click.group()
|
|
99
|
-
def cli():
|
|
100
|
-
pass
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
@cli.command()
|
|
104
|
-
@click.option("--simulator", "--sim", is_flag=True,
|
|
105
|
-
help="Start the Hexapod Puna Simulator as the backend.")
|
|
106
|
-
def start(simulator):
|
|
107
|
-
"""Start the Hexapod Puna Control Server."""
|
|
108
|
-
|
|
109
|
-
if simulator:
|
|
110
|
-
|
|
111
|
-
Settings.set_simulation_mode(True)
|
|
112
|
-
|
|
113
|
-
try:
|
|
114
|
-
|
|
115
|
-
controller = PunaControlServer()
|
|
116
|
-
controller.serve()
|
|
117
|
-
|
|
118
|
-
except KeyboardInterrupt:
|
|
119
|
-
|
|
120
|
-
print("Shutdown requested...exiting")
|
|
121
|
-
|
|
122
|
-
except SystemExit as exit_code:
|
|
123
|
-
|
|
124
|
-
print("System Exit with code {}.".format(exit_code))
|
|
125
|
-
sys.exit(exit_code)
|
|
126
|
-
|
|
127
|
-
except Exception:
|
|
128
|
-
|
|
129
|
-
logger.exception("Cannot start the Hexapod Puna Control Server")
|
|
130
|
-
|
|
131
|
-
# The above line does exactly the same as the traceback, but on the logger
|
|
132
|
-
# import traceback
|
|
133
|
-
# traceback.print_exc(file=sys.stdout)
|
|
134
|
-
|
|
135
|
-
return 0
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
@cli.command()
|
|
139
|
-
@click.option("--simulator", "--sim", is_flag=True,
|
|
140
|
-
help="Start the Hexapod Puna Simulator as the backend.")
|
|
141
|
-
def start_bg(simulator):
|
|
142
|
-
"""Start the PUNA Control Server in the background."""
|
|
143
|
-
sim = "--simulator" if simulator else ""
|
|
144
|
-
invoke.run(f"puna_cs start {sim}", disown=True)
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
@cli.command()
|
|
148
|
-
def stop():
|
|
149
|
-
"""Send a 'quit_server' command to the Hexapod Puna Control Server."""
|
|
150
|
-
|
|
151
|
-
*_, device_id, device_name, controller_type = get_hexapod_controller_pars()
|
|
152
|
-
|
|
153
|
-
factory = ProxyFactory()
|
|
154
|
-
|
|
155
|
-
try:
|
|
156
|
-
with factory.create(device_name, device_id=device_id) as proxy:
|
|
157
|
-
sp = proxy.get_service_proxy()
|
|
158
|
-
sp.quit_server()
|
|
159
|
-
except ConnectionError:
|
|
160
|
-
rich.print("[red]Couldn't connect to 'puna_cs', process probably not running. ")
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
@cli.command()
|
|
164
|
-
def status():
|
|
165
|
-
"""Request status information from the Control Server."""
|
|
166
|
-
|
|
167
|
-
protocol = CTRL_SETTINGS.PROTOCOL
|
|
168
|
-
hostname_cs = CTRL_SETTINGS.HOSTNAME
|
|
169
|
-
port_cs = CTRL_SETTINGS.COMMANDING_PORT
|
|
170
|
-
|
|
171
|
-
endpoint = connect_address(protocol, hostname_cs, port_cs)
|
|
172
|
-
|
|
173
|
-
*_, device_id, device_name, controller_type = get_hexapod_controller_pars()
|
|
174
|
-
|
|
175
|
-
factory = ProxyFactory()
|
|
176
|
-
|
|
177
|
-
if is_control_server_active(endpoint):
|
|
178
|
-
rich.print("PUNA Hexapod: [green]active")
|
|
179
|
-
with factory.create(device_name, device_id=device_id) as puna:
|
|
180
|
-
sim = puna.is_simulator()
|
|
181
|
-
connected = puna.is_connected()
|
|
182
|
-
ip = puna.get_ip_address()
|
|
183
|
-
rich.print(f"type: {controller_type}")
|
|
184
|
-
rich.print(f"mode: {'simulator' if sim else 'device'}{'' if connected else ' not'} connected")
|
|
185
|
-
rich.print(f"hostname: {ip}")
|
|
186
|
-
rich.print(f"commanding port: {port_cs}")
|
|
187
|
-
else:
|
|
188
|
-
rich.print("PUNA Hexapod: [red]not active")
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
if __name__ == "__main__":
|
|
192
|
-
|
|
193
|
-
logging.basicConfig(level=logging.DEBUG, format=Settings.LOG_FORMAT_FULL)
|
|
194
|
-
|
|
195
|
-
sys.exit(cli())
|
|
@@ -1,134 +0,0 @@
|
|
|
1
|
-
import logging
|
|
2
|
-
|
|
3
|
-
from egse.command import ClientServerCommand
|
|
4
|
-
from egse.control import ControlServer
|
|
5
|
-
from egse.device import DeviceConnectionState
|
|
6
|
-
from egse.hexapod.symetrie import ControllerFactory
|
|
7
|
-
from egse.hexapod.symetrie.puna import PunaInterface
|
|
8
|
-
from egse.hexapod.symetrie.puna import PunaSimulator
|
|
9
|
-
from egse.hexapod.symetrie import get_hexapod_controller_pars
|
|
10
|
-
from egse.hk import read_conversion_dict, convert_hk_names
|
|
11
|
-
from egse.protocol import CommandProtocol
|
|
12
|
-
from egse.settings import Settings
|
|
13
|
-
from egse.setup import load_setup
|
|
14
|
-
from egse.system import format_datetime
|
|
15
|
-
from egse.zmq_ser import bind_address
|
|
16
|
-
|
|
17
|
-
logger = logging.getLogger(__name__)
|
|
18
|
-
|
|
19
|
-
ctrl_settings = Settings.load("Hexapod PUNA Control Server")
|
|
20
|
-
PUNA_SETTINGS = Settings.load("PMAC Controller")
|
|
21
|
-
DEVICE_SETTINGS = Settings.load(filename="puna.yaml")
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
class PunaCommand(ClientServerCommand):
|
|
25
|
-
pass
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
class PunaProtocol(CommandProtocol):
|
|
29
|
-
def __init__(self, control_server: ControlServer):
|
|
30
|
-
super().__init__()
|
|
31
|
-
self.control_server = control_server
|
|
32
|
-
setup = load_setup()
|
|
33
|
-
|
|
34
|
-
self.hk_conversion_table = read_conversion_dict(self.control_server.get_storage_mnemonic(), use_site=True,
|
|
35
|
-
setup=setup)
|
|
36
|
-
|
|
37
|
-
if Settings.simulation_mode():
|
|
38
|
-
self.hexapod = PunaSimulator()
|
|
39
|
-
else:
|
|
40
|
-
hostname, port, device_id, device_name, controller_type = get_hexapod_controller_pars()
|
|
41
|
-
|
|
42
|
-
factory = ControllerFactory()
|
|
43
|
-
self.hexapod = factory.create(device_name, device_id=device_id)
|
|
44
|
-
# self.hexapod = PunaController(hostname=hostname, port=port)
|
|
45
|
-
self.hexapod.add_observer(self)
|
|
46
|
-
|
|
47
|
-
try:
|
|
48
|
-
self.hexapod.connect()
|
|
49
|
-
except ConnectionError:
|
|
50
|
-
logger.warning("Couldn't establish a connection to the PUNA Hexapod, check the log messages.")
|
|
51
|
-
|
|
52
|
-
self.load_commands(DEVICE_SETTINGS.Commands, PunaCommand, PunaInterface)
|
|
53
|
-
self.build_device_method_lookup_table(self.hexapod)
|
|
54
|
-
|
|
55
|
-
def get_bind_address(self):
|
|
56
|
-
return bind_address(
|
|
57
|
-
self.control_server.get_communication_protocol(),
|
|
58
|
-
self.control_server.get_commanding_port(),
|
|
59
|
-
)
|
|
60
|
-
|
|
61
|
-
def get_device(self):
|
|
62
|
-
return self.hexapod
|
|
63
|
-
|
|
64
|
-
def get_status(self):
|
|
65
|
-
|
|
66
|
-
status = super().get_status()
|
|
67
|
-
|
|
68
|
-
if self.state == DeviceConnectionState.DEVICE_NOT_CONNECTED and not Settings.simulation_mode():
|
|
69
|
-
return status
|
|
70
|
-
|
|
71
|
-
mach_positions = self.hexapod.get_machine_positions()
|
|
72
|
-
user_positions = self.hexapod.get_user_positions()
|
|
73
|
-
actuator_length = self.hexapod.get_actuator_length()
|
|
74
|
-
|
|
75
|
-
status.update({"mach": mach_positions, "user": user_positions, "alength": actuator_length})
|
|
76
|
-
|
|
77
|
-
return status
|
|
78
|
-
|
|
79
|
-
def get_housekeeping(self) -> dict:
|
|
80
|
-
|
|
81
|
-
result = dict()
|
|
82
|
-
result["timestamp"] = format_datetime()
|
|
83
|
-
|
|
84
|
-
if self.state == DeviceConnectionState.DEVICE_NOT_CONNECTED and not Settings.simulation_mode():
|
|
85
|
-
return result
|
|
86
|
-
|
|
87
|
-
mach_positions = self.hexapod.get_machine_positions()
|
|
88
|
-
user_positions = self.hexapod.get_user_positions()
|
|
89
|
-
actuator_length = self.hexapod.get_actuator_length()
|
|
90
|
-
|
|
91
|
-
# The result of the previous calls might be None when e.g. the connection
|
|
92
|
-
# to the device gets lost.
|
|
93
|
-
|
|
94
|
-
if mach_positions is None or user_positions is None or actuator_length is None:
|
|
95
|
-
if not self.hexapod.is_connected():
|
|
96
|
-
logger.warning("Hexapod PUNA disconnected.")
|
|
97
|
-
self.update_connection_state(DeviceConnectionState.DEVICE_NOT_CONNECTED)
|
|
98
|
-
return result
|
|
99
|
-
|
|
100
|
-
for idx, key in enumerate(
|
|
101
|
-
["user_t_x", "user_t_y", "user_t_z", "user_r_x", "user_r_y", "user_r_z"]
|
|
102
|
-
):
|
|
103
|
-
result[key] = user_positions[idx]
|
|
104
|
-
|
|
105
|
-
for idx, key in enumerate(
|
|
106
|
-
["mach_t_x", "mach_t_y", "mach_t_z", "mach_r_x", "mach_r_y", "mach_r_z"]
|
|
107
|
-
):
|
|
108
|
-
result[key] = mach_positions[idx]
|
|
109
|
-
|
|
110
|
-
for idx, key in enumerate(
|
|
111
|
-
["alen_t_x", "alen_t_y", "alen_t_z", "alen_r_x", "alen_r_y", "alen_r_z"]
|
|
112
|
-
):
|
|
113
|
-
result[key] = actuator_length[idx]
|
|
114
|
-
|
|
115
|
-
# TODO:
|
|
116
|
-
# the get_general_state() method should be refactored as to return a dict instead of a
|
|
117
|
-
# list. Also, we might want to rethink the usefulness of returning the tuple,
|
|
118
|
-
# it the first return value ever used?
|
|
119
|
-
|
|
120
|
-
_, _ = self.hexapod.get_general_state()
|
|
121
|
-
|
|
122
|
-
result["Homing done"] = self.hexapod.is_homing_done()
|
|
123
|
-
result["In position"] = self.hexapod.is_in_position()
|
|
124
|
-
|
|
125
|
-
return convert_hk_names(result, self.hk_conversion_table)
|
|
126
|
-
|
|
127
|
-
def is_device_connected(self):
|
|
128
|
-
# FIXME(rik): There must be another way to check if the socket is still alive...
|
|
129
|
-
# This will send way too many VERSION requests to the controllers.
|
|
130
|
-
# According to SO [https://stackoverflow.com/a/15175067] the best way
|
|
131
|
-
# to check for a connection drop / close is to handle the exceptions
|
|
132
|
-
# properly.... so, no polling for connections by sending it a simple
|
|
133
|
-
# command.
|
|
134
|
-
return self.hexapod.is_connected()
|