cgse 2024.7.0__py3-none-any.whl → 2025.0.2__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- README.md +27 -0
- bump.py +85 -0
- cgse-2025.0.2.dist-info/METADATA +38 -0
- cgse-2025.0.2.dist-info/RECORD +5 -0
- {cgse-2024.7.0.dist-info → cgse-2025.0.2.dist-info}/WHEEL +1 -2
- cgse-2024.7.0.dist-info/COPYING +0 -674
- cgse-2024.7.0.dist-info/COPYING.LESSER +0 -165
- cgse-2024.7.0.dist-info/METADATA +0 -144
- cgse-2024.7.0.dist-info/RECORD +0 -660
- cgse-2024.7.0.dist-info/entry_points.txt +0 -75
- cgse-2024.7.0.dist-info/top_level.txt +0 -2
- egse/__init__.py +0 -12
- egse/__main__.py +0 -32
- egse/aeu/aeu.py +0 -5238
- egse/aeu/aeu_awg.yaml +0 -265
- egse/aeu/aeu_crio.yaml +0 -273
- egse/aeu/aeu_cs.py +0 -627
- egse/aeu/aeu_devif.py +0 -321
- egse/aeu/aeu_main_ui.py +0 -903
- egse/aeu/aeu_metrics.py +0 -131
- egse/aeu/aeu_protocol.py +0 -463
- egse/aeu/aeu_psu.yaml +0 -204
- egse/aeu/aeu_ui.py +0 -873
- egse/aeu/arbdata/FccdRead.arb +0 -2
- egse/aeu/arbdata/FccdRead_min_points.arb +0 -2
- egse/aeu/arbdata/HeaterSync_FccdRead.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead25.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead31_25.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead37_50.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead43_75.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead50.arb +0 -2
- egse/aeu/arbdata/Heater_FccdRead_min_points.arb +0 -2
- egse/aeu/arbdata/ccdRead25.arb +0 -2
- egse/aeu/arbdata/ccdRead25_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead31_25.arb +0 -2
- egse/aeu/arbdata/ccdRead31_25_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead37_50.arb +0 -2
- egse/aeu/arbdata/ccdRead37_50_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead43_75.arb +0 -2
- egse/aeu/arbdata/ccdRead43_75_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead50.arb +0 -2
- egse/aeu/arbdata/ccdRead50_150ms.arb +0 -2
- egse/alert/__init__.py +0 -1049
- egse/alert/alertman.yaml +0 -37
- egse/alert/alertman_cs.py +0 -233
- egse/alert/alertman_ui.py +0 -600
- egse/alert/gsm/beaglebone.py +0 -138
- egse/alert/gsm/beaglebone.yaml +0 -51
- egse/alert/gsm/beaglebone_cs.py +0 -108
- egse/alert/gsm/beaglebone_devif.py +0 -122
- egse/alert/gsm/beaglebone_protocol.py +0 -46
- egse/bits.py +0 -318
- egse/camera.py +0 -44
- egse/collimator/__init__.py +0 -0
- egse/collimator/fcul/__init__.py +0 -0
- egse/collimator/fcul/ogse.py +0 -1077
- egse/collimator/fcul/ogse.yaml +0 -14
- egse/collimator/fcul/ogse_cs.py +0 -154
- egse/collimator/fcul/ogse_devif.py +0 -358
- egse/collimator/fcul/ogse_protocol.py +0 -132
- egse/collimator/fcul/ogse_sim.py +0 -431
- egse/collimator/fcul/ogse_ui.py +0 -1108
- egse/command.py +0 -699
- egse/config.py +0 -410
- egse/confman/__init__.py +0 -1058
- egse/confman/confman.yaml +0 -70
- egse/confman/confman_cs.py +0 -240
- egse/confman/confman_ui.py +0 -381
- egse/confman/setup_ui.py +0 -565
- egse/control.py +0 -632
- egse/coordinates/__init__.py +0 -534
- egse/coordinates/avoidance.py +0 -100
- egse/coordinates/cslmodel.py +0 -127
- egse/coordinates/laser_tracker_to_dict.py +0 -122
- egse/coordinates/point.py +0 -707
- egse/coordinates/pyplot.py +0 -194
- egse/coordinates/referenceFrame.py +0 -1279
- egse/coordinates/refmodel.py +0 -737
- egse/coordinates/rotationMatrix.py +0 -85
- egse/coordinates/transform3d_addon.py +0 -419
- egse/csl/__init__.py +0 -50
- egse/csl/commanding.py +0 -78
- egse/csl/icons/hexapod-connected-selected.svg +0 -30
- egse/csl/icons/hexapod-connected.svg +0 -30
- egse/csl/icons/hexapod-homing-selected.svg +0 -68
- egse/csl/icons/hexapod-homing.svg +0 -68
- egse/csl/icons/hexapod-retract-selected.svg +0 -56
- egse/csl/icons/hexapod-retract.svg +0 -51
- egse/csl/icons/hexapod-zero-selected.svg +0 -56
- egse/csl/icons/hexapod-zero.svg +0 -56
- egse/csl/icons/logo-puna.svg +0 -92
- egse/csl/icons/stop.svg +0 -1
- egse/csl/initialisation.py +0 -102
- egse/csl/mech_pos_settings.yaml +0 -18
- egse/das.py +0 -1240
- egse/das.yaml +0 -7
- egse/data/conf/SETUP_CSL_00000_170620_150000.yaml +0 -5
- egse/data/conf/SETUP_CSL_00001_170620_151010.yaml +0 -69
- egse/data/conf/SETUP_CSL_00002_170620_151020.yaml +0 -69
- egse/data/conf/SETUP_CSL_00003_170620_151030.yaml +0 -69
- egse/data/conf/SETUP_CSL_00004_170620_151040.yaml +0 -69
- egse/data/conf/SETUP_CSL_00005_170620_151050.yaml +0 -69
- egse/data/conf/SETUP_CSL_00006_170620_151060.yaml +0 -69
- egse/data/conf/SETUP_CSL_00007_170620_151070.yaml +0 -69
- egse/data/conf/SETUP_CSL_00008_170620_151080.yaml +0 -75
- egse/data/conf/SETUP_CSL_00010_210308_083016.yaml +0 -138
- egse/data/conf/SETUP_INTA_00000_170620_150000.yaml +0 -4
- egse/data/conf/SETUP_SRON_00000_170620_150000.yaml +0 -4
- egse/decorators.py +0 -514
- egse/device.py +0 -269
- egse/dpu/__init__.py +0 -2698
- egse/dpu/ccd_ui.py +0 -514
- egse/dpu/dpu.py +0 -783
- egse/dpu/dpu.yaml +0 -153
- egse/dpu/dpu_cs.py +0 -272
- egse/dpu/dpu_ui.py +0 -671
- egse/dpu/fitsgen.py +0 -2096
- egse/dpu/fitsgen_ui.py +0 -399
- egse/dpu/hdf5_model.py +0 -332
- egse/dpu/hdf5_ui.py +0 -277
- egse/dpu/hdf5_viewer.py +0 -506
- egse/dpu/hk_ui.py +0 -468
- egse/dpu_commands.py +0 -81
- egse/dsi/__init__.py +0 -33
- egse/dsi/_libesl.py +0 -232
- egse/dsi/constants.py +0 -296
- egse/dsi/esl.py +0 -630
- egse/dsi/rmap.py +0 -444
- egse/dsi/rmapci.py +0 -39
- egse/dsi/spw.py +0 -335
- egse/dsi/spw_state.py +0 -29
- egse/dummy.py +0 -318
- egse/dyndummy.py +0 -179
- egse/env.py +0 -278
- egse/exceptions.py +0 -88
- egse/fdir/__init__.py +0 -26
- egse/fdir/fdir_manager.py +0 -85
- egse/fdir/fdir_manager.yaml +0 -37
- egse/fdir/fdir_manager_controller.py +0 -136
- egse/fdir/fdir_manager_cs.py +0 -164
- egse/fdir/fdir_manager_interface.py +0 -15
- egse/fdir/fdir_remote.py +0 -73
- egse/fdir/fdir_remote.yaml +0 -30
- egse/fdir/fdir_remote_controller.py +0 -30
- egse/fdir/fdir_remote_cs.py +0 -94
- egse/fdir/fdir_remote_interface.py +0 -9
- egse/fdir/fdir_remote_popup.py +0 -26
- egse/fee/__init__.py +0 -106
- egse/fee/f_fee_register.yaml +0 -43
- egse/fee/feesim.py +0 -914
- egse/fee/n_fee_hk.py +0 -768
- egse/fee/nfee.py +0 -188
- egse/filterwheel/__init__.py +0 -4
- egse/filterwheel/eksma/__init__.py +0 -49
- egse/filterwheel/eksma/fw8smc4.py +0 -657
- egse/filterwheel/eksma/fw8smc4.yaml +0 -121
- egse/filterwheel/eksma/fw8smc4_cs.py +0 -144
- egse/filterwheel/eksma/fw8smc4_devif.py +0 -473
- egse/filterwheel/eksma/fw8smc4_protocol.py +0 -82
- egse/filterwheel/eksma/fw8smc4_ui.py +0 -940
- egse/filterwheel/eksma/fw8smc5.py +0 -115
- egse/filterwheel/eksma/fw8smc5.yaml +0 -105
- egse/filterwheel/eksma/fw8smc5_controller.py +0 -307
- egse/filterwheel/eksma/fw8smc5_cs.py +0 -141
- egse/filterwheel/eksma/fw8smc5_interface.py +0 -65
- egse/filterwheel/eksma/fw8smc5_simulator.py +0 -29
- egse/filterwheel/eksma/fw8smc5_ui.py +0 -1065
- egse/filterwheel/eksma/testpythonfw.py +0 -215
- egse/fov/__init__.py +0 -65
- egse/fov/fov_hk.py +0 -710
- egse/fov/fov_ui.py +0 -859
- egse/fov/fov_ui_controller.py +0 -140
- egse/fov/fov_ui_model.py +0 -200
- egse/fov/fov_ui_view.py +0 -345
- egse/gimbal/__init__.py +0 -32
- egse/gimbal/symetrie/__init__.py +0 -26
- egse/gimbal/symetrie/alpha.py +0 -586
- egse/gimbal/symetrie/generic_gimbal_ui.py +0 -1521
- egse/gimbal/symetrie/gimbal.py +0 -877
- egse/gimbal/symetrie/gimbal.yaml +0 -168
- egse/gimbal/symetrie/gimbal_cs.py +0 -183
- egse/gimbal/symetrie/gimbal_protocol.py +0 -138
- egse/gimbal/symetrie/gimbal_ui.py +0 -361
- egse/gimbal/symetrie/pmac.py +0 -1006
- egse/gimbal/symetrie/pmac_regex.py +0 -83
- egse/graph.py +0 -132
- egse/gui/__init__.py +0 -47
- egse/gui/buttons.py +0 -378
- egse/gui/focalplane.py +0 -1285
- egse/gui/formatter.py +0 -10
- egse/gui/led.py +0 -162
- egse/gui/limitswitch.py +0 -143
- egse/gui/mechanisms.py +0 -587
- egse/gui/states.py +0 -148
- egse/gui/stripchart.py +0 -729
- egse/gui/styles.qss +0 -48
- egse/gui/switch.py +0 -112
- egse/h5.py +0 -274
- egse/help/__init__.py +0 -0
- egse/help/help_ui.py +0 -126
- egse/hexapod/__init__.py +0 -32
- egse/hexapod/symetrie/__init__.py +0 -137
- egse/hexapod/symetrie/alpha.py +0 -874
- egse/hexapod/symetrie/dynalpha.py +0 -1387
- egse/hexapod/symetrie/hexapod_ui.py +0 -1516
- egse/hexapod/symetrie/pmac.py +0 -1010
- egse/hexapod/symetrie/pmac_regex.py +0 -83
- egse/hexapod/symetrie/puna.py +0 -1167
- egse/hexapod/symetrie/puna.yaml +0 -193
- egse/hexapod/symetrie/puna_cs.py +0 -195
- egse/hexapod/symetrie/puna_protocol.py +0 -134
- egse/hexapod/symetrie/puna_ui.py +0 -433
- egse/hexapod/symetrie/punaplus.py +0 -107
- egse/hexapod/symetrie/zonda.py +0 -872
- egse/hexapod/symetrie/zonda.yaml +0 -337
- egse/hexapod/symetrie/zonda_cs.py +0 -172
- egse/hexapod/symetrie/zonda_devif.py +0 -414
- egse/hexapod/symetrie/zonda_protocol.py +0 -123
- egse/hexapod/symetrie/zonda_ui.py +0 -449
- egse/hk.py +0 -791
- egse/icons/aeu-cs-start.svg +0 -117
- egse/icons/aeu-cs-stop.svg +0 -118
- egse/icons/aeu-cs.svg +0 -107
- egse/icons/aeu_cs-started.svg +0 -112
- egse/icons/aeu_cs-stopped.svg +0 -112
- egse/icons/aeu_cs.svg +0 -55
- egse/icons/alert.svg +0 -1
- egse/icons/arrow-double-left.png +0 -0
- egse/icons/arrow-double-right.png +0 -0
- egse/icons/arrow-up.svg +0 -11
- egse/icons/backward.svg +0 -1
- egse/icons/busy.svg +0 -1
- egse/icons/cleaning.svg +0 -115
- egse/icons/color-scheme.svg +0 -1
- egse/icons/cs-connected-alert.svg +0 -91
- egse/icons/cs-connected-disabled.svg +0 -43
- egse/icons/cs-connected.svg +0 -89
- egse/icons/cs-not-connected.svg +0 -44
- egse/icons/double-left-arrow.svg +0 -1
- egse/icons/double-right-arrow.svg +0 -1
- egse/icons/erase-disabled.svg +0 -19
- egse/icons/erase.svg +0 -59
- egse/icons/fitsgen-start.svg +0 -47
- egse/icons/fitsgen-stop.svg +0 -48
- egse/icons/fitsgen.svg +0 -1
- egse/icons/forward.svg +0 -1
- egse/icons/fov-hk-start.svg +0 -33
- egse/icons/fov-hk-stop.svg +0 -37
- egse/icons/fov-hk.svg +0 -1
- egse/icons/front-desk.svg +0 -1
- egse/icons/home-actioned.svg +0 -15
- egse/icons/home-disabled.svg +0 -15
- egse/icons/home.svg +0 -13
- egse/icons/info.svg +0 -1
- egse/icons/invalid.png +0 -0
- egse/icons/led-green.svg +0 -20
- egse/icons/led-grey.svg +0 -20
- egse/icons/led-orange.svg +0 -20
- egse/icons/led-red.svg +0 -20
- egse/icons/led-square-green.svg +0 -134
- egse/icons/led-square-grey.svg +0 -134
- egse/icons/led-square-orange.svg +0 -134
- egse/icons/led-square-red.svg +0 -134
- egse/icons/limit-switch-all-green.svg +0 -115
- egse/icons/limit-switch-all-red.svg +0 -117
- egse/icons/limit-switch-el+.svg +0 -116
- egse/icons/limit-switch-el-.svg +0 -117
- egse/icons/location-marker.svg +0 -1
- egse/icons/logo-dpu.svg +0 -48
- egse/icons/logo-gimbal.svg +0 -112
- egse/icons/logo-huber.svg +0 -23
- egse/icons/logo-ogse.svg +0 -31
- egse/icons/logo-puna.svg +0 -92
- egse/icons/logo-tcs.svg +0 -29
- egse/icons/logo-zonda.svg +0 -66
- egse/icons/maximize.svg +0 -1
- egse/icons/meter.svg +0 -1
- egse/icons/more.svg +0 -45
- egse/icons/n-fee-hk-start.svg +0 -24
- egse/icons/n-fee-hk-stop.svg +0 -25
- egse/icons/n-fee-hk.svg +0 -83
- egse/icons/observing-off.svg +0 -46
- egse/icons/observing-on.svg +0 -46
- egse/icons/open-document-hdf5.png +0 -0
- egse/icons/open-document-hdf5.svg +0 -21
- egse/icons/ops-mode.svg +0 -1
- egse/icons/play-green.svg +0 -17
- egse/icons/plugged-disabled.svg +0 -27
- egse/icons/plugged.svg +0 -21
- egse/icons/pm_ui.svg +0 -1
- egse/icons/power-button-green.svg +0 -27
- egse/icons/power-button-red.svg +0 -27
- egse/icons/power-button.svg +0 -27
- egse/icons/radar.svg +0 -1
- egse/icons/radioactive.svg +0 -2
- egse/icons/reload.svg +0 -1
- egse/icons/remote-control-off.svg +0 -28
- egse/icons/remote-control-on.svg +0 -28
- egse/icons/repeat-blue.svg +0 -15
- egse/icons/repeat.svg +0 -1
- egse/icons/settings.svg +0 -1
- egse/icons/shrink.svg +0 -1
- egse/icons/shutter.svg +0 -1
- egse/icons/sign-off.svg +0 -1
- egse/icons/sign-on.svg +0 -1
- egse/icons/sim-mode.svg +0 -1
- egse/icons/small-buttons-go.svg +0 -20
- egse/icons/small-buttons-minus.svg +0 -51
- egse/icons/small-buttons-plus.svg +0 -51
- egse/icons/sponge.svg +0 -220
- egse/icons/start-button-disabled.svg +0 -84
- egse/icons/start-button.svg +0 -50
- egse/icons/stop-button-disabled.svg +0 -84
- egse/icons/stop-button.svg +0 -50
- egse/icons/stop-red.svg +0 -17
- egse/icons/stop.svg +0 -1
- egse/icons/switch-disabled-square.svg +0 -87
- egse/icons/switch-disabled.svg +0 -15
- egse/icons/switch-off-square.svg +0 -87
- egse/icons/switch-off.svg +0 -72
- egse/icons/switch-on-square.svg +0 -87
- egse/icons/switch-on.svg +0 -61
- egse/icons/temperature-control.svg +0 -44
- egse/icons/th_ui_logo.svg +0 -1
- egse/icons/unplugged.svg +0 -23
- egse/icons/unvalid.png +0 -0
- egse/icons/user-interface.svg +0 -1
- egse/icons/vacuum.svg +0 -1
- egse/icons/valid.png +0 -0
- egse/icons/zoom-to-pixel-dark.svg +0 -64
- egse/icons/zoom-to-pixel-white.svg +0 -36
- egse/images/big-rotation-stage.png +0 -0
- egse/images/connected-100.png +0 -0
- egse/images/cross.svg +0 -6
- egse/images/disconnected-100.png +0 -0
- egse/images/gui-icon.png +0 -0
- egse/images/home.svg +0 -6
- egse/images/info-icon.png +0 -0
- egse/images/led-black.svg +0 -89
- egse/images/led-green.svg +0 -85
- egse/images/led-orange.svg +0 -85
- egse/images/led-red.svg +0 -85
- egse/images/load-icon.png +0 -0
- egse/images/load-setup.png +0 -0
- egse/images/load.png +0 -0
- egse/images/pause.png +0 -0
- egse/images/play-button.svg +0 -8
- egse/images/play.png +0 -0
- egse/images/process-status.png +0 -0
- egse/images/restart.png +0 -0
- egse/images/search.png +0 -0
- egse/images/sma.png +0 -0
- egse/images/start.png +0 -0
- egse/images/stop-button.svg +0 -8
- egse/images/stop.png +0 -0
- egse/images/switch-off.svg +0 -48
- egse/images/switch-on.svg +0 -48
- egse/images/undo.png +0 -0
- egse/images/update-button.svg +0 -11
- egse/imageviewer/exposureselection.py +0 -475
- egse/imageviewer/imageviewer.py +0 -198
- egse/imageviewer/matchfocalplane.py +0 -179
- egse/imageviewer/subfieldposition.py +0 -133
- egse/lampcontrol/__init__.py +0 -4
- egse/lampcontrol/beaglebone/beaglebone.py +0 -178
- egse/lampcontrol/beaglebone/beaglebone.yaml +0 -62
- egse/lampcontrol/beaglebone/beaglebone_cs.py +0 -106
- egse/lampcontrol/beaglebone/beaglebone_devif.py +0 -150
- egse/lampcontrol/beaglebone/beaglebone_protocol.py +0 -73
- egse/lampcontrol/energetiq/__init__.py +0 -22
- egse/lampcontrol/energetiq/eq99.yaml +0 -98
- egse/lampcontrol/energetiq/lampEQ99.py +0 -283
- egse/lampcontrol/energetiq/lampEQ99_cs.py +0 -128
- egse/lampcontrol/energetiq/lampEQ99_devif.py +0 -158
- egse/lampcontrol/energetiq/lampEQ99_encode_decode_errors.py +0 -73
- egse/lampcontrol/energetiq/lampEQ99_protocol.py +0 -71
- egse/lampcontrol/energetiq/lampEQ99_ui.py +0 -465
- egse/lib/CentOS-7/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/CentOS-8/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/CentOS-8/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/Debian/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/Debian/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/Debian/libetherspacelink_v35_21.dylib +0 -0
- egse/lib/Linux/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/Linux/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/Ubuntu-20/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/Ubuntu-20/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/gssw/python3-gssw_2.2.3+31f63c9f-1_all.deb +0 -0
- egse/lib/ximc/__pycache__/pyximc.cpython-38 2.pyc +0 -0
- egse/lib/ximc/__pycache__/pyximc.cpython-38.pyc +0 -0
- egse/lib/ximc/libximc.framework/Frameworks/libbindy.dylib +0 -0
- egse/lib/ximc/libximc.framework/Frameworks/libxiwrapper.dylib +0 -0
- egse/lib/ximc/libximc.framework/Headers/ximc.h +0 -5510
- egse/lib/ximc/libximc.framework/Resources/Info.plist +0 -42
- egse/lib/ximc/libximc.framework/Resources/keyfile.sqlite +0 -0
- egse/lib/ximc/libximc.framework/libbindy.so +0 -0
- egse/lib/ximc/libximc.framework/libximc +0 -0
- egse/lib/ximc/libximc.framework/libximc.so +0 -0
- egse/lib/ximc/libximc.framework/libximc.so.7.0.0 +0 -0
- egse/lib/ximc/libximc.framework/libxiwrapper.so +0 -0
- egse/lib/ximc/pyximc.py +0 -922
- egse/listener.py +0 -179
- egse/logger/__init__.py +0 -243
- egse/logger/log_cs.py +0 -321
- egse/metrics.py +0 -102
- egse/mixin.py +0 -464
- egse/monitoring.py +0 -95
- egse/ni/alarms/__init__.py +0 -26
- egse/ni/alarms/cdaq9375.py +0 -300
- egse/ni/alarms/cdaq9375.yaml +0 -89
- egse/ni/alarms/cdaq9375_cs.py +0 -130
- egse/ni/alarms/cdaq9375_devif.py +0 -183
- egse/ni/alarms/cdaq9375_protocol.py +0 -48
- egse/obs_inspection.py +0 -165
- egse/observer.py +0 -41
- egse/obsid.py +0 -163
- egse/powermeter/__init__.py +0 -0
- egse/powermeter/ni/__init__.py +0 -38
- egse/powermeter/ni/cdaq9184.py +0 -224
- egse/powermeter/ni/cdaq9184.yaml +0 -73
- egse/powermeter/ni/cdaq9184_cs.py +0 -130
- egse/powermeter/ni/cdaq9184_devif.py +0 -201
- egse/powermeter/ni/cdaq9184_protocol.py +0 -48
- egse/powermeter/ni/cdaq9184_ui.py +0 -544
- egse/powermeter/thorlabs/__init__.py +0 -25
- egse/powermeter/thorlabs/pm100a.py +0 -380
- egse/powermeter/thorlabs/pm100a.yaml +0 -132
- egse/powermeter/thorlabs/pm100a_cs.py +0 -136
- egse/powermeter/thorlabs/pm100a_devif.py +0 -127
- egse/powermeter/thorlabs/pm100a_protocol.py +0 -80
- egse/powermeter/thorlabs/pm100a_ui.py +0 -725
- egse/process.py +0 -451
- egse/procman/__init__.py +0 -834
- egse/procman/cannot_start_process_popup.py +0 -43
- egse/procman/procman.yaml +0 -49
- egse/procman/procman_cs.py +0 -201
- egse/procman/procman_ui.py +0 -2081
- egse/protocol.py +0 -605
- egse/proxy.py +0 -531
- egse/randomwalk.py +0 -140
- egse/reg.py +0 -585
- egse/reload.py +0 -122
- egse/reprocess.py +0 -693
- egse/resource.py +0 -333
- egse/rmap.py +0 -406
- egse/rst.py +0 -135
- egse/search.py +0 -182
- egse/serialdevice.py +0 -190
- egse/services.py +0 -247
- egse/services.yaml +0 -68
- egse/settings.py +0 -379
- egse/settings.yaml +0 -980
- egse/setup.py +0 -1181
- egse/shutter/__init__.py +0 -0
- egse/shutter/thorlabs/__init__.py +0 -19
- egse/shutter/thorlabs/ksc101.py +0 -205
- egse/shutter/thorlabs/ksc101.yaml +0 -105
- egse/shutter/thorlabs/ksc101_cs.py +0 -136
- egse/shutter/thorlabs/ksc101_devif.py +0 -201
- egse/shutter/thorlabs/ksc101_protocol.py +0 -71
- egse/shutter/thorlabs/ksc101_ui.py +0 -548
- egse/shutter/thorlabs/sc10.py +0 -82
- egse/shutter/thorlabs/sc10.yaml +0 -52
- egse/shutter/thorlabs/sc10_controller.py +0 -81
- egse/shutter/thorlabs/sc10_cs.py +0 -108
- egse/shutter/thorlabs/sc10_interface.py +0 -25
- egse/shutter/thorlabs/sc10_simulator.py +0 -30
- egse/simulator.py +0 -41
- egse/slack.py +0 -61
- egse/socketdevice.py +0 -218
- egse/sockets.py +0 -218
- egse/spw.py +0 -1401
- egse/stages/__init__.py +0 -12
- egse/stages/aerotech/ensemble.py +0 -245
- egse/stages/aerotech/ensemble.yaml +0 -205
- egse/stages/aerotech/ensemble_controller.py +0 -275
- egse/stages/aerotech/ensemble_cs.py +0 -110
- egse/stages/aerotech/ensemble_interface.py +0 -132
- egse/stages/aerotech/ensemble_parameters.py +0 -433
- egse/stages/aerotech/ensemble_simulator.py +0 -27
- egse/stages/aerotech/mgse_sim.py +0 -188
- egse/stages/arun/smd3.py +0 -110
- egse/stages/arun/smd3.yaml +0 -68
- egse/stages/arun/smd3_controller.py +0 -470
- egse/stages/arun/smd3_cs.py +0 -112
- egse/stages/arun/smd3_interface.py +0 -53
- egse/stages/arun/smd3_simulator.py +0 -27
- egse/stages/arun/smd3_stop.py +0 -16
- egse/stages/huber/__init__.py +0 -49
- egse/stages/huber/smc9300.py +0 -920
- egse/stages/huber/smc9300.yaml +0 -63
- egse/stages/huber/smc9300_cs.py +0 -178
- egse/stages/huber/smc9300_devif.py +0 -345
- egse/stages/huber/smc9300_protocol.py +0 -113
- egse/stages/huber/smc9300_sim.py +0 -547
- egse/stages/huber/smc9300_ui.py +0 -973
- egse/state.py +0 -173
- egse/statemachine.py +0 -274
- egse/storage/__init__.py +0 -1067
- egse/storage/persistence.py +0 -2295
- egse/storage/storage.yaml +0 -79
- egse/storage/storage_cs.py +0 -231
- egse/styles/dark.qss +0 -343
- egse/styles/default.qss +0 -48
- egse/synoptics/__init__.py +0 -417
- egse/synoptics/syn.yaml +0 -9
- egse/synoptics/syn_cs.py +0 -195
- egse/system.py +0 -1611
- egse/tcs/__init__.py +0 -14
- egse/tcs/tcs.py +0 -879
- egse/tcs/tcs.yaml +0 -14
- egse/tcs/tcs_cs.py +0 -202
- egse/tcs/tcs_devif.py +0 -292
- egse/tcs/tcs_protocol.py +0 -180
- egse/tcs/tcs_sim.py +0 -177
- egse/tcs/tcs_ui.py +0 -543
- egse/tdms.py +0 -171
- egse/tempcontrol/__init__.py +0 -23
- egse/tempcontrol/agilent/agilent34970.py +0 -109
- egse/tempcontrol/agilent/agilent34970.yaml +0 -44
- egse/tempcontrol/agilent/agilent34970_cs.py +0 -114
- egse/tempcontrol/agilent/agilent34970_devif.py +0 -182
- egse/tempcontrol/agilent/agilent34970_protocol.py +0 -96
- egse/tempcontrol/agilent/agilent34972.py +0 -111
- egse/tempcontrol/agilent/agilent34972.yaml +0 -44
- egse/tempcontrol/agilent/agilent34972_cs.py +0 -115
- egse/tempcontrol/agilent/agilent34972_devif.py +0 -189
- egse/tempcontrol/agilent/agilent34972_protocol.py +0 -98
- egse/tempcontrol/beaglebone/beaglebone.py +0 -341
- egse/tempcontrol/beaglebone/beaglebone.yaml +0 -110
- egse/tempcontrol/beaglebone/beaglebone_cs.py +0 -117
- egse/tempcontrol/beaglebone/beaglebone_protocol.py +0 -134
- egse/tempcontrol/beaglebone/beaglebone_ui.py +0 -674
- egse/tempcontrol/digalox/digalox.py +0 -115
- egse/tempcontrol/digalox/digalox.yaml +0 -36
- egse/tempcontrol/digalox/digalox_cs.py +0 -108
- egse/tempcontrol/digalox/digalox_protocol.py +0 -56
- egse/tempcontrol/keithley/__init__.py +0 -33
- egse/tempcontrol/keithley/daq6510.py +0 -662
- egse/tempcontrol/keithley/daq6510.yaml +0 -105
- egse/tempcontrol/keithley/daq6510_cs.py +0 -163
- egse/tempcontrol/keithley/daq6510_devif.py +0 -343
- egse/tempcontrol/keithley/daq6510_protocol.py +0 -79
- egse/tempcontrol/keithley/daq6510_sim.py +0 -186
- egse/tempcontrol/lakeshore/__init__.py +0 -33
- egse/tempcontrol/lakeshore/lsci.py +0 -361
- egse/tempcontrol/lakeshore/lsci.yaml +0 -162
- egse/tempcontrol/lakeshore/lsci_cs.py +0 -174
- egse/tempcontrol/lakeshore/lsci_devif.py +0 -292
- egse/tempcontrol/lakeshore/lsci_protocol.py +0 -76
- egse/tempcontrol/lakeshore/lsci_ui.py +0 -387
- egse/tempcontrol/ni/__init__.py +0 -0
- egse/tempcontrol/spid/spid.py +0 -109
- egse/tempcontrol/spid/spid.yaml +0 -81
- egse/tempcontrol/spid/spid_controller.py +0 -279
- egse/tempcontrol/spid/spid_cs.py +0 -136
- egse/tempcontrol/spid/spid_protocol.py +0 -107
- egse/tempcontrol/spid/spid_ui.py +0 -723
- egse/tempcontrol/srs/__init__.py +0 -22
- egse/tempcontrol/srs/ptc10.py +0 -867
- egse/tempcontrol/srs/ptc10.yaml +0 -227
- egse/tempcontrol/srs/ptc10_cs.py +0 -128
- egse/tempcontrol/srs/ptc10_devif.py +0 -116
- egse/tempcontrol/srs/ptc10_protocol.py +0 -39
- egse/tempcontrol/srs/ptc10_ui.py +0 -906
- egse/ups/apc/apc.py +0 -236
- egse/ups/apc/apc.yaml +0 -45
- egse/ups/apc/apc_cs.py +0 -101
- egse/ups/apc/apc_protocol.py +0 -125
- egse/user.yaml +0 -7
- egse/vacuum/beaglebone/beaglebone.py +0 -149
- egse/vacuum/beaglebone/beaglebone.yaml +0 -44
- egse/vacuum/beaglebone/beaglebone_cs.py +0 -108
- egse/vacuum/beaglebone/beaglebone_devif.py +0 -159
- egse/vacuum/beaglebone/beaglebone_protocol.py +0 -192
- egse/vacuum/beaglebone/beaglebone_ui.py +0 -638
- egse/vacuum/instrutech/igm402.py +0 -91
- egse/vacuum/instrutech/igm402.yaml +0 -90
- egse/vacuum/instrutech/igm402_controller.py +0 -124
- egse/vacuum/instrutech/igm402_cs.py +0 -108
- egse/vacuum/instrutech/igm402_interface.py +0 -49
- egse/vacuum/instrutech/igm402_simulator.py +0 -36
- egse/vacuum/keller/kellerBus.py +0 -256
- egse/vacuum/keller/leo3.py +0 -100
- egse/vacuum/keller/leo3.yaml +0 -38
- egse/vacuum/keller/leo3_controller.py +0 -81
- egse/vacuum/keller/leo3_cs.py +0 -101
- egse/vacuum/keller/leo3_interface.py +0 -33
- egse/vacuum/mks/evision.py +0 -86
- egse/vacuum/mks/evision.yaml +0 -75
- egse/vacuum/mks/evision_cs.py +0 -101
- egse/vacuum/mks/evision_devif.py +0 -313
- egse/vacuum/mks/evision_interface.py +0 -60
- egse/vacuum/mks/evision_simulator.py +0 -24
- egse/vacuum/mks/evision_ui.py +0 -701
- egse/vacuum/pfeiffer/acp40.py +0 -87
- egse/vacuum/pfeiffer/acp40.yaml +0 -60
- egse/vacuum/pfeiffer/acp40_controller.py +0 -117
- egse/vacuum/pfeiffer/acp40_cs.py +0 -109
- egse/vacuum/pfeiffer/acp40_interface.py +0 -40
- egse/vacuum/pfeiffer/acp40_simulator.py +0 -37
- egse/vacuum/pfeiffer/tc400.py +0 -87
- egse/vacuum/pfeiffer/tc400.yaml +0 -83
- egse/vacuum/pfeiffer/tc400_controller.py +0 -136
- egse/vacuum/pfeiffer/tc400_cs.py +0 -109
- egse/vacuum/pfeiffer/tc400_interface.py +0 -70
- egse/vacuum/pfeiffer/tc400_simulator.py +0 -35
- egse/vacuum/pfeiffer/tpg261.py +0 -80
- egse/vacuum/pfeiffer/tpg261.yaml +0 -66
- egse/vacuum/pfeiffer/tpg261_controller.py +0 -150
- egse/vacuum/pfeiffer/tpg261_cs.py +0 -109
- egse/vacuum/pfeiffer/tpg261_interface.py +0 -59
- egse/vacuum/pfeiffer/tpg261_simulator.py +0 -23
- egse/version.py +0 -174
- egse/visitedpositions.py +0 -398
- egse/windowing.py +0 -213
- egse/zmq/__init__.py +0 -28
- egse/zmq/spw.py +0 -160
- egse/zmq_ser.py +0 -41
- scripts/alerts/cold.yaml +0 -278
- scripts/alerts/example_alerts.yaml +0 -54
- scripts/alerts/transition.yaml +0 -14
- scripts/alerts/warm.yaml +0 -49
- scripts/analyse_n_fee_hk_data.py +0 -52
- scripts/check_hdf5_files.py +0 -192
- scripts/check_register_sync.py +0 -47
- scripts/check_tcs_calib_coef.py +0 -90
- scripts/correct_ccd_cold_temperature_cal.py +0 -157
- scripts/create_hdf5_report.py +0 -293
- scripts/csl_model.py +0 -420
- scripts/csl_restore_setup.py +0 -229
- scripts/export-grafana-dashboards.py +0 -49
- scripts/fdir/cs_recovery/fdir_cs_recovery.py +0 -54
- scripts/fdir/fdir_table.yaml +0 -70
- scripts/fdir/fdir_test_recovery.py +0 -10
- scripts/fdir/hw_recovery/fdir_agilent_hw_recovery.py +0 -73
- scripts/fdir/limit_recovery/fdir_agilent_limit.py +0 -61
- scripts/fdir/limit_recovery/fdir_bb_heater_limit.py +0 -59
- scripts/fdir/limit_recovery/fdir_ensemble_limit.py +0 -33
- scripts/fdir/limit_recovery/fdir_pressure_limit_recovery.py +0 -71
- scripts/fix_csv.py +0 -80
- scripts/ias/correct_ccd_temp_cal_elfique.py +0 -43
- scripts/ias/correct_ccd_temp_cal_floreffe.py +0 -43
- scripts/ias/correct_trp_swap_achel.py +0 -199
- scripts/inta/correct_ccd_temp_cal_duvel.py +0 -43
- scripts/inta/correct_ccd_temp_cal_gueuze.py +0 -43
- scripts/n_fee_supply_voltage_calculation.py +0 -92
- scripts/playground.py +0 -30
- scripts/print_hdf5_hk_data.py +0 -68
- scripts/print_register_map.py +0 -43
- scripts/remove_lines_between_matches.py +0 -188
- scripts/sron/commanding/control_heaters.py +0 -44
- scripts/sron/commanding/pumpdown.py +0 -46
- scripts/sron/commanding/set_pid_setpoint.py +0 -19
- scripts/sron/commanding/shutdown_bbb_heaters.py +0 -10
- scripts/sron/commanding/shutdown_pumps.py +0 -33
- scripts/sron/correct_mgse_coordinates_brigand_chimay.py +0 -272
- scripts/sron/correct_trp_swap_brigand.py +0 -204
- scripts/sron/gimbal_conversions.py +0 -75
- scripts/sron/tm_gen/tm_gen_agilent.py +0 -37
- scripts/sron/tm_gen/tm_gen_heaters.py +0 -4
- scripts/sron/tm_gen/tm_gen_spid.py +0 -13
- scripts/update_operational_cgse.py +0 -268
- scripts/update_operational_cgse_old.py +0 -273
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
"""
|
|
2
|
-
The RotationMatrix provides a number of convenience methods to define and apply rotations.
|
|
3
|
-
|
|
4
|
-
@author: pierre
|
|
5
|
-
"""
|
|
6
|
-
|
|
7
|
-
import transforms3d as t3
|
|
8
|
-
import numpy as np
|
|
9
|
-
|
|
10
|
-
class RotationMatrix():
|
|
11
|
-
"""
|
|
12
|
-
RotationMatrix(angle1, angle2, angle3, rot_config="sxyz", active=True)
|
|
13
|
-
|
|
14
|
-
The ``angle`` parameters provide the amplitude of rotation around an axis
|
|
15
|
-
according to the order of rotations corresponding to the ``rot_config`` parameter.
|
|
16
|
-
|
|
17
|
-
The ``rot_config`` parameter is a string that consists of four letter
|
|
18
|
-
indicating the rotation system and the order of applying the rotations. The default
|
|
19
|
-
for this parameter is ``"rxyz"`` where the first character can be 'r' or 's' and
|
|
20
|
-
the next three characters define the axes of rotation in the order specified, here 'xyz'.
|
|
21
|
-
|
|
22
|
-
* 'r' stands for rotating system (intrinsic rotations)
|
|
23
|
-
* 's' stands for static system (extrinsic rotations)
|
|
24
|
-
* "rxyz" imposes angle1 describes the rotation around X
|
|
25
|
-
* even if two angles = 0, the match between angle orders and rot_config is still critical
|
|
26
|
-
|
|
27
|
-
:param str rot_config: otation system to be used, 4 characters. Default = "sxyz"
|
|
28
|
-
|
|
29
|
-
:param float angle1: amplitude of rotations around the first axis
|
|
30
|
-
|
|
31
|
-
:param float angle2: amplitude of rotations around the second axis
|
|
32
|
-
|
|
33
|
-
:param float angle3: amplitude of rotations around the third axis
|
|
34
|
-
|
|
35
|
-
:param bool active: when True the object rotates **in** a fixed coord system,
|
|
36
|
-
when False the coord system rotates **around** a fixed object
|
|
37
|
-
The default for the transform3d.euleur package is to represent movements
|
|
38
|
-
of the coordinate system itself --> **around** the object <==> passive
|
|
39
|
-
"""
|
|
40
|
-
_ROT_CONFIG_DEFAULT = 'sxyz'
|
|
41
|
-
|
|
42
|
-
def __init__(self,angle1,angle2,angle3,rot_config=_ROT_CONFIG_DEFAULT,active=True):
|
|
43
|
-
R = t3.euler.euler2mat(angle1,angle2,angle3,rot_config)
|
|
44
|
-
if active:
|
|
45
|
-
self.R = R
|
|
46
|
-
else:
|
|
47
|
-
self.R = R.T
|
|
48
|
-
rot_config_array = np.array(list(rot_config[1:]))
|
|
49
|
-
angles_array = np.array([angle1,angle2,angle3])
|
|
50
|
-
self.angles_hash = {}
|
|
51
|
-
for axis in ['x','y','z']:
|
|
52
|
-
self.angles_hash[axis] = angles_array[np.where(rot_config_array==axis)[0][0]]
|
|
53
|
-
self.active=active
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
def getRotationMatrix(self):
|
|
57
|
-
'''Return the Rotation Matrix'''
|
|
58
|
-
return self.R
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
def trace(self):
|
|
62
|
-
return np.sum([self.R[i,i] for i in range(3)])
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
def getAngle(self, axis):
|
|
66
|
-
"""
|
|
67
|
-
Returns the angle
|
|
68
|
-
|
|
69
|
-
:param str axis: 'x', 'y', 'z'
|
|
70
|
-
|
|
71
|
-
:return: the angle
|
|
72
|
-
"""
|
|
73
|
-
return self.angles_hash[axis]
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
def apply(self, vectors):
|
|
77
|
-
"""
|
|
78
|
-
if self = active, the output = the coords of these vectors after rotation
|
|
79
|
-
|
|
80
|
-
if self = passive, the ouput = the coords of these vectors after transformation to the rotated coordinate system
|
|
81
|
-
|
|
82
|
-
:param vectors: an array of shape [3,N] gathering a set of vectors along its columns
|
|
83
|
-
"""
|
|
84
|
-
return np.dot(self.R, vectors)
|
|
85
|
-
|
|
@@ -1,419 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
# -*- coding: utf-8 -*-
|
|
3
|
-
"""
|
|
4
|
-
Created on Mon Jun 25 16:25:33 2018
|
|
5
|
-
|
|
6
|
-
@author: pierre
|
|
7
|
-
"""
|
|
8
|
-
import numpy
|
|
9
|
-
import numpy as np
|
|
10
|
-
import math
|
|
11
|
-
import transforms3d as t3
|
|
12
|
-
|
|
13
|
-
from egse.coordinates.rotationMatrix import RotationMatrix
|
|
14
|
-
|
|
15
|
-
def affine_isEuclidian(matrix):
|
|
16
|
-
"""
|
|
17
|
-
Tests if a matrix is a pure solid-body euclidian rotation + translation (no shear or scaling)
|
|
18
|
-
|
|
19
|
-
We only need to check that
|
|
20
|
-
. the rotation part is orthogonal : R @ R.T = I
|
|
21
|
-
. the det(R) = 1 (=> this is not a reflexion)
|
|
22
|
-
"""
|
|
23
|
-
rotation = matrix[:3,:3]
|
|
24
|
-
return np.allclose((rotation @ rotation.T),np.identity(3)) & np.allclose(np.linalg.det(matrix),1)
|
|
25
|
-
|
|
26
|
-
def affine_inverse(matrix):
|
|
27
|
-
"""
|
|
28
|
-
affine_inverse(matrix)
|
|
29
|
-
|
|
30
|
-
WARNING:
|
|
31
|
-
This is NOT a generic inversion of an affine transformation matrix
|
|
32
|
-
|
|
33
|
-
This returns the affine transformation inverting that produced by the input matrix,
|
|
34
|
-
|
|
35
|
-
ASSSUMING that only rotation and translation were involved
|
|
36
|
-
in the affine transformation, no zoom, no shear!
|
|
37
|
-
|
|
38
|
-
That preserves the fact that the orthogonal property of the part of the input matrix
|
|
39
|
-
corresponding to rotation => the inverse is simply the transpose.
|
|
40
|
-
|
|
41
|
-
Pierre Royer
|
|
42
|
-
"""
|
|
43
|
-
#import numpy as np
|
|
44
|
-
|
|
45
|
-
# Extract Rotation matrix and translation vector from input affine transformation
|
|
46
|
-
R = matrix[:3,:3]
|
|
47
|
-
t = matrix[:3,3]
|
|
48
|
-
#
|
|
49
|
-
# Invert the rotation and the translation
|
|
50
|
-
Rinv = R.T
|
|
51
|
-
tinv = -t
|
|
52
|
-
#
|
|
53
|
-
# The inverse affine is composed from R^-1 for the rotation and -(R^-1 . t) for the translation
|
|
54
|
-
result = np.identity(4)
|
|
55
|
-
result[:3,:3] = Rinv
|
|
56
|
-
result[:3,3] = np.dot(Rinv,tinv)
|
|
57
|
-
|
|
58
|
-
if affine_isEuclidian(result):
|
|
59
|
-
return result
|
|
60
|
-
else:
|
|
61
|
-
print("WARNING: This is not a rigid-body transformation matrix")
|
|
62
|
-
#print(f"R.T-based (.6f) = \n {np.round(result,6)}")
|
|
63
|
-
#print(f"np.inverse (.6f) = \n {np.round(np.linalg.inv(matrix),6)}")
|
|
64
|
-
return np.linalg.inv(matrix)
|
|
65
|
-
|
|
66
|
-
def affine_matrix_from_points(v0, v1, shear=False, scale=False, usesvd=True):
|
|
67
|
-
"""affine_matrix_from_points(v0, v1, shear=False, scale=False, usesvd=True)
|
|
68
|
-
Return affine transform matrix to register two point sets.
|
|
69
|
-
|
|
70
|
-
v0 and v1 are shape (ndims, \*) arrays of at least ndims non-homogeneous
|
|
71
|
-
coordinates, where ndims is the dimensionality of the coordinate space.
|
|
72
|
-
|
|
73
|
-
If shear is False, a similarity transformation matrix is returned.
|
|
74
|
-
If also scale is False, a rigid/Euclidean transformation matrix
|
|
75
|
-
is returned.
|
|
76
|
-
|
|
77
|
-
By default the algorithm by Hartley and Zissermann [15] is used.
|
|
78
|
-
If usesvd is True, similarity and Euclidean transformation matrices
|
|
79
|
-
are calculated by minimizing the weighted sum of squared deviations
|
|
80
|
-
(RMSD) according to the algorithm by Kabsch [8].
|
|
81
|
-
Otherwise, and if ndims is 3, the quaternion based algorithm by Horn [9]
|
|
82
|
-
is used, which is slower when using this Python implementation.
|
|
83
|
-
|
|
84
|
-
The returned matrix performs rotation, translation and uniform scaling
|
|
85
|
-
(if specified).
|
|
86
|
-
|
|
87
|
-
>>> v0 = [[0, 1031, 1031, 0], [0, 0, 1600, 1600]]
|
|
88
|
-
>>> v1 = [[675, 826, 826, 677], [55, 52, 281, 277]]
|
|
89
|
-
>>> affine_matrix_from_points(v0, v1)
|
|
90
|
-
array([[ 0.14549, 0.00062, 675.50008],
|
|
91
|
-
[ 0.00048, 0.14094, 53.24971],
|
|
92
|
-
[ 0. , 0. , 1. ]])
|
|
93
|
-
>>> T = translation_matrix(numpy.random.random(3)-0.5)
|
|
94
|
-
>>> R = random_rotation_matrix(numpy.random.random(3))
|
|
95
|
-
>>> S = scale_matrix(random.random())
|
|
96
|
-
>>> M = concatenate_matrices(T, R, S)
|
|
97
|
-
>>> v0 = (numpy.random.rand(4, 100) - 0.5) * 20
|
|
98
|
-
>>> v0[3] = 1
|
|
99
|
-
>>> v1 = numpy.dot(M, v0)
|
|
100
|
-
>>> v0[:3] += numpy.random.normal(0, 1e-8, 300).reshape(3, -1)
|
|
101
|
-
>>> M = affine_matrix_from_points(v0[:3], v1[:3])
|
|
102
|
-
>>> numpy.allclose(v1, numpy.dot(M, v0))
|
|
103
|
-
True
|
|
104
|
-
|
|
105
|
-
More examples in superimposition_matrix()
|
|
106
|
-
|
|
107
|
-
Author: this function was extracted from the original transformations.py
|
|
108
|
-
written by Christoph Golke:
|
|
109
|
-
https://www.lfd.uci.edu/~gohlke/code/transformations.py.html
|
|
110
|
-
|
|
111
|
-
usesvd controls the use of a method based on Singular Value Decomposition (SVD)
|
|
112
|
-
--> when True, it is equivalent to rigid_transform_3D (see below)
|
|
113
|
-
|
|
114
|
-
"""
|
|
115
|
-
import numpy
|
|
116
|
-
v0 = numpy.array(v0, dtype=numpy.float64, copy=True)
|
|
117
|
-
v1 = numpy.array(v1, dtype=numpy.float64, copy=True)
|
|
118
|
-
|
|
119
|
-
ndims = v0.shape[0]
|
|
120
|
-
if ndims < 2 or v0.shape[1] < ndims or v0.shape != v1.shape:
|
|
121
|
-
print(f"ndims {ndims} v0/1.shape {v0.shape} {v1.shape} v0/1 class {v0.__class__} {v1.__class__}")
|
|
122
|
-
raise ValueError('input arrays are of wrong shape or type')
|
|
123
|
-
|
|
124
|
-
# move centroids to origin
|
|
125
|
-
t0 = -numpy.mean(v0, axis=1)
|
|
126
|
-
M0 = numpy.identity(ndims+1)
|
|
127
|
-
M0[:ndims, ndims] = t0
|
|
128
|
-
v0 += t0.reshape(ndims, 1)
|
|
129
|
-
t1 = -numpy.mean(v1, axis=1)
|
|
130
|
-
M1 = numpy.identity(ndims+1)
|
|
131
|
-
M1[:ndims, ndims] = t1
|
|
132
|
-
v1 += t1.reshape(ndims, 1)
|
|
133
|
-
|
|
134
|
-
if shear:
|
|
135
|
-
# Affine transformation
|
|
136
|
-
A = numpy.concatenate((v0, v1), axis=0)
|
|
137
|
-
u, s, vh = numpy.linalg.svd(A.T)
|
|
138
|
-
vh = vh[:ndims].T
|
|
139
|
-
B = vh[:ndims]
|
|
140
|
-
C = vh[ndims:2*ndims]
|
|
141
|
-
t = numpy.dot(C, numpy.linalg.pinv(B))
|
|
142
|
-
t = numpy.concatenate((t, numpy.zeros((ndims, 1))), axis=1)
|
|
143
|
-
M = numpy.vstack((t, ((0.0,)*ndims) + (1.0,)))
|
|
144
|
-
elif usesvd or ndims != 3:
|
|
145
|
-
# Rigid transformation via SVD of covariance matrix
|
|
146
|
-
u, s, vh = numpy.linalg.svd(numpy.dot(v1, v0.T))
|
|
147
|
-
# rotation matrix from SVD orthonormal bases
|
|
148
|
-
R = numpy.dot(u, vh)
|
|
149
|
-
if numpy.linalg.det(R) < 0.0:
|
|
150
|
-
# R does not constitute right handed system
|
|
151
|
-
R -= numpy.outer(u[:, ndims-1], vh[ndims-1, :]*2.0)
|
|
152
|
-
s[-1] *= -1.0
|
|
153
|
-
# homogeneous transformation matrix
|
|
154
|
-
M = numpy.identity(ndims+1)
|
|
155
|
-
M[:ndims, :ndims] = R
|
|
156
|
-
else:
|
|
157
|
-
# Rigid transformation matrix via quaternion
|
|
158
|
-
# compute symmetric matrix N
|
|
159
|
-
xx, yy, zz = numpy.sum(v0 * v1, axis=1)
|
|
160
|
-
xy, yz, zx = numpy.sum(v0 * numpy.roll(v1, -1, axis=0), axis=1)
|
|
161
|
-
xz, yx, zy = numpy.sum(v0 * numpy.roll(v1, -2, axis=0), axis=1)
|
|
162
|
-
N = [[xx+yy+zz, 0.0, 0.0, 0.0],
|
|
163
|
-
[yz-zy, xx-yy-zz, 0.0, 0.0],
|
|
164
|
-
[zx-xz, xy+yx, yy-xx-zz, 0.0],
|
|
165
|
-
[xy-yx, zx+xz, yz+zy, zz-xx-yy]]
|
|
166
|
-
# quaternion: eigenvector corresponding to most positive eigenvalue
|
|
167
|
-
w, V = numpy.linalg.eigh(N)
|
|
168
|
-
q = V[:, numpy.argmax(w)]
|
|
169
|
-
q /= _vector_norm(q) # unit quaternion
|
|
170
|
-
# homogeneous transformation matrix
|
|
171
|
-
M = _quaternion_matrix(q)
|
|
172
|
-
|
|
173
|
-
if scale and not shear:
|
|
174
|
-
# Affine transformation; scale is ratio of RMS deviations from centroid
|
|
175
|
-
v0 *= v0
|
|
176
|
-
v1 *= v1
|
|
177
|
-
M[:ndims, :ndims] *= math.sqrt(numpy.sum(v1) / numpy.sum(v0))
|
|
178
|
-
|
|
179
|
-
# move centroids back
|
|
180
|
-
M = numpy.dot(numpy.linalg.inv(M1), numpy.dot(M, M0))
|
|
181
|
-
M /= M[ndims, ndims]
|
|
182
|
-
return M
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
def _vector_norm(data, axis=None, out=None):
|
|
186
|
-
"""Return length, i.e. Euclidean norm, of ndarray along axis.
|
|
187
|
-
|
|
188
|
-
>>> v = numpy.random.random(3)
|
|
189
|
-
>>> n = vector_norm(v)
|
|
190
|
-
>>> numpy.allclose(n, numpy.linalg.norm(v))
|
|
191
|
-
True
|
|
192
|
-
>>> v = numpy.random.rand(6, 5, 3)
|
|
193
|
-
>>> n = vector_norm(v, axis=-1)
|
|
194
|
-
>>> numpy.allclose(n, numpy.sqrt(numpy.sum(v*v, axis=2)))
|
|
195
|
-
True
|
|
196
|
-
>>> n = vector_norm(v, axis=1)
|
|
197
|
-
>>> numpy.allclose(n, numpy.sqrt(numpy.sum(v*v, axis=1)))
|
|
198
|
-
True
|
|
199
|
-
>>> v = numpy.random.rand(5, 4, 3)
|
|
200
|
-
>>> n = numpy.empty((5, 3))
|
|
201
|
-
>>> vector_norm(v, axis=1, out=n)
|
|
202
|
-
>>> numpy.allclose(n, numpy.sqrt(numpy.sum(v*v, axis=1)))
|
|
203
|
-
True
|
|
204
|
-
>>> vector_norm([])
|
|
205
|
-
0.0
|
|
206
|
-
>>> vector_norm([1])
|
|
207
|
-
1.0
|
|
208
|
-
|
|
209
|
-
This function is called by affine_matrix_from_points when usesvd=False
|
|
210
|
-
|
|
211
|
-
Author: this function was extracted from the original transformations.py
|
|
212
|
-
written by Christoph Golke:
|
|
213
|
-
https://www.lfd.uci.edu/~gohlke/code/transformations.py.html
|
|
214
|
-
|
|
215
|
-
"""
|
|
216
|
-
data = numpy.array(data, dtype=numpy.float64, copy=True)
|
|
217
|
-
if out is None:
|
|
218
|
-
if data.ndim == 1:
|
|
219
|
-
return math.sqrt(numpy.dot(data, data))
|
|
220
|
-
data *= data
|
|
221
|
-
out = numpy.atleast_1d(numpy.sum(data, axis=axis))
|
|
222
|
-
numpy.sqrt(out, out)
|
|
223
|
-
return out
|
|
224
|
-
else:
|
|
225
|
-
data *= data
|
|
226
|
-
numpy.sum(data, axis=axis, out=out)
|
|
227
|
-
numpy.sqrt(out, out)
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
def _quaternion_matrix(quaternion):
|
|
231
|
-
"""Return homogeneous rotation matrix from quaternion.
|
|
232
|
-
|
|
233
|
-
>>> M = quaternion_matrix([0.99810947, 0.06146124, 0, 0])
|
|
234
|
-
>>> numpy.allclose(M, rotation_matrix(0.123, [1, 0, 0]))
|
|
235
|
-
True
|
|
236
|
-
>>> M = quaternion_matrix([1, 0, 0, 0])
|
|
237
|
-
>>> numpy.allclose(M, numpy.identity(4))
|
|
238
|
-
True
|
|
239
|
-
>>> M = quaternion_matrix([0, 1, 0, 0])
|
|
240
|
-
>>> numpy.allclose(M, numpy.diag([1, -1, -1, 1]))
|
|
241
|
-
True
|
|
242
|
-
|
|
243
|
-
This function is called by affine_matrix_from_points when usesvd=False
|
|
244
|
-
|
|
245
|
-
Author: this function was extracted from the original transformations.py
|
|
246
|
-
written by Christoph Golke:
|
|
247
|
-
https://www.lfd.uci.edu/~gohlke/code/transformations.py.html
|
|
248
|
-
"""
|
|
249
|
-
_EPS = np.finfo(float).eps * 5
|
|
250
|
-
|
|
251
|
-
q = numpy.array(quaternion, dtype=numpy.float64, copy=True)
|
|
252
|
-
n = numpy.dot(q, q)
|
|
253
|
-
if n < _EPS:
|
|
254
|
-
return numpy.identity(4)
|
|
255
|
-
q *= math.sqrt(2.0 / n)
|
|
256
|
-
q = numpy.outer(q, q)
|
|
257
|
-
return numpy.array([
|
|
258
|
-
[1.0-q[2, 2]-q[3, 3], q[1, 2]-q[3, 0], q[1, 3]+q[2, 0], 0.0],
|
|
259
|
-
[ q[1, 2]+q[3, 0], 1.0-q[1, 1]-q[3, 3], q[2, 3]-q[1, 0], 0.0],
|
|
260
|
-
[ q[1, 3]-q[2, 0], q[2, 3]+q[1, 0], 1.0-q[1, 1]-q[2, 2], 0.0],
|
|
261
|
-
[ 0.0, 0.0, 0.0, 1.0]])
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
def rigid_transform_3D(fromA, toB, verbose=True):
|
|
265
|
-
"""rigid_transform_3D(fromA, toB, verbose=True)
|
|
266
|
-
|
|
267
|
-
INPUT
|
|
268
|
-
Afrom, Bto 3xn arrays = xyz coords of n points to be registered
|
|
269
|
-
|
|
270
|
-
OUTPUT
|
|
271
|
-
Rotation + translation transformation matrix registering fromA into toB
|
|
272
|
-
|
|
273
|
-
Author : Nghia Ho - 2013 - http://nghiaho.com/?page_id=671
|
|
274
|
-
"Finding optimal rotation and translation between corresponding 3D points"
|
|
275
|
-
Based on "A Method for Registration of 3-D Shapes", by Besl and McKay, 1992.
|
|
276
|
-
|
|
277
|
-
This is based on Singular Value Decomposition (SVD)
|
|
278
|
-
--> it is equivalent to affine_matrix_from_points with parameter usesvd=True
|
|
279
|
-
"""
|
|
280
|
-
A = fromA.T
|
|
281
|
-
B = toB.T
|
|
282
|
-
|
|
283
|
-
assert len(A) == len(B)
|
|
284
|
-
|
|
285
|
-
N = A.shape[0]; # total points
|
|
286
|
-
|
|
287
|
-
centroid_A = np.mean(A, axis=0)
|
|
288
|
-
centroid_B = np.mean(B, axis=0)
|
|
289
|
-
|
|
290
|
-
# centre the points
|
|
291
|
-
AA = A - np.tile(centroid_A, (N, 1))
|
|
292
|
-
BB = B - np.tile(centroid_B, (N, 1))
|
|
293
|
-
|
|
294
|
-
# @ is matrix multiplication for array
|
|
295
|
-
H = np.transpose(AA) @ BB
|
|
296
|
-
|
|
297
|
-
U, S, Vt = np.linalg.svd(H)
|
|
298
|
-
|
|
299
|
-
R = Vt.T @ U.T
|
|
300
|
-
|
|
301
|
-
# special reflection case
|
|
302
|
-
if np.linalg.det(R) < 0:
|
|
303
|
-
print ("Reflection detected")
|
|
304
|
-
Vt[2,:] *= -1
|
|
305
|
-
R = Vt.T @ U.T
|
|
306
|
-
|
|
307
|
-
t = -R @ centroid_A.T + centroid_B.T
|
|
308
|
-
|
|
309
|
-
result = np.identity(4)
|
|
310
|
-
result[:3,:3] = R
|
|
311
|
-
result[:3,3] = t
|
|
312
|
-
|
|
313
|
-
return result
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
def translationRotationToTransformation(translation,rotation,rot_config="sxyz",active=True,degrees=True,translationFirst=False):
|
|
317
|
-
"""
|
|
318
|
-
translationRotationToTransformation(translation,rotation,rot_config="sxyz",active=True,degrees=True,translationFirst=False)
|
|
319
|
-
|
|
320
|
-
translationFirst : translation first
|
|
321
|
-
False first 3 rows of transformation matrix = (R t) [usual convention and default here]
|
|
322
|
-
True first 3 rows of transformation matrix = (R Rt) [used in the hexapod]
|
|
323
|
-
"""
|
|
324
|
-
import transforms3d as t3
|
|
325
|
-
import numpy as np
|
|
326
|
-
# Zoom - unit
|
|
327
|
-
zdef = np.array([1,1,1])
|
|
328
|
-
# Shear
|
|
329
|
-
sdef = np.array([0,0,0])
|
|
330
|
-
translation = np.array(translation)
|
|
331
|
-
#if degrees: rotation = np.deg2rad(np.array(rotation))
|
|
332
|
-
if degrees: rotation = np.array([np.deg2rad(item) for item in rotation])
|
|
333
|
-
rotx,roty,rotz = rotation
|
|
334
|
-
rmat = RotationMatrix(rotx,roty,rotz,rot_config=rot_config,active=active)
|
|
335
|
-
#
|
|
336
|
-
if translationFirst:
|
|
337
|
-
result = np.identity(4)
|
|
338
|
-
result[:3,:3] = rmat.R
|
|
339
|
-
result[:3,3] = rmat.R @ translation
|
|
340
|
-
else:
|
|
341
|
-
result = t3.affines.compose(translation,rmat.R,Z=zdef,S=sdef)
|
|
342
|
-
return result
|
|
343
|
-
|
|
344
|
-
def translationRotationFromTransformation(transformation,rot_config="sxyz",active=True,degrees=True,translationFirst=False):
|
|
345
|
-
"""
|
|
346
|
-
translationRotationFromTransformation(transformation,rot_config="sxyz",active=True,degrees=True,translationFirst=False)
|
|
347
|
-
|
|
348
|
-
translationFirst : translation first
|
|
349
|
-
False first 3 rows of transformation matrix = (R t) [usual convention and default here]
|
|
350
|
-
True first 3 rows of transformation matrix = (R Rt) [used in the hexapod]
|
|
351
|
-
"""
|
|
352
|
-
translation = transformation[:3,3]
|
|
353
|
-
rotation = t3.euler.mat2euler(transformation,axes=rot_config)
|
|
354
|
-
if degrees: rotation = np.array([np.rad2deg(item) for item in rotation])
|
|
355
|
-
if translationFirst:
|
|
356
|
-
translation = transformation[:3,:3].T @ translation
|
|
357
|
-
return translation,rotation
|
|
358
|
-
|
|
359
|
-
tr2T = translationRotationToTransformation
|
|
360
|
-
T2tr = translationRotationFromTransformation
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
def vectorPlaneIntersection(pt, frame, epsilon=1.e-6):
|
|
364
|
-
"""
|
|
365
|
-
return the coordinates of the intersection of a vector with a plane.
|
|
366
|
-
|
|
367
|
-
pt = input vector. Point object, expressing the vector
|
|
368
|
-
vector origin = pt.ref.getOrigin().coordinates[:3]
|
|
369
|
-
vector direction = pt.coordinates[:3]
|
|
370
|
-
frame = input plane. ReferenceFrame object whose x-y plane is the target plane for intersection
|
|
371
|
-
|
|
372
|
-
If the vector's own reference frame is 'frame', the problem is trivial
|
|
373
|
-
|
|
374
|
-
In all cases, the coordinates of the interesection point are provided as a Point object, in "frame" coordinates
|
|
375
|
-
|
|
376
|
-
Ref:
|
|
377
|
-
https://stackoverflow.com/questions/5666222/3d-line-plane-intersection
|
|
378
|
-
"""
|
|
379
|
-
|
|
380
|
-
from egse.coordinates.point import Point
|
|
381
|
-
|
|
382
|
-
if pt.ref == frame:
|
|
383
|
-
# The point is defined in frame => the origin of the vector is the origin of the target plane.
|
|
384
|
-
return np.array([0,0,0])
|
|
385
|
-
else:
|
|
386
|
-
# Express all inputs in 'frame'
|
|
387
|
-
|
|
388
|
-
# Vector Origin (p0)
|
|
389
|
-
vec_orig = Point(pt.ref.getOrigin().coordinates[:3],ref=pt.ref, name='ptorig').expressIn(frame)[:3]
|
|
390
|
-
# Vector End (p1)
|
|
391
|
-
vec_end = pt.expressIn(frame)[:3]
|
|
392
|
-
# Vector (u)
|
|
393
|
-
vec = vec_end - vec_orig
|
|
394
|
-
|
|
395
|
-
# A point in Plane (pco)
|
|
396
|
-
#plane_orig = np.array([0,0,0],dtype=float)
|
|
397
|
-
plane_orig = frame.getOrigin().coordinates[:3]
|
|
398
|
-
# Normal to the plane (pno)
|
|
399
|
-
plane_normal = frame.getAxis('z').coordinates[:3]
|
|
400
|
-
|
|
401
|
-
# Vector to normal 'angle'
|
|
402
|
-
vec_x_normal = np.dot(vec, plane_normal)
|
|
403
|
-
|
|
404
|
-
# Test if there is an intersection (and if it's unique)
|
|
405
|
-
# --> input vector and normal mustn't be perpendicular, else the vector is // to the plane or inside it
|
|
406
|
-
#
|
|
407
|
-
if (np.allclose(vec_x_normal, 0., atol=epsilon)):
|
|
408
|
-
print('The input vector is // to the plane normal (or inside the plane)')
|
|
409
|
-
print('--> there exists no intersection (or an infinity of them)')
|
|
410
|
-
return None
|
|
411
|
-
else:
|
|
412
|
-
# Vector from the point in the plane to the origin of the vector (w)
|
|
413
|
-
plane_to_vec = vec_orig - plane_orig
|
|
414
|
-
|
|
415
|
-
# Solution ("how many 'vectors' away is the interesection ?")
|
|
416
|
-
vec_multiplicator = - np.dot(plane_normal, plane_to_vec) / vec_x_normal
|
|
417
|
-
|
|
418
|
-
return Point(vec_orig + (vec * vec_multiplicator), ref=frame)
|
|
419
|
-
|
egse/csl/__init__.py
DELETED
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
from enum import Enum
|
|
2
|
-
from pathlib import Path
|
|
3
|
-
from executor import ExternalCommand
|
|
4
|
-
from gui_executor.utils import read_id
|
|
5
|
-
|
|
6
|
-
from egse.settings import Settings
|
|
7
|
-
|
|
8
|
-
HERE = Path(__file__).parent.resolve()
|
|
9
|
-
HOME_DIR = Path('~').expanduser()
|
|
10
|
-
ID_FILE = HOME_DIR / "hexapod_id.txt"
|
|
11
|
-
|
|
12
|
-
HEXAPODS = Settings.load(location=HOME_DIR,
|
|
13
|
-
filename="mech_pos_settings.yaml",
|
|
14
|
-
group_name="Hexapod",
|
|
15
|
-
add_local_settings=False)
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
class HexapodID(str, Enum):
|
|
19
|
-
H_1A = "1A"
|
|
20
|
-
H_1B = "1B"
|
|
21
|
-
H_2A = "2A"
|
|
22
|
-
H_2B = "2B"
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
def get_endpoint_hexapod(hexapod_id: str = None):
|
|
26
|
-
"""Returns the hostname and port number for the Hexapod."""
|
|
27
|
-
|
|
28
|
-
hexapod_id = hexapod_id or read_id(ID_FILE)
|
|
29
|
-
|
|
30
|
-
hostname = HEXAPODS[f"H_{hexapod_id}"]["HOSTNAME"]
|
|
31
|
-
port = HEXAPODS[f"H_{hexapod_id}"]["PORT"]
|
|
32
|
-
|
|
33
|
-
print(f"{hexapod_id=}, {hostname=}, {port=}")
|
|
34
|
-
|
|
35
|
-
return "PUNA", hexapod_id, hostname, port
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
def mechanical_position_ui():
|
|
39
|
-
""" Definition of the UI for the mechanical position at CSL.
|
|
40
|
-
|
|
41
|
-
This UI is built using the gui-executor code, and uses the definitions from this module.
|
|
42
|
-
"""
|
|
43
|
-
logo_path = HERE / "icons/logo-puna.svg"
|
|
44
|
-
cmd = ExternalCommand(
|
|
45
|
-
f"gui-executor --module-path egse.csl --logo {logo_path} --single "
|
|
46
|
-
f"--kernel-name plato-common-egse "
|
|
47
|
-
f"--app-name 'CSL Operator GUI (M-position)'",
|
|
48
|
-
asynchronous=True
|
|
49
|
-
)
|
|
50
|
-
cmd.start()
|
egse/csl/commanding.py
DELETED
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
""" Content of the UI for the mechanical position at CSL. This basically needs two buttons to command the hexapod:
|
|
2
|
-
- a button to go to the home position;
|
|
3
|
-
- a button to go to the retracted position.
|
|
4
|
-
"""
|
|
5
|
-
from pathlib import Path
|
|
6
|
-
|
|
7
|
-
from gui_executor.exec import exec_ui
|
|
8
|
-
|
|
9
|
-
from egse.csl import get_endpoint_hexapod
|
|
10
|
-
from egse.hexapod.symetrie.puna import PunaController
|
|
11
|
-
|
|
12
|
-
UI_MODULE_DISPLAY_NAME = "2 - Commanding"
|
|
13
|
-
|
|
14
|
-
ID_FILE = Path('~').expanduser() / "id.txt"
|
|
15
|
-
|
|
16
|
-
HERE = Path(__file__).parent.resolve()
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
@exec_ui(display_name="Zero position",
|
|
20
|
-
icons=(HERE/"icons/hexapod-zero.svg", HERE/"icons/hexapod-zero-selected.svg"))
|
|
21
|
-
def goto_zero_position():
|
|
22
|
-
""" Move the hexapod to the zero position."""
|
|
23
|
-
|
|
24
|
-
hexapod = None
|
|
25
|
-
hexapod_name, hexapod_id, hostname, port = get_endpoint_hexapod()
|
|
26
|
-
try:
|
|
27
|
-
from egse.hexapod.symetrie import ControllerFactory
|
|
28
|
-
factory = ControllerFactory()
|
|
29
|
-
hexapod = factory.create(hexapod_name, device_id=hexapod_id)
|
|
30
|
-
hexapod.connect()
|
|
31
|
-
hexapod.goto_zero_position()
|
|
32
|
-
except ConnectionError as exc:
|
|
33
|
-
print("[red]Couldn't connect to the Hexapod Controller. "
|
|
34
|
-
"Check if the Controller is switched on and no error is reported on the front panel of the controller.[/]")
|
|
35
|
-
finally:
|
|
36
|
-
if hexapod is not None:
|
|
37
|
-
hexapod.disconnect()
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
@exec_ui(display_name="Retracted position",
|
|
41
|
-
icons=(HERE/"icons/hexapod-retract.svg", HERE/"icons/hexapod-retract-selected.svg"))
|
|
42
|
-
def goto_retracted_position():
|
|
43
|
-
""" Move the hexapod to the retracted position."""
|
|
44
|
-
|
|
45
|
-
hexapod = None
|
|
46
|
-
hexapod_name, hexapod_id, hostname, port = get_endpoint_hexapod()
|
|
47
|
-
try:
|
|
48
|
-
from egse.hexapod.symetrie import ControllerFactory
|
|
49
|
-
factory = ControllerFactory()
|
|
50
|
-
hexapod = factory.create(hexapod_name, device_id=hexapod_id)
|
|
51
|
-
hexapod.connect()
|
|
52
|
-
hexapod.goto_retracted_position()
|
|
53
|
-
except ConnectionError as exc:
|
|
54
|
-
print("[red]Couldn't connect to the Hexapod Controller. "
|
|
55
|
-
"Check if the Controller is switched on and no error is reported on the front panel of the controller.[/]")
|
|
56
|
-
finally:
|
|
57
|
-
if hexapod is not None:
|
|
58
|
-
hexapod.disconnect()
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
@exec_ui(display_name="Emergency stop", icons=(HERE / "icons/stop.svg", HERE / "icons/stop.svg"), immediate_run=True)
|
|
62
|
-
def emergency_stop():
|
|
63
|
-
""" Emergency stop of the hexapod."""
|
|
64
|
-
|
|
65
|
-
hexapod = None
|
|
66
|
-
hexapod_name, hexapod_id, hostname, port = get_endpoint_hexapod()
|
|
67
|
-
try:
|
|
68
|
-
from egse.hexapod.symetrie import ControllerFactory
|
|
69
|
-
factory = ControllerFactory()
|
|
70
|
-
hexapod = factory.create(hexapod_name, device_id=hexapod_id)
|
|
71
|
-
hexapod.connect()
|
|
72
|
-
hexapod.stop()
|
|
73
|
-
except ConnectionError as exc:
|
|
74
|
-
print("[red]Couldn't connect to the Hexapod Controller. "
|
|
75
|
-
"Check if the Controller is switched on and no error is reported on the front panel of the controller.[/]")
|
|
76
|
-
finally:
|
|
77
|
-
if hexapod is not None:
|
|
78
|
-
hexapod.disconnect()
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
-
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
|
3
|
-
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0" y="0" width="512.004" height="512.004" viewBox="0, 0, 512.004, 512.004">
|
|
4
|
-
<g id="connected-selected">
|
|
5
|
-
<path d="M481.539,52.376 L458.251,29.089 C455.051,25.889 449.385,25.889 446.185,29.089 L376.314,98.96 C372.978,102.296 372.978,107.69 376.314,111.026 L399.601,134.313 C401.197,135.917 403.373,136.813 405.634,136.813 C407.895,136.813 410.063,135.917 411.667,134.313 L481.538,64.442 C484.875,61.106 484.875,55.713 481.539,52.376 z M405.635,116.214 L394.414,104.993 L452.219,47.188 L463.44,58.409 L405.635,116.214 z" fill="#126EFF"/>
|
|
6
|
-
<path d="M417.07,127.657 L382.971,93.558 C372.987,83.574 356.757,83.574 346.773,93.558 L335.543,104.779 C333.939,106.375 333.043,108.542 333.043,110.812 C333.043,113.073 333.939,115.241 335.543,116.845 L393.775,175.076 C395.371,176.68 397.547,177.576 399.808,177.576 C402.078,177.576 404.245,176.671 405.85,175.076 L417.071,163.855 C427.054,153.871 427.054,137.641 417.07,127.657 z M404.995,151.781 L399.807,156.969 L353.65,110.804 L358.838,105.616 C362.166,102.305 367.576,102.288 370.904,105.616 L404.995,139.715 C408.323,143.043 408.323,148.453 404.995,151.781 z" fill="#126EFF"/>
|
|
7
|
-
<path d="M410.192,167.354 L343.257,100.419 C330.363,87.525 313.228,80.425 294.992,80.425 C276.765,80.425 259.63,87.525 246.736,100.419 L195.801,151.354 C194.197,152.95 193.301,155.117 193.301,157.387 C193.301,159.657 194.197,161.816 195.801,163.42 L347.191,314.818 C348.855,316.482 351.04,317.318 353.224,317.318 C355.409,317.318 357.593,316.482 359.257,314.818 L410.192,263.883 C436.799,237.268 436.799,193.961 410.192,167.354 z M398.126,251.817 L353.224,296.719 L213.899,157.387 L258.801,112.493 C268.469,102.825 281.32,97.5 294.991,97.5 C308.67,97.5 321.521,102.825 331.189,112.493 L398.124,179.428 C418.076,199.38 418.076,231.858 398.126,251.817 z" fill="#126EFF"/>
|
|
8
|
-
<path d="M398.061,251.81 L353.159,296.712 L213.834,157.38 L258.736,112.486 C268.404,102.818 281.255,97.493 294.926,97.493 C308.605,97.493 321.456,102.818 331.124,112.486 L398.059,179.421 C418.011,199.373 418.011,231.851 398.061,251.81 z" fill="#E29AFF"/>
|
|
9
|
-
<path d="M341.797,145.543 L318.501,122.238 C305.539,109.284 284.47,109.284 271.517,122.238 L248.221,145.543 C244.884,148.88 244.884,154.273 248.221,157.609 C251.558,160.945 256.959,160.945 260.287,157.609 L283.583,134.304 C289.889,128.006 300.138,128.006 306.435,134.304 L329.731,157.609 C331.395,159.273 333.58,160.109 335.764,160.109 C337.94,160.109 340.124,159.273 341.797,157.609 C345.133,154.273 345.133,148.879 341.797,145.543 z" fill="#126EFF"/>
|
|
10
|
-
<path d="M134.093,400.187 L110.806,376.9 C109.21,375.296 107.034,374.4 104.773,374.4 C102.512,374.4 100.344,375.296 98.74,376.9 L28.868,446.771 C25.532,450.108 25.532,455.501 28.868,458.837 L52.155,482.124 C53.751,483.728 55.927,484.624 58.188,484.624 C60.458,484.624 62.625,483.728 64.221,482.124 L134.092,412.253 C137.429,408.917 137.429,403.524 134.093,400.187 z M58.189,464.025 L46.968,452.804 L104.773,394.999 L115.994,406.22 L58.189,464.025 z" fill="#126EFF"/>
|
|
11
|
-
<path d="M174.848,394.376 L116.617,336.145 C115.021,334.541 112.845,333.645 110.584,333.645 C108.323,333.645 106.155,334.541 104.551,336.145 L93.33,347.366 C83.346,357.35 83.346,373.58 93.33,383.564 L127.429,417.663 C132.421,422.655 138.975,425.147 145.528,425.147 C152.081,425.147 158.635,422.655 163.619,417.663 L174.849,406.442 C176.453,404.846 177.349,402.679 177.349,400.409 C177.348,398.148 176.452,395.981 174.848,394.376 z M151.578,405.589 C148.25,408.9 142.84,408.917 139.512,405.589 L105.413,371.49 C102.085,368.162 102.085,362.752 105.413,359.424 L110.601,354.236 L156.766,400.401 L151.578,405.589 z" fill="#126EFF"/>
|
|
12
|
-
<path d="M326.247,336.128 L174.857,184.738 C171.657,181.538 165.991,181.538 162.791,184.738 L100.208,247.321 C73.601,273.936 73.601,317.243 100.208,343.85 L167.143,410.785 C180.037,423.679 197.172,430.779 215.408,430.779 C233.644,430.779 250.779,423.679 263.673,410.777 L326.248,348.194 C329.583,344.857 329.583,339.464 326.247,336.128 z M251.597,398.72 C241.929,408.388 229.078,413.713 215.407,413.713 C201.728,413.713 188.877,408.388 179.209,398.72 L112.274,331.785 C92.323,311.834 92.323,279.356 112.274,259.397 L168.824,202.847 L308.139,342.171 L251.597,398.72 z" fill="#126EFF"/>
|
|
13
|
-
<path d="M251.597,398.72 C241.929,408.388 229.078,413.713 215.407,413.713 C201.728,413.713 188.877,408.388 179.209,398.72 L112.274,331.785 C92.323,311.834 92.323,279.356 112.274,259.397 L168.824,202.847 L308.139,342.171 L251.597,398.72 z" fill="#E29AFF"/>
|
|
14
|
-
<path d="M279.663,336.136 L174.857,231.33 C171.521,227.993 166.127,227.993 162.791,231.33 L116.208,277.913 C112.871,281.25 112.871,286.643 116.208,289.979 L221.023,394.785 C222.687,396.449 224.872,397.285 227.056,397.285 C229.232,397.285 231.417,396.449 233.081,394.785 L279.664,348.202 C283,344.866 283,339.473 279.663,336.136 z M227.047,376.687 L134.307,283.947 L168.824,249.43 L261.564,342.17 L227.047,376.687 z" fill="#126EFF"/>
|
|
15
|
-
<path d="M231.44,314.497 L196.505,279.553 C193.168,276.217 187.775,276.216 184.439,279.553 C181.103,282.89 181.103,288.283 184.439,291.619 L219.374,326.563 C221.038,328.227 223.223,329.063 225.407,329.063 C227.591,329.063 229.776,328.227 231.44,326.563 C234.777,323.226 234.777,317.833 231.44,314.497 z" fill="#126EFF"/>
|
|
16
|
-
</g>
|
|
17
|
-
<g id="connected" display="none">
|
|
18
|
-
<path d="M481.539,52.376 L458.251,29.089 C455.051,25.889 449.385,25.889 446.185,29.089 L376.314,98.96 C372.978,102.296 372.978,107.69 376.314,111.026 L399.601,134.313 C401.197,135.917 403.373,136.813 405.634,136.813 C407.895,136.813 410.063,135.917 411.667,134.313 L481.538,64.442 C484.875,61.106 484.875,55.713 481.539,52.376 z M405.635,116.214 L394.414,104.993 L452.219,47.188 L463.44,58.409 L405.635,116.214 z" fill="#126EFF"/>
|
|
19
|
-
<path d="M417.07,127.657 L382.971,93.558 C372.987,83.574 356.757,83.574 346.773,93.558 L335.543,104.779 C333.939,106.375 333.043,108.542 333.043,110.812 C333.043,113.073 333.939,115.241 335.543,116.845 L393.775,175.076 C395.371,176.68 397.547,177.576 399.808,177.576 C402.078,177.576 404.245,176.671 405.85,175.076 L417.071,163.855 C427.054,153.871 427.054,137.641 417.07,127.657 z M404.995,151.781 L399.807,156.969 L353.65,110.804 L358.838,105.616 C362.166,102.305 367.576,102.288 370.904,105.616 L404.995,139.715 C408.323,143.043 408.323,148.453 404.995,151.781 z" fill="#126EFF"/>
|
|
20
|
-
<path d="M410.192,167.354 L343.257,100.419 C330.363,87.525 313.228,80.425 294.992,80.425 C276.765,80.425 259.63,87.525 246.736,100.419 L195.801,151.354 C194.197,152.95 193.301,155.117 193.301,157.387 C193.301,159.657 194.197,161.816 195.801,163.42 L347.191,314.818 C348.855,316.482 351.04,317.318 353.224,317.318 C355.409,317.318 357.593,316.482 359.257,314.818 L410.192,263.883 C436.799,237.268 436.799,193.961 410.192,167.354 z M398.126,251.817 L353.224,296.719 L213.899,157.387 L258.801,112.493 C268.469,102.825 281.32,97.5 294.991,97.5 C308.67,97.5 321.521,102.825 331.189,112.493 L398.124,179.428 C418.076,199.38 418.076,231.858 398.126,251.817 z" fill="#126EFF"/>
|
|
21
|
-
<path d="M398.061,251.81 L353.159,296.712 L213.834,157.38 L258.736,112.486 C268.404,102.818 281.255,97.493 294.926,97.493 C308.605,97.493 321.456,102.818 331.124,112.486 L398.059,179.421 C418.011,199.373 418.011,231.851 398.061,251.81 z" fill="#A5CBFF"/>
|
|
22
|
-
<path d="M341.797,145.543 L318.501,122.238 C305.539,109.284 284.47,109.284 271.517,122.238 L248.221,145.543 C244.884,148.88 244.884,154.273 248.221,157.609 C251.558,160.945 256.959,160.945 260.287,157.609 L283.583,134.304 C289.889,128.006 300.138,128.006 306.435,134.304 L329.731,157.609 C331.395,159.273 333.58,160.109 335.764,160.109 C337.94,160.109 340.124,159.273 341.797,157.609 C345.133,154.273 345.133,148.879 341.797,145.543 z" fill="#126EFF"/>
|
|
23
|
-
<path d="M134.093,400.187 L110.806,376.9 C109.21,375.296 107.034,374.4 104.773,374.4 C102.512,374.4 100.344,375.296 98.74,376.9 L28.868,446.771 C25.532,450.108 25.532,455.501 28.868,458.837 L52.155,482.124 C53.751,483.728 55.927,484.624 58.188,484.624 C60.458,484.624 62.625,483.728 64.221,482.124 L134.092,412.253 C137.429,408.917 137.429,403.524 134.093,400.187 z M58.189,464.025 L46.968,452.804 L104.773,394.999 L115.994,406.22 L58.189,464.025 z" fill="#126EFF"/>
|
|
24
|
-
<path d="M174.848,394.376 L116.617,336.145 C115.021,334.541 112.845,333.645 110.584,333.645 C108.323,333.645 106.155,334.541 104.551,336.145 L93.33,347.366 C83.346,357.35 83.346,373.58 93.33,383.564 L127.429,417.663 C132.421,422.655 138.975,425.147 145.528,425.147 C152.081,425.147 158.635,422.655 163.619,417.663 L174.849,406.442 C176.453,404.846 177.349,402.679 177.349,400.409 C177.348,398.148 176.452,395.981 174.848,394.376 z M151.578,405.589 C148.25,408.9 142.84,408.917 139.512,405.589 L105.413,371.49 C102.085,368.162 102.085,362.752 105.413,359.424 L110.601,354.236 L156.766,400.401 L151.578,405.589 z" fill="#126EFF"/>
|
|
25
|
-
<path d="M326.247,336.128 L174.857,184.738 C171.657,181.538 165.991,181.538 162.791,184.738 L100.208,247.321 C73.601,273.936 73.601,317.243 100.208,343.85 L167.143,410.785 C180.037,423.679 197.172,430.779 215.408,430.779 C233.644,430.779 250.779,423.679 263.673,410.777 L326.248,348.194 C329.583,344.857 329.583,339.464 326.247,336.128 z M251.597,398.72 C241.929,408.388 229.078,413.713 215.407,413.713 C201.728,413.713 188.877,408.388 179.209,398.72 L112.274,331.785 C92.323,311.834 92.323,279.356 112.274,259.397 L168.824,202.847 L308.139,342.171 L251.597,398.72 z" fill="#126EFF"/>
|
|
26
|
-
<path d="M251.597,398.72 C241.929,408.388 229.078,413.713 215.407,413.713 C201.728,413.713 188.877,408.388 179.209,398.72 L112.274,331.785 C92.323,311.834 92.323,279.356 112.274,259.397 L168.824,202.847 L308.139,342.171 L251.597,398.72 z" fill="#A5CBFF"/>
|
|
27
|
-
<path d="M279.663,336.136 L174.857,231.33 C171.521,227.993 166.127,227.993 162.791,231.33 L116.208,277.913 C112.871,281.25 112.871,286.643 116.208,289.979 L221.023,394.785 C222.687,396.449 224.872,397.285 227.056,397.285 C229.232,397.285 231.417,396.449 233.081,394.785 L279.664,348.202 C283,344.866 283,339.473 279.663,336.136 z M227.047,376.687 L134.307,283.947 L168.824,249.43 L261.564,342.17 L227.047,376.687 z" fill="#126EFF"/>
|
|
28
|
-
<path d="M231.44,314.497 L196.505,279.553 C193.168,276.217 187.775,276.216 184.439,279.553 C181.103,282.89 181.103,288.283 184.439,291.619 L219.374,326.563 C221.038,328.227 223.223,329.063 225.407,329.063 C227.591,329.063 229.776,328.227 231.44,326.563 C234.777,323.226 234.777,317.833 231.44,314.497 z" fill="#126EFF"/>
|
|
29
|
-
</g>
|
|
30
|
-
</svg>
|