Adafruit_MLX90632/examples/test_MLX90632/test_MLX90632.ino
ladyada c93ea16dd6 Integrate calibration loading and add comprehensive mode support
- Automatically load calibration constants in begin() method
- Remove separate getCalibrations() call from example sketch
- Add selectable measurement modes in example with commented options
- Implement proper SOC (Start of Conversion) triggering for step modes
- Support all measurement modes: Continuous, Step, and Sleeping Step
- Optimize loop for efficient new data flag handling
- Add automatic single measurement triggering for step-based modes
- Tested and verified both continuous and step mode operation
- Apply clang-format code formatting to all C++ files

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-02 16:29:51 -04:00

195 lines
No EOL
5.8 KiB
C++

// Basic test sketch for Adafruit MLX90632 Far Infrared Temperature Sensor
#include "Adafruit_MLX90632.h"
Adafruit_MLX90632 mlx = Adafruit_MLX90632();
void setup() {
Serial.begin(115200);
while (!Serial) delay(10);
Serial.println(F("Adafruit MLX90632 test"));
if (!mlx.begin()) {
Serial.println(F("Failed to find MLX90632 chip"));
while (1) { delay(10); }
}
Serial.println(F("MLX90632 Found!"));
// Reset the device
if (!mlx.reset()) {
Serial.println(F("Device reset failed"));
while (1) { delay(10); }
}
Serial.println(F("Device reset: SUCCESS"));
uint64_t productID = mlx.getProductID();
Serial.print(F("Product ID: 0x"));
Serial.print((uint32_t)(productID >> 32), HEX);
Serial.println((uint32_t)(productID & 0xFFFFFFFF), HEX);
uint16_t productCode = mlx.getProductCode();
Serial.print(F("Product Code: 0x"));
Serial.println(productCode, HEX);
uint16_t eepromVersion = mlx.getEEPROMVersion();
Serial.print(F("EEPROM Version: 0x"));
Serial.println(eepromVersion, HEX);
// Decode product code bits
uint8_t fov = (productCode >> 8) & 0x3;
uint8_t package = (productCode >> 5) & 0x7;
uint8_t accuracy = productCode & 0x1F;
Serial.print(F("FOV: "));
Serial.println(fov == 0 ? F("50°") : F("Unknown"));
Serial.print(F("Package: "));
Serial.println(package == 1 ? F("SFN 3x3") : F("Unknown"));
Serial.print(F("Accuracy: "));
if (accuracy == 1) {
Serial.println(F("Medical"));
} else if (accuracy == 2) {
Serial.println(F("Standard"));
} else {
Serial.println(F("Unknown"));
}
// Set and get mode - choose one:
Serial.println(F("\n--- Mode Settings ---"));
if (!mlx.setMode(MLX90632_MODE_CONTINUOUS)) {
// if (!mlx.setMode(MLX90632_MODE_STEP)) { // Uncomment for step mode testing
// if (!mlx.setMode(MLX90632_MODE_SLEEPING_STEP)) { // Uncomment for sleeping step mode testing
Serial.println(F("Failed to set mode"));
while (1) { delay(10); }
}
mlx90632_mode_t currentMode = mlx.getMode();
Serial.print(F("Current mode: "));
switch (currentMode) {
case MLX90632_MODE_HALT:
Serial.println(F("Halt"));
break;
case MLX90632_MODE_SLEEPING_STEP:
Serial.println(F("Sleeping Step"));
break;
case MLX90632_MODE_STEP:
Serial.println(F("Step"));
break;
case MLX90632_MODE_CONTINUOUS:
Serial.println(F("Continuous"));
break;
default:
Serial.println(F("Unknown"));
}
// Set and get measurement select (medical)
Serial.println(F("\n--- Measurement Select Settings ---"));
if (!mlx.setMeasurementSelect(MLX90632_MEAS_MEDICAL)) {
Serial.println(F("Failed to set measurement select to Medical"));
while (1) { delay(10); }
}
mlx90632_meas_select_t currentMeasSelect = mlx.getMeasurementSelect();
Serial.print(F("Current measurement select: "));
switch (currentMeasSelect) {
case MLX90632_MEAS_MEDICAL:
Serial.println(F("Medical"));
break;
case MLX90632_MEAS_EXTENDED_RANGE:
Serial.println(F("Extended Range"));
break;
default:
Serial.println(F("Unknown"));
}
// Set and get refresh rate (default to 2Hz)
Serial.println(F("\n--- Refresh Rate Settings ---"));
if (!mlx.setRefreshRate(MLX90632_REFRESH_2HZ)) {
Serial.println(F("Failed to set refresh rate to 2Hz"));
while (1) { delay(10); }
}
mlx90632_refresh_rate_t currentRefreshRate = mlx.getRefreshRate();
Serial.print(F("Current refresh rate: "));
switch (currentRefreshRate) {
case MLX90632_REFRESH_0_5HZ:
Serial.println(F("0.5 Hz"));
break;
case MLX90632_REFRESH_1HZ:
Serial.println(F("1 Hz"));
break;
case MLX90632_REFRESH_2HZ:
Serial.println(F("2 Hz"));
break;
case MLX90632_REFRESH_4HZ:
Serial.println(F("4 Hz"));
break;
case MLX90632_REFRESH_8HZ:
Serial.println(F("8 Hz"));
break;
case MLX90632_REFRESH_16HZ:
Serial.println(F("16 Hz"));
break;
case MLX90632_REFRESH_32HZ:
Serial.println(F("32 Hz"));
break;
case MLX90632_REFRESH_64HZ:
Serial.println(F("64 Hz"));
break;
default:
Serial.println(F("Unknown"));
}
// Clear new data flag before starting continuous measurements
Serial.println(F("\\n--- Starting Continuous Measurements ---"));
if (!mlx.resetNewData()) {
Serial.println(F("Failed to reset new data flag"));
while (1) { delay(10); }
}
Serial.println(F("New data flag reset - starting measurements"));
}
void loop() {
// Only check new data flag - much more efficient for continuous mode
if (mlx.isNewData()) {
Serial.print(F("New Data Available - Cycle Position: "));
Serial.println(mlx.readCyclePosition());
// Read ambient temperature
double ambientTemp = mlx.getAmbientTemperature();
Serial.print(F("Ambient Temperature: "));
Serial.print(ambientTemp, 4);
Serial.println(F(" °C"));
// Read object temperature
double objectTemp = mlx.getObjectTemperature();
Serial.print(F("Object Temperature: "));
if (isnan(objectTemp)) {
Serial.println(F("NaN (invalid cycle position)"));
} else {
Serial.print(objectTemp, 4);
Serial.println(F(" °C"));
}
// Reset new data flag after reading
if (!mlx.resetNewData()) {
Serial.println(F("Failed to reset new data flag"));
}
Serial.println(); // Add blank line between readings
}
// Check if we need to trigger a new measurement for step modes
mlx90632_mode_t currentMode = mlx.getMode();
if (currentMode == MLX90632_MODE_STEP || currentMode == MLX90632_MODE_SLEEPING_STEP) {
// Trigger single measurement (SOC bit) for step modes
if (!mlx.startSingleMeasurement()) {
Serial.println(F("Failed to start single measurement"));
}
}
// Small delay to prevent overwhelming the I2C bus
delay(10);
}