Лазерный датчик ToF (VL53L0X) не работает
У меня есть лазерный датчик расстояния для времени полета: http://www.dx.com/de/p/cjmcu-vl53l0x-tof-laser-distance-measuring-sensor-module-purple-449081#.WSbn52jyi70
Пример кода библиотеки VL53L0X-arduino не работает; Я всегда получаю последовательное сообщение
65535 ТАЙМ-АУТ
Однако я предполагаю, что проблема в датчике. Связь осуществляется через I2C, так что сканер i2c должен найти его адрес, верно?
Этот поисковик не находит ни одного адреса - я прав, значит проблема в датчике?
Я подключил VCC к (почти) 5 В, GND к GND, SCL к A5 и SDA к A4 (Arduino Uno)
@black, 👍1
Обсуждение4 ответа
Чтобы включить устройство, необходимо подать на XSH высокий уровень (3,3 В) (либо через порт ввода-вывода, либо через подтягивающий резистор до 3,3 В).
Кроме того, устройство рассчитано на максимальное напряжение 3,3 В, вы можете повредить его, если подключите его к 5 В.
С уважением
У меня была такая же проблема с использованием этот датчик. Решение заключалось в подключении
- VCC -> 5 В
- Земля -> Земля
- SCL -> A5 (SCL)
- ПДД -> А4 (ПДД)
- DNC -x Не подключен
- GN2 -> GND
- XSH -> 5 В
- INT -x Не подключено
А затем использовать код, упомянутый здесь Тедом Мейерсом. Я использовал Nano с ATmega328P и Arduino IDE 1.8.5.
КОД:
#include <Wire.h>
#define VL53L0X_REG_IDENTIFICATION_MODEL_ID 0xc0
#define VL53L0X_REG_IDENTIFICATION_REVISION_ID 0xc2
#define VL53L0X_REG_PRE_RANGE_CONFIG_VCSEL_PERIOD 0x50
#define VL53L0X_REG_FINAL_RANGE_CONFIG_VCSEL_PERIOD 0x70
#define VL53L0X_REG_SYSRANGE_START 0x00
#define VL53L0X_REG_RESULT_INTERRUPT_STATUS 0x13
#define VL53L0X_REG_RESULT_RANGE_STATUS 0x14
#define address 0x29
byte gbuf[16];
void setup() {
// поместите сюда код установки для однократного запуска:
Wire.begin(); // подключение к шине i2c (адрес необязателен для мастера)
Serial.begin(9600); // запускаем сериал для вывода
Serial.println("VLX53LOX test started.");
}
void loop() {
Serial.println("----- START TEST ----");
test();
Serial.println("----- END TEST ----");
Serial.println("");
delay(4000);
}
void test() {
byte val1 = read_byte_data_at(VL53L0X_REG_IDENTIFICATION_REVISION_ID);
Serial.print("Revision ID: "); Serial.println(val1);
val1 = read_byte_data_at(VL53L0X_REG_IDENTIFICATION_MODEL_ID);
Serial.print("Device ID: "); Serial.println(val1);
val1 = read_byte_data_at(VL53L0X_REG_PRE_RANGE_CONFIG_VCSEL_PERIOD);
Serial.print("PRE_RANGE_CONFIG_VCSEL_PERIOD="); Serial.println(val1);
Serial.print(" decode: "); Serial.println(VL53L0X_decode_vcsel_period(val1));
val1 = read_byte_data_at(VL53L0X_REG_FINAL_RANGE_CONFIG_VCSEL_PERIOD);
Serial.print("FINAL_RANGE_CONFIG_VCSEL_PERIOD="); Serial.println(val1);
Serial.print(" decode: "); Serial.println(VL53L0X_decode_vcsel_period(val1));
write_byte_data_at(VL53L0X_REG_SYSRANGE_START, 0x01);
byte val = 0;
int cnt = 0;
while (cnt < 100) { // время ожидания не более 1 секунды
delay(10);
val = read_byte_data_at(VL53L0X_REG_RESULT_RANGE_STATUS);
if (val & 0x01) break;
cnt++;
}
if (val & 0x01) Serial.println("ready"); else Serial.println("not ready");
read_block_data_at(0x14, 12);
uint16_t acnt = makeuint16(gbuf[7], gbuf[6]);
uint16_t scnt = makeuint16(gbuf[9], gbuf[8]);
uint16_t dist = makeuint16(gbuf[11], gbuf[10]);
byte DeviceRangeStatusInternal = ((gbuf[0] & 0x78) >> 3);
Serial.print("ambient count: "); Serial.println(acnt);
Serial.print("signal count: "); Serial.println(scnt);
Serial.print("distance "); Serial.println(dist);
Serial.print("status: "); Serial.println(DeviceRangeStatusInternal);
}
uint16_t bswap(byte b[]) {
// Big Endian unsigned Short в Little Endian unsigned Short
uint16_t val = ((b[0] << 8) & b[1]);
return val;
}
uint16_t makeuint16(int lsb, int msb) {
return ((msb & 0xFF) << 8) | (lsb & 0xFF);
}
void write_byte_data(byte data) {
Wire.beginTransmission(address);
Wire.write(data);
Wire.endTransmission();
}
void write_byte_data_at(byte reg, byte data) {
// записываем слово данных по адресу и регистрируем
Wire.beginTransmission(address);
Wire.write(reg);
Wire.write(data);
Wire.endTransmission();
}
void write_word_data_at(byte reg, uint16_t data) {
// записываем слово данных по адресу и регистрируем
byte b0 = (data &0xFF);
byte b1 = ((data >> 8) && 0xFF);
Wire.beginTransmission(address);
Wire.write(reg);
Wire.write(b0);
Wire.write(b1);
Wire.endTransmission();
}
byte read_byte_data() {
Wire.requestFrom(address, 1);
while (Wire.available() < 1) delay(1);
byte b = Wire.read();
return b;
}
byte read_byte_data_at(byte reg) {
//write_byte_data((byte)0x00);
write_byte_data(reg);
Wire.requestFrom(address, 1);
while (Wire.available() < 1) delay(1);
byte b = Wire.read();
return b;
}
uint16_t read_word_data_at(byte reg) {
write_byte_data(reg);
Wire.requestFrom(address, 2);
while (Wire.available() < 2) delay(1);
gbuf[0] = Wire.read();
gbuf[1] = Wire.read();
return bswap(gbuf);
}
void read_block_data_at(byte reg, int sz) {
int i = 0;
write_byte_data(reg);
Wire.requestFrom(address, sz);
for (i=0; i<sz; i++) {
while (Wire.available() < 1) delay(1);
gbuf[i] = Wire.read();
}
}
uint16_t VL53L0X_decode_vcsel_period(short vcsel_period_reg) {
// Преобразует закодированное значение регистра периода VCSEL в реальное
// период в часах PLL
uint16_t vcsel_period_pclks = (vcsel_period_reg + 1) << 1;
return vcsel_period_pclks;
}
Еще один момент, который нужно проверить, так как у меня самого была эта ошибка, и это было просто потому, что я не припаял штыревые контакты устройства nano или TOF, которые я только что вставил в свою макетную плату. Я использую iHaospace VL53l0x от Amazon. Я подумал об этом только после того, как запустил проверку сканера i2C, которая не распознала (увидела) устройство, так что я думаю - (https ://gammon.com.au/i2c). Код Sketch сканера I2C для использования в IDE Arduino находится на две трети ниже этой страницы. Я также должен отметить, что вам нужно запустить последовательный монитор на скорости 115200 бод, не ниже, иначе вы можете получить абракадабру. Теперь все работает так же, как и со стандартным примером Arduino Adafruit, #include wire.h не требуется.
У меня была эта проблема. После подключения VL53L0X скрипт завис на старте. Сканирование устройств i2c тоже зависало. Помогла промывка мест пайки контактов. Видимо устройство очень чувствительно к загрязнениям на контактах.
- Увеличение скорости датчиков Vl6180x
- Несколько датчиков I2C с одинаковым адресом
- Проблемы с подключением I2C на ESP8266 — 12F, какие контакты использовать?
- Как связаться с датчиком через порты RX/TX Arduino?
- MAX30100 не работает
- Как включать и выключать датчики I2C с помощью Arduino Mega 2560?
- Могу ли я соединить вместе несколько плат Arduino Nano ?
- Считывание значений с емкостного сенсорного датчика TTP229 на arduino
Похоже, что на этой плате нет подтягивающих резисторов на выводах SDA и SCL. Попробуйте добавить их. Что-то в районе 2 кОм (не то чтобы критично)., @Gerben
@Gerben Я пробовал. Я добавил для SDA и SCL резисторы 2,2 кОм, чтобы подтянуть его к 5 В. Однако я все еще получаю «65535 TIMEOUT». Но вы согласны, что я должен получить адрес с помощью сканера I2C?, @black
Да. Он должен появиться на сканере. Глядя на список, он указывает, что это устройство на 3,3 В. Но глядя на фотки кажется, что внизу есть регулятор напряжения и что-то типа буфера., @Gerben
Почему вы подключили его к 5V?, @Code Gorilla
ты решил проблему? У меня есть такой же., @Mcrane
@Mcrane, к сожалению, нет. Пожалуйста, оставьте ответ, если вы делаете, @black