Source code for mxcubecore.HardwareObjects.abstract.AbstractMotor

# encoding: utf-8
#
#  Project name: MXCuBE
#  https://github.com/mxcube
#
#  This file is part of MXCuBE software.
#
#  MXCuBE is free software: you can redistribute it and/or modify
#  it under the terms of the GNU Lesser General Public License as published by
#  the Free Software Foundation, either version 3 of the License, or
#  (at your option) any later version.
#
#  MXCuBE is distributed in the hope that it will be useful,
#  but WITHOUT ANY WARRANTY; without even the implied warranty of
#  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
#  GNU Lesser General Public License for more details.
#
#  You should have received a copy of the GNU General Lesser Public License
#  along with MXCuBE. If not, see <http://www.gnu.org/licenses/>.

"""Abstract Motor class.
Defines the MotorStates enum, get/set velocity, home and set_value_relative
methods.
Emits signals valueChanged and limitsChanged.
"""

import abc
from enum import (
    Enum,
    unique,
)

from mxcubecore.BaseHardwareObjects import HardwareObjectState
from mxcubecore.HardwareObjects.abstract.AbstractActuator import AbstractActuator

__copyright__ = """ Copyright © 2010-2020 by the MXCuBE collaboration """
__license__ = "LGPLv3+"


[docs]@unique class MotorStates(Enum): """Motor states definitions.""" HOME = HardwareObjectState.READY, 5 LOWLIMIT = HardwareObjectState.READY, 6 HIGHLIMIT = HardwareObjectState.READY, 7 MOVING = HardwareObjectState.BUSY, 8
[docs]class AbstractMotor(AbstractActuator): """Abstract motor class""" __metaclass__ = abc.ABCMeta unit = None SPECIFIC_STATES = MotorStates def __init__(self, name): super().__init__(name) self._velocity = None self._tolerance = None
[docs] def init(self): """Initialise tolerance property""" super().init() self._tolerance = self.get_property("tolerance") or 1e-3
[docs] def get_velocity(self): """Read motor velocity. Returns: (float): velocity [unit/s] """ return self._velocity
[docs] def set_velocity(self, velocity): """Set the motor velocity Args: velocity (float): target velocity """ self._velocity = velocity
[docs] def set_value_relative(self, relative_value, timeout=0): """ Set actuator to relative to the current value Args: value (float): target value timeout (float): optional - timeout [s], If timeout == 0: return at once and do not wait; if timeout is None: wait forever. """ self.set_value(self.get_value() + relative_value, timeout)
[docs] def home(self, timeout=None): """Homing procedure. Args: timeout (float): Timeout [s]. """ raise NotImplementedError
[docs] def update_value(self, value=None): """Check if the value has changed. Emits signal valueChanged. Args: value (float): value """ if value is None: value = self.get_value() if self._nominal_value is None: if value is None: return elif value is not None and self._tolerance: if abs(value - self._nominal_value) <= self._tolerance: return self._nominal_value = value self.emit("valueChanged", (value,))