VMEL 6030 locks up?

I am working on a project to read from several Lux sensors, but I am having an issues that I cannot figure out.

after running fro somewhere between 15 seconds to 3 min the system will lock up and stop working. using indicator LEDs I have found that it hangs on the Line:

LuxBottomRSensor.Reading = VEML6030_BR.readLight();

this is using the Library SparkFun_VEML6030_Ambient_Light_Sensor.h

and I am reading approx. every 200 ms with a 50 ms integration time.

here is the Snippet:

  if (LuxBottomRSensor.MinLevel != 0){
    LEDIOBoard.digitalWrite(LED_DEBUG, HIGH);
    LuxBottomRSensor.Reading = VEML6030_BR.readLight();
    LEDIOBoard.digitalWrite(LED_DEBUG, LOW);
    if (CheckAndUpdateArray(LuxBottomRSensor))
      IsRunning = true;
  }


  if (LuxBottomLSensor.MinLevel != 0){
    LuxBottomLSensor.Reading = VEML6030_BL.readLight();
    if (CheckAndUpdateArray(LuxBottomLSensor))
      IsRunning = true;
  }

If anyone has an idea why this would be locking up I would appreciate it

I’ve recreated the issue with this small modification of the Example code

#include <Wire.h>
#include "SparkFun_VEML6030_Ambient_Light_Sensor.h"

#define AL_ADDR 0x48

#define AL_ADDR2 0x10

SparkFun_Ambient_Light light(AL_ADDR);
SparkFun_Ambient_Light light2(AL_ADDR2);

// Possible values: .125, .25, 1, 2
// Both .125 and .25 should be used in most cases except darker rooms.
// A gain of 2 should only be used if the sensor will be covered by a dark
// glass.
float gain = .125;

// Possible integration times in milliseconds: 800, 400, 200, 100, 50, 25
// Higher times give higher resolutions and should be used in darker light. 
int time = 50;
long luxVal = 0; 
long luxVal2 = 0;
long loopcount = 0;

void setup(){

  Wire.begin();
  Serial.begin(115200);

  if(light.begin())
    Serial.println("Ready to sense some light!"); 
  else
    Serial.println("Could not communicate with the sensor!");

    if(light2.begin())
    Serial.println("Ready to sense some light!"); 
  else
    Serial.println("Could not communicate with the sensor!");

  // Again the gain and integration times determine the resolution of the lux
  // value, and give different ranges of possible light readings. Check out
  // hoookup guide for more info. 
  light.setGain(gain);
  light.setIntegTime(time);
  light2.setGain(gain);
  light2.setIntegTime(time);

  Serial.println("Reading settings..."); 
  Serial.print("Gain: ");
  float gainVal = light.readGain();
  Serial.print(gainVal, 3); 
  Serial.print(" Integration Time: ");
  int timeVal = light.readIntegTime();
  Serial.println(timeVal);
  pinMode(LED_BUILTIN, OUTPUT);

}

void loop(){

  luxVal = light.readLight();
  luxVal2 = light2.readLight();
  Serial.print("Ambient Light Reading: ");
  Serial.print(luxVal);
  Serial.println(" Lux");  
  Serial.print("Ambient Light 2 Reading: ");
  Serial.print(luxVal2);
  Serial.println(" Lux"); 
  if((loopcount%2) == 1){
    digitalWrite(LED_BUILTIN, HIGH);
  } else {
    digitalWrite(LED_BUILTIN, LOW);
  }
  loopcount ++;
  Serial.print("Iteration: ");
  Serial.println(loopcount);
  delay(200);

}

If you go back to just one sensor with the default I2C address and use the Example1 code, do you have the same issues?

no it did not lock up, seems to be from 2 only, sorry for the late reply, I had a minor medial emergency.

Did you close the ADR jumper on one of the two boards? If you have multiple boards at the same address, that can cause lockups. If it’s not that, you might have a code issue. Another thing to check is how long your I2C (Qwiic) bus is. The shorter it is the more reliable it will be. For testing purposes, use the shortest Qwiic cables we have and see if that helps.