NAME
Device::Chip::Sensor
- declarations of sensor readings for Device::Chip
SYNOPSIS
class Device::Chip::MySensorChip
extends Device::Chip;
use Device::Chip::Sensor -declare;
...
declare_sensor voltage =>
units => "volts",
precision => 3;
async method read_voltage () {
...
}
DESCRIPTION
This package provides some helper methods for describing metadata on Device::Chip drivers that provide sensor values. The resulting metadata helps to describe the quantities that the sensor chip can measure, and provides a consistent API for accessing them.
CHIP METHODS
When imported into a Device::Chip
driver class using the -declare
option the following methods are added to it.
list_sensors
@sensors = $chip->list_sensors;
Returns a list of individual sensor objects. Each object represents a single sensor reading that can be measured.
OPTIONAL CHIP METHODS
The following methods may also be provided by the chip driver class if required. Callers should check they are implemented (e.g. with can
) before attempting to call them.
initialize_sensors
await $chip->initialize_sensors;
If the chip requires any special configuration changes, initial calibrations, startup delay, or other operations before the sensors are available then this method should perform it. It can presume that the application wishes to interact with the chip primarily via the sensors API, and thus if required it can presume particular settings to make this happen.
SENSOR DECLARATIONS
Sensor metadata is provided by the following function.
declare_sensor
declare_sensor $name => %params;
Declares a new sensor object with the given name and parameters.
The following named parameters are recognised:
- type => STRING
-
Optional. A string specifying what overall type of data is being returned. Normally this is
gauge
to indicate a quantity that is measured on every observation. A type ofcounter
instead indicates that the value will be an integer giving the total number of times some event has happened - typically used to count interrupt events from chips.A convenience function "declare_sensor_counter" exists for making counters.
- units => STRING
-
A string describing the units in which the value is returned. This should be an empty string for purely abstract counting sensors, or else describe the measured quantities in physical units (such as
volts
,seconds
,metres
,Hz
, ...) - precision => INT
-
The number of decimal places of floating-point accuracy that values should be printed with. This should be 0 for integer readings.
- method => STRING or CODE
-
Optional string or code reference giving the method on the main chip object to call to obtain a new reading of this sensor's current value. If not provided a default will be created by prefixing
"read_"
onto the sensor name. - sanity_bounds => ARRAY[ 2 * NUM ]
-
Optional bounding values to sanity-test reported readings. If a reading is obtained that is lower than the first value or higher than the second, it is declared to be out of bounds by the "read" method. Either bound may be set to
undef
to ignore that setting. For example, setting just a lower bound of zero ensures that any negative values that are obtained are considered out of the valid range.
declare_sensor_counter
declare_sensor_counter $name => %params;
Declares a sensor of the counter
type. This will pass undef
for the units and 0 for precision.
SENSOR METHODS
Each returned sensor object provides the following methods.
name
units
precision
$name = $sensor->name;
$units = $sensor->units;
$prec = $sensor->precision;
Metadata fields from the sensor's declaration.
chip
$chip = $sensor->chip;
The Device::Chip instance this sensor is a part of.
read
$value = await $sensor->read;
Performs an actual read operation on the sensor chip to return the currently measured value.
This method always returns a single scalar value, even if the underlying method on the sensor chip returned more than one.
If the value obtained from the sensor is outside of the sanity-check bounds then an exception is thrown instead.
format
$string = $sensor->format( $value );
Returns a string by formatting an observed value to the required precision.
AUTHOR
Paul Evans <leonerd@leonerd.org.uk>