微信图片_20230822161139.jpg

Table of Contents:

1. Introduction

1.1 What is SN50v3-NB NB-IoT Sensor Node

SN50v3-NB is a Long Range NB-IoT Sensor Node.  It is designed to facilitate developers to quickly deploy industrial level NB-IoT solutions. It helps users to turn the idea into a practical application and make the Internet of Things a reality. It is easy to program, create and connect your things everywhere.

SN50v3-NB wireless part is based on NB model allows the user to send data and reach extremely long ranges at low data-rates.It provides ultra-long range spread spectrum communication and high interference immunity whilst minimising current consumption.It targets professional wireless sensor network applications such as irrigation systems, smart metering, smart cities, building automation, and so on.

SN50v3-NB uses STM32l0x chip from ST, STML0x is the ultra-low-power STM32L072xxxx microcontrollers incorporate the connectivity power of the universal serial bus (USB 2.0 crystal-less) with the high-performance ARM® Cortex®-M0+ 32-bit RISC core operating at a 32 MHz frequency, a memory protection unit (MPU), high-speed embedded memories (192 Kbytes of Flash program memory, 6 Kbytes of data EEPROM and 20 Kbytes of RAM) plus an extensive range of enhanced I/Os and peripherals.

SN50v3-NB is an open source product, it is based on the STM32Cube HAL drivers and lots of libraries can be found in ST site for rapid development.

SN50v3-NB supports different uplink methods including COAP, MQTT, MQTTs, UDP & TCP for different application requirement, and support uplinks to various IoT Servers.

SN50v3-NB supports BLE configure and OTA update which make user easy to use.

SN50v3-NB is powered by 8500mAh Li-SOCI2 battery, it is designed for long-term use up to several years.

SN50v3-NB has optional built-in SIM card and default IoT server connection version. Which makes it works with simple configuration.

微信图片_20230823093934.png

1.2 ​Features

  • NB-IoT Bands: B1/B2/B3/B4/B5/B8/B12/B13/B17/B18/B19/B20/B25/B28/B66/B70/B85 @H-FDD
  • Ultra-low power consumption
  • Open-source hardware / software
  • Multiply Sampling and one uplink
  • Support Bluetooth v5.1 remote configure and update firmware
  • Uplink via COAP, MQTT, MQTTs, TCP, or UDP
  • Uplink on periodically
  • Downlink to change configure
  • 8500mAh Battery for long term use
  • Nano SIM card slot for NB-IoT SIM

1.3 Specification

Common DC Characteristics:

  • Supply Voltage: 2.5v ~ 3.6v
  • Operating Temperature: -40 ~ 85°C

I/O Interface:

  • Battery output (2.6v ~ 3.6v depends on battery)
  • +5v controllable output
  • 3 x Interrupt or Digital IN/OUT pins
  • 3 x one-wire interfaces
  • 1 x UART Interface
  • 1 x I2C Interface

NB-IoT Spec:

NB-IoT Module: BC660K-GL

Support Bands:

  • B1 @H-FDD: 2100MHz
  • B2 @H-FDD: 1900MHz
  • B3 @H-FDD: 1800MHz
  • B4 @H-FDD: 2100MHz
  • B5 @H-FDD: 860MHz
  • B8 @H-FDD: 900MHz
  • B12 @H-FDD: 720MHz
  • B13 @H-FDD: 740MHz
  • B17 @H-FDD: 730MHz
  • B18 @H-FDD: 870MHz
  • B19 @H-FDD: 870MHz
  • B20 @H-FDD: 790MHz
  • B25 @H-FDD: 1900MHz
  • B28 @H-FDD: 750MHz
  • B66 @H-FDD: 2000MHz
  • B70 @H-FDD: 2000MHz
  • B85 @H-FDD: 700MHz

Battery:

  • Li/SOCI2 un-chargeable battery
  • Capacity: 8500mAh
  • Self Discharge: <1% / Year @ 25°C
  • Max continuously current: 130mA
  • Max boost current: 2A, 1 second

Power Consumption

  • STOP Mode: 10uA @ 3.3v
  • Max transmit power: 350mA@3.3v

1.4 Applications

  • Smart Buildings & Home Automation
  • Logistics and Supply Chain Management
  • Smart Metering
  • Smart Agriculture
  • Smart Cities
  • Smart Factory

1.5 Sleep mode and working mode

Deep Sleep Mode: Sensor doesn't have any NB-IoT activate. This mode is used for storage and shipping to save battery life.

Working Mode: In this mode, Sensor will work as NB-IoT Sensor to Join NB-IoT network and send out sensor data to server. Between each sampling/tx/rx periodically, sensor will be in IDLE mode), in IDLE mode, sensor has the same power consumption as Deep Sleep mode.

1.6 Button & LEDs

1675071855856-879.png

Behavior on ACTFunctionAction
Pressing ACT between 1s < time < 3sSend an uplink

If sensor has already attached to NB-IoT network, sensor will send an uplink packet, blue led will blink once.
Meanwhile, BLE module will be active and user can connect via BLE to configure device.

Pressing ACT for more than 3sActive Device

Green led will fast blink 5 times, device will enter OTA mode for 3 seconds. And then start to  attach NB-IoT network.
Green led will solidly turn on for 5 seconds after joined in network.
Once sensor is active, BLE module will be active and user can connect via BLE to configure device, no matter if device attach NB-IoT network or not.

Fast press ACT 5 times.Deactivate DeviceRed led will solid on for 5 seconds. Means device is in Deep Sleep Mode.

Note: When the device is executing a program, the buttons may become invalid. It is best to press the buttons after the device has completed the program execution.

1.7 BLE connection

SN50v3-NB support BLE remote configure and firmware update.

BLE can be used to configure the parameter of sensor or see the console output from sensor. BLE will be only activate on below case:

  • Press button to send an uplink
  • Press button to active device.
  • Device Power on or reset.

