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/gimbal/symetrie/gimbal.yaml
DELETED
|
@@ -1,168 +0,0 @@
|
|
|
1
|
-
BaseClass:
|
|
2
|
-
egse.gimbal.symmetrie.GimbalInterface
|
|
3
|
-
|
|
4
|
-
ProxyClass:
|
|
5
|
-
egse.gimbal.symetrie.GimbalProxy
|
|
6
|
-
|
|
7
|
-
ControlServerClass:
|
|
8
|
-
egse.gimbal.symetrie.GimbalControlServer
|
|
9
|
-
|
|
10
|
-
ControlServer:
|
|
11
|
-
egse.gimbal.symetrie.gimbal_cs
|
|
12
|
-
|
|
13
|
-
UserInterface:
|
|
14
|
-
egse.gimbal.symetrie.gimbal_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
|
-
# GimbalInterface 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 GimbalProtocol 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 Gimbal hardware controller is connected.
|
|
45
|
-
|
|
46
|
-
connect:
|
|
47
|
-
description: Connect the Gimbal hardware controller
|
|
48
|
-
|
|
49
|
-
reconnect:
|
|
50
|
-
description: Reconnect the Gimbal 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 gimbal controller.
|
|
56
|
-
|
|
57
|
-
This command will be send to the Gimbal 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 Gimbal and the Controller.
|
|
72
|
-
|
|
73
|
-
reset:
|
|
74
|
-
description: Completely resets the Gimbal 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 Gimbal.
|
|
83
|
-
cmd: "&2 Q20=1"
|
|
84
|
-
|
|
85
|
-
is_homing_done:
|
|
86
|
-
description: Check if Homing is done.
|
|
87
|
-
|
|
88
|
-
clear_error:
|
|
89
|
-
description: Clear all errors in the controller software.
|
|
90
|
-
cmd: "&2 Q20=15"
|
|
91
|
-
|
|
92
|
-
activate_control_loop:
|
|
93
|
-
description: Activates the control loop on motors.
|
|
94
|
-
cmd: "&2 Q20=3"
|
|
95
|
-
|
|
96
|
-
deactivate_control_loop:
|
|
97
|
-
description: Disables the control loop on the servo motors.
|
|
98
|
-
cmd: "&2 Q20=4"
|
|
99
|
-
|
|
100
|
-
configure_offsets:
|
|
101
|
-
description: Change the definition of the offsets.
|
|
102
|
-
cmd: "&2 Q80={grx} Q81={gry} Q20=21"
|
|
103
|
-
|
|
104
|
-
get_offsets:
|
|
105
|
-
description: Retrieve the definition of the offsets.
|
|
106
|
-
cmd: "&2 Q20=31"
|
|
107
|
-
query: "&2 Q20 Q80,2,1"
|
|
108
|
-
|
|
109
|
-
get_general_state:
|
|
110
|
-
description: Retreive general state information of the gimbal.
|
|
111
|
-
|
|
112
|
-
get_user_positions:
|
|
113
|
-
description: Retreive the position of the object in the User Coordinate System.
|
|
114
|
-
cmd: "&2 Q53,2,1"
|
|
115
|
-
|
|
116
|
-
get_machine_positions:
|
|
117
|
-
description: Retreive the position of the gimbal in the Machine Coordinate System.
|
|
118
|
-
cmd: "&2 Q47,2,1"
|
|
119
|
-
|
|
120
|
-
get_motor_temperatures:
|
|
121
|
-
description: Retrieve the temperatures of the Gimbal motors.
|
|
122
|
-
cmd: "&2 Q59,2,1"
|
|
123
|
-
|
|
124
|
-
get_actuator_length:
|
|
125
|
-
description: Retreive the current length of the gimbal actuators.
|
|
126
|
-
cmd: "&2 Q41,2,1"
|
|
127
|
-
|
|
128
|
-
get_actuator_state:
|
|
129
|
-
description: Returns the general state of the actuators.
|
|
130
|
-
|
|
131
|
-
move_absolute:
|
|
132
|
-
description: Move/define the Object Coordinate System position and orientation expressed in the invariant user coordinate system.
|
|
133
|
-
cmd: "&2 Q70=0 Q71={grx} Q72={gry} Q20=11"
|
|
134
|
-
|
|
135
|
-
move_relative:
|
|
136
|
-
description: Move the object relative to its current object position and orientation.
|
|
137
|
-
cmd: "&2 Q70=1 Q71={grx} Q72={gry} Q20=11"
|
|
138
|
-
|
|
139
|
-
check_absolute_movement:
|
|
140
|
-
description: Check if the requested object movement is valid.
|
|
141
|
-
cmd: "&2 Q70=0 Q71={grx} Q72={gry} Q20=10"
|
|
142
|
-
|
|
143
|
-
check_relative_movement:
|
|
144
|
-
description: Check if the requested object movement is valid.
|
|
145
|
-
cmd: "&2 Q70=0 Q71={grx} Q72={gry} Q20=11"
|
|
146
|
-
|
|
147
|
-
goto_zero_position:
|
|
148
|
-
cmd: "&2 Q80=2 Q20=13"
|
|
149
|
-
|
|
150
|
-
goto_specific_position:
|
|
151
|
-
cmd: "&2 Q80={pos} Q20=13"
|
|
152
|
-
|
|
153
|
-
perform_maintenance:
|
|
154
|
-
description: Ask the controller to perform the maintenance cycle which consists to
|
|
155
|
-
travel the full range on one axis. Full range corresponds to the Gimbal
|
|
156
|
-
machine limts (defined by the manufacturer), and the movement is
|
|
157
|
-
performed in Machine coordinate system.
|
|
158
|
-
|
|
159
|
-
get_speed:
|
|
160
|
-
description: Returns the rotation speed. the angular speed is expressed in degrees
|
|
161
|
-
per second.
|
|
162
|
-
|
|
163
|
-
set_speed:
|
|
164
|
-
description: Sets the speed of movements.
|
|
165
|
-
cmd: "&2 Q81={sr} Q20=25"
|
|
166
|
-
|
|
167
|
-
get_debug_info:
|
|
168
|
-
description: Returns debugging status information.
|
|
@@ -1,183 +0,0 @@
|
|
|
1
|
-
"""
|
|
2
|
-
The Control Server that connects to the Gimbal Hardware Controller.
|
|
3
|
-
|
|
4
|
-
Start the control server from the terminal as follows:
|
|
5
|
-
|
|
6
|
-
$ gimbal_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
|
-
$ gimbal_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
|
-
if __name__ != "__main__":
|
|
20
|
-
import multiprocessing
|
|
21
|
-
multiprocessing.current_process().name = "gimbal_cs"
|
|
22
|
-
|
|
23
|
-
import sys
|
|
24
|
-
|
|
25
|
-
import click
|
|
26
|
-
import invoke
|
|
27
|
-
import rich
|
|
28
|
-
import zmq
|
|
29
|
-
|
|
30
|
-
from egse.control import is_control_server_active
|
|
31
|
-
from egse.zmq_ser import connect_address
|
|
32
|
-
|
|
33
|
-
from prometheus_client import start_http_server
|
|
34
|
-
|
|
35
|
-
from egse.control import ControlServer
|
|
36
|
-
from egse.gimbal.symetrie.gimbal import GimbalProxy
|
|
37
|
-
from egse.gimbal.symetrie.gimbal_protocol import GimbalProtocol
|
|
38
|
-
from egse.settings import Settings
|
|
39
|
-
|
|
40
|
-
logger = logging.getLogger(__name__)
|
|
41
|
-
|
|
42
|
-
CTRL_SETTINGS = Settings.load("Gimbal Control Server")
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
class GimbalControlServer(ControlServer):
|
|
46
|
-
"""GimbalControlServer - Command and monitor the Gimbal hardware.
|
|
47
|
-
|
|
48
|
-
This class works as a command and monitoring server to control the Symétrie Gimbal.
|
|
49
|
-
This control server shall be used as the single point access for controlling the hardware
|
|
50
|
-
device. Monitoring access should be done preferably through this control server also,
|
|
51
|
-
but can be done with a direct connection through the GimbalController if needed.
|
|
52
|
-
|
|
53
|
-
The sever binds to the following ZeroMQ sockets:
|
|
54
|
-
|
|
55
|
-
* a REQ-REP socket that can be used as a command server. Any client can connect and
|
|
56
|
-
send a command to the Gimbal.
|
|
57
|
-
|
|
58
|
-
* a PUB-SUP socket that serves as a monitoring server. It will send out Gimbal status
|
|
59
|
-
information to all the connected clients every five seconds.
|
|
60
|
-
|
|
61
|
-
"""
|
|
62
|
-
|
|
63
|
-
def __init__(self):
|
|
64
|
-
super().__init__()
|
|
65
|
-
|
|
66
|
-
self.device_protocol = GimbalProtocol(self)
|
|
67
|
-
|
|
68
|
-
self.logger.info(f"Binding ZeroMQ socket to {self.device_protocol.get_bind_address()}")
|
|
69
|
-
|
|
70
|
-
self.device_protocol.bind(self.dev_ctrl_cmd_sock)
|
|
71
|
-
|
|
72
|
-
self.poller.register(self.dev_ctrl_cmd_sock, zmq.POLLIN)
|
|
73
|
-
|
|
74
|
-
def get_communication_protocol(self):
|
|
75
|
-
return CTRL_SETTINGS.PROTOCOL
|
|
76
|
-
|
|
77
|
-
def get_commanding_port(self):
|
|
78
|
-
return CTRL_SETTINGS.COMMANDING_PORT
|
|
79
|
-
|
|
80
|
-
def get_service_port(self):
|
|
81
|
-
return CTRL_SETTINGS.SERVICE_PORT
|
|
82
|
-
|
|
83
|
-
def get_monitoring_port(self):
|
|
84
|
-
return CTRL_SETTINGS.MONITORING_PORT
|
|
85
|
-
|
|
86
|
-
def get_storage_mnemonic(self):
|
|
87
|
-
try:
|
|
88
|
-
return CTRL_SETTINGS.STORAGE_MNEMONIC
|
|
89
|
-
except AttributeError:
|
|
90
|
-
return "GIMBAL"
|
|
91
|
-
|
|
92
|
-
def before_serve(self):
|
|
93
|
-
start_http_server(CTRL_SETTINGS.METRICS_PORT)
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
@click.group()
|
|
97
|
-
def cli():
|
|
98
|
-
pass
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
@cli.command()
|
|
102
|
-
@click.option("--simulator", "--sim", is_flag=True,
|
|
103
|
-
help="Start the Gimbal Simulator as the backend.")
|
|
104
|
-
def start(simulator):
|
|
105
|
-
"""Start the Gimbal Control Server."""
|
|
106
|
-
|
|
107
|
-
if simulator:
|
|
108
|
-
|
|
109
|
-
Settings.set_simulation_mode(True)
|
|
110
|
-
|
|
111
|
-
try:
|
|
112
|
-
|
|
113
|
-
controller = GimbalControlServer()
|
|
114
|
-
controller.serve()
|
|
115
|
-
|
|
116
|
-
except KeyboardInterrupt:
|
|
117
|
-
|
|
118
|
-
print("Shutdown requested...exiting")
|
|
119
|
-
|
|
120
|
-
except SystemExit as exit_code:
|
|
121
|
-
|
|
122
|
-
print("System Exit with code {}.".format(exit_code))
|
|
123
|
-
sys.exit(exit_code)
|
|
124
|
-
|
|
125
|
-
except Exception:
|
|
126
|
-
|
|
127
|
-
logger.exception("Cannot start the Gimbal Control Server")
|
|
128
|
-
|
|
129
|
-
# The above line does exactly the same as the traceback, but on the logger
|
|
130
|
-
# import traceback
|
|
131
|
-
# traceback.print_exc(file=sys.stdout)
|
|
132
|
-
|
|
133
|
-
return 0
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
@cli.command()
|
|
137
|
-
@click.option("--simulator", "--sim", is_flag=True,
|
|
138
|
-
help="Start the Gimbal Simulator as the backend.")
|
|
139
|
-
def start_bg(simulator):
|
|
140
|
-
"""Start the Gimbal Control Server in the background."""
|
|
141
|
-
sim = "--simulator" if simulator else ""
|
|
142
|
-
invoke.run(f"gimbal_cs start {sim}", disown=True)
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
@cli.command()
|
|
146
|
-
def stop():
|
|
147
|
-
"""Send a 'quit_server' command to the Gimbal Control Server."""
|
|
148
|
-
|
|
149
|
-
try:
|
|
150
|
-
with GimbalProxy() as proxy:
|
|
151
|
-
sp = proxy.get_service_proxy()
|
|
152
|
-
sp.quit_server()
|
|
153
|
-
except ConnectionError:
|
|
154
|
-
rich.print("[red]Couldn't connect to 'gimbal_cs', process probably not running. ")
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
@cli.command()
|
|
158
|
-
def status():
|
|
159
|
-
"""Request status information from the Control Server."""
|
|
160
|
-
|
|
161
|
-
protocol = CTRL_SETTINGS.PROTOCOL
|
|
162
|
-
hostname = CTRL_SETTINGS.HOSTNAME
|
|
163
|
-
port = CTRL_SETTINGS.COMMANDING_PORT
|
|
164
|
-
|
|
165
|
-
endpoint = connect_address(protocol, hostname, port)
|
|
166
|
-
|
|
167
|
-
if is_control_server_active(endpoint):
|
|
168
|
-
rich.print(f"Gimbal: [green]active")
|
|
169
|
-
with GimbalProxy() as gimbal:
|
|
170
|
-
sim = gimbal.is_simulator()
|
|
171
|
-
connected = gimbal.is_connected()
|
|
172
|
-
ip = gimbal.get_ip_address()
|
|
173
|
-
rich.print(f"mode: {'simulator' if sim else 'device'}{' not' if not connected else ''} connected")
|
|
174
|
-
rich.print(f"hostname: {ip}")
|
|
175
|
-
else:
|
|
176
|
-
rich.print(f"Gimbal: [red]not active")
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
if __name__ == "__main__":
|
|
180
|
-
|
|
181
|
-
logging.basicConfig(level=logging.DEBUG, format=Settings.LOG_FORMAT_FULL)
|
|
182
|
-
|
|
183
|
-
sys.exit(cli())
|
|
@@ -1,138 +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.gimbal.symetrie.gimbal import GimbalController
|
|
7
|
-
from egse.gimbal.symetrie.gimbal import GimbalInterface
|
|
8
|
-
from egse.gimbal.symetrie.gimbal import GimbalSimulator
|
|
9
|
-
from egse.hk import read_conversion_dict, convert_hk_names
|
|
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
|
-
from egse.metrics import define_metrics
|
|
16
|
-
|
|
17
|
-
logger = logging.getLogger(__name__)
|
|
18
|
-
|
|
19
|
-
ctrl_settings = Settings.load("Gimbal Control Server")
|
|
20
|
-
gimbal_settings = Settings.load(filename="gimbal.yaml")
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
class GimbalCommand(ClientServerCommand):
|
|
24
|
-
pass
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
class GimbalProtocol(CommandProtocol):
|
|
28
|
-
def __init__(self, control_server: ControlServer):
|
|
29
|
-
super().__init__()
|
|
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.gimbal = GimbalSimulator()
|
|
38
|
-
else:
|
|
39
|
-
self.gimbal = GimbalController()
|
|
40
|
-
self.gimbal.add_observer(self)
|
|
41
|
-
|
|
42
|
-
try:
|
|
43
|
-
self.gimbal.connect()
|
|
44
|
-
except ConnectionError as exc:
|
|
45
|
-
logger.warning(
|
|
46
|
-
f"Couldn't establish a connection to the Gimbal, check the log messages.")
|
|
47
|
-
|
|
48
|
-
self.load_commands(gimbal_settings.Commands, GimbalCommand, GimbalInterface)
|
|
49
|
-
self.build_device_method_lookup_table(self.gimbal)
|
|
50
|
-
|
|
51
|
-
self.metrics = define_metrics(origin="GIMBAL", use_site=True, setup=setup)
|
|
52
|
-
|
|
53
|
-
def get_bind_address(self):
|
|
54
|
-
return bind_address(
|
|
55
|
-
self.control_server.get_communication_protocol(),
|
|
56
|
-
self.control_server.get_commanding_port(),
|
|
57
|
-
)
|
|
58
|
-
|
|
59
|
-
def get_status(self):
|
|
60
|
-
|
|
61
|
-
status = super().get_status()
|
|
62
|
-
|
|
63
|
-
if self.state == DeviceConnectionState.DEVICE_NOT_CONNECTED and not Settings.simulation_mode():
|
|
64
|
-
return status
|
|
65
|
-
|
|
66
|
-
mach_positions = self.gimbal.get_machine_positions()
|
|
67
|
-
user_positions = self.gimbal.get_user_positions()
|
|
68
|
-
actuator_length = self.gimbal.get_actuator_length()
|
|
69
|
-
|
|
70
|
-
status.update({"mach": mach_positions, "user": user_positions, "alength": actuator_length})
|
|
71
|
-
|
|
72
|
-
return status
|
|
73
|
-
|
|
74
|
-
def get_housekeeping(self) -> dict:
|
|
75
|
-
|
|
76
|
-
metrics_dict = self.metrics
|
|
77
|
-
|
|
78
|
-
result = dict()
|
|
79
|
-
result["timestamp"] = format_datetime()
|
|
80
|
-
|
|
81
|
-
if self.state == DeviceConnectionState.DEVICE_NOT_CONNECTED and not Settings.simulation_mode():
|
|
82
|
-
return result
|
|
83
|
-
|
|
84
|
-
mach_positions = self.gimbal.get_machine_positions()
|
|
85
|
-
user_positions = self.gimbal.get_user_positions()
|
|
86
|
-
actuator_length = self.gimbal.get_actuator_length()
|
|
87
|
-
|
|
88
|
-
# The result of the previous calls might be None when e.g. the connection
|
|
89
|
-
# to the device gets lost.
|
|
90
|
-
|
|
91
|
-
if mach_positions is None or user_positions is None or actuator_length is None:
|
|
92
|
-
if not self.gimbal.is_connected():
|
|
93
|
-
logger.warning("Gimbal disconnected.")
|
|
94
|
-
self.update_connection_state(DeviceConnectionState.DEVICE_NOT_CONNECTED)
|
|
95
|
-
return result
|
|
96
|
-
|
|
97
|
-
for idx, key in enumerate(
|
|
98
|
-
["user_r_x", "user_r_y"]
|
|
99
|
-
):
|
|
100
|
-
result[key] = user_positions[idx]
|
|
101
|
-
|
|
102
|
-
for idx, key in enumerate(
|
|
103
|
-
["mach_r_x", "mach_r_y"]
|
|
104
|
-
):
|
|
105
|
-
result[key] = mach_positions[idx]
|
|
106
|
-
|
|
107
|
-
for idx, key in enumerate(
|
|
108
|
-
["alen_r_x", "alen_r_y"]
|
|
109
|
-
):
|
|
110
|
-
result[key] = actuator_length[idx]
|
|
111
|
-
|
|
112
|
-
# TODO:
|
|
113
|
-
# the get_general_state() method should be refactored as to return a dict instead of a
|
|
114
|
-
# list. Also, we might want to rethink the usefulness of returning the tuple,
|
|
115
|
-
# it the first return value ever used?
|
|
116
|
-
|
|
117
|
-
_, _ = self.gimbal.get_general_state()
|
|
118
|
-
|
|
119
|
-
result["Homing done"] = self.gimbal.is_homing_done()
|
|
120
|
-
result["In position"] = self.gimbal.is_in_position()
|
|
121
|
-
temperatures = self.gimbal.get_motor_temperatures()
|
|
122
|
-
result["Temp_X"] = temperatures[0]
|
|
123
|
-
result["Temp_Y"] = temperatures[1]
|
|
124
|
-
hk_dict = convert_hk_names(result, self.hk_conversion_table)
|
|
125
|
-
|
|
126
|
-
for hk_name in metrics_dict.keys():
|
|
127
|
-
metrics_dict[hk_name].set(hk_dict[hk_name])
|
|
128
|
-
|
|
129
|
-
return hk_dict
|
|
130
|
-
|
|
131
|
-
def is_device_connected(self):
|
|
132
|
-
# FIXME(rik): There must be another way to check if the socket is still alive...
|
|
133
|
-
# This will send way too many VERSION requests to the controllers.
|
|
134
|
-
# According to SO [https://stackoverflow.com/a/15175067] the best way
|
|
135
|
-
# to check for a connection drop / close is to handle the exceptions
|
|
136
|
-
# properly.... so, no polling for connections by sending it a simple
|
|
137
|
-
# command.
|
|
138
|
-
return self.gimbal.is_connected()
|