cgse 2023.38.0__py3-none-any.whl → 2024.1.4__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-2024.1.4.dist-info/METADATA +38 -0
- cgse-2024.1.4.dist-info/RECORD +5 -0
- {cgse-2023.38.0.dist-info → cgse-2024.1.4.dist-info}/WHEEL +1 -2
- cgse-2023.38.0.dist-info/COPYING +0 -674
- cgse-2023.38.0.dist-info/COPYING.LESSER +0 -165
- cgse-2023.38.0.dist-info/METADATA +0 -144
- cgse-2023.38.0.dist-info/RECORD +0 -649
- cgse-2023.38.0.dist-info/entry_points.txt +0 -75
- cgse-2023.38.0.dist-info/top_level.txt +0 -2
- egse/__init__.py +0 -12
- egse/__main__.py +0 -32
- egse/aeu/aeu.py +0 -5235
- egse/aeu/aeu_awg.yaml +0 -265
- egse/aeu/aeu_crio.yaml +0 -273
- egse/aeu/aeu_cs.py +0 -626
- egse/aeu/aeu_devif.py +0 -321
- egse/aeu/aeu_main_ui.py +0 -912
- 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 -234
- egse/alert/alertman_ui.py +0 -603
- 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 -130
- egse/alert/gsm/beaglebone_protocol.py +0 -48
- 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 -129
- 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 -1015
- egse/confman/confman.yaml +0 -67
- egse/confman/confman_cs.py +0 -239
- egse/confman/confman_ui.py +0 -381
- egse/confman/setup_ui.py +0 -565
- egse/control.py +0 -442
- egse/coordinates/__init__.py +0 -531
- egse/coordinates/avoidance.py +0 -103
- egse/coordinates/cslmodel.py +0 -127
- egse/coordinates/laser_tracker_to_dict.py +0 -120
- egse/coordinates/point.py +0 -707
- egse/coordinates/pyplot.py +0 -195
- 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 -1247
- 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 -415
- egse/device.py +0 -269
- egse/dpu/__init__.py +0 -2681
- egse/dpu/ccd_ui.py +0 -508
- egse/dpu/dpu.py +0 -786
- egse/dpu/dpu.yaml +0 -153
- egse/dpu/dpu_cs.py +0 -272
- egse/dpu/dpu_ui.py +0 -668
- egse/dpu/fitsgen.py +0 -2077
- egse/dpu/fitsgen_test.py +0 -752
- 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/constants.py +0 -220
- egse/dsi/esl.py +0 -870
- egse/dsi/rmap.py +0 -1042
- egse/dsi/rmapci.py +0 -37
- egse/dsi/spw.py +0 -154
- egse/dsi/spw_state.py +0 -29
- egse/dummy.py +0 -258
- egse/dyndummy.py +0 -179
- egse/env.py +0 -278
- egse/exceptions.py +0 -88
- egse/fdir/__init__.py +0 -28
- egse/fdir/fdir_manager.py +0 -85
- egse/fdir/fdir_manager.yaml +0 -51
- egse/fdir/fdir_manager_controller.py +0 -228
- egse/fdir/fdir_manager_cs.py +0 -164
- egse/fdir/fdir_manager_interface.py +0 -25
- egse/fdir/fdir_remote.py +0 -73
- egse/fdir/fdir_remote.yaml +0 -37
- egse/fdir/fdir_remote_controller.py +0 -50
- egse/fdir/fdir_remote_cs.py +0 -97
- egse/fdir/fdir_remote_interface.py +0 -14
- egse/fdir/fdir_remote_popup.py +0 -31
- egse/fee/__init__.py +0 -114
- egse/fee/f_fee_register.yaml +0 -43
- egse/fee/fee.py +0 -631
- egse/fee/feesim.py +0 -750
- egse/fee/n_fee_hk.py +0 -761
- egse/fee/nfee.py +0 -187
- egse/filterwheel/__init__.py +0 -4
- egse/filterwheel/eksma/__init__.py +0 -24
- egse/filterwheel/eksma/fw8smc4.py +0 -661
- 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 -81
- egse/filterwheel/eksma/fw8smc4_ui.py +0 -940
- egse/filterwheel/eksma/fw8smc5.py +0 -111
- 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 -1068
- egse/filterwheel/eksma/testpythonfw.py +0 -215
- egse/fov/__init__.py +0 -65
- egse/fov/fov_hk.py +0 -712
- egse/fov/fov_ui.py +0 -861
- 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 -135
- 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 -1281
- egse/gui/formatter.py +0 -10
- egse/gui/led.py +0 -162
- egse/gui/limitswitch.py +0 -143
- egse/gui/mechanisms.py +0 -588
- egse/gui/states.py +0 -148
- egse/gui/stripchart.py +0 -729
- 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 -138
- 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 -196
- egse/hexapod/symetrie/puna_protocol.py +0 -131
- egse/hexapod/symetrie/puna_ui.py +0 -434
- 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 -415
- egse/hexapod/symetrie/zonda_protocol.py +0 -119
- egse/hexapod/symetrie/zonda_ui.py +0 -449
- egse/hk.py +0 -765
- 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 -69
- 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/macOS/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/macOS/EtherSpaceLink_v34_86.dylib +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 -73
- egse/logger/__init__.py +0 -243
- egse/logger/log_cs.py +0 -321
- egse/metrics.py +0 -98
- 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 -163
- 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 -811
- 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 -603
- egse/proxy.py +0 -522
- egse/randomwalk.py +0 -140
- egse/reg.py +0 -585
- egse/reload.py +0 -122
- egse/reprocess.py +0 -675
- egse/resource.py +0 -333
- egse/rst.py +0 -135
- egse/search.py +0 -182
- egse/serialdevice.py +0 -190
- egse/services.py +0 -212
- egse/services.yaml +0 -51
- egse/settings.py +0 -379
- egse/settings.yaml +0 -980
- egse/setup.py +0 -1180
- 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 -69
- 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 -1479
- egse/stages/__init__.py +0 -12
- egse/stages/aerotech/ensemble.py +0 -247
- 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 -193
- egse/stages/arun/smd3.py +0 -111
- egse/stages/arun/smd3.yaml +0 -68
- egse/stages/arun/smd3_controller.py +0 -472
- 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 -904
- 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 -111
- 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 -1004
- egse/storage/persistence.py +0 -2295
- egse/storage/storage.yaml +0 -72
- egse/storage/storage_cs.py +0 -214
- egse/styles/dark.qss +0 -343
- egse/styles/default.qss +0 -48
- egse/synoptics/__init__.py +0 -412
- egse/synoptics/syn.yaml +0 -9
- egse/synoptics/syn_cs.py +0 -195
- egse/system.py +0 -1408
- egse/tcs/__init__.py +0 -14
- egse/tcs/tcs.py +0 -874
- 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 -177
- 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 -116
- egse/tempcontrol/agilent/agilent34970_devif.py +0 -182
- egse/tempcontrol/agilent/agilent34970_protocol.py +0 -99
- egse/tempcontrol/agilent/agilent34972.py +0 -111
- egse/tempcontrol/agilent/agilent34972.yaml +0 -44
- egse/tempcontrol/agilent/agilent34972_cs.py +0 -117
- egse/tempcontrol/agilent/agilent34972_devif.py +0 -189
- egse/tempcontrol/agilent/agilent34972_protocol.py +0 -101
- egse/tempcontrol/beaglebone/beaglebone.py +0 -342
- egse/tempcontrol/beaglebone/beaglebone.yaml +0 -110
- egse/tempcontrol/beaglebone/beaglebone_cs.py +0 -117
- egse/tempcontrol/beaglebone/beaglebone_protocol.py +0 -135
- egse/tempcontrol/beaglebone/beaglebone_ui.py +0 -681
- egse/tempcontrol/digalox/digalox.py +0 -107
- egse/tempcontrol/digalox/digalox.yaml +0 -36
- egse/tempcontrol/digalox/digalox_cs.py +0 -112
- egse/tempcontrol/digalox/digalox_protocol.py +0 -55
- 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 -78
- 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 -73
- egse/tempcontrol/lakeshore/lsci_ui.py +0 -389
- 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 -727
- egse/tempcontrol/srs/__init__.py +0 -22
- egse/tempcontrol/srs/ptc10.py +0 -875
- egse/tempcontrol/srs/ptc10.yaml +0 -227
- egse/tempcontrol/srs/ptc10_cs.py +0 -128
- egse/tempcontrol/srs/ptc10_devif.py +0 -118
- egse/tempcontrol/srs/ptc10_protocol.py +0 -42
- 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 -164
- egse/vacuum/beaglebone/beaglebone_protocol.py +0 -193
- egse/vacuum/beaglebone/beaglebone_ui.py +0 -638
- egse/vacuum/instrutech/igm402.py +0 -92
- egse/vacuum/instrutech/igm402.yaml +0 -90
- egse/vacuum/instrutech/igm402_controller.py +0 -128
- 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 -102
- egse/vacuum/keller/leo3.yaml +0 -38
- egse/vacuum/keller/leo3_controller.py +0 -83
- 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 -316
- egse/vacuum/mks/evision_interface.py +0 -60
- egse/vacuum/mks/evision_simulator.py +0 -24
- egse/vacuum/mks/evision_ui.py +0 -704
- 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 -39
- egse/vacuum/pfeiffer/tc400.py +0 -113
- egse/vacuum/pfeiffer/tc400.yaml +0 -83
- egse/vacuum/pfeiffer/tc400_controller.py +0 -140
- egse/vacuum/pfeiffer/tc400_cs.py +0 -109
- egse/vacuum/pfeiffer/tc400_interface.py +0 -70
- egse/vacuum/pfeiffer/tc400_simulator.py +0 -24
- egse/vacuum/pfeiffer/tpg261.py +0 -81
- 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 -60
- egse/vacuum/pfeiffer/tpg261_simulator.py +0 -24
- 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 -44
- scripts/check_hdf5_files.py +0 -192
- scripts/check_register_sync.py +0 -47
- scripts/create_hdf5_report.py +0 -295
- scripts/csl_model.py +0 -436
- scripts/csl_restore_setup.py +0 -230
- scripts/export-grafana-dashboards.py +0 -50
- scripts/fdir/cs_recovery/fdir_cs_recovery.py +0 -59
- scripts/fdir/fdir_table.yaml +0 -70
- scripts/fdir/fdir_test_recovery.py +0 -11
- scripts/fdir/hw_recovery/fdir_agilent_hw_recovery.py +0 -73
- scripts/fdir/limit_recovery/fdir_agilent_limit.py +0 -64
- scripts/fdir/limit_recovery/fdir_bb_heater_limit.py +0 -61
- 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/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/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/tm_gen/tm_gen_agilent.py +0 -38
- 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/tdms.py
DELETED
|
@@ -1,171 +0,0 @@
|
|
|
1
|
-
"""
|
|
2
|
-
This module provides functions to load and parse Labview TDMS files.
|
|
3
|
-
|
|
4
|
-
The text representation of a TDMS file is sent over a TCP/IP socket from the TCS EGSE to the Common-EGSE control
|
|
5
|
-
server. The format of the text string is as follows:
|
|
6
|
-
|
|
7
|
-
There are four groups of data: (1) the start time, (2) the time interval of the sampling, i.e. delta time,
|
|
8
|
-
(3) the parameter names, and (4) the actual sampled data. There is a blank line between each group. Each line
|
|
9
|
-
contains a lot of trailing whitespace in the form of a TAB character, '\\t'.
|
|
10
|
-
|
|
11
|
-
start time:
|
|
12
|
-
12/04/2019 17:38:27.584141
|
|
13
|
-
|
|
14
|
-
dt:
|
|
15
|
-
0.1
|
|
16
|
-
|
|
17
|
-
channel names:
|
|
18
|
-
Ch1_name Ch2_name Ch3_name
|
|
19
|
-
|
|
20
|
-
data:
|
|
21
|
-
0.1 0.2 0.3
|
|
22
|
-
0.2 0.3 0.1
|
|
23
|
-
0.3 0.1 0.2
|
|
24
|
-
|
|
25
|
-
A full description of the TDMS text file format is given in the TCS EGSE ICD [PTO-AST-PL-TCGSE-ICD-0012].
|
|
26
|
-
"""
|
|
27
|
-
import datetime
|
|
28
|
-
import io
|
|
29
|
-
import logging
|
|
30
|
-
from typing import Union
|
|
31
|
-
|
|
32
|
-
import numpy as np
|
|
33
|
-
|
|
34
|
-
from collections import namedtuple
|
|
35
|
-
from pathlib import Path
|
|
36
|
-
|
|
37
|
-
from egse.config import find_file
|
|
38
|
-
from egse.system import Timer
|
|
39
|
-
|
|
40
|
-
logging.basicConfig(level=logging.DEBUG)
|
|
41
|
-
LOGGER = logging.getLogger(__name__)
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
def load_tdms_from_string(data_string: str):
|
|
45
|
-
"""
|
|
46
|
-
Loads and parses a string representation of a Labview TDMS file. This function calls `load_tdms_from_stream()`.
|
|
47
|
-
See the latter function for documentation on the return value.
|
|
48
|
-
|
|
49
|
-
Args:
|
|
50
|
-
data_string: a string containing the TDMS data
|
|
51
|
-
|
|
52
|
-
Returns:
|
|
53
|
-
a namedtuple with fields ['start_time', 'time_interval', 'names', 'values', 'time'].
|
|
54
|
-
|
|
55
|
-
Raises:
|
|
56
|
-
ValueError: when an input error is detected, e.g. incorrect file format or filename is None
|
|
57
|
-
|
|
58
|
-
"""
|
|
59
|
-
with io.StringIO(data_string) as tdms:
|
|
60
|
-
data = load_tdms_from_stream(tdms)
|
|
61
|
-
|
|
62
|
-
return data
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
def load_tdms_from_file(filename: Union[str, Path]):
|
|
66
|
-
"""
|
|
67
|
-
Loads and parses a text file representation of a Labview TDMS file. This function calls `load_tdms_from_stream()`.
|
|
68
|
-
See the latter function for documentation on the return value.
|
|
69
|
-
|
|
70
|
-
Args:
|
|
71
|
-
filename: the full path name of the file
|
|
72
|
-
|
|
73
|
-
Returns:
|
|
74
|
-
a namedtuple with fields ['start_time', 'time_interval', 'names', 'values', 'time'].
|
|
75
|
-
|
|
76
|
-
Raises:
|
|
77
|
-
ValueError: when an input error is detected, e.g. incorrect file format or filename is None
|
|
78
|
-
FileNotFoundError: when a given filename doesn't exist
|
|
79
|
-
|
|
80
|
-
"""
|
|
81
|
-
if filename is None:
|
|
82
|
-
raise ValueError("No filename was given or filename is None.")
|
|
83
|
-
|
|
84
|
-
with Path(filename).open(mode='r') as tdms:
|
|
85
|
-
data = load_tdms_from_stream(tdms)
|
|
86
|
-
|
|
87
|
-
return data
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
def load_tdms_from_stream(stream):
|
|
91
|
-
"""
|
|
92
|
-
Loads and parses a text representation of a Labview TDMS file. The format of the file is fixed and is
|
|
93
|
-
described at the module level docstring.
|
|
94
|
-
|
|
95
|
-
The stream is parsed and returned as a namedtuple which contains the following fields:
|
|
96
|
-
|
|
97
|
-
* **start_time**: a `datetime` object that contains the start time of the sampling period [datetime]
|
|
98
|
-
* **time_interval**: the sampling time interval [s]
|
|
99
|
-
* **names**: a list of parameter names, one for each column in values [str]
|
|
100
|
-
* **values**: a two-dimensional numpy array containing the samples. The shape is (number of names,
|
|
101
|
-
number of samples) [float]
|
|
102
|
-
* **time**: a numpy array with the sampling times for the values [datetime]
|
|
103
|
-
|
|
104
|
-
Args:
|
|
105
|
-
stream: a stream that supports the io protocol for readline() and readlines().
|
|
106
|
-
|
|
107
|
-
Returns:
|
|
108
|
-
a namedtuple with fields ['start_time', 'time_interval', 'names', 'values', 'time'].
|
|
109
|
-
|
|
110
|
-
Raises:
|
|
111
|
-
ValueError: when an input error is detected, e.g. incorrect file format or filename is None
|
|
112
|
-
|
|
113
|
-
"""
|
|
114
|
-
|
|
115
|
-
MAX_LINE_LENGTH = 80
|
|
116
|
-
|
|
117
|
-
# The first line in the file shall be the starting time of the sample
|
|
118
|
-
|
|
119
|
-
line = stream.readline()
|
|
120
|
-
if line.startswith('start time:'):
|
|
121
|
-
line = stream.readline().rstrip()
|
|
122
|
-
start_time = line.split('\t')[0]
|
|
123
|
-
start_time = datetime.datetime.strptime(start_time, '%m/%d/%Y %H:%M:%S.%f')
|
|
124
|
-
else:
|
|
125
|
-
raise ValueError(
|
|
126
|
-
f"TDMS Error: expected start time as the first line, got {line[:MAX_LINE_LENGTH]}.")
|
|
127
|
-
|
|
128
|
-
# The next line shall be the time interval 'dt' as a float
|
|
129
|
-
|
|
130
|
-
stream.readline() # skip the empty line
|
|
131
|
-
line = stream.readline()
|
|
132
|
-
if line.startswith('dt:'):
|
|
133
|
-
line = stream.readline().rstrip()
|
|
134
|
-
time_interval = float(line.split('\t')[0])
|
|
135
|
-
else:
|
|
136
|
-
raise ValueError(f"TDMS Error: expected 'dt:', got {line[:MAX_LINE_LENGTH]}.")
|
|
137
|
-
|
|
138
|
-
# The next line contains the channel names
|
|
139
|
-
|
|
140
|
-
stream.readline() # skip the empty line
|
|
141
|
-
line = stream.readline()
|
|
142
|
-
if line.startswith('channel names:'):
|
|
143
|
-
line = stream.readline().rstrip()
|
|
144
|
-
names = line.split('\t')
|
|
145
|
-
keys = [name for name in names]
|
|
146
|
-
data = [[] for _ in names]
|
|
147
|
-
else:
|
|
148
|
-
raise ValueError(f"TDMS Error: expected 'channel names:', got {line[:MAX_LINE_LENGTH]}.")
|
|
149
|
-
|
|
150
|
-
# The next lines contain the data
|
|
151
|
-
|
|
152
|
-
stream.readline() # skip the empty line
|
|
153
|
-
line = stream.readline()
|
|
154
|
-
if line.startswith('data:'):
|
|
155
|
-
lines = stream.readlines() # this should read the rest of the file
|
|
156
|
-
for line in lines:
|
|
157
|
-
values = line.rstrip().split('\t')
|
|
158
|
-
for idx, value in enumerate(values):
|
|
159
|
-
data[idx].append(float(value))
|
|
160
|
-
else:
|
|
161
|
-
raise ValueError(f"TDMS Error: expected 'data:', got {line[:MAX_LINE_LENGTH]}.")
|
|
162
|
-
|
|
163
|
-
time_serie = np.array(
|
|
164
|
-
[start_time + datetime.timedelta(seconds=x*time_interval) for x in range(len(lines))]
|
|
165
|
-
)
|
|
166
|
-
|
|
167
|
-
# Make a data structure out of this, i.e. a named tuple
|
|
168
|
-
|
|
169
|
-
tdms = namedtuple('TDMS', ['start_time', 'time_interval', 'names', 'values', 'time'])
|
|
170
|
-
|
|
171
|
-
return tdms(start_time=start_time, time_interval=time_interval, names=keys, values=np.array(data), time=time_serie)
|
egse/tempcontrol/__init__.py
DELETED
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
"""
|
|
2
|
-
This package provides services for different kinds of temperature controllers.
|
|
3
|
-
|
|
4
|
-
The current on-going work is for support of the following devices:
|
|
5
|
-
|
|
6
|
-
* Keithley DAQ6510
|
|
7
|
-
* LakeShore Model 336
|
|
8
|
-
* National Instruments
|
|
9
|
-
* SRS PTC10 temperature regulator
|
|
10
|
-
|
|
11
|
-
"""
|
|
12
|
-
class TempError(Exception):
|
|
13
|
-
pass
|
|
14
|
-
|
|
15
|
-
# The __pdoc__ dict is understood by pdoc3 and instructs to exclude the 'keys' from the documentation.
|
|
16
|
-
# See: https://pdoc3.github.io/pdoc/doc/pdoc/#overriding-docstrings-with-__pdoc__
|
|
17
|
-
|
|
18
|
-
# The following modules are excluded because they assume the gssw package is installed (SRON specific)
|
|
19
|
-
|
|
20
|
-
__pdoc__ = {
|
|
21
|
-
'beaglebone': False,
|
|
22
|
-
'spid': False,
|
|
23
|
-
}
|
|
@@ -1,109 +0,0 @@
|
|
|
1
|
-
import logging
|
|
2
|
-
|
|
3
|
-
from egse.proxy import Proxy
|
|
4
|
-
from egse.decorators import dynamic_interface
|
|
5
|
-
from egse.device import DeviceInterface
|
|
6
|
-
from egse.settings import Settings
|
|
7
|
-
from egse.tempcontrol.agilent.agilent34970_devif import Agilent34970Error
|
|
8
|
-
from egse.tempcontrol.agilent.agilent34970_devif import Agilent34970DeviceInterface
|
|
9
|
-
from egse.zmq_ser import connect_address
|
|
10
|
-
|
|
11
|
-
logger = logging.getLogger(__name__)
|
|
12
|
-
|
|
13
|
-
DEVICE_SETTINGS = Settings.load(filename='agilent34970.yaml')
|
|
14
|
-
CTRL_SETTINGS = Settings.load("Agilent 34970 Control Server")
|
|
15
|
-
|
|
16
|
-
class Agilent34970Interface(DeviceInterface):
|
|
17
|
-
""" Agilent 34970 base class."""
|
|
18
|
-
|
|
19
|
-
@dynamic_interface
|
|
20
|
-
def get_idn(self):
|
|
21
|
-
""" Get Agilent34970 IDN message. """
|
|
22
|
-
return NotImplemented
|
|
23
|
-
|
|
24
|
-
@dynamic_interface
|
|
25
|
-
def read_resistance_temperature(self):
|
|
26
|
-
""" Measure 4-wire resistance. """
|
|
27
|
-
return NotImplemented
|
|
28
|
-
|
|
29
|
-
@dynamic_interface
|
|
30
|
-
def trigger_scan(self):
|
|
31
|
-
return NotImplemented
|
|
32
|
-
|
|
33
|
-
class Agilent34970Simulator(Agilent34970Interface):
|
|
34
|
-
|
|
35
|
-
def __init__(self):
|
|
36
|
-
self._is_connected = True
|
|
37
|
-
|
|
38
|
-
def is_connected(self):
|
|
39
|
-
return self._is_connected
|
|
40
|
-
|
|
41
|
-
def is_simulator(self):
|
|
42
|
-
return True
|
|
43
|
-
|
|
44
|
-
def connect(self):
|
|
45
|
-
self._is_connected = True
|
|
46
|
-
|
|
47
|
-
def disconnect(self):
|
|
48
|
-
self._is_connected = False
|
|
49
|
-
|
|
50
|
-
def reconnect(self):
|
|
51
|
-
if self.is_connected():
|
|
52
|
-
self.disconnect()
|
|
53
|
-
self.connect()
|
|
54
|
-
|
|
55
|
-
def get_idn(self, dev_idx):
|
|
56
|
-
return 'Agilent34970'
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
def read_resistance_temperature(self):
|
|
60
|
-
return [0, 0, 0, 0], [0, 0, 0, 0]
|
|
61
|
-
|
|
62
|
-
def trigger_scan(self):
|
|
63
|
-
pass
|
|
64
|
-
|
|
65
|
-
class Agilent34970Controller(Agilent34970Interface):
|
|
66
|
-
|
|
67
|
-
def __init__(self, device_index):
|
|
68
|
-
super().__init__()
|
|
69
|
-
|
|
70
|
-
logger.debug('Initalizing Agilent34970 Controller')
|
|
71
|
-
|
|
72
|
-
try:
|
|
73
|
-
self.agilent = Agilent34970DeviceInterface(device_index)
|
|
74
|
-
except Agilent34970Error as exc:
|
|
75
|
-
logger.warning(f"Agilent34970Error caught: Couldn't establish connectin ({exc})")
|
|
76
|
-
raise Agilent34970Error(
|
|
77
|
-
"Couldn't establish a connection with Agilent34970 controller."
|
|
78
|
-
) from exc
|
|
79
|
-
|
|
80
|
-
def is_simulator(self):
|
|
81
|
-
return False
|
|
82
|
-
|
|
83
|
-
def is_connected(self):
|
|
84
|
-
return self.agilent.is_connected()
|
|
85
|
-
|
|
86
|
-
def connect(self):
|
|
87
|
-
if not self.agilent.is_connected():
|
|
88
|
-
self.agilent.connect()
|
|
89
|
-
|
|
90
|
-
def disconnect(self):
|
|
91
|
-
self.agilent.disconnect()
|
|
92
|
-
|
|
93
|
-
def reconnect(self):
|
|
94
|
-
self.agilent.reconnect()
|
|
95
|
-
|
|
96
|
-
def get_idn(self):
|
|
97
|
-
return self.agilent.get_idn()
|
|
98
|
-
|
|
99
|
-
def read_resistance_temperature(self):
|
|
100
|
-
return self.agilent.read_resistance_temperature()
|
|
101
|
-
|
|
102
|
-
def trigger_scan(self):
|
|
103
|
-
return self.agilent.trigger_scan()
|
|
104
|
-
|
|
105
|
-
class Agilent34970Proxy(Proxy, Agilent34970Interface):
|
|
106
|
-
def __init__(self, agilent_index: int):
|
|
107
|
-
self.name = "DAQ"+str(agilent_index)
|
|
108
|
-
|
|
109
|
-
super().__init__(connect_address(CTRL_SETTINGS.PROTOCOL, CTRL_SETTINGS.HOSTNAME, CTRL_SETTINGS[self.name]["COMMANDING_PORT"]), timeout=20000)
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
BaseClass:
|
|
2
|
-
egse.tempcontrol.agilent.Agilent34970Interface
|
|
3
|
-
|
|
4
|
-
ProxyClass:
|
|
5
|
-
egse.tempcontrol.agilent.Agilent34970Proxy
|
|
6
|
-
|
|
7
|
-
ControlServerClass:
|
|
8
|
-
egse.tempcontrol.agilent.Agilent34972ControlServer
|
|
9
|
-
|
|
10
|
-
ControlServer:
|
|
11
|
-
egse.tempcontrol.agilent.agilent34970_cs
|
|
12
|
-
|
|
13
|
-
Commands:
|
|
14
|
-
# The command strings in this file are not used.
|
|
15
|
-
# They need to include the arguments of the commands though or else the control server will
|
|
16
|
-
# remove them from the interface.
|
|
17
|
-
|
|
18
|
-
disconnect:
|
|
19
|
-
description: Disconnect from the Agilent34970 Controller.
|
|
20
|
-
|
|
21
|
-
connect:
|
|
22
|
-
description: Connect to the Agilent34970 Controller.
|
|
23
|
-
|
|
24
|
-
reconnect:
|
|
25
|
-
description: Reconnect to the Agilent34970 Controller.
|
|
26
|
-
|
|
27
|
-
is_simulator:
|
|
28
|
-
description: Ask if the control server is a simulator.
|
|
29
|
-
returns: bool | True if far end is a simulator.
|
|
30
|
-
|
|
31
|
-
is_connected:
|
|
32
|
-
description: Check if Agilent34970 Controller is connected.
|
|
33
|
-
|
|
34
|
-
# Definition of the device commands.
|
|
35
|
-
get_idn:
|
|
36
|
-
description: Get device IDN message.
|
|
37
|
-
returns: str
|
|
38
|
-
|
|
39
|
-
read_resistance_temperature:
|
|
40
|
-
description: Measure temperatures for all channels in the scan list
|
|
41
|
-
returns: tuple(list(float), list(float)) | tuple of lists of resistance and temperature values
|
|
42
|
-
|
|
43
|
-
trigger_scan:
|
|
44
|
-
description: Perform a scan of the specified channels
|
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
import argparse
|
|
3
|
-
import logging
|
|
4
|
-
import sys
|
|
5
|
-
import click
|
|
6
|
-
|
|
7
|
-
import zmq
|
|
8
|
-
from prometheus_client import start_http_server
|
|
9
|
-
|
|
10
|
-
import multiprocessing
|
|
11
|
-
multiprocessing.current_process().name = "agilent34970_cs"
|
|
12
|
-
|
|
13
|
-
from egse.control import ControlServer
|
|
14
|
-
from egse.settings import Settings
|
|
15
|
-
from egse.zmq_ser import connect_address
|
|
16
|
-
from egse.tempcontrol.agilent.agilent34970 import Agilent34970Interface, Agilent34970Proxy
|
|
17
|
-
from egse.tempcontrol.agilent.agilent34970_protocol import Agilent34970Protocol
|
|
18
|
-
|
|
19
|
-
logging.basicConfig(level=logging.DEBUG, format=Settings.LOG_FORMAT_FULL)
|
|
20
|
-
|
|
21
|
-
logger = logging.getLogger('__name__')
|
|
22
|
-
|
|
23
|
-
CTRL_SETTINGS = Settings.load("Agilent 34970 Control Server")
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
class Agilent34970ControlServer(ControlServer):
|
|
27
|
-
|
|
28
|
-
def __init__(self, index):
|
|
29
|
-
self.index = index
|
|
30
|
-
self.name = "DAQ"+str(index)
|
|
31
|
-
super().__init__()
|
|
32
|
-
|
|
33
|
-
self.device_protocol = Agilent34970Protocol(self, self.index)
|
|
34
|
-
|
|
35
|
-
logger.debug(f'Binding ZeroMQ socket to {self.device_protocol.get_bind_address()}')
|
|
36
|
-
|
|
37
|
-
self.device_protocol.bind(self.dev_ctrl_cmd_sock)
|
|
38
|
-
|
|
39
|
-
self.poller.register(self.dev_ctrl_cmd_sock, zmq.POLLIN)
|
|
40
|
-
|
|
41
|
-
self.set_hk_delay(CTRL_SETTINGS.DELAY)
|
|
42
|
-
|
|
43
|
-
def get_communication_protocol(self):
|
|
44
|
-
return CTRL_SETTINGS.PROTOCOL
|
|
45
|
-
|
|
46
|
-
def get_commanding_port(self):
|
|
47
|
-
return CTRL_SETTINGS[self.name]['COMMANDING_PORT']
|
|
48
|
-
|
|
49
|
-
def get_service_port(self):
|
|
50
|
-
return CTRL_SETTINGS[self.name]['SERVICE_PORT']
|
|
51
|
-
|
|
52
|
-
def get_monitoring_port(self):
|
|
53
|
-
return CTRL_SETTINGS[self.name]['MONITORING_PORT']
|
|
54
|
-
|
|
55
|
-
def get_storage_mnemonic(self):
|
|
56
|
-
try:
|
|
57
|
-
return CTRL_SETTINGS[self.name]['STORAGE_MNEMONIC']
|
|
58
|
-
except:
|
|
59
|
-
return f'Agilent34970_{self.index}'
|
|
60
|
-
|
|
61
|
-
def before_serve(self):
|
|
62
|
-
start_http_server(CTRL_SETTINGS[self.name]['METRICS_PORT'])
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
@click.group()
|
|
66
|
-
def cli():
|
|
67
|
-
pass
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
@cli.command()
|
|
71
|
-
@click.option("--simulator", "--sim", is_flag=True, help="Start the Agilent34970 Simulator as the backend.")
|
|
72
|
-
@click.argument('index', type=click.IntRange(0, 1))
|
|
73
|
-
def start(simulator, index):
|
|
74
|
-
"""Start the BeagleBone Control Server."""
|
|
75
|
-
|
|
76
|
-
if simulator:
|
|
77
|
-
Settings.set_simulation_mode(True)
|
|
78
|
-
try:
|
|
79
|
-
logger.debug(f'Starting Agilent 34970 {index} Control Server')
|
|
80
|
-
|
|
81
|
-
multiprocessing.current_process().name = f"agilent34970_cs_{index}"
|
|
82
|
-
|
|
83
|
-
control_server = Agilent34970ControlServer(index)
|
|
84
|
-
control_server.serve()
|
|
85
|
-
|
|
86
|
-
except KeyboardInterrupt:
|
|
87
|
-
logger.info("Shutdown requested...exiting")
|
|
88
|
-
|
|
89
|
-
except SystemExit as exit_code:
|
|
90
|
-
logger.info("System Exit with code {}.".format(exit_code))
|
|
91
|
-
sys.exit(exit_code)
|
|
92
|
-
|
|
93
|
-
except Exception:
|
|
94
|
-
|
|
95
|
-
logger.exception("Cannot start the Agilent Control Server")
|
|
96
|
-
# The above line does exactly the same as the traceback, but on the logger
|
|
97
|
-
# import traceback
|
|
98
|
-
# traceback.print_exc(file=sys.stdout)
|
|
99
|
-
|
|
100
|
-
return 0
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
@cli.command()
|
|
104
|
-
@click.argument('index', type=click.IntRange(0, 1))
|
|
105
|
-
def stop(index):
|
|
106
|
-
"""Send a 'quit_server' command to the Control Server."""
|
|
107
|
-
|
|
108
|
-
with Agilent34970Proxy(index) as proxy:
|
|
109
|
-
|
|
110
|
-
sp = proxy.get_service_proxy()
|
|
111
|
-
sp.quit_server()
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
if __name__ == "__main__":
|
|
115
|
-
|
|
116
|
-
sys.exit(cli())
|
|
@@ -1,182 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
|
|
3
|
-
import logging
|
|
4
|
-
import time
|
|
5
|
-
|
|
6
|
-
from egse.command import ClientServerCommand
|
|
7
|
-
from egse.exceptions import DeviceNotFoundError
|
|
8
|
-
from egse.serialdevice import SerialDevice
|
|
9
|
-
from egse.settings import Settings
|
|
10
|
-
from egse.setup import get_setup
|
|
11
|
-
|
|
12
|
-
logger = logging.getLogger(__name__)
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
class Agilent34970Error(Exception):
|
|
17
|
-
pass
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
class Agilent34970Command(ClientServerCommand):
|
|
21
|
-
def get_cmd_string(self, *args, **kwargs):
|
|
22
|
-
out = super().get_cmd_string(*args, **kwargs)
|
|
23
|
-
return out + '\n'
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
class Agilent34970DeviceInterface(SerialDevice):
|
|
27
|
-
|
|
28
|
-
def __init__(self, device_index):
|
|
29
|
-
|
|
30
|
-
self._ctrl_settings = Settings.load(f'Agilent 34970 Controller')
|
|
31
|
-
self._setup = get_setup()
|
|
32
|
-
|
|
33
|
-
self.device_index = device_index
|
|
34
|
-
|
|
35
|
-
# Load device configuration from the common-egse global config file
|
|
36
|
-
self._port = self._ctrl_settings[f"DAQ {device_index}"]["PORT"]
|
|
37
|
-
self._baudrate = self._ctrl_settings[f"DAQ {device_index}"]["BAUDRATE"]
|
|
38
|
-
|
|
39
|
-
self._setup = self._setup['gse'][f'agilent34970_{device_index}']
|
|
40
|
-
self._conversions = self._setup['conversion']
|
|
41
|
-
|
|
42
|
-
# Initialize the SerialDevice class with the port and baudrate
|
|
43
|
-
super().__init__(port=self._port, baudrate=self._baudrate, terminator='\n', timeout=15)
|
|
44
|
-
self.connect()
|
|
45
|
-
|
|
46
|
-
self.create_scanlist()
|
|
47
|
-
self.configure_agilent()
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
def get_idn(self):
|
|
51
|
-
return self.query('*IDN?\n')
|
|
52
|
-
|
|
53
|
-
def format_scanlist(self, ch_list):
|
|
54
|
-
scanlist = '(@'
|
|
55
|
-
for idx, ch in enumerate(ch_list):
|
|
56
|
-
if idx == 0:
|
|
57
|
-
scanlist += f'{ch}'
|
|
58
|
-
elif idx < len(ch_list):
|
|
59
|
-
scanlist += f',{ch}'
|
|
60
|
-
scanlist += ')'
|
|
61
|
-
return scanlist
|
|
62
|
-
|
|
63
|
-
def create_scanlist(self):
|
|
64
|
-
thermocouple = self._setup.thermocouples
|
|
65
|
-
two_wire = self._setup.two_wire
|
|
66
|
-
four_wire = self._setup.four_wire
|
|
67
|
-
pt100 = self._setup.pt100
|
|
68
|
-
|
|
69
|
-
self.scanlist = thermocouple + two_wire + four_wire
|
|
70
|
-
self.scanlist.sort()
|
|
71
|
-
|
|
72
|
-
self.thermocouple = thermocouple
|
|
73
|
-
self.two_wire = two_wire
|
|
74
|
-
self.four_wire = four_wire
|
|
75
|
-
self.pt100 = pt100
|
|
76
|
-
|
|
77
|
-
def configure_agilent(self):
|
|
78
|
-
|
|
79
|
-
# Extract configuration and scanlist from setup
|
|
80
|
-
scan_list = self.format_scanlist(self.scanlist) if self.scanlist != [] else []
|
|
81
|
-
thermocouple_list = self.format_scanlist(self.thermocouple) if self.thermocouple != [] else []
|
|
82
|
-
two_wire_list = self.format_scanlist(self.two_wire) if self.two_wire != [] else []
|
|
83
|
-
four_wire_list = self.format_scanlist(self.four_wire) if self.four_wire != [] else []
|
|
84
|
-
pt100_list = self.format_scanlist(self.pt100) if self.pt100 != [] else []
|
|
85
|
-
|
|
86
|
-
logger.info(f"Thermocouples: {thermocouple_list}")
|
|
87
|
-
logger.info(f"Two wire: {two_wire_list}")
|
|
88
|
-
logger.info(f"Four wire: {four_wire_list}")
|
|
89
|
-
logger.info(f"Pt100s: {pt100_list}")
|
|
90
|
-
logger.info(f"Final scanlist: {scan_list}")
|
|
91
|
-
|
|
92
|
-
# Reset scan list
|
|
93
|
-
self.send_command("*RST\n")
|
|
94
|
-
|
|
95
|
-
# Configure channels
|
|
96
|
-
if two_wire_list != []:
|
|
97
|
-
self.send_command(f"CONF:RES {two_wire_list}\n")
|
|
98
|
-
time.sleep(1)
|
|
99
|
-
if four_wire_list != []:
|
|
100
|
-
self.send_command(f"CONF:FRES {four_wire_list}\n")
|
|
101
|
-
time.sleep(1)
|
|
102
|
-
if thermocouple_list != []:
|
|
103
|
-
self.send_command(f"CONF:TEMP TC,T,{thermocouple_list}\n")
|
|
104
|
-
time.sleep(1)
|
|
105
|
-
if pt100_list != []:
|
|
106
|
-
self.send_command(f"CALC:SCAL:GAIN 10,{pt100_list}\n")
|
|
107
|
-
self.send_command(f'CALC:SCAL:STAT ON,{pt100_list}\n')
|
|
108
|
-
time.sleep(1)
|
|
109
|
-
|
|
110
|
-
# Save values with unit
|
|
111
|
-
self.send_command("FORM:READ:UNIT ON\n")
|
|
112
|
-
self.send_command("FORM:READ:CHAN ON\n")
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
# Load scan list
|
|
116
|
-
self.send_command(f"ROUT:SCAN {scan_list}\n")
|
|
117
|
-
time.sleep(0.1)
|
|
118
|
-
|
|
119
|
-
self.send_command(f'SENS:VOLT:DC:NPLC 10\n')
|
|
120
|
-
self.send_command('ROUT:CHAN:DEL 0.1\n')
|
|
121
|
-
|
|
122
|
-
self.send_command("INIT\n")
|
|
123
|
-
time.sleep(15)
|
|
124
|
-
|
|
125
|
-
def trigger_scan(self):
|
|
126
|
-
self.send_command("INIT\n")
|
|
127
|
-
|
|
128
|
-
def read_resistance_temperature(self):
|
|
129
|
-
# Fetch values stored in non-volatile memory
|
|
130
|
-
return_string = self.query(f"DATA:REMOVE? {len(self.scanlist)}\n")
|
|
131
|
-
|
|
132
|
-
# Check for errors
|
|
133
|
-
if len(return_string) == 0:
|
|
134
|
-
raise ConnectionError(f"No reply from device")
|
|
135
|
-
|
|
136
|
-
if return_string[-1] != '\n':
|
|
137
|
-
raise ConnectionError(f"Invalid termination character in response: {return_string}")
|
|
138
|
-
|
|
139
|
-
values = return_string.split(',')
|
|
140
|
-
|
|
141
|
-
resistances = {}
|
|
142
|
-
temperatures = {}
|
|
143
|
-
|
|
144
|
-
for i in range(0, len(values), 2):
|
|
145
|
-
value = values[i].split(' ')
|
|
146
|
-
channel = int(values[i+1])
|
|
147
|
-
if 'C' in value or 'C\r' in value:
|
|
148
|
-
resistances[f'{channel}'] = 0
|
|
149
|
-
temperatures[f'{channel}'] = float(value[0])
|
|
150
|
-
elif 'OHM' in value or 'OHM\r' in value:
|
|
151
|
-
resistances[f'{channel}'] = abs(float(value[0]))
|
|
152
|
-
temperatures[f'{channel}'] = self._convert_resistance(abs(float(value[0])))
|
|
153
|
-
|
|
154
|
-
# Return values as list
|
|
155
|
-
return resistances, temperatures
|
|
156
|
-
|
|
157
|
-
def _convert_resistance(self, resistance):
|
|
158
|
-
return ( self._conversions[0]
|
|
159
|
-
+ self._conversions[1] * resistance
|
|
160
|
-
+ self._conversions[2] * resistance**2
|
|
161
|
-
+ self._conversions[3] * resistance**3
|
|
162
|
-
+ self._conversions[4] * resistance**4
|
|
163
|
-
+ self._conversions[5] * resistance**5
|
|
164
|
-
)
|
|
165
|
-
|
|
166
|
-
def main():
|
|
167
|
-
|
|
168
|
-
dev0 = Agilent34970DeviceInterface(0)
|
|
169
|
-
dev1 = Agilent34970DeviceInterface(1)
|
|
170
|
-
print(dev0.get_idn())
|
|
171
|
-
print(dev1.get_idn())
|
|
172
|
-
|
|
173
|
-
while True:
|
|
174
|
-
dev0.trigger_scan()
|
|
175
|
-
dev1.trigger_scan()
|
|
176
|
-
time.sleep(10)
|
|
177
|
-
print(dev0.read_resistance_temperature())
|
|
178
|
-
print(dev1.read_resistance_temperature())
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
if __name__ == '__main__':
|
|
182
|
-
main()
|