If there is no activity connection on BLE in 60 seconds, sensor will shut down BLE module to enter low power mode.

1.8 Pin Definitions , Switch & SIM Direction

SN50v3-NB use the mother board which as below.

SN50v3-NB.png

1.8.1 Jumper JP2

Power on Device when put this jumper.

1.8.2 BOOT MODE / SW1

1) ISP: upgrade mode, device won't have any signal in this mode. but ready for upgrade firmware. LED won't work. Firmware won't run.

2) Flash: work mode, device starts to work and send out console output for further debug

1.8.3 Reset Button

Press to reboot the device.

1.8.4 SIM Card Direction

See this link. How to insert SIM Card.

 

2. Use SN50v3-NB to communicate with IoT Server

2.1 Send data to IoT server via NB-IoT network

The SN50v3-NB is equipped with a NB-IoT module, the pre-loaded firmware in SN50v3-NB will get environment data from sensors and send the value to local NB-IoT network via the NB-IoT module.  The NB-IoT network will forward this value to IoT server via the protocol defined by SN50v3-NB.

Below shows the network structure:

微信图片_20230823093934.png

There are two version: -GE and -1D version of SN50v3-NB.

GE Version: This version doesn't include SIM card or point to any IoT server. User needs to use AT Commands to configure below two steps to set SN50v3-NB send data to IoT server.

  • Install NB-IoT SIM card and configure APN. See instruction of Attach Network.

Below shows result of different server as a glance.

ServersDash BoardComments
Node-Red

image-20240506133928-1.png

 
DataCake

image-20240506141253-3.png

 
Tago.IOimage-20240506141610-4.png 
General UDPRaw Payload. Need Developer to design Dash Board 
General MQTTRaw Payload. Need Developer to design Dash Board 
ThingSpeak

image-20240506134509-2.png

 
ThingsBoard

image-20230819113244-11.png

 

1D Version: This version has 1NCE SIM card pre-installed and configure to send value to DataCake. User Just need to select the sensor type in DataCake and Activate SN50v3-NB and user will be able to see data in DataCake. See here for DataCake Config Instruction.

2.2  Working Mode & Uplink Payload

SN50v3-NB has different working mode for the connections of different type of sensors. This section describes these modes. User can use the AT Command AT+CFGMOD to set SN50v3-NB to different working modes.

For example:

 AT+CFGMOD=2       // will set the SN50v3-NB to work in MOD=2 distance mode which target to measure distance via Ultrasonic Sensor.

The uplink payloads are composed in ASCII String. For example:

89 30 04 7b 0c e9 17 02 ff ff 00 00 00 0b a4 00 00 66 4f f6 90 (total 24 ASCII Chars). Representative the actually payload:

0x 89 30 04 7b 0c e9 17 02 ff ff 00 00 00 0b a4 00 00 66 4f f6 90  Total 21 bytes

NOTE:

1. All modes share the same Payload Explanation from HERE.
2. By default, the device will send an uplink message every 1 hour.

2.2.1  CFGMOD=1 (Default Mode)

In this mode, the uplink payload usually contains 29 bytes. (Note: Time stamp field are added since firmware version v1.2.0)

Size(bytes)

8221121112224
ValueDevice IDVerBATSignal Strength

MOD
0x01

Temperature (DS18B20)(PC13)

PA4_ level 

Interrupt
(PB15)

interrupt_ level ADC

Temperature
by
SHT20/SHT31

Humidity
by
SHT20/SHT31

Timestamp

If the cache upload mechanism is turned on, you will receive the payload shown in the figure below.

Frame headerFrame data(1)Frame data(2)F…Frame data(X)

If we use the MQTT client to subscribe to this MQTT topic, we can see the following information when the NB sensor uplink data.

  • image-20240524154347-3.jpeg

The payload is ASCII string, representative same HEX: 0x f863663062798930 047b 0d15 18 01 ffff 00 00 00 0b94 010c 02db 664ff85e

where:

Device ID: f863663062798930 = 863663062798930

Version: 0x04:dSN50v3-NB, 0x7b=123=1.2.3

BAT:  0x0d1 = 3349 mV = 3.349V

Singal:  0x18 = 24

Model: 0x01 = 1

Temperature by DS18b20: 0x00f7 = 247/10=24.7

PA4_level: 0x00 =0

Interrupt: 0x00 = 0

Interrupt_level: 0x00 =0

ADC: 0x0b94 =2964= 2964.00mv

Temperature by SHT20/SHT31: 0x010c = 268 = 26.8 °C

Humidity by SHT20/SHT31: 0x02db= 731 = 73.1 %rh

Timestamp: 664FF85E =1716516958=2024-05-24 10:15:58

Connection mode of I2C sensor and DS18B20 temperature sensor:

image-20240312185720-1.jpeg
  

2.2.2  CFGMOD=2 (Distance Mode)

This mode is target to measure the distance. Total 27 bytes, (Note: Time stamp field are added since firmware version v1.2.0)

Size(bytes)

822112111224
ValueDevice IDVerBATSignal Strength

MOD
0x02

Temperature (DS18B20)(PC13)

PA4_ level 

 Interrupt
(PB15)

interrupt_ level ADC
(PA4)

Distance measure by:
1) LIDAR-Lite V3HP
Or
2) Ultrasonic Sensor

Timestamp

If the cache upload mechanism is turned on, you will receive the payload shown in the figure below.

Frame headerFrame data(1)Frame data(2)F…Frame data(X)

If we use the MQTT client to subscribe to this MQTT topic, we can see the following information when the NB sensor uplink data.

image-20240527095513-2.png

So the payload is  f863663062798930 047b 0cd7 13 02 ffff 00 00 00 0b92 0000 664ff77f

where:

Device ID: 0xf863663062798930 = 863663062798930

Version:    0x04:dSN50v3-NB, 0x7b=123=1.2.3

BAT:      0x0c7d = 3287mV = 3.287 V

Singal:  0x13 = 19

Model: 0x02 = 2

