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
|
@@ -1,140 +0,0 @@
|
|
|
1
|
-
import logging
|
|
2
|
-
import time
|
|
3
|
-
from functools import partial
|
|
4
|
-
from copy import deepcopy
|
|
5
|
-
|
|
6
|
-
from egse.serialdevice import SerialDevice
|
|
7
|
-
from egse.command import Command
|
|
8
|
-
from egse.settings import Settings
|
|
9
|
-
from egse.vacuum.pfeiffer.tc400_interface import Tc400Interface, Tc400Command
|
|
10
|
-
|
|
11
|
-
logger = logging.getLogger(__name__)
|
|
12
|
-
|
|
13
|
-
# Load the device settings from the global common-egse config file
|
|
14
|
-
DEVICE_SETTINGS = Settings.load("Pfeiffer TC400 Controller")
|
|
15
|
-
|
|
16
|
-
# Load the device protocol
|
|
17
|
-
DEVICE_PROTOCOL = Settings.load(filename='tc400.yaml')['Commands']
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
def get_checksum(data):
|
|
22
|
-
""" Checksum is the addition modulo 265 of ascii values in the dataword. """
|
|
23
|
-
|
|
24
|
-
charsum = sum(ord(c) for c in data)
|
|
25
|
-
return charsum % 256
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
class Tc400Controller(SerialDevice, Tc400Interface):
|
|
29
|
-
|
|
30
|
-
def __init__(self, port=None, baudrate=None, address=None):
|
|
31
|
-
|
|
32
|
-
# Load device configuration from the common-egse global config file
|
|
33
|
-
self._port = DEVICE_SETTINGS.PORT if port is None else port
|
|
34
|
-
self._baudrate = DEVICE_SETTINGS.BAUDRATE if baudrate is None else baudrate
|
|
35
|
-
self._address = DEVICE_SETTINGS.ADDRESS if address is None else address
|
|
36
|
-
|
|
37
|
-
# Initialize the parent class with the port and baudrate
|
|
38
|
-
super().__init__(port=self._port, baudrate=self._baudrate)
|
|
39
|
-
self.connect()
|
|
40
|
-
|
|
41
|
-
def get_idn(self):
|
|
42
|
-
cmd = f"{self._address:03d}0034902=?"
|
|
43
|
-
cmd += f"{get_checksum(cmd):03d}" + "\r"
|
|
44
|
-
return self.query(cmd)
|
|
45
|
-
|
|
46
|
-
def get_last_error(self):
|
|
47
|
-
cmd = f"{self._address:03d}0030302=?"
|
|
48
|
-
cmd += f"{get_checksum(cmd):03d}" + "\r"
|
|
49
|
-
return int(self.query(cmd))
|
|
50
|
-
|
|
51
|
-
def get_active_speed(self):
|
|
52
|
-
cmd = f"{self._address:03d}0030902=?"
|
|
53
|
-
cmd += f"{get_checksum(cmd):03d}" + "\r"
|
|
54
|
-
return int(self.query(cmd))
|
|
55
|
-
|
|
56
|
-
def get_drive_power(self):
|
|
57
|
-
cmd = f"{self._address:03d}0031602=?"
|
|
58
|
-
cmd += f"{get_checksum(cmd):03d}" + "\r"
|
|
59
|
-
return int(self.query(cmd))
|
|
60
|
-
|
|
61
|
-
def get_motor_temperature(self):
|
|
62
|
-
cmd = f"{self._address:03d}0034602=?"
|
|
63
|
-
cmd += f"{get_checksum(cmd):03d}" + "\r"
|
|
64
|
-
return int(self.query(cmd))
|
|
65
|
-
|
|
66
|
-
def set_heating(self, enable):
|
|
67
|
-
cmd = f"{self._address:03d}1000101{int(enable):1d}"
|
|
68
|
-
cmd += f"{get_checksum(cmd):03d}" + "\r"
|
|
69
|
-
return self.query(cmd)
|
|
70
|
-
|
|
71
|
-
def set_standby(self, enable):
|
|
72
|
-
cmd = f"{self._address:03d}1000201{int(enable):1d}"
|
|
73
|
-
cmd += f"{get_checksum(cmd):03d}" + "\r"
|
|
74
|
-
return self.query(cmd)
|
|
75
|
-
|
|
76
|
-
def set_pumpingstation(self, enable):
|
|
77
|
-
cmd = f"{self._address:03d}1001001{int(enable):1d}"
|
|
78
|
-
cmd += f"{get_checksum(cmd):03d}" + "\r"
|
|
79
|
-
return self.query(cmd)
|
|
80
|
-
|
|
81
|
-
def set_motorpump(self, enable):
|
|
82
|
-
cmd = f"{self._address:03d}1002301{int(enable):1d}"
|
|
83
|
-
cmd += f"{get_checksum(cmd):03d}" + "\r"
|
|
84
|
-
return self.query(cmd)
|
|
85
|
-
|
|
86
|
-
def set_gasmode(self, mode):
|
|
87
|
-
cmd = f"{self._address:03d}100271{mode:1d}"
|
|
88
|
-
cmd += f"{get_checksum(cmd):03d}" + "\r"
|
|
89
|
-
return self.query(cmd)
|
|
90
|
-
|
|
91
|
-
def query(self, command: str):
|
|
92
|
-
""" Override the parent class to do some error checking on the response. """
|
|
93
|
-
|
|
94
|
-
response = super().query(command)
|
|
95
|
-
|
|
96
|
-
if len(response) == 0:
|
|
97
|
-
raise ConnectionError(f"No reply from device")
|
|
98
|
-
|
|
99
|
-
elif response[-1] != '\r':
|
|
100
|
-
raise ConnectionError(f"Invalid termination character in response: {response}")
|
|
101
|
-
|
|
102
|
-
elif int(response[:3]) != self._address:
|
|
103
|
-
raise ConnectionError(
|
|
104
|
-
f"Got response with incorrect address from device: {response[:3]}")
|
|
105
|
-
|
|
106
|
-
elif response[3] != '1':
|
|
107
|
-
raise ConnectionError(f"Invalid opcode in response: {response}")
|
|
108
|
-
|
|
109
|
-
elif Tc400Command.get_checksum(response[:-4]) != int(response[-4:-1]):
|
|
110
|
-
raise ConnectionError(
|
|
111
|
-
f"Invalid checksum in response: {get_checksum(response[:-4])} != {int(response[-4:-1])}")
|
|
112
|
-
|
|
113
|
-
elif int(response[8:10]) == 6:
|
|
114
|
-
if response[10:16] == 'NO_DEF':
|
|
115
|
-
raise ConnectionError(f"Error response: parameter {response[5:8]} does not exist")
|
|
116
|
-
elif response[10:16] == '_RANGE':
|
|
117
|
-
raise ConnectionError(f"Error response: data outside permitted range")
|
|
118
|
-
elif response[10:16] == '_LOGIC':
|
|
119
|
-
raise ConnectionError(f"Error response: Logic access violation")
|
|
120
|
-
|
|
121
|
-
return response[10:-4]
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
def main():
|
|
125
|
-
logging.basicConfig()
|
|
126
|
-
|
|
127
|
-
dev = Tc400Controller()
|
|
128
|
-
|
|
129
|
-
print(dev.get_idn())
|
|
130
|
-
print(dev.get_active_speed())
|
|
131
|
-
print(dev.get_drive_power())
|
|
132
|
-
print(dev.get_motor_temperature())
|
|
133
|
-
print(dev.get_last_error())
|
|
134
|
-
|
|
135
|
-
#print(dev.set_motorpump(False))
|
|
136
|
-
# print(dev.set_pumpingstation(False))
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
if __name__ == '__main__':
|
|
140
|
-
main()
|
egse/vacuum/pfeiffer/tc400_cs.py
DELETED
|
@@ -1,109 +0,0 @@
|
|
|
1
|
-
import click
|
|
2
|
-
import logging
|
|
3
|
-
import sys
|
|
4
|
-
|
|
5
|
-
import zmq
|
|
6
|
-
from prometheus_client import start_http_server
|
|
7
|
-
|
|
8
|
-
from egse.control import ControlServer
|
|
9
|
-
from egse.settings import Settings
|
|
10
|
-
from egse.vacuum.pfeiffer.tc400 import Tc400Protocol, Tc400Proxy
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
logging.basicConfig(level=logging.DEBUG, format=Settings.LOG_FORMAT_FULL)
|
|
14
|
-
|
|
15
|
-
logger = logging.getLogger(__name__)
|
|
16
|
-
|
|
17
|
-
CTRL_SETTINGS = Settings.load("Pfeiffer TC400 Control Server")
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
class Tc400ControlServer(ControlServer):
|
|
21
|
-
"""
|
|
22
|
-
Tc400ControlServer - Command and monitor the Tc400 roots pump controller.
|
|
23
|
-
This class works as a command and monitoring server to control the device remotely.
|
|
24
|
-
The sever binds to the following ZeroMQ sockets:
|
|
25
|
-
* a REP socket that can be used as a command server. Any client can connect and
|
|
26
|
-
send a command to the Lamp controller.
|
|
27
|
-
* a PUB socket that serves as a monitoring server. It will send out Lamp status
|
|
28
|
-
information to all the connected clients every DELAY seconds.
|
|
29
|
-
"""
|
|
30
|
-
|
|
31
|
-
def __init__(self):
|
|
32
|
-
super().__init__()
|
|
33
|
-
|
|
34
|
-
self.device_protocol = Tc400Protocol(self)
|
|
35
|
-
|
|
36
|
-
self.logger.debug(f"Binding ZeroMQ socket to {self.device_protocol.get_bind_address()}")
|
|
37
|
-
|
|
38
|
-
self.device_protocol.bind(self.dev_ctrl_cmd_sock)
|
|
39
|
-
|
|
40
|
-
self.poller.register(self.dev_ctrl_cmd_sock, zmq.POLLIN)
|
|
41
|
-
|
|
42
|
-
def get_communication_protocol(self):
|
|
43
|
-
return CTRL_SETTINGS.PROTOCOL
|
|
44
|
-
|
|
45
|
-
def get_commanding_port(self):
|
|
46
|
-
return CTRL_SETTINGS.COMMANDING_PORT
|
|
47
|
-
|
|
48
|
-
def get_service_port(self):
|
|
49
|
-
return CTRL_SETTINGS.SERVICE_PORT
|
|
50
|
-
|
|
51
|
-
def get_monitoring_port(self):
|
|
52
|
-
return CTRL_SETTINGS.MONITORING_PORT
|
|
53
|
-
|
|
54
|
-
def get_storage_mnemonic(self):
|
|
55
|
-
try:
|
|
56
|
-
return CTRL_SETTINGS.STORAGE_MNEMONIC
|
|
57
|
-
except AttributeError:
|
|
58
|
-
return "TC400"
|
|
59
|
-
|
|
60
|
-
def before_serve(self):
|
|
61
|
-
start_http_server(CTRL_SETTINGS.METRICS_PORT)
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
@click.group()
|
|
65
|
-
def cli():
|
|
66
|
-
pass
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
@cli.command()
|
|
70
|
-
@click.option("--simulator", "--sim", is_flag=True, help="Start the TC400 Simulator as the backend.")
|
|
71
|
-
def start(simulator):
|
|
72
|
-
"""Start the TC400 Control Server."""
|
|
73
|
-
|
|
74
|
-
if simulator:
|
|
75
|
-
Settings.set_simulation_mode(True)
|
|
76
|
-
try:
|
|
77
|
-
controller = Tc400ControlServer()
|
|
78
|
-
controller.serve()
|
|
79
|
-
|
|
80
|
-
except KeyboardInterrupt:
|
|
81
|
-
print("Shutdown requested...exiting")
|
|
82
|
-
|
|
83
|
-
except SystemExit as exit_code:
|
|
84
|
-
print("System Exit with code {}.".format(exit_code))
|
|
85
|
-
sys.exit(exit_code)
|
|
86
|
-
|
|
87
|
-
except Exception:
|
|
88
|
-
|
|
89
|
-
logger.exception("Cannot start the TC400 Control Server")
|
|
90
|
-
# The above line does exactly the same as the traceback, but on the logger
|
|
91
|
-
# import traceback
|
|
92
|
-
# traceback.print_exc(file=sys.stdout)
|
|
93
|
-
|
|
94
|
-
return 0
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
@cli.command()
|
|
98
|
-
def stop():
|
|
99
|
-
"""Send a 'quit_server' command to the TC400 Control Server."""
|
|
100
|
-
|
|
101
|
-
with Tc400Proxy() as proxy:
|
|
102
|
-
|
|
103
|
-
sp = proxy.get_service_proxy()
|
|
104
|
-
sp.quit_server()
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
if __name__ == "__main__":
|
|
108
|
-
|
|
109
|
-
sys.exit(cli())
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
from egse.device import DeviceInterface
|
|
2
|
-
from egse.decorators import dynamic_interface
|
|
3
|
-
from egse.command import ClientServerCommand
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
class Tc400Command(ClientServerCommand):
|
|
7
|
-
""" Subclass to handle the checksum. Note that only kwargs are supported """
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
@staticmethod
|
|
11
|
-
def get_checksum(data):
|
|
12
|
-
""" Checksum is the addition modulo 265 of ascii values in the dataword. """
|
|
13
|
-
|
|
14
|
-
charsum = sum(ord(c) for c in data)
|
|
15
|
-
return charsum % 256
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
def get_cmd_string(self, *args, **kwargs) -> str:
|
|
19
|
-
""" The TC400 commands include a checksum at the end. To avoid having to calculate this at
|
|
20
|
-
the client side, it is not included in the cmd string definition in the yaml file
|
|
21
|
-
"""
|
|
22
|
-
|
|
23
|
-
cmd_string = super().get_cmd_string(*args, **kwargs)
|
|
24
|
-
cmd_string += f"{Tc400Command.get_checksum(cmd_string):03d}"
|
|
25
|
-
cmd_string += "\r"
|
|
26
|
-
|
|
27
|
-
return cmd_string
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
class Tc400Interface(DeviceInterface):
|
|
31
|
-
|
|
32
|
-
@dynamic_interface
|
|
33
|
-
def get_idn(self):
|
|
34
|
-
return NotImplemented
|
|
35
|
-
|
|
36
|
-
@dynamic_interface
|
|
37
|
-
def get_last_error(self):
|
|
38
|
-
return NotImplemented
|
|
39
|
-
|
|
40
|
-
@dynamic_interface
|
|
41
|
-
def get_active_speed(self):
|
|
42
|
-
return NotImplemented
|
|
43
|
-
|
|
44
|
-
@dynamic_interface
|
|
45
|
-
def get_drive_power(self):
|
|
46
|
-
return NotImplemented
|
|
47
|
-
|
|
48
|
-
@dynamic_interface
|
|
49
|
-
def get_motor_temperature(self):
|
|
50
|
-
return NotImplemented
|
|
51
|
-
|
|
52
|
-
@dynamic_interface
|
|
53
|
-
def set_heating(self, enable):
|
|
54
|
-
return NotImplemented
|
|
55
|
-
|
|
56
|
-
@dynamic_interface
|
|
57
|
-
def set_standby(self, enable):
|
|
58
|
-
return NotImplemented
|
|
59
|
-
|
|
60
|
-
@dynamic_interface
|
|
61
|
-
def set_pumpingstation(self, enable):
|
|
62
|
-
return NotImplemented
|
|
63
|
-
|
|
64
|
-
@dynamic_interface
|
|
65
|
-
def set_motorpump(self, enable):
|
|
66
|
-
return NotImplemented
|
|
67
|
-
|
|
68
|
-
@dynamic_interface
|
|
69
|
-
def set_gasmode(self, mode):
|
|
70
|
-
return NotImplemented
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import logging
|
|
2
|
-
|
|
3
|
-
from egse.settings import Settings
|
|
4
|
-
from egse.simulator import Simulator
|
|
5
|
-
from egse.command import Command
|
|
6
|
-
from egse.vacuum.pfeiffer.tc400_interface import Tc400Interface
|
|
7
|
-
|
|
8
|
-
logger = logging.getLogger(__name__)
|
|
9
|
-
|
|
10
|
-
# Load the device protocol
|
|
11
|
-
DEVICE_PROTOCOL = Settings.load(filename='tc400.yaml')['Commands']
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
class Tc400Simulator(Tc400Interface, Simulator):
|
|
15
|
-
|
|
16
|
-
def __init__(self):
|
|
17
|
-
super().__init__()
|
|
18
|
-
self.connect()
|
|
19
|
-
|
|
20
|
-
def is_simulator(self):
|
|
21
|
-
return True
|
|
22
|
-
|
|
23
|
-
def get_idn(self):
|
|
24
|
-
return "TM 700 (simulator)"
|
egse/vacuum/pfeiffer/tpg261.py
DELETED
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
import logging
|
|
2
|
-
|
|
3
|
-
from prometheus_client import Gauge
|
|
4
|
-
|
|
5
|
-
from egse.control import ControlServer
|
|
6
|
-
from egse.protocol import CommandProtocol
|
|
7
|
-
from egse.proxy import Proxy
|
|
8
|
-
from egse.settings import Settings
|
|
9
|
-
from egse.zmq_ser import bind_address
|
|
10
|
-
from egse.system import format_datetime
|
|
11
|
-
# from egse.fdir.fdir_manager import FdirManagerProxy
|
|
12
|
-
from egse.vacuum.pfeiffer.tpg261_interface import Tpg261Command, Tpg261Interface
|
|
13
|
-
from egse.vacuum.pfeiffer.tpg261_controller import Tpg261Controller
|
|
14
|
-
from egse.vacuum.pfeiffer.tpg261_simulator import Tpg261Simulator
|
|
15
|
-
from egse.zmq_ser import connect_address
|
|
16
|
-
|
|
17
|
-
LOGGER = logging.getLogger(__name__)
|
|
18
|
-
|
|
19
|
-
DEVICE_SETTINGS = Settings.load(filename="tpg261.yaml")
|
|
20
|
-
CTRL_SETTINGS = Settings.load("Pfeiffer TPG261 Control Server")
|
|
21
|
-
|
|
22
|
-
class Tpg261Protocol(CommandProtocol):
|
|
23
|
-
|
|
24
|
-
gauge_pressure_1 = Gauge('GSRON_TPG261_P_1', '')
|
|
25
|
-
gauge_errors = Gauge('GSRON_TPG261_ERR', '')
|
|
26
|
-
|
|
27
|
-
def __init__(self, control_server: ControlServer):
|
|
28
|
-
|
|
29
|
-
super().__init__()
|
|
30
|
-
self.control_server = control_server
|
|
31
|
-
|
|
32
|
-
if Settings.simulation_mode():
|
|
33
|
-
self.dev = Tpg261Simulator()
|
|
34
|
-
else:
|
|
35
|
-
self.dev = Tpg261Controller()
|
|
36
|
-
|
|
37
|
-
self.load_commands(DEVICE_SETTINGS.Commands, Tpg261Command, Tpg261Interface)
|
|
38
|
-
|
|
39
|
-
self.build_device_method_lookup_table(self.dev)
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
# move to parent class?
|
|
43
|
-
def get_bind_address(self):
|
|
44
|
-
return bind_address(
|
|
45
|
-
self.control_server.get_communication_protocol(),
|
|
46
|
-
self.control_server.get_commanding_port(),
|
|
47
|
-
)
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
def get_status(self):
|
|
51
|
-
status_dict = super().get_status()
|
|
52
|
-
|
|
53
|
-
status_dict['P1'] = self.dev.pressure_1
|
|
54
|
-
|
|
55
|
-
return status_dict
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
def get_housekeeping(self) -> dict:
|
|
59
|
-
result = dict()
|
|
60
|
-
result["timestamp"] = format_datetime()
|
|
61
|
-
try:
|
|
62
|
-
self.dev.pressure_1 = self.dev.get_gauge_pressure()
|
|
63
|
-
result['GSRON_TPG261_P_1'] = self.dev.pressure_1
|
|
64
|
-
result['GSRON_TPG261_ERR'] = self.dev.get_errors()
|
|
65
|
-
except Exception as e:
|
|
66
|
-
LOGGER.warning(f'Failed to get HK: {e}')
|
|
67
|
-
return result
|
|
68
|
-
|
|
69
|
-
self.gauge_pressure_1.set(result['GSRON_TPG261_P_1'])
|
|
70
|
-
self.gauge_errors.set(result['GSRON_TPG261_ERR'])
|
|
71
|
-
|
|
72
|
-
return result
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
class Tpg261Proxy(Proxy, Tpg261Interface):
|
|
77
|
-
|
|
78
|
-
def __init__(self):
|
|
79
|
-
super().__init__(
|
|
80
|
-
connect_address(
|
|
81
|
-
CTRL_SETTINGS.PROTOCOL, CTRL_SETTINGS.HOSTNAME, CTRL_SETTINGS.COMMANDING_PORT))
|
egse/vacuum/pfeiffer/tpg261.yaml
DELETED
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
BaseClass:
|
|
2
|
-
egse.vacuum.pfeiffer.tpg261_interface.Tpg261Interface
|
|
3
|
-
|
|
4
|
-
ProxyClass:
|
|
5
|
-
egse.vacuum.pfeiffer.tpg261.Tpg261Proxy
|
|
6
|
-
|
|
7
|
-
ControlServer:
|
|
8
|
-
egse.vacuum.pfeiffer.tpg261_cs
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
Commands:
|
|
12
|
-
|
|
13
|
-
disconnect:
|
|
14
|
-
description: Disconnect from the device.
|
|
15
|
-
|
|
16
|
-
connect:
|
|
17
|
-
description: Connect to the device.
|
|
18
|
-
|
|
19
|
-
reconnect:
|
|
20
|
-
description: Reconnect to the device.
|
|
21
|
-
This command will force a disconnect and then try to re-connect to the controller.
|
|
22
|
-
is_connected:
|
|
23
|
-
description: Check if the Thorlabs Hardware Controller is connected.
|
|
24
|
-
|
|
25
|
-
is_simulator:
|
|
26
|
-
description: Ask if the control server is a simulator instead of the real controller class.
|
|
27
|
-
returns: bool | True if the far end is a simulator instead of the real hardware
|
|
28
|
-
|
|
29
|
-
get_idn:
|
|
30
|
-
description:
|
|
31
|
-
returns: str | firmware version
|
|
32
|
-
|
|
33
|
-
get_errors:
|
|
34
|
-
description: Get errors
|
|
35
|
-
returns: bytes | errors
|
|
36
|
-
|
|
37
|
-
reset:
|
|
38
|
-
description: Reset all errors
|
|
39
|
-
returns: bytes | list of errors
|
|
40
|
-
|
|
41
|
-
turn_off_gauge:
|
|
42
|
-
description: Turn off a gauge
|
|
43
|
-
cmd: '{gauge}'
|
|
44
|
-
returns: bytes | status
|
|
45
|
-
|
|
46
|
-
turn_on_gauge:
|
|
47
|
-
description: Turn on a gauge
|
|
48
|
-
cmd: '{gauge}'
|
|
49
|
-
returns: bytes | status
|
|
50
|
-
|
|
51
|
-
get_gauge_pressure:
|
|
52
|
-
description: Get the pressure on a specific gauge
|
|
53
|
-
cmd: ''
|
|
54
|
-
returns: float | pressure
|
|
55
|
-
|
|
56
|
-
request:
|
|
57
|
-
description: Request information
|
|
58
|
-
cmd: '{cmd}'
|
|
59
|
-
returns: bool | acknowledge or not
|
|
60
|
-
|
|
61
|
-
enquire:
|
|
62
|
-
description: Get the requested information
|
|
63
|
-
returns: bytes | requested information
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
@@ -1,150 +0,0 @@
|
|
|
1
|
-
# from egse.serialdevice import SerialDevice, SerialTimeoutException
|
|
2
|
-
from serial import Serial, SerialTimeoutException
|
|
3
|
-
from egse.command import Command
|
|
4
|
-
from egse.settings import Settings
|
|
5
|
-
from egse.vacuum.pfeiffer.tpg261_interface import Tpg261Interface
|
|
6
|
-
import rich
|
|
7
|
-
from threading import Lock
|
|
8
|
-
from time import sleep
|
|
9
|
-
|
|
10
|
-
# Load the device settings from the global common-egse config file
|
|
11
|
-
DEVICE_SETTINGS = Settings.load("Pfeiffer TPG261 Controller")
|
|
12
|
-
|
|
13
|
-
# Load the device protocol
|
|
14
|
-
DEVICE_PROTOCOL = Settings.load(filename='tpg261.yaml')['Commands']
|
|
15
|
-
|
|
16
|
-
class Tpg261Controller(Tpg261Interface):
|
|
17
|
-
|
|
18
|
-
def __init__(self, port=None, baudrate=None, address=None):
|
|
19
|
-
# Load device configuration from the common-egse global config file
|
|
20
|
-
self._port = DEVICE_SETTINGS.PORT if port is None else port
|
|
21
|
-
self._baudrate = DEVICE_SETTINGS.BAUDRATE if baudrate is None else baudrate
|
|
22
|
-
|
|
23
|
-
self._lock = Lock()
|
|
24
|
-
self._current_mode = None
|
|
25
|
-
|
|
26
|
-
self.pressure_1 = 0
|
|
27
|
-
|
|
28
|
-
# Initialize the serial device with the port and baudrate
|
|
29
|
-
self.dev = Serial(port=self._port, baudrate=self._baudrate, timeout=1)
|
|
30
|
-
|
|
31
|
-
def connect(self):
|
|
32
|
-
self.dev.open()
|
|
33
|
-
|
|
34
|
-
def disconnect(self):
|
|
35
|
-
self.dev.close()
|
|
36
|
-
|
|
37
|
-
def reconnect(self):
|
|
38
|
-
self.dev.close()
|
|
39
|
-
self.dev.open()
|
|
40
|
-
|
|
41
|
-
def is_connected(self):
|
|
42
|
-
return self.dev.is_open
|
|
43
|
-
|
|
44
|
-
def is_simulator(self):
|
|
45
|
-
return False
|
|
46
|
-
|
|
47
|
-
def get_idn(self):
|
|
48
|
-
if self._current_mode == 'PNR':
|
|
49
|
-
return_string = self.enquire()
|
|
50
|
-
return return_string
|
|
51
|
-
else:
|
|
52
|
-
if self.request(f"PNR\r\n"):
|
|
53
|
-
sleep(1)
|
|
54
|
-
return_string = self.enquire()
|
|
55
|
-
self._current_mode = 'PNR'
|
|
56
|
-
return return_string
|
|
57
|
-
else:
|
|
58
|
-
raise RuntimeError('Command not acknowledged')
|
|
59
|
-
sleep(1)
|
|
60
|
-
|
|
61
|
-
def get_errors(self):
|
|
62
|
-
if self._current_mode == 'ERR':
|
|
63
|
-
return_string = self.enquire()
|
|
64
|
-
return return_string
|
|
65
|
-
else:
|
|
66
|
-
if self.request(f"ERR\r\n"):
|
|
67
|
-
self._current_mode = 'ERR'
|
|
68
|
-
return_string = self.enquire()
|
|
69
|
-
return int(return_string)
|
|
70
|
-
|
|
71
|
-
else:
|
|
72
|
-
raise RuntimeError('Command not acknowledged')
|
|
73
|
-
|
|
74
|
-
def reset(self):
|
|
75
|
-
if self.request(f"RES\r\n"):
|
|
76
|
-
return_string = self.enquire()
|
|
77
|
-
return return_string
|
|
78
|
-
else:
|
|
79
|
-
raise RuntimeError('Command not acknowledged')
|
|
80
|
-
|
|
81
|
-
def turn_off_gauge(self, gauge: int):
|
|
82
|
-
assert 1 <= gauge <= 2
|
|
83
|
-
if self.request(f"SEN1,0\r\n" if gauge == 1 else f"SEN0,1\r\n"):
|
|
84
|
-
return_string = self.enquire()
|
|
85
|
-
return return_string
|
|
86
|
-
else:
|
|
87
|
-
raise RuntimeError('Command not acknowledged')
|
|
88
|
-
|
|
89
|
-
def turn_on_gauge(self, gauge: int):
|
|
90
|
-
assert 1 <= gauge <= 2
|
|
91
|
-
if self.request(f"SEN20\r\n" if gauge == 1 else f"SEN02\r\n"):
|
|
92
|
-
return_string = self.enquire()
|
|
93
|
-
return return_string
|
|
94
|
-
else:
|
|
95
|
-
raise RuntimeError('Command not acknowledged')
|
|
96
|
-
|
|
97
|
-
def get_gauge_pressure(self):
|
|
98
|
-
if self._current_mode == 'PR':
|
|
99
|
-
return_string = self.enquire()
|
|
100
|
-
else:
|
|
101
|
-
if self.request('PR1\r\n'):
|
|
102
|
-
self._current_mode = 'PR'
|
|
103
|
-
return_string = self.enquire()
|
|
104
|
-
else:
|
|
105
|
-
raise RuntimeError('Command not acknowledged')
|
|
106
|
-
return float(return_string[2:-2])
|
|
107
|
-
|
|
108
|
-
def send_command(self, command: str):
|
|
109
|
-
try:
|
|
110
|
-
with self._lock:
|
|
111
|
-
self.dev.write(command.encode('ascii', 'ignore'))
|
|
112
|
-
|
|
113
|
-
except SerialTimeoutException as e_timeout:
|
|
114
|
-
raise ConnectionError("Serial timeout error") from e_timeout
|
|
115
|
-
|
|
116
|
-
def request(self, command: str):
|
|
117
|
-
self.send_command(command)
|
|
118
|
-
|
|
119
|
-
try:
|
|
120
|
-
with self._lock:
|
|
121
|
-
return_string = self.dev.read_until(b'\r\n', size=None)
|
|
122
|
-
except SerialTimeoutException as e_timeout:
|
|
123
|
-
raise ConnectionError("Serial timeout during query") from e_timeout
|
|
124
|
-
|
|
125
|
-
if return_string[0:1] == b'\x06':
|
|
126
|
-
return True
|
|
127
|
-
elif return_string[0:1] == b'\x05':
|
|
128
|
-
return False
|
|
129
|
-
|
|
130
|
-
def enquire(self):
|
|
131
|
-
self.send_command('\x05')
|
|
132
|
-
|
|
133
|
-
try:
|
|
134
|
-
with self._lock:
|
|
135
|
-
return_string = self.dev.read_until(b'\r\n', size=None)
|
|
136
|
-
except SerialTimeoutException as e_timeout:
|
|
137
|
-
raise ConnectionError("Serial timeout during query") from e_timeout
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
return return_string
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
if __name__ == "__main__":
|
|
144
|
-
tpg = Tpg261Controller()
|
|
145
|
-
tpg.get_idn()
|
|
146
|
-
tpg.get_gauge_pressure()
|
|
147
|
-
tpg.get_gauge_pressure()
|
|
148
|
-
tpg.get_errors()
|
|
149
|
-
tpg.get_gauge_pressure()
|
|
150
|
-
|