Skip to content

Commit

Permalink
YDLIDAR X2 example works
Browse files Browse the repository at this point in the history
  • Loading branch information
kaiaai authored Jun 5, 2024
1 parent 1e92812 commit 2afb22d
Showing 1 changed file with 137 additions and 0 deletions.
137 changes: 137 additions & 0 deletions examples/ydlidar_x2_esp32/ydlidar_x2_esp32.ino
Original file line number Diff line number Diff line change
@@ -0,0 +1,137 @@
// Copyright 2023-2024 REMAKE.AI, KAIA.AI, MAKERSPET.COM
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#ifndef ESP32
#error This example runs on ESP32
#endif

#include <LDS_YDLIDAR_X2_X2L.h>

const uint8_t LDS_MOTOR_EN_PIN = 19; // ESP32 Dev Kit LiDAR enable pin
const uint8_t LDS_MOTOR_PWM_PIN = 15; // LiDAR motor speed control using PWM
#define LDS_MOTOR_PWM_FREQ 10000
#define LDS_MOTOR_PWM_BITS 11
#define LDS_MOTOR_PWM_CHANNEL 2 // ESP32 PWM channel for LiDAR motor speed control

HardwareSerial LidarSerial(2); // TX 17, RX 16
LDS_YDLIDAR_X2_X2L lidar;

void setup() {
Serial.begin(115200);

Serial.print("LiDAR model ");
Serial.println(lidar.getModelName());

Serial.print("LiDAR RX buffer size "); // default 128 hw + 256 sw
Serial.print(LidarSerial.setRxBufferSize(1024)); // must be before .begin()

uint32_t baud_rate = lidar.getSerialBaudRate();
Serial.print(", baud rate ");
Serial.println(baud_rate);

LidarSerial.begin(baud_rate); // Use default GPIO TX 17, RX 16
// Assign TX, RX pins
// LidarSerial.begin(baud_rate, SERIAL_8N1, rxPin, txPin);
// Details https://github.com/espressif/arduino-esp32/blob/master/cores/esp32/HardwareSerial.h
// Tutorial https://www.youtube.com/watch?v=eUPAoP7xC7A

//while (LidarSerial.read() >= 0);

lidar.setScanPointCallback(lidar_scan_point_callback);
lidar.setPacketCallback(lidar_packet_callback);
lidar.setSerialWriteCallback(lidar_serial_write_callback);
lidar.setSerialReadCallback(lidar_serial_read_callback);
lidar.setMotorPinCallback(lidar_motor_pin_callback);
lidar.init();

LDS::result_t result = lidar.start();
Serial.print("LiDAR start() result: ");
Serial.println(lidar.resultCodeToString(result));

if (result < 0)
Serial.println("Is the LiDAR connected to ESP32?");
}

int lidar_serial_read_callback() {
return LidarSerial.read();
// int ch = LidarSerial.read();
// if (ch != -1)
// Serial.println(ch);
// return ch;
}

size_t lidar_serial_write_callback(const uint8_t * buffer, size_t length) {
return LidarSerial.write(buffer, length);
}

void lidar_scan_point_callback(float angle_deg, float distance_mm, float quality,
bool scan_completed) {
static int i=0;

if ((i++ % 20 == 0) || scan_completed) {
Serial.print(i);
Serial.print(' ');
Serial.print(distance_mm);
Serial.print(' ');
Serial.print(angle_deg);
if (scan_completed)
Serial.println('*');
else
Serial.println();
}
}

void lidar_info_callback(LDS::info_t code, String info) {
Serial.print("LiDAR info ");
Serial.print(lidar.infoCodeToString(code));
Serial.print(": ");
Serial.println(info);
}

void lidar_error_callback(LDS::result_t code, String aux_info) {
Serial.print("LiDAR error ");
Serial.print(lidar.resultCodeToString(code));
Serial.print(": ");
Serial.println(aux_info);
}

void lidar_motor_pin_callback(float value, LDS::lds_pin_t lidar_pin) {
int pin = (lidar_pin == LDS::LDS_MOTOR_EN_PIN) ?
LDS_MOTOR_EN_PIN : LDS_MOTOR_PWM_PIN;

if (value <= LDS::DIR_INPUT) {
// Configure pin direction
if (value == LDS::DIR_OUTPUT_PWM) {
ledcSetup(LDS_MOTOR_PWM_CHANNEL, LDS_MOTOR_PWM_FREQ, LDS_MOTOR_PWM_BITS);
ledcAttachPin(pin, LDS_MOTOR_PWM_CHANNEL);
} else
pinMode(pin, (value == LDS::DIR_INPUT) ? INPUT : OUTPUT);
return;
}

if (value < LDS::VALUE_PWM) // set constant output
digitalWrite(pin, (value == LDS::VALUE_HIGH) ? HIGH : LOW);
else { // set PWM duty cycle
int pwm_value = ((1<<LDS_MOTOR_PWM_BITS)-1)*value;
ledcWrite(LDS_MOTOR_PWM_CHANNEL, pwm_value);
}
}

void lidar_packet_callback(uint8_t * packet, uint16_t length, bool scan_completed) {
return;
}

void loop() {
lidar.loop();
}

0 comments on commit 2afb22d

Please sign in to comment.