Temperature by DS18b20: 0x010b= 267 = 26.7  °

PA4_level: 0x00 =0

Interrupt: 0x01 = 1

Interrupt_level: 0x01 =1

ADC: 0x0ca8 = 3240 mv

Distance by LIDAR-Lite V3HP/Ultrasonic Sensor: 0x0158 = 344 cm

Timestamp: 0x664FF77F = 1,716,516,735 = 2024-05-24 10:12:15

  

Connection of LIDAR-Lite V3HP:

image-20230512173758-5.png

Connection to Ultrasonic Sensor:

Need to remove R1 and R2 resistors to get low power,otherwise there will be 240uA standby current.

image-20230512173903-6.png

2.2.3  CFGMOD=3 (3 ADC + I2C)

This mode has total 31 bytes. Include 3 x ADC + 1x I2C, (Note: Time stamp field are added since firmware version v1.2.0)

Size(bytes)

82211211122224
ValueDevice IDVerBATSignal Strength

MOD
0x03

ADC1
(PA4)

PA4_
level

Interrupt
(PB15)

Interrupt
_level

ADC2
(PA5)

Temperature
by
SHT20/SHT31

Humidity by
SHT20/SHT31

ADC3
(PA8)
Timestamp

ADC1 uses pin PA4 to measure

ADC2 uses pin PA5 to measure

ADC3 uses pin PA8 to measure

(Suitable for motherboard version: LSN50 v3.3)

If the cache upload mechanism is turned on, you will receive the payload shown in the figure below.

Frame headerFrame data(1)Frame data(2)F…Frame data(X)

If we use the MQTT client to subscribe to this MQTT topic, we can see the following information when the NB sensor uplink data.

image-20240527102949-3.png

So the payload is 0x  f863663062798930 047b 0d0e 16 03 0b9b 00 00 00 0003 011c 02f1 0000 664ff429

where: 

Device ID: 0xf868411056754138 = 868411056754138

Version:     0x04:dSN50v3-NB, 0x7b=123=1.2.3

BAT:      0x0d0e = 3342 mV = 3.342 V

Singal:  0x16 = 22

Model: 0x03 = 3

ADC1:  0x0b9b= 2971mV

PA4_level: 0x00 =0

Interrupt: 0x00 = 0

Interrupt_level: 0x00 =0

ADC2: 0x0003 =3 mv

Temperature by SHT20/SHT31: 0x011c = 284 = 28.4 °C

Humidity by SHT20/SHT31: 0x02f1 =753 = 75.3 %rh

ADC3: 0x0000 = 0 mv

Timestamp: 0x664ff429 = 1,716,515,881= 2024-05-24 09:58:01 

2.2.4  CFGMOD=4 (3 x DS18B20)

Hardware connection is as below.

image-20230513134006-1.png

This mode has total 29 bytes. (Note: Time stamp field are added since firmware version v1.2.0)  As shown below:

Size(bytes)

82211221  224
ValueDevice IDVerBATSignal Strength

MOD
0x04

Temperature1 (DS18B20) (PC13)

ADC

PA4_
level

Interrupt
(PB15)

Interrupt
_level

Temperature2 (DS18B20) (PA9)

Temperature3 (DS18B20) (PA10)

Timestamp

If the cache upload mechanism is turned on, you will receive the payload shown in the figure below.

Frame headerFrame data(1)Frame data(2)F…Frame data(X)

If we use the MQTT client to subscribe to this MQTT topic, we can see the following information when the NB sensor uplink data.

image-20240527103016-4.png

So the payload is 0x f863663062798930 047b 0d11 16 04 010c 0000 00 00 00 010b 010a 664ff308

where:

Device ID: 0xf863663062798930 = f863663062798930

Version: 0x04:dSN50v3-NB, 0x7b=123=1.2.3

BAT:      0x0d11 = 3345 mV = 3.345 V

Singal:  0x16 = 22

Model: 0x04 = 4

Temperature1 by DS18b20: 0x010c = 268 = 26.8 °C

ADC: 0x0000 = 0 mv

PA4_level: 0x00 =0

Interrupt: 0x00 = 0

Interrupt_level: 0x00 =0

Temperature2 by DS18b20: 0x010b = 267 = 26.°C

Temperature3 by DS18b20: 0x010a  = 266 = 26.6 °C

Timestamp: 0x664FF308 = 1,716,515,592= 2024-05-24 09:53:12

  

2.2.5  CFGMOD=5 (Weight Measurement by HX711)

image-20230512164658-2.png

Notes about hardware connection:

  1. Don't connect the HX711 module VCC to SN50v3-NB 3.3v VCC, in this case, the SN50v3-NB will always power on HX711 and the battery will run out soon.
  2. HX711 support 5v VCC, but while connect the SN50v3-NB's +5V to HX711 VCC, the value from HX711 is not stable.
  3. Connect SN50v3-NB +5V to HX711 VCC via a LDO module is stable.

Each HX711 need to be calibrated before used. User need to do below two steps:

  1. Zero calibration. Don't put anything on load cell and run AT+WEIGRE to calibrate to Zero gram.
  2. Adjust calibration factor (default value 400): Put a known weight thing on load cell and run AT+WEIGAP to adjust the Calibration Factor.

For example:

AT+WEIGAP =403.0

Response:  Weight is 401 g

Check the response of this command and adjust the value to match the real value for thing. 

This mode has total 27 bytes. (Note: Time stamp field are added since firmware version v1.2.0). As shown below:

Size(bytes)

822112211124
ValueDevice IDVerBATSignal Strength

MOD
0x05

Temperature (DS18B20)

ADC

PA4_
level

Interrupt
(PB15)

Interrupt
_level

Weight

Timestamp

If the cache upload mechanism is turned on, you will receive the payload shown in the figure below.

Frame headerFrame data(1)Frame data(2)F…Frame data(X)

If we use the MQTT client to subscribe to this MQTT topic, we can see the following information when the NB sensor uplink data.

