2023-07-25 12:21:50 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
#include "hardware/i2c.h"
|
|
|
|
#include "hardware/gpio.h"
|
|
|
|
#include "common/pimoroni_common.hpp"
|
|
|
|
#include "common/pimoroni_i2c.hpp"
|
|
|
|
#include "as7343_regs.hpp"
|
|
|
|
|
|
|
|
namespace pimoroni {
|
|
|
|
|
|
|
|
class AS7343 {
|
|
|
|
//--------------------------------------------------
|
|
|
|
// Constants
|
|
|
|
//--------------------------------------------------
|
|
|
|
public:
|
|
|
|
static const uint8_t DEFAULT_I2C_ADDRESS = 0x39;
|
|
|
|
|
|
|
|
//--------------------------------------------------
|
|
|
|
// Enums
|
|
|
|
//--------------------------------------------------
|
|
|
|
public:
|
|
|
|
enum class channel_count : uint8_t {
|
|
|
|
SIX_CHANNEL = 6,
|
|
|
|
TWELVE_CHANNEL = 12,
|
|
|
|
EIGHTEEN_CHANNEL = 18
|
|
|
|
};
|
|
|
|
/*
|
|
|
|
enum class COMPENSATION_GAIN : float {
|
|
|
|
F1 = 1.84f,
|
|
|
|
F2 = 6.03f,
|
|
|
|
FZ = 4.88f,
|
|
|
|
F3 = 13.74f,
|
|
|
|
F4 = 3.37f,
|
|
|
|
FY = 2.82f,
|
|
|
|
F5 = 6.72f,
|
|
|
|
FXL = 2.22f,
|
|
|
|
F6 = 3.17f,
|
|
|
|
F7 = 1.95f,
|
|
|
|
F8 = 12.25f,
|
|
|
|
NIR = 1.00f,
|
|
|
|
};
|
|
|
|
*/
|
|
|
|
|
|
|
|
//--------------------------------------------------
|
|
|
|
// Substructures
|
|
|
|
//--------------------------------------------------
|
|
|
|
public:
|
|
|
|
struct reading {
|
|
|
|
// Cycle 1
|
2024-09-06 09:57:58 +01:00
|
|
|
uint16_t c1_astatus = 0; // (c1_astatus >> 8) & 0b10001111
|
|
|
|
// 0b10000000 = saturated
|
|
|
|
// 0b00001111 = gain lowest nibble
|
2023-07-25 12:21:50 +01:00
|
|
|
uint16_t FZ = 0; // 428-480 nm
|
|
|
|
uint16_t FY = 0; // 534-593 nm
|
|
|
|
uint16_t FXL = 0; // 593-628 nm
|
|
|
|
uint16_t NIR = 0; // 849-903 nm
|
|
|
|
|
|
|
|
uint16_t c1_vis_tl = 0; // Visible top-left
|
|
|
|
uint16_t c1_vis_br = 0; // Visible bottom-right
|
2024-09-06 09:57:58 +01:00
|
|
|
//uint16_t c1_fd = 0; // This is where flicker detect *would* be
|
2023-07-25 12:21:50 +01:00
|
|
|
|
|
|
|
// Cycle 2
|
2024-09-06 09:57:58 +01:00
|
|
|
uint16_t c2_astatus = 0;
|
2023-07-25 12:21:50 +01:00
|
|
|
uint16_t F2 = 0; // 408-448 nm
|
|
|
|
uint16_t F3 = 0; // 448-500 mn
|
|
|
|
uint16_t F4 = 0; // 500-534 nm
|
|
|
|
uint16_t F6 = 0; // 618-665 nm
|
|
|
|
|
|
|
|
uint16_t c2_vis_tl = 0;
|
|
|
|
uint16_t c2_vis_br = 0;
|
2024-09-06 09:57:58 +01:00
|
|
|
//uint16_t c2_fd = 0;
|
2023-07-25 12:21:50 +01:00
|
|
|
|
|
|
|
// Cycle 3
|
2024-09-06 09:57:58 +01:00
|
|
|
uint16_t c3_astatus = 0;
|
2023-07-25 12:21:50 +01:00
|
|
|
uint16_t F1 = 0; // 396-408 nm
|
|
|
|
uint16_t F7 = 0; // 685-715 nm
|
|
|
|
uint16_t F8 = 0; // 715-766 nm
|
2024-09-06 09:57:58 +01:00
|
|
|
uint16_t F5 = 0; // 531-594 nm
|
2023-07-25 12:21:50 +01:00
|
|
|
|
|
|
|
uint16_t c3_vis_tl = 0;
|
|
|
|
uint16_t c3_vis_br = 0;
|
2024-09-06 09:57:58 +01:00
|
|
|
//uint16_t c3_fd = 0;
|
|
|
|
|
|
|
|
float gain(uint8_t cycle) {
|
|
|
|
uint8_t status = 0;
|
|
|
|
switch(cycle) {
|
|
|
|
case 1:
|
|
|
|
status = c1_astatus & 0xf;
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
status = c2_astatus & 0xf;
|
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
status = c3_astatus & 0xf;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return status ? 1 << (status - 1) : 0.5f;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool saturated(uint8_t cycle) {
|
|
|
|
switch(cycle) {
|
|
|
|
case 1:
|
|
|
|
return c1_astatus & 0x80;
|
|
|
|
case 2:
|
|
|
|
return c2_astatus & 0x80;
|
|
|
|
case 3:
|
|
|
|
return c3_astatus & 0x80;
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2023-07-25 12:21:50 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------
|
|
|
|
// Variables
|
|
|
|
//--------------------------------------------------
|
|
|
|
private:
|
|
|
|
I2C *i2c;
|
|
|
|
|
|
|
|
// interface pins with our standard defaults where appropriate
|
|
|
|
int8_t address = DEFAULT_I2C_ADDRESS;
|
|
|
|
uint interrupt = PIN_UNUSED;
|
|
|
|
|
|
|
|
uint8_t read_cycles = 1;
|
|
|
|
uint8_t ch_count = (uint8_t)channel_count::SIX_CHANNEL;
|
|
|
|
|
2024-09-06 09:57:58 +01:00
|
|
|
bool running = false;
|
|
|
|
|
2023-07-25 12:21:50 +01:00
|
|
|
|
|
|
|
//--------------------------------------------------
|
|
|
|
// Constructors/Destructor
|
|
|
|
//--------------------------------------------------
|
|
|
|
public:
|
|
|
|
AS7343(uint interrupt = PIN_UNUSED) : AS7343(new I2C(), interrupt) {};
|
|
|
|
|
|
|
|
AS7343(I2C *i2c, uint interrupt = PIN_UNUSED) : i2c(i2c), interrupt(interrupt) {}
|
|
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------
|
|
|
|
// Methods
|
|
|
|
//--------------------------------------------------
|
|
|
|
public:
|
|
|
|
bool init();
|
|
|
|
void reset();
|
|
|
|
|
|
|
|
// For print access in micropython
|
|
|
|
i2c_inst_t* get_i2c() const;
|
|
|
|
int get_sda() const;
|
|
|
|
int get_scl() const;
|
|
|
|
int get_int() const;
|
|
|
|
|
|
|
|
void get_version(uint8_t &auxid, uint8_t &revid, uint8_t &hwid);
|
|
|
|
|
2024-09-06 09:57:58 +01:00
|
|
|
void start_measurement();
|
|
|
|
void stop_measurement();
|
|
|
|
|
2023-07-25 12:21:50 +01:00
|
|
|
reading read();
|
|
|
|
|
|
|
|
void read_fifo(uint16_t *buf);
|
|
|
|
|
|
|
|
void set_gain(float gain);
|
|
|
|
void set_illumination_current(float current);
|
|
|
|
void set_illumination_led(bool state);
|
|
|
|
void set_measurement_time(float measurement_time_ms);
|
|
|
|
void set_integration_time(float integration_time_us, uint8_t repeat=1);
|
|
|
|
|
|
|
|
void set_channels(channel_count channel_count);
|
|
|
|
|
|
|
|
private:
|
|
|
|
void bank_select(uint8_t bank=0);
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|