dodal.plan_stubs.motor_utils#
Functions
Caches the positions of all Motors on specified device if they are within smallest_move of home_position. |
|
|
|
|
|
|
Wrapper that does the following: |
Exceptions
|
- dodal.plan_stubs.motor_utils.check_and_cache_values(devices_and_positions: dict[MovableReadableDevice, float], smallest_move: float, maximum_move: float) Generator[Msg, Any, dict[MovableReadableDevice, float]] [source]#
Caches the positions of all Motors on specified device if they are within smallest_move of home_position. Throws MoveTooLarge if they are outside maximum_move of the home_position
- dodal.plan_stubs.motor_utils.home_and_reset_wrapper(plan: Generator[Msg, Any, P], device: Device, smallest_move: float, maximum_move: float, group: str | None = None, wait_for_all: bool = True) Generator[Msg, Any, P] [source]#
- dodal.plan_stubs.motor_utils.move_and_reset_wrapper(plan: Generator[Msg, Any, P], device_and_positions: dict[MovableReadable, float], smallest_move: float, maximum_move: float, group: str | None = None, wait_for_all: bool = True) Generator[Msg, Any, P] [source]#
- Wrapper that does the following:
Caches the positions of all Motors on device
2. Throws a MoveTooLarge exception if any positions are maximum_move away from home_position 2. Moves any motor that is more than smallest_move away from the home_position to home_position 3. Runs the specified plan 4. Moves all motors back to their cached positions
- Parameters:
plan (Callable[[], MsgGenerator]) – The plan to move between homing and returning to the cache
device (Device) – The device to move. All Motors in the device will be cached and moved
smallest_move (float) – The smallest move that we care about doing the home and cache for. Useful for not wearing out motors if you have large tolerances
maximum_move (float) – If any Motor starts this far from the home an exception is raised and no moves occur
home_position (float) – The position to move every motor to after caching
group (str, optional) – If set the home move will be done using the home-{group} group and the reset to cache done using reset-{group}
wait_for_all (bool, optional) – If true the home and reset to cache will be waited on. If false it is left up to the caller to wait on them. Defaults to True.
- Return type: