Ejemplo n.º 1
0
class Scan:

    configure_value = Value(Type([("method", "s")]), dict(method="configure"))
    abort_value = Value(Type([("method", "s")]), dict(method="abort"))
    reset_value = Value(Type([("method", "s")]), dict(method="reset"))

    def __init__(self, block_name: str) -> None:
        self.block_name = block_name
        self.context = context

    def reset(self) -> None:
        self.context.rpc(self.block_name, None, Scan.reset_value)

    def abort(self) -> None:
        self.context.rpc(self.block_name, None, Scan.abort_value)

    def run_scan(
        self,
        axes_params: Union[AxisParams, List[AxisParams]],
        duration: float,
        file_dir: str,
    ):
        self.report("Configuring scan...")

    def report(self, message):
        print(f"{self.block_name}: {message}")
Ejemplo n.º 2
0
 def testRpcRoot(self):
     method = Value(Type([("method", "s")]), dict(method="zero"))
     self.ctxt.rpc("TESTCOUNTER", value=None, request=method)
     self.assertCounter(0)
     method = Value(Type([("method", "s")]), dict(method="increment"))
     ret = self.ctxt.rpc("TESTCOUNTER", EMPTY, method)
     self.assertEqual(ret.tolist(), [])
     self.assertCounter(1)
     method = Value(Type([("method", "s")]), dict(method="zero"))
     self.ctxt.rpc("TESTCOUNTER", EMPTY, method)
     self.assertCounter(0)
Ejemplo n.º 3
0
 def hist(self, **kws):
   pv = kws['pv']
   value = [{"secondsPastEpoch": 1, "values": 123.45, "nanoseconds": 0, "severity": 0, "status": 0}]
   pv_list = pv.split(",")
   if len(pv_list) == 1:
     return single_pv_struct.wrap(value)
   else:
     result_list = []
     for p in pv_list:
       pv_data = Value(multi_pv_struct, {"pvName": p, "value": single_pv_struct.wrap(value)})
       result_list.append(pv_data)
     return Value(multi_response_struct, {"value": result_list})
Ejemplo n.º 4
0
    def update(self):
        mask = self.fieldMask.current().get('value')
        names = self.fieldNames.current().get('value')
        types = self.fieldTypes.current().get('value')
        oid = self.payload.current().getID()
        nid = str(mask)

        if nid == oid:
            nid += 'a'
        ntypes = []
        nvalues = {}
        ntypes.append(('valid', 'i'))
        nvalues['valid'] = 0
        for i in range(31):
            if mask & 1:
                ntypes.append((names[i], chr(types[i])))
                nvalues[names[i]] = 0
            mask >>= 1

        pvname = self.prefix + 'PAYLOAD'
        self.provider.remove(pvname)
        self.payload = SharedPV(initial=Value(Type(ntypes, id=nid), nvalues),
                                handler=DefaultPVHandler(self))
        print('Payload struct ID %s' % self.payload.current().getID())
        self.provider.add(pvname, self.payload)
Ejemplo n.º 5
0
    def send_put(self, mri, attribute_name, value):
        """Abstract method to dispatch a Put to the server

        Args:
            mri (str): The mri of the Block
            attribute_name (str): The name of the Attribute within the Block
            value: The value to put
        """
        path = attribute_name + ".value"
        typ, value = convert_to_type_tuple_value(value)
        if isinstance(typ, tuple):
            # Structure, make into a Value
            _, typeid, fields = typ
            value = Value(Type(fields, typeid), value)
        try:
            self._ctxt.put(mri, {path: value}, path)
        except RemoteError:
            if attribute_name == "exports":
                # TODO: use a tag instead of a name
                # This will change the structure of the block
                # Wait for reconnect
                self._queues[mri].get(timeout=DEFAULT_TIMEOUT)
            else:
                # Not expected, raise
                raise
Ejemplo n.º 6
0
    def update(self):
        self.app.Enable.set(0)

        mask = self.fieldMask.current().get('value')
        names = self.fieldNames.current().get('value')
        types = self.fieldTypes.current().get('value')
        oid = self.payload.current().getID()
        nid = str(mask)

        print('PVCtrls.update mask[{:x}] oid[{:}]'.format(mask, oid))

        if nid == oid:
            nid += 'a'
        ntypes = []
        nvalues = {}
        ntypes.append(('valid', 'i'))
        nvalues['valid'] = 0
        mmask = mask
        for i in range(31):
            if mmask & 1:
                ntypes.append((names[i], chr(types[i])))
                nvalues[names[i]] = 0
            mmask >>= 1

        pvname = self.prefix + 'PAYLOAD'
        self.provider.remove(pvname)
        self.payload = SharedPV(initial=Value(Type(ntypes, id=nid), nvalues),
                                handler=DefaultPVHandler(self))
        print('Payload struct ID %s' % self.payload.current().getID())
        self.provider.add(pvname, self.payload)

        if mask:
            self.app.channelMask.set(mask)
            self.app.Enable.set(1)