image-20240527105110-5.png

So the payload is 0x f863663062798930 047b 0d0e 14 05 Ffff 0b97 00 00 00 0000 664ffb4b

where:

Device ID: f863663062798930 = 863663062798930

Version:    0x04:dSN50v3-NB, 0x7b=123=1.2.3

BAT:      0x0d0e = 3342 mV = 3.342 V

Singal:  0x14 = 20

Model: 0x05 = 5

Temperature by DS18b20: 0x0137 = 311 = 31.1 °C

ADC: 0x0b97 = 2967 mv

PA4_level: 0x00 =0

Interrupt: 0x00 = 0

Interrupt_level: 0x00 =0

Weigt by HX711: 0x003a  = 58 g

Timestamp: 0x664ffb4b = 1,716,517,707= 2024-05-24 10:28:27

  

2.2.6  CFGMOD=6 (Counting mode)

In this mode, uplink payload includes in total 22 bytes, (Note: Time stamp field are added since firmware version v1.2.0)

Size(bytes)

8221144
ValueDevice IDVerBATSignal Strength

MOD 0x06

Pulse count(PB15)Timestamp

If the cache upload mechanism is turned on, you will receive the payload shown in the figure below.

Frame headerFrame data(1)Frame data(2)F…Frame data(X)

If we use the MQTT client to subscribe to this MQTT topic, we can see the following information when the NB sensor uplink data.

image-20240527105720-6.png

The payload is ASCII string, representative same HEX: 0x f868411056754138 0078 0cc7 14 06 00000002 60dc03e5

 where:

  • Device ID: 0xf868411056754138 = 868411056754138
  • Version: 0x0078=120=1.2.0
  • BAT:      0x0cc7 =3271mV =3.271V
  • Singal:  0x14 = 20
  • Model: 0x06 = 6
  • Pulse count:  0x00000002= 2
  • Timestamp:  0x60dc03e5 = 1,625,031,653= 2021-06-30 13:40:53

2.2.7  CFGMOD=7 (3xADC + 3xDS18B20 mode)

In this mode, the uplink payload totals 161 bytes, including 25 bytes of real-time data and 16 bytes of timed acquisition data (8 groups are stored by default) (Note: Added since firmware version v1.2.4)

  image-20240902100519-6.png

ADC1 uses pin PA4 to measure

ADC2 uses pin PA5 to measure

ADC3 uses pin PA8 to measure

(Suitable for motherboard version: LSN50 v3.3)

If we use the MQTT client to subscribe to this MQTT topic, we can see the following information when the NB sensor uplink data.

image-20240827155958-3.png

The payload is ASCII string, representative same HEX:0xf863663062798930 047c 0d1e 14 07 00 00 00 0000 00eb 023c 00fa 00f5 00fb 66cd8702

Device ID: f863663062798930 = 863663062798930

Version:    0x04:dSN50v3-NB, 0x7c=124=1.2.4

BAT:      0x0d1e = 3358 mV = 3.358 V

Singal:  0x14 = 20

Model: 0x07 = 7

PA4_level: 0x00 =0

Interrupt: 0x00 = 0

Interrupt_level: 0x00 =0

ADC1(PA4): 0x0000 = 0mV

ADC2(PA5):  0x00eb = 235mV

ADC3(PA8):  0x023c = 572mV

Temp1(PC13): 0x00fa = 250/10 = 25.0℃

Temp2(PB9): 0x00f5 = 245/10 = 24.5℃

Temp3(PB8): 0x00fb  = 251/10 = 25.1℃

Timestamp: 0x66cd8702 = 1,724,745,474= 2024-08-27 15:57:54
 

2.2.8  CFGMOD=8 (Three interrupts or three counting modes)

2.2.8.a Three interrupts modes:

In this mode, the uplink payload totals 124 bytes, including 20 bytes of real-time data and 12 bytes of timed acquisition data (8 groups are stored by default). (Note: Added since firmware version v1.2.4)

image-20240902142920-14.png

If we use the MQTT client to subscribe to this MQTT topic, we can see the following information when the NB sensor uplink data.

image-20240902142934-15.png

The payload is ASCII string, representative same HEX:0xf863663062798930  047c  0d1e  1b  08  0b9d  0102  00  00  00  00  00  00  66d55a77

Device ID: f863663062798930 = 863663062798930

Version:    0x04:dSN50v3-NB, 0x7c=124=1.2.4

BAT:      0x0d1e = 3358 mV = 3.358 V

Singal:  0x1b = 27

Model:  0x08 = 8

ADC2(PA5): 0x0b9d = 2973mv

DS18B20_temp(PC13): 0x0102 = 258/10 = 25.8℃

Interrupt(PB15): 0x00 = 0

Interrupt_level(PB15): 0x00 = 0

Interrupt_pa4(PA4): 0x00 = 0

Interrupt_level_pa4(PA4): 0x00 = 0

Interrupt_pa8(PA8): 0x00 = 0

Interrupt_level_pa8(PA8): 0x00 = 0

Timestamp: 0x66d55a77 = 1,725,258,359 = 2024-09-02 14:25:59

2.2.8.b Three counting modes:

In this mode, the uplink payload totals 158 bytes, including 22 bytes of real-time data and 16 bytes of timed acquisition data (8 groups are stored by default). (Note: Added since firmware version v1.2.4)

image-20240831141848-4.png

If we use the MQTT client to subscribe to this MQTT topic, we can see the following information when the NB sensor uplink data.

image-20240831140502-2.png

The payload is ASCII string, representative same HEX:0xf863663062798930  047c  0d13  1a  08  0000006c  0000005c  0000004e  66d2ac24

Device ID: f863663062798930 = 863663062798930

Version:    0x04:dSN50v3-NB, 0x7c=124=1.2.4

BAT:      0x0d13 = 3347 mV = 3.347 V

Singal:  0x1a = 26

Model: 0x08 = 8

count1(PB15): 0x0000006c = 108

