Version 423.1 by Bei Jinggeng on 2022/08/23 17:38

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 {{toc/}}
23
24
25
26
27
28
29
30
31
32
33 = 1.  Introduction =
34
35
36 == 1.1 ​ What is LSN50 LoRa Sensor Node ==
37
38
39 (((
40 (((
41 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.
42 )))
43
44 (((
45 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.
46 )))
47
48 (((
49 (% 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.
50 )))
51
52 (((
53 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.
54 )))
55 )))
56
57
58 [[image:1656294562709-486.png]]
59
60
61
62 == 1.2  Specifications ==
63
64
65 (% style="color:#037691" %)**Micro Controller:**
66
67 * STM32L072CZT6 MCU
68 * MCU: STM32L072CZT6
69 * Flash: 192KB
70 * RAM: 20KB
71 * EEPROM: 6KB
72 * Clock Speed: 32Mhz
73
74
75
76 (% style="color:#037691" %)**Common DC Characteristics:**
77
78 * Supply Voltage: 2.1v ~~ 3.6v
79 * Operating Temperature: -40 ~~ 85°C
80 * I/O pins: Refer to STM32L072 datasheet
81
82
83
84 (% style="color:#037691" %)**LoRa Spec:**
85
86 * Frequency Range, 
87 ** Band 1 (HF): 862 ~~ 1020 Mhz
88
89 or
90
91 *
92 ** Band 2 (LF): 410 ~~ 528 Mhz
93 * 168 dB maximum link budget.
94 * +20 dBm - 100 mW constant RF output vs.
95 * +14 dBm high efficiency PA.
96 * Programmable bit rate up to 300 kbps.
97 * High sensitivity: down to -148 dBm.
98 * Bullet-proof front end: IIP3 = -12.5 dBm.
99 * Excellent blocking immunity.
100 * Low RX current of 10.3 mA, 200 nA register retention.
101 * Fully integrated synthesizer with a resolution of 61 Hz .
102 * FSK, GFSK, MSK, GMSK, LoRaTM and OOK modulation.
103 * Built-in bit synchronizer for clock recovery.
104 * Preamble detection.
105 * 127 dB Dynamic Range RSSI.
106 * Automatic RF Sense and CAD with ultra-fast AFC.
107 * Packet engine up to 256 bytes with CRC.
108 * LoRaWAN 1.0.2 Specification
109
110
111
112 (% style="color:#037691" %)**Battery:**
113
114 * Li/SOCI2 un-chargeable battery
115 * Capacity: 4000mAh
116 * Self Discharge: <1% / Year @ 25°C
117 * Max continuously current: 130mA
118 * Max boost current: 2A, 1 second
119
120
121
122 (% style="color:#037691" %)**Power Consumption**
123
124 * STOP Mode: 2.7uA @ 3.3v
125 * LoRa Transmit Mode: 125mA @ 20dBm 44mA @ 14dBm
126
127
128
129
130
131 == ​1.3  Features ==
132
133
134 * LoRaWAN 1.0.3 Class A, Class C
135 * STM32L072CZT6 MCU
136 * SX1276/78 Wireless Chip
137 * Pre-load bootloader on USART1/USART2
138 * MDK-ARM Version 5.24a IDE
139 * I2C, LPUSART1, USB, SPI2
140 * 3x12bit ADC, 1x12bit DAC
141 * 20xDigital I/Os
142 * LoRa™ Modem
143 * Preamble detection
144 * Baud rate configurable
145 * CN470/EU433/KR920/US915/IN865
146 * EU868/AS923/AU915
147 * Open-source hardware / software
148 * Available Band:433/868/915/920 Mhz
149 * IP66 Waterproof Enclosure
150 * Ultra-Low Power consumption
151 * AT Commands to change parameters
152 * 4000mAh or 8500mAh Battery for long term use。
153
154
155
156
157
158 == 1.4 ​ Applications ==
159
160
161 * Smart Buildings & Home Automation
162 * Logistics and Supply Chain Management
163 * Smart Metering
164 * Smart Agriculture
165 * Smart Cities
166 * Smart Factory
167
168
169
170
171
172 == 1.5  Pin Definitions and Switch ==
173
174
175 (% class="wikigeneratedid" %)
176 [[image:1656295519542-152.png||height="413" width="728"]]
177
178
179 (% class="wikigeneratedid" %)
180 [[image:1656295532863-613.png||height="371" width="721"]]
181
182
183 (% class="wikigeneratedid" %)
184 [[image:image-20220627101527-1.png]]
185
186
187
188 === 1.5.1 Jumper JP2 ===
189
190
191 Power on Device when put this jumper.
192
193
194
195 === 1.5.2 BOOT MODE / SW1 ===
196
197
198 (((
199 ~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.
200 )))
201
202 (((
203 2. Flash:  work mode, device starts to work and send out console output for further debug
204 )))
205
206
207
208 === 1.5.3 Reset Button ===
209
210
211 Press to reboot the device.
212
213
214
215 === 1.5.4 LED ===
216
217
218 It will flash:
219
220 1. When boot the device in flash mode
221 1. Send an uplink packet
222
223
224
225
226
227 === 1.6  Hardware Change log ===
228
229
230 (% style="color:red" %)**Note: Hardware version is marked in the PCB.**
231
232
233 (% style="color:#4472c4" %)**LSN50 v2.1:**
234
235 1. Change R14 to 1M ohm
236 1. Change R3, R4 to 4.7Kohm. So no need to modify them for 3 DS18B20 connection.
237 1. Add ESD to each I/O
238
239 (% style="color:#4472c4" %)**LSN50 v2.0:**
240
241 * Change to a new enclosure. Improve with external antenna, IP68, ear hook.
242
243 (% style="color:#4472c4" %)**LSN50 v1.3**:
244
245 * Add P-MOS to control 5V output
246
247 (% style="color:#4472c4" %)**LSN50 v1.2**:
248
249 * Add LED. Turn on for every LoRa transmit
250 * Add pin PA4, PB13, NRST
251 * Add 5V Output, on/off control by PB5(Low to Enable, High to Disable)
252
253 (% style="color:#4472c4" %)**LSN50 v1.8**:
254
255 * (((
256 ~1. LoRaWAN Stack update to DR-LWS-007([[http:~~/~~/www.dragino.com/downloads/downloads/LoRa_End_Node/DR-LWS/changelog>>url:http://www.dragino.com/downloads/downloads/LoRa_End_Node/DR-LWS/changelog]])
257 )))
258 * (((
259 2. Add AS923-4 band and MA869 band
260 )))
261 * (((
262 3 .Fixed the inaccurate ranging of DF-Robot SEN0208 in mode2.
263 )))
264 * (((
265 4. Remove the limit of plus or minus 5Kg in mode 5, and expand from 2 bytes to 4 bytes, the unit is g.
266 )))
267 * (((
268 5. AT command change: AT+INTMOD is changed to AT+INTMOD1; AT command increase: AT+INTMOD2, AT+INTMOD3, AT+SETCNT.
269 )))
270 * (((
271 6. Added working mode 7(3Interrupt),8(3ADC+1DS18B20),9(3DS18B20+2Count)
272
273
274
275
276
277 )))
278
279 == 1.7  Hole Option ==
280
281
282 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:
283
284 [[image:image-20220627104757-1.png]]
285
286
287 [[image:1656298089706-973.png]]
288
289
290
291 = 2.  Use LSN50 with LoRaWAN firmware =
292
293
294 == 2.1  How it works ==
295
296
297 (((
298 (((
299 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.
300 )))
301
302 (((
303
304 )))
305
306 (((
307 The diagram below shows the working flow in default firmware (ver 1.7.0): 
308 )))
309
310
311 [[image:image-20220627104855-2.png]]
312
313
314 (((
315 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>>||anchor="H3.A0UsingtheATCommands"]] to set the keys in the LSN50.
316 )))
317 )))
318
319
320
321 == 2.2  ​Quick guide to connect to LoRaWAN server (OTAA) ==
322
323
324 (((
325 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. 
326
327
328 (% 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]]
329
330
331 )))
332
333 (% 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" %)​(%%)​
334
335 (((
336
337
338 (% style="color:blue" %)**Step 1**(%%): Create a device in TTN with the OTAA keys from LSN50.
339
340 Each LSN50is shipped with a sticker with the default device EUI as below:
341 )))
342
343 (((
344
345 )))
346
347 (% 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" %)​(%%)​
348
349
350 (((
351 (((
352 You can enter this key in the LoRaWAN Server portal. Below is TTN screen shot:
353 )))
354
355 (((
356 **Register the device:**
357 )))
358 )))
359
360 (% 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" %)​​
361
362 (% 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" %)​
363
364
365 **Add APP EUI and DEV EUI:**
366
367
368 (% 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" %)​
369
370
371
372 **Add APP EUI in the application:**
373
374
375 (% 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" %)​
376
377
378 **Add APP KEY**
379
380 (% 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" %)​
381
382 (% 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" %)​
383
384 (% 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" %)​(%%)​
385
386 (% style="color:blue" %)**Step 2**(%%)**:** Power on LSN50
387
388 Put a Jumper on JP2 to power on the device.(% style="display:none" %)
389
390 [[image:image-20220627145643-5.png]](% style="display:none" %)
391
392 (% style="display:none" %)
393
394
395 (% style="display:none" %) (%%)
396
397 **For LSn50v2:**
398
399 [[image:1656313034748-905.png]](% style="display:none" %)
400
401
402 (% 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" %)​(%%)​
403
404 (((
405 (((
406 (% 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.
407 )))
408 )))
409
410 (% 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"]]
411
412 ​(% 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" %)​​
413
414
415 == 2.3  ​Working Mode & Uplink Payload ==
416
417
418 (((
419 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.
420 )))
421
422 (((
423 For example:
424 )))
425
426 (((
427 (% 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.
428 )))
429
430 (((
431
432 )))
433
434 (((
435 (% style="color:red" %)**NOTE:**
436 )))
437
438 (((
439 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.
440 1. All modes share the same Payload Explanation from HERE.
441 1. By default, the device will send an uplink message every 5 minutes.
442 )))
443
444
445
446
447
448 === 2.3.1  MOD~=1 (Default Mode) ===
449
450
451 (((
452 In this mode, uplink payload includes in total 11 bytes. Uplink packets use FPORT=2.
453 [[image:image-20220627171207-27.png]]
454
455 [[image:image-20220627150949-6.png]]
456
457
458 )))
459
460
461 === 2.3.2 MOD~=2 (Distance Mode) ===
462
463
464 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.
465
466 [[image:image-20220627180835-31.png]]
467
468
469 [[image:1656324539647-568.png]]
470
471
472
473 (% style="color:red" %)**Connection of LIDAR-Lite V3HP:**
474
475 [[image:1656324581381-162.png]]
476
477
478
479 (% style="color:red" %)**Connection to Ultrasonic Sensor:**
480
481 [[image:1656324598488-204.png]]
482
483
484
485 For the connection to TF-Mini or TF-Luna , MOD2 payload is as below:
486
487 [[image:image-20220628083801-1.png]]
488
489 [[image:1656376779088-686.png]]
490
491
492
493 (% style="color:red" %)**Connection to [[TF-Mini plus>>url:http://en.benewake.com/product/detail/5c345cd0e5b3a844c472329b.html]] LiDAR(UART version):**
494
495 Need to remove R3 and R4 resistors to get low power. Since firmware v1.7.0
496
497 [[image:1656376795715-436.png]]
498
499
500
501 (% style="color:red" %)**Connection to [[TF-Luna>>url:http://en.benewake.com/product/detail/5e1c1fd04d839408076b6255.html]] LiDAR (UART version):**
502
503 Need to remove R3 and R4 resistors to get low power. Since firmware v1.7.0
504
505 [[image:1656376865561-355.png]]
506
507
508 (((
509 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.
510 )))
511
512
513
514 === 2.3.3 MOD~=3 (3 ADC + I2C) ===
515
516
517 This mode has total 12 bytes. Include 3 x ADC + 1x I2C
518
519 [[image:image-20220628085009-2.png]]
520
521 [[image:1656377431497-975.png]]
522
523
524
525 === 2.3.4 MOD~=4 (3 x DS18B20) ===
526
527
528 This mode is supported in firmware version since v1.6.1. Software set to AT+MOD=4
529
530 Hardware connection is as below,
531
532 (% style="color:red" %)**( Note:**
533
534 * 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.
535 * In hardware version v2.1 no need to change R3 , R4, by default, they are 4.7k ohm already.
536
537 See [[here>>||anchor="H1.6A0HardwareChangelog"]] for hardware changelog. (% style="color:red" %)**) **
538
539 [[image:1656377461619-156.png]]
540
541
542 This mode has total 11 bytes. As shown below:
543
544 [[image:image-20220628085248-3.png]]
545
546 [[image:1656377606181-607.png]]
547
548
549
550 === 2.3.5 MOD~=5(Weight Measurement by HX711) ===
551
552
553 (((
554 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.
555 )))
556
557 [[image:1656378224664-860.png]]
558
559
560 Each HX711 need to be calibrated before used. User need to do below two steps:
561
562 1. Zero calibration. Don't put anything on load cell and run **AT+WEIGRE** to calibrate to Zero gram.
563 1. Adjust calibration factor (default value 400): Put a known weight thing on load cell and run **AT+WEIGAP** to adjust the Calibration Factor.
564
565 For example:
566
567 (% style="color:#4472c4" %)**AT+WEIGAP =403.0**
568
569 Response:  Weight is 401 g
570
571
572 Check the response of this command and adjust the value to match the real value for thing.
573
574
575 (% border="1" cellspacing="10" style="background-color:#ffffcc; color:green; width:510px" %)
576 |=(% style="width: 70px;" %)**Size(bytes)**|=(% style="width: 44px;" %)**2**|=(% style="width: 110px;" %)**2**|=(% style="width: 51px;" %)**2**|=(% style="width: 110px;" %)**1**|=(% style="width: 50px;" %)**2**|=(% style="width: 60px;" %)**2**
577 |(% style="width:97px" %)**Value**|(% style="width:44px" %)[[BAT>>||anchor="H2.4.1BatteryInfo"]]|(% style="width:172px" %)(((
578 [[Temperature(DS18B20)>>||anchor="H2.4.2Temperature28DS18B2029"]]
579 )))|(% style="width:51px" %)[[ADC>>||anchor="H2.4.4AnalogueDigitalConverter28ADC29"]]|(% style="width:206px" %)[[Digital in & Digital Interrupt>>||anchor="H2.4.3DigitalInput"]]|(% style="width:72px" %)Weight|(% style="width:81px" %)Reserved
580
581 [[image:image-20220820120036-2.png||height="469" width="1003"]]
582
583
584
585 === 2.3.6 MOD~=6(Counting Mode, Since firmware v1.6.5) ===
586
587
588 (((
589 (((
590 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.
591 )))
592 )))
593
594 (((
595 (((
596 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.
597 )))
598 )))
599
600
601 [[image:1656378351863-572.png]]
602
603
604 (((
605 (% style="color:red" %)**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.
606 )))
607
608 (((
609
610 )))
611
612 (% border="1" cellspacing="10" style="background-color:#ffffcc; color:green; width:410px" %)
613 |=(% style="width: 60px;" %)**Size(bytes)**|=(% style="width: 44px;" %)**2**|=(% style="width: 110px;" %)**2**|=(% style="width: 51px;" %)**2**|=(% style="width: 70px;" %)**1**|=(% style="width: 50px;" %)**4**
614 |(% style="width:80px" %)**Value**|(% style="width:44px" %)[[BAT>>||anchor="H2.4.1BatteryInfo"]]|(% style="width:172px" %)(((
615 [[Temperature(DS18B20)>>||anchor="H2.4.2Temperature28DS18B2029"]]
616 )))|(% style="width:51px" %)[[ADC>>||anchor="H2.4.4AnalogueDigitalConverter28ADC29"]]|(% style="width:206px" %)[[Digital in>>||anchor="H2.4.3DigitalInput"]]|(% style="width:72px" %)Count
617
618 [[image:1656378441509-171.png]]
619
620
621
622 === 2.3.7 MOD~=7 Three interrupt contracting modes (the hardware version needs to support three interrupt versions, Since firmware v1.8.0) ===
623
624
625 [[image:image-20220820140109-3.png]]
626
627 (% border="1" cellspacing="10" style="background-color:#ffffcc; color:green; width:410px" %)
628 |(((
629 **Size(bytes)**
630 )))|2|2|2|1|1|1|2
631 |(((
632 **Value**
633 )))|(((
634 BAT
635 )))|(((
636 Temperature
637
638 (DS18B20)
639 )))|(((
640 ADC
641 )))|(((
642 Digital in&Digital Interrupt1(PB14)
643 )))|(((
644 Digital Interrupt2(PB15)
645 )))|(((
646 Digital Interrupt3(PA4)
647 )))|(((
648 Reserved
649 )))
650
651
652
653
654 === 2.3.8  ​Decode payload in The Things Network ===
655
656
657 While using TTN V3 network, you can add the payload format to decode the payload.
658
659
660 [[image:1656378466788-734.png]]
661
662
663 (((
664 The payload decoder function for TTN V3 are here:
665 )))
666
667 (((
668 LSN50 TTN V3 Payload Decoder:  [[https:~~/~~/www.dropbox.com/sh/dtkj65broivz2gy/AAAjL1ONAm9-TrVvl4HUtdwQa?dl=0>>https://www.dropbox.com/sh/dtkj65broivz2gy/AAAjL1ONAm9-TrVvl4HUtdwQa?dl=0]]
669 )))
670
671
672
673 == 2.4 Payload Explanation and Sensor Interface ==
674
675
676 === 2.4.1 Battery Info ===
677
678
679 (((
680 Check the battery voltage for LSN50.
681 )))
682
683 (((
684 Ex1: 0x0B45 = 2885mV
685 )))
686
687 (((
688 Ex2: 0x0B49 = 2889mV
689 )))
690
691
692
693 === 2.4.2 Temperature (DS18B20) ===
694
695
696 If there is a DS18B20 connected to PB3 pin. The temperature will be uploaded in the payload.
697
698 More DS18B20 can check the [[3 DS18B20 mode>>||anchor="2.3.4MOD3D4283xDS18B2029"]]
699
700
701 (% style="color:#4472c4" %)**Connection:**
702
703 [[image:1656378573379-646.png]]
704
705
706 (% style="color:#4472c4" %)**Example**:
707
708 If payload is: 0105H:  (0105 & FC00 == 0), temp = 0105H /10 = 26.1 degree
709
710 If payload is: FF3FH :  (FF3F & FC00 == 1) , temp = (FF3FH - 65536)/10 = -19.3 degrees.
711
712
713
714 === 2.4.3 Digital Input ===
715
716
717 The digital input for pin PA12,
718
719 * When PA12 is high, the bit 1 of payload byte 6 is 1.
720 * When PA12 is low, the bit 1 of payload byte 6 is 0.
721
722
723
724
725 === 2.4.4 Analogue Digital Converter (ADC) ===
726
727
728 (((
729 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.
730 )))
731
732
733 (((
734 The ADC monitors the voltage on the PA0 line, in mV.
735 )))
736
737 (((
738 Ex: 0x021F = 543mv,
739 )))
740
741
742 (((
743 (% style="color:#4472c4" %)** Example1:** (%%) Reading an Oil Sensor (Read a resistance value):
744 )))
745
746 [[image:image-20220627172409-28.png]]
747
748
749 In the LSN50, we can use PB4 and PA0 pin to calculate the resistance for the oil sensor.
750
751
752 (% style="color:blue" %)**Steps:**
753
754 1. Solder a 10K resistor between PA0 and VCC.
755 1. Screw oil sensor's two pins to PA0 and PB4.
756
757 The equipment circuit is as below:
758
759
760 [[image:image-20220627172500-29.png]]
761
762
763 According to above diagram:
764
765 [[image:image-20220628091043-4.png]]
766
767 So
768
769 [[image:image-20220628091344-6.png]]
770
771
772 [[image:image-20220628091621-8.png]] is the reading of ADC. So if ADC=0x05DC=0.9 v and VCC (BAT) is 2.9v
773
774
775 The [[image:image-20220628091702-9.png]] 4.5K ohm
776
777 Since the Bouy is linear resistance from 10 ~~ 70cm.
778
779
780 The position of Bouy is [[image:image-20220628091824-10.png]] , from the bottom of Bouy.
781
782
783
784 === 2.4.5 Digital Interrupt ===
785
786
787 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.
788
789
790 (((
791 (% style="color:#4472c4" %)** Interrupt connection method:**
792 )))
793
794 [[image:1656379178634-321.png]]
795
796
797 (((
798 (% style="color:#4472c4" %)**Example to use with door sensor :**(%%)
799 (% style="color:#4472c4" %)(Requires firmware > 1.5.1)
800 )))
801
802
803 (((
804 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.
805 )))
806
807 [[image:1656379210849-860.png]]
808
809
810 (((
811 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.
812 )))
813
814
815 (((
816 (% style="color:#4472c4" %)** Below is the installation example:**
817 )))
818
819 (((
820 Fix one piece of the magnetic sensor to the door and connect the two pins to LSN50 as follows:
821 )))
822
823 * (((
824 One pin to LSN50's PB14 pin
825 )))
826 * (((
827 The other pin to LSN50's VCC pin
828 )))
829
830 (((
831 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.
832 )))
833
834
835 (((
836 Door sensors have two types: ** (% style="color:#4472c4" %)NC (Normal close)(%%)** and (% style="color:#4472c4" %)**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.
837 )))
838
839 (((
840 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.
841 )))
842
843
844 [[image:1656379283019-229.png]]
845
846
847 (((
848 The above photos shows the two parts of the magnetic switch fitted to a door.
849 )))
850
851
852 (((
853 (((
854 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.
855 )))
856 )))
857
858
859 (((
860 The command is:
861 )))
862
863 (((
864 (% style="color:blue" %)**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]]**. **)
865 )))
866
867
868 (((
869 Below shows some screen captures in TTN V3:
870 )))
871
872
873 [[image:1656379339508-835.png]]
874
875
876 In MOD=1, user can use byte 6 to see the status for door open or close. TTN V3 decoder is as below:
877
878 (% style="background-color:#dcdcdc" %)door= (bytes[6] & 0x80)? "CLOSE":"OPEN";
879
880
881 (% style="color:red" %)**Notice for hardware version LSN50 v1 < v1.3**(%%) (produced before 2018-Nov).
882
883 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.
884
885 [[image:1656379563303-771.png]]
886
887
888
889 === 2.4.6 I2C Interface (SHT20) ===
890
891
892 (((
893 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.
894 )))
895
896 (((
897 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 (% style="color:#4472c4" %)**AT+MOD=1 (default value).**
898 )))
899
900 (((
901 Below is the connection to SHT20.
902 )))
903
904
905 [[image:1656379593307-549.png]]
906
907
908 The device will be able to get the I2C sensor data now and upload to IoT Server.
909
910
911 [[image:1656379664142-345.png]]
912
913 Convert the read byte to decimal and divide it by ten.
914
915
916 (% style="color:blue" %)**Example:**
917
918 Temperature:  Read:0116(H) = 278(D)  Value:  278 /10=27.8℃;
919
920 Humidity:    Read:0248(H)=584(D)  Value:  584 / 10=58.4, So 58.4%
921
922
923 If you want to use other I2C device, please refer the SHT20 part source code as reference.
924
925
926
927 === 2.4.7 ​Distance Reading ===
928
929
930 Refer [[Ultrasonic Sensor section>>||anchor="H2.4.8UltrasonicSensor"]].
931
932
933
934 === 2.4.8 Ultrasonic Sensor ===
935
936
937 (((
938 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]]
939 )))
940
941
942 (((
943 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.
944 )))
945
946
947 (((
948 The picture below shows the connection:
949 )))
950
951 [[image:1656380061365-178.png]]
952
953
954
955 Connect to the LSN50 and run (% style="color:blue" %)**AT+MOD=2**(%%) to switch to ultrasonic mode (ULT).
956
957 The ultrasonic sensor uses the 8^^th^^ and 9^^th^^ byte for the measurement value.
958
959
960 (% style="color:blue" %)**Example:**
961
962 Distance:  Read:0C2D(Hex) = 3117(D)  Value:  3117 mm=311.7 cm
963
964
965 [[image:1656384895430-327.png]]
966
967
968 [[image:1656384913616-455.png]]
969
970
971 You can see the serial output in ULT mode as below:
972
973 [[image:1656384939855-223.png]]
974
975
976 In TTN V3 server:
977
978
979 [[image:1656384961830-307.png]]
980
981
982 [[image:1656384973646-598.png]]
983
984
985
986 === 2.4.9 +5V Output ===
987
988
989 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. 
990
991
992 (((
993 Since firmware (% style="color:red" %)**v1.6.3**(%%), The 5V output time can be controlled by AT Command.
994 )))
995
996 (((
997 (% style="color:#4472c4" %)**AT+5VT=1000**
998 )))
999
1000 (((
1001 Means set 5V valid time to have 1000ms. So the real 5V output will actually have 1000ms + sampling time for other sensors.
1002 )))
1003
1004
1005 (((
1006 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.
1007 )))
1008
1009
1010
1011 === 2.4.10 Weigh Sensor HX711 ===
1012
1013
1014 Since v1.6.2 firmware, LSN50 support Weigh Sensor HX711.
1015
1016
1017
1018 === 2.4.11  BH1750 Illumination Sensor ===
1019
1020
1021 Since v1.7.0 firmware, MOD=1 support this sensor. The sensor value is in the 8^^th^^ and 9^^th^^ bytes.
1022
1023
1024 [[image:image-20220628110012-11.jpeg]]
1025
1026
1027 [[image:image-20220628110012-12.png]]
1028
1029
1030
1031 === 2.4.12 Working MOD ===
1032
1033
1034 (((
1035 The working MOD info is contained in the Digital in & Digital Interrupt byte (7^^th^^ Byte).
1036 )))
1037
1038 (((
1039 User can use the 3^^rd^^ ~~ 7^^th^^  bit of this byte to see the working mod:
1040 )))
1041
1042 (((
1043 Case 7^^th^^ Byte >> 2 & 0x1f:
1044 )))
1045
1046 * 0: MOD1
1047 * 1: MOD2
1048 * 2: MOD3
1049 * 3: MOD4
1050 * 4:MOD5
1051 * 5:MOD6
1052
1053
1054
1055
1056 == 2.5 Configure LSN50 via AT or Downlink ==
1057
1058
1059 (((
1060 User can configure LSN50 via [[AT Commands >>||anchor="H3.A0UsingtheATCommands"]]or LoRaWAN Downlink Commands
1061 )))
1062
1063 (((
1064 There are two kinds of Commands:
1065 )))
1066
1067 * (% 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:  [[End Device AT Commands>>doc:Main.End Device AT Commands and Downlink Command.WebHome]]
1068
1069 * (% style="color:#4472c4" %)**Sensor Related Commands**(%%): These commands are special designed for LSN50.  User can see these commands below:
1070
1071
1072
1073
1074 === 2.5.1 Common Commands: ===
1075
1076
1077 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: [[End Device AT Commands>>doc:Main.End Device AT Commands and Downlink Command.WebHome]]
1078
1079
1080
1081 === 2.5.2 Sensor related commands: ===
1082
1083
1084 (% style="color:#4472c4" %)**Set work mode:**
1085
1086 * (% style="color:#037691" %)**AT Command:**
1087
1088 (((
1089 (% style="background-color:#dcdcdc" %)**AT+MOD=2 **(%%) ~/~/ Set work MOD =2. (1:IIC mode,2:Distance mode,3:3ADC mode, 4:3DS18B20 mode,5:weight mode)
1090 )))
1091
1092 (((
1093 (% style="background-color:#dcdcdc" %)**AT+MOD=?** (%%) ~/~/  Get current work MOD
1094 )))
1095
1096
1097 * (% style="color:#037691" %)**Downlink Payload:**
1098
1099 (% style="background-color:#dcdcdc" %)**0x0A aa** (%%) ~/~/ Same as AT+MOD=aa
1100
1101
1102
1103 (% style="color:#4472c4" %)**Set the trigger interrupt mode:**
1104
1105 * (% style="color:#037691" %)**AT Command:**
1106
1107 (((
1108 (% style="background-color:#dcdcdc" %)**AT+INTMOD=2**  (%%) ~/~/ Set INTMOD =2. (0:Disable,1:falling or rising,2:falling,3:rising)
1109 )))
1110
1111 (((
1112 (% style="background-color:#dcdcdc" %)**AT+INTMOD=?**  (%%) ~/~/  Get current INTMOD
1113 )))
1114
1115
1116 * (% style="color:#037691" %)**Downlink Payload:**
1117
1118 (% style="background-color:#dcdcdc" %)**0x06 000003**      (%%) ~/~/ Set AT+INTMOD=3
1119
1120
1121
1122 (% style="color:#4472c4" %)**Set the 5V power open time during sampling:**
1123
1124 * (% style="color:#037691" %)**AT Command:**
1125
1126 (((
1127 (% style="background-color:#dcdcdc" %)**AT+5VT=1000** (%%) ~/~/ Set 5v open time to 1000ms
1128 )))
1129
1130 (((
1131 (% style="background-color:#dcdcdc" %)**AT+5VT=?**    (%%) ~/~/  Check current 5v open duration
1132 )))
1133
1134
1135 * (% style="color:#037691" %)**Downlink Payload:**
1136
1137 (% style="background-color:#dcdcdc" %)**0x07 aa bb**    (%%) ~/~/ Equal AT+5VT=0x(aa bb)
1138
1139
1140
1141 (% style="color:#4472c4" %)**Set the weight to 0g (Zero Calibration)**
1142
1143 * (% style="color:#037691" %)**AT Command:**
1144
1145 (% style="background-color:#dcdcdc" %)**AT+WEIGRE** ** **(%%)** **~/~/ Set the weight to 0g
1146
1147
1148 * (% style="color:#037691" %)**Downlink Payload:**
1149
1150 (% style="background-color:#dcdcdc" %)**0x08 01** (%%) ~/~/ Set the weight to 0g
1151
1152
1153
1154 (% style="color:#4472c4" %)**Get or Set the GAP Value (calibrate factor) of measurement**
1155
1156 * (% style="color:#037691" %)**AT Command:**
1157
1158 (((
1159 (% style="background-color:#dcdcdc" %)**AT+WEIGAP=403.0**  (%%) ~/~/ Set GAP Value =403.0 (response: Weight: xx g)
1160 )))
1161
1162 (((
1163 (% style="background-color:#dcdcdc" %)**AT+WEIGAP=?**  (%%) ~/~/  Get current GAP Value
1164 )))
1165
1166
1167 * (% style="color:#037691" %)**Downlink Payload:**
1168
1169 (% style="background-color:#dcdcdc" %)**0x08 02 aa bb** (%%) ~/~/ Equal to AT+WEIGAP=0x(aa bb)/10
1170
1171
1172
1173 == 2.6 Show Data in Datacake IoT Server ==
1174
1175
1176 (((
1177 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:
1178 )))
1179
1180 (((
1181
1182 )))
1183
1184 (((
1185 (% style="color:blue" %)**Step 1**(%%)**:** Be sure that your device is programmed and properly connected to the network at this time.
1186 )))
1187
1188 (((
1189 (% 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:
1190 )))
1191
1192
1193 [[image:1656385623971-339.png]]
1194
1195
1196 [[image:1656385646347-395.png]]
1197
1198
1199 [[image:1656385662459-942.png]]
1200
1201
1202 (% style="color:blue" %)**Step 3**(%%)**: **Create an account or log in Datacake.
1203
1204 (% style="color:blue" %)**Step 4**(%%)**:** Search the LSN50 and add DevEUI.
1205
1206 [[image:1656385688973-317.png]]
1207
1208
1209
1210 == 2.7 ​Firmware Change Log ==
1211
1212
1213 (((
1214 **Firmware download: ** [[https:~~/~~/www.dropbox.com/sh/9k0a6sn8a94dc03/AAD54woDmnmAMUMY2WfKfjxoa?dl=0>>https://www.dropbox.com/sh/9k0a6sn8a94dc03/AAD54woDmnmAMUMY2WfKfjxoa?dl=0]]
1215 )))
1216
1217 (((
1218 **Firmware Change Log: **[[https:~~/~~/www.dropbox.com/sh/9k0a6sn8a94dc03/AAD54woDmnmAMUMY2WfKfjxoa?dl=0>>https://www.dropbox.com/sh/9k0a6sn8a94dc03/AAD54woDmnmAMUMY2WfKfjxoa?dl=0]]
1219
1220
1221
1222 )))
1223
1224 == 2.8 Use VDD or +5V to Power External Sensor ==
1225
1226
1227 (((
1228 User can use VDD or +5V to power external sensor.
1229 )))
1230
1231 (((
1232 (% style="color:red" %)**Note:**
1233 )))
1234
1235 1. (((
1236 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.
1237 )))
1238 1. (((
1239 +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>>||anchor="H2.4.92B5VOutput"]].
1240 )))
1241
1242 (((
1243 (% style="color:red" %)**Note: Always test the actually current pass by the JP2 jumper when connect to a new type of sensor.**
1244 )))
1245
1246
1247
1248 == 2.9  Battery Analysis ==
1249
1250
1251 === 2.9.1  Battery Type ===
1252
1253
1254 (((
1255 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.
1256 )))
1257
1258 (((
1259 The battery is designed to last for more than 5 years for the LSN50.
1260 )))
1261
1262
1263 (((
1264 The battery related documents as below:
1265 )))
1266
1267 * [[Battery Dimension>>https://www.dragino.com/downloads/index.php?dir=datasheet/Battery/]],
1268 * [[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/]]
1269 * [[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/]]
1270
1271 [[image:image-20220627175349-30.png]]
1272
1273
1274
1275 === 2.9.2 ​Power consumption Analyze ===
1276
1277
1278 When connect to different sensors, it is good to test the power consumption with the sensor working. User can remove the ON/OFF Jumper 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.
1279
1280 (((
1281 A victor VC86E is recommended.
1282 )))
1283
1284 [[image:1656323400306-359.png]]
1285
1286
1287 (((
1288 In a minimum system with DS18B20 and Oil Sensor and default firmware, the power consumption includes:
1289 )))
1290
1291 (((
1292
1293 )))
1294
1295 (((
1296 ~1. Deep Sleep (Stop mode) for STM32. ~~ 5uA
1297 )))
1298
1299 (((
1300 2. Sampling current while reading DS18B20 and Oil Sensor
1301 )))
1302
1303 * (((
1304 Oil Sensor sampling time: 200us, current: 0.3mA
1305 )))
1306 * (((
1307 DS18B20 sampling time: 750ms, current: 0.64mA
1308 )))
1309 * (((
1310 Above power should add 8mA CPU power in working mode.
1311 )))
1312
1313 (((
1314 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]].
1315 )))
1316
1317
1318 (((
1319 In a typical LoRaWAN data transmit. The energy profile is as below:
1320 )))
1321
1322
1323 [[image:1656323450362-299.png]]
1324
1325
1326 (((
1327 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:
1328 )))
1329
1330 1. Lower power LoRa radio. Device has a good signal to gateway
1331 1. Higher power LoRa radio. Device has a poor signal to gateway
1332
1333 (% style="color:blue" %)**Low Power Case**:
1334
1335 * Radio Parameter: SF7, 125kHz, 20dbm
1336 * Transmit interval: 15 minutes.
1337 * Payload: 8 Bytes.
1338
1339 (% style="color:blue" %)**High Power Case**:
1340
1341 * Radio Parameter: SF10, 125kHz, 20dbm
1342 * Transmit interval: 15 minutes.
1343 * Payload: 8 Bytes.
1344
1345 To simplify the calculation, we can:
1346
1347 * Combine oil sensor and DS18B20 sampling energy together to (% style="color:#4472c4" %)**751ms@8.64ma**
1348
1349 * Combine the two RX windows together.
1350
1351 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.
1352
1353
1354 [[image:1656323531520-949.png]]
1355
1356 [[image:1656323549994-233.png]]
1357
1358
1359 (% style="color:red" %)**Note: Ignore the 18 year result, because the battery has a max 2% discharge per year.**
1360
1361
1362
1363 === 2.9.3 ​Battery Note ===
1364
1365
1366 (((
1367 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.
1368 )))
1369
1370
1371
1372 === 2.9.4 Replace the battery ===
1373
1374
1375 (((
1376 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.
1377 )))
1378
1379 (((
1380 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).
1381 )))
1382
1383
1384
1385 = 3.  Using the AT Commands =
1386
1387
1388 == 3.1  Access AT Commands ==
1389
1390
1391 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.
1392
1393
1394 (% style="color:#4472c4" %)**LSN50 v1 UART connection photo**
1395
1396 [[image:image-20220627165424-24.png||height="495" width="486"]]
1397
1398
1399
1400 (% style="color:#4472c4" %)**LSN50 v2 UART connection photo**
1401
1402 [[image:image-20220627165424-25.png||height="437" width="894"]]
1403
1404
1405 (((
1406 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:
1407 )))
1408
1409
1410 [[image:image-20220627165531-26.png||height="624" width="893"]](% style="display:none" %)
1411
1412
1413
1414 == 3.2  Common AT Command Sequence ==
1415
1416
1417 === 3.2.1  Multi-channel ABP mode (Use with SX1301/LG308) ===
1418
1419
1420 (((
1421 (% style="color:#037691" %)**If device has not joined network via OTAA:**
1422 )))
1423
1424 (((
1425 (% style="background-color:#dcdcdc" %)AT+FDR
1426 )))
1427
1428 (((
1429 (% style="background-color:#dcdcdc" %)AT+NJM=0
1430 )))
1431
1432 (((
1433 (% style="background-color:#dcdcdc" %)ATZ
1434 )))
1435
1436
1437 (((
1438 (% style="color:#037691" %)**If device already joined network:**
1439 )))
1440
1441 (((
1442 (% style="background-color:#dcdcdc" %)AT+NJM=0
1443 )))
1444
1445 (((
1446 (% style="background-color:#dcdcdc" %)ATZ
1447 )))
1448
1449
1450
1451 === 3.2.2  Single-channel ABP mode (Use with LG01/LG02) ===
1452
1453
1454 See [[Sect 6.7>>||anchor="H6.7A0HowtoconfiguretheEUIkeysinLSN503F"]]
1455
1456
1457
1458 = 4.  Upload Firmware =
1459
1460
1461 (% style="color:red" %)**Notes**:
1462
1463 * 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.
1464 * Always run AT+FDR to reset parameters to factory default after an update image.
1465 If the update is from image >= v1.3 to another image version >=v1.3, then the keys will be kept after running AT+FDR.
1466 Otherwise (e.g. from v1.2 to v1.3), AT+FDR may erase the keys.
1467
1468
1469
1470
1471 == 4.1  Upload Firmware via Serial Port ==
1472
1473
1474 The LSN50's AT Command port can be used for firmware upgrade. The hardware connection for upgrade firmware is as below:
1475
1476
1477 [[image:image-20220627163506-18.png||height="426" width="418"]]
1478
1479
1480 (% 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]].
1481
1482 (% style="color:blue" %)**Step2**(%%)**:** Download the [[LSN50 Image files>>url:https://github.com/dragino/LoRa_STM32/tree/master/LSN50.hex]].
1483
1484 (% style="color:blue" %)**Step3**(%%)**: **Open flashloader; choose the correct COM port to update
1485
1486 [[image:image-20220627163821-19.png]]
1487
1488
1489 [[image:image-20220627163930-20.png||height="450" width="751"]]
1490
1491
1492 [[image:image-20220627164030-21.png||height="459" width="750"]]
1493
1494
1495 (((
1496 (% style="color:blue" %)**Step4**(%%)**: **Switch SW1 back to flash state and push the RESET button.
1497 )))
1498
1499 (((
1500 The LSN50 will then run the new firmware.
1501 )))
1502
1503
1504
1505 == 4.2  Upload Firmware via ST-Link V2 ==
1506
1507
1508 You can use ST-LINK to upgrade firmware into LSN50. The hardware connection for upgrade firmware is as below:
1509
1510
1511 [[image:1656319349131-664.png]]
1512
1513
1514 (% style="color:blue" %)**Connection:**
1515
1516 * (% style="background-color:yellow" %)**ST-LINK v2 GND  <~-~-> LSN50 GND**
1517 * (% style="background-color:yellow" %)**ST-LINK v2 SWCLK <~-~-> LSN50 PA14**
1518 * (% style="background-color:yellow" %)**ST-LINK v2 SWDIO <~-~-> LSN50 PA13**
1519 * (% style="background-color:yellow" %)**ST-LINK v2 RST  <~-~->  LSN50 NRST**
1520
1521 (% 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]]
1522
1523 (% style="color:blue" %)**Step2**(%%): Download the [[LSN50 Image files>>url:https://github.com/dragino/LoRa_STM32/tree/master/LSN50.hex]].
1524
1525 (% style="color:blue" %)**Step3:**(%%)** **Open ST-LINK utility, (% style="color:blue" %)**file ~-~-> open file**(%%) to select the image to be upgraded.
1526
1527 (% style="color:blue" %)**Step4:**(%%)** **Click the “(% style="color:blue" %)**Program Verify**”(%%) button on ST-LINK.
1528
1529
1530 [[image:image-20220627164303-22.png]]
1531
1532
1533 (((
1534 (% 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.
1535 )))
1536
1537 (((
1538 (% 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.**
1539 )))
1540
1541
1542
1543 [[image:image-20220627164303-23.png]]
1544
1545
1546
1547 = 5.  Developer Guide =
1548
1549
1550 * (((
1551 Software Source Code Download : [[https:~~/~~/github.com/dragino/LoRa_STM32/tree/master/STM32CubeExpansion_LRWAN>>https://github.com/dragino/LoRa_STM32/tree/master/STM32CubeExpansion_LRWAN]]
1552 )))
1553 * (((
1554 Hardware Source Code Download: [[https:~~/~~/github.com/dragino/Lora/tree/master/LSN50>>https://github.com/dragino/Lora/tree/master/LSN50]]
1555 )))
1556
1557 (((
1558 LSN50 is an open source project, developer can use compile their firmware for customized applications. User can get the source code from:
1559 )))
1560
1561 * (((
1562 Software Source Code: [[https:~~/~~/github.com/dragino/LoRa_STM32/tree/master/STM32CubeExpansion_LRWAN>>url:https://github.com/dragino/LoRa_STM32/tree/master/STM32CubeExpansion_LRWAN]]
1563 )))
1564 * (((
1565 Hardware Design files:  [[https:~~/~~/github.com/dragino/Lora/tree/master/LSN50>>url:https://github.com/dragino/Lora/tree/master/LSN50]]
1566 )))
1567 * (((
1568 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/]]
1569 )))
1570
1571 (((
1572 Use Keil to open project file:
1573 )))
1574
1575 (((
1576 STM32CubeExpansion_LRWAN/Projects/Multi/Applications/LoRa/DRAGINO-LRWAN(AT)/MDK-ARM/STM32L072CZ-Nucleo/Lora.uvprojx
1577 )))
1578
1579 (((
1580
1581 )))
1582
1583 (((
1584 In Keil, you can see what frequency band the code support.
1585 )))
1586
1587 [[image:image-20220627162417-15.png]]
1588
1589
1590 **~1. If you want to change frequency, modify the Preprocessor Symbols.**
1591
1592
1593 For example, change EU868 to US915
1594
1595 [[image:1656318662202-530.png]]
1596
1597
1598 **2. Compile and build**
1599
1600 [[image:image-20220627163212-17.png]]
1601
1602
1603
1604 = 6.  FAQ =
1605
1606
1607 == 6.1  Why there is 433/868/915 version? ==
1608
1609
1610 (((
1611 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.
1612 )))
1613
1614
1615
1616 == 6.2 What is the frequency range of LT LoRa part? ==
1617
1618
1619 Different LT version supports different frequency range, below is the table for the working frequency and recommend bands for each model:
1620
1621 [[image:image-20220627155456-9.png]]
1622
1623
1624
1625 == 6.3  How to change the LoRa Frequency Bands/Region? ==
1626
1627
1628 You can follow the instructions for [[how to upgrade image>>||anchor="H2.7200BFirmwareChangeLog"]].
1629 When downloading the images, choose the required image file for download.
1630
1631
1632
1633 == 6.4  Can I use Private LoRa protocol? ==
1634
1635
1636 (((
1637 (((
1638 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.
1639 )))
1640
1641 (((
1642 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.
1643 )))
1644
1645
1646 )))
1647
1648 (% style="color:#4472c4" %)**LoRa Shield + UNO**:
1649
1650 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.
1651
1652
1653 Refs:
1654
1655 [[https:~~/~~/www.dropbox.com/sh/u9s41qdx5yujwcb/AAAT5r4QkMaeOogWrzJt7Wn4a?dl=0>>https://www.dropbox.com/sh/u9s41qdx5yujwcb/AAAT5r4QkMaeOogWrzJt7Wn4a?dl=0]]
1656
1657
1658 Open the serial monitor to Arduino. The device acts as a LoRa Receiver and listen on the frequency 868.3Mhz by default.
1659
1660
1661 (% style="color:#4472c4" %)**LSN50**:
1662
1663 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
1664
1665 Compile it and Upload it to LSN50, the LSN50 will transfer on the frequency 868.3Mhz.
1666
1667 In the Arduino Console, it will see the received packets as below.
1668
1669
1670 [[image:image-20220627160116-10.png]]
1671
1672
1673
1674 == 6.5  How to set up LSN50 to work in 8 channel mode ==
1675
1676
1677 (((
1678 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.
1679 )))
1680
1681 (((
1682 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.
1683 )))
1684
1685 (((
1686
1687 )))
1688
1689 (((
1690 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.
1691 )))
1692
1693 [[image:image-20220627160940-13.png]]
1694
1695
1696 (((
1697 When you use the TTN V3 network, the US915 frequency bands use are:
1698 )))
1699
1700 * (((
1701 903.9 - SF7BW125 to SF10BW125
1702 )))
1703 * (((
1704 904.1 - SF7BW125 to SF10BW125
1705 )))
1706 * (((
1707 904.3 - SF7BW125 to SF10BW125
1708 )))
1709 * (((
1710 904.5 - SF7BW125 to SF10BW125
1711 )))
1712 * (((
1713 904.7 - SF7BW125 to SF10BW125
1714 )))
1715 * (((
1716 904.9 - SF7BW125 to SF10BW125
1717 )))
1718 * (((
1719 905.1 - SF7BW125 to SF10BW125
1720 )))
1721 * (((
1722 905.3 - SF7BW125 to SF10BW125
1723 )))
1724 * (((
1725 904.6 - SF8BW500
1726 )))
1727
1728 (((
1729 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:
1730 )))
1731
1732 (((
1733 (% style="color:blue" %)**AT+CHE=2**
1734 )))
1735
1736 (((
1737 (% style="color:blue" %)**ATZ**
1738 )))
1739
1740
1741 (((
1742 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.
1743 )))
1744
1745 (((
1746 The (% style="color:blue" %)**AU915**(%%) band is similar. Below are the AU915 Uplink Channels.
1747 )))
1748
1749 [[image:image-20220627161124-14.png]]
1750
1751
1752
1753 == 6.6  How to set up LSN50 to work with Single Channel Gateway such as LG01/LG02? ==
1754
1755
1756 (((
1757 In this case, users need to set LSN50 to work in ABP mode and transmit in only one frequency.
1758 )))
1759
1760 (((
1761 Assume we have a LG02 working in the frequency 868400000 now, below is the steps.
1762 )))
1763
1764
1765 (((
1766 (% 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.
1767 )))
1768
1769
1770 [[image:image-20220627160542-11.png]]
1771
1772
1773 (((
1774 (% 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.**
1775 )))
1776
1777
1778 (((
1779 (% style="color:red" %)**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]].**
1780 )))
1781
1782
1783
1784 (((
1785 (% style="color:blue" %)**Step2:  **(%%)Run AT commands to make the LSN50 work in Single frequency and ABP mode. Below are the AT commands:
1786 )))
1787
1788
1789 (((
1790 (% style="background-color:#dcdcdc" %)AT+FDR(%%)  Reset Parameters to Factory Default, Keys Reserve
1791 )))
1792
1793 (((
1794 (% style="background-color:#dcdcdc" %)AT+NJM=0(%%)  Set to ABP mode
1795 )))
1796
1797 (((
1798 (% style="background-color:#dcdcdc" %)AT+ADR=0(%%)  Set the Adaptive Data Rate Off
1799 )))
1800
1801 (((
1802 (% style="background-color:#dcdcdc" %)AT+DR=5(%%)  Set Data Rate (Set AT+DR=3 for 915 band)
1803 )))
1804
1805 (((
1806 (% style="background-color:#dcdcdc" %)AT+TDC=300000(%%)  Set transmit interval to 5 minutes
1807 )))
1808
1809 (((
1810 (% style="background-color:#dcdcdc" %)AT+CHS=868400000(%%)  Set transmit frequency to 868.4Mhz
1811 )))
1812
1813 (((
1814 (% style="background-color:#dcdcdc" %)AT+DADDR=26 01 1A F1(%%)  Set Device Address to 26 01 1A F1
1815 )))
1816
1817 (((
1818 (% style="background-color:#dcdcdc" %)ATZ(%%)  Reset MCU
1819 )))
1820
1821
1822 (((
1823 As shown  below:
1824 )))
1825
1826 [[image:image-20220627160542-12.png]]
1827
1828
1829
1830 == 6.7  How to configure the EUI keys in LSN50? ==
1831
1832
1833 (((
1834 The early version of LSN50 firmware doesn't have pre-configured keys.
1835 It is recommended that you update the image to the latest version before configure the keys. Refer [[upgrade_image>>||anchor="H2.7200BFirmwareChangeLog"]] to update the firmware to the latest version.
1836 )))
1837
1838 (((
1839 Run AT commands to set the keys to desired keys; refer [[AT Command manual>>https://www.dragino.com/downloads/downloads/LSN50-LoRaST/DRAGINO_LSN50_AT_Commands_v1.6.3.pdf]].
1840 )))
1841
1842
1843
1844 = 7.  Trouble Shooting =
1845
1846
1847 == 7.1  Connection problem when uploading firmware. ==
1848
1849
1850 (((
1851 (% 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.
1852 )))
1853
1854 (((
1855
1856 )))
1857
1858 (((
1859 (% style="color:green" %)**Checklist**:
1860 )))
1861
1862 (((
1863 ~1. Double check if follow up exactly the steps as manual.
1864 )))
1865
1866 (((
1867 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.
1868 )))
1869
1870 (((
1871 3. If you use Windows10 system. Please change the flash loader to run in Windows7 compatibility mode.
1872 )))
1873
1874
1875 [[image:image-20220627153421-8.png]]
1876
1877
1878 (((
1879 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.
1880 )))
1881
1882
1883
1884 == 7.2  Why I can't join TTN V3 in US915 / AU915 bands? ==
1885
1886
1887 It is due to channel mapping. Please see the [[Eight Channel Mode>>doc:Main.End Device AT Commands and Downlink Command.WebHome||anchor="H7.19EightChannelMode"]] section above for details.
1888
1889
1890
1891 == 7.3  AT Command input doesn't work ==
1892
1893
1894 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.
1895
1896
1897
1898 = 8.  Order Info =
1899
1900
1901 Part Number: (% style="color:blue" %)**LSN50-XX-YY  **(%%)**or  (% style="color:blue" %)LSN50-v2-XX-YY-ZZ(%%)**
1902
1903 (% style="color:blue" %)**XX**(%%): The default frequency band
1904
1905 * (% style="color:red" %)**AS923 **(%%)**:** LoRaWAN AS923 band
1906 * (% style="color:red" %)**AU915 **(%%)**:** LoRaWAN AU915 band
1907 * (% style="color:red" %)**EU433 **(%%)**:** LoRaWAN EU433 band
1908 * (% style="color:red" %)**EU868 **(%%)**:** LoRaWAN EU868 band
1909 * (% style="color:red" %)**KR920 **(%%)**:** LoRaWAN KR920 band
1910 * (% style="color:red" %)**US915 **(%%)**:** LoRaWAN US915 band
1911 * (% style="color:red" %)**IN865 **(%%)**:**  LoRaWAN IN865 band
1912 * (% style="color:red" %)**CN470 **(%%)**:** LoRaWAN CN470 band
1913
1914 (% style="color:blue" %)**YY**(%%)**: **Hole Option
1915
1916 * (% style="color:red" %)**12**(%%): With M12 waterproof cable hole
1917 * (% style="color:red" %)**16**(%%): With M16 waterproof cable hole
1918 * (% style="color:red" %)**20**(%%): With M20 waterproof cable hole (LSN50 v2 doesn't have this version)
1919 * (% style="color:red" %)**NH**(%%): No Hole
1920
1921 (% style="color:blue" %)**ZZ**(%%)**: **Battery Option ( Only valid for v2 model)
1922
1923 * (% style="color:red" %)**4**(%%): with 4000mAh battery
1924 * (% style="color:red" %)**8**(%%): with 8500mAg battery
1925
1926
1927
1928
1929 = 9. ​ Packing Info =
1930
1931
1932 (% style="color:blue" %)**For LSN50**(%%)**:**
1933
1934 **Package Includes**:
1935
1936 * LSN50 LoRa Sensor Node x 1
1937
1938 **Dimension and weight**:
1939
1940 * Device Size: 8 x 6.5 x 5 cm
1941 * Device Weight: 137g
1942 * Package Size / pcs : 9 x 7 x 6cm
1943 * Weight / pcs : 160g
1944
1945
1946 (% style="color:blue" %)**For LSN50 v2**(%%)**:**
1947
1948 **Package Includes**:
1949
1950 * LSN50 v2 LoRa Sensor Node x 1
1951 * External antenna x 1
1952 * Spring Antenna (evaluate purpose)
1953
1954 **Dimension and weight**:
1955
1956 * Device Size: 9.7 x 6.5 x 4.7 cm
1957 * Device Weight: 150g
1958 * Package Size / pcs : 14.0 x 8x 5 cm
1959 * Weight / pcs : 180g
1960
1961
1962
1963
1964 = 10.  ​Support =
1965
1966
1967 * 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.
1968 * 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]].
1969
1970
1971
1972
1973 = 11.  References =
1974
1975
1976 * [[Product Page>>url:http://www.dragino.com/products/lora/item/128-lsn50.html]]
1977 * [[Data Sheet, Document Base>>https://www.dropbox.com/sh/djkxs7mr17y94mi/AABVlWbM9uzK9OA3mXyAT10Za?dl=0]]
1978 * [[Image Download>>url:https://github.com/dragino/LoRa_STM32/tree/master/LSN50.hex]]
1979
1980