Version 361.7 by Xiaoling on 2022/06/27 18:08

Show last authors
1 (% style="display:none" %) (%%) ​​​(% style="display:none" %)
2
3 (% style="text-align:center" %)
4 [[image:image-20220627094803-5.png||height="366" width="804"]]
5
6
7 (% style="display:none" %) (%%)
8
9
10
11
12
13
14
15 **Table of Contents:**
16
17 (% aria-label="macro:toc widget" contenteditable="false" role="region" tabindex="-1" %)
18 (((
19 (% style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||height="15" role="presentation" title="Click and drag to move" width="15"]]
20 )))
21
22
23
24
25
26
27
28
29
30
31
32
33 = 1.  Introduction =
34
35 == 1.1 ​ What is LSN50 LoRa Sensor Node ==
36
37
38 (((
39 (((
40 LSN50 is a Long Range LoRaWAN Sensor Node. It is designed for (% style="color:#4472c4" %)**outdoor data logging **(%%)and powered by (% style="color:#4472c4" %)**Li/SOCl2 battery**(%%) for long term use and secure data transmission. It is designed to facilitate developers to quickly deploy industrial level LoRa and 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.
41 )))
42
43 (((
44 It is based on SX1276/SX1278 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 minimizing current consumption. It targets professional wireless sensor network applications such as irrigation systems, smart metering, smart cities, smartphone detection, building automation, and so on.
45 )))
46
47 (((
48 (% style="color:#4472c4" %)**LSN50**(%%) uses STM32l0x chip from ST, STML0x is the (% style="color:#4472c4" %)**ultra-low-power**(%%) STM32L072xx 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.
49 )))
50
51 (((
52 LSN50 is an (% style="color:#4472c4" %)**open source product**(%%), it is based on the STM32Cube HAL drivers and lots of libraries can be found in ST site for rapid development.
53 )))
54 )))
55
56
57 [[image:1656294562709-486.png]]
58
59
60
61 == 1.2  Specifications ==
62
63
64 (% style="color:#037691" %)**Micro Controller:**
65
66 * STM32L072CZT6 MCU
67 * MCU: STM32L072CZT6
68 * Flash: 192KB
69 * RAM: 20KB
70 * EEPROM: 6KB
71 * Clock Speed: 32Mhz
72
73 (% style="color:#037691" %)**Common DC Characteristics:**
74
75 * Supply Voltage: 2.1v ~~ 3.6v
76 * Operating Temperature: -40 ~~ 85°C
77 * I/O pins: Refer to STM32L072 datasheet
78
79 (% style="color:#037691" %)**LoRa Spec:**
80
81
82 * Frequency Range, 
83 ** Band 1 (HF): 862 ~~ 1020 Mhz
84
85 or
86
87 *
88 ** Band 2 (LF): 410 ~~ 528 Mhz
89 * 168 dB maximum link budget.
90 * +20 dBm - 100 mW constant RF output vs.
91 * +14 dBm high efficiency PA.
92 * Programmable bit rate up to 300 kbps.
93 * High sensitivity: down to -148 dBm.
94 * Bullet-proof front end: IIP3 = -12.5 dBm.
95 * Excellent blocking immunity.
96 * Low RX current of 10.3 mA, 200 nA register retention.
97 * Fully integrated synthesizer with a resolution of 61 Hz .
98 * FSK, GFSK, MSK, GMSK, LoRaTM and OOK modulation.
99 * Built-in bit synchronizer for clock recovery.
100 * Preamble detection.
101 * 127 dB Dynamic Range RSSI.
102 * Automatic RF Sense and CAD with ultra-fast AFC.
103 * Packet engine up to 256 bytes with CRC.
104 * LoRaWAN 1.0.2 Specification
105
106 (% style="color:#037691" %)**Battery:**
107
108 * Li/SOCI2 un-chargeable battery
109 * Capacity: 4000mAh
110 * Self Discharge: <1% / Year @ 25°C
111 * Max continuously current: 130mA
112 * Max boost current: 2A, 1 second
113
114 (% style="color:#037691" %)**Power Consumption**
115
116 * STOP Mode: 2.7uA @ 3.3v
117 * LoRa Transmit Mode: 125mA @ 20dBm 44mA @ 14dBm
118
119 == ​1.3  Features ==
120
121 * LoRaWAN 1.0.3 Class A, Class C
122 * STM32L072CZT6 MCU
123 * SX1276/78 Wireless Chip
124 * Pre-load bootloader on USART1/USART2
125 * MDK-ARM Version 5.24a IDE
126 * I2C, LPUSART1, USB, SPI2
127 * 3x12bit ADC, 1x12bit DAC
128 * 20xDigital I/Os
129 * LoRa™ Modem
130 * Preamble detection
131 * Baud rate configurable
132 * CN470/EU433/KR920/US915/IN865
133 * EU868/AS923/AU915
134 * Open-source hardware / software
135 * Available Band:433/868/915/920 Mhz
136 * IP66 Waterproof Enclosure
137 * Ultra-Low Power consumption
138 * AT Commands to change parameters
139 * 4000mAh or 8500mAh Battery for long term use。
140
141 == 1.4 ​ Applications ==
142
143
144 * Smart Buildings & Home Automation
145 * Logistics and Supply Chain Management
146 * Smart Metering
147 * Smart Agriculture
148 * Smart Cities
149 * Smart Factory
150
151 (% title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]][[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)​(%%)​
152
153
154
155 == 1.5  Pin Definitions and Switch ==
156
157 (% class="wikigeneratedid" %)
158 [[image:1656295519542-152.png||height="413" width="728"]]
159
160
161 (% class="wikigeneratedid" %)
162 [[image:1656295532863-613.png||height="371" width="721"]]
163
164
165 (% class="wikigeneratedid" %)
166 [[image:image-20220627101527-1.png]]
167
168 (% class="wikigeneratedid" style="display:none" %)
169
170
171
172 === 1.5.1 Jumper JP2 ===
173
174 Power on Device when put this jumper.
175
176
177 === 1.5.2 BOOT MODE / SW1 ===
178
179 (((
180 ~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.
181 )))
182
183 (((
184 2. Flash:  work mode, device starts to work and send out console output for further debug
185 )))
186
187
188 === 1.5.3 Reset Button ===
189
190 Press to reboot the device.
191
192
193 === 1.5.4 LED ===
194
195 It will flash:
196
197 1. When boot the device in flash mode
198 1. Send an uplink packet
199
200 === 1.6  Hardware Change log ===
201
202 Note: Hardware version is marked in the PCB.
203
204 **LSN50 v2.1:**
205
206 1. Change R14 to 1M ohm
207 1. Change R3, R4 to 4.7Kohm. So no need to modify them for 3 DS18B20 connection.
208 1. Add ESD to each I/O
209
210 **LSN50 v2.0:**
211
212 * Change to a new enclosure. Improve with external antenna, IP68, ear hook.
213
214 **LSN50 v1.3**:
215
216 * Add P-MOS to control 5V output
217
218 **LSN50 v1.2**:
219
220 * Add LED. Turn on for every LoRa transmit
221 * Add pin PA4, PB13, NRST
222 * Add 5V Output, on/off control by PB5(Low to Enable, High to Disable)
223
224 == (% id="cke_bm_478801S" style="display:none" %) (%%)1.7  Hole Option ==
225
226 The LSN50 provides different hole size options for different size sensor cable. The options provided are M12, M16 and M20. The definition is as below:
227
228 [[image:image-20220627104757-1.png]]
229
230
231 [[image:1656298089706-973.png]]
232
233
234
235 = 2.  Use LSN50 with LoRaWAN firmware =
236
237 == 2.1  How it works ==
238
239 (((
240 (((
241 The LSN50 is pre-loaded with a firmware and is configured as LoRaWAN OTAA Class A mode by default. It has OTAA keys to join LoRaWAN network. To connect a local LoRaWAN network, you just need to input the OTAA keys in the LoRaWAN IoT server and power on the LSN50. It will automatically join the network via OTAA.
242 )))
243
244 (((
245
246 )))
247
248 (((
249 The diagram below shows the working flow in default firmware (ver 1.7.0): 
250 )))
251
252
253 [[image:image-20220627104855-2.png]]
254
255
256 In case you can't set the OTAA keys in the LoRaWAN OTAA server, and you have to use the keys from the server, you can [[use AT Commands>>doc:Main.End Device AT Commands and Downlink Command.WebHome]] to set the keys in the LSN50.
257 )))
258
259
260 == 2.2  ​Quick guide to connect to LoRaWAN server (OTAA) ==
261
262 (((
263 Following is an example for how to join the [[TTN V3 LoRaWAN Network>>url:http://www.thethingsnetwork.org/]]. Below is the network structure; we use the [[LG308>>url:http://www.dragino.com/products/lora/item/140-lg308.html]] as a LoRaWAN gateway in this example. 
264
265 (% style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]][[image:1655891470063-521.png]](% title="Click and drag to resize" %)​[[image:1656298385089-555.png]]
266
267
268 )))
269
270 (% title="Click and drag to resize" %)​(%%)The LG308 is already set to connected to [[TTN V3 network >>url:https://www.thethingsnetwork.org/]], so what we need to now is configure the TTN V3 server.(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]][[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)​(%%)​
271
272 (((
273
274
275 (% style="color:blue" %)**Step 1**(%%): Create a device in TTN with the OTAA keys from LSN50.
276
277 Each LSN50is shipped with a sticker with the default device EUI as below:
278 )))
279
280 (((
281
282 )))
283
284 (% aria-label="image-20220607170145-1.jpeg image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220607170145-1.jpeg||data-widget="image"]](% style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(% title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]][[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)​(%%)​
285
286
287 (((
288 You can enter this key in the LoRaWAN Server portal. Below is TTN screen shot:
289
290 **Register the device:**
291 )))
292
293 (% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(% title="Click and drag to resize" %)​(% aria-label="1654935135620-998.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:1654935135620-998.png||data-widget="image"]](% style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](%%)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(% title="Click and drag to resize" %)​​
294
295 (% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(% title="Click and drag to resize" %)​
296
297
298 **Add APP EUI and DEV EUI:**
299
300
301 (% aria-label="image-20220611161308-4.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220611161308-4.png||data-widget="image" height="551" width="753"]](% style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
302
303
304
305 **Add APP EUI in the application:**
306
307
308 (% aria-label="image-20220611161308-5.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220611161308-5.png||data-widget="image" height="601" width="742"]](% style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
309
310
311 **Add APP KEY**
312
313 (% aria-label="image-20220611161308-6.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220611161308-6.png||data-widget="image" height="485" width="744"]](% style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
314
315 (% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​
316
317 (% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]][[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)​(%%)​
318
319 (% style="color:blue" %)**Step 2**(%%): Power on LSN50
320
321 Put a Jumper on JP2 to power on the device.(% style="display:none" %)
322
323 [[image:image-20220627145643-5.png]](% style="display:none" %)
324
325 (% style="display:none" %)
326
327
328 (% style="display:none" %) (%%)
329
330 **For LSn50v2:**
331
332 [[image:1656313034748-905.png]](% style="display:none" %)
333
334
335 (% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(%%)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]][[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)​(%%)​
336
337 (((
338 (((
339 (% style="color:blue" %)**Step 3**(%%)**:**  The LSN50 will auto join to the TTN V3 network. After join success, it will start to upload messages to TTN V3 and you can see the messages in the panel.
340 )))
341 )))
342
343 (% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(% title="Click and drag to resize" %)​[[image:1656312908855-552.png]](% style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]]
344
345 ​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" %)[[image:||data-widget="image" draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220, 220, 220, 0.5); display:none" tabindex="-1" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% aria-label="Data URI image image widget" contenteditable="false" role="region" style="background-image:url(http://wiki1.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" tabindex="-1" title="Click and drag to resize" %)​(% title="Click and drag to resize" %)​​
346
347
348 == 2.3  ​Working Mode & Uplink Payload ==
349
350 LSN50 has different working mode for the connections of different type of sensors. This section describes these modes. Use can use the AT Command AT+MOD to set LSN50 to different working modes.
351
352 For example:
353
354 (% style="color:red" %)**AT+MOD=2**(%%) ~/~/ will set the LSN50 to work in MOD=2 distance mode which target to measure distance via Ultrasonic Sensor.
355
356
357 (% style="color:red" %)**NOTE:**
358
359 (% style="color:red" %)1. Some working modes has payload more than 12 bytes, The US915/AU915/AS923 frequency bands’ definition has maximum 11 bytes in **DR0**. Server sides will see NULL payload while LSn50 transmit in DR0 with 12 bytes payload.
360 2. All modes share the same Payload Explanation from HERE.
361 3. By default, the device will send an uplink message every 5 minutes.
362
363 (% border="1" cellspacing="10" style="background-color:#ffffcc; color:green; width:400px" %)
364 |=(% style="width: 62.5px;" %)(((
365 **Size (bytes)**
366 )))|=(% style="width: 60px;" %)2|=(% style="width: 60px;" %)4|=(% style="width: 65px;" %)1|=(% style="width: 65px;" %)**2**|=(% style="width: 65px;" %)2
367 |(% style="width:65px" %)**Value**|(((
368 [[Battery>>||anchor="HBattery:"]]
369 )))|(% style="width:61px" %)(((
370 ignore
371 )))|(% style="width:91px" %)(((
372 [[Alarm Flag>>||anchor="HAlarmFlag26MOD:"]]
373 )))|(% style="width:99px" %)(((
374 [[Temperature>>||anchor="HTemperature:"]]
375 )))|(% style="width:97px" %)(((
376 [[Humidity>>||anchor="HHumidity:"]]
377 )))
378
379 === 2.3.1  MOD~=1 (Default Mode) ===
380
381 (((
382 In this mode, uplink payload includes in total 11 bytes. Uplink packets use FPORT=2.
383 [[image:image-20220627171207-27.png]]
384
385 [[image:image-20220627150949-6.png]]
386
387
388 )))
389
390
391 === 2.3.2 MOD~=2 (Distance Mode) ===
392
393 This mode is target to measure the distance. The payload of this mode is totally 11 bytes. The 8^^th^^ and 9^^th^^ bytes is for the distance.
394
395
396
397 (% border="1" style="background-color:#ffffcc; color:green; width:836px" %)
398 |(% style="width:96px" %)**Size(bytes)**|(% style="width:45px" %)**2**|(% style="width:178px" %)**2**|(% style="width:53px" %)**2**|(% style="width:209px" %)**1**|(% style="width:167px" %)**2**|(% style="width:85px" %)**2**
399 |(% style="width:96px" %)**Value**|(% style="width:45px" %)BAT|(% style="width:178px" %)(((
400 Temperature(DS18B20)
401 )))|(% style="width:53px" %)ADC|(% style="width:209px" %)Digital in & Digital Interrupt|(% style="width:167px" %)(((
402 Distance measure by:
403
404 1) LIDAR-Lite V3HP
405
406 Or
407
408 2) Ultrasonic Sensor
409 )))|(% style="width:85px" %)Reserved
410
411
412 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image001.png]]
413
414
415
416 Connection of LIDAR-Lite V3HP:
417
418 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image002.png]]
419
420
421 Connection to Ultrasonic Sensor:
422
423 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image003.png]]
424
425
426
427
428
429 For the connection to TF-Mini or TF-Luna , MOD2 payload is as below:
430
431
432 (% border="1" style="background-color:#ffffcc; color:green" %)
433 |**Size(bytes)**|**2**|**2**|**1**|**2**|**2**|**2**
434 |**Value**|BAT|(((
435 Temperature
436
437 (DS18B20)
438 )))|Digital in & Digital Interrupt|ADC|(((
439 Distance measure by:
440
441 1)TF-Mini plus LiDAR
442
443 Or
444
445 2) TF-Luna LiDAR
446 )))|Distance signal  strength
447
448
449 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image004.png]]
450
451
452 Connection to [[TF-Mini plus>>url:http://en.benewake.com/product/detail/5c345cd0e5b3a844c472329b.html]] LiDAR(UART version):
453
454 Need to remove R3 and R4 resistors to get low power. Since firmware v1.7.0[[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image005.png]]
455
456
457
458 Connection to [[TF-Luna>>url:http://en.benewake.com/product/detail/5e1c1fd04d839408076b6255.html]] LiDAR (UART version):
459
460 Need to remove R3 and R4 resistors to get low power. Since firmware v1.7.0
461
462
463 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image006.png]]
464
465
466 Please use firmware version > 1.6.5 when use MOD=2, in this firmware version, user can use LSn50 v1 to power the ultrasonic sensor directly and with low power consumption.
467
468
469
470
471
472 === 2.3.3 MOD~=3 (3 ADC + I2C) ===
473
474
475 This mode has total 12 bytes. Include 3 x ADC + 1x I2C
476
477
478 (% border="1" style="background-color:#ffffcc; color:green" %)
479 |**Size(bytes)**|**2**|**2**|**2**|**1**|**2**|**2**|**1**
480 |**Value**|(((
481 ADC1
482
483 (Pin PA0)
484 )))|(((
485 ADC2
486
487 (PA1)
488 )))|(((
489 ADC3
490
491 (PA4)
492 )))|Digital in & Digital Interrupt|(((
493 Temperature
494
495 (SHT20 or SHT31)
496 )))|(((
497 Humidity
498
499 (SHT20 or SHT31)
500 )))|BAT
501
502
503 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image007.png]]
504
505
506 === 2.3.4 MOD~=4 (3 x DS18B20) ===
507
508
509 This mode is supported in firmware version since v1.6.1. Software set to AT+MOD=4
510
511 Hardware connection is as below,
512
513 (Note:
514
515 * In hardware version v1.x and v2.0 , R3 & R4 should change from 10k to 4.7k ohm to support the other 2 x DS18B20 probes.
516 * In hardware version v2.1 no need to change R3 , R4, by default, they are 4.7k ohm already.
517
518 See [[here>>path:#hardware_changelog]] for hardware changelog.
519
520 )
521
522 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image008.png]]
523
524
525 This mode has total 11 bytes. As shown below:
526
527 (% border="1" style="background-color:#ffffcc; color:green" %)
528 |**Size(bytes)**|**2**|**2**|**2**|**1**|**2**|**2**
529 |**Value**|BAT|(((
530 Temperature1
531
532 (DS18B20)
533
534 (PB3)
535 )))|(((
536 ADC
537
538
539 )))|Digital in & Digital Interrupt|(((
540 Temperature2
541
542 (DS18B20)
543
544 (PA9)
545 )))|(((
546 Temperature3
547
548 (DS18B20)
549
550 (PA10)
551 )))
552
553 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image009.png]]
554
555
556 === 2.3.5 MOD~=5(Weight Measurement by HX711) ===
557
558
559 This mode is supported in firmware version since v1.6.2. Please use v1.6.5 firmware version so user no need to use extra LDO for connection.
560
561 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image010.png]]
562
563
564 Each HX711 need to be calibrated before used. User need to do below two steps:
565
566 1. Zero calibration. Don’t put anything on load cell and run **AT+WEIGRE** to calibrate to Zero gram.
567 1. Adjust calibration factor (default value 400): Put a known weight thing on load cell and run **AT+WEIGAP** to adjust the Calibration Factor.
568
569 For example:
570
571
572 **AT+WEIGAP =403.0**
573
574 Response:  Weight is 401 g
575
576
577 Check the response of this command and adjust the value to match the real value for thing.
578
579
580
581 (% border="1" style="background-color:#ffffcc; color:green" %)
582 |**Size(bytes)**|**2**|**2**|**2**|**1**|**2**|**2**
583 |**Value**|[[BAT>>path:#BAT]]|(((
584 [[Temperature>>path:#DS18B20]]
585
586 [[(DS18B20)>>path:#DS18B20]]
587 )))|[[ADC>>path:#ADC]]|[[Digital in & Digital Interrupt>>path:#Digtial_input]]|Weight|Reserved
588
589 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image011.png]]
590
591
592
593
594
595 === 2.3.6 MOD~=6(Counting Mode, Since firmware v1.6.5) ===
596
597
598 In this mode, the device will work in counting mode. It counts the interrupt on the interrupt pins and sends the count on TDC time.
599
600
601 Connection is as below. The PIR sensor is a count sensor, it will generate interrupt when people come close or go away. User can replace the PIR sensor with other counting sensors.
602
603
604 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image012.png]]
605
606 Note: LoRaWAN wireless transmission will infect the PIR sensor. Which cause the counting value increase +1 for every uplink. User can change PIR sensor or put sensor away of the LSN50 to avoid this happen.
607
608
609 (% border="1" style="background-color:#ffffcc; color:green" %)
610 |**Size(bytes)**|**2**|**2**|**2**|**1**|**4**
611 |**Value**|[[BAT>>path:#BAT]]|(((
612 [[Temperature>>path:#DS18B20]]
613
614 [[(DS18B20)>>path:#DS18B20]]
615 )))|[[ADC>>path:#ADC]]|[[Digital in>>path:#Digtial_input]]|Count
616
617
618 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image013.png]]
619
620
621
622
623
624
625 === 2.3.7 ​Decode payload in The Things Network ===
626
627 While using TTN V3 network, you can add the payload format to decode the payload.
628
629
630 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image014.png]]
631
632
633 The payload decoder function for TTN V3 are here:
634
635 LSN50 TTN V3 Payload Decoder: [[http:~~/~~/www.dragino.com/downloads/downloads/LSN50-LoRaST/Payload_decoder/>>url:http://www.dragino.com/downloads/downloads/LSN50-LoRaST/Payload_decoder/]]
636
637
638
639
640
641
642
643 == 2.4 Payload Explanation and Sensor Interface ==
644
645 === 2.4.1 Battery Info ===
646
647 Check the battery voltage for LSN50.
648
649 Ex1: 0x0B45 = 2885mV
650
651 Ex2: 0x0B49 = 2889mV
652
653
654 === 2.4.2 Temperature (DS18B20) ===
655
656 If there is a DS18B20 connected to PB3 pin. The temperature will be uploaded in the payload.
657
658
659 More DS18B20 can check the [[3 DS18B20 mode>>path:#ds18b20_3]]
660
661
662 **Connection**
663
664 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image015.png]]
665
666
667 **Example**:
668
669 If payload is: 0105H:  (0105 & FC00 == 0), temp = 0105H /10 = 26.1 degree
670
671 If payload is: FF3FH :  (FF3F & FC00 == 1) , temp = (FF3FH - 65536)/10 = -19.3 degrees.
672
673
674 === 2.4.3 Digital Input ===
675
676 The digital input for pin PA12,
677
678 * When PA12 is high, the bit 1 of payload byte 6 is 1.
679 * When PA12 is low, the bit 1 of payload byte 6 is 0.
680
681
682
683
684 === 2.4.4 Analogue Digital Converter (ADC) ===
685
686
687 The ADC pins in LSN50 can measure range from 0~~3.3v, it use reference voltage from STM32. If user need to measure a voltage >3.3v, please use resistors to divide this voltage to lower than 3.3v, otherwise, it may destroy the ADC pin.
688
689
690 The ADC monitors the voltage on the PA0 line, in mV.
691
692 Ex: 0x021F = 543mv,
693
694
695 **Example1:**  Reading an Oil Sensor (Read a resistance value):
696
697 [[image:image-20220627172409-28.png]]
698
699
700
701
702 In the LSN50, we can use PB4 and PA0 pin to calculate the resistance for the oil sensor.
703
704
705 Steps:
706
707 1. Solder a 10K resistor between PA0 and VCC.
708 1. Screw oil sensor's two pins to PA0 and PB4.
709
710 The equipment circuit is as below:
711
712 [[image:image-20220627172500-29.png]]
713
714
715
716
717 According to above diagram:
718
719 (//VCC-VPA010k=VPA0Roilsensor//[[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image018.png]]
720
721
722 So
723
724 //Roilsensor=VPA0×10KVCC-VPA0//[[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image019.png]]
725
726 //VPA0//[[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image020.png]] is the reading of ADC. So if ADC=0x05DC=0.9 v and VCC (BAT) is 2.9v
727
728
729 The //Roilsensor=0.9×10K2.9-0.9=//[[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image021.png]] 4.5K ohm
730
731 Since the Bouy is linear resistance from 10 ~~ 70cm.
732
733
734 The position of Bouy is //4.5K10K×70cm-10cm+10cm=37cm//[[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image022.png]] , from the bottom of Bouy
735
736
737 === 2.4.5 Digital Interrupt ===
738
739 Digital Interrupt refers to pin PB14, and there are different trigger methods. When there is a trigger, the LSN50 will send a packet to the server.
740
741
742 Interrupt connection method:
743
744 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image023.png]]
745
746
747 **Example to use with door sensor **
748 (Requires firmware > 1.5.1)
749
750
751 The door sensor is shown at right. It is a two wire magnetic contact switch used for detecting the open/close status of doors or windows. [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image024.png]]
752
753
754 When the two pieces are close to each other, the 2 wire output will be short or open (depending on the type), while if the two pieces are away from each other, the 2 wire output will be the opposite status. So we can use LSN50 interrupt interface to detect the status for the door or window.
755
756
757 Below is the installation example:
758
759 Fix one piece of the magnetic sensor to the door and connect the two pins to LSN50 as follows:
760
761 * One pin to LSN50’s PB14 pin
762 * The other pin to LSN50’s VCC pin
763
764 Install the other piece to the door. Find a place where the two pieces will be close to each other when the door is closed. For this particular magnetic sensor, when the door is closed, the output will be short, and PB14 will be at the VCC voltage.
765
766
767 Door sensors have two types:  NC (Normal close) and NO (normal open). The connection for both type sensors are the same. But the decoding for payload are reverse, user need to modify this in the IoT Server decoder.
768
769
770 When door sensor is shorted, there will extra power consumption in the circuit, the extra current is 3v3/R14 = 3v2/1Mohm = 0.3uA which can be ignored.
771
772
773
774
775 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image025.png]]
776
777
778 The above photos shows the two parts of the magnetic switch fitted to a door.
779
780
781 The software by default uses the falling edge on the signal line as an interrupt. We need to modify it to accept both the rising edge (0v ~-~-> VCC , door close) and the falling edge (VCC ~-~-> 0v , door open) as the interrupt.
782
783
784 The command is:
785
786 **AT+INTMOD=1    ~/~/(more info about INMOD please refer **[[**AT Command Manual**>>url:http://www.dragino.com/downloads/index.php?dir=LSN50-LoRaST/&file=DRAGINO_LSN50_AT_Commands_v1.5.1.pdf]]**. )**
787
788
789 Below shows some screen captures in TTN V3:
790
791
792 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image026.png]]
793
794
795 In MOD=1, user can use byte 6 to see the status for door open or close. TTN V3 decoder is as below:
796
797
798 door= (bytes[6] & 0x80)? "CLOSE":"OPEN";
799
800
801
802 **Notice for hardware version LSN50 v1 < v1.3** (produced before 2018-Nov).
803
804 In this hardware version, there is no R14 resistance solder. When use the latest firmware, it should set AT+INTMOD=0 to close the interrupt. If user need to use Interrupt in this hardware version, user need to solder R14 with 10M resistor and C1 (0.1uF) on board.
805
806 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image027.png]]
807
808
809
810
811
812 === 2.4.6 I2C Interface (SHT20) ===
813
814 The PB6(SDA) and PB7(SCK) are I2C interface lines. You can use these to connect to an I2C device and get the sensor data.
815
816
817 We have made an example to show how to use the I2C interface to connect to the SHT20 Temperature and Humidity Sensor. This is supported in the stock firmware since v1.5 with **AT+MOD=1 (default value).**
818
819
820 Below is the connection to SHT20.
821
822
823 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image028.png]]
824
825
826 The device will be able to get the I2C sensor data now and upload to IoT Server.
827
828
829 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image029.png]]
830
831 Convert the read byte to decimal and divide it by ten.
832
833
834 **Example:**
835
836 Temperature:  Read:0116(H) = 278(D)  Value:  278 /10=27.8℃;
837
838 Humidity:    Read:0248(H)=584(D)    Value:  584 / 10=58.4, So 58.4%
839
840
841 If you want to use other I2C device, please refer the SHT20 part source code as reference.
842
843
844 === 2.4.7 ​Distance Reading ===
845
846 Refer [[Ultrasonic Sensor section>>path:#Ultrasonic_Sensor]].
847
848
849 === 2.4.8 Ultrasonic Sensor ===
850
851 The LSN50 v1.5 firmware supports ultrasonic sensor (with AT+MOD=2) such as SEN0208 from DF-Robot. This Fundamental Principles of this sensor can be found at this link: [[https:~~/~~/wiki.dfrobot.com/Weather_-_proof_Ultrasonic_Sensor_with_Separate_Probe_SKU~~_~~__SEN0208>>url:https://wiki.dfrobot.com/Weather_-_proof_Ultrasonic_Sensor_with_Separate_Probe_SKU___SEN0208]]
852
853
854 The LSN50 detects the pulse width of the sensor and converts it to mm output. The accuracy will be within 1 centimeter. The usable range (the distance between the ultrasonic probe and the measured object) is between 24cm and 600cm.
855
856
857 The picture below shows the connection:
858
859 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image003.png]]
860
861
862
863 Connect to the LSN50 and run **AT+MOD=2** to switch to ultrasonic mode (ULT).
864
865 The ultrasonic sensor uses the 8^^th^^ and 9^^th^^ byte for the measurement value.
866
867
868 **Example:**
869
870 Distance:  Read:0C2D(Hex) = 3117(D)  Value:  3117 mm=311.7 cm
871
872
873 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image030.png]]
874
875
876 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image031.png]]
877
878
879
880 You can see the serial output in ULT mode as below:
881
882
883 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image032.png]]
884
885
886 In TTN V3 server:
887
888
889 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image030.png]]
890
891
892 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image031.png]]
893
894
895 === 2.4.9 +5V Output ===
896
897 Since v1.2 hardware version, a +5v output is added in the hardware. The +5V output will be valid for every sampling.  LSN50 will enable +5V output before all sampling and disable the +5v after all sampling. 
898
899
900 Since firmware **v1.6.3**, The 5V output time can be controlled by AT Command.
901
902 **AT+5VT=1000**
903
904 Means set 5V valid time to have 1000ms. So the real 5V output will actually have 1000ms + sampling time for other sensors.
905
906
907 By default the AT+5VT=500. If the external sensor which require 5v and require more time to get stable state, user can use this command to increase the power ON duration for this sensor.
908
909
910
911
912 === 2.4.10 Weigh Sensor HX711 ===
913
914 Since v1.6.2 firmware, LSN50 support Weigh Sensor HX711.
915
916
917 === 2.4.11 BH1750 Illumination Sensor ===
918
919 Since v1.7.0 firmware, MOD=1 support this sensor. The sensor value is in the 8^^th^^ and 9^^th^^ bytes.
920
921 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image033.jpg]]
922
923
924 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image034.png]]
925
926
927
928 === 2.4.12 Working MOD ===
929
930 The working MOD info is contained in the Digital in & Digital Interrupt byte (7^^th^^ Byte).
931
932
933 User can use the 3^^rd^^ ~~ 7^^th^^  bit of this byte to see the working mod:
934
935
936 Case 7^^th^^ Byte >> 2 & 0x1f:
937
938 * 0: MOD1
939 * 1: MOD2
940 * 2: MOD3
941 * 3: MOD4
942 * 4:MOD5
943 * 5:MOD6
944
945
946
947 == 2.5 Configure LSN50 via AT or Downlink ==
948
949 User can configure LSN50 via [[AT Commands >>path:#_​Using_the_AT]]or LoRaWAN Downlink Commands
950
951 There are two kinds of Commands:
952
953 * (% style="color:#4472c4" %)**Common Commands**(%%): They should be available for each sensor, such as: change uplink interval, reset device. For firmware v1.7.0, user can find what common commands it supports: http:~/~/wiki.dragino.com/index.php?title=End_Device_AT_Commands_and_Downlink_Commands
954
955 * (% style="color:#4472c4" %)**Sensor Related Commands**(%%): These commands are special designed for LSN50.  User can see these commands below:
956
957 === 2.5.1 Common Commands: ===
958
959
960 They should be available for each of Dragino Sensors, such as: change uplink interval, reset device. For firmware v1.7.0, user can find what common commands it supports: http:~/~/wiki.dragino.com/index.php?title=End_Device_AT_Commands_and_Downlink_Commands
961
962
963 === 2.5.2 Sensor related commands: ===
964
965
966 (% style="color:#4472c4" %)**Set work mode:**
967
968 * (% style="color:#037691" %)AT Command:
969
970 AT+MOD=2  ~/~/ Set work MOD =2. (1:IIC mode,2:Distance mode,3:3ADC mode, 4:3DS18B20 mode,5:weight mode)
971
972 AT+MOD=?      ~/~/  Get current work MOD
973
974
975 * (% style="color:#037691" %)Downlink Payload:
976
977 0x0A aa ~/~/ Same as AT+MOD=aa
978
979
980
981 (% style="color:#4472c4" %)**Set the trigger interrupt mode:**
982
983 * (% style="color:#037691" %)AT Command:
984
985 AT+INTMOD=2  ~/~/ Set INTMOD =2. (0:Disable,1:falling or rising,2:falling,3:rising)
986
987 AT+INTMOD=?      ~/~/  Get current INTMOD
988
989
990 * (% style="color:#037691" %)Downlink Payload:
991
992 0x06 000003     ~/~/ Set AT+INTMOD=3
993
994
995 (% style="color:#4472c4" %)**Set the 5V power open time during sampling:**
996
997
998 * (% style="color:#037691" %)AT Command:
999
1000 AT+5VT=1000  ~/~/ Set 5v open time to 1000ms
1001
1002 AT+5VT=?      ~/~/  Check current 5v open duration
1003
1004
1005 * (% style="color:#037691" %)Downlink Payload:
1006
1007 0x07 aa bb     ~/~/ Equal AT+5VT=0x(aa bb)
1008
1009
1010
1011
1012 (% style="color:#4472c4" %)**Set the weight to 0g (Zero Calibration)**
1013
1014 * (% style="color:#037691" %)AT Command:
1015
1016 AT+WEIGRE  ~/~/ Set the weight to 0g
1017
1018
1019 * (% style="color:#037691" %)Downlink Payload:
1020
1021 0x08 01     ~/~/ Set the weight to 0g
1022
1023
1024
1025 (% style="color:#4472c4" %)**Get or Set the GAP Value (calibrate factor) of measurement**
1026
1027 * (% style="color:#037691" %)AT Command:
1028
1029 AT+WEIGAP=403.0  ~/~/ Set GAP Value =403.0 (response: Weight: xx g)
1030
1031 AT+WEIGAP=?      ~/~/  Get current GAP Value
1032
1033
1034 * (% style="color:#037691" %)Downlink Payload:
1035
1036 0x08 02 aa bb     ~/~/ Equal to AT+WEIGAP=0x(aa bb)/10
1037
1038
1039
1040
1041
1042
1043
1044 == 2.6 Show Data in Datacake IoT Server ==
1045
1046 Datacake provides a human friendly interface to show the sensor data, once we have data in TTN V3, we can use Datacake to connect to TTN V3 and see the data in Datacake. Below are the steps:
1047
1048
1049 (% style="color:blue" %)Step 1(%%): Be sure that your device is programmed and properly connected to the network at this time.
1050
1051 (% style="color:blue" %)Step 2(%%): To configure the Application to forward data to Datacake you will need to add integration. To add the Datacake integration, perform the following steps:
1052
1053
1054 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image035.png]]
1055
1056
1057 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image036.png]]
1058
1059
1060 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image037.png]]
1061
1062
1063
1064 (% style="color:blue" %)Step 3(%%): Create an account or log in Datacake.
1065
1066 (% style="color:blue" %)Step 4(%%): Search the LSN50 and add DevEUI.
1067
1068 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image038.png]]
1069
1070
1071
1072 == 2.7 ​Firmware Change Log ==
1073
1074 ~* [[**Firmware download link**>>url:https://github.com/dragino/LoRa_STM32/tree/master/LSN50.hex]]
1075
1076 [[http:~~/~~/www.dragino.com/downloads/index.php?dir=LSN50-LoRaST/Firmware/LSN50.hex/>>url:http://www.dragino.com/downloads/index.php?dir=LSN50-LoRaST/Firmware/LSN50.hex/]]
1077
1078
1079 **~* Firmware Change Log:**
1080
1081 [[http:~~/~~/www.dragino.com/downloads/index.php?dir=LSN50-LoRaST/Firmware/LSN50.hex/>>url:http://www.dragino.com/downloads/index.php?dir=LSN50-LoRaST/Firmware/LSN50.hex/]]
1082
1083
1084
1085
1086 == 2.8 Use VDD or +5V to Power External Sensor ==
1087
1088 User can use VDD or +5V to power external sensor.
1089
1090 (% style="color:red" %)Note:
1091
1092 1. VDD is 2.5~~3.3v from the battery + diode, the VDD is always on, so when use VDD to power external sensor, make sure the sensor has a low power consumption in sleep mode ( less 50 uA) to get a long battery life.
1093 1. +5V output is only ON when sampling. And MCU will turn off it after sampling. So if sensor can support 5v, +5V out is the best choice. [[See here for more info>>path:#output_5v]].
1094
1095 (% style="color:red" %)Note: Always test the actually current pass by the JP2 jumper when connect to a new type of sensor.
1096
1097
1098
1099
1100
1101
1102
1103 == 2.9  Battery Analysis ==
1104
1105 === 2.9.1  Battery Type ===
1106
1107 The LSN50 battery is a combination of a 4000mAh or 8500mAh Li/SOCI2 Battery and a Super Capacitor. The battery is non-rechargeable battery type with a low discharge rate (<2% per year). This type of battery is commonly used in IoT devices such as water meter.
1108
1109
1110 The battery is designed to last for more than 5 years for the LSN50.
1111
1112
1113 The battery related documents as below:
1114
1115 * [[Battery Dimension>>https://www.dragino.com/downloads/index.php?dir=datasheet/Battery/]],
1116 * [[Lithium-Thionyl Chloride Battery datasheet>>https://www.dragino.com/downloads/index.php?dir=datasheet/Battery/]], [[Tech Spec>>https://www.dragino.com/downloads/index.php?dir=datasheet/Battery/]]
1117 * [[Lithium-ion Battery-Capacitor datasheet>>https://www.dragino.com/downloads/index.php?dir=datasheet/Battery/]], [[Tech Spec>>https://www.dragino.com/downloads/index.php?dir=datasheet/Battery/]]
1118
1119 [[image:image-20220627175349-30.png]]
1120
1121
1122 === 2.9.2 ​Power consumption Analyze ===
1123
1124 When connect to different sensors, it is good to test the power consumption with the sensor working. User can remove the [[ON/OFF Jumper>>path:#power_on]] of LSN50, and connect a multimeter between the two pins of this header and measure the current to know the whole system power consumption. Because the sleep mode will have as low as 10uA, at least 4.5 digit multimeter is required to measure this level of current.
1125
1126 A victor VC86E is recommended.
1127
1128 [[image:1656323400306-359.png]]
1129
1130
1131 In a minimum system with DS18B20 and Oil Sensor and default firmware, the power consumption includes:
1132
1133
1134 ~1. Deep Sleep (Stop mode) for STM32. ~~ 5uA
1135
1136 2. Sampling current while reading DS18B20 and Oil Sensor
1137
1138 * Oil Sensor sampling time: 200us, current: 0.3mA
1139 * DS18B20 sampling time: 750ms, current: 0.64mA
1140 * Above power should add 8mA CPU power in working mode.
1141
1142 3. LoRaWAN transmit and receive time consumption. The LoRa TX / RX time and power can be found in the [[LoRa calculator tool>>url:https://www.semtech.com/uploads/documents/SX1272LoRaCalculatorSetup1_1.zip]].
1143
1144
1145 In a typical LoRaWAN data transmit. The energy profile is as below:
1146
1147
1148 [[image:1656323450362-299.png]]
1149
1150 In the LoRaWAN protocol, the device will transfer in different LoRa Radio, and have different energy profile in LoRa part. We can calculate the battery life in two cases:
1151
1152 1. Lower power LoRa radio. Device has a good signal to gateway
1153 1. Higher power LoRa radio. Device has a poor signal to gateway
1154
1155
1156 (% style="color:blue" %)**Low Power Case**:
1157
1158 * Radio Parameter: SF7, 125kHz, 20dbm
1159 * Transmit interval: 15 minutes.
1160 * Payload: 8 Bytes.
1161
1162 (% style="color:blue" %)**High Power Case**:
1163
1164 * Radio Parameter: SF10, 125kHz, 20dbm
1165 * Transmit interval: 15 minutes.
1166 * Payload: 8 Bytes.
1167
1168 To simplify the calculation, we can:
1169
1170 * Combine oil sensor and DS18B20 sampling energy together to **751ms@8.64ma**
1171
1172 * Combine the two RX windows together.
1173
1174 There is a [[power consumption tool>>url:http://www.dragino.com/downloads/index.php?dir=LSN50-LoRaST/&file=Battery_Calculator_v1.0.xlsx]] for easy analysis. Below is the analysis result.
1175
1176
1177 [[image:1656323531520-949.png]]
1178
1179 [[image:1656323549994-233.png]]
1180
1181
1182 (% style="color:red" %)Note: Ignore the 18 year result, because the battery has a max 2% discharge per year.
1183
1184
1185 === 2.9.3 ​Battery Note ===
1186
1187 (((
1188 The Li-SICO battery is designed for small current / long period application. It is not good to use a high current, short period transmit method. The recommended minimum period for use of this battery is 5 minutes. If you use a shorter period time to transmit LoRa, then the battery life may be decreased.
1189 )))
1190
1191
1192 === 2.9.4 Replace the battery ===
1193
1194 (((
1195 You can change the battery in the LSN50.The type of battery is not limited as long as the output is between 3v to 3.6v. On the main board, there is a diode (D1) between the battery and the main circuit. If you need to use a battery with less than 3.3v, please remove the D1 and shortcut the two pads of it so there won’t be voltage drop between battery and main board.
1196 )))
1197
1198 (((
1199 The default battery pack of LSN50 includes a ER18505 plus super capacitor. If user can't find this pack locally, they can find ER18505 or equivalence, which will also work in most case. The SPC can enlarge the battery life for high frequency use (update period below 5 minutes).
1200 )))
1201
1202
1203
1204 = 3.  Using the AT Commands =
1205
1206 == 3.1  Access AT Commands ==
1207
1208 LSN50 supports AT Command set in the stock firmware. You can use a USB to TTL adapter to connect to LSN50 for using AT command, as below.
1209
1210
1211 (% style="color:#4472c4" %)**LSN50 v1 UART connection photo**
1212
1213 [[image:image-20220627165424-24.png||height="495" width="486"]]
1214
1215
1216 (% style="color:#4472c4" %)**LSN50 v2 UART connection photo**
1217
1218 [[image:image-20220627165424-25.png||height="483" width="988"]]
1219
1220
1221 (((
1222 In the PC, you need to set the serial baud rate to (% style="color:green" %)**9600**(%%) to access the serial console for LSN50. LSN50 will output system info once power on as below:
1223 )))
1224
1225 [[image:image-20220627165531-26.png]]
1226
1227
1228
1229 == 3.2  Common AT Command Sequence ==
1230
1231
1232 === 3.2.1  Multi-channel ABP mode (Use with SX1301/LG308) ===
1233
1234 (% style="color:#037691" %)**If device has not joined network via OTAA:**
1235
1236 (% style="background-color:#dcdcdc" %)AT+FDR
1237
1238 (% style="background-color:#dcdcdc" %)AT+NJM=0
1239
1240 (% style="background-color:#dcdcdc" %)ATZ
1241
1242
1243 (% style="color:#037691" %)**If device already joined network:**
1244
1245 (% style="background-color:#dcdcdc" %)AT+NJM=0
1246
1247 (% style="background-color:#dcdcdc" %)ATZ
1248
1249
1250 === 3.2.2  Single-channel ABP mode (Use with LG01/LG02) ===
1251
1252 See [[Sect 6.7>>path:#single_channel_mode]]
1253
1254
1255
1256 = 4.  Upload Firmware =
1257
1258 (% style="color:red" %)**Notes**:
1259
1260 * Since image v1.3, the firmware will show version info during boot. If your device doesn't show version info, you may have a very old image version.
1261 * Always run AT+FDR to reset parameters to factory default after an update image.
1262 If the update is from image >= v1.3 to another image version >=v1.3, then the keys will be kept after running AT+FDR.
1263 Otherwise (e.g. from v1.2 to v1.3), AT+FDR may erase the keys.
1264
1265 == 4.1  Upload Firmware via Serial Port ==
1266
1267 The LSN50's AT Command port can be used for firmware upgrade. The hardware connection for upgrade firmware is as below:
1268
1269
1270 [[image:image-20220627163506-18.png||height="426" width="418"]]
1271
1272
1273 (% style="color:blue" %)**Step1**(%%)**:** Download [[flash loader>>url:https://www.st.com/content/st_com/en/products/development-tools/software-development-tools/stm32-software-development-tools/stm32-programmers/flasher-stm32.html]].
1274
1275
1276 (% style="color:blue" %)**Step2**(%%)**:** Download the [[LSN50 Image files>>url:https://github.com/dragino/LoRa_STM32/tree/master/LSN50.hex]].
1277
1278
1279 (% style="color:blue" %)**Step3**(%%)**: **Open flashloader; choose the correct COM port to update
1280
1281 [[image:image-20220627163821-19.png]]
1282
1283
1284 [[image:image-20220627163930-20.png||height="450" width="751"]]
1285
1286
1287 [[image:image-20220627164030-21.png||height="459" width="750"]]
1288
1289 (% style="color:blue" %)**Step4**(%%)**: **Switch SW1 back to flash state and push the RESET button.
1290
1291 The LSN50 will then run the new firmware.
1292
1293
1294 == 4.2  Upload Firmware via ST-Link V2 ==
1295
1296 You can use ST-LINK to upgrade firmware into LSN50. The hardware connection for upgrade firmware is as below:
1297
1298 [[image:1656319349131-664.png]]
1299
1300 Connection:
1301
1302 * ST-LINK v2 GND <~-~-> LSN50 GND
1303 * ST-LINK v2 SWCLK <~-~-> LSN50 PA14
1304 * ST-LINK v2 SWDIO <~-~-> LSN50 PA13
1305 * ST-LINK v2 RST <~-~->LSN50 NRST.
1306
1307 (% style="color:blue" %)**Step1:**(%%) Install [[ST-LINK driver>>url:https://www.stmicroelectronics.com.cn/content/st_com/en/products/development-tools/software-development-tools/stm32-software-development-tools/stm32-utilities/stsw-link009.html]] first and then install [[ST-LINK Utility>>url:https://www.st.com/content/st_com/en/products/development-tools/software-development-tools/stm32-software-development-tools/stm32-programmers/stsw-link004.html]]
1308
1309
1310 (% style="color:blue" %)**Step2**(%%): Download the [[LSN50 Image files>>url:https://github.com/dragino/LoRa_STM32/tree/master/LSN50.hex]].
1311
1312
1313 (% style="color:blue" %)**Step3:**(%%)** **Open ST-LINK utility, (% style="color:blue" %)**file ~-~-> open file**(%%) to select the image to be upgraded.
1314
1315
1316 (% style="color:blue" %)**Step4:**(%%)** **Click the “(% style="color:blue" %)**Program Verify**”(%%) button on ST-LINK.
1317
1318
1319 [[image:image-20220627164303-22.png]]
1320
1321
1322 (% style="color:blue" %)**Step5:**(%%)** **The led on the ST-LINK adapter will now blinking, and the ST-Link utility will pop up a download window. Click the start button to download the image to LSN50.
1323
1324
1325 (% style="color:red" %)NOTE: If this step fails, ST-LINK can't establish connection to LSN50, please try to swap SWDIO & SWCLK pin. Some ST-LINK v2 devices are incorrectly marked.
1326
1327
1328 [[image:image-20220627164303-23.png]]
1329
1330
1331
1332 = 5.  Developer Guide =
1333
1334 (% style="display:none" %)
1335
1336 * Software Source Code Download : [[https:~~/~~/github.com/dragino/LoRa_STM32/tree/master/STM32CubeExpansion_LRWAN>>https://github.com/dragino/LoRa_STM32/tree/master/STM32CubeExpansion_LRWAN]]
1337 * Hardware Source Code Download: [[https:~~/~~/github.com/dragino/Lora/tree/master/LSN50>>https://github.com/dragino/Lora/tree/master/LSN50]]
1338
1339 LSN50 is an open source project, developer can use compile their firmware for customized applications. User can get the source code from:
1340
1341 * Software Source Code: [[https:~~/~~/github.com/dragino/LoRa_STM32/tree/master/STM32CubeExpansion_LRWAN>>url:https://github.com/dragino/LoRa_STM32/tree/master/STM32CubeExpansion_LRWAN]]
1342 * Hardware Design files:  [[https:~~/~~/github.com/dragino/Lora/tree/master/LSN50>>url:https://github.com/dragino/Lora/tree/master/LSN50]]
1343 * Compile instruction:  [[http:~~/~~/wiki.dragino.com/xwiki/bin/view/Main/Firmware%20Compile%20Instruction%20~~-~~-%20STM32/>>http://wiki.dragino.com/xwiki/bin/view/Main/Firmware%20Compile%20Instruction%20--%20STM32/]]
1344
1345 Use Keil to open project file:
1346
1347 STM32CubeExpansion_LRWAN/Projects/Multi/Applications/LoRa/DRAGINO-LRWAN(AT)/MDK-ARM/STM32L072CZ-Nucleo/Lora.uvprojx
1348
1349
1350 In Keil, you can see what frequency band the code support.
1351
1352 [[image:image-20220627162417-15.png]]
1353
1354
1355 ~1. If you want to change frequency, modify the Preprocessor Symbols.
1356 For example, change EU868 to US915
1357
1358 [[image:1656318662202-530.png]]
1359
1360 [[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image002.emz]]
1361
1362 2. Compile and build
1363
1364 [[image:image-20220627163212-17.png]]
1365
1366
1367
1368 = 6.  FAQ =
1369
1370 == 6.1  Why there is 433/868/915 version? ==
1371
1372 (((
1373 Different countries have different rules for the ISM band for LoRa. Although the LoRa chip can support a wide range of Frequencies, we provide different versions of the hardware for best tune of the LoRa hardware part.
1374 )))
1375
1376
1377 == 6.2 What is the frequency range of LT LoRa part? ? ==
1378
1379 Different LT version supports different frequency range, below is the table for the working frequency and recommend bands for each model:
1380
1381 [[image:image-20220627155456-9.png]]
1382
1383
1384
1385 == 6.3  How to change the LoRa Frequency Bands/Region? ==
1386
1387 You can follow the instructions for [[how to upgrade image>>path:#3ygebqi]].
1388 When downloading the images, choose the required image file for download.
1389
1390
1391 == 6.4  Can I use Private LoRa protocol? ==
1392
1393 (((
1394 (((
1395 The stock firmware is based on LoRaWAN protocol. You can use a private LoRa protocol in LSN50. This section describes an example for base LoRa transfer. It is a reference/demo and we do not provide further software development support on this topic.
1396 )))
1397
1398 (((
1399 In this demo, we will show the communication between LoRa Shield and LSN50, both of them using the basic LoRa library. LSN50 will send a message to a LoRa Shield and the LoRa Shield will print it to the console.
1400 )))
1401
1402
1403 )))
1404
1405 (% style="color:#4472c4" %)**LoRa Shield + UNO**:
1406
1407 Use the [[LoRa Library>>url:http://www.dragino.com/downloads/index.php?dir=LSN50-LoRaST/LoRa_Raw_Example/Arduino/&file=LoRa.zip]] and upload the [[LoRa Receive>>http://www.dragino.com/downloads/downloads/LSN50-LoRaST/LoRa_Raw_Example/Arduino/LoRaReceiver.ino]] Sketch to Arduino.
1408
1409
1410 Refs:
1411
1412 [[http:~~/~~/www.dragino.com/downloads/index.php?dir=LSN50-LoRaST/LoRa_Raw_Example/Arduino/&file=LoRa.zip>>url:http://www.dragino.com/downloads/index.php?dir=LSN50-LoRaST/LoRa_Raw_Example/Arduino/&file=LoRa.zip]]
1413
1414 [[http:~~/~~/www.dragino.com/downloads/downloads/LSN50-LoRaST/LoRa_Raw_Example/Arduino/LoRaReceiver.ino>>url:http://www.dragino.com/downloads/downloads/LSN50-LoRaST/LoRa_Raw_Example/Arduino/LoRaReceiver.ino]]
1415
1416
1417 Open the serial monitor to Arduino. The device acts as a LoRa Receiver and listen on the frequency 868.3Mhz by default.
1418
1419
1420 (% style="color:#4472c4" %)**LSN50**:
1421
1422 Use the <[[LoRa RAW code>>url:http://www.dragino.com/downloads/index.php?dir=LSN50-LoRaST/LoRa_Raw_Example/LSN50/&file=lora_send.zip]]> . The project file is in: MDK-ARM\STM32L072CZ-Nucleo\ Lora.uvprojx
1423
1424 [[Compile>>path:#19c6y18]] it and [[Upload>>path:#3ygebqi]] it to LSN50, the LSN50 will transfer on the frequency 868.3Mhz.
1425
1426 In the Arduino Console, it will see the received packets as below.
1427
1428
1429 [[image:image-20220627160116-10.png]]
1430
1431
1432 == 6.5  How to set up LSN50 to work in 8 channel mode ==
1433
1434 By default, the frequency bands US915, AU915, CN470 work in 72 frequencies. Many gateways are 8 channel gateways, and in this case, the OTAA join time and uplink schedule is long and unpredictable while the end node is hopping in 72 frequencies.
1435
1436 You can configure the end node to work in 8 channel mode by using the AT+CHE command. The 500kHz channels are always included for OTAA.
1437
1438
1439 For example, in (% style="color:blue" %)**US915**(%%) band, the frequency table is as below. By default, the end node will use all channels (0~~71) for OTAA Join process. After the OTAA Join, the end node will use these all channels (0~~71) to send uplink packets.
1440
1441 [[image:image-20220627160940-13.png]]
1442
1443
1444 When you use the TTN V3 network, the US915 frequency bands use are:
1445
1446 * 903.9 - SF7BW125 to SF10BW125
1447 * 904.1 - SF7BW125 to SF10BW125
1448 * 904.3 - SF7BW125 to SF10BW125
1449 * 904.5 - SF7BW125 to SF10BW125
1450 * 904.7 - SF7BW125 to SF10BW125
1451 * 904.9 - SF7BW125 to SF10BW125
1452 * 905.1 - SF7BW125 to SF10BW125
1453 * 905.3 - SF7BW125 to SF10BW125
1454 * 904.6 - SF8BW500
1455
1456 Because the end node is now hopping in 72 frequency, it makes it difficult for the devices to Join the TTN V3 network and uplink data. To solve this issue, you can access the device via the AT commands and run:
1457
1458 (% style="color:blue" %)**AT+CHE=2**
1459
1460 (% style="color:blue" %)**ATZ**
1461
1462
1463 to set the end node to work in 8 channel mode. The device will work in Channel 8-15 & 64-71 for OTAA, and channel 8-15 for Uplink.
1464
1465 The (% style="color:blue" %)**AU915**(%%) band is similar. Below are the AU915 Uplink Channels.
1466
1467 [[image:image-20220627161124-14.png]]
1468
1469
1470 == 6.6  How to set up LSN50 to work with Single Channel Gateway such as LG01/LG02? ==
1471
1472 In this case, users need to set LSN50 to work in ABP mode and transmit in only one frequency.
1473
1474 Assume we have a LG02 working in the frequency 868400000 now, below is the steps.
1475
1476
1477 (% style="color:blue" %)**Step1: **(%%)Log in TTN V3, Create an ABP device in the application and input the network session key (NETSKEY), app session key (APPSKEY) from the device.
1478
1479
1480 [[image:image-20220627160542-11.png]]
1481
1482
1483 (% style="color:red" %)Note: You need to make sure the above three keys match in the device and in TTN V3. You can change them either in TTN V3 or in the Device to make them match. In TTN V3, NETSKEY and APPSKEY can be configured in the setting page, but the Device Addr is generated by TTN V3.
1484 You can also change the Device ADDR in TTN V3 by using the [[The Things Network CLI>>url:https://www.thethingsnetwork.org/docs/network/cli/quick-start.html]].
1485
1486
1487 (% style="color:blue" %)**Step2:  **(%%)Run AT commands to make the LSN50 work in Single frequency and ABP mode. Below are the AT commands:
1488
1489
1490 (% style="background-color:#dcdcdc" %)AT+FDR(%%)  Reset Parameters to Factory Default, Keys Reserve
1491
1492 (% style="background-color:#dcdcdc" %)AT+NJM=0(%%)  Set to ABP mode
1493
1494 (% style="background-color:#dcdcdc" %)AT+ADR=0(%%)  Set the Adaptive Data Rate Off
1495
1496 (% style="background-color:#dcdcdc" %)AT+DR=5(%%)  Set Data Rate (Set AT+DR=3 for 915 band)
1497
1498 (% style="background-color:#dcdcdc" %)AT+TDC=300000(%%)  Set transmit interval to 5 minutes
1499
1500 (% style="background-color:#dcdcdc" %)AT+CHS=868400000(%%)  Set transmit frequency to 868.4Mhz
1501
1502 (% style="background-color:#dcdcdc" %)AT+DADDR=26 01 1A F1(%%)  Set Device Address to 26 01 1A F1
1503
1504 (% style="background-color:#dcdcdc" %)ATZ(%%)  Reset MCU
1505
1506
1507 As shown  below:
1508
1509 [[image:image-20220627160542-12.png]]
1510
1511
1512 == 6.7  How to configure the EUI keys in LSN50? ==
1513
1514 The early version of LSN50 firmware doesn't have pre-configured keys.
1515 It is recommended that you update the image to the latest version before configure the keys. Refer [[upgrade_image>>path:#3ygebqi]] to update the firmware to the latest version.
1516
1517 Run AT commands to set the keys to desired keys; refer [[AT Command manual>>path:#23ckvvd]].
1518
1519
1520 = 7.  Trouble Shooting =
1521
1522 == 7.1  Connection problem when uploading firmware. ==
1523
1524 (% style="color:red" %)**Issue**(%%): While using USB to TTL to upload firmware via UART interface. It works for several times but most of times it fails.
1525
1526
1527 (% style="color:green" %)**Checklist**:
1528
1529 ~1. Double check if follow up exactly the steps as manual.
1530
1531 2. Check if hardware works fine: a) check if AT command works, b) check if ISP / flash switch works: PA12 will have different output level while set the ISP/Flash Switch in different position. c) check if reset button works.
1532
1533 3. If you use Windows10 system. Please change the flash loader to run in Windows7 compatibility mode.
1534
1535
1536 [[image:image-20220627153421-8.png]]
1537
1538 4. We have seen cases where the FT232 USB TTL adapter has a reliability issue with the PC USB chipset (Intel). In this case, even though points 1 and 2 above work, it still has a reliability issue for uploading. If this happens, change to a different PC or change the USB to TTL adapter to solve the issue.
1539
1540
1541 == 7.2  Why I can't join TTN V3 in US915 / AU915 bands? ==
1542
1543 It is due to channel mapping. Please see the [[Eight Channel Mode>>path:#206ipza]] section above for details.
1544
1545
1546 7.3  AT Command input doesn't work
1547
1548 In the case if user can see the console output but can't type input to the device. Please check if you already include the (% style="color:red" %)**ENTER**(%%) while sending out the command. Some serial tool doesn't send (% style="color:red" %)**ENTER**(%%) while press the send key, user need to add ENTER in their string.
1549
1550
1551
1552 = 8.  Order Info =
1553
1554 Part Number: (% style="color:blue" %)**LSN50-XX-YY  **(%%)**or  (% style="color:blue" %)LSN50-XX-YY-ZZ(%%)**
1555
1556
1557 (% style="color:blue" %)**XX**(%%): The default frequency band
1558
1559 * (% style="color:red" %)**AS923 **(%%)**:** LoRaWAN AS923 band
1560 * (% style="color:red" %)**AU915 **(%%)**:** LoRaWAN AU915 band
1561 * (% style="color:red" %)**EU433 **(%%)**:** LoRaWAN EU433 band
1562 * (% style="color:red" %)**EU868 **(%%)**:** LoRaWAN EU868 band
1563 * (% style="color:red" %)**KR920 **(%%)**:** LoRaWAN KR920 band
1564 * (% style="color:red" %)**US915 **(%%)**:** LoRaWAN US915 band
1565 * (% style="color:red" %)**IN865 **(%%)**:**  LoRaWAN IN865 band
1566 * (% style="color:red" %)**CN470 **(%%)**:** LoRaWAN CN470 band
1567
1568 (% style="color:blue" %)**YY**(%%)**: **Hole Option
1569
1570 * (% style="color:red" %)**12**(%%): With M12 waterproof cable hole
1571 * (% style="color:red" %)**16**(%%): With M16 waterproof cable hole
1572 * (% style="color:red" %)**20**(%%): With M20 waterproof cable hole (LSN50 v2 doesn’t have this version)
1573 * (% style="color:red" %)**NH**(%%): No Hole
1574
1575 (% style="color:blue" %)**ZZ**(%%)**: **Battery Option ( Only valid for v2 model)
1576
1577 * (% style="color:red" %)**4**(%%): with 4000mAh battery
1578 * (% style="color:red" %)**8**(%%): with 8500mAg battery
1579
1580 = 9. ​ Packing Info =
1581
1582
1583 (% style="color:blue" %)**For LSN50**(%%)**:**
1584
1585 **Package Includes**:
1586
1587 * LSN50 LoRa Sensor Node x 1
1588
1589 **Dimension and weight**:
1590
1591 * Device Size: 8 x 6.5 x 5 cm
1592 * Device Weight: 137g
1593 * Package Size / pcs : 9 x 7 x 6cm
1594 * Weight / pcs : 160g
1595
1596 (% style="color:blue" %)**For LSN50 v2**(%%)**:**
1597
1598 **Package Includes**:
1599
1600 * LSN50 v2 LoRa Sensor Node x 1
1601 * External antenna x 1
1602 * Spring Antenna (evaluate purpose)
1603
1604 **Dimension and weight**:
1605
1606 * Device Size: 9.7 x 6.5 x 4.7 cm
1607 * Device Weight: 150g
1608 * Package Size / pcs : 14.0 x 8x 5 cm
1609 * Weight / pcs : 180g
1610
1611 (((
1612
1613
1614
1615
1616
1617 )))
1618
1619 = 10.  ​Support =
1620
1621 * 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.
1622 * 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.com>>url:http://../../../../../../D:%5C%E5%B8%82%E5%9C%BA%E8%B5%84%E6%96%99%5C%E8%AF%B4%E6%98%8E%E4%B9%A6%5CLoRa%5CLT%E7%B3%BB%E5%88%97%5Csupport@dragino.com]].
1623
1624 = 11.  References =
1625
1626 * [[Product Page>>url:http://www.dragino.com/products/lora/item/128-lsn50.html]]
1627 * [[Data Sheet>>url:http://www.dragino.com/downloads/index.php?dir=datasheet/EN/&file=Datasheet_LoRaSensorNode.pdf]]
1628 * [[Image Download>>url:https://github.com/dragino/LoRa_STM32/tree/master/LSN50.hex]]
1629 * [[Mechanical Drawing>>http://www.dragino.com/downloads/index.php?dir=LSN50-LoRaST/Mechanical_Drawing/]]
1630
1631
Copyright ©2010-2024 Dragino Technology Co., LTD. All rights reserved
Dragino Wiki v2.0