// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-

#ifndef __AP_RANGEFINDER_PULSEDLIGHTLRF_H__
#define __AP_RANGEFINDER_PULSEDLIGHTLRF_H__

#include "RangeFinder.h"

/* Connection diagram
 *
 *        ------------------------------------------------------------------------------------
 *        |                 J5-1(NA) J5-2(NA) J5-3(NA) J5-4(NA) J5-5(NA)                     |
 *        |  J1-1(GND)                                                     J2-5(I2C Data)    |
 *        |  J1-2(5V)                                                      J2-4(I2C Clk)     |
 *        |  J1-3(Enable)                                                  J2-3(NA)          |
 *        |  J1-4(Ser RX)                                                  J2-2(Laser 5-20V) |
 *        |  J1-5(Ser TX)                             (HV Bypass)          J2-1(Boost 5V)    |
 *        |                                                                                  |
 *        |     J6-1(NA)  J6-2(NA)                                                           |
 *        ------------------------------------------------------------------------------------
 *
 * To connect to APM2.x:
 *    APM I2C Clock <-> J2-4
 *    APM I2C Data  <-> J2-5 
 *    APM GND (from output Rail) <-> J1-1
 *    APM 5V (from output Rail fed by ESC or BEC) <-> J1-2
 *
 *  APM2.x's I2C connector from outside edge: GND, Data, CLK, 3.3V
 */

// i2c address
#define AP_RANGEFINDER_PULSEDLIGHTLRF_ADDR   0x70

// min and max distances
#define AP_RANGEFINDER_PULSEDLIGHTLRF_MIN_DISTANCE 0
#define AP_RANGEFINDER_PULSEDLIGHTLRF_MAX_DISTANCE 1400

// registers
#define AP_RANGEFINDER_PULSEDLIGHTLRF_COMMAND_REG           0x00
#define AP_RANGEFINDER_PULSEDLIGHTLRF_MODESTATUS_REG        0x01    // mode & status register to turn on/off continuous measurements and averaging
#define AP_RANGEFINDER_PULSEDLIGHTLRF_SIGNALSTRENGTH_REG    0x05    // signal strenght
#define AP_RANGEFINDER_PULSEDLIGHTLRF_VELOCITY_REG          0x06    // velocity sensed
#define AP_RANGEFINDER_PULSEDLIGHTLRF_DISTHIGH_REG          0x07    // high byte of distance measurement
#define AP_RANGEFINDER_PULSEDLIGHTLRF_DISTLOW_REG           0x08    // low byte of distance measurement
#define AP_RANGEFINDER_PULSEDLIGHTLRF_PROCESSINGCNTRL_REG   0x09    // to set criteria for successful reads including min/max distances and signal strengths
#define AP_RANGEFINDER_PULSEDLIGHTLRF_AVERAGING_REG         0x13
#define AP_RANGEFINDER_PULSEDLIGHTLRF_CONTINUOUSRATE_REG    0x14
#define AP_RANGEFINDER_PULSEDLIGHTLRF_AUTOINCREMENT         0x80    // To-Do: this does not work - we still need to read from each registry individually instead of reading from multiple contiguous registries all at once

// command register values
#define AP_RANGEFINDER_PULSEDLIGHTLRF_CMDREG_ACQUISITION    0x01
#define AP_RANGEFINDER_PULSEDLIGHTLRF_CMDREG_READBLOCK      0x02
#define AP_RANGEFINDER_PULSEDLIGHTLRF_CMDREG_READWRITE_RAM  0x03
#define AP_RANGEFINDER_PULSEDLIGHTLRF_CMDREG_ERASEFLASH     0x04
#define AP_RANGEFINDER_PULSEDLIGHTLRF_CMDREG_POWERDOWN      0x06
#define AP_RANGEFINDER_PULSEDLIGHTLRF_CMDREG_READFLASH      0x07
#define AP_RANGEFINDER_PULSEDLIGHTLRF_CMDREG_SOFTRESET      0x09
#define AP_RANGEFINDER_PULSEDLIGHTLRF_CMDREG_STOREUSERCMD   0x0a

// mode & status  - valid values for mode/status register 0x01
#define AP_RANGEFINDER_PULSEDLIGHTLRF_MODESTATUS_CONTINUOUS 0x20
#define AP_RANGEFINDER_PULSEDLIGHTLRF_MODESTATUS_AVERAGING  0x80        

// averaging - valid values for averaging register 0x13
#define AP_RANGEFINDER_PULSEDLIGHTLRF_AVERAGING_NONE        0
#define AP_RANGEFINDER_PULSEDLIGHTLRF_AVERAGING_2           1
#define AP_RANGEFINDER_PULSEDLIGHTLRF_AVERAGING_4           2
#define AP_RANGEFINDER_PULSEDLIGHTLRF_AVERAGING_8           3
#define AP_RANGEFINDER_PULSEDLIGHTLRF_AVERAGING_16          4
#define AP_RANGEFINDER_PULSEDLIGHTLRF_AVERAGING_64          5
#define AP_RANGEFINDER_PULSEDLIGHTLRF_AVERAGING_128         6
#define AP_RANGEFINDER_PULSEDLIGHTLRF_AVERAGING_256         8

// continuous rates - valid values for continuous rate register 0x14
#define AP_RANGEFINDER_PULSEDLIGHTLRF_CONTINUOUSRATE_100_HZ 1
#define AP_RANGEFINDER_PULSEDLIGHTLRF_CONTINUOUSRATE_10_HZ  10
#define AP_RANGEFINDER_PULSEDLIGHTLRF_CONTINUOUSRATE_1_HZ   100

class AP_RangeFinder_PulsedLightLRF : public RangeFinder
{

public:

    // constructor
    AP_RangeFinder_PulsedLightLRF(FilterInt16 *filter);

    // init - simply sets the i2c address
    void init(uint8_t address = AP_RANGEFINDER_PULSEDLIGHTLRF_ADDR);

    // take_reading - ask sensor to make a range reading
    bool            take_reading();

    // read value from sensor and return distance in cm
    int16_t         read();

    // heath
    bool            healthy;

protected:
    uint8_t _addr;
};
#endif  // __AP_RANGEFINDER_PULSEDLIGHTLRF_H__