cgse 2024.7.0__py3-none-any.whl → 2025.0.2__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- README.md +27 -0
- bump.py +85 -0
- cgse-2025.0.2.dist-info/METADATA +38 -0
- cgse-2025.0.2.dist-info/RECORD +5 -0
- {cgse-2024.7.0.dist-info → cgse-2025.0.2.dist-info}/WHEEL +1 -2
- cgse-2024.7.0.dist-info/COPYING +0 -674
- cgse-2024.7.0.dist-info/COPYING.LESSER +0 -165
- cgse-2024.7.0.dist-info/METADATA +0 -144
- cgse-2024.7.0.dist-info/RECORD +0 -660
- cgse-2024.7.0.dist-info/entry_points.txt +0 -75
- cgse-2024.7.0.dist-info/top_level.txt +0 -2
- egse/__init__.py +0 -12
- egse/__main__.py +0 -32
- egse/aeu/aeu.py +0 -5238
- egse/aeu/aeu_awg.yaml +0 -265
- egse/aeu/aeu_crio.yaml +0 -273
- egse/aeu/aeu_cs.py +0 -627
- egse/aeu/aeu_devif.py +0 -321
- egse/aeu/aeu_main_ui.py +0 -903
- egse/aeu/aeu_metrics.py +0 -131
- egse/aeu/aeu_protocol.py +0 -463
- egse/aeu/aeu_psu.yaml +0 -204
- egse/aeu/aeu_ui.py +0 -873
- egse/aeu/arbdata/FccdRead.arb +0 -2
- egse/aeu/arbdata/FccdRead_min_points.arb +0 -2
- egse/aeu/arbdata/HeaterSync_FccdRead.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead25.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead31_25.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead37_50.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead43_75.arb +0 -2
- egse/aeu/arbdata/HeaterSync_ccdRead50.arb +0 -2
- egse/aeu/arbdata/Heater_FccdRead_min_points.arb +0 -2
- egse/aeu/arbdata/ccdRead25.arb +0 -2
- egse/aeu/arbdata/ccdRead25_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead31_25.arb +0 -2
- egse/aeu/arbdata/ccdRead31_25_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead37_50.arb +0 -2
- egse/aeu/arbdata/ccdRead37_50_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead43_75.arb +0 -2
- egse/aeu/arbdata/ccdRead43_75_150ms.arb +0 -2
- egse/aeu/arbdata/ccdRead50.arb +0 -2
- egse/aeu/arbdata/ccdRead50_150ms.arb +0 -2
- egse/alert/__init__.py +0 -1049
- egse/alert/alertman.yaml +0 -37
- egse/alert/alertman_cs.py +0 -233
- egse/alert/alertman_ui.py +0 -600
- egse/alert/gsm/beaglebone.py +0 -138
- egse/alert/gsm/beaglebone.yaml +0 -51
- egse/alert/gsm/beaglebone_cs.py +0 -108
- egse/alert/gsm/beaglebone_devif.py +0 -122
- egse/alert/gsm/beaglebone_protocol.py +0 -46
- egse/bits.py +0 -318
- egse/camera.py +0 -44
- egse/collimator/__init__.py +0 -0
- egse/collimator/fcul/__init__.py +0 -0
- egse/collimator/fcul/ogse.py +0 -1077
- egse/collimator/fcul/ogse.yaml +0 -14
- egse/collimator/fcul/ogse_cs.py +0 -154
- egse/collimator/fcul/ogse_devif.py +0 -358
- egse/collimator/fcul/ogse_protocol.py +0 -132
- egse/collimator/fcul/ogse_sim.py +0 -431
- egse/collimator/fcul/ogse_ui.py +0 -1108
- egse/command.py +0 -699
- egse/config.py +0 -410
- egse/confman/__init__.py +0 -1058
- egse/confman/confman.yaml +0 -70
- egse/confman/confman_cs.py +0 -240
- egse/confman/confman_ui.py +0 -381
- egse/confman/setup_ui.py +0 -565
- egse/control.py +0 -632
- egse/coordinates/__init__.py +0 -534
- egse/coordinates/avoidance.py +0 -100
- egse/coordinates/cslmodel.py +0 -127
- egse/coordinates/laser_tracker_to_dict.py +0 -122
- egse/coordinates/point.py +0 -707
- egse/coordinates/pyplot.py +0 -194
- egse/coordinates/referenceFrame.py +0 -1279
- egse/coordinates/refmodel.py +0 -737
- egse/coordinates/rotationMatrix.py +0 -85
- egse/coordinates/transform3d_addon.py +0 -419
- egse/csl/__init__.py +0 -50
- egse/csl/commanding.py +0 -78
- egse/csl/icons/hexapod-connected-selected.svg +0 -30
- egse/csl/icons/hexapod-connected.svg +0 -30
- egse/csl/icons/hexapod-homing-selected.svg +0 -68
- egse/csl/icons/hexapod-homing.svg +0 -68
- egse/csl/icons/hexapod-retract-selected.svg +0 -56
- egse/csl/icons/hexapod-retract.svg +0 -51
- egse/csl/icons/hexapod-zero-selected.svg +0 -56
- egse/csl/icons/hexapod-zero.svg +0 -56
- egse/csl/icons/logo-puna.svg +0 -92
- egse/csl/icons/stop.svg +0 -1
- egse/csl/initialisation.py +0 -102
- egse/csl/mech_pos_settings.yaml +0 -18
- egse/das.py +0 -1240
- egse/das.yaml +0 -7
- egse/data/conf/SETUP_CSL_00000_170620_150000.yaml +0 -5
- egse/data/conf/SETUP_CSL_00001_170620_151010.yaml +0 -69
- egse/data/conf/SETUP_CSL_00002_170620_151020.yaml +0 -69
- egse/data/conf/SETUP_CSL_00003_170620_151030.yaml +0 -69
- egse/data/conf/SETUP_CSL_00004_170620_151040.yaml +0 -69
- egse/data/conf/SETUP_CSL_00005_170620_151050.yaml +0 -69
- egse/data/conf/SETUP_CSL_00006_170620_151060.yaml +0 -69
- egse/data/conf/SETUP_CSL_00007_170620_151070.yaml +0 -69
- egse/data/conf/SETUP_CSL_00008_170620_151080.yaml +0 -75
- egse/data/conf/SETUP_CSL_00010_210308_083016.yaml +0 -138
- egse/data/conf/SETUP_INTA_00000_170620_150000.yaml +0 -4
- egse/data/conf/SETUP_SRON_00000_170620_150000.yaml +0 -4
- egse/decorators.py +0 -514
- egse/device.py +0 -269
- egse/dpu/__init__.py +0 -2698
- egse/dpu/ccd_ui.py +0 -514
- egse/dpu/dpu.py +0 -783
- egse/dpu/dpu.yaml +0 -153
- egse/dpu/dpu_cs.py +0 -272
- egse/dpu/dpu_ui.py +0 -671
- egse/dpu/fitsgen.py +0 -2096
- egse/dpu/fitsgen_ui.py +0 -399
- egse/dpu/hdf5_model.py +0 -332
- egse/dpu/hdf5_ui.py +0 -277
- egse/dpu/hdf5_viewer.py +0 -506
- egse/dpu/hk_ui.py +0 -468
- egse/dpu_commands.py +0 -81
- egse/dsi/__init__.py +0 -33
- egse/dsi/_libesl.py +0 -232
- egse/dsi/constants.py +0 -296
- egse/dsi/esl.py +0 -630
- egse/dsi/rmap.py +0 -444
- egse/dsi/rmapci.py +0 -39
- egse/dsi/spw.py +0 -335
- egse/dsi/spw_state.py +0 -29
- egse/dummy.py +0 -318
- egse/dyndummy.py +0 -179
- egse/env.py +0 -278
- egse/exceptions.py +0 -88
- egse/fdir/__init__.py +0 -26
- egse/fdir/fdir_manager.py +0 -85
- egse/fdir/fdir_manager.yaml +0 -37
- egse/fdir/fdir_manager_controller.py +0 -136
- egse/fdir/fdir_manager_cs.py +0 -164
- egse/fdir/fdir_manager_interface.py +0 -15
- egse/fdir/fdir_remote.py +0 -73
- egse/fdir/fdir_remote.yaml +0 -30
- egse/fdir/fdir_remote_controller.py +0 -30
- egse/fdir/fdir_remote_cs.py +0 -94
- egse/fdir/fdir_remote_interface.py +0 -9
- egse/fdir/fdir_remote_popup.py +0 -26
- egse/fee/__init__.py +0 -106
- egse/fee/f_fee_register.yaml +0 -43
- egse/fee/feesim.py +0 -914
- egse/fee/n_fee_hk.py +0 -768
- egse/fee/nfee.py +0 -188
- egse/filterwheel/__init__.py +0 -4
- egse/filterwheel/eksma/__init__.py +0 -49
- egse/filterwheel/eksma/fw8smc4.py +0 -657
- egse/filterwheel/eksma/fw8smc4.yaml +0 -121
- egse/filterwheel/eksma/fw8smc4_cs.py +0 -144
- egse/filterwheel/eksma/fw8smc4_devif.py +0 -473
- egse/filterwheel/eksma/fw8smc4_protocol.py +0 -82
- egse/filterwheel/eksma/fw8smc4_ui.py +0 -940
- egse/filterwheel/eksma/fw8smc5.py +0 -115
- egse/filterwheel/eksma/fw8smc5.yaml +0 -105
- egse/filterwheel/eksma/fw8smc5_controller.py +0 -307
- egse/filterwheel/eksma/fw8smc5_cs.py +0 -141
- egse/filterwheel/eksma/fw8smc5_interface.py +0 -65
- egse/filterwheel/eksma/fw8smc5_simulator.py +0 -29
- egse/filterwheel/eksma/fw8smc5_ui.py +0 -1065
- egse/filterwheel/eksma/testpythonfw.py +0 -215
- egse/fov/__init__.py +0 -65
- egse/fov/fov_hk.py +0 -710
- egse/fov/fov_ui.py +0 -859
- egse/fov/fov_ui_controller.py +0 -140
- egse/fov/fov_ui_model.py +0 -200
- egse/fov/fov_ui_view.py +0 -345
- egse/gimbal/__init__.py +0 -32
- egse/gimbal/symetrie/__init__.py +0 -26
- egse/gimbal/symetrie/alpha.py +0 -586
- egse/gimbal/symetrie/generic_gimbal_ui.py +0 -1521
- egse/gimbal/symetrie/gimbal.py +0 -877
- egse/gimbal/symetrie/gimbal.yaml +0 -168
- egse/gimbal/symetrie/gimbal_cs.py +0 -183
- egse/gimbal/symetrie/gimbal_protocol.py +0 -138
- egse/gimbal/symetrie/gimbal_ui.py +0 -361
- egse/gimbal/symetrie/pmac.py +0 -1006
- egse/gimbal/symetrie/pmac_regex.py +0 -83
- egse/graph.py +0 -132
- egse/gui/__init__.py +0 -47
- egse/gui/buttons.py +0 -378
- egse/gui/focalplane.py +0 -1285
- egse/gui/formatter.py +0 -10
- egse/gui/led.py +0 -162
- egse/gui/limitswitch.py +0 -143
- egse/gui/mechanisms.py +0 -587
- egse/gui/states.py +0 -148
- egse/gui/stripchart.py +0 -729
- egse/gui/styles.qss +0 -48
- egse/gui/switch.py +0 -112
- egse/h5.py +0 -274
- egse/help/__init__.py +0 -0
- egse/help/help_ui.py +0 -126
- egse/hexapod/__init__.py +0 -32
- egse/hexapod/symetrie/__init__.py +0 -137
- egse/hexapod/symetrie/alpha.py +0 -874
- egse/hexapod/symetrie/dynalpha.py +0 -1387
- egse/hexapod/symetrie/hexapod_ui.py +0 -1516
- egse/hexapod/symetrie/pmac.py +0 -1010
- egse/hexapod/symetrie/pmac_regex.py +0 -83
- egse/hexapod/symetrie/puna.py +0 -1167
- egse/hexapod/symetrie/puna.yaml +0 -193
- egse/hexapod/symetrie/puna_cs.py +0 -195
- egse/hexapod/symetrie/puna_protocol.py +0 -134
- egse/hexapod/symetrie/puna_ui.py +0 -433
- egse/hexapod/symetrie/punaplus.py +0 -107
- egse/hexapod/symetrie/zonda.py +0 -872
- egse/hexapod/symetrie/zonda.yaml +0 -337
- egse/hexapod/symetrie/zonda_cs.py +0 -172
- egse/hexapod/symetrie/zonda_devif.py +0 -414
- egse/hexapod/symetrie/zonda_protocol.py +0 -123
- egse/hexapod/symetrie/zonda_ui.py +0 -449
- egse/hk.py +0 -791
- egse/icons/aeu-cs-start.svg +0 -117
- egse/icons/aeu-cs-stop.svg +0 -118
- egse/icons/aeu-cs.svg +0 -107
- egse/icons/aeu_cs-started.svg +0 -112
- egse/icons/aeu_cs-stopped.svg +0 -112
- egse/icons/aeu_cs.svg +0 -55
- egse/icons/alert.svg +0 -1
- egse/icons/arrow-double-left.png +0 -0
- egse/icons/arrow-double-right.png +0 -0
- egse/icons/arrow-up.svg +0 -11
- egse/icons/backward.svg +0 -1
- egse/icons/busy.svg +0 -1
- egse/icons/cleaning.svg +0 -115
- egse/icons/color-scheme.svg +0 -1
- egse/icons/cs-connected-alert.svg +0 -91
- egse/icons/cs-connected-disabled.svg +0 -43
- egse/icons/cs-connected.svg +0 -89
- egse/icons/cs-not-connected.svg +0 -44
- egse/icons/double-left-arrow.svg +0 -1
- egse/icons/double-right-arrow.svg +0 -1
- egse/icons/erase-disabled.svg +0 -19
- egse/icons/erase.svg +0 -59
- egse/icons/fitsgen-start.svg +0 -47
- egse/icons/fitsgen-stop.svg +0 -48
- egse/icons/fitsgen.svg +0 -1
- egse/icons/forward.svg +0 -1
- egse/icons/fov-hk-start.svg +0 -33
- egse/icons/fov-hk-stop.svg +0 -37
- egse/icons/fov-hk.svg +0 -1
- egse/icons/front-desk.svg +0 -1
- egse/icons/home-actioned.svg +0 -15
- egse/icons/home-disabled.svg +0 -15
- egse/icons/home.svg +0 -13
- egse/icons/info.svg +0 -1
- egse/icons/invalid.png +0 -0
- egse/icons/led-green.svg +0 -20
- egse/icons/led-grey.svg +0 -20
- egse/icons/led-orange.svg +0 -20
- egse/icons/led-red.svg +0 -20
- egse/icons/led-square-green.svg +0 -134
- egse/icons/led-square-grey.svg +0 -134
- egse/icons/led-square-orange.svg +0 -134
- egse/icons/led-square-red.svg +0 -134
- egse/icons/limit-switch-all-green.svg +0 -115
- egse/icons/limit-switch-all-red.svg +0 -117
- egse/icons/limit-switch-el+.svg +0 -116
- egse/icons/limit-switch-el-.svg +0 -117
- egse/icons/location-marker.svg +0 -1
- egse/icons/logo-dpu.svg +0 -48
- egse/icons/logo-gimbal.svg +0 -112
- egse/icons/logo-huber.svg +0 -23
- egse/icons/logo-ogse.svg +0 -31
- egse/icons/logo-puna.svg +0 -92
- egse/icons/logo-tcs.svg +0 -29
- egse/icons/logo-zonda.svg +0 -66
- egse/icons/maximize.svg +0 -1
- egse/icons/meter.svg +0 -1
- egse/icons/more.svg +0 -45
- egse/icons/n-fee-hk-start.svg +0 -24
- egse/icons/n-fee-hk-stop.svg +0 -25
- egse/icons/n-fee-hk.svg +0 -83
- egse/icons/observing-off.svg +0 -46
- egse/icons/observing-on.svg +0 -46
- egse/icons/open-document-hdf5.png +0 -0
- egse/icons/open-document-hdf5.svg +0 -21
- egse/icons/ops-mode.svg +0 -1
- egse/icons/play-green.svg +0 -17
- egse/icons/plugged-disabled.svg +0 -27
- egse/icons/plugged.svg +0 -21
- egse/icons/pm_ui.svg +0 -1
- egse/icons/power-button-green.svg +0 -27
- egse/icons/power-button-red.svg +0 -27
- egse/icons/power-button.svg +0 -27
- egse/icons/radar.svg +0 -1
- egse/icons/radioactive.svg +0 -2
- egse/icons/reload.svg +0 -1
- egse/icons/remote-control-off.svg +0 -28
- egse/icons/remote-control-on.svg +0 -28
- egse/icons/repeat-blue.svg +0 -15
- egse/icons/repeat.svg +0 -1
- egse/icons/settings.svg +0 -1
- egse/icons/shrink.svg +0 -1
- egse/icons/shutter.svg +0 -1
- egse/icons/sign-off.svg +0 -1
- egse/icons/sign-on.svg +0 -1
- egse/icons/sim-mode.svg +0 -1
- egse/icons/small-buttons-go.svg +0 -20
- egse/icons/small-buttons-minus.svg +0 -51
- egse/icons/small-buttons-plus.svg +0 -51
- egse/icons/sponge.svg +0 -220
- egse/icons/start-button-disabled.svg +0 -84
- egse/icons/start-button.svg +0 -50
- egse/icons/stop-button-disabled.svg +0 -84
- egse/icons/stop-button.svg +0 -50
- egse/icons/stop-red.svg +0 -17
- egse/icons/stop.svg +0 -1
- egse/icons/switch-disabled-square.svg +0 -87
- egse/icons/switch-disabled.svg +0 -15
- egse/icons/switch-off-square.svg +0 -87
- egse/icons/switch-off.svg +0 -72
- egse/icons/switch-on-square.svg +0 -87
- egse/icons/switch-on.svg +0 -61
- egse/icons/temperature-control.svg +0 -44
- egse/icons/th_ui_logo.svg +0 -1
- egse/icons/unplugged.svg +0 -23
- egse/icons/unvalid.png +0 -0
- egse/icons/user-interface.svg +0 -1
- egse/icons/vacuum.svg +0 -1
- egse/icons/valid.png +0 -0
- egse/icons/zoom-to-pixel-dark.svg +0 -64
- egse/icons/zoom-to-pixel-white.svg +0 -36
- egse/images/big-rotation-stage.png +0 -0
- egse/images/connected-100.png +0 -0
- egse/images/cross.svg +0 -6
- egse/images/disconnected-100.png +0 -0
- egse/images/gui-icon.png +0 -0
- egse/images/home.svg +0 -6
- egse/images/info-icon.png +0 -0
- egse/images/led-black.svg +0 -89
- egse/images/led-green.svg +0 -85
- egse/images/led-orange.svg +0 -85
- egse/images/led-red.svg +0 -85
- egse/images/load-icon.png +0 -0
- egse/images/load-setup.png +0 -0
- egse/images/load.png +0 -0
- egse/images/pause.png +0 -0
- egse/images/play-button.svg +0 -8
- egse/images/play.png +0 -0
- egse/images/process-status.png +0 -0
- egse/images/restart.png +0 -0
- egse/images/search.png +0 -0
- egse/images/sma.png +0 -0
- egse/images/start.png +0 -0
- egse/images/stop-button.svg +0 -8
- egse/images/stop.png +0 -0
- egse/images/switch-off.svg +0 -48
- egse/images/switch-on.svg +0 -48
- egse/images/undo.png +0 -0
- egse/images/update-button.svg +0 -11
- egse/imageviewer/exposureselection.py +0 -475
- egse/imageviewer/imageviewer.py +0 -198
- egse/imageviewer/matchfocalplane.py +0 -179
- egse/imageviewer/subfieldposition.py +0 -133
- egse/lampcontrol/__init__.py +0 -4
- egse/lampcontrol/beaglebone/beaglebone.py +0 -178
- egse/lampcontrol/beaglebone/beaglebone.yaml +0 -62
- egse/lampcontrol/beaglebone/beaglebone_cs.py +0 -106
- egse/lampcontrol/beaglebone/beaglebone_devif.py +0 -150
- egse/lampcontrol/beaglebone/beaglebone_protocol.py +0 -73
- egse/lampcontrol/energetiq/__init__.py +0 -22
- egse/lampcontrol/energetiq/eq99.yaml +0 -98
- egse/lampcontrol/energetiq/lampEQ99.py +0 -283
- egse/lampcontrol/energetiq/lampEQ99_cs.py +0 -128
- egse/lampcontrol/energetiq/lampEQ99_devif.py +0 -158
- egse/lampcontrol/energetiq/lampEQ99_encode_decode_errors.py +0 -73
- egse/lampcontrol/energetiq/lampEQ99_protocol.py +0 -71
- egse/lampcontrol/energetiq/lampEQ99_ui.py +0 -465
- egse/lib/CentOS-7/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/CentOS-8/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/CentOS-8/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/Debian/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/Debian/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/Debian/libetherspacelink_v35_21.dylib +0 -0
- egse/lib/Linux/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/Linux/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/Ubuntu-20/ESL-RMAP_v34_86.dylib +0 -0
- egse/lib/Ubuntu-20/EtherSpaceLink_v34_86.dylib +0 -0
- egse/lib/gssw/python3-gssw_2.2.3+31f63c9f-1_all.deb +0 -0
- egse/lib/ximc/__pycache__/pyximc.cpython-38 2.pyc +0 -0
- egse/lib/ximc/__pycache__/pyximc.cpython-38.pyc +0 -0
- egse/lib/ximc/libximc.framework/Frameworks/libbindy.dylib +0 -0
- egse/lib/ximc/libximc.framework/Frameworks/libxiwrapper.dylib +0 -0
- egse/lib/ximc/libximc.framework/Headers/ximc.h +0 -5510
- egse/lib/ximc/libximc.framework/Resources/Info.plist +0 -42
- egse/lib/ximc/libximc.framework/Resources/keyfile.sqlite +0 -0
- egse/lib/ximc/libximc.framework/libbindy.so +0 -0
- egse/lib/ximc/libximc.framework/libximc +0 -0
- egse/lib/ximc/libximc.framework/libximc.so +0 -0
- egse/lib/ximc/libximc.framework/libximc.so.7.0.0 +0 -0
- egse/lib/ximc/libximc.framework/libxiwrapper.so +0 -0
- egse/lib/ximc/pyximc.py +0 -922
- egse/listener.py +0 -179
- egse/logger/__init__.py +0 -243
- egse/logger/log_cs.py +0 -321
- egse/metrics.py +0 -102
- egse/mixin.py +0 -464
- egse/monitoring.py +0 -95
- egse/ni/alarms/__init__.py +0 -26
- egse/ni/alarms/cdaq9375.py +0 -300
- egse/ni/alarms/cdaq9375.yaml +0 -89
- egse/ni/alarms/cdaq9375_cs.py +0 -130
- egse/ni/alarms/cdaq9375_devif.py +0 -183
- egse/ni/alarms/cdaq9375_protocol.py +0 -48
- egse/obs_inspection.py +0 -165
- egse/observer.py +0 -41
- egse/obsid.py +0 -163
- egse/powermeter/__init__.py +0 -0
- egse/powermeter/ni/__init__.py +0 -38
- egse/powermeter/ni/cdaq9184.py +0 -224
- egse/powermeter/ni/cdaq9184.yaml +0 -73
- egse/powermeter/ni/cdaq9184_cs.py +0 -130
- egse/powermeter/ni/cdaq9184_devif.py +0 -201
- egse/powermeter/ni/cdaq9184_protocol.py +0 -48
- egse/powermeter/ni/cdaq9184_ui.py +0 -544
- egse/powermeter/thorlabs/__init__.py +0 -25
- egse/powermeter/thorlabs/pm100a.py +0 -380
- egse/powermeter/thorlabs/pm100a.yaml +0 -132
- egse/powermeter/thorlabs/pm100a_cs.py +0 -136
- egse/powermeter/thorlabs/pm100a_devif.py +0 -127
- egse/powermeter/thorlabs/pm100a_protocol.py +0 -80
- egse/powermeter/thorlabs/pm100a_ui.py +0 -725
- egse/process.py +0 -451
- egse/procman/__init__.py +0 -834
- egse/procman/cannot_start_process_popup.py +0 -43
- egse/procman/procman.yaml +0 -49
- egse/procman/procman_cs.py +0 -201
- egse/procman/procman_ui.py +0 -2081
- egse/protocol.py +0 -605
- egse/proxy.py +0 -531
- egse/randomwalk.py +0 -140
- egse/reg.py +0 -585
- egse/reload.py +0 -122
- egse/reprocess.py +0 -693
- egse/resource.py +0 -333
- egse/rmap.py +0 -406
- egse/rst.py +0 -135
- egse/search.py +0 -182
- egse/serialdevice.py +0 -190
- egse/services.py +0 -247
- egse/services.yaml +0 -68
- egse/settings.py +0 -379
- egse/settings.yaml +0 -980
- egse/setup.py +0 -1181
- egse/shutter/__init__.py +0 -0
- egse/shutter/thorlabs/__init__.py +0 -19
- egse/shutter/thorlabs/ksc101.py +0 -205
- egse/shutter/thorlabs/ksc101.yaml +0 -105
- egse/shutter/thorlabs/ksc101_cs.py +0 -136
- egse/shutter/thorlabs/ksc101_devif.py +0 -201
- egse/shutter/thorlabs/ksc101_protocol.py +0 -71
- egse/shutter/thorlabs/ksc101_ui.py +0 -548
- egse/shutter/thorlabs/sc10.py +0 -82
- egse/shutter/thorlabs/sc10.yaml +0 -52
- egse/shutter/thorlabs/sc10_controller.py +0 -81
- egse/shutter/thorlabs/sc10_cs.py +0 -108
- egse/shutter/thorlabs/sc10_interface.py +0 -25
- egse/shutter/thorlabs/sc10_simulator.py +0 -30
- egse/simulator.py +0 -41
- egse/slack.py +0 -61
- egse/socketdevice.py +0 -218
- egse/sockets.py +0 -218
- egse/spw.py +0 -1401
- egse/stages/__init__.py +0 -12
- egse/stages/aerotech/ensemble.py +0 -245
- egse/stages/aerotech/ensemble.yaml +0 -205
- egse/stages/aerotech/ensemble_controller.py +0 -275
- egse/stages/aerotech/ensemble_cs.py +0 -110
- egse/stages/aerotech/ensemble_interface.py +0 -132
- egse/stages/aerotech/ensemble_parameters.py +0 -433
- egse/stages/aerotech/ensemble_simulator.py +0 -27
- egse/stages/aerotech/mgse_sim.py +0 -188
- egse/stages/arun/smd3.py +0 -110
- egse/stages/arun/smd3.yaml +0 -68
- egse/stages/arun/smd3_controller.py +0 -470
- egse/stages/arun/smd3_cs.py +0 -112
- egse/stages/arun/smd3_interface.py +0 -53
- egse/stages/arun/smd3_simulator.py +0 -27
- egse/stages/arun/smd3_stop.py +0 -16
- egse/stages/huber/__init__.py +0 -49
- egse/stages/huber/smc9300.py +0 -920
- egse/stages/huber/smc9300.yaml +0 -63
- egse/stages/huber/smc9300_cs.py +0 -178
- egse/stages/huber/smc9300_devif.py +0 -345
- egse/stages/huber/smc9300_protocol.py +0 -113
- egse/stages/huber/smc9300_sim.py +0 -547
- egse/stages/huber/smc9300_ui.py +0 -973
- egse/state.py +0 -173
- egse/statemachine.py +0 -274
- egse/storage/__init__.py +0 -1067
- egse/storage/persistence.py +0 -2295
- egse/storage/storage.yaml +0 -79
- egse/storage/storage_cs.py +0 -231
- egse/styles/dark.qss +0 -343
- egse/styles/default.qss +0 -48
- egse/synoptics/__init__.py +0 -417
- egse/synoptics/syn.yaml +0 -9
- egse/synoptics/syn_cs.py +0 -195
- egse/system.py +0 -1611
- egse/tcs/__init__.py +0 -14
- egse/tcs/tcs.py +0 -879
- egse/tcs/tcs.yaml +0 -14
- egse/tcs/tcs_cs.py +0 -202
- egse/tcs/tcs_devif.py +0 -292
- egse/tcs/tcs_protocol.py +0 -180
- egse/tcs/tcs_sim.py +0 -177
- egse/tcs/tcs_ui.py +0 -543
- egse/tdms.py +0 -171
- egse/tempcontrol/__init__.py +0 -23
- egse/tempcontrol/agilent/agilent34970.py +0 -109
- egse/tempcontrol/agilent/agilent34970.yaml +0 -44
- egse/tempcontrol/agilent/agilent34970_cs.py +0 -114
- egse/tempcontrol/agilent/agilent34970_devif.py +0 -182
- egse/tempcontrol/agilent/agilent34970_protocol.py +0 -96
- egse/tempcontrol/agilent/agilent34972.py +0 -111
- egse/tempcontrol/agilent/agilent34972.yaml +0 -44
- egse/tempcontrol/agilent/agilent34972_cs.py +0 -115
- egse/tempcontrol/agilent/agilent34972_devif.py +0 -189
- egse/tempcontrol/agilent/agilent34972_protocol.py +0 -98
- egse/tempcontrol/beaglebone/beaglebone.py +0 -341
- egse/tempcontrol/beaglebone/beaglebone.yaml +0 -110
- egse/tempcontrol/beaglebone/beaglebone_cs.py +0 -117
- egse/tempcontrol/beaglebone/beaglebone_protocol.py +0 -134
- egse/tempcontrol/beaglebone/beaglebone_ui.py +0 -674
- egse/tempcontrol/digalox/digalox.py +0 -115
- egse/tempcontrol/digalox/digalox.yaml +0 -36
- egse/tempcontrol/digalox/digalox_cs.py +0 -108
- egse/tempcontrol/digalox/digalox_protocol.py +0 -56
- egse/tempcontrol/keithley/__init__.py +0 -33
- egse/tempcontrol/keithley/daq6510.py +0 -662
- egse/tempcontrol/keithley/daq6510.yaml +0 -105
- egse/tempcontrol/keithley/daq6510_cs.py +0 -163
- egse/tempcontrol/keithley/daq6510_devif.py +0 -343
- egse/tempcontrol/keithley/daq6510_protocol.py +0 -79
- egse/tempcontrol/keithley/daq6510_sim.py +0 -186
- egse/tempcontrol/lakeshore/__init__.py +0 -33
- egse/tempcontrol/lakeshore/lsci.py +0 -361
- egse/tempcontrol/lakeshore/lsci.yaml +0 -162
- egse/tempcontrol/lakeshore/lsci_cs.py +0 -174
- egse/tempcontrol/lakeshore/lsci_devif.py +0 -292
- egse/tempcontrol/lakeshore/lsci_protocol.py +0 -76
- egse/tempcontrol/lakeshore/lsci_ui.py +0 -387
- egse/tempcontrol/ni/__init__.py +0 -0
- egse/tempcontrol/spid/spid.py +0 -109
- egse/tempcontrol/spid/spid.yaml +0 -81
- egse/tempcontrol/spid/spid_controller.py +0 -279
- egse/tempcontrol/spid/spid_cs.py +0 -136
- egse/tempcontrol/spid/spid_protocol.py +0 -107
- egse/tempcontrol/spid/spid_ui.py +0 -723
- egse/tempcontrol/srs/__init__.py +0 -22
- egse/tempcontrol/srs/ptc10.py +0 -867
- egse/tempcontrol/srs/ptc10.yaml +0 -227
- egse/tempcontrol/srs/ptc10_cs.py +0 -128
- egse/tempcontrol/srs/ptc10_devif.py +0 -116
- egse/tempcontrol/srs/ptc10_protocol.py +0 -39
- egse/tempcontrol/srs/ptc10_ui.py +0 -906
- egse/ups/apc/apc.py +0 -236
- egse/ups/apc/apc.yaml +0 -45
- egse/ups/apc/apc_cs.py +0 -101
- egse/ups/apc/apc_protocol.py +0 -125
- egse/user.yaml +0 -7
- egse/vacuum/beaglebone/beaglebone.py +0 -149
- egse/vacuum/beaglebone/beaglebone.yaml +0 -44
- egse/vacuum/beaglebone/beaglebone_cs.py +0 -108
- egse/vacuum/beaglebone/beaglebone_devif.py +0 -159
- egse/vacuum/beaglebone/beaglebone_protocol.py +0 -192
- egse/vacuum/beaglebone/beaglebone_ui.py +0 -638
- egse/vacuum/instrutech/igm402.py +0 -91
- egse/vacuum/instrutech/igm402.yaml +0 -90
- egse/vacuum/instrutech/igm402_controller.py +0 -124
- egse/vacuum/instrutech/igm402_cs.py +0 -108
- egse/vacuum/instrutech/igm402_interface.py +0 -49
- egse/vacuum/instrutech/igm402_simulator.py +0 -36
- egse/vacuum/keller/kellerBus.py +0 -256
- egse/vacuum/keller/leo3.py +0 -100
- egse/vacuum/keller/leo3.yaml +0 -38
- egse/vacuum/keller/leo3_controller.py +0 -81
- egse/vacuum/keller/leo3_cs.py +0 -101
- egse/vacuum/keller/leo3_interface.py +0 -33
- egse/vacuum/mks/evision.py +0 -86
- egse/vacuum/mks/evision.yaml +0 -75
- egse/vacuum/mks/evision_cs.py +0 -101
- egse/vacuum/mks/evision_devif.py +0 -313
- egse/vacuum/mks/evision_interface.py +0 -60
- egse/vacuum/mks/evision_simulator.py +0 -24
- egse/vacuum/mks/evision_ui.py +0 -701
- egse/vacuum/pfeiffer/acp40.py +0 -87
- egse/vacuum/pfeiffer/acp40.yaml +0 -60
- egse/vacuum/pfeiffer/acp40_controller.py +0 -117
- egse/vacuum/pfeiffer/acp40_cs.py +0 -109
- egse/vacuum/pfeiffer/acp40_interface.py +0 -40
- egse/vacuum/pfeiffer/acp40_simulator.py +0 -37
- egse/vacuum/pfeiffer/tc400.py +0 -87
- egse/vacuum/pfeiffer/tc400.yaml +0 -83
- egse/vacuum/pfeiffer/tc400_controller.py +0 -136
- egse/vacuum/pfeiffer/tc400_cs.py +0 -109
- egse/vacuum/pfeiffer/tc400_interface.py +0 -70
- egse/vacuum/pfeiffer/tc400_simulator.py +0 -35
- egse/vacuum/pfeiffer/tpg261.py +0 -80
- egse/vacuum/pfeiffer/tpg261.yaml +0 -66
- egse/vacuum/pfeiffer/tpg261_controller.py +0 -150
- egse/vacuum/pfeiffer/tpg261_cs.py +0 -109
- egse/vacuum/pfeiffer/tpg261_interface.py +0 -59
- egse/vacuum/pfeiffer/tpg261_simulator.py +0 -23
- egse/version.py +0 -174
- egse/visitedpositions.py +0 -398
- egse/windowing.py +0 -213
- egse/zmq/__init__.py +0 -28
- egse/zmq/spw.py +0 -160
- egse/zmq_ser.py +0 -41
- scripts/alerts/cold.yaml +0 -278
- scripts/alerts/example_alerts.yaml +0 -54
- scripts/alerts/transition.yaml +0 -14
- scripts/alerts/warm.yaml +0 -49
- scripts/analyse_n_fee_hk_data.py +0 -52
- scripts/check_hdf5_files.py +0 -192
- scripts/check_register_sync.py +0 -47
- scripts/check_tcs_calib_coef.py +0 -90
- scripts/correct_ccd_cold_temperature_cal.py +0 -157
- scripts/create_hdf5_report.py +0 -293
- scripts/csl_model.py +0 -420
- scripts/csl_restore_setup.py +0 -229
- scripts/export-grafana-dashboards.py +0 -49
- scripts/fdir/cs_recovery/fdir_cs_recovery.py +0 -54
- scripts/fdir/fdir_table.yaml +0 -70
- scripts/fdir/fdir_test_recovery.py +0 -10
- scripts/fdir/hw_recovery/fdir_agilent_hw_recovery.py +0 -73
- scripts/fdir/limit_recovery/fdir_agilent_limit.py +0 -61
- scripts/fdir/limit_recovery/fdir_bb_heater_limit.py +0 -59
- scripts/fdir/limit_recovery/fdir_ensemble_limit.py +0 -33
- scripts/fdir/limit_recovery/fdir_pressure_limit_recovery.py +0 -71
- scripts/fix_csv.py +0 -80
- scripts/ias/correct_ccd_temp_cal_elfique.py +0 -43
- scripts/ias/correct_ccd_temp_cal_floreffe.py +0 -43
- scripts/ias/correct_trp_swap_achel.py +0 -199
- scripts/inta/correct_ccd_temp_cal_duvel.py +0 -43
- scripts/inta/correct_ccd_temp_cal_gueuze.py +0 -43
- scripts/n_fee_supply_voltage_calculation.py +0 -92
- scripts/playground.py +0 -30
- scripts/print_hdf5_hk_data.py +0 -68
- scripts/print_register_map.py +0 -43
- scripts/remove_lines_between_matches.py +0 -188
- scripts/sron/commanding/control_heaters.py +0 -44
- scripts/sron/commanding/pumpdown.py +0 -46
- scripts/sron/commanding/set_pid_setpoint.py +0 -19
- scripts/sron/commanding/shutdown_bbb_heaters.py +0 -10
- scripts/sron/commanding/shutdown_pumps.py +0 -33
- scripts/sron/correct_mgse_coordinates_brigand_chimay.py +0 -272
- scripts/sron/correct_trp_swap_brigand.py +0 -204
- scripts/sron/gimbal_conversions.py +0 -75
- scripts/sron/tm_gen/tm_gen_agilent.py +0 -37
- scripts/sron/tm_gen/tm_gen_heaters.py +0 -4
- scripts/sron/tm_gen/tm_gen_spid.py +0 -13
- scripts/update_operational_cgse.py +0 -268
- scripts/update_operational_cgse_old.py +0 -273
egse/coordinates/refmodel.py
DELETED
|
@@ -1,737 +0,0 @@
|
|
|
1
|
-
"""
|
|
2
|
-
The Reference Frame Model is a self-consistent graph of reference frames that are connected by
|
|
3
|
-
reference and/or by explicit links.
|
|
4
|
-
|
|
5
|
-
The ReferenceFrameModel class will keep the model consistent and self-contained.
|
|
6
|
-
|
|
7
|
-
Functionality:
|
|
8
|
-
|
|
9
|
-
* Initialization from a list of ReferenceFrames.
|
|
10
|
-
* Serialization into a dictionary that can be saved into a YAML file.
|
|
11
|
-
* Manipulation of the model
|
|
12
|
-
* Move a reference frame (translation, rotation) with respect to another reference frame
|
|
13
|
-
* Absolute movement, center of rotation either local or other
|
|
14
|
-
* Relative Movement, center of rotation either local or other
|
|
15
|
-
* Move a reference frame (translation, rotation) with respect to itself
|
|
16
|
-
* Absolute movement
|
|
17
|
-
* Relative Movement
|
|
18
|
-
* Change the definition of a reference frame in the model
|
|
19
|
-
* Inspection of the model
|
|
20
|
-
* Get the definition of a reference frame (what should this be? only translation & rotation?)
|
|
21
|
-
* Get position of a reference frame
|
|
22
|
-
* Get the position of a point in a 'target' reference frame, but defined in a 'source'
|
|
23
|
-
reference frame
|
|
24
|
-
* Get a string representation of the model.
|
|
25
|
-
* Find inconsistencies in the model
|
|
26
|
-
* What other information do we need?
|
|
27
|
-
* find the path from one reference frame to another reference frame?
|
|
28
|
-
* find all reference frames that are affected by a movement or redefinition of a
|
|
29
|
-
reference frame?
|
|
30
|
-
* ...
|
|
31
|
-
|
|
32
|
-
"""
|
|
33
|
-
import logging
|
|
34
|
-
from typing import Dict
|
|
35
|
-
from typing import List
|
|
36
|
-
from typing import Union
|
|
37
|
-
|
|
38
|
-
import matplotlib.pyplot as plt
|
|
39
|
-
import numpy as np
|
|
40
|
-
from matplotlib.transforms import ScaledTranslation
|
|
41
|
-
from mpl_toolkits.mplot3d import Axes3D
|
|
42
|
-
|
|
43
|
-
import egse.coordinates.transform3d_addon as t3add
|
|
44
|
-
from egse.coordinates import dict_to_ref_model
|
|
45
|
-
from egse.coordinates import ref_model_to_dict
|
|
46
|
-
from egse.coordinates.referenceFrame import ReferenceFrame
|
|
47
|
-
from egse.setup import NavigableDict
|
|
48
|
-
|
|
49
|
-
LOGGER = logging.getLogger(__name__)
|
|
50
|
-
|
|
51
|
-
# TODO : HANDLING "moving_in_ref" (obusr) in move_absolute_ext and move_relative_ext
|
|
52
|
-
# should it be added to the model temporarily ??
|
|
53
|
-
# after the move : remove the link and delete that frame
|
|
54
|
-
#
|
|
55
|
-
# Priority 1
|
|
56
|
-
# * access methods to allow for things like is_avoidance_ok(hexsim.cs_user, hexsim.cs_object,
|
|
57
|
-
# setup=setup, verbose=True)
|
|
58
|
-
#
|
|
59
|
-
# Priority 2
|
|
60
|
-
# * Move name handling from ReferenceFrame to here (if necessary)
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
class ReferenceFrameModel:
|
|
64
|
-
"""
|
|
65
|
-
A ReferenceFrameModel is a collection of reference frames that are linked to each other to
|
|
66
|
-
form a Graph.
|
|
67
|
-
"""
|
|
68
|
-
|
|
69
|
-
_ROT_CONFIG_DEFAULT = "sxyz"
|
|
70
|
-
_ACTIVE_DEFAULT = True
|
|
71
|
-
_DEGREES_DEFAULT = True
|
|
72
|
-
|
|
73
|
-
def __init__(
|
|
74
|
-
self,
|
|
75
|
-
model: Union[Dict, List[ReferenceFrame]] = None,
|
|
76
|
-
rot_config: str = _ROT_CONFIG_DEFAULT,
|
|
77
|
-
use_degrees: bool = _DEGREES_DEFAULT,
|
|
78
|
-
use_active_movements: bool = _ACTIVE_DEFAULT,
|
|
79
|
-
):
|
|
80
|
-
"""
|
|
81
|
-
When the model_dict is empty or None, a new model is created with a master reference frame.
|
|
82
|
-
|
|
83
|
-
Args:
|
|
84
|
-
model: a list or a dictionary of reference frames that make up the model
|
|
85
|
-
use_degrees: use degrees throughout this model unless explicitly specified in the
|
|
86
|
-
function call.
|
|
87
|
-
"""
|
|
88
|
-
self._use_degrees = use_degrees
|
|
89
|
-
self._use_active_movements = use_active_movements
|
|
90
|
-
self._rot_config = rot_config
|
|
91
|
-
|
|
92
|
-
# Keep a dictionary with all reference frames that are part of the model. The keys shall
|
|
93
|
-
# be the name of the reference frame. When the model passed is empty, create only a
|
|
94
|
-
# master reference frame.
|
|
95
|
-
|
|
96
|
-
if isinstance(model, (dict, list)):
|
|
97
|
-
self._model = self.deserialize(model)
|
|
98
|
-
else:
|
|
99
|
-
self._model = NavigableDict({})
|
|
100
|
-
|
|
101
|
-
def __str__(self):
|
|
102
|
-
return self._model.pretty_str()
|
|
103
|
-
|
|
104
|
-
def __len__(self):
|
|
105
|
-
return len(self._model)
|
|
106
|
-
|
|
107
|
-
def __contains__(self, item):
|
|
108
|
-
return item in self._model
|
|
109
|
-
|
|
110
|
-
def __iter__(self):
|
|
111
|
-
return iter(self._model.values())
|
|
112
|
-
|
|
113
|
-
def summary(self):
|
|
114
|
-
result = f"Nb of frames: {len(self)}\n"
|
|
115
|
-
|
|
116
|
-
for ref in self:
|
|
117
|
-
result += (
|
|
118
|
-
f"{ref.name:>10}[{ref.ref.name}]" f" --- {[link.name for link in ref.linkedTo]}\n"
|
|
119
|
-
)
|
|
120
|
-
return result
|
|
121
|
-
|
|
122
|
-
@staticmethod
|
|
123
|
-
def deserialize(model_dict: dict) -> NavigableDict:
|
|
124
|
-
"""
|
|
125
|
-
Deserialize means you take a serialized representation of a reference frames model and
|
|
126
|
-
turn it into a dictionary containing all the reference frames with their links and
|
|
127
|
-
references.
|
|
128
|
-
|
|
129
|
-
Args:
|
|
130
|
-
model_dict: a dictionary of serialized reference frames
|
|
131
|
-
|
|
132
|
-
Returns:
|
|
133
|
-
A dictionary of ReferenceFrames that make up a model.
|
|
134
|
-
|
|
135
|
-
"""
|
|
136
|
-
return dict_to_ref_model(model_dict)
|
|
137
|
-
|
|
138
|
-
def serialize(self) -> NavigableDict:
|
|
139
|
-
"""
|
|
140
|
-
Serialize the model by serializing each of the reference frames into an object that can
|
|
141
|
-
easily be saved to a YAML or a JSON file. Return a dictionary with the serialized frames.
|
|
142
|
-
|
|
143
|
-
Returns:
|
|
144
|
-
A dictionary with all the reference framed serialized.
|
|
145
|
-
"""
|
|
146
|
-
|
|
147
|
-
return ref_model_to_dict(self._model)
|
|
148
|
-
|
|
149
|
-
def add_master_frame(self):
|
|
150
|
-
|
|
151
|
-
# TODO: First check if there is not already a Master frame in the model
|
|
152
|
-
|
|
153
|
-
self._model["Master"] = ReferenceFrame.createMaster()
|
|
154
|
-
|
|
155
|
-
def add_frame(
|
|
156
|
-
self,
|
|
157
|
-
name: str,
|
|
158
|
-
*,
|
|
159
|
-
translation: List[float] = None,
|
|
160
|
-
rotation: List[float] = None,
|
|
161
|
-
transformation=None,
|
|
162
|
-
ref: str,
|
|
163
|
-
):
|
|
164
|
-
"""
|
|
165
|
-
Add a reference frame to the model.
|
|
166
|
-
|
|
167
|
-
.. note::
|
|
168
|
-
Only the `name` parameter can be positional, all the other arguments (translation,
|
|
169
|
-
rotation, transformation, and ref) must be given as keyword arguments.
|
|
170
|
-
|
|
171
|
-
Args:
|
|
172
|
-
name: the name for the reference frame. This name is it's identifier within the model.
|
|
173
|
-
translation: the translation vector
|
|
174
|
-
rotation: the rotation vector
|
|
175
|
-
transformation: the transformation vector, if `transformation` is given,
|
|
176
|
-
both `translation` and `rotation` are ignored.
|
|
177
|
-
ref: the reference frame that is a reference for 'name', i.e. 'name' is defined with
|
|
178
|
-
respect to 'ref'.
|
|
179
|
-
"""
|
|
180
|
-
|
|
181
|
-
if name in self._model:
|
|
182
|
-
raise KeyError("A reference frame with the name '{name} already exists in the model.")
|
|
183
|
-
|
|
184
|
-
ref = self._model[ref]
|
|
185
|
-
|
|
186
|
-
if transformation is not None:
|
|
187
|
-
self._model[name] = ReferenceFrame(
|
|
188
|
-
transformation, ref=ref, name=name, rot_config=self._rot_config,
|
|
189
|
-
)
|
|
190
|
-
else:
|
|
191
|
-
self._model[name] = ReferenceFrame.fromTranslationRotation(
|
|
192
|
-
translation,
|
|
193
|
-
rotation,
|
|
194
|
-
name=name,
|
|
195
|
-
ref=ref,
|
|
196
|
-
rot_config=self._rot_config,
|
|
197
|
-
degrees=self._use_degrees,
|
|
198
|
-
active=self._use_active_movements,
|
|
199
|
-
)
|
|
200
|
-
|
|
201
|
-
def remove_frame(self, name: str):
|
|
202
|
-
"""
|
|
203
|
-
Deletes the reference frame from the model. If the reference frame doesn't exist in the
|
|
204
|
-
model, a warning message is logged.
|
|
205
|
-
|
|
206
|
-
Args:
|
|
207
|
-
name: the name of the reference frame to remove
|
|
208
|
-
"""
|
|
209
|
-
|
|
210
|
-
if name in self._model:
|
|
211
|
-
|
|
212
|
-
frame: ReferenceFrame = self._model[name]
|
|
213
|
-
|
|
214
|
-
# We need to get the links out in a list because the frame.removeLink() method deletes
|
|
215
|
-
# frames from the linkedTo dictionary and that is not allowed in a for loop.
|
|
216
|
-
|
|
217
|
-
links = [linked_frame for linked_frame in frame.linkedTo]
|
|
218
|
-
for link in links:
|
|
219
|
-
frame.removeLink(link)
|
|
220
|
-
|
|
221
|
-
del self._model[name]
|
|
222
|
-
else:
|
|
223
|
-
LOGGER.warning(
|
|
224
|
-
f"You tried to remove a non-existing reference frame '{name}' from the model."
|
|
225
|
-
)
|
|
226
|
-
|
|
227
|
-
def get_frame(self, name: str) -> ReferenceFrame:
|
|
228
|
-
"""
|
|
229
|
-
Returns a frame with the given name.
|
|
230
|
-
|
|
231
|
-
.. note::
|
|
232
|
-
Use this function with care since this breaks encapsulation and may lead to an
|
|
233
|
-
inconsistent model when the frame is changed outside of the scope of the reference
|
|
234
|
-
model.
|
|
235
|
-
|
|
236
|
-
Args:
|
|
237
|
-
name: the name of the requested reference frame
|
|
238
|
-
|
|
239
|
-
Returns:
|
|
240
|
-
The reference frame with the given name.
|
|
241
|
-
"""
|
|
242
|
-
return self._model[name]
|
|
243
|
-
|
|
244
|
-
def add_link(self, source: str, target: str):
|
|
245
|
-
"""
|
|
246
|
-
Add a link between two reference frames. All links are bi-directional.
|
|
247
|
-
|
|
248
|
-
Args:
|
|
249
|
-
source: the source reference frame
|
|
250
|
-
target: the target reference frame
|
|
251
|
-
|
|
252
|
-
"""
|
|
253
|
-
if source not in self._model:
|
|
254
|
-
raise KeyError(f"There is no reference frame with the name '{source} in the model.")
|
|
255
|
-
if target not in self._model:
|
|
256
|
-
raise KeyError(f"There is no reference frame with the name '{target} in the model.")
|
|
257
|
-
|
|
258
|
-
source = self._model[source]
|
|
259
|
-
target = self._model[target]
|
|
260
|
-
|
|
261
|
-
source.addLink(target)
|
|
262
|
-
|
|
263
|
-
def remove_link(self, source: str, target: str):
|
|
264
|
-
"""
|
|
265
|
-
Remove a link between two reference frames. All links are bi-directional and this method
|
|
266
|
-
removes both links.
|
|
267
|
-
|
|
268
|
-
Args:
|
|
269
|
-
source: the source reference frame
|
|
270
|
-
target: the target reference frame
|
|
271
|
-
|
|
272
|
-
"""
|
|
273
|
-
if source not in self._model:
|
|
274
|
-
raise KeyError(f"There is no reference frame with the name '{source} in the model.")
|
|
275
|
-
if target not in self._model:
|
|
276
|
-
raise KeyError(f"There is no reference frame with the name '{target} in the model.")
|
|
277
|
-
|
|
278
|
-
source = self._model[source]
|
|
279
|
-
target = self._model[target]
|
|
280
|
-
|
|
281
|
-
source.removeLink(target)
|
|
282
|
-
|
|
283
|
-
def move_absolute_self(self, frame: str, translation, rotation, degrees=_DEGREES_DEFAULT):
|
|
284
|
-
"""
|
|
285
|
-
Apply an absolute movement to the given ReferenceFrame such that it occupies a given
|
|
286
|
-
absolute position wrt "frame_ref" after the movement.
|
|
287
|
-
|
|
288
|
-
NO Hexapod equivalent.
|
|
289
|
-
|
|
290
|
-
Args:
|
|
291
|
-
frame (str): the name of the reference frame to move
|
|
292
|
-
"""
|
|
293
|
-
|
|
294
|
-
frame = self._model[frame]
|
|
295
|
-
frame.setTranslationRotation(
|
|
296
|
-
translation,
|
|
297
|
-
rotation,
|
|
298
|
-
rot_config=self._rot_config,
|
|
299
|
-
active=self._use_active_movements,
|
|
300
|
-
degrees=degrees,
|
|
301
|
-
preserveLinks=True,
|
|
302
|
-
)
|
|
303
|
-
|
|
304
|
-
def move_absolute_in_other(
|
|
305
|
-
self, frame: str, other: str, translation, rotation, degrees=_DEGREES_DEFAULT
|
|
306
|
-
):
|
|
307
|
-
"""
|
|
308
|
-
Apply an absolute movement to the ReferenceFrame "frame", such that it occupies
|
|
309
|
-
a given absolute position with respect to "other" after the movement.
|
|
310
|
-
|
|
311
|
-
EQUIVALENT PunaSimulator.move_absolute, setting hexobj wrt hexusr.
|
|
312
|
-
|
|
313
|
-
Args:
|
|
314
|
-
frame (str): the name (id) of the reference frame to move
|
|
315
|
-
other (str): the name (id) of the reference frame
|
|
316
|
-
"""
|
|
317
|
-
|
|
318
|
-
# TODO:
|
|
319
|
-
# There can not be a link between frame and other, not direct and not indirect.
|
|
320
|
-
# So, with A-link-B-link-C-link-D, we can not do move_absolute_in_other('A', 'D', ...)
|
|
321
|
-
|
|
322
|
-
frame = self._model[frame]
|
|
323
|
-
other = self._model[other]
|
|
324
|
-
|
|
325
|
-
transformation = other.getActiveTransformationTo(frame)
|
|
326
|
-
|
|
327
|
-
moving_in_other = ReferenceFrame(
|
|
328
|
-
transformation, rot_config=self._rot_config, ref=other, name="moving_in_other"
|
|
329
|
-
)
|
|
330
|
-
|
|
331
|
-
moving_in_other.addLink(frame)
|
|
332
|
-
|
|
333
|
-
moving_in_other.setTranslationRotation(
|
|
334
|
-
translation,
|
|
335
|
-
rotation,
|
|
336
|
-
rot_config=self._rot_config,
|
|
337
|
-
active=self._use_active_movements,
|
|
338
|
-
degrees=degrees,
|
|
339
|
-
preserveLinks=True,
|
|
340
|
-
)
|
|
341
|
-
|
|
342
|
-
moving_in_other.removeLink(frame)
|
|
343
|
-
|
|
344
|
-
del moving_in_other
|
|
345
|
-
|
|
346
|
-
def move_relative_self(self, frame: str, translation, rotation, degrees=_DEGREES_DEFAULT):
|
|
347
|
-
"""
|
|
348
|
-
Apply a relative movement to the given ReferenceFrame assuming the movement is expressed
|
|
349
|
-
in that same frame.
|
|
350
|
-
|
|
351
|
-
EQUIVALENT PunaSimulator.move_relative_object
|
|
352
|
-
|
|
353
|
-
Args:
|
|
354
|
-
frame (str): the name of the reference frame to move
|
|
355
|
-
"""
|
|
356
|
-
|
|
357
|
-
frame = self._model[frame]
|
|
358
|
-
frame.applyTranslationRotation(
|
|
359
|
-
translation,
|
|
360
|
-
rotation,
|
|
361
|
-
rot_config=self._rot_config,
|
|
362
|
-
active=self._use_active_movements,
|
|
363
|
-
degrees=degrees,
|
|
364
|
-
preserveLinks=True,
|
|
365
|
-
)
|
|
366
|
-
|
|
367
|
-
def move_relative_other(
|
|
368
|
-
self, frame: str, other: str, translation, rotation, degrees=_DEGREES_DEFAULT
|
|
369
|
-
):
|
|
370
|
-
"""
|
|
371
|
-
Apply a relative movement to the ReferenceFrame "frame". The movement is expressed wrt
|
|
372
|
-
the axes of another frame, "other".
|
|
373
|
-
|
|
374
|
-
The center of rotation is the origin of the reference frame 'other'.
|
|
375
|
-
|
|
376
|
-
NO Hexapod equivalent.
|
|
377
|
-
|
|
378
|
-
Args:
|
|
379
|
-
frame (str): the name (id) of the reference frame to move
|
|
380
|
-
other (str): the name (id) of the reference frame
|
|
381
|
-
"""
|
|
382
|
-
|
|
383
|
-
# TODO:
|
|
384
|
-
# There can not be a link between frame and other, not direct and not indirect.
|
|
385
|
-
# So, with A-link-B-link-C-link-D, we can not do move_absolute_in_other('A', 'D', ...)
|
|
386
|
-
|
|
387
|
-
frame = self._model[frame]
|
|
388
|
-
other = self._model[other]
|
|
389
|
-
|
|
390
|
-
transformation = frame.getActiveTransformationTo(other)
|
|
391
|
-
|
|
392
|
-
moving_in_other = ReferenceFrame(
|
|
393
|
-
transformation, rot_config=self._rot_config, ref=other, name="moving_in_other"
|
|
394
|
-
)
|
|
395
|
-
|
|
396
|
-
moving_in_other.addLink(frame)
|
|
397
|
-
|
|
398
|
-
moving_in_other.applyTranslationRotation(
|
|
399
|
-
translation,
|
|
400
|
-
rotation,
|
|
401
|
-
rot_config=self._rot_config,
|
|
402
|
-
active=self._use_active_movements,
|
|
403
|
-
degrees=degrees,
|
|
404
|
-
preserveLinks=True,
|
|
405
|
-
)
|
|
406
|
-
|
|
407
|
-
moving_in_other.removeLink(frame)
|
|
408
|
-
|
|
409
|
-
del moving_in_other # not need as local scope
|
|
410
|
-
|
|
411
|
-
def move_relative_other_local(
|
|
412
|
-
self, frame: str, other: str, translation, rotation, degrees=_DEGREES_DEFAULT
|
|
413
|
-
):
|
|
414
|
-
"""
|
|
415
|
-
Apply a relative movement to the ReferenceFrame "frame".
|
|
416
|
-
|
|
417
|
-
The movement is expressed wrt the axes of an external frame "other"
|
|
418
|
-
|
|
419
|
-
The center of rotation is the origin of the reference frame 'frame'.
|
|
420
|
-
|
|
421
|
-
EQUIVALENT PunaSimulator.move_relative_user
|
|
422
|
-
|
|
423
|
-
"""
|
|
424
|
-
|
|
425
|
-
# TODO:
|
|
426
|
-
# There can not be a link between frame and other, not direct and not indirect.
|
|
427
|
-
# So, with A-link-B-link-C-link-D, we can not do move_absolute_in_other('A', 'D', ...)
|
|
428
|
-
|
|
429
|
-
frame = self._model[frame]
|
|
430
|
-
other = self._model[other]
|
|
431
|
-
|
|
432
|
-
# Represent the requested movement
|
|
433
|
-
|
|
434
|
-
# Derotation of MOVING --> REF (align frame_moving axes on those of frame_ref)
|
|
435
|
-
|
|
436
|
-
derotation = frame.getActiveTransformationTo(other)
|
|
437
|
-
derotation[:3, 3] = [0, 0, 0]
|
|
438
|
-
|
|
439
|
-
# Reverse rotation (record inverse rotation, to restore the frame in the end)
|
|
440
|
-
|
|
441
|
-
rerotation = derotation.T
|
|
442
|
-
|
|
443
|
-
# Requested translation matrix (already expressed wrt frame_ref)
|
|
444
|
-
|
|
445
|
-
translation_ = np.identity(4)
|
|
446
|
-
translation_[:3, 3] = translation
|
|
447
|
-
|
|
448
|
-
# Requested rotation matrix (already expressed wrt frame_ref)
|
|
449
|
-
|
|
450
|
-
zeros = [0, 0, 0]
|
|
451
|
-
rotation_ = t3add.translationRotationToTransformation(
|
|
452
|
-
zeros, rotation, rot_config=self._rot_config
|
|
453
|
-
)
|
|
454
|
-
|
|
455
|
-
# All translations and rotations are applied to frame_moving
|
|
456
|
-
# ==> a. need for "derotation" before applying the translation
|
|
457
|
-
# b. the center or rotation is always the origin of frame_moving
|
|
458
|
-
# 1. rotate frame_moving to align it with frame_ref (i.e. render their axes parallel)
|
|
459
|
-
# 2. apply the translation in this frame
|
|
460
|
-
# 3. restore the original orientation of the moving frame
|
|
461
|
-
# 4. apply the requested rotation
|
|
462
|
-
|
|
463
|
-
transformation = derotation @ translation_ @ rerotation @ rotation_
|
|
464
|
-
|
|
465
|
-
# Apply the requested movement
|
|
466
|
-
|
|
467
|
-
frame.applyTransformation(transformation, preserveLinks=True)
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
def plot_ref_model(model: ReferenceFrameModel):
|
|
471
|
-
|
|
472
|
-
# figsize is in inch, 6 inch = 15.24 cm, 5 inch = 12.7 cm
|
|
473
|
-
|
|
474
|
-
fig = plt.figure(figsize=(6, 5), dpi=100)
|
|
475
|
-
|
|
476
|
-
ax = fig.add_subplot(1, 1, 1)
|
|
477
|
-
|
|
478
|
-
# Set axes limits in data coordinates
|
|
479
|
-
|
|
480
|
-
ax.set_xlim(-10, 10)
|
|
481
|
-
ax.set_ylim(-10, 10)
|
|
482
|
-
ax.set_xticks(range(-10, 11, 2))
|
|
483
|
-
ax.set_yticks(range(-10, 11, 2))
|
|
484
|
-
ax.grid(True)
|
|
485
|
-
|
|
486
|
-
for frame in model:
|
|
487
|
-
draw_frame(ax, frame, plane="xz")
|
|
488
|
-
|
|
489
|
-
plt.show()
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
def plot_ref_model_3d(model: ReferenceFrameModel):
|
|
493
|
-
|
|
494
|
-
fig = plt.figure(figsize=(8, 8), dpi=100)
|
|
495
|
-
ax = Axes3D(fig)
|
|
496
|
-
# ax.set_box_aspect([1, 1, 1])
|
|
497
|
-
|
|
498
|
-
ax.set_xlabel("x")
|
|
499
|
-
ax.set_ylabel("y")
|
|
500
|
-
ax.set_zlabel("z")
|
|
501
|
-
|
|
502
|
-
def get_fix_mins_maxs(mins, maxs):
|
|
503
|
-
deltas = (maxs - mins) / 12.0
|
|
504
|
-
mins = mins + deltas / 4.0
|
|
505
|
-
maxs = maxs - deltas / 4.0
|
|
506
|
-
|
|
507
|
-
return [mins, maxs]
|
|
508
|
-
|
|
509
|
-
min_ = -8
|
|
510
|
-
max_ = 8
|
|
511
|
-
minmax = get_fix_mins_maxs(min_, max_)
|
|
512
|
-
|
|
513
|
-
# ax.set_xticks(range(min_, max_, 2))
|
|
514
|
-
# ax.set_yticks(range(min_, max_, 2))
|
|
515
|
-
# ax.set_zticks(range(min_, max_, 2))
|
|
516
|
-
|
|
517
|
-
ax.set_xlim(minmax)
|
|
518
|
-
ax.set_ylim(minmax)
|
|
519
|
-
ax.set_zlim(minmax)
|
|
520
|
-
|
|
521
|
-
delta = 0.1
|
|
522
|
-
ax.scatter(
|
|
523
|
-
[min_ + delta, max_ - delta],
|
|
524
|
-
[min_ + delta, max_ - delta],
|
|
525
|
-
[min_ + delta, max_ - delta],
|
|
526
|
-
color="k",
|
|
527
|
-
marker=".",
|
|
528
|
-
)
|
|
529
|
-
|
|
530
|
-
for frame in model:
|
|
531
|
-
draw_frame_3d(ax, frame)
|
|
532
|
-
|
|
533
|
-
# ax.set_proj_type('ortho')
|
|
534
|
-
ax.set_proj_type("persp")
|
|
535
|
-
|
|
536
|
-
set_axes_equal(ax)
|
|
537
|
-
plt.show()
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
# The aspect ration of the plots is not equal by default.
|
|
541
|
-
# This solution was given in SO: https://stackoverflow.com/a/63625222/4609203
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
def set_axes_equal(ax: plt.Axes):
|
|
545
|
-
"""Set 3D plot axes to equal scale.
|
|
546
|
-
|
|
547
|
-
Make axes of 3D plot have equal scale so that spheres appear as
|
|
548
|
-
spheres and cubes as cubes. Required since `ax.axis('equal')`
|
|
549
|
-
and `ax.set_aspect('equal')` don't work on 3D.
|
|
550
|
-
"""
|
|
551
|
-
limits = np.array([ax.get_xlim3d(), ax.get_ylim3d(), ax.get_zlim3d()])
|
|
552
|
-
origin = np.mean(limits, axis=1)
|
|
553
|
-
radius = 0.5 * np.max(np.abs(limits[:, 1] - limits[:, 0]))
|
|
554
|
-
x, y, z = origin
|
|
555
|
-
ax.set_xlim3d([x - radius, x + radius])
|
|
556
|
-
ax.set_ylim3d([y - radius, y + radius])
|
|
557
|
-
ax.set_zlim3d([z - radius, z + radius])
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
def draw_frame_3d(ax: Axes3D, frame: ReferenceFrame, DEFAULT_AXIS_LENGTH=100, **kwargs):
|
|
561
|
-
|
|
562
|
-
master = frame.find_master()
|
|
563
|
-
|
|
564
|
-
f0 = frame.getOrigin()
|
|
565
|
-
fx = frame.getAxis("x", name="fx")
|
|
566
|
-
fy = frame.getAxis("y", name="fy")
|
|
567
|
-
fz = frame.getAxis("z", name="fz")
|
|
568
|
-
f0m = f0.expressIn(master)[:3]
|
|
569
|
-
fxm = fx.expressIn(master)[:3]
|
|
570
|
-
fym = fy.expressIn(master)[:3]
|
|
571
|
-
fzm = fz.expressIn(master)[:3]
|
|
572
|
-
|
|
573
|
-
# Origin of the X,Y and Z vectors (x = the 'x' coordinates of the origin of all 3 vectors)
|
|
574
|
-
# Every vector independently (--> plot in diff. colors)
|
|
575
|
-
x, y, z = np.array([f0m[0]]), np.array([f0m[1]]), np.array([f0m[2]])
|
|
576
|
-
|
|
577
|
-
# Orientation of the X,Y and Z vectors
|
|
578
|
-
vecxx, vecyx, veczx = (
|
|
579
|
-
np.array([fxm[0] - f0m[0]]),
|
|
580
|
-
np.array([fym[0] - f0m[0]]),
|
|
581
|
-
np.array([fzm[0] - f0m[0]]),
|
|
582
|
-
)
|
|
583
|
-
vecxy, vecyy, veczy = (
|
|
584
|
-
np.array([fxm[1] - f0m[1]]),
|
|
585
|
-
np.array([fym[1] - f0m[1]]),
|
|
586
|
-
np.array([fzm[1] - f0m[1]]),
|
|
587
|
-
)
|
|
588
|
-
vecxz, vecyz, veczz = (
|
|
589
|
-
np.array([fxm[2] - f0m[2]]),
|
|
590
|
-
np.array([fym[2] - f0m[2]]),
|
|
591
|
-
np.array([fzm[2] - f0m[2]]),
|
|
592
|
-
)
|
|
593
|
-
|
|
594
|
-
kwargs.setdefault("length", 2)
|
|
595
|
-
kwargs.setdefault("normalize", True)
|
|
596
|
-
|
|
597
|
-
ax.quiver(x, y, z, vecxx, vecxy, vecxz, color="r", **kwargs)
|
|
598
|
-
ax.quiver(x, y, z, vecyx, vecyy, vecyz, color="g", **kwargs)
|
|
599
|
-
ax.quiver(x, y, z, veczx, veczy, veczz, color="b", **kwargs)
|
|
600
|
-
|
|
601
|
-
offset = 0.1
|
|
602
|
-
ax.text(f0m[0] + offset, f0m[1] + offset, f0m[2] + offset, frame.name)
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
def draw_frame(ax, frame: ReferenceFrame, plane="xz", DEFAULT_AXIS_LENGTH=100):
|
|
606
|
-
|
|
607
|
-
fig = ax.get_figure()
|
|
608
|
-
|
|
609
|
-
# FC : Figure coordinates (pixels)
|
|
610
|
-
# NFC : Normalized figure coordinates (0 → 1)
|
|
611
|
-
# DC : Data coordinates (data units)
|
|
612
|
-
# NDC : Normalized data coordinates (0 → 1)
|
|
613
|
-
|
|
614
|
-
dc2fc = ax.transData.transform
|
|
615
|
-
fc2dc = ax.transData.inverted().transform
|
|
616
|
-
fc2ndc = ax.transAxes.inverted().transform
|
|
617
|
-
|
|
618
|
-
def dc2ndc(x): # better than defining and assigning a lambda function
|
|
619
|
-
return fc2ndc(dc2fc(x))
|
|
620
|
-
|
|
621
|
-
x_idx, y_idx = {"xz": (0, 2), "xy": (0, 1), "yz": (1, 2)}[plane]
|
|
622
|
-
|
|
623
|
-
# Draw the origin
|
|
624
|
-
|
|
625
|
-
origin = frame.getOrigin()
|
|
626
|
-
origin_in_master = origin.expressIn(frame.find_master())
|
|
627
|
-
|
|
628
|
-
ax.scatter([origin_in_master[x_idx]], [origin_in_master[y_idx]], color="k")
|
|
629
|
-
|
|
630
|
-
# Draw the axis
|
|
631
|
-
|
|
632
|
-
origin_dc = np.array([[origin_in_master[x_idx], origin_in_master[y_idx]]])
|
|
633
|
-
|
|
634
|
-
point = dc2fc(origin_dc[0])
|
|
635
|
-
point[0] += DEFAULT_AXIS_LENGTH
|
|
636
|
-
target_dc = np.append(origin_dc, [fc2dc(point)], axis=0)
|
|
637
|
-
|
|
638
|
-
ax.plot(target_dc[:, 0], target_dc[:, 1], color="k")
|
|
639
|
-
|
|
640
|
-
point = dc2fc(origin_dc[0])
|
|
641
|
-
point[1] += DEFAULT_AXIS_LENGTH
|
|
642
|
-
target_dc = np.append(origin_dc, [fc2dc(point)], axis=0)
|
|
643
|
-
|
|
644
|
-
ax.plot(target_dc[:, 0], target_dc[:, 1], color="k")
|
|
645
|
-
|
|
646
|
-
# Draw the axes label
|
|
647
|
-
|
|
648
|
-
dx, dy = 10 / fig.dpi, 10 / fig.dpi
|
|
649
|
-
offset = ScaledTranslation(dx, dy, fig.dpi_scale_trans)
|
|
650
|
-
point = dc2ndc(origin_dc[0])
|
|
651
|
-
plt.text(point[0], point[1], frame.name, transform=ax.transAxes + offset)
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
def define_the_initial_setup():
|
|
655
|
-
model = ReferenceFrameModel()
|
|
656
|
-
|
|
657
|
-
model.add_master_frame()
|
|
658
|
-
model.add_frame("A", translation=[2, 2, 2], rotation=[0, 0, 0], ref="Master")
|
|
659
|
-
model.add_frame("B", translation=[-2, 2, 2], rotation=[0, 0, 0], ref="Master")
|
|
660
|
-
model.add_frame("C", translation=[2, 2, 5], rotation=[0, 0, 0], ref="A")
|
|
661
|
-
model.add_frame("D", translation=[2, 2, 2], rotation=[0, 0, 0], ref="B")
|
|
662
|
-
|
|
663
|
-
model.add_link("A", "B")
|
|
664
|
-
model.add_link("B", "C")
|
|
665
|
-
|
|
666
|
-
print(model.serialize())
|
|
667
|
-
plot_ref_model_3d(model)
|
|
668
|
-
|
|
669
|
-
return model
|
|
670
|
-
|
|
671
|
-
|
|
672
|
-
def get_vectors(rf1, rf2, model):
|
|
673
|
-
"""
|
|
674
|
-
get_vectors(rf1,rf2, model)
|
|
675
|
-
:param rf1: string : name of ref. frame "from"
|
|
676
|
-
:param rf2: string : name of ref. frame "to"
|
|
677
|
-
:param model: CSLReferenceFrameModel containing rf1 and rf2
|
|
678
|
-
:return: translation and rotation vectors from rf1 to rf2
|
|
679
|
-
"""
|
|
680
|
-
return model.get_frame(rf1).getActiveTranslationRotationVectorsTo(model.get_frame(rf2))
|
|
681
|
-
|
|
682
|
-
|
|
683
|
-
def print_vectors(rf1, rf2, model):
|
|
684
|
-
"""
|
|
685
|
-
:param rf1: string : name of ref. frame "from"
|
|
686
|
-
:param rf2: string : name of ref. frame "to"
|
|
687
|
-
:param model: CSLReferenceFrameModel containing rf1 and rf2
|
|
688
|
-
:return: N.A.
|
|
689
|
-
Prints the translation and rotation vectors from rf1 to rf2
|
|
690
|
-
"""
|
|
691
|
-
trans, rot = model.get_frame(rf1).getActiveTranslationRotationVectorsTo(model.get_frame(rf2))
|
|
692
|
-
print(f"{rf1:8s} -> {rf2:8s} : Trans [{trans[0]:11.4e}, {trans[1]:11.4e}, {trans[2]:11.4e}] Rot [{rot[0]:11.4e}, {rot[1]:11.4e}, {rot[2]:11.4e}]")
|
|
693
|
-
return
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
if __name__ == "__main__":
|
|
697
|
-
|
|
698
|
-
logging.basicConfig(level=20)
|
|
699
|
-
|
|
700
|
-
model = define_the_initial_setup()
|
|
701
|
-
|
|
702
|
-
print(model.summary())
|
|
703
|
-
|
|
704
|
-
print("\nMove frame 'A', frames 'B' and 'C' move with it.\n")
|
|
705
|
-
model.move_absolute_self("A", [1, 1, 3], [0, 0, 45])
|
|
706
|
-
print(model.serialize())
|
|
707
|
-
plot_ref_model_3d(model)
|
|
708
|
-
|
|
709
|
-
model = define_the_initial_setup()
|
|
710
|
-
|
|
711
|
-
print("\nMove frame 'B' with respect to 'Master, frames 'A' and 'C' move with it.\n")
|
|
712
|
-
model.move_absolute_in_other("B", "Master", [1, 1, -1], [0, 0, 0])
|
|
713
|
-
print(model.serialize())
|
|
714
|
-
plot_ref_model_3d(model)
|
|
715
|
-
|
|
716
|
-
model = define_the_initial_setup()
|
|
717
|
-
|
|
718
|
-
print("\nMove frame 'D' relative to itself, turn 45º\n")
|
|
719
|
-
model.move_relative_self("D", [0, 0, 0], [45, 0, 0])
|
|
720
|
-
print(model.serialize())
|
|
721
|
-
plot_ref_model_3d(model)
|
|
722
|
-
|
|
723
|
-
model = define_the_initial_setup()
|
|
724
|
-
|
|
725
|
-
print("\nMove frame 'D' relative to 'A', turn 45º around origin of 'A'\n")
|
|
726
|
-
model.move_relative_other("D", "A", [0, 0, 0], [0, 45, 0])
|
|
727
|
-
print(model.serialize())
|
|
728
|
-
plot_ref_model_3d(model)
|
|
729
|
-
|
|
730
|
-
model = define_the_initial_setup()
|
|
731
|
-
|
|
732
|
-
print("\nMove frame 'D' relative to 'A', turn 45º around origin of 'D'\n")
|
|
733
|
-
model.move_relative_other_local("D", "A", [0, 0, 0], [0, 45, 0])
|
|
734
|
-
print(model.serialize())
|
|
735
|
-
plot_ref_model_3d(model)
|
|
736
|
-
|
|
737
|
-
model = define_the_initial_setup()
|