-
Notifications
You must be signed in to change notification settings - Fork 13
5. Examples
CatWAN Arduino LoRa Shield supports LoRa and LoRaWAN technologies. In the following section, we will explore how to utilize each of these technologies with different examples.
For the following examples, we will use two CatWAN USB Sticks, one to send information and the other to sniff it.
CatWAN USB Stick SAMD21 915 MHz version
|
CatWAN USB Stick RP2040 915 MHz version
|
Remember that to use your CatWAN USB Stick you need to have different libraries installed. If you have not installed it yet, check the section: Install the Libraries.
The LoRa technology, on its own, is ideal for applications that require long-range communication and low energy consumption. Its main uses include sending and receiving information over considerable distances, as well as remote control.
In the LoRa examples, we will show seamless communication between two boards using LoRa technology. To achieve this we will need two CatWAN USB Sticks that have LoRa technology.
In this case, we will use a CatWAN USB Stick RP2040 version and a CatWAN USB Stick SAMD version.
For this first example, we will use the basic examples from the repository, for the examples from the CatWAN USB Stick SAMD version you can find them in the LoRa examples folder.
In the case of using a CatWAN USB Stick RP2040 version, you must download the examples directly from the Latest Release.
So, we will upload the "LoRaReceiver example code" to our CatWAN USB Stick SAMD version.
Then, we will upload the "lorasender.uf2" to our CatWAN USB Stick RP2040 version.
CatWAN USB Stick RP2040 Release
After this, our boards should start communicating and now we will be able to see the values we receive through the serial port:
Serial Output
Typing help in the serial terminal we can see the commands that the LoRa Sniffer tool has:
Fw version: 0.2v
Configuration commands:
set_rx
set_tx
set_tx_hex
set_tx_ascii
set_chann
set_freq
set_sf
set_bw
set_cr
Monitor commands:
get_freq
get_sf
get_bw
get_cr
get_config
set_rx -> LoRa Sniffer goes into rx mode and changes rx_status to 1 if the frequency value is between 902 MHz and 923 MHz, it can accept the frequency value as an argument.
set_freq -> Sets the frequency between 902 MHz and 923 MHz.
set_sf -> Sets the spread factor value between 6 and 12.
set_cr -> Sets the coding rate value between 5 and 8.
set_bw -> Sets the bandwidth value using 0 - 8.
0 - Bandwidth set to 7.8 kHz
1 - Bandwidth set to 10.4 kHz
2 - Bandwidth set to 15.6 kHz
3 - Bandwidth set to 20.8 kHz
4 - Bandwidth set to 31.25 kHz
5 - Bandwidth set to 41.7 kHz
6 - Bandwidth set to 62.5 kHz
7 - Bandwidth set to 125 kHz
8 - Bandwidth set to 250 kHz
set_tx - > Use a series of xxx values separated by spaces. The value xxx represents a 3-digit number.
set_tx_hex -> Use a series of yy values separated by spaces. The value yy represents any pair of hexadecimal digits.
set_tx_ascii -> Use for sending ASCII messages.
set_chann -> Sets the LoRaWAN channel value between 0 and 63.
get_freq -> get frequency value.
get_sf -> get spreading factor value.
get_cr -> Get coding rate value.
get_bw -> Get bandwidth value.
get_config -> Get radio configurations.
input->
set_freq 903.9
set_sf 8
set_cr 5
set_rx
output->
Frequency set to 903.90 MHz
Spreading factor set to 8
CodingRate set to 4/5
LoRa radio receiving at 903.90 MHz
...
Received packet '
19 bytes ' 401F80C0ED000305018BB696B5827DFEA36D33
ASCII: '@⸮&⸮⸮⸮⸮⸮}⸮⸮m3' with RSSI -81
Received packet '
19 bytes ' 401F80C0ED00070501D8FF1D53C1976AAEEF71
ASCII: '@⸮&⸮⸮S⸮⸮j⸮⸮⸮q' with RSSI -122
input ->
set_tx_hex AB CD EF 12 34 56 78 90
output ->
171 205 239 18 52 86 120 144
8 Byte(s) sent
input ->
set_tx 123
output ->
123
1 Byte(s) sent
input ->
set_tx_ascii hello_world
output ->
hello_world ASCII message sent
Thank you for reading our Wiki!