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>