NAME
Device::Chip::AS3935
- chip driver for AS3935
SYNOPSIS
use
Device::Chip::AS3935;
use
Future::AsyncAwait;
my
$chip
= Device::Chip::AS3935->new;
await
$chip
->mount( Device::Chip::Adapter::...->new );
if
( ( await
$chip
->read_int )->{INT_L} ) {
printf
"Lightning detected %dkm away\n"
, await
$chip
->read_distance;
}
DESCRIPTION
This Device::Chip subclass provides specific communcation to an ams AS3935 lightning detector chip attached to a computer via an I²C adapter.
The reader is presumed to be familiar with the general operation of this chip; the documentation here will not attempt to explain or define chip-specific concepts or features, only the use of this module to access them.
METHODS
The following methods documented in an await
expression return Future instances.
reset
await
$chip
->
reset
;
Sends a reset command to initialise the configuration back to defaults.
calibrate_rco
await
$chip
->calibrate_rco;
Sends a calibrate command to request the chip perform its internal RC oscillator calibration.
read_config
$config
= await
$chip
->read_config;
Returns a HASH
reference of the contents of configuration registers using fields named from the data sheet.
AFE_GB
=> 0 .. 31
PWD
=>
"active"
|
"powerdown"
NF_LEV
=> 0 .. 7
WDTH
=> 0 .. 15
CL_STAT
=> bool
MIN_NUM_LIGH
=> 1 | 5 | 9 | 16
SREJ
=> 0 .. 15
LCO_FDIV
=> 16 | 32 | 64 | 128
MASK_DIST
=> bool
DISP_LCO
=> bool
DISP_SRCO
=> bool
DISP_TRCO
=> bool
TUN_CAP
=> 0 .. 15
Additionally, the following keys are provided calculated from those, as a convenience.
afe
=>
"indoor"
|
"outdoor"
noisefloor
=>
int
(in units of µVrms)
change_config
await
$chip
->change_config(
%changes
);
Writes updates to the configuration registers.
read_calib_status
$status
= await
$chip
->read_calib_status;
Returns a 4-element HASH
reference indicating the calibration status:
TRCO_CALIB_DONE
=> bool
TRCO_CALIB_NOK
=> bool
SRCO_CALIB_DONE
=> bool
SRCO_CALIB_NOK
=> bool
read_int
$ints
= await
$chip
->read_int;
Returns a 3-element HASH
reference containing the three interrupt flags:
INT_NH
=> bool
INT_D
=> bool
INT_L
=> bool
read_distance
$distance
= await
$chip
->read_distance;
Returns an integer giving the estimated lightning distance, in km, or undef
if it is below the detection limit.
AUTHOR
Paul Evans <leonerd@leonerd.org.uk>