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

Updated to VL53LXX and Buttons & Switches #1376

Closed
wants to merge 4 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
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
2 changes: 1 addition & 1 deletion docs/Buttons-and-Switches.md
Original file line number Diff line number Diff line change
Expand Up @@ -237,7 +237,7 @@ Multipress functions for 2 and more presses cannot be changed using SetOptions o
!!! note "If [ButtonRetain](Commands.md#buttonretain) has been enabled the MQTT message will also contain the MQTT retain flag."

!!! danger
When a button is configured as inverted or with a [Switchmode](Commands.md#switchmode) that keeps it as ON while depressed it activates the reset to firmware defaults function. Change the Button configuration or SwitchMode to avoid repeated reset to defaults or use `Setoption1 1` to disable that function.
When a button is configured as inverted so that it is read as pressed when not depressed, the reset to firmware defaults function will be activated. Change the Button configuration to avoid repeated reset to defaults or use `Setoption1 1` to disable that function.

!!! warning
If you define a button with a number higher than available power outputs it will default to controlling `Power1`. Example: Button4 on a device with Power1 and Power2 will control `Power1`.
Expand Down
52 changes: 25 additions & 27 deletions docs/VL53Lxx.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,11 @@

The VL53L0X and VL53L1X are Time-of-Flight (ToF) laser-ranging devices from ST MicroElectronics commonly available on small modules.

In the documentation below, VL53LXX is used whenever the information applies to either VL53L0X or VL53L1X. The exact name is used for any information that is specific to the specific model.
In the documentation below, VL53LXX is used whenever the information applies to either the VL53L0X or the VL53L1X. The exact names are used for information that are model specific.

## The devices

About how to install those sensor and how to adapt the laser operation for several use-cases, please check:
For specifics on how to install and adapt these sensors for specific use-cases, please consult the datasheet. You will also find information on the supported distances and the impact of the reflectance of the target object and the amount of ambient light and how those are effected by each mode.

* Datasheet [VL53L0X](https://www.st.com/resource/en/datasheet/vl53l0x.pdf)
* Datasheet [VL53L1X](https://www.st.com/resource/en/datasheet/vl53l1x.pdf)
Expand All @@ -37,9 +37,8 @@ About how to install those sensor and how to adapt the laser operation for sever
| Max distance | 2000 | 4000 | mm |
| Field of vision | 25 | 27 | ° |

For more details on the supported distance range depending on the mode, the reflectance of the object and the ambient light regarding the different modes, please refer to the datasheets.

If you are going to use long I2C wires read [this article](https://hackaday.com/2017/02/08/taking-the-leap-off-board-an-introduction-to-i2c-over-long-wires/)
If long I2C wires will be used, please consult [this article](https://hackaday.com/2017/02/08/taking-the-leap-off-board-an-introduction-to-i2c-over-long-wires/)

## Breakout Boards

Expand All @@ -58,51 +57,51 @@ Sample boards for VL53L0X. Similar boards exist for VL53L1X.
|SCL | GPIOb

### Tasmota Settings for single sensor
In order to use a VL53LXX sensor you need to:
To use a VL53LXX sensor one must:
- configure ESP GPIOs for I2C bus
- enable the right driver

#### Step 1 - Configure I2C
In the **_Configuration -> Configure Module_** page assign:
In the **_Configuration -> Configure Module_** page, assign:

1. GPIOa to `I2C SDA`
2. GPIOb to `I2C SCL`

On ESP8266 almost any GPIO can be used for I2C except for GPIO15. However the standard is to use GPIO4 (D1) for I2C SCL and GPIO5 (D2) for I2C SDA.
On an ESP8266, almost any GPIO can be used for I2C except for GPIO15. However the standard is to use GPIO4 (D1) and GPIO5 (D2) for I2C SCL and I2C SDA, respectively.

On ESP32 any pin can be assigned to I2C.
On ESP32 any pin can be assigned to I2C SDA and I2C SCL.

#### Step 2 - Enable the proper driver
I2C devices are identified on the I2C bus by their address. Because the number of possible addresses are limited (127) a lot of devices are sharing the same address. This as means that it is not possible to use simultaneously on the same I2C bus 2 devices that are using the same address. Beside, in most cases, a driver cannot correctly identify the chip it is talking to. This is why in most of the case it is important to disable Tasmota drivers for devices that you are not using and leave enabled only driver for a device you are going to use.
I2C devices are identified on the I2C bus by their address. Because the number of possible addresses is limited to 127 a lot of devices share the same address. It is not possible to simultaneously use two devices using the same address on a single I2C bus. Also, typically, a driver cannot correctly identify the chip it is communicating with. Due to this fact, in most cases, the drivers for devices that will not be used must be disabled.

In the list of [I2CDEVICES](I2CDEVICES) supported by Tasmota it is listed that the address 0x29 can be used by either TSL2561 (driver 16), VL53L0X (driver 31), TSL2591 (driver 40) and VL53L1X (driver VL53L1X). It means that you can't use a TSL2561 or a TSL2591 at the same time as a VL53L0X/VL53L1X. And you can't use a VL53L0X at the same time as a VL53L1X.
The list of supported [I2CDEVICES](I2CDEVICES) the address 0x29 can be used by the TSL2561 (driver 16), the VL53L0X (driver 31), the TSL2591 (driver 40), or the VL53L1X (driver VL53L1X). This means that a TSL2561 or a TSL2591 cannot be used at the same times as a VL53L0X or VL53L1X. Also, a VL53L0X cannot be used at the same time as a a VL53L1X.

If you have build a tasmota binary that include the driver for TSL2561 and/or TSL2591 you must disable those drivers. You must also disable the driver for the other VL53LXX device. As a summary, here are the command to type in the console:
If your Tasmota binary includes the drivers for the TSL2561 and/or the TSL2591 they must disabled. Similarly, the driver for the other VL53LXX device must also be disabled. Here are the commands to type in the console for each sensor:

* To use a VL53L0X : `backlog i2cdriver16 0;i2cdriver40 0;i2cdriver31 1;i2cdriver54 0`
* To use a VL53L1X : `backlog i2cdriver16 0;i2cdriver40 0;i2cdriver31 0;i2cdriver54 1`


After a reboot Tasmota will detect the VL53LXX automatically is the proper driver has been enabled.
After configuring these optinos, Tasmota will reboot and detect the correct VL53LXX device automatically.

![image](_media/peripherals/vl53l0x.png)

Sensor sends a `tele/%topic%/SENSOR` JSON response:
These sensors send a `tele/%topic%/SENSOR` JSON response:

For VL53L0X:
For the VL53L0X:
```json
{"Time":"2019-12-20T11:29:22","VL53L0X":{"Distance":263}}
```
Or for VL53L1X
For the VL53L1X
```json
{"Time":"2019-12-20T11:29:22","VL53L1X":{"Distance":263}}
```

## Configuration for Multiple VL53LXX sensors in parallel

Tasmota supports by default up to 8 of these sensors in parallel. Note that they all must be of the same model (either all VL53L0X or all VL53L1X). In any case, the above I2C GPIO and I2C driver configuration remain valid.
Tasmota, by default, supports up to 8 of sensors of the same model in parallel. The I2C GPIO and I2C driver configuration listed above are the same.

When using multiple VL53LXX, it is required to wire the XSHUT pin of each sensors to a dedicated free GPIO and assign as `VL53LXX XSHUT` 1 to 8. This is to let Tasmota change by software the I2C address of those and give them an unique address for operation. The sensor don't save its address and this procedure is performed automatically at every restart. The Addresses used for this are by default 0x78 (120) to 0x7F (127). As for a single sensor, you must not use any other I2C device on those addresses. As the date of writing, there is currently no I2C device supported by Tasmota with those addresses. However such devices exists and may be supported by later versions of Tasmota. You can change the relocation address by a compile option, see the [compile options](#compile-options) section.
When using multiple VL53LXX devices the XSHUT pin of each sensor must be wired to a dedicated GPIO and assigned as `VL53LXX XSHUT` 1 to 8. This allows Tasmota to programatically change the I2C address of each sensor so that they are unique. The sensors don't save this new address so this procedure is performed automatically at every restart. The addresses used for this are, by default, 0x78 (120) to 0x7F (127). As a consequence, no other devices can use those addresses. As of January 2023, there are no I2C devices supported by Tasmota with those addresses. However, such devices exist and may be supported by later versions. You can change the reassigned addresses via a compile option, see the [compile options](#compile-options) section.

### Wiring for Multiple Sensors
| VL53LXX-1 | VL53LXX-2 | VL53LXX-3 | ... | ESP |
Expand All @@ -118,7 +117,7 @@ When using multiple VL53LXX, it is required to wire the XSHUT pin of each sensor

On ESP8266, please refer to the guide [Expending Tasmota](Expanding-Tasmota#gpio-overview) for suitable GPIOs. GPIO 1 and 3 being used by serial console are generally unadvised. GPIO15 has a pull-down on every ESP board to allow proper boot. If you want to use this GPIO for a XSHUT, you must remove the pull-up resistor that is on the VL53LXX module otherwise your ESP will not boot.

On ESP32 any GPIO that can be an output can be used.
On ESP32 any GPIO that can be configured as an output can be used.

### Tasmota Settings for multiple sensors
In the **_Configuration -> Configure Module_** page assign:
Expand All @@ -130,7 +129,7 @@ In the **_Configuration -> Configure Module_** page assign:
5. GPIOe to `XSHUT 3`
6. ...

After a reboot Tasmota will detect each VL53LXX in sequence and after auto-configuring them, it will display distance in mm.
After a reboot Tasmota will detect each VL53LXX in sequence and after re-addressing them, the distance will be displayed in mm.

Example: for VL53L0X it sends `tele/%topic%/SENSOR` JSON such as:

Expand All @@ -140,7 +139,7 @@ Example: for VL53L0X it sends `tele/%topic%/SENSOR` JSON such as:

With VL053L1X, the name of the sensor is adapted.

The index separator is either a `-` if `SetOption4` is `0` or a `_` if it is `1`. See [`SetOption4`](Commands.md#setoption4).
The index separator is either `-` if `SetOption4` is set to `0` or `_` if `SetOption4` is set to `1`. See [`SetOption4`](Commands.md#setoption4).

![image](https://user-images.githubusercontent.com/35405447/111362860-144c4780-866e-11eb-84f1-461d2857ede7.png)

Expand All @@ -154,7 +153,7 @@ The index separator is either a `-` if `SetOption4` is `0` or a `_` if it is `1`

* **MAXIMUM AMOUNT OF SENSORS:** Tasmota supports by default up to 8 of these sensors in parallel. Expanding this limit is possible but backwards incompatible. The default value of VL53LXX_MAX_SENSORS is set in the file tasmota.h

* **XHUT Relocation address** The addresses at which the VL53LXX are relocated when using XSHUT can be changed by a define in `user_config_override.h` file. Replace the `0x78` for the 1st address. You need that as many consecutives address are free for the number of devices you are using.
* **XHUT Relocation address** The addresses the VL53LXX are relocated to when using XSHUT can be changed by a define in the `user_config_override.h` file. Replace the `0x78` with the 1st address. Each successive sensor will use the next address. All addresses must be free of other devices.
For VL53L0X use:
```cpp
#define VL53L0X_XSHUT_ADDRESS 0x78
Expand All @@ -166,24 +165,23 @@ For VL53L1X use:

### VL53L0X options

* **VL53L0X LONG RANGE:** By default VL53L0X reads up to 1.2 meters. If you want to use the long range mode (up to 2.2 meters), you need to add a define in `user_config_override.h` file:
The VL53L0X can operate in one of 4 ranging profiles. They are Default, Long Range, High Speed, and High Accuracy. The default Ranging Profile can read up to 1.2 meters and provides a good mix of accuracy and speed. The Long Range Mode profile can read distances up to 2.2m. However, this profile is more susceptible to reflections from objects otehr than the target and to ambient light. This profile works best in dark conditions. The High Speed profile will give the fastest readings and the High Accuracy profile will result in the most accurate readings but be slower than the other three profiles. The profile can be onfigured by adding one of the following to the `user_config_override.h` file.
* **VL53L0X LONG RANGE:**
```cpp
#define VL53L0X_LONG_RANGE
```
This increases the sensitivity of the sensor and extends its potential range, but increases the likelihood of getting an inaccurate reading because of reflections from objects other than the intended target. It works best in dark conditions.

* **VL53L0X_HIGH_SPEED** vs **VL53L0X_HIGH_ACCURACY** Either or the other can be added in `user_config_override.h` file to change the default compromise to either proceed at higher speed (but at the cost of accuracy) or at higher accuracy.
* **VL53L0X_HIGH_SPEED:**
```cpp
#define VL53L0X_HIGH_SPEED
```
or
* **VL53L0X_HIGH_ACCURACY:**
```cpp
#define VL53L0X_HIGH_ACCURACY
```

### VL53L1X options

* **Distance range** can be changed between *Long*, *Medium* or *Short* by copying one (and only one) of the below lines in `user_config_override.h`. The default value is **Long**. For details on those range, please refer to the [datasheet](#the-devices) of the device.
* **Distance range** can be changed. The options are *Long*, *Medium*, and *Short*. Copy one, and only one, of the following lines into `user_config_override.h`. The default value is **Long**. For details on the resulting range please refer to the [datasheet](#the-devices).
```cpp
#define VL53L1X_DISTANCE_MODE Long
#define VL53L1X_DISTANCE_MODE Medium
Expand Down