Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[P159] Add LD2410 Radar presence detection #4852

Merged
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
0756853
[P159] Add LD2410 Radar presence detection
tonhuisman Oct 16, 2023
38bd3ef
[P159] Remove copy/paste evidence :-D
tonhuisman Oct 17, 2023
a3be20f
Merge branch 'mega' of https://github.com/letscontrolit/ESPEasy into …
tonhuisman Oct 18, 2023
3c81f77
[P159] Many improvements, add/update settings for sensitivity
tonhuisman Oct 21, 2023
ca48cb1
[P159] Fix compilation on LIMIT_BUILD_SIZE builds
tonhuisman Oct 22, 2023
402c5c8
[P159] Small improvements
tonhuisman Oct 22, 2023
d94d8bd
[P159] Small improvements
tonhuisman Oct 22, 2023
17db570
[P159] Add command for sensor factoryreset
tonhuisman Oct 22, 2023
cd2c6ec
Merge branch 'mega' of https://github.com/letscontrolit/ESPEasy into …
tonhuisman Oct 22, 2023
b3e1715
[Lib] LD2410: Fix bug (-1 for uint), add undocumented OutputPinState …
tonhuisman Oct 23, 2023
f3306c0
[P159] Add OutputPinState option after AmbientLight option (breaking …
tonhuisman Oct 23, 2023
0caef38
[P159] Minor change to determine how that may influence the build
tonhuisman Oct 24, 2023
f689cae
[Build] Freeze Python to 3.11 to fix pygit2 build issue
tonhuisman Oct 28, 2023
1938bf3
[P159] Add Gate0 energy values that where missing
tonhuisman Oct 28, 2023
b9030fa
Merge branch 'mega' of https://github.com/letscontrolit/ESPEasy into …
tonhuisman Oct 29, 2023
b753f5c
[Lib] LD2410: Read all data that can be read in 5 msec, add errorcoun…
tonhuisman Oct 29, 2023
5a9b6e6
[P159] Rework processing, now near-instant response
tonhuisman Oct 29, 2023
53ffcbd
[Lib] LD2410: Reformat source (nearly all is changed!) Replace yield(…
tonhuisman Oct 29, 2023
68ca970
[P159] Fix wrong use of F(""), should be EMPTY_STRING
tonhuisman Oct 29, 2023
01ed5da
Merge branch 'mega' of https://github.com/letscontrolit/ESPEasy into …
tonhuisman Nov 3, 2023
5395c92
Merge branch 'mega' of https://github.com/letscontrolit/ESPEasy into …
tonhuisman Nov 5, 2023
4b16752
Merge branch 'mega' of https://github.com/letscontrolit/ESPEasy into …
tonhuisman Nov 8, 2023
a3eea72
Merge branch 'mega' of https://github.com/letscontrolit/ESPEasy into …
tonhuisman Nov 13, 2023
c7344df
[P159] Add documentation
tonhuisman Nov 14, 2023
357ecb3
[P159] Update EasyColorMirror
tonhuisman Nov 15, 2023
30f0cb3
[P159] Update comments to explicitly name LD2410
tonhuisman Nov 15, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
504 changes: 504 additions & 0 deletions lib/ld2410/LICENSE

Large diffs are not rendered by default.

89 changes: 89 additions & 0 deletions lib/ld2410/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
# LD2410
## Introduction

An Arduino library for the Hi-Link LD2410 24Ghz FMCW radar sensor. This sensor is a Frequency Modulated Continuous Wave radar, which makes it good for presence detection and its sensitivity at different ranges to both static and moving targets can be configured.

![](ld2410andbreakout.jpg)

The code in this library is based heavily off this [piece of work for ESPHome](https://github.com/rain931215/ESPHome-LD2410) and the manufacturer datasheet.

The LD2410, as sold for configuration with the common breakout boards shown above communicates over serial at 256000 baud by default. This library allows you to configure and use the sensor over this serial connection. As the LD2410 is a device that uses a high baud rate, a microcontroller with a spare hardware UART for this communication is preferable to bit-banged software serial.

The modules also provide an 'active high' output on the 'OUT' pin which can be used to signal presence, based off the settings configured. Once the modules are configured it is not necessary to use their UART, but it provides much more information.

## Connections

The module must be powered by 5V or higher, but does 3.3v I/O, please consider this when working with the module.

![](ld2410pinout.jpg)

The default header pitch is 1.27mm, half the size of the usual 0.1" hobbyist pin headers so you may need to buy some, or carefully de-solder the existing pins to use the module.

![](ld2410pcb.jpg)

If you have the breakout board, you can use the VCC, GND, TX and RX pins to work with the module.

## Reading distances

The LD2410 has a number of 'gates', each of which correspond to a distance of about 0.75m and many of the settings/measurements are calculated from this.

You set the sensitivity at each 'gate' on a scale 0-100, any object that doesn't register above this scale is not reported on. The defaults do a good job of spotting an adult person and estimating distance.

Both moving and stationary targets are detected separately, with a value for each in centimetres. The accuracy of this distance isn't amazing but given this sensor is targeted as a replacement for something like a passive infrared sensor it's a very big improvement.

The minimal sketch to read distances is in the example 'basicSensor.ino'.

## Configuring the sensor

Each 'gate' has a sensitivity value for stationary and moving targets. You can also set a maximum gate that ignores readings beyond a certain gate for both stationary and moving targets and an 'idle timeout' for how long it reports on something after moving away.

A sketch to configure the sensor is in the example 'setupSensor.ino' it's an interactive sketch that will take commands sent over the Serial monitor. It should demonstrate all the various bits of the configuration you can change.

## Methods/variables

Many of the configuration methods return a boolean value. This is because the protocol between the LD2410 and the microcontroller involves requesting the change and the LD2410 acknowledges this with success or failure. This means these methods are synchronous, they will block until the LD2410 responds with succeed/fail or the transaction times out after 100ms.

The presence/distance readings report the most recent values as the LD2410 continuously streams data, which is processed by calling *read()* as often as is practical.

```
bool ld2410::begin(Stream &radarStream, bool waitForRadar = true) - You must supply a Stream for the UART (eg. Serial1 that the LD2410 is connected to) and by default it waits for the radar to respond so it feeds back if it is connected
void debug(Stream &debugStream) - Enables debugging output of the library on a Stream you pass it (eg. Serial)
void read() - You must call this frequently in your main loop to process incoming frames from the LD2410
bool isConnected() - Is the LD2410 connected and sending data regularly
bool presenceDetected() - Is a presence detected. Nice and simple
bool stationaryTargetDetected() - Is a stationary target detected.
uint16_t stationaryTargetDistance() - Distance to the stationary target in centimetres.
uint8_t stationaryTargetEnergy() - The 'energy'of the target on a scale 0-100, which also a kind of confidence value.
bool movingTargetDetected() - Is a moving target detected.
uint16_t movingTargetDistance() - Distance to the moving target in centimetres.
uint8_t movingTargetEnergy() - The 'energy'of the target on a scale 0-100, which also a kind of confidence value.
bool requestFirmwareVersion() - Request the firmware version, which is then available on the values below.
uint8_t firmware_major_version
uint8_t firmware_minor_version
uint32_t firmware_bugfix_version - This is coded as HEX
bool requestCurrentConfiguration() - Request the full current configuration, which you can then read with the variable & methods below.
uint8_t max_gate - The max gate ID reported by the sensor
uint8_t max_moving_gate - The highest gate ID that will report moving targets
uint8_t max_stationary_gate - The highers gate ID that will report stationary targets
uint8_t motion_sensitivity[max_gate + 1] - One value 0-100 per gate
uint8_t stationary_sensitivity[max_gate + 1] - One value 0-100 per gate
bool setMaxValues(uint8_t moving, uint8_t stationary, uint16_t inactivityTimer) - Set furthest gates and inactivitity timer for targets
bool setGateSensitivity(uint8_t gate, uint8_t moving, uint8_t stationary) - Set gate sensitivites 0-100
bool requestRestart() - Request a restart of the LD2410. Which is needed to apply some settings.
bool requestFactoryReset() - Request a factory reset of the LD2410. You need to restart afterwards to take effect.
bool requestStartEngineeringMode() - Request engineering mode, which sends more data on targets.
bool requestEndEngineeringMode() - Request the end of engineering mode.
```

## Changelog

- v0.1.1 - Readings for stationary and moving targets were transposed, now fixed. Fixes #1 - stationaryTargetDetected() always true. Many improvements to parsing of commands/acks from the LD2410 and better debug logging.
- v0.1.0 - Initial release

## Known issues/to-do list

The code is somewhat verbose/inefficient.

No support for engineering mode data yet.

Feel free to contact me with PRs, suggestions and improvements.
Loading