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/synoptics/__init__.py
DELETED
|
@@ -1,417 +0,0 @@
|
|
|
1
|
-
import logging
|
|
2
|
-
import os
|
|
3
|
-
from pathlib import Path
|
|
4
|
-
|
|
5
|
-
import numpy as np
|
|
6
|
-
import pandas
|
|
7
|
-
|
|
8
|
-
from egse.command import ClientServerCommand
|
|
9
|
-
from egse.config import find_file
|
|
10
|
-
from egse.control import ControlServer
|
|
11
|
-
from egse.control import Failure
|
|
12
|
-
from egse.control import is_control_server_active
|
|
13
|
-
from egse.decorators import dynamic_interface
|
|
14
|
-
from egse.env import get_data_storage_location
|
|
15
|
-
from egse.hk import TmDictionaryColumns
|
|
16
|
-
from egse.metrics import define_metrics
|
|
17
|
-
from egse.obsid import obsid_from_storage
|
|
18
|
-
from egse.protocol import CommandProtocol
|
|
19
|
-
from egse.proxy import Proxy
|
|
20
|
-
from egse.settings import Settings
|
|
21
|
-
from egse.setup import load_setup, Setup
|
|
22
|
-
from egse.storage import StorageProxy
|
|
23
|
-
from egse.storage import is_storage_manager_active
|
|
24
|
-
from egse.storage import register_to_storage_manager
|
|
25
|
-
from egse.storage.persistence import CSV
|
|
26
|
-
from egse.system import format_datetime
|
|
27
|
-
from egse.zmq_ser import bind_address
|
|
28
|
-
from egse.zmq_ser import connect_address
|
|
29
|
-
|
|
30
|
-
logger = logging.getLogger(__name__)
|
|
31
|
-
|
|
32
|
-
ORIGIN = "SYN-HK"
|
|
33
|
-
CTRL_SETTINGS = Settings.load("Synoptics Manager Control Server")
|
|
34
|
-
COMMAND_SETTINGS = Settings.load(filename="syn.yaml")
|
|
35
|
-
SITE_ID = Settings.load("SITE").ID
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
def is_synoptics_manager_active(timeout: float = 0.5):
|
|
39
|
-
"""Check if the Synoptics Manager is running.
|
|
40
|
-
|
|
41
|
-
Returns:
|
|
42
|
-
True if the Synoptics Manager is running and replied with the expected answer.
|
|
43
|
-
"""
|
|
44
|
-
|
|
45
|
-
endpoint = connect_address(
|
|
46
|
-
CTRL_SETTINGS.PROTOCOL, CTRL_SETTINGS.HOSTNAME, CTRL_SETTINGS.COMMANDING_PORT
|
|
47
|
-
)
|
|
48
|
-
|
|
49
|
-
return is_control_server_active(endpoint, timeout)
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
class SynopticsManagerProtocol(CommandProtocol):
|
|
53
|
-
|
|
54
|
-
"""
|
|
55
|
-
Command Protocol for Synoptics Management.
|
|
56
|
-
"""
|
|
57
|
-
|
|
58
|
-
def __init__(self, control_server: ControlServer):
|
|
59
|
-
"""Initialisation of a new Protocol for Synoptics Management.
|
|
60
|
-
|
|
61
|
-
The initialisation of this Protocol consists of the following steps:
|
|
62
|
-
|
|
63
|
-
- create a Controller to which the given Control Server should send commands;
|
|
64
|
-
- load the commands;
|
|
65
|
-
- build a look-up table for the commands.
|
|
66
|
-
|
|
67
|
-
Args:
|
|
68
|
-
- control_server: Control Server via which commands should be sent
|
|
69
|
-
to the Controller.
|
|
70
|
-
"""
|
|
71
|
-
|
|
72
|
-
super().__init__()
|
|
73
|
-
|
|
74
|
-
# Control Server for Synoptics Management
|
|
75
|
-
|
|
76
|
-
self.control_server = control_server
|
|
77
|
-
|
|
78
|
-
# Create a new Controller for Synoptics Management
|
|
79
|
-
|
|
80
|
-
self.controller = SynopticsManagerController()
|
|
81
|
-
|
|
82
|
-
# Load the commands (for commanding of the Synoptics Manager Controller) from the
|
|
83
|
-
# YAML file into a dictionary, stored in the Synoptics Manager Protocol
|
|
84
|
-
|
|
85
|
-
self.load_commands(
|
|
86
|
-
COMMAND_SETTINGS.Commands, SynopticsManagerCommand, SynopticsManagerController)
|
|
87
|
-
|
|
88
|
-
# Build a look-up table for the methods
|
|
89
|
-
|
|
90
|
-
self.build_device_method_lookup_table(self.controller)
|
|
91
|
-
|
|
92
|
-
def get_bind_address(self):
|
|
93
|
-
"""Returns the address to bind a socket to.
|
|
94
|
-
|
|
95
|
-
This bind address is a properly formatted URL, based on the communication protocol and
|
|
96
|
-
the commanding port.
|
|
97
|
-
|
|
98
|
-
Returns:
|
|
99
|
-
- Properly formatted URL to bind a socket to.
|
|
100
|
-
"""
|
|
101
|
-
|
|
102
|
-
return bind_address(
|
|
103
|
-
self.control_server.get_communication_protocol(),
|
|
104
|
-
self.control_server.get_commanding_port(),
|
|
105
|
-
)
|
|
106
|
-
|
|
107
|
-
def get_status(self) -> dict:
|
|
108
|
-
"""Returns the status information for the Control Server."""
|
|
109
|
-
|
|
110
|
-
return super().get_status()
|
|
111
|
-
|
|
112
|
-
def get_housekeeping(self) -> dict:
|
|
113
|
-
"""Returns the housekeeping data for the Control Server.
|
|
114
|
-
|
|
115
|
-
This housekeeping data is returns in the form of a dictionary that contains the following
|
|
116
|
-
information about the Control Server for Synoptics Management:
|
|
117
|
-
|
|
118
|
-
- timestamp (str): string representation of the current datetime.
|
|
119
|
-
|
|
120
|
-
Returns:
|
|
121
|
-
- Dictionary with housekeeping data for the Control Server for Synoptics Management.
|
|
122
|
-
"""
|
|
123
|
-
|
|
124
|
-
return {"timestamp": format_datetime()}
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
class SynopticsManagerCommand(ClientServerCommand):
|
|
128
|
-
|
|
129
|
-
"""
|
|
130
|
-
Command (client-server) for Synoptics Management.
|
|
131
|
-
"""
|
|
132
|
-
|
|
133
|
-
pass
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
class SynopticsManagerInterface:
|
|
137
|
-
|
|
138
|
-
@dynamic_interface
|
|
139
|
-
def store_common_synoptics(self, common_synoptics: dict):
|
|
140
|
-
""" Store the given non-testhouse-specific synoptics.
|
|
141
|
-
|
|
142
|
-
Args:
|
|
143
|
-
- common_synoptics: Non-testhouse-specific synoptics.
|
|
144
|
-
"""
|
|
145
|
-
|
|
146
|
-
raise NotImplementedError
|
|
147
|
-
|
|
148
|
-
@dynamic_interface
|
|
149
|
-
def store_th_synoptics(self, th_synoptics: dict):
|
|
150
|
-
""" Store the given testhouse-specific synoptics.
|
|
151
|
-
|
|
152
|
-
Args:
|
|
153
|
-
- th_synoptics: Testhouse-specific synoptics.
|
|
154
|
-
"""
|
|
155
|
-
|
|
156
|
-
raise NotImplementedError
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
class SynopticsManagerController(SynopticsManagerInterface):
|
|
160
|
-
|
|
161
|
-
"""
|
|
162
|
-
Controller for Synoptics Management.
|
|
163
|
-
"""
|
|
164
|
-
|
|
165
|
-
def __init__(self):
|
|
166
|
-
"""Initialisation for the Synoptics Manager Controller.
|
|
167
|
-
"""
|
|
168
|
-
|
|
169
|
-
self.setup = load_setup()
|
|
170
|
-
|
|
171
|
-
# Storage Manager must be active
|
|
172
|
-
|
|
173
|
-
if not is_storage_manager_active():
|
|
174
|
-
|
|
175
|
-
logger.error("No Storage Manager available!!!!")
|
|
176
|
-
|
|
177
|
-
# Register to storage
|
|
178
|
-
|
|
179
|
-
self.syn_names = read_all_syn_names()
|
|
180
|
-
self.register_to_storage()
|
|
181
|
-
|
|
182
|
-
self.hk_info_read = False
|
|
183
|
-
self.original_name_egse, self.original_name_th = None, None
|
|
184
|
-
|
|
185
|
-
self.synoptics_metrics = None
|
|
186
|
-
|
|
187
|
-
def read_hk_info(self):
|
|
188
|
-
self.syn_names, self.original_name_egse, self.original_name_th = read_hk_info(self.setup)
|
|
189
|
-
self.synoptics_metrics = define_metrics(ORIGIN, setup=self.setup)
|
|
190
|
-
|
|
191
|
-
self.hk_info_read = True
|
|
192
|
-
|
|
193
|
-
def register_to_storage(self):
|
|
194
|
-
""" Register the Synoptics Manager to the storage.
|
|
195
|
-
|
|
196
|
-
The Storage Manager will take care of producing daily files and duplicate the information during observations.
|
|
197
|
-
"""
|
|
198
|
-
|
|
199
|
-
register_to_storage_manager(ORIGIN, CSV, prep=dict(mode='a', column_names=list(self.syn_names)))
|
|
200
|
-
|
|
201
|
-
def store_common_synoptics(self, common_hk: dict):
|
|
202
|
-
""" Store the given non-TH-specific calibrated device housekeeping as synoptics.
|
|
203
|
-
|
|
204
|
-
Args:
|
|
205
|
-
- common_hk: Non-TH-specific HK that needs to be included in the synoptics.
|
|
206
|
-
"""
|
|
207
|
-
|
|
208
|
-
if not self.hk_info_read:
|
|
209
|
-
self.read_hk_info()
|
|
210
|
-
|
|
211
|
-
common_synoptics = {}
|
|
212
|
-
|
|
213
|
-
for hk_name, cal_value in common_hk.items():
|
|
214
|
-
|
|
215
|
-
try:
|
|
216
|
-
syn_name = self.original_name_egse[hk_name]
|
|
217
|
-
common_synoptics[syn_name] = cal_value
|
|
218
|
-
|
|
219
|
-
self.store_metrics(syn_name, cal_value)
|
|
220
|
-
except KeyError:
|
|
221
|
-
# do add the timestamp although it's not in the tm-dictionary
|
|
222
|
-
if hk_name == "timestamp":
|
|
223
|
-
common_synoptics[hk_name] = cal_value
|
|
224
|
-
|
|
225
|
-
self.store_synoptics(common_synoptics)
|
|
226
|
-
|
|
227
|
-
def store_th_synoptics(self, th_hk: dict):
|
|
228
|
-
""" Store the given TH-specific calibrated device housekeeping as synoptics.
|
|
229
|
-
|
|
230
|
-
Args:
|
|
231
|
-
- th_hk: TH-specific HK that needs to be included in the synoptics.
|
|
232
|
-
"""
|
|
233
|
-
|
|
234
|
-
if not self.hk_info_read:
|
|
235
|
-
self.read_hk_info()
|
|
236
|
-
|
|
237
|
-
th_synoptics = {}
|
|
238
|
-
|
|
239
|
-
for hk_name, cal_value in th_hk.items():
|
|
240
|
-
|
|
241
|
-
try:
|
|
242
|
-
syn_name = self.original_name_th[hk_name]
|
|
243
|
-
th_synoptics[syn_name] = cal_value
|
|
244
|
-
|
|
245
|
-
self.store_metrics(syn_name, cal_value)
|
|
246
|
-
except KeyError:
|
|
247
|
-
# do add the timestamp although it's not in the tm-dictionary
|
|
248
|
-
if hk_name == "timestamp":
|
|
249
|
-
th_synoptics[hk_name] = cal_value
|
|
250
|
-
|
|
251
|
-
self.store_synoptics(th_synoptics)
|
|
252
|
-
|
|
253
|
-
def store_synoptics(self, synoptics: dict):
|
|
254
|
-
""" Store the given synoptics."""
|
|
255
|
-
|
|
256
|
-
logger.log(0, "Sending synoptics to storage manager.")
|
|
257
|
-
|
|
258
|
-
try:
|
|
259
|
-
|
|
260
|
-
with StorageProxy() as storage:
|
|
261
|
-
|
|
262
|
-
response = storage.save({"origin": ORIGIN, "data": synoptics})
|
|
263
|
-
|
|
264
|
-
if isinstance(response, Failure):
|
|
265
|
-
logger.warning(f"Couldn't save synoptics to the Storage Manager: {synoptics}, "
|
|
266
|
-
f"cause: {response.cause}")
|
|
267
|
-
|
|
268
|
-
except ConnectionError as exc:
|
|
269
|
-
logger.warning(f"Couldn't connect to the Storage Manager to store synoptics: {exc}")
|
|
270
|
-
|
|
271
|
-
def store_metrics(self, name: str, value):
|
|
272
|
-
""" Store the given synoptical parameter in the metrics.
|
|
273
|
-
|
|
274
|
-
Args:
|
|
275
|
-
- name: Name of the synoptical parameter and its metrics.
|
|
276
|
-
- value: Value to store in the given metrics.
|
|
277
|
-
"""
|
|
278
|
-
|
|
279
|
-
if not self.hk_info_read:
|
|
280
|
-
self.read_hk_info()
|
|
281
|
-
|
|
282
|
-
try:
|
|
283
|
-
self.synoptics_metrics[name].set(value)
|
|
284
|
-
except KeyError:
|
|
285
|
-
logger.debug(f"Cannot store synoptics metrics: {name} is not a synoptical parameter")
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
def read_hk_info(setup: Setup) -> (dict, dict):
|
|
289
|
-
""" Read the table with the HK information, i.e. the TM dictionary.
|
|
290
|
-
|
|
291
|
-
Args:
|
|
292
|
-
- setup: Setup
|
|
293
|
-
|
|
294
|
-
Returns:
|
|
295
|
-
- List with the name of the timestamp and synoptics
|
|
296
|
-
- Dictionary with the original name at the TH you are currently at
|
|
297
|
-
- Dictionary with the original name from the EGSE (not TH-specific)
|
|
298
|
-
"""
|
|
299
|
-
|
|
300
|
-
hk_info_table = setup.telemetry.dictionary
|
|
301
|
-
|
|
302
|
-
syn_selection = np.where(hk_info_table[TmDictionaryColumns.STORAGE_MNEMONIC].values == ORIGIN)
|
|
303
|
-
syn_names = hk_info_table[TmDictionaryColumns.CORRECT_HK_NAMES].values[syn_selection]
|
|
304
|
-
original_name_egse = hk_info_table[TmDictionaryColumns.ORIGINAL_EGSE_HK_NAMES].values[syn_selection]
|
|
305
|
-
|
|
306
|
-
original_name_egse = dict(zip(original_name_egse, syn_names))
|
|
307
|
-
original_name_egse = {k: original_name_egse[k] for k in original_name_egse if isinstance(k, str)}
|
|
308
|
-
|
|
309
|
-
try:
|
|
310
|
-
|
|
311
|
-
original_name_th = hk_info_table[f"Origin of synoptics at {SITE_ID}"].values[syn_selection]
|
|
312
|
-
original_name_th = dict(zip(original_name_th, syn_names))
|
|
313
|
-
original_name_th = {k: original_name_th[k] for k in original_name_th if isinstance(k, str)}
|
|
314
|
-
|
|
315
|
-
except (NameError, KeyError):
|
|
316
|
-
|
|
317
|
-
logger.warning(f"No TH-specific HK for {SITE_ID}")
|
|
318
|
-
original_name_th = {}
|
|
319
|
-
|
|
320
|
-
# Add the timestamp as a column in the Synoptic table
|
|
321
|
-
|
|
322
|
-
syn_names = np.concatenate((["timestamp"], syn_names))
|
|
323
|
-
|
|
324
|
-
return syn_names, original_name_egse, original_name_th
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
def read_all_syn_names():
|
|
328
|
-
""" Return all synoptical names that have been used so far.
|
|
329
|
-
|
|
330
|
-
Not all camera models will use the same synoptics: this is defined in the TM dictionary that is mentioned in the
|
|
331
|
-
setup. Since the Synoptical Manager is a core process, it will be started before a setup is loaded, so it cannot
|
|
332
|
-
determine the names of the columns of its HK file from there. However, at start-up, the column names need to be
|
|
333
|
-
known, for the registration to the Storage Manager.
|
|
334
|
-
|
|
335
|
-
The work-around is to read the synoptical names from all TM dictionaries that have been used to far, and use those.
|
|
336
|
-
|
|
337
|
-
Returns: Synoptical names used for all camera models so far.
|
|
338
|
-
"""
|
|
339
|
-
|
|
340
|
-
tm_location_dir = Path(os.environ["PLATO_CONF_REPO_LOCATION"]) / "data" / "common" / "telemetry"
|
|
341
|
-
tm_filenames = os.listdir(tm_location_dir)
|
|
342
|
-
|
|
343
|
-
all_syn_names = np.array([])
|
|
344
|
-
|
|
345
|
-
for tm_filename in tm_filenames:
|
|
346
|
-
if tm_filename.endswith(".csv"):
|
|
347
|
-
tm_filepath = tm_location_dir / tm_filename
|
|
348
|
-
hk_info_table = pandas.read_csv(tm_filepath, sep=";")
|
|
349
|
-
|
|
350
|
-
syn_selection = np.where(hk_info_table[TmDictionaryColumns.STORAGE_MNEMONIC].values == ORIGIN)
|
|
351
|
-
syn_names = hk_info_table[TmDictionaryColumns.CORRECT_HK_NAMES].values[syn_selection]
|
|
352
|
-
|
|
353
|
-
all_syn_names = np.append(all_syn_names, syn_names)
|
|
354
|
-
|
|
355
|
-
all_syn_names = np.unique(all_syn_names)
|
|
356
|
-
|
|
357
|
-
return np.concatenate((["timestamp"], all_syn_names))
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
class SynopticsManagerProxy(Proxy, SynopticsManagerInterface):
|
|
361
|
-
"""
|
|
362
|
-
Proxy for Synoptics Management, used to connect to the Synoptics Manager Control Server and
|
|
363
|
-
send commands remotely.
|
|
364
|
-
"""
|
|
365
|
-
|
|
366
|
-
def __init__(
|
|
367
|
-
self,
|
|
368
|
-
protocol=CTRL_SETTINGS.PROTOCOL,
|
|
369
|
-
hostname=CTRL_SETTINGS.HOSTNAME,
|
|
370
|
-
port=CTRL_SETTINGS.COMMANDING_PORT,
|
|
371
|
-
):
|
|
372
|
-
"""Initialisation of a new Proxy for Synoptics Management.
|
|
373
|
-
|
|
374
|
-
If no connection details (transport protocol, hostname, and port) are not provided,
|
|
375
|
-
these are taken from the settings file.
|
|
376
|
-
|
|
377
|
-
Args:
|
|
378
|
-
protocol: Transport protocol [default is taken from settings file].
|
|
379
|
-
hostname: Location of the control server (IP address)
|
|
380
|
-
[default is taken from the settings file].
|
|
381
|
-
port: TCP port on which the Control Server is listening for commands
|
|
382
|
-
[default is taken from the settings file].
|
|
383
|
-
"""
|
|
384
|
-
|
|
385
|
-
super().__init__(connect_address(protocol, hostname, port))
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
def get_synoptics_table(obsid: str, data_dir=None):
|
|
389
|
-
"""
|
|
390
|
-
Read and return the synoptics table for the given obsid as a pandas DataFrame.
|
|
391
|
-
|
|
392
|
-
Args:
|
|
393
|
-
obsid: Observation identifier [TEST_LAB or TEST_LAB_SETUP].
|
|
394
|
-
data_dir: Folder (with sub-folders /daily and /obs) in which the data files are stored. If this argument is not
|
|
395
|
-
provided, the data_dir will be determined from the environment variable PLATO_DATA_STORAGE_LOCATION.
|
|
396
|
-
|
|
397
|
-
Returns:
|
|
398
|
-
Synoptics table for the given obsid as a pandas DataFrame.
|
|
399
|
-
"""
|
|
400
|
-
|
|
401
|
-
data_dir = data_dir or get_data_storage_location()
|
|
402
|
-
|
|
403
|
-
obsid = obsid_from_storage(obsid, data_dir=data_dir)
|
|
404
|
-
obs_dir = f"{data_dir}/obs/{obsid}" # Where the synoptics file is stored
|
|
405
|
-
|
|
406
|
-
# Read the synoptics for the given obsid
|
|
407
|
-
|
|
408
|
-
pattern = f"{obsid}_{ORIGIN}_*.csv"
|
|
409
|
-
synoptics_filename = str(find_file(pattern, root=obs_dir))
|
|
410
|
-
|
|
411
|
-
synoptics_table = pandas.read_csv(synoptics_filename, sep=",")
|
|
412
|
-
|
|
413
|
-
# Sort by timestamps
|
|
414
|
-
|
|
415
|
-
synoptics_table = synoptics_table.sort_values(by="timestamp")
|
|
416
|
-
|
|
417
|
-
return synoptics_table
|
egse/synoptics/syn.yaml
DELETED
egse/synoptics/syn_cs.py
DELETED
|
@@ -1,195 +0,0 @@
|
|
|
1
|
-
import logging
|
|
2
|
-
import multiprocessing
|
|
3
|
-
import sys
|
|
4
|
-
|
|
5
|
-
import click
|
|
6
|
-
import zmq
|
|
7
|
-
from prometheus_client import start_http_server
|
|
8
|
-
|
|
9
|
-
multiprocessing.current_process().name = "syn_cs"
|
|
10
|
-
|
|
11
|
-
from egse.control import ControlServer
|
|
12
|
-
from egse.settings import Settings
|
|
13
|
-
from egse.synoptics import is_synoptics_manager_active, SynopticsManagerProtocol, SynopticsManagerProxy, ORIGIN
|
|
14
|
-
|
|
15
|
-
logger = logging.getLogger(__name__)
|
|
16
|
-
|
|
17
|
-
CTRL_SETTINGS = Settings.load("Synoptics Manager Control Server")
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
class SynopticsManager(ControlServer):
|
|
21
|
-
|
|
22
|
-
"""
|
|
23
|
-
The Process Manager Control Server handles all Common-EGSE processes.
|
|
24
|
-
"""
|
|
25
|
-
|
|
26
|
-
def __init__(self):
|
|
27
|
-
"""Initialisation of a new Control Server for Process Management.
|
|
28
|
-
|
|
29
|
-
The initialisation of this Control Server consists of the following
|
|
30
|
-
steps:
|
|
31
|
-
|
|
32
|
-
- Define the device protocol;
|
|
33
|
-
- Bind the command socket to the device protocol (to listen for
|
|
34
|
-
commands);
|
|
35
|
-
- Add the device protocol to the poller, to be able to listen for
|
|
36
|
-
commands on different sockets in one thread.
|
|
37
|
-
"""
|
|
38
|
-
|
|
39
|
-
super().__init__()
|
|
40
|
-
|
|
41
|
-
# Protocol used for commanding
|
|
42
|
-
|
|
43
|
-
self.device_protocol = SynopticsManagerProtocol(self)
|
|
44
|
-
|
|
45
|
-
# Bind to a socket to listen for commands
|
|
46
|
-
|
|
47
|
-
bind_address = self.device_protocol.get_bind_address()
|
|
48
|
-
|
|
49
|
-
self.logger = logger
|
|
50
|
-
self.logger.debug(f"Binding ZeroMQ socket to {bind_address}")
|
|
51
|
-
|
|
52
|
-
self.device_protocol.bind(self.dev_ctrl_cmd_sock)
|
|
53
|
-
|
|
54
|
-
# Listen on different sockets in the same threads -> poller
|
|
55
|
-
|
|
56
|
-
self.poller.register(self.dev_ctrl_cmd_sock, zmq.POLLIN)
|
|
57
|
-
|
|
58
|
-
def get_communication_protocol(self):
|
|
59
|
-
"""Returns the communication protocol, as defined in the settings.
|
|
60
|
-
|
|
61
|
-
Returns:
|
|
62
|
-
- Communication protocol, as defined in the settings.
|
|
63
|
-
"""
|
|
64
|
-
return CTRL_SETTINGS.PROTOCOL
|
|
65
|
-
|
|
66
|
-
def get_commanding_port(self):
|
|
67
|
-
"""Returns the commanding port number.
|
|
68
|
-
|
|
69
|
-
The commanding port is the port on which the Controller listens for
|
|
70
|
-
commands, using the REQ-REP (ZeroMQ) socket pattern. Its number is
|
|
71
|
-
read from the settings file.
|
|
72
|
-
|
|
73
|
-
Returns:
|
|
74
|
-
- Number of the port on which the Controller listens for commands.
|
|
75
|
-
"""
|
|
76
|
-
|
|
77
|
-
return CTRL_SETTINGS.COMMANDING_PORT
|
|
78
|
-
|
|
79
|
-
def get_service_port(self):
|
|
80
|
-
"""Returns the service port number.
|
|
81
|
-
|
|
82
|
-
The service port is the port on which the Controller listens for
|
|
83
|
-
configuration and administration, using the PUB-SUB (ZeroMQ) socket
|
|
84
|
-
pattern. Its number is read from the settings file.
|
|
85
|
-
|
|
86
|
-
Returns:
|
|
87
|
-
- Number of the port on which the Controller listens for
|
|
88
|
-
configuration and administration.
|
|
89
|
-
"""
|
|
90
|
-
|
|
91
|
-
return CTRL_SETTINGS.SERVICE_PORT
|
|
92
|
-
|
|
93
|
-
def get_monitoring_port(self):
|
|
94
|
-
"""Returns the monitoring port number.
|
|
95
|
-
|
|
96
|
-
The monitoring port is the port on which the Controller sends periodic
|
|
97
|
-
information on the device, using the PUB-SUB (ZeroMQ) socket
|
|
98
|
-
pattern. Its number is read from the settings file.
|
|
99
|
-
|
|
100
|
-
Returns:
|
|
101
|
-
- Number of the port on which the Controller sends periodic status
|
|
102
|
-
information on the device.
|
|
103
|
-
"""
|
|
104
|
-
|
|
105
|
-
return CTRL_SETTINGS.MONITORING_PORT
|
|
106
|
-
|
|
107
|
-
def get_storage_mnemonic(self):
|
|
108
|
-
"""Returns the storage mnemonic for the Controller.
|
|
109
|
-
|
|
110
|
-
The storage mnemonic is used in the filename of the housekeeping of
|
|
111
|
-
the Controller (as using by the Storage). If this is not defined in
|
|
112
|
-
the settings file, "PM" will be used instead.
|
|
113
|
-
|
|
114
|
-
Returns:
|
|
115
|
-
- Storage mnemonic for the Controller.
|
|
116
|
-
"""
|
|
117
|
-
|
|
118
|
-
try:
|
|
119
|
-
|
|
120
|
-
# As defined in the settings file
|
|
121
|
-
|
|
122
|
-
return CTRL_SETTINGS.STORAGE_MNEMONIC
|
|
123
|
-
|
|
124
|
-
except AttributeError:
|
|
125
|
-
|
|
126
|
-
# Default
|
|
127
|
-
|
|
128
|
-
return "SYN"
|
|
129
|
-
|
|
130
|
-
def before_serve(self):
|
|
131
|
-
start_http_server(CTRL_SETTINGS.METRICS_PORT)
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
@click.group()
|
|
135
|
-
def cli():
|
|
136
|
-
pass
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
@cli.command()
|
|
140
|
-
def start():
|
|
141
|
-
"""Start the Synoptics Manager."""
|
|
142
|
-
|
|
143
|
-
# We import this class such that the class name is
|
|
144
|
-
# 'egse.synoptics.syn_cs.SynopticsControlServer' and we
|
|
145
|
-
# can compare self with isinstance inside the Control.
|
|
146
|
-
# If this import is not done, the class name for the
|
|
147
|
-
# SynopticsControlServer would be '__main__.SynopticsControlServer'.
|
|
148
|
-
|
|
149
|
-
from egse.synoptics.syn_cs import SynopticsManager
|
|
150
|
-
|
|
151
|
-
try:
|
|
152
|
-
control_server = SynopticsManager()
|
|
153
|
-
control_server.serve()
|
|
154
|
-
except KeyboardInterrupt:
|
|
155
|
-
print("Shutdown requested...exiting")
|
|
156
|
-
except SystemExit as exit_code:
|
|
157
|
-
print("System Exit with code {}.".format(exit_code))
|
|
158
|
-
sys.exit(exit_code)
|
|
159
|
-
except Exception:
|
|
160
|
-
import traceback
|
|
161
|
-
|
|
162
|
-
traceback.print_exc(file=sys.stdout)
|
|
163
|
-
|
|
164
|
-
return 0
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
@cli.command()
|
|
168
|
-
def stop():
|
|
169
|
-
"""Send a 'quit_server' command to the Synoptics Manager."""
|
|
170
|
-
|
|
171
|
-
with SynopticsManagerProxy() as syn_proxy:
|
|
172
|
-
sp = syn_proxy.get_service_proxy()
|
|
173
|
-
sp.quit_server()
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
@cli.command()
|
|
177
|
-
def status():
|
|
178
|
-
"""Print the status of the control server."""
|
|
179
|
-
|
|
180
|
-
import rich
|
|
181
|
-
|
|
182
|
-
rich.print("Synoptics Manager:")
|
|
183
|
-
if is_synoptics_manager_active():
|
|
184
|
-
rich.print(f" Status: [green]active")
|
|
185
|
-
with SynopticsManagerProxy() as syn_proxy:
|
|
186
|
-
rich.print(f" Hostname: {syn_proxy.get_ip_address()}")
|
|
187
|
-
rich.print(f" Monitoring port: {syn_proxy.get_monitoring_port()}")
|
|
188
|
-
rich.print(f" Commanding port: {syn_proxy.get_commanding_port()}")
|
|
189
|
-
rich.print(f" Service port: {syn_proxy.get_service_port()}")
|
|
190
|
-
else:
|
|
191
|
-
rich.print(f" Status: [red]not active")
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
if __name__ == "__main__":
|
|
195
|
-
sys.exit(cli())
|