NAME Device::Chip::OPT3001 - chip driver for OPT3001 SYNOPSIS use Device::Chip::OPT3001; use Future::AsyncAwait; my $chip = Device::Chip::OPT3001->new; await $chip->mount( Device::Chip::Adapter::...->new ); await $chip->power(1); sleep 1; # Wait for one integration cycle printf "Current ambient light level is %.2f lux\n", scalar await $chip->read_lux; DESCRIPTION This Device::Chip subclass provides specific communication to a Texas Instruments OPT3001 ambient light sensor 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. read_config $config = await $chip->read_config Returns a HASH reference containing the chip config, using fields named from the data sheet. RN => 0 .. 15 CT => 100 | 800 M => "shutdown" | "single" | "cont" OVF => bool CRF => bool FH => bool FL => bool L => bool POL => "active-low" | "active-high" ME => bool FC => 1 | 2 | 4 | 8 change_config await $chip->change_config( %changes ) Writes updates to the configuration registers. Note that these two methods use a cache of configuration bytes to make subsequent modifications more efficient. read_lux $lux = await $chip->read_lux Reads the latest light level conversion value and returns the value in Lux. AUTHOR Paul Evans <leonerd@leonerd.org.uk>