81 lines
4.0 KiB
Markdown
81 lines
4.0 KiB
Markdown
# LoRa-Training
|
|
|
|
An repository containing some example code written for the Raspberry Pi Pico; also contains ping pong
|
|
|
|
|
|
## Requirements
|
|
|
|
To re-run this tests, you need at least two LoRa transceivers with the chip SX127x (e.g. SX1278) connected to two different Raspberry Pi Picos.
|
|
Also - for improved "usability", attach two buttons, two leds (red for send and green for receive) and an LCD to the microcontrollers. The matching pins are for ...
|
|
|
|
|
|
**... the LoRa transceiver:**
|
|
|
|
|
|
| Device | Pin on device | Pin on Pico |
|
|
| ------ | ------------- | ----------- |
|
|
| LoRa | VCC | 36 (V3V) |
|
|
| LoRa | GND | 3 (GND) |
|
|
| LoRa | MISO | 6 (GPIO 4) |
|
|
| LoRa | MOSI | 5 (GPIO 3) |
|
|
| LoRa | SCLK | 4 (GPIO 2) |
|
|
| LoRa | NSS | 7 (GPIO 5) |
|
|
| LoRa | DIO0 | 9 (GPIO 6) |
|
|
|
|
|
|
**... further components (optional):**
|
|
|
|
|
|
| Device | Pin on device | Pin on Pico |
|
|
| ------ | ------------- | ----------- |
|
|
| LCD<sup>1</sup> | SDA | 1 (GPIO 0) |
|
|
| LCD<sup>1</sup> | SCL | 2 (GPIO 1) |
|
|
| LCD<sup>1</sup> | VCC | 40 (VBUS<sup>2</sup>) |
|
|
| LCD<sup>1</sup> | GND | 3 (GND) |
|
|
| BTN1 | Pin 1 | 36 (V3V) |
|
|
| BTN1 | Pin 2 | 10 (GPIO 7) |
|
|
| BTN2 | Pin 2 | 11 (GPIO 8) |
|
|
| BTN2 | Pin 1 | 36 (V3V) |
|
|
| LED green | + | 31 (GPIO 26) |
|
|
| LED green | - | 33 (GND) |
|
|
| LED red | + | 32 (GPIO 27) |
|
|
| LED red | - | 33 (GND) |
|
|
|
|
|
|
<sup>1</sup> with PCM5102 I<sup>2</sup>C port multiplexer
|
|
|
|
<sup>2</sup> works only if the pico's connected over USB
|
|
|
|
|
|
|
|
## Installation
|
|
|
|
|
|
To get the tests to run, start by uploading all the content of this repo on the two (ideally empty) Pi Picos with **[MicroPython](https://micropython.org/download/?vendor=Raspberry%20Pi)** installed on. To do this, use e.g. **[Thonny](https://thonny.org/)**.
|
|
|
|
Also make sure you have at least added the LoRa transceiver module, otherwise nothing will work.
|
|
|
|
Now, depending on whether the lcd and buttons are installed or not (always buttons AND lcd, only one of these won't work), open the `main_+lcd.py` for running with lcd screen and `main_-lcd.py` else.
|
|
Save the opened one as main.py, so that this script (the main.py) is run at startup (when you connect power). Don't worry - you will still be able to access the data on the pico just by interrupting the execution using e.g. Thonny.
|
|
The LEDs will always turn on and off - if there are none connected, there's just no light. No way to disable that easily (you'd have to refactor all the files as LED pins are hardcoded sometimes :).
|
|
|
|
By default, the main_-lcd.py file will execute an ping-pong program as the responder. As a responder, it waits for the first message and short after receiving it, sends the response including info e.g. about the signal quality. To change this behaviour, change the variable `to_run` right in this file.
|
|
|
|
When running the main_+lcd.py file, you are able to choose whether to run as a ping-pong responder, initializer, just simple sender, etc. from the list by navigating with the two buttons (this is done with the **[ProgramChooser library](https://git.privacynerd.de/BlueFox/ProgramChooser)**).
|
|
|
|
|
|
## Credits and useful links
|
|
|
|
Lastly, thanks to all the people sharing their code, e.g. the driver for the SX127x chip series ported for MicroPython on the Pico.
|
|
Here are some links:
|
|
|
|
- [The driver library used in this tests](https://github.com/lemariva/uPyLoRaWAN/)
|
|
- [Tutorial introducing main steps to get the SX127x board to run](https://www.electroniclinic.com/raspberry-pi-pico-w-with-lora-sx1278-for-sensor-monitoring/)
|
|
- [Website providing some pinout and info](https://wei1234c.blogspot.com/2017/08/sx127x-lora-transceiver-driver-for.html)
|
|
- [More pinout and stuff :)](https://www.electroschematics.com/rf-radio-frequency/)
|
|
- [Interesting article for building general LoRa knowledge](https://circuitdigest.com/microcontroller-projects/arduino-lora-sx1278-interfacing-tutorial)
|
|
|
|
|
|
## License
|
|
|
|
The scripts contained here are licensed under the GNU GPLv3-or-later. A copy of this license can be found in the [LICENSE](LICENSE) file |