예제 #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}")
예제 #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)
예제 #3
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)
예제 #4
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()
예제 #5
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)
예제 #6
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')
예제 #7
0
 def buildType(klass, extra=[]):
     """Build type
     """
     return Type([
         ('value', 'aB'),
         ('alarm', alarm),
         ('timeStamp', timeStamp),
     ],
                 id='ami:export/NTBytes:1.0')
예제 #8
0
 def buildType(klass, extra=[]):
     """Build type
     """
     return Type([
         ('value', ('S', None, klass.schema)),
         ('alarm', alarm),
         ('timeStamp', timeStamp),
     ],
                 id='ami:export/NTStore:1.0')
예제 #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
예제 #10
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
예제 #11
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
예제 #12
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"})
예제 #13
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"})
예제 #14
0
from p4p import Type, Value
from p4p.nt import NTTable
from p4p.rpc import rpc, quickRPCServer

single_pv_struct = NTTable([("secondsPastEpoch", "l"), ("values", "d"), ("nanoseconds", "i"), ("severity", "i"), ("status", "i")])

"""
pv_data = pvaccess.PvObject({"value": {"pvName": pvaccess.STRING, "value": single_pv_struct}},{"value": {"pvName": pv, "value": single_pv_value}})
"""

multi_pv_struct = Type([
  ("pvName", "s"),
  ("value", ("S", "NTComplexTable", single_pv_struct.type.items()))
])

multi_response_struct = Type([
  ("value", "av")
])

class ArchiveTester(object):
  @rpc(None)
  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)})
예제 #15
0
                    ("tags", "as"),
                    ("writeable", "?"),
                    ("label", "s"),
                    ("display", display_tuple),
                ],
            ),
        ),
    ],
)

counter_block_t = Type(
    [
        ("meta", block_meta_tuple),
        ("health", health_attribute_tuple),
        ("counter", ntscalar_tuple),
        ("delta", ntscalar_tuple),
        ("zero", empty_method_tuple),
        ("increment", empty_method_tuple),
    ],
    "malcolm:core/Block:1.0",
)

counter_dict = {
    "meta": {
        "description": "Hardware Block simulating a single float64 counter",
        "tags": ["version:pymalcolm:%s" % __version__],
        "writeable": True,
        "label": "TESTCOUNTER",
        "fields": ["health", "counter", "delta", "zero", "increment"],
    },
    "health": {
예제 #16
0
    }
else:
    empty_map_meta_dict = {
        'elements': {},
        'required': []
    }

counter_block_t = Type([
    ('meta', block_meta_tuple),
    ('health', health_attribute_tuple),
    ('counter', ('S', 'epics:nt/NTScalar:1.0', [
        ('value', 'd'),
        ('alarm', alarm_tuple),
        ('timeStamp', ts_tuple),
        ('meta', ('S', 'malcolm:core/NumberMeta:1.0', [
            ('dtype', 's'),
            ('description', 's'),
            ('tags', 'as'),
            ('writeable', '?'),
            ('label', 's')
        ])),
    ])),
    ('zero', empty_method_tuple),
    ('increment', empty_method_tuple)
], 'malcolm:core/Block:1.0')

counter_dict = {
    'meta': {
        'description': 'Hardware Block simulating a single float64 counter',
        'tags': [],
        'writeable': True,
        'label': 'TESTCOUNTER',
예제 #17
0
def MySharedPV(nt, cb=None):
    return SharedPV(initial=Value(Type(pvTypes(nt)), pvValues(nt)),
                    handler=DefaultPVHandler(cb))
예제 #18
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()}