count2(PA4): 0x0000005c = 92

count3(PA8): 0x0000004e = 78

Timestamp: 0x66d2ac24 = 1,725,082,660 = 2024-08-31 13:37:40

2.2.9  CFGMOD=9 (Count+SHT31 mode)

In this mode, the uplink payload totals 123 bytes, including 19 bytes of real-time data and 12 bytes of timed acquisition data (8 groups are stored by default)(Note: Added since firmware version v1.2.4)

image-20240902092149-1.png

If we use the MQTT client to subscribe to this MQTT topic, we can see the following information when the NB sensor uplink data.

image-20240902092316-2.png

The payload is ASCII string, representative same HEX:0xf863663062798930  047c  0d15  18  09  00  0000004e  011f   0210  66d51154

Device ID: f863663062798930 = 863663062798930

Version:    0x04:dSN50v3-NB, 0x7c=124=1.2.4

BAT:      0x0d15 = 3349 mV = 3.349 V

Singal:  0x18 = 24

Model: 0x09 = 9

digital in: 0x00 = 0( 0:low level; 1:high level)

count(PA8): 0x0000004e = 78

Temp(sht31): 0x011f = 287/10 = 28.7℃

Hum(sht31): 0x0210 = 528/10 = 52.8%rh

Timestamp: 0x66d51154 = 1,725,239,636 = 2024-09-02 09:13:56

image-20240911140914-2.jpeg

2.2.9  CFGMOD=10 (TMP117 Temperature Sensor Mode)

In this mode, the uplink payload totals 106 bytes, including 18 bytes of real-time data and 10 bytes of timed acquisition data (8 groups are stored by default)(Note: Added since firmware version v1.2.4)

image-20240902112124-10.png

If we use the MQTT client to subscribe to this MQTT topic, we can see the following information when the NB sensor uplink data.

image-20240902094324-3.png

The payload is ASCII string, representative same HEX:0xf863663062798930  047c  0d23  1a  0a  010e  0000  00  00  0a98  66d525cd

Device ID: f863663062798930 = 863663062798930

Version:    0x04:dSN50v3-NB, 0x7c=124=1.2.4

BAT:      0x0d23 = 3363 mV = 3.363 V

Singal:  0x1a = 26

Model: 0x0a = 10

DS18B20: 0x010e = 270/10 = 27.0℃

ADC1(PA4): 0x0000 = 0mV

Interrupt: 0x00 = 0

Interrupt_level: 0x00 =0

Temp(TMP117): 0xa98 = 2712/100 = 27.12℃

Timestamp: 0x66d525cd = 1,725,244,877= 2024-09-02 10:41:17

image-20240911140648-1.jpeg

2.3 ​Payload Types

To meet different server requirement, SN50v3-NB supports different payload type.

Includes:

User can specify the payload type when choose the connection protocol. Example:

AT+PRO=1,0            // Use COAP Connection & hex Payload

AT+PRO=1,5            // Use COAP Connection & Json Payload

AT+PRO=2,0            // Use UDP Connection & hex Payload

AT+PRO=2,5            // Use UDP Connection & Json Payload

AT+PRO=3,0            // Use MQTT Connection & Json Payload

AT+PRO=3,5            // Use MQTT Connection & Json Payload

AT+PRO=4,0            // Use TCP Connection & Json Payload

AT+PRO=4,5            // Use TCP Connection & Json Payload

2.3.1 General Json Format(Type=5)

This is the General Json Format. As below:

{"IMEI":"863663062798930","Model":"SN50V3-NB","mod":1,"battery":3.36,"signal":19,"DS18B20_Temp":-409.5,"digital_in":0,"interrupt":0,"interrupt_level":0,"adc1":2974,"temperature":26.9,"humidity":73.9,"1":[130.0,0.0,0,-409.5,"2024/05/24 01:20:14"],"2":[24.0,64.1,1,-409.5,"2024/05/24 00:53:05"],"3":[23.9,64.1,1,-409.5,"2024/05/24 00:38:05"],"4":[23.8,64.0,1,-409.5,"2024/05/24 00:23:05"],"5":[24.2,63.7,1,-409.5,"2024/05/24 00:08:05"],"6":[24.3,63.5,0,-409.5,"2024/05/23 23:53:05"],"7":[24.7,64.3,0,-409.5,"2024/05/23 23:38:05"],"8":[24.5,69.4,1,-409.5,"2024/05/23 23:23:05"]}

Notice, from above payload:

  • Temperature , Humidity , Battery & Signal are the value at uplink time.
  • Json entry 1 ~ 8 are the last 1 ~ 8 sampling data as specify by AT+CLOCKLOG=1,65535,15,8  Command. Each entry includes (from left to right): Temperature, Humidity, Sampling time.

2.3.2 HEX format Payload(Type=0)

This is the HEX Format. As below:

f863663062798930047b0d111301ffff0000000b92010b02d8664ff9770000f00105140000664feb4e0001f00100f00281664fe4f10001f00100ef0281664fe16d0001f00100ee0280664fdde90001f00100f2027d664fda650000f00100f3027b664fd6e10000f00100f70283664fd35d0001f00100f502b6664fcfd9

image-20240527110551-7.png

Note: Only hex payload contains PA4_level bytes, JSON payload does not contain PA4_level.

Version:

These bytes include the hardware and software version.

Higher byte: Specify Sensor Model: 0x04 for SN50v3

Lower byte: Specify the software version: 0x7b=123, means firmware version 1.2.3

BAT (Battery Info):

Ex1: 0x0d11 = 3345mV

Signal Strength:

NB-IoT Network signal Strength.

Ex1: 0x13 = 19

0        -113dBm or less

1        -111dBm

2...30 -109dBm... -53dBm

31      -51dBm or greater

99      Not known or not detectable

Temperature: 

If payload is: 0105H:  (0105 & 8000 == 0), temp = 0105H /10 = 26.1 degree

