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>