Ejemplo n.º 7
0
    def __init__(self, provider_name, prefix):
        self.provider = StaticProvider(provider_name)
        self.prefix = prefix
        self.pvs = []

        self.fieldNames = SharedPV(initial=NTScalar('as').wrap(
            {'value': ['pid%02x' % i for i in range(31)]}),
                                   handler=DefaultPVHandler(self))

        # 'i' (integer) or 'f' (float)
        self.fieldTypes = SharedPV(initial=NTScalar('aB').wrap(
            {'value': [ord('i')] * 31}),
                                   handler=DefaultPVHandler(self))

        self.fieldMask = SharedPV(initial=NTScalar('I').wrap({'value': 0x1}),
                                  handler=DefaultPVHandler(self))

        self.payload = SharedPV(initial=Value(Type([]), {}),
                                handler=DefaultPVHandler(self))

        self.provider.add(prefix + 'HPS:FIELDNAMES', self.fieldNames)
        self.provider.add(prefix + 'HPS:FIELDTYPES', self.fieldTypes)
        self.provider.add(prefix + 'HPS:FIELDMASK', self.fieldMask)
        self.provider.add(prefix + 'PAYLOAD', self.payload)
        self.update()
Ejemplo n.º 8
0
    def run(self):
        self.provider = StaticProvider(__name__)

        self.fieldNames = SharedPV(initial=NTScalar('as').wrap(
            {'value': ['pid%02x' % i for i in range(31)]}),
                                   handler=DefaultPVHandler(self))

        # 'i' (integer) or 'f' (float)
        self.fieldTypes = SharedPV(initial=NTScalar('aB').wrap(
            {'value': [ord('i')] * 31}),
                                   handler=DefaultPVHandler(self))

        self.fieldMask = SharedPV(initial=NTScalar('I').wrap({'value':
                                                              0x8000}),
                                  handler=DefaultPVHandler(self))

        self.payload = SharedPV(initial=Value(Type([]), {}),
                                handler=DefaultPVHandler(self))

        print('Hosting {:}HPS:FIELDMASK'.format(self.prefix))
        self.provider.add(self.prefix + 'HPS:FIELDNAMES', self.fieldNames)
        self.provider.add(self.prefix + 'HPS:FIELDTYPES', self.fieldTypes)
        self.provider.add(self.prefix + 'HPS:FIELDMASK', self.fieldMask)
        self.provider.add(self.prefix + 'PAYLOAD', self.payload)
        self.update()

        try:
            Server.forever(providers=[self.provider])
        except:
            print('Server exited')
Ejemplo n.º 9
0
def convert_dict_to_value(d: Dict) -> Value:
    if d is None:
        val = EMPTY
    else:
        (_, typeid, fields), value_for_set = convert_to_type_tuple_value(d)
        try:
            typ = Type(fields, typeid)
        except RuntimeError as e:
            raise RuntimeError(f"{e} when doing Type({fields}, {typeid})")
        val = Value(typ, value_for_set)
    return val
Ejemplo n.º 10
0
 def wrap(self, value):
     """Wrap dictionary as Value
     """
     S, NS = divmod(time.time(), 1.0)
     return Value(
         self.type, {
             'value': np.frombuffer(dill.dumps(value), dtype=np.ubyte),
             'timeStamp': {
                 'secondsPastEpoch': S,
                 'nanoseconds': NS * 1e9,
             },
         })
Ejemplo n.º 11
0
def convert_dict_to_value(d):
    # type: (Dict) -> Value
    if d is None:
        val = EMPTY
    else:
        (_, typeid, fields), value_for_set = convert_to_type_tuple_value(d)
        try:
            typ = Type(fields, typeid)
        except RuntimeError as e:
            raise RuntimeError("%s when doing Type(%s, %s)" %
                               (e, fields, typeid))
        val = Value(typ, value_for_set)
    return val
Ejemplo n.º 12
0
 def wrap(self, value):
     """Wrap dictionary as Value
     """
     S, NS = divmod(time.time(), 1.0)
     for field in self.byte_fields:
         value[field] = np.frombuffer(value[field], np.ubyte)
     for field in self.object_fields:
         value[field] = np.frombuffer(dill.dumps(value[field]), np.ubyte)
     return Value(
         self.type, {
             'value': value,
             'timeStamp': {
                 'secondsPastEpoch': S,
                 'nanoseconds': NS * 1e9,
             },
         })
