Medium: Radio, Wire | Pins used: 6
With ThroughLora
strategy, PJON can run through a software or hardware SPI in order to communicate with supported LoRa modules. See Supported Shields/Modules.
This strategy is a wrapper around Arduino LoRa library created by Sandeep Mistry so all the credit to the specific LoRa implementation goes to him.
Consider that, because of the inherent limitations of LoRa, the synchronous acknowledgement is not supported.
- ATmega88/168/328 16MHz (Diecimila, Duemilanove, Uno, Nano, Mini, Lillypad)
- ATmega2560 16MHz (Arduino Mega)
- ATmega16u4/32u4 16MHz (Arduino Leonardo)
- STM32F103 (Blue Pill)
- Define
PJON_INCLUDE_TL
before including PJON header<PJON.h>
- Pass the
ThroughLora
type as PJON template parameter to instantiate a PJON object ready to communicate through this Strategy. - Configure the shield/module pins according to the correct connection. See Hardware connection.
- Initialize the module with its specified frequency.
#define PJON_INCLUDE_TL //Definition to enable ThroughLora strategy
#include <PJON.h> //PJON header
PJON<ThroughLora> bus; //PJON Lora bus instance
bus.strategy.setPins(10,9,2); //CS pin, Reset pin, Interrupt pin
bus.strategy.setFrequency(868100000UL); //initialize 868 MHZ module
Manufacturer | Hardware |
---|---|
Dragino | Dragino Lora Shield |
HopeRF | RFM95W / RFM96W / RFM98W |
Modtronix | inAir4 / inAir9 / inAir9B |
Adafruit | Adafruit Feather 32u4 LoRa Radio (RFM9x) |
General Wiring | Arduino |
---|---|
VCC | 3.3V |
GND | GND |
SCK | SCK |
MISO | MISO |
MOSI | MOSI |
NSS | 10 |
NRESET | 9 |
DIO0 | 2 |
NSS
,NRESET
, andDIO0
pins can be changed by usingPJON.strategy.setPins(ss, reset, dio0)
.DIO0
pin is optional, it is only needed for receive callback mode. IfDIO0
pin is used, it must be interrupt capable viaattachInterrupt(...)
.
Here are listed basic examples of a transmitter and receiver code. After tou include the necessary code to initialize the Lora module you can use the normal PJON functions to handle data communication.
Keep in mind that to use the LoRa startegy you must download the Arduino LoRa library.
More examples can be found in https://github.com/gioblu/PJON/tree/master/examples/ARDUINO/Local/ThroughLoRa
#define PJON_INCLUDE_TL
#include <PJON.h>
PJON<ThroughLora> bus(45);
void setup() {
// Obligatory to initialize Radio with correct frequency
bus.strategy.setFrequency(868100000UL);
bus.begin();
// Synchronous acknowledgement is not supported
bus.set_synchronous_acknowledge(false);
// Send B to device 44 every second
bus.send_repeatedly(44, "B", 1, 1000000);
};
void loop() {
bus.update();
};
#define PJON_INCLUDE_TL
#include <PJON.h>
// <Strategy name> bus(selected device id)
PJON<ThroughLora> bus(44);
void setup() {
pinMode(13, OUTPUT);
digitalWrite(13, LOW); // Initialize LED 13 to be off
Serial.begin(9600);
// Obligatory to initialize Radio with correct frequency
bus.strategy.setFrequency(868100000UL);
// Synchronous acknowledgement is not supported
bus.set_synchronous_acknowledge(false);
// Optional
bus.strategy.setSignalBandwidth(250E3);
bus.begin();
bus.set_receiver(receiver_function);
};
void receiver_function(uint8_t *payload, uint16_t length, const PJON_Packet_Info &packet_info) {
/* Make use of the payload before sending something, the buffer where payload points to is
overwritten when a new message is dispatched */
if (payload[0] == 'B') {
digitalWrite(13, HIGH);
delay(30);
digitalWrite(13, LOW);
}
};
void loop() {
bus.receive(1000);
};
This API is a specific wrapper around the Arduino-LoRa library
All the LoRa API is accessible through the exposed strategy in a PJON instance. Ex: bus.strategy
Initialize the library with the specified frequency.
bus.strategy.setFrequency(frequency);
frequency
- frequency in Hz (433E6
,866E6
,915E6
)
Returns 1
on success, 0
on failure.
Override the default NSS
, NRESET
, and DIO0
pins used by the library. Must be called before LoRa.begin()
.
bus.strategy.setPins(ss, reset, dio0);
ss
- new slave select pin to use, defaults to10
reset
- new reset pin to use, defaults to9
dio0
- new DIO0 pin to use, defaults to2
, must be interrupt capable via attachInterrupt(...).
This call is optional and only needs to be used if you need to change the default pins used.
int rssi = bus.strategy.packetRssi();
Returns the RSSI of the received packet.
float snr = bus.strategy.packetSnr();
Returns the estimated SNR of the received packet in dB.
bus.strategy.setSignalBandwidth(signalBandwidth);
Change the signal bandwidth of the radio, signalBandwidth
represents the signal bandwidth in Hz, defaults to 125E3
. Supported values are 7.8E3
, 10.4E3
, 15.6E3
, 20.8E3
, 31.25E3
, 41.7E3
, 62.5E3
, 125E3
, and 250E3
.
bus.strategy.setSpreadingFactor(spreadingFactor);
Change the spreading factor of the radio. spreadingFactor
represents the spreading factor, defaults to 7
. Supported values are between 6
and 12
. If a spreading factor of 6
is set, implicit header mode must be used to transmit and receive packets.
bus.strategy.setCodingRate4(codingRateDenominator);
Change the coding rate of the radio. codingRateDenominator
represents denominator of the coding rate, defaults to 5
. Supported values are between 5
and 8
, these correspond to coding rates of 4/5
and 4/8
. The coding rate numerator is fixed at 4
.
bus.strategy.setPreambleLength(preambleLength);
Change the preamble length of the radio. preambleLength
represents preamble length in symbols, defaults to 8
. Supported values are between 6
and 65535
.
bus.strategy.setSyncWord(syncWord);
Change the sync word of the radio. syncWord
represents byte value to use as the sync word, defaults to 0x34
bus.strategy.setCRC(false); //To disable CRC
bus.strategy.setCRC(true); // To enable CRC
Enable or disable CRC usage, by default a CRC is not used.
LoRa.setTxPower(txPower); //Configure the radio TX power
LoRa.setTxPower(txPower, outputPin); //Configure the radio TX power with extra boost pin
Change the TX power of the radio.
txPower
- TX power in dB, defaults to17
outputPin
- (optional) PA output pin, supported values arePA_OUTPUT_RFO_PIN
andPA_OUTPUT_PA_BOOST_PIN
, defaults toPA_OUTPUT_PA_BOOST_PIN
.
Supported values are between 2
and 17
for PA_OUTPUT_PA_BOOST_PIN
, 0
and 14
for PA_OUTPUT_RFO_PIN
.
Most modules have the PA output pin connected to PA BOOST.
bus.strategy.idle();
Put the radio in idle (standby) mode.
bus.strategy.sleep();
Put the radio in sleep mode.
byte b = bus.strategy.getRandom();
Generate a random byte, based on the Wideband RSSI measurement.
In all cases, when installing or maintaining a PJON network, extreme care must be taken to avoid any danger. Before any practical test or hardware purchase for a wireless ThroughLoRa radio setup, compliance with government requirements and regulations must be ensured.