If payload is: FF3FH :  (FF3F & 8000 == 1) , temp = (FF3FH - 65536)/10 = -19.3 degrees.

(FF3F & 8000: Judge whether the highest bit is 1, when the highest bit is 1, it is negative)

Humidity:   

Read:0295(H)=661(D)    Value:  661 / 10=66.1, So 66.1%

TimeStamp:   

Unit TimeStamp Example: 64d49439(H) = 1691653177(D)

Put the decimal value into this link(https://www.epochconverter.com/https://www.epochconverter.com/) to get the time.

2.3.3 ThingsBoard Payload(Type=3)

Type3 payload special design for ThingsBoard, it will also configure other default server to ThingsBoard.

{
    "topic": "2276492",
    "payload": {
        "IMEI": "863663062798930",
        "Model": "SN50V3-NB",
        "mod": 1,
        "battery": 3.3,
        "signal": 22,
        "DS18B20_Temp": -409.5,
        "digital_in": 0,
        "interrupt": 0,
        "interrupt_level": 0,
        "adc1": 2962,
        "temperature": 25.9,
        "humidity": 66.0,
        "1": [25.8, 65.5, 0, -409.5, "2024/05/27 03:29:46"],
        "2": [26.0, 67.6, 2968, -409.5, "2024/05/27 03:27:39"],
        "3": [26.2, 64.9, 2963, -409.5, "2024/05/27 03:26:39"],
        "4": [26.1, 65.7, 2961, -409.5, "2024/05/27 03:25:39"],
        "5": [26.2, 63.9, 2967, -409.5, "2024/05/27 03:25:15"],
        "6": [26.3, 63.9, 2971, -409.5, "2024/05/27 03:24:15"],
        "7": [25.7, 67.7, 2960, -409.5, "2024/05/27 03:20:27"],
        "8": [25.9, 64.4, 2963, -409.5, "2024/05/27 03:19:27"]
    }
}

image-20240527140754-8.png

2.3.4 ThingSpeak Payload(Type=1)

This payload meets ThingSpeak platform requirement. It includes only four fields. Form 1~8 are:

distance1, Battery, Signal, DS18B20_Temp, Interrupt_level, Interrupt, ADC,Temperature. This payload type only valid for ThingSpeak Platform.

Note: ThingSpeak has a maximum of eight fields, so the humidity curve is not on the graph.

As below:

field1=distance1 value&field2=battery value&field3=Signal value&field4=DS18B20_Temp value&field5=Interrupt_level value&field6=ADC value&field7=Temperature value&field8=Humidity value

image-20240527140847-9.png

image-20240527140925-11.png

2.4 Test Uplink and Change Update Interval

By default, Sensor will send uplinks every 2 hours 

User can use below commands to change the uplink interval.

AT+TDC=7200        // Set Update Interval to 7200s

User can also push the button for more than 1 seconds to activate an uplink.

Notice: The AT+NOUD feature is upgraded to Clock Logging, please refer Clock Logging Feature.

To save battery life, SN50v3-NB will sample temperature & humidity data every 15 minutes and send one uplink every 2 hours. So each uplink it will include 8 stored data + 1 real-time data. They are defined by:

  • AT+TR=900        // The unit is seconds, and the default is to record data once every 900 seconds (15 minutes, the minimum can be set to 180 seconds)
  • AT+NOUD=8     //  The device uploads 8 sets of recorded data by default. Up to 32 sets of record data can be uploaded.

The diagram below explains the relationship between TR, NOUD, and TDC more clearly:

1692424376354-959.png

2.6 Trggier an uplink by external interrupt

Feature, Set Interrupt mode for PB15,PA4,PA8.

AT command:AT+INTMOD

Command ExampleFunctionResponse
AT+INTMOD?

Get or Set the trigger interrupt mode

1:0,2:0,3:0(default)
OK 

AT+INTMOD=?

Get current trigger mode

0:input

1:falling or rising

2:falling

3:rising

1:1,2:1,3:1

OK

 

AT+INTMOD=1,1,1

Set PB15,PA4,PA8 trigger mode

OK

Downlink command: 0x06

Format: Command Code (0x06) followed by 3 byte.

Ex1: Downlink payload: 0x06010002   //AT+INTMOD=1,0,2

Ex2: Downlink payload: 0x06000103   //AT+INTMOD=0,1,3

2.7 +5V Output

Control the output duration 5V . Before each sampling, device will

1. first enable the power output to external sensor,

2. keep it on as per duration, read sensor value and construct uplink payload

3. final, close the power output.

AT command: AT+5VT

Command ExampleFunctionResponse
AT+5VT=?Show 5V open time.

0(default)
OK

AT+5VT=1000

Close after a delay of 1000 milliseconds.

OK

2.8 Analogue Digital Converter (ADC)

The ADC pins in SN50V3-NB can measure range from 0~Vbat, it use reference voltage from STM32. If user need to measure a voltage > VBat, please use resistors to divide this voltage to lower than VBat, otherwise, it may destroy the ADC pin.

Note: minimum VBat is 2.5v, when batrrey lower than this value. Device won't be able to send LoRa Uplink.

The ADC monitors the voltage on the PA0 line, in mV.

Ex: 0x021F = 543mv,

图片-20220628150112-1.png

Note: If the ADC type sensor needs to be powered by SN50_v3, it is recommended to use +5V to control its switch.Only sensors with low power consumption can be powered with VDD.

The position of PA5 on the hardware after SN50 v3.3 is changed to the position shown in the figure below, and the collected voltage becomes one-sixth of the original.

image-20230811113449-1.png

2.9 Clock logging (Since firmware version v1.2.1)

Sometimes when we deploy lots of end nodes in field. We want all sensors sample data at the same time, and upload these data together for analyze. In such case, we can use clock loging feature.

We can use this command to set the start time of data recording and the time interval to meet the requirements of the specific collection time of data.

  • AT command: AT+CLOCKLOG=a,b,c,d

a: 0: Disable Clock logging.   1: Enable Clock Logging

b: Specify First sampling start second: range (0 ~ 3599, 65535)         // Note: If parameter b is set to 65535, the log period starts after the node accesses the network and sends packets.

c: Specify the sampling interval: range (0 ~ 255 minutes)

d: How many entries should be uplink on every TDC (max 32)

Note: To disable clock recording, set the following parameters: AT+CLOCKLOG=1,65535,0,0

image-20240315141254-1.png

Example:

AT+CLOCKLOG=1,65535,1,5

After the node sends the first packet, data is recorded to the memory at intervals of 1 minute. For each TDC uplink, the uplink load will include: battery information + the last 5 memory records (payload + timestamp).

image-20240316170545-1.png

Note: Users need to synchronize the server time before configuring this command. If the server time is not synchronized before this command is configured, the command takes effect only after the node is reset.

  • Downlink command: 0x0A  

Format: Command Code (0x0A) followed by 5 bytes.

  • Example 1: Downlink Payload: 0A01FFFF0F08             // Set SHT record time: AT+CLOCKLOG=1,65535,15,8
  • Example 1: Downlink Payload: 0A0104B00F08             // Set SHT record time: AT+CLOCKLOG=1,1200,15,8

Note: When entering the downlink payload, there must be no Spaces between bytes.

Unix TimeStamp

S31x-NB uses Unix TimeStamp format based on

image-20240921164109-1.png

User can get this time from link:  https://www.epochconverter.com/ :

Below is the converter example

image-20240921164124-2.png

So, 1725875962 means that the current time is Monday, September 9, 2024 at 9:59 AM.

Poll sensor value

User can poll sensor value based on timestamps from the server. Below is the downlink command.

1 byte4 bytes4 bytes
31Timestamp startTimestamp end

Timestamp start and Timestamp end use Unix TimeStamp format as mentioned above. Devices will reply with all data log during this time period.

For example, downlink command 31 66DE 6384 66DE 7194

Is to check 2024/9/9 02:55:00 to 2024/9/9 03:55:00's data

Datalog Uplink payload

The Datalog poll reply uplink will use below payload format.

Retrieval data payload:

Size(bytes)222
valueHumTempTimestamp

Function Description: This feature is only used when the clock logging feature is turned on. one uplink packet can send 64 groups of stored data totaling 512 bytes.

Example(For MQTT.fx):

If user sends below downlink command: 

Where : Start time: 60065F97 = time 24/9/9 02:55:00

             Stop time: 66DE6A8C= time 24/9/9 03:25:00

S31x-NB will uplink this payload.

image-20240909163051-1.png

0x0100024966de638b 0100024866de63c7 00ff024d66de6403 00ff024b66de643f 00ff024666de647b 0100024b66de64b7 00ff024f66de64f3 00ff024566de652f

image-20240909165436-4.png

Temp=0x0100/10=25.6℃

Hum=0x0249/10=58.5%rh

Unix time is 0x66de638b =1725850507s=24/9/9 02:55:00

2.10 Example Query saved historical records

  • AT command: AT+CDP

This command can be used to search the saved history, recording up to 32 groups of data, each group of historical data contains a maximum of 100 bytes.

image-20240316170626-2.png

2.11 Uplink log query

  • AT command: AT+GETLOG

This command can be used to query upstream logs of data packets.

image-20240407191922-2.png

2.12 Scheduled domain name resolution

This command is used to set up scheduled domain name resolution.

AT command:

  • AT+DNSTIMER   // Unit: hour

After setting this command, domain name resolution will be performed regularly.

2.13 Set the QoS level

This command is used to set the QoS level of MQTT.

AT command:

  • AT+MQOS    // 0~2

Downlink command: 0x07  

Format: Command Code (0x07) followed by 1 byte.

Ex1: Downlink payload: 0x0700   //AT+MQOS=0

Ex2: Downlink payload: 0x0701   //AT+MQOS=1

2.14 set CoAP option

This command sets the connection parameters of the COAP. 

AT command:

  • AT+URI1~AT+URI4

Format:

  • AT+URI1=CoAP option name, CoAP option length, "CoAP option value"

Example:

  • AT+URI1=11,38,"i/faaa241f-af4a-b780-4468-c671bb574858"

2.15 Get or Set Count value

Feature,Get or set the count value and set the interrupt mode or count mode.(Note: Added since firmware version v1.2.4)

AT command:AT+EXT

Command ExampleFunctionResponse
AT+EXT?

Get or Set Count value

OK 

AT+EXT=?

Get count value and current mode

The last parameter:

0: interrupt trigger mode;

1: count mode.

1:108,2:92,3:78,1

OK

AT+EXT=0,0,0,1Set PB15,PA4, PA8 to count mode and count value to 0.OK

Note: 

  • There is no downlink command for this instruction, it can only be set through the serial port. 
  • The format of AT instruction is: AT+EXT=0,0,0,1 or AT+EXT=0,0,0,0
  • The last parameter of the current instruction sets the pin's operating mode to interrupt-triggered or count mode.(can only be set to 0 or 1)
  • This command is valid only in mode 6 and mode 8.

3. Configure SN50v3-NB

3.1 Configure Methods

SN50v3-NB supports below configure method:

3.2  Serial Access Password

After the Bluetooth or UART connection is successful, use the Serial Access Password to enter the AT command window.

The label on the box of the node will print the initial password: AT+PIN=xxxxxx, and directly use the six-digit password to access the AT instruction window.

image-20240823173918-1.png

If you need to change the password, use AT+PWORD=xxxxxx (6 characters), NB nodes only support lowercase letters.

image-20240823174332-2.png

Note: After entering the command, you need to add a line break, and you can also set automatic line breaks in the Bluetooth tool or UART connection tool.

image-20240823174639-3.png

3.3 AT Commands Set

AT+<CMD>?           : Help on <CMD>

AT+<CMD>                      : Run <CMD>

AT+<CMD>=<value>      : Set the value

AT+<CMD>=?          : Get the value

General Commands       

AT                    : Attention        

AT?                  : Short Help      

ATZ                  : Trig a reset of the MCU

AT+CFGMOD     : Working mode selection

AT+DEUI         : Get or set the Device ID

AT+PWORD    : Get or set the System password

AT+TDC          : Application Data Transmission Interval

AT+CFG          : Print all configurations

AT+5VT           : Set extend the time of 5V power   

AT+PRO          : Choose agreement

AT+APN          : Get or set the APN

AT+EXT           : Get or Set Count value

AT+RXDL            : Extend the sending and receiving time

AT+SERVADDR            :   Server Address

AT+WEIGRE              : Get weight or set weight to 0

AT+WEIGAP             : Get or Set the GapValue of weight

AT+CFGMOD           : Working mode selection

AT+INTMOD            : Set the trigger interrupt mode

AT+GETSENSORVALUE              : Returns the current sensor measurement

AT+CSQTIME            : Get or Set the time to join the network

AT+DNSTIMER      :Regularly resolve domain names

AT+TLSMOD            : Get or Set the TLS mode

AT+CLOCKLOG   : Get or set SHT record time

AT+CDP             : Read or Clear cached data

AT+CUM              : Get or Set cache upload mechanism (0: Off 1: On)

AT+SERVADDR            :   Server Address

AT+DNSCFG         : Get or Set DNS Server

AT+MQOS            : Set the QoS level of MQTT

AT+SLEEP            : Get or Set the sleep mode

MQTT Management

AT+CLIENT               : Get or Set MQTT client

AT+UNAME              : Get or Set MQTT Username

AT+PWD                  : Get or Set MQTT password

AT+PUBTOPIC          : Get or Set MQTT publish topic

AT+SUBTOPIC          : Get or Set MQTT subscription topic

Information           

AT+FDR1             : Reset parameters to factory default values except for passwords

AT+FDR               : Factory Data Reset

AT+PWORD        : Serial Access Password

AT+LDATA           : Get the last upload data

AT+CDP               : Read or Clear cached data

AT+GETLOG       : Print serial port logs

COAP Management

AT+URI1            : Get or set CoAP option 1

AT+URI2            : Get or set CoAP option 2

AT+URI3            : Get or set CoAP option 3

AT+URI4            : Get or set CoAP option 4

Print or clear historical data

AT+PDTA           : Print the sector data from start page to stop page

AT+PLDTA         : Print the last few sets of data

AT+CLRDTA       : Clear the storage, record position back to 1st

4. Battery & Power Consumption

SN50v3-NB use ER26500 + SPC1520 battery pack. See below link for detail information about the battery info and how to replace.

Battery Info & Power Consumption Analyze .

5. Firmware update

User can change device firmware to::

  • Update with new features.
  • Fix bugs. 

Firmware and changelog can be downloaded from : Firmware download link

Methods to Update Firmware:

  • (Recommended way) OTA firmware update via BLE: Instruction.

6.  Get and compile Software

NBSN95 is an open-source project, developer can compile their firmware for customized applications. User can get the source code from:

See FAQ of this file.

The project file is in:  SN50V3-NB\MDK-ARM\uvprojx

7. FAQ

7.1 How can I access the BC660K-GL AT Commands?

User can access to BC660K-GL directly and send AT Commands.

See BC660K-GL AT Command set

7.2 Why can't the password access AT command after upgrade?

Refer to this link to view the password using STM32Cube Programmer.

8. Order Info

Part Number: SN50v3-NB-XX

XX

  • GE: General version ( Exclude SIM card)
  • 1D: with 1NCE* 10 years 500MB SIM card and Pre-configure to DataCake server

YY: The grand connector hole size

  • M12: M12 hole
  • M16: M16 hole
  • M20: M20 hole

9. ​Packing Info

Package Includes:

  • SN50v3-NB NB-IoT Sensor Node x 1
  • External antenna x 1

Dimension and weight:

  • Device Size: 13.0 x 5 x 4.5 cm
  • Device Weight: 150g
  • Package Size / pcs : 14.0 x 8x 5 cm
  • Weight / pcs : 180g

10. Support

  • Support is provided Monday to Friday, from 09:00 to 18:00 GMT+8. Due to different timezones we cannot offer live support. However, your questions will be answered as soon as possible in the before-mentioned schedule.
  • Provide as much information as possible regarding your enquiry (product models, accurately describe your problem and steps to replicate it etc) and send a mail to Support@dragino.cc.

11. FCC Warning

Any Changes or modifications not expressly approved by the party responsible for compliance could void the user's authority to operate the equipment.

This device complies with part 15 of the FCC Rules. Operation is subject to the following two conditions: (1) This device may not cause harmful interference, and (2) this device must accept any interference received, including interference that may cause undesired operation.

Note: This equipment has been tested and found to comply with the limits for a Class B digital device, pursuant to part 15 of the FCC Rules. These limits are designed to provide reasonable protection against harmful interference in a residential installation. This equipment generates, uses and can radiate radio frequency energy and, if not installed and used in accordance with the instructions, may cause harmful interference to radio communications. However, there is no guarantee that interference will not occur in a particular installation. If this equipment does cause harmful interference to radio or television reception, which can be determined by turning the equipment off and on, the user is encouraged to try to correct the interference by one or more of the following measures:

—Reorient or relocate the receiving antenna.

—Increase the separation between the equipment and receiver.

—Connect the equipment into an outlet on a circuit different from that to which the receiver is connected.

—Consult the dealer or an experienced radio/TV technician for help.

This equipment complies with FCC radiation exposure limits set forth for an uncontrolled environment. This equipment should be installed and operated with minimum distance 20cm between the radiator& your body.

   

Tags:
Created by Xiaoling on 2023/08/22 16:34
    
Copyright ©2010-2022 Dragino Technology Co., LTD. All rights reserved
Dragino Wiki v2.0