Ejemplo n.º 13
0
    def createPV(self, pvname, node):
        """
        Takes a string prefix and a dict of pv definitions similar to pcaspy and creates PVAccess pv's for them.
        Example PV definitions:
        {'type' : 'int', 'count' : 2, 'value' : [0,0x0fffffff] }
        {'type' : 'float', 'value' : 156.25 }
        """

        pvdef = {}

        logger.debug("Creating PV for %s", pvname)
        missing_specs = pvdef.keys() - set(['type', 'count', 'value', 'extra'])
        if missing_specs:
            raise Exception(
                "Do not have support for specifier {0} as of yet".format(
                    ",".join(missing_specs)))
        try:
            tp = __pcastypes2p4ptype__[pvdef['type']]
            starting_val = pvdef.get('value',
                                     __pcastypes2startingval__[pvdef['type']])
            if pvdef.get('count', 1) > 1:
                tp = 'a' + tp
                starting_val = pvdef.get(
                    'value', [__pcastypes2startingval__[pvdef['type']]] *
                    pvdef['count'])
            init_val = {"value": starting_val}
            extra_defs = []
            if 'extra' in pvdef:
                init_val.update({fn: fv for (fn, _, fv) in pvdef['extra']})
                extra_defs = [(fn, __pcastypes2p4ptype__[ft])
                              for (fn, ft, _) in pvdef['extra']]
                logger.debug("NTScalar(%s, extra=%s).wrap(%s)", tp, extra_defs,
                             init_val)
            pv = SharedPV(initial=NTScalar(tp,
                                           extra=extra_defs).wrap(init_val),
                          handler=DefaultPVHandler())
        except:
            pv = SharedPV(initial=Value(Type(pvdef['type']), pvdef['value']),
                          handler=DefaultPVHandler())
        self.pvs.append(
            pv
        )  # we must keep a reference in order to keep the Handler from being collected
        logger.debug("Created PV for %s", pvname)
        return pv
Ejemplo n.º 14
0
 def testRpcArgumentsDotted(self):
     args = Value(Type([("name", "s")]), dict(name="me"))
     result = self.ctxt.rpc("TESTHELLO.greet", args)
     self.assertEqual(dict(result.items()), {"return": "Hello me"})
Ejemplo n.º 15
0
 def testRpcArguments(self):
     args = Value(Type([("name", "s")]), dict(name="world"))
     method = Value(Type([("method", "s")]), dict(method="greet"))
     result = self.ctxt.rpc("TESTHELLO", args, method)
     self.assertEqual(dict(result.items()), {"return": "Hello world"})
Ejemplo n.º 16
0
from enum import Enum
from typing import Any, Dict, List, Tuple, Union

import numpy as np
from annotypes import Array
from p4p import Type, Value

from malcolm.compat import OrderedDict
from malcolm.core import AlarmSeverity, AlarmStatus
from malcolm.core.models import NTTable

EMPTY = Value(Type([]))

# https://mdavidsaver.github.io/p4p/values.html
type_specifiers = {
    np.bool_: "?",
    np.int8: "b",
    np.uint8: "B",
    np.int16: "h",
    np.uint16: "H",
    np.int32: "i",
    np.uint32: "I",
    np.int64: "l",
    np.uint64: "L",
    np.float32: "f",
    np.float64: "d",
    str: "s",
}

# Make the reverse lookup
specifier_types = {v: k for k, v in type_specifiers.items()}
Ejemplo n.º 17
0
    },
    "increment": {
        "took": empty_method_log_dict,
        "returned": empty_method_log_dict,
        "meta": {
            "takes": empty_map_meta_dict,
            "description": "Add delta to the counter attribute",
            "tags": [],
            "writeable": True,
            "label": "Increment",
            "returns": empty_map_meta_dict,
        },
    },
}

counter_expected = Value(counter_block_t, counter_dict)

string_meta = "malcolm:core/StringMeta:1.0"
number_meta = "malcolm:core/NumberMeta:1.0"

hello_block_t = Type(
    [
        ("meta", block_meta_tuple),
        ("health", health_attribute_tuple),
        (
            "greet",
            (
                "S",
                "malcolm:core/Method:1.1",
                [
                    (
Ejemplo n.º 18
0
def MySharedPV(nt, cb=None):
    return SharedPV(initial=Value(Type(pvTypes(nt)), pvValues(nt)),
                    handler=DefaultPVHandler(cb))