mahos.msgs.param_msgs#

Message Types for Generic Parameters.

Param is a wrapper around a value of primitive (mostly Python builtin) type, with a default. NumberParam has bounds (minimum and maximum). ChoiceParam has its available options. Collection of parameters are expressed as a ParamDict: nestable, str-keyed dict of Params.

GetParamDictReq (get_param_dict()) is usually served by meas nodes, to tell the client about required parameters for a measurement. The client can use param_dict to update the parameter values and pass it in StateReq (change_state()). At the meas node side, it is usually required to unwrap the Params using unwrap().

Messages#

class mahos.msgs.param_msgs.GetParamDictReq(label: str = '')#

Request to get ParamDict.

ParamDict#

Measurement parameter can be reported by using ParamDict.

class mahos.msgs.param_msgs.ParamDict(dict=None, /, **kwargs)#
mahos.msgs.param_msgs.PDValue#

Allowed value types for ParamDict

mahos.msgs.param_msgs.RawPDValue#

Allowed value types for Raw (unwrapped) ParamDict

Contents of ParamDict is instances of Param. The Param is mutable object; we can get / set the value.

class mahos.msgs.param_msgs.Param(typ, default, optional: bool, enable: bool, doc: str)#

Base class for all Param types.

value()#

Get raw value of this Param.

set(value) bool#

Set value of this Param. Return True on success.

Param has subclasses according to the types.

NumberParam#

NumberParam has bounds: minimum and maximum.

class mahos.msgs.param_msgs.NumberParam(typ, default, minimum, maximum, unit, SI_prefix, digit, step, optional, enable, doc)#

Base class for Param types represents a number.

minimum()#

Get minimum value (lower bound) of this NumberParam.

maximum()#

Get maximum value (upper bound) of this NumberParam.

class mahos.msgs.param_msgs.IntParam(default: int = 0, minimum=None, maximum=None, unit: str = '', SI_prefix: bool = False, digit: int = 6, step: int = 1, optional: bool = False, enable: bool = True, doc: str = '')#

Param type of builtin int.

class mahos.msgs.param_msgs.FloatParam(default: float = 0.0, minimum=None, maximum=None, unit: str = '', SI_prefix: bool = False, digit: int = 6, step: float = 1.0, optional: bool = False, enable: bool = True, doc: str = '')#

Param type of builtin float.

ChoiceParam#

class mahos.msgs.param_msgs.ChoiceParam(typ, default, options, optional, enable, doc)#

Base class for Param types expressing a choice from finite set options.

options() tuple#

Get available options for this Param.

class mahos.msgs.param_msgs.BoolParam(default: bool, optional: bool = False, enable: bool = True, doc: str = '')#

Param type of builtin bool.

class mahos.msgs.param_msgs.EnumParam(typ: Enum, default, options=None, optional: bool = False, enable: bool = True, doc: str = '')#

Param type of Enum.

class mahos.msgs.param_msgs.StrChoiceParam(default, options: tuple[str], optional: bool = False, enable: bool = True, doc: str = '')#

Param type of selection type of builtin strs.

class mahos.msgs.param_msgs.IntChoiceParam(default, options: tuple[int], optional: bool = False, enable: bool = True, doc: str = '')#

Param type of selection type of builtin ints.

Other Param#

class mahos.msgs.param_msgs.StrParam(default: str = '', optional: bool = False, enable: bool = True, doc: str = '')#

Param type of builtin str.

class mahos.msgs.param_msgs.UUIDParam(optional: bool = False, enable: bool = True, doc: str = '')#

Param type of uuid.UUID.

Functions#

mahos.msgs.param_msgs.unwrap(params: ParamDict[str, Param | ParamDict | List[Param | ParamDict | List[PDValue]]] | dict[str, bool | str | int | float | Enum | UUID | dict | List[bool | str | int | float | Enum | UUID | dict | List[RawPDValue]]]) dict[str, bool | str | int | float | Enum | UUID | dict | List[bool | str | int | float | Enum | UUID | dict | List[RawPDValue]]]#

Unwrap the ParamDict to RawParamDict. If params is not a ParamDict, do nothing.

mahos.msgs.param_msgs.isclose(params: ParamDict[str, Param | ParamDict | List[Param | ParamDict | List[PDValue]]] | dict[str, bool | str | int | float | Enum | UUID | dict | List[bool | str | int | float | Enum | UUID | dict | List[RawPDValue]]], other: ParamDict[str, Param | ParamDict | List[Param | ParamDict | List[PDValue]]] | dict[str, bool | str | int | float | Enum | UUID | dict | List[bool | str | int | float | Enum | UUID | dict | List[RawPDValue]]], rtol: float = 1e-05, atol: float = 1e-08) bool#

Check if two ParamDicts or RawParamDicts are close.