Nwave LoRaWAN Parking Sensor - Getting Started
Table of contents
- 1 1 Principle of operation
- 2 2 Calibration and first commissioning
- 3 3 LoRaWAN Interface
- 4 4 Application protocol description
- 4.1 4.1 Additional features
- 4.2 4.2 Uplink messages
- 4.2.1 4.2.1 Parking status
- 4.2.2 4.2.2 Heartbeat
- 4.2.3 4.2.3 Startup
- 4.2.4 4.2.4 SDI tag registration message
- 4.2.5 4.2.5 Debug messages
- 4.2.6 4.2.6 Configuration feedback message
- 4.3 4.3 Downlink messages
- 5 5. Changelog
1 Principle of operation
Data from the device’s sensors are processed by the device's embedded algorithm. The algorithm output is the parking state “free” or “occupied”. Device checks, if the parking status has been changed since the last processing run and in case the parking state change will be communicated via the LoRa interface. This means, that the parking sensor will only report if the parking state has been changed. Generally, the parking state detection time is about 3 seconds after conditions were stabilized (a vehicle stopped above the sensor or left the parking lot completely).
Considering an additional delay caused by the LoRa transmission and possibly re-transmissions, transmission time limitation of every device, transmission from the Gateway to the LoRa network, and processing by the LoRa network, the complete delay from new parking status until the state becomes visible in the LoRa application server maybe 4 or more seconds.
2 Calibration and first commissioning
Default sensor firmware was designed to minimize power consumption and radio spectrum usage until the sensor will be installed. When a sensor has been installed it is necessary to calibrate it using Nwave Device Management App. The first calibration works as an activation procedure and only after the first calibration the sensor will start detecting vehicles and try to join a LoRaWAN network.
Calibration must be done when the sensor is vacant(no car above the sensor). If the sensor was removed and then installed again it must be calibrated again. There is a slower automatic calibration that is designed to adjust to changing environmental conditions. Even if the initial calibration has been made with a car above the sensor or the sensor was moved after the last manual calibration the automatic calibration will make the sensor work but it can require some undetermined time depending on environment.
Note for developers:
If the sensor was moved or rotated you need to calibrate it in order to make it detect vehicles correctly. You can use a phone to simulate vehicle, to do it put it on the sensor covering square in the middle. You can stick the sensor with double-sided tape to something that does not move(floor or a table) to prevent sensor from moving or rotating.
3 LoRaWAN Interface
A parking sensor device is equipped with a LoRa radio operated in Class A. The implemented functionality complies with the LoRaWAN Specification 1.0.3.
The frequencies supported and receive window parameters follow the LoRaWAN v1.0.3 EU868 Regional Parameters rev. a.
3.1 Join Procedure
The first calibration initiates the join process. The Join procedure follows the Over-the-Air Activation (OTAA) described in the LoRaWAN Specification 1.0.2. Activation By Personalization (ABP) is not supported.
After powering up the parking sensor device, it will try to join a LoRaWAN Network by sending the join request message. In case the join request is not answered, the sensor will retry as soon as possible, according to transmission time limitations, up to 4 additional times (5 attempts in total). After the 5th unsuccessful attempt, the sensor will wait with exponentially increasing intervals (see chapter 3.2) and repeat the process 5 more times.
If the Join request message will not be answered with a Join Accept message, the sensor retries, according to the following sequence:
In case the Join accept message is received while attempts 3, 4, or 5, the sensor restores the configured DataRate to the default value (DR2) if the data rate used was lower than the configured data rate(4.3.2). This behavior assumes that the configured DataRate does not allow communication with the Gateway.
For regions where multiple frequency sub-bands exist(like US915) it is necessary to keep in mind that in default firmware only 1 sub-band is enabled(4.1.2).
For force new join attempt after initial calibration you can reboot the sensor via DM App.
3.2 Exponentially increasing intervals
If the join sequence will not successful the sensor retries again with exponentially increasing intervals. The intervals are: 1, 2, 4, 8, 16, 32, 64, 128 minutes. Once reached 128 minutes, the wait time is always 128 minutes. There is also an additional random delay from 0 to 32 seconds added every time to the selected interval.
3.3 Device EUI
The device EUI of the sensor is pre-provisioned during production and may be derived from the serial number printed on the sensor casing. The device EUI may be derived from the serial number as in this example:
If the serial number will be 123456, the device EUI is 00 E8 BF 3B 00 12 34 56.
Exchanging the DevEUI of the sensor is not possible.
3.4 Application EUI
The AppEUI is pre-provisioned during production and will be delivered with the sensor zone. Exchanging the AppEUI of the sensor is currently impossible.
3.5 Application Key
The AppKey is pre-provisioned during production and will be delivered with the sensor zone. Exchanging the AppKey of the sensor is impossible.
4 Application protocol description
After a successful join (join accepted message is received) the sensor will send a startup message, then starts with the normal operation and send park status messages whenever a change is detected. Most part of the application messages (startup message, heartbeat message, and parking state message) are sent as confirmed by default. In case of the confirmation is not received, the sensor will retry 7 more times, adapting the DataRate as recommended in the LoRaWAN v1.0.2 spec(look at 18.4 Data-Rate Adaptation during Message Retransmissions and 18.1 Uplink Timing Diagram for Confirmed Data Messages).
The parking state message can be configured as not confirmed with or without repetitions. It reduces gateway utilization to acknowledge all messages, but may also reduce the percentage of successfully received messages by the Gateway.
The DataRate is used in the uplink messages by the sensor is DR2 by default but may be configured(4.3.2) from DR0 to DR5(for EU868).
Nwave Parking Sensor does not enable Adaptive Data Rate(ADR), as RF conditions of a sensor depend significantly on whether there is a vehicle above the sensor or not. Adjacent vehicles are also able to impact the RF conditions. As in the case of ADR, it is the network server's responsibility to correctly choose data rate, and this is done with the assumption that RF conditions are stable, so this could lead to unpredictable behavior.
The application protocol may be subject to change. The functionality may be extended in the next versions.
4.1 Additional features
4.1.1 Short stay filtration
Nwave parking sensor is able to detect cars in a very short time(within 5 seconds after car stopped) but there are some cases when sending messages for each short parking session is not desirable. For example, in a situation where the gateway is far away from the sensor and you need to use low datarate(DR0, DR1) but the place is often used as a drop-off point it may be necessary to use short stay filtration to save energy and decrease airtime to enable more sensors per gateway. Or for example, if sensors are mainly used to enforce parking rules and are not used to show real-time data it can be useful to use parking status messages with confirmation and probably low data rate but to have a significant delay after occupation before parking status message is sent.
The short stay filtration implemented in Nwave parking sensor consists of 2 different mechanisms(4.3.6):
static filtration by using Minimal occupation duration. Minimal occupation duration sets the delay between occupation and parking status message transmission.
adaptive filtration by setting expected maximum of parking sessions per day. If there are more sessions than were expected the sensor will try to gradually increase the delay between occupation and parking status message transmission. The maximum delay that can be set by this mechanism is 100 seconds.
In both cases, if parking session was too short, no messages will be sent. Both filtration mechanisms can work together. In some cases delay before message transmission can be caused duty cycle restrictions rather than short stay filtration. Short stay filtration does not affect sending parking status messages when vehicle released the sensor.
4.1.2 Preconfigured frequency sub-bands for US915 and AU915
By default sensors for these regions are sent with preconfigured FSB2. If you need another sub-band or full band enabled please contact Nwave.
4.2 Uplink messages
Uplink messages are those sent from the sensor to the network. The device has four (4) types of Uplink messages:
Parking status - port 1
Heartbeat - port 2
Startup - port 3
SDI tag registration - port 10
The simplest method of getting occupancy status from 1 and 2 is shown in the following Java Script code example:
You can also refer to our Java Script payload decoder shared on the Github.
Examples of decoded messages are available on the TTN device page.
Please refer to the sections below for detailed information on message payload structure.
4.2.1 Parking status
The parking status message uses port 1 and is confirmed by default. It may be configured as unconfirmed with or without repetitions (see downlink messages).
Byte | Bits | Name |
---|---|---|
0 | 0 | Parking status 0: Free parking space 1: Occupied parking space |
7..1 | Compressed duration of the previous status |
Compressed duration of the previous status may be used to restore (with some limitation) the time of the previous status change(the same as the time of the last Parking Status message, may differ from the time of actual parking event if the Parking Status message was delayed due to some limitations ) if the previous parking status message was lost. It makes historic data more consistent if connectivity is not 100% (for example, if parking status messages are configured as unconfirmed).
The following table demonstrates how to calculate the previous status duration using the compressed value.
Compressed duration | Calculated duration(full minutes) | Maximum compression error(minutes)** |
---|---|---|
compressed_duration < 90 | compressed_duration | 0 |
90 ≤ compressed_duration <120 | 90 + (compressed_duration - 90)*5 | 4 |
120 ≤ compressed_duration <127 | 240 + (compressed_duration - 120)*60 | 59 |
127 | >= 660 | undefined |
** Total error of previous status duration consists of:
Maximum compression error;
Rounding error up to 1 minute because duration is calculated in full minutes;
Transmission delay caused by LoRaWAN in-air limitations.
This error is additive, so the actual previous status duration is in the range [Calculated duration .. Calculated duration + total error].
4.2.2 Heartbeat
The heartbeat message uses port 2 and it is always confirmed. The heartbeat message contains parking status and information necessary for sensor health monitoring and it is sent every 24 hours (by default).
Byte | Bits | Name |
---|---|---|
0 | 0 | Parking status 0: Free parking space 1: Occupied parking space |
7..1 | Error Mask | |
1 | 7..0 | Battery voltage. To convert to actual voltage: Vbat = (2500 + X*4)mV, where X is the value of the byte as unsigned integer This parameter can be used as a source for Low Battery Alert:
|
2 | 7..0 | Temperature at which battery voltage was obtained * |
3 | 7..0 | Minimum temperature during last 24 hours * |
4 | 7..0 | Maximum temperature during last 24 hours * |
5 | 7..6 | Nwave debug data. Ignore these bytes. |
5..0 | Average current consumption estimation for the last 24 hours. Only power consumption of embedded sensors is used in the estimation(LoRaWAN messages transmission/reception consumption is not used in the estimation). To convert this value (unsigned integer) to current consumption: Current consumption = (X + 10)uA. Current consumption should be less than 50uA. Please contact Nwave support if you get higher numbers (X>40). |
Heartbeat messages allow the device’s health monitoring using Error Mask, where all zeros mean that no hardware issues were detected.
Heartbeat messages are also used to initiate the re-join procedure (which is similar to the join procedure). If a count of sequential heartbeat messages without acknowledgment is bigger than the Heartbeat NACK limit (described in 4.2.5) re-join procedure will be initiated. This behavior assumes that the connection with the network has been lost. This is generally a good indicator that the Gateways are not able to maintain stable communication with the sensor.
* All temperatures have good linearity but their absolute offset can be +/- 5C in the temperature range 30..80C(contact nwave if you need more accurate temperature measurements). To convert the transmitted value into temperature in Celsius:
T = (t/2 + 10), where t is the value of the transmitted byte as signed integer(two's complement).
4.2.3 Startup
The startup message uses port 3 and it is always confirmed. It will be sent after every startup/reboot / (re-) join event:
Byte | Name |
---|---|
0 | Major part of version number |
1 | Minor part of version number |
2 | Micro part of version number |
3 | Reset cause 0x00 No reset ( Startup message after re-joining LoRaWAN network) 0x01: Watchdog reset 0x02: Power On Reset 0x03: User Request Reset 0x06 - Brownout Reset 0x07 - Others |
4 | Bit 0 - parking status 0: Free parking space Bits 7..1 - reserved |
4.2.4 SDI tag registration message
The SDI tag registration message uses port 10 and it is always confirmed. It provides 32 bit SDI tag serial ID (Big Endian)
Bluetooth tag setup and principles of work
Byte | Name |
---|---|
0 | This byte value depends on when Registration message is being sent:
|
1 | SDI tag serial address, bits 31..24 |
2 | SDI tag serial address, bits 23..16 |
3 | SDI tag serial address, bits 15..8 |
4 | SDI tag serial address, bits 7..0 |
4.2.5 Debug messages
The Debug messages use port 6 and they are always unconfirmed. By default, these messages are enabled and have no repetitions, but they may be disabled or increased by the number of repetitions used (see downlink messages). These messages do not have a fixed length as their payload depends on the type of debug message.
The first 2 bytes of the payload represent the debug code in Big Endian format, and the rest of the payload(if any) contains additional parameters which meaning depend on the exact debug code.
Debug code | Meaning | Additional parameters |
---|---|---|
404 (0x194) | Calibration has been competed. The calibration could have been an initial calibration after activation or requested by user calibration. Automatic calibration (adjustment to changing environment) does not cause this message to be sent. | 1 byte |
899 (0x383) | Invalid user request. The downlink command has not been recognised or provided configuration cannot be used. | None |
805 (0x325) | No change in configuration. Provided configuration parameters are equal to the current parameters in use | None |
4.2.6 Configuration feedback message
Nwave parking sensor allows reading its current configuration. The request to read the configuration can be sent via Downlink messages. It can be done in two ways:
by requesting it via Command(4.3.8)
by appending the acknowledgment flag to the Full configuration downlink message(4.3.7)
The configuration feedback message uses port 7 and is always confirmed. The structure of the message is equal to Full configuration downlink message(4.3.7)
4.3 Downlink messages
Downlink messages are those sent from the Network to the Sensor. The sensor supports confirmed and unconfirmed downlink messages.
4.3.1 Parking status confirmable configuration
Parking status confirmable configuration uses port 51 and it applies only to the parking status message. The default value is Confirmed (0x00). The configuration selected is persistent.
4.3.2 DataRate configuration
DataRate configuration uses port 52. There are different configurations for data rate when the sensor assumes that it is occupied and when it assumes that it is vacant. The default value is DR2 (0x02) for the occupied state and DR3 (0x03) for the vacant state. The selected configuration is persistent unless overwritten in the join procedure. Higher DataRates increases the battery lifetime of the sensor but may reduce the reliability of the reception of messages by the Gateway. This is especially the case for unconfirmed messages. The data rate for “vacant” state must be not less than for “occupied” state.
Byte | Bits | Name | Default value |
---|---|---|---|
0 | 2..0 | DataRate configuration for “vacant” state | 3 (DR3) |
3 | Reserved |
| |
6..4 | DataRate configuration for “occupied” state. This data rate is also used during first 2 attempts in Join cycly sequence. | 2 (DR2) | |
7 | Reserved |
|
DataRate configuration value | DataRate(Spreading Factor) EU868 |
---|---|
0 | DR0 (SF12BW125) |
1 | DR1 (SF11BW125) |
2 | DR2 (SF10BW125) |
3 | DR3 (SF9BW125) |
4 | DR4 (SF8BW125) |
5 | DR5 (SF7BW125) |
DataRate configuration value | DataRate(Spreading Factor) US915 |
---|---|
0 | DR0 (SF10BW125) |
1 | DR1 (SF9BW125) |
2 | DR2 (SF8BW125) |
3 | DR3 (SF7BW125) |
4 | DR4 (SF8BW500) |
4.3.3 Heartbeat frequency
Heartbeat frequency uses port 53. The default value is 23 what is equal to 24 hours. The configuration selected is persistent.
Byte | Name |
---|---|
0 | Heartbeat interval configuration Interval = (value+1)hours |
4.3.4 Debug configuration
Debug configuration uses port 56 and is used to enable or disable the Debug messages (see uplink messages) and select the number of repetitions. By default, the Debug messages are enabled with 0 repetitions. The configuration selected is persistent.
4.3.5 Heartbeat NACK limit
Heartbeat NACK limit configuration uses port 72 and is used to specify how many heartbeat messages may be unacknowledged without initiating re-join procedure. The selected configuration is persistent. The default value is 3. 15 (0xF) and it is a special value that disables re-join functionality completely.
Byte | Bits | Name | Default value |
---|---|---|---|
0 | 3..0 | Heartbeat NACK limit | 3 |
7..4 | Reserved | 0 |
4.3.6 Short stay filtration configuration
Short stay filtration can be used to optimize battery power consumption and decrease airtime (to decrease gateway utilization and to enable more sensors to be served by each gateway). It uses port 73 and the selected configuration is persistent.
Byte | Bits | Name | Default value |
---|---|---|---|
0 | 7..0 | Expected maximum count of sessions per day. Value 0 is special and means that adaptive filtration is disabled. | 35 |
1 | 7..0 | Minimal occupation duration. The value of delay between occupation detection and Parking Status message transmission is DELAY = value * 10s. The delay before transmission can be different due to LoRaWAN duty cycle restrictions. | 0 |
4.3.7 Full configuration
The full configuration uses port 70 and is used to configure all parameters in one message.
Byte | Bits | Name | Default value |
---|---|---|---|
0 | 2..0 | Parking status confirmable configuration (4.3.1 ) | 0 |
3 | Reserved | 0 | |
6..4 | Debug configuration (4.3.4) | 1 | |
7 | Reserved | 0 | |
1 | 2..0 | DataRate configuration for “vacant” state (4.3.2) | 3 (DR3) |
3 | Reserved | 0 | |
6..4 | DataRate configuration for “occupied” state (4.3.2) | 2 (DR2) | |
7 | Reserved | 0 | |
2 | 3..0 | Heartbeat NACK limit (4.5.2) | 3 |
7..4 | Reserved | 0 | |
3 | 7..0 | Heartbeat frequency (4.3.3) | 23 (0x17) |
4 | 7..0 | Short stay filtration - expected maximum count of sessions per day (4.3.6) | 35 (0x23) |
5 | 7..0 | Short stay filtration - minimal occupation duration(4.3.6) | 0 |
If you append 1 more byte equal to AA to this message, you will also be sent a Configuration feedback message as a way to acknowledge if the configuration was accepted.
4.3.7.1 The default configuration and other configuration examples
The default configuration described above looks like
10 23 03 17 23 00
Here is an example of some configuration messages that can be useful:
10 02 03 17 23 00 AA - change data rate to DR0 and DR2 for Occupied/Vacant messages accordingly and send an acknowledgment. Can be used if the sensors are known to be far away from the gateways(so lower datarates are needed to decrease the reception delay of the uplink messages).
11 01 03 17 23 00 AA - change data rate to DR0 and DR1 for Occupied/Vacant messages accordingly, send Parking status messages as unconfirmed without repetitions, and send an acknowledgment. Can be used if the sensors are known to be far away from the gateways(so lower datarates are needed to decrease the reception delay of the uplink messages) and utilization of gateways does not allow to send enough confirmation messages.
10 23 03 17 00 00 AA - disable adaptive filtration and send an acknowledgment. Can be used when a lot of parking sessions are expected and need to be sent without any additional delays, for example, for developers while testing or on demonstrations.
4.3.8 Command
Command uses port 71 and it is used to initiate different commands mainly for debugging.
Write:
01 (1 byte) to calibrate the device,
02 (1 byte) to reboot the device,
03 (1 byte) to put the device into initial mode (the device sleeps until the next calibration with no detection and no LoRaWAN messages).
04(1 byte) to read current configuration(to request transmission of Configuration feedback message)
5. Changelog
2.3.2 28 March 2022
Features:
Request for reading configuration was added
Known issues and limitations:
None at the moment.
2.3.1 14 March 2022
Features:
Improved detection
Fix for occasional rare hardware errors
Known issues and limitations:
None at the moment.
2.1.0 18 January 2022
Features:
Heartbeat message is extended to provide data for sensor health monitoring
Known issues and limitations:
None at the moment.
1.14.1 23 September 2021
Features:
Increased Error Mask to improve monitoring
Health Check via BLE support added
Known issues and limitations:
None at the moment.
1.14.0 20 June 2021
Features:
Short stay filtration mechanism added.
Known issues and limitations:
None at the moment.
1.13.4 8 April 2021
Features:
Support for the version of hardware with high power radio output (for the USA market) . There are 2 different firmware images for 2 versions of the sensors.
General performance improvement
Known issues and limitations:
None at the moment.
1.13.0 16 December 2020
Features:
Compressed duration of the previous status was added to Parking Status message.
Known issues and limitations:
None at the moment.
1.12.0 12 December 2020
Features:
Fix of magnetometer initialization error.
Known issues and limitations:
None at the moment.
1.11.0 7 December 2020
This firmware contains a bug leading to decreased detection performance - updating is required.
Features:
Heartbeat NACK limit default value changed to 3;
Sleep until the next calibration command was added.
Known issues and limitations:
Magnetometer initialization bug leading to decreased detection performance.
1.10.1 1 December 2020
This firmware contains a bug leading to decreased detection performance - updating is required.
Features:
Independent data rate configuration for occupied and vacant statuses;
Minimized consumption until the first calibration;
Configurable re-join behavior.
Known issues and limitations:
Magnetometer initialization bug leading to decreased detection performance.