Source code for pychron.spectrometer.map.magnet
# ===============================================================================
# Copyright 2011 Jake Ross
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ===============================================================================
# ============= enthought library imports =======================
from traits.api import Any
# ============= standard library imports ========================
import time
# ============= local library imports ==========================
from pychron.hardware import get_float
from pychron.spectrometer.base_magnet import BaseMagnet
[docs]class MapMagnet(BaseMagnet):
"""
Abstraction for the MAP Magent
"""
device = Any
# ===============================================================================
# positioning
# ===============================================================================
[docs] def set_range(self, r, verbose=False):
"""
if float convert to integer and use as range.
send B[r-1] ::
# r = 6
dev.tell('B5')
:param r: float or int
:param verbose:
"""
dev = self.device
if dev:
r = int(r) - 1
dev.tell("B{}.".format(r), verbose=verbose)
[docs] def set_dac(self, v, verbose=False):
"""
set the magnet dac voltage.
set the range then send W[v] ::
dev.tell('W4.543')
:param v: v, dac voltage
:param verbose:
:return: bool, True if dac changed else False
"""
dev = self.device
if dev:
self.set_range(v)
dev.tell("W{}.".format(v), verbose=verbose)
time.sleep(self.settling_time)
change = v != self._dac
self._dac = v
self.dac_changed = True
return change
@get_float
def read_dac(self):
return self._dac
# ============= EOF =============================================