Changes for page SN50v3-LB/LS -- LoRaWAN Sensor Node User Manual
Last modified by Bei Jinggeng on 2025/01/10 15:51
Change comment:
Uploaded new attachment "image-20230817173858-5.png", version {1}
Summary
-
Page properties (3 modified, 0 added, 0 removed)
-
Attachments (0 modified, 31 added, 0 removed)
- image-20230512163509-1.png
- image-20230512164658-2.png
- image-20230512170701-3.png
- image-20230512172447-4.png
- image-20230512173758-5.png
- image-20230512173903-6.png
- image-20230512180609-7.png
- image-20230512180718-8.png
- image-20230512181814-9.png
- image-20230513084523-1.png
- image-20230513102034-2.png
- image-20230513103633-3.png
- image-20230513105207-4.png
- image-20230513105351-5.png
- image-20230513110214-6.png
- image-20230513111203-7.png
- image-20230513111231-8.png
- image-20230513111255-9.png
- image-20230513134006-1.png
- image-20230515135611-1.jpeg
- image-20230610162852-1.png
- image-20230610163213-1.png
- image-20230610170047-1.png
- image-20230610170152-2.png
- image-20230810121434-1.png
- image-20230811113449-1.png
- image-20230817170702-1.png
- image-20230817172209-2.png
- image-20230817173800-3.png
- image-20230817173830-4.png
- image-20230817173858-5.png
Details
- Page properties
-
- Title
-
... ... @@ -1,1 +1,1 @@ 1 -SN50v3-LB User Manual 1 +SN50v3-LB LoRaWAN Sensor Node User Manual - Author
-
... ... @@ -1,1 +1,1 @@ 1 -XWiki. Edwin1 +XWiki.Saxer - Content
-
... ... @@ -1,4 +1,5 @@ 1 -[[image:image-20230511201248-1.png||height="403" width="489"]] 1 +(% style="text-align:center" %) 2 +[[image:image-20230515135611-1.jpeg||height="589" width="589"]] 2 2 3 3 4 4 ... ... @@ -15,23 +15,21 @@ 15 15 16 16 == 1.1 What is SN50v3-LB LoRaWAN Generic Node == 17 17 19 + 18 18 (% style="color:blue" %)**SN50V3-LB **(%%)LoRaWAN Sensor Node is a Long Range LoRa Sensor Node. It is designed for outdoor use and powered by (% style="color:blue" %)** 8500mA Li/SOCl2 battery**(%%) for long term use.SN50V3-LB is designed to facilitate developers to quickly deploy industrial level LoRa and IoT solutions. It help 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. 19 19 20 - 21 21 (% style="color:blue" %)**SN50V3-LB wireless part**(%%) is based on SX1262 allows the user to send data and reach extremely long ranges at low data-rates.It provides ultra-long range spread spectrum communication and high interference immunity whilst minimising current consumption.It targets professional wireless sensor network applications such as irrigation systems, smart metering, smart cities, smartphone detection, building automation, and so on. 22 22 23 - 24 24 (% style="color:blue" %)**SN50V3-LB **(%%)has a powerful 48Mhz ARM microcontroller with 256KB flash and 64KB RAM. It has multiplex I/O pins to connect to different sensors. 25 25 26 - 27 27 (% style="color:blue" %)**SN50V3-LB**(%%) has a built-in BLE module, user can configure the sensor remotely via Mobile Phone. It also support OTA upgrade via private LoRa protocol for easy maintaining. 28 28 29 - 30 30 SN50V3-LB is the 3^^rd^^ generation of LSN50 series generic sensor node from Dragino. It is an (% style="color:blue" %)**open source project**(%%) and has a mature LoRaWAN stack and application software. User can use the pre-load software for their IoT projects or easily customize the software for different requirements. 31 31 32 32 33 33 == 1.2 Features == 34 34 33 + 35 35 * LoRaWAN 1.0.3 Class A 36 36 * Ultra-low power consumption 37 37 * Open-Source hardware/software ... ... @@ -42,8 +42,11 @@ 42 42 * Downlink to change configure 43 43 * 8500mAh Battery for long term use 44 44 44 + 45 + 45 45 == 1.3 Specification == 46 46 48 + 47 47 (% style="color:#037691" %)**Common DC Characteristics:** 48 48 49 49 * Supply Voltage: built in 8500mAh Li-SOCI2 battery , 2.5v ~~ 3.6v ... ... @@ -78,8 +78,11 @@ 78 78 * Sleep Mode: 5uA @ 3.3v 79 79 * LoRa Transmit Mode: 125mA @ 20dBm, 82mA @ 14dBm 80 80 83 + 84 + 81 81 == 1.4 Sleep mode and working mode == 82 82 87 + 83 83 (% style="color:blue" %)**Deep Sleep Mode: **(%%)Sensor doesn't have any LoRaWAN activate. This mode is used for storage and shipping to save battery life. 84 84 85 85 (% style="color:blue" %)**Working Mode:** (%%)In this mode, Sensor will work as LoRaWAN Sensor to Join LoRaWAN network and send out sensor data to server. Between each sampling/tx/rx periodically, sensor will be in IDLE mode), in IDLE mode, sensor has the same power consumption as Deep Sleep mode. ... ... @@ -104,6 +104,8 @@ 104 104 ))) 105 105 |(% style="width:167px" %)Fast press ACT 5 times.|(% style="width:117px" %)Deactivate Device|(% style="width:225px" %)(% style="color:red" %)**Red led**(%%) will solid on for 5 seconds. Means device is in Deep Sleep Mode. 106 106 112 + 113 + 107 107 == 1.6 BLE connection == 108 108 109 109 ... ... @@ -122,7 +122,7 @@ 122 122 == 1.7 Pin Definitions == 123 123 124 124 125 -[[image:image-20230 511203450-2.png||height="443" width="785"]]132 +[[image:image-20230610163213-1.png||height="404" width="699"]] 126 126 127 127 128 128 == 1.8 Mechanical == ... ... @@ -135,8 +135,9 @@ 135 135 [[image:Main.User Manual for LoRaWAN End Nodes.D20-LBD22-LBD23-LB_LoRaWAN_Temperature_Sensor_User_Manual.WebHome@1675143909447-639.png]] 136 136 137 137 138 -== Hole Option == 145 +== 1.9 Hole Option == 139 139 147 + 140 140 SN50v3-LB has different hole size options for different size sensor cable. The options provided are M12, M16 and M20. The definition is as below: 141 141 142 142 [[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/image-20220627104757-1.png?rev=1.1||alt="image-20220627104757-1.png"]] ... ... @@ -149,7 +149,7 @@ 149 149 == 2.1 How it works == 150 150 151 151 152 -The SN50v3-LB is configured as (% style="color:#037691" %)**LoRaWAN OTAA Class A**(%%) mode by default. It has OTAA keys to join LoRaWAN network. To connect a local LoRaWAN network, you need to input the OTAA keys in the LoRaWAN IoT server and press the button to activate the S3 1x-LB. It will automatically join the network via OTAA and start to send the sensor value. The default uplink interval is 20 minutes.160 +The SN50v3-LB is configured as (% style="color:#037691" %)**LoRaWAN OTAA Class A**(%%) mode by default. It has OTAA keys to join LoRaWAN network. To connect a local LoRaWAN network, you need to input the OTAA keys in the LoRaWAN IoT server and press the button to activate the SN50v3-LB. It will automatically join the network via OTAA and start to send the sensor value. The default uplink interval is 20 minutes. 153 153 154 154 155 155 == 2.2 Quick guide to connect to LoRaWAN server (OTAA) == ... ... @@ -157,7 +157,7 @@ 157 157 158 158 Following is an example for how to join the [[TTN v3 LoRaWAN Network>>url:https://console.cloud.thethings.network/]]. Below is the network structure; we use the [[LPS8v2>>url:https://www.dragino.com/products/lora-lorawan-gateway/item/228-lps8v2.html]] as a LoRaWAN gateway in this example. 159 159 160 -The LPS8 V2 is already set to connected to [[TTN network >>url:https://console.cloud.thethings.network/]], so what we need to now is configure the TTN server.168 +The LPS8v2 is already set to connected to [[TTN network >>url:https://console.cloud.thethings.network/]], so what we need to now is configure the TTN server. 161 161 162 162 163 163 (% style="color:blue" %)**Step 1:**(%%) Create a device in TTN with the OTAA keys from SN50v3-LB. ... ... @@ -206,7 +206,7 @@ 206 206 === 2.3.1 Device Status, FPORT~=5 === 207 207 208 208 209 -Users can use the downlink command(**0x26 01**) to ask SN50v3 to send device configure detail, include device configure status. SN50v3 will uplink a payload via FPort=5 to server. 217 +Users can use the downlink command(**0x26 01**) to ask SN50v3-LB to send device configure detail, include device configure status. SN50v3-LB will uplink a payload via FPort=5 to server. 210 210 211 211 The Payload format is as below. 212 212 ... ... @@ -214,44 +214,44 @@ 214 214 (% border="1" cellspacing="4" style="background-color:#f2f2f2; width:510px" %) 215 215 |(% colspan="6" style="background-color:#d9e2f3; color:#0070c0" %)**Device Status (FPORT=5)** 216 216 |(% style="width:103px" %)**Size (bytes)**|(% style="width:72px" %)**1**|**2**|(% style="width:91px" %)**1**|(% style="width:86px" %)**1**|(% style="width:44px" %)**2** 217 -|(% style="width:103px" %) **Value**|(% style="width:72px" %)Sensor Model|Firmware Version|(% style="width:91px" %)Frequency Band|(% style="width:86px" %)Sub-band|(% style="width:44px" %)BAT225 +|(% style="width:103px" %)Value|(% style="width:72px" %)Sensor Model|Firmware Version|(% style="width:91px" %)Frequency Band|(% style="width:86px" %)Sub-band|(% style="width:44px" %)BAT 218 218 219 219 Example parse in TTNv3 220 220 221 221 222 -(% style="color:#037691" %)**Sensor Model**(%%): For SN50v3, this value is 0x1C 230 +(% style="color:#037691" %)**Sensor Model**(%%): For SN50v3-LB, this value is 0x1C 223 223 224 224 (% style="color:#037691" %)**Firmware Version**(%%): 0x0100, Means: v1.0.0 version 225 225 226 226 (% style="color:#037691" %)**Frequency Band**: 227 227 228 - *0x01: EU868236 +0x01: EU868 229 229 230 - *0x02: US915238 +0x02: US915 231 231 232 - *0x03: IN865240 +0x03: IN865 233 233 234 - *0x04: AU915242 +0x04: AU915 235 235 236 - *0x05: KZ865244 +0x05: KZ865 237 237 238 - *0x06: RU864246 +0x06: RU864 239 239 240 - *0x07: AS923248 +0x07: AS923 241 241 242 - *0x08: AS923-1250 +0x08: AS923-1 243 243 244 - *0x09: AS923-2252 +0x09: AS923-2 245 245 246 - *0x0a: AS923-3254 +0x0a: AS923-3 247 247 248 - *0x0b: CN470256 +0x0b: CN470 249 249 250 - *0x0c: EU433258 +0x0c: EU433 251 251 252 - *0x0d: KR920260 +0x0d: KR920 253 253 254 - *0x0e: MA869262 +0x0e: MA869 255 255 256 256 257 257 (% style="color:#037691" %)**Sub-Band**: ... ... @@ -272,41 +272,347 @@ 272 272 Ex2: 0x0B49 = 2889mV 273 273 274 274 275 -=== 2.3.2 283 +=== 2.3.2 Working Modes & Sensor Data. Uplink via FPORT~=2 === 276 276 277 277 278 -Sen sorDataisuplinkviaFPORT=2286 +SN50v3-LB has different working mode for the connections of different type of sensors. This section describes these modes. Use can use the AT Command (% style="color:blue" %)**AT+MOD**(%%) to set SN50v3-LB to different working modes. 279 279 280 -(% border="1" cellspacing="5" style="background-color:#f2f2f2; width:500px" %) 281 -|=(% style="width: 90px;background-color:#D9E2F3" %)((( 288 +For example: 289 + 290 + (% style="color:blue" %)**AT+MOD=2 ** (%%) ~/~/ will set the SN50v3 to work in MOD=2 distance mode which target to measure distance via Ultrasonic Sensor. 291 + 292 + 293 +(% style="color:red" %) **Important Notice:** 294 + 295 +~1. Some working modes has payload more than 12 bytes, The US915/AU915/AS923 frequency bands' definition has maximum 11 bytes in (% style="color:blue" %)**DR0**(%%). Server sides will see NULL payload while SN50v3-LB transmit in DR0 with 12 bytes payload. 296 + 297 +2. All modes share the same Payload Explanation from HERE. 298 + 299 +3. By default, the device will send an uplink message every 20 minutes. 300 + 301 + 302 +==== 2.3.2.1 MOD~=1 (Default Mode) ==== 303 + 304 + 305 +In this mode, uplink payload includes in total 11 bytes. Uplink packets use FPORT=2. 306 + 307 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:520px" %) 308 +|(% style="background-color:#d9e2f3; color:#0070c0; width:50px" %)**Size(bytes)**|(% style="background-color:#d9e2f3; color:#0070c0; width:20px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:100px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:50px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:90px" %)**1**|(% style="background-color:#d9e2f3; color:#0070c0; width:130px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:80px" %)**2** 309 +|Value|Bat|(% style="width:191px" %)((( 310 +Temperature(DS18B20)(PC13) 311 +)))|(% style="width:78px" %)((( 312 +ADC(PA4) 313 +)))|(% style="width:216px" %)((( 314 +Digital in(PB15)&Digital Interrupt(PA8) 315 +)))|(% style="width:308px" %)((( 316 +Temperature(SHT20 or SHT31 or BH1750 Illumination Sensor) 317 +)))|(% style="width:154px" %)((( 318 +Humidity(SHT20 or SHT31) 319 +))) 320 + 321 +[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/image-20220627150949-6.png?rev=1.1||alt="image-20220627150949-6.png"]] 322 + 323 + 324 +==== 2.3.2.2 MOD~=2 (Distance Mode) ==== 325 + 326 + 327 +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. 328 + 329 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:520px" %) 330 +|(% style="background-color:#d9e2f3; color:#0070c0; width:50px" %)**Size(bytes)**|(% style="background-color:#d9e2f3; color:#0070c0; width:30px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:110px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:40px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:110px" %)**1**|(% style="background-color:#d9e2f3; color:#0070c0; width:140px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:40px" %)**2** 331 +|Value|BAT|(% style="width:196px" %)((( 332 +Temperature(DS18B20)(PC13) 333 +)))|(% style="width:87px" %)((( 334 +ADC(PA4) 335 +)))|(% style="width:189px" %)((( 336 +Digital in(PB15) & Digital Interrupt(PA8) 337 +)))|(% style="width:208px" %)((( 338 +Distance measure by: 1) LIDAR-Lite V3HP 339 +Or 2) Ultrasonic Sensor 340 +)))|(% style="width:117px" %)Reserved 341 + 342 +[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/1656324539647-568.png?rev=1.1||alt="1656324539647-568.png"]] 343 + 344 + 345 +(% style="color:blue" %)**Connection of LIDAR-Lite V3HP:** 346 + 347 +[[image:image-20230512173758-5.png||height="563" width="712"]] 348 + 349 + 350 +(% style="color:blue" %)**Connection to Ultrasonic Sensor:** 351 + 352 +(% style="color:red" %)**Need to remove R1 and R2 resistors to get low power,otherwise there will be 240uA standby current.** 353 + 354 +[[image:image-20230512173903-6.png||height="596" width="715"]] 355 + 356 + 357 +For the connection to TF-Mini or TF-Luna , MOD2 payload is as below: 358 + 359 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:520px" %) 360 +|(% style="background-color:#d9e2f3; color:#0070c0; width:50px" %)**Size(bytes)**|(% style="background-color:#d9e2f3; color:#0070c0; width:20px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:100px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:100px" %)**1**|(% style="background-color:#d9e2f3; color:#0070c0; width:50px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:120px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:80px" %)**2** 361 +|Value|BAT|(% style="width:183px" %)((( 362 +Temperature(DS18B20)(PC13) 363 +)))|(% style="width:173px" %)((( 364 +Digital in(PB15) & Digital Interrupt(PA8) 365 +)))|(% style="width:84px" %)((( 366 +ADC(PA4) 367 +)))|(% style="width:323px" %)((( 368 +Distance measure by:1)TF-Mini plus LiDAR 369 +Or 2) TF-Luna LiDAR 370 +)))|(% style="width:188px" %)Distance signal strength 371 + 372 +[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/1656376779088-686.png?rev=1.1||alt="1656376779088-686.png"]] 373 + 374 + 375 +**Connection to [[TF-Mini plus>>url:http://en.benewake.com/product/detail/5c345cd0e5b3a844c472329b.html]] LiDAR(UART version):** 376 + 377 +(% style="color:red" %)**Need to remove R3 and R4 resistors to get low power,otherwise there will be 400uA standby current.** 378 + 379 +[[image:image-20230512180609-7.png||height="555" width="802"]] 380 + 381 + 382 +**Connection to [[TF-Luna>>url:http://en.benewake.com/product/detail/5e1c1fd04d839408076b6255.html]] LiDAR (UART version):** 383 + 384 +(% style="color:red" %)**Need to remove R3 and R4 resistors to get low power,otherwise there will be 400uA standby current.** 385 + 386 +[[image:image-20230610170047-1.png||height="452" width="799"]] 387 + 388 + 389 +==== 2.3.2.3 MOD~=3 (3 ADC + I2C) ==== 390 + 391 + 392 +This mode has total 12 bytes. Include 3 x ADC + 1x I2C 393 + 394 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:520px" %) 395 +|=(% style="width: 50px;background-color:#D9E2F3;color:#0070C0" %)((( 282 282 **Size(bytes)** 283 -)))|=(% style="width: 80px;background-color:#D9E2F3" %)2|=(% style="width: 90px;background-color:#D9E2F3" %)4|=(% style="width:80px;background-color:#D9E2F3" %)1|=(% style="width: 80px;background-color:#D9E2F3" %)**2**|=(% style="width: 80px;background-color:#D9E2F3" %)2 284 -|(% style="width:99px" %)**Value**|(% style="width:69px" %)((( 285 -[[Battery>>||anchor="HBattery:"]] 286 -)))|(% style="width:130px" %)((( 287 -[[Unix TimeStamp>>||anchor="H2.5.2UnixTimeStamp"]] 288 -)))|(% style="width:91px" %)((( 289 -[[Alarm Flag>>||anchor="HAlarmFlag26MOD:"]] 290 -)))|(% style="width:103px" %)((( 291 -[[Temperature>>||anchor="HTemperature:"]] 292 -)))|(% style="width:80px" %)((( 293 -[[Humidity>>||anchor="HHumidity:"]] 397 +)))|=(% style="width: 50px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 50px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 50px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 90px;background-color:#D9E2F3;color:#0070C0" %)**1**|=(% style="width: 110px;background-color:#D9E2F3;color:#0070C0" %)2|=(% style="width: 100px;background-color:#D9E2F3;color:#0070C0" %)2|=(% style="width: 20px;background-color:#D9E2F3;color:#0070C0" %)1 398 +|Value|(% style="width:68px" %)((( 399 +ADC1(PA4) 400 +)))|(% style="width:75px" %)((( 401 +ADC2(PA5) 402 +)))|((( 403 +ADC3(PA8) 404 +)))|((( 405 +Digital Interrupt(PB15) 406 +)))|(% style="width:304px" %)((( 407 +Temperature(SHT20 or SHT31 or BH1750 Illumination Sensor) 408 +)))|(% style="width:163px" %)((( 409 +Humidity(SHT20 or SHT31) 410 +)))|(% style="width:53px" %)Bat 411 + 412 +[[image:image-20230513110214-6.png]] 413 + 414 + 415 +==== 2.3.2.4 MOD~=4 (3 x DS18B20) ==== 416 + 417 + 418 +This mode has total 11 bytes. As shown below: 419 + 420 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:520px" %) 421 +|(% style="background-color:#d9e2f3; color:#0070c0; width:50px" %)**Size(bytes)**|(% style="background-color:#d9e2f3; color:#0070c0; width:20px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:100px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:50px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:100px" %)**1**|(% style="background-color:#d9e2f3; color:#0070c0; width:100px" %)**2**|(% style="background-color:#d9e2f3; color:#0070c0; width:100px" %)**2** 422 +|Value|BAT|(% style="width:186px" %)((( 423 +Temperature1(DS18B20)(PC13) 424 +)))|(% style="width:82px" %)((( 425 +ADC(PA4) 426 +)))|(% style="width:210px" %)((( 427 +Digital in(PB15) & Digital Interrupt(PA8) 428 +)))|(% style="width:191px" %)Temperature2(DS18B20) 429 +(PB9)|(% style="width:183px" %)Temperature3(DS18B20)(PB8) 430 + 431 +[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/1656377606181-607.png?rev=1.1||alt="1656377606181-607.png"]] 432 + 433 + 434 +[[image:image-20230513134006-1.png||height="559" width="736"]] 435 + 436 + 437 +==== 2.3.2.5 MOD~=5(Weight Measurement by HX711) ==== 438 + 439 + 440 +[[image:image-20230512164658-2.png||height="532" width="729"]] 441 + 442 +Each HX711 need to be calibrated before used. User need to do below two steps: 443 + 444 +1. Zero calibration. Don't put anything on load cell and run (% style="color:blue" %)**AT+WEIGRE**(%%) to calibrate to Zero gram. 445 +1. Adjust calibration factor (default value 400): Put a known weight thing on load cell and run (% style="color:blue" %)**AT+WEIGAP**(%%) to adjust the Calibration Factor. 446 +1. ((( 447 +Weight has 4 bytes, the unit is g. 448 + 449 + 450 + 294 294 ))) 295 295 296 - ==== (% style="color:#4472c4"%)**Battery**(%%) ====453 +For example: 297 297 298 - SensorBatteryLevel.455 +(% style="color:blue" %)**AT+GETSENSORVALUE =0** 299 299 457 +Response: Weight is 401 g 458 + 459 +Check the response of this command and adjust the value to match the real value for thing. 460 + 461 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:520px" %) 462 +|=(% style="width: 50px;background-color:#D9E2F3;color:#0070C0" %)((( 463 +**Size(bytes)** 464 +)))|=(% style="width: 20px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 150px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 50px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 200px;background-color:#D9E2F3;color:#0070C0" %)**1**|=(% style="width: 50px;background-color:#D9E2F3;color:#0070C0" %)**4** 465 +|Value|BAT|(% style="width:193px" %)((( 466 +Temperature(DS18B20)(PC13) 467 +)))|(% style="width:85px" %)((( 468 +ADC(PA4) 469 +)))|(% style="width:186px" %)((( 470 +Digital in(PB15) & Digital Interrupt(PA8) 471 +)))|(% style="width:100px" %)Weight 472 + 473 +[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/image-20220820120036-2.png?width=1003&height=469&rev=1.1||alt="image-20220820120036-2.png" height="469" width="1003"]] 474 + 475 + 476 +==== 2.3.2.6 MOD~=6 (Counting Mode) ==== 477 + 478 + 479 +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. 480 + 481 +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. 482 + 483 +[[image:image-20230512181814-9.png||height="543" width="697"]] 484 + 485 + 486 +(% 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 SN50_v3 to avoid this happen.** 487 + 488 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:520px" %) 489 +|=(% style="width: 60px;background-color:#D9E2F3;color:#0070C0" %)**Size(bytes)**|=(% style="width: 40px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 180px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 60px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 100px;background-color:#D9E2F3;color:#0070C0" %)**1**|=(% style="width: 80px;background-color:#D9E2F3;color:#0070C0" %)**4** 490 +|Value|BAT|(% style="width:256px" %)((( 491 +Temperature(DS18B20)(PC13) 492 +)))|(% style="width:108px" %)((( 493 +ADC(PA4) 494 +)))|(% style="width:126px" %)((( 495 +Digital in(PB15) 496 +)))|(% style="width:145px" %)((( 497 +Count(PA8) 498 +))) 499 + 500 +[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/1656378441509-171.png?rev=1.1||alt="1656378441509-171.png"]] 501 + 502 + 503 +==== 2.3.2.7 MOD~=7 (Three interrupt contact modes) ==== 504 + 505 + 506 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:520px" %) 507 +|=(% style="width: 50px;background-color:#D9E2F3;color:#0070C0" %)((( 508 +**Size(bytes)** 509 +)))|=(% style="width: 20px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 90px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 50px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 90px;background-color:#D9E2F3;color:#0070C0" %)**1**|=(% style="width: 90px;background-color:#D9E2F3;color:#0070C0" %)**1**|=(% style="width: 90px;background-color:#D9E2F3;color:#0070C0" %)1|=(% style="width: 40px;background-color:#D9E2F3;color:#0070C0" %)2 510 +|Value|BAT|(% style="width:188px" %)((( 511 +Temperature(DS18B20) 512 +(PC13) 513 +)))|(% style="width:83px" %)((( 514 +ADC(PA5) 515 +)))|(% style="width:184px" %)((( 516 +Digital Interrupt1(PA8) 517 +)))|(% style="width:186px" %)Digital Interrupt2(PA4)|(% style="width:197px" %)Digital Interrupt3(PB15)|(% style="width:100px" %)Reserved 518 + 519 +[[image:image-20230513111203-7.png||height="324" width="975"]] 520 + 521 + 522 +==== 2.3.2.8 MOD~=8 (3ADC+1DS18B20) ==== 523 + 524 + 525 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:520px" %) 526 +|=(% style="width: 50px;background-color:#D9E2F3;color:#0070C0" %)((( 527 +**Size(bytes)** 528 +)))|=(% style="width: 30px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 110px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 70px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 120px;background-color:#D9E2F3;color:#0070C0" %)**1**|=(% style="width: 70px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 70px;background-color:#D9E2F3;color:#0070C0" %)2 529 +|Value|BAT|(% style="width:207px" %)((( 530 +Temperature(DS18B20) 531 +(PC13) 532 +)))|(% style="width:94px" %)((( 533 +ADC1(PA4) 534 +)))|(% style="width:198px" %)((( 535 +Digital Interrupt(PB15) 536 +)))|(% style="width:84px" %)((( 537 +ADC2(PA5) 538 +)))|(% style="width:82px" %)((( 539 +ADC3(PA8) 540 +))) 541 + 542 +[[image:image-20230513111231-8.png||height="335" width="900"]] 543 + 544 + 545 +==== 2.3.2.9 MOD~=9 (3DS18B20+ two Interrupt count mode) ==== 546 + 547 + 548 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:520px" %) 549 +|=(% style="width: 50px;background-color:#D9E2F3;color:#0070C0" %)((( 550 +**Size(bytes)** 551 +)))|=(% style="width: 20px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 90px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 90px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 60px;background-color:#D9E2F3;color:#0070C0" %)**1**|=(% style="width: 90px;background-color:#D9E2F3;color:#0070C0" %)**2**|=(% style="width: 60px;background-color:#D9E2F3;color:#0070C0" %)4|=(% style="width: 60px;background-color:#D9E2F3;color:#0070C0" %)4 552 +|Value|BAT|((( 553 +Temperature 554 +(DS18B20)(PC13) 555 +)))|((( 556 +Temperature2 557 +(DS18B20)(PB9) 558 +)))|((( 559 +Digital Interrupt 560 +(PB15) 561 +)))|(% style="width:193px" %)((( 562 +Temperature3 563 +(DS18B20)(PB8) 564 +)))|(% style="width:78px" %)((( 565 +Count1(PA8) 566 +)))|(% style="width:78px" %)((( 567 +Count2(PA4) 568 +))) 569 + 570 +[[image:image-20230513111255-9.png||height="341" width="899"]] 571 + 572 +(% style="color:blue" %)**The newly added AT command is issued correspondingly:** 573 + 574 +(% style="color:#037691" %)** AT+INTMOD1 PA8**(%%) pin: Corresponding downlink: (% style="color:#037691" %)**06 00 00 xx** 575 + 576 +(% style="color:#037691" %)** AT+INTMOD2 PA4**(%%) pin: Corresponding downlink: (% style="color:#037691" %)**06 00 01 xx** 577 + 578 +(% style="color:#037691" %)** AT+INTMOD3 PB15**(%%) pin: Corresponding downlink: (% style="color:#037691" %)** 06 00 02 xx** 579 + 580 + 581 +(% style="color:blue" %)**AT+SETCNT=aa,bb** 582 + 583 +When AA is 1, set the count of PA8 pin to BB Corresponding downlink:09 01 bb bb bb bb 584 + 585 +When AA is 2, set the count of PA4 pin to BB Corresponding downlink:09 02 bb bb bb bb 586 + 587 + 588 +=== 2.3.3 Decode payload === 589 + 590 + 591 +While using TTN V3 network, you can add the payload format to decode the payload. 592 + 593 +[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/1656378466788-734.png?rev=1.1||alt="1656378466788-734.png"]] 594 + 595 +The payload decoder function for TTN V3 are here: 596 + 597 +SN50v3-LB TTN V3 Payload Decoder: [[https:~~/~~/github.com/dragino/dragino-end-node-decoder>>url:https://github.com/dragino/dragino-end-node-decoder]] 598 + 599 + 600 +==== 2.3.3.1 Battery Info ==== 601 + 602 + 603 +Check the battery voltage for SN50v3-LB. 604 + 300 300 Ex1: 0x0B45 = 2885mV 301 301 302 302 Ex2: 0x0B49 = 2889mV 303 303 304 304 610 +==== 2.3.3.2 Temperature (DS18B20) ==== 305 305 306 -==== (% style="color:#4472c4" %)**Temperature**(%%) ==== 307 307 308 - **Example**:613 +If there is a DS18B20 connected to PC13 pin. The temperature will be uploaded in the payload. 309 309 615 +More DS18B20 can check the [[3 DS18B20 mode>>||anchor="H2.3.2.4MOD3D4283xDS18B2029"]] 616 + 617 +(% style="color:blue" %)**Connection:** 618 + 619 +[[image:image-20230512180718-8.png||height="538" width="647"]] 620 + 621 + 622 +(% style="color:blue" %)**Example**: 623 + 310 310 If payload is: 0105H: (0105 & 8000 == 0), temp = 0105H /10 = 26.1 degree 311 311 312 312 If payload is: FF3FH : (FF3F & 8000 == 1) , temp = (FF3FH - 65536)/10 = -19.3 degrees. ... ... @@ -314,200 +314,238 @@ 314 314 (FF3F & 8000:Judge whether the highest bit is 1, when the highest bit is 1, it is negative) 315 315 316 316 317 -==== (%style="color:#4472c4"%)**Humidity**(%%)====631 +==== 2.3.3.3 Digital Input ==== 318 318 319 319 320 - Read:0x(0197)=412Value:412/10=41.2,So 41.2%634 +The digital input for pin PB15, 321 321 636 +* When PB15 is high, the bit 1 of payload byte 6 is 1. 637 +* When PB15 is low, the bit 1 of payload byte 6 is 0. 322 322 323 -==== (% style="color:#4472c4" %)**Alarm Flag& MOD**(%%) ==== 639 +(% class="wikigeneratedid" id="H2.3.3.4A0AnalogueDigitalConverter28ADC29" %) 640 +((( 641 +When the digital interrupt pin is set to AT+INTMODx=0, this pin is used as a digital input pin. 324 324 643 +(% style="color:red" %)**Note: The maximum voltage input supports 3.6V.** 325 325 326 -**Example:** 645 + 646 +))) 327 327 328 - Ifpayload& 0x01 = 0x01 **~-~->** Thisisan AlarmMessage648 +==== 2.3.3.4 Analogue Digital Converter (ADC) ==== 329 329 330 -If payload & 0x01 = 0x00 **~-~->** This is a normal uplink message, no alarm 331 331 332 - Ifpayload>>2=0x00**~-~->**means MOD=1,Thisisa samplinguplinkmessage651 +The measuring range of the ADC is only about 0.1V to 1.1V The voltage resolution is about 0.24mv. 333 333 334 - Ifpayload>>2=0x31**~-~->**meansMOD=31, thismessage isareplymessagefor polling,thismessagecontains thealarmsettings.see[[this link>>path:#HPolltheAlarmsettings:]]fordetail.653 +When the measured output voltage of the sensor is not within the range of 0.1V and 1.1V, the output voltage terminal of the sensor shall be divided The example in the following figure is to reduce the output voltage of the sensor by three times If it is necessary to reduce more times, calculate according to the formula in the figure and connect the corresponding resistance in series. 335 335 655 +[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LHT65N%20LoRaWAN%20Temperature%20%26%20Humidity%20Sensor%20Manual/WebHome/image-20220628150112-1.png?width=285&height=241&rev=1.1||alt="image-20220628150112-1.png" height="241" width="285"]] 336 336 337 -== 2.4 Payload Decoder file == 338 338 658 +(% style="color:red" %)**Note: If the ADC type sensor needs to be powered by SN50_v3, it is recommended to use +5V to control its switch.Only sensors with low power consumption can be powered with VDD.** 339 339 340 -In TTN, use can add a custom payload so it shows friendly reading 341 341 342 - In thepage(% style="color:#037691"%)**Applications~-~-> PayloadFormats~-~-> Custom~-~->decoder**(%%)to addthe decoderfrom:661 +The position of PA5 on the hardware after **LSN50 v3.3** is changed to the position shown in the figure below, and the collected voltage becomes one-sixth of the original. 343 343 344 -[[ https:~~/~~/github.com/dragino/dragino-end-node-decoder/tree/main/LSN50v2-S31%26S31B >>https://github.com/dragino/dragino-end-node-decoder/tree/main/LSN50v2-S31%26S31B]]663 +[[image:image-20230811113449-1.png||height="370" width="608"]] 345 345 665 +==== 2.3.3.5 Digital Interrupt ==== 346 346 347 -== 2.5 Datalog Feature == 348 348 668 +Digital Interrupt refers to pin PA8, and there are different trigger methods. When there is a trigger, the SN50v3-LB will send a packet to the server. 349 349 350 - Datalog Featureistoensure IoT Server can get all sampling datafrom Sensor evenif theLoRaWAN networkis down.For each sampling, S31x-LB will storee reading for future retrieving purposes.670 +(% style="color:blue" %)** Interrupt connection method:** 351 351 672 +[[image:image-20230513105351-5.png||height="147" width="485"]] 352 352 353 -=== 2.5.1 Ways to get datalog via LoRaWAN === 354 354 675 +(% style="color:blue" %)**Example to use with door sensor :** 355 355 356 - Set[[PNACKMD=1>>||anchor="H2.5.4DatalogUplinkpayloadA028FPORT3D329"]],S31x-LB willwaitforACK for every uplink, whenthereisno LoRaWANnetwork,S31x-LBwillmark theserecordswithnon-ack messages andstorethesensor data, anditwill send all messages(10sinterval)afterthe networkrecovery.677 +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. 357 357 358 -* a) S31x-LB will do an ACK check for data records sending to make sure every data arrive server. 359 -* b) S31x-LB will send data in **CONFIRMED Mode** when PNACKMD=1, but S31x-LB won't re-transmit the packet if it doesn't get ACK, it will just mark it as a NONE-ACK message. In a future uplink if S31x-LB gets a ACK, S31x-LB will consider there is a network connection and resend all NONE-ACK messages. 679 +[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/1656379210849-860.png?rev=1.1||alt="1656379210849-860.png"]] 360 360 361 - Below is the typical case for theauto-updatedatalogfeature(SetPNACKMD=1)681 +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 SN50v3-LB interrupt interface to detect the status for the door or window. 362 362 363 -[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LHT65N%20LoRaWAN%20Temperature%20%26%20Humidity%20Sensor%20Manual/WebHome/image-20220703111700-2.png?width=1119&height=381&rev=1.1||alt="图片-20220703111700-2.png" height="381" width="1119"]] 364 364 365 -= ==2.5.2UnixTimeStamp===684 +(% style="color:blue" %)**Below is the installation example:** 366 366 686 +Fix one piece of the magnetic sensor to the door and connect the two pins to SN50v3-LB as follows: 367 367 368 -S31x-LB uses Unix TimeStamp format based on 688 +* ((( 689 +One pin to SN50v3-LB's PA8 pin 690 +))) 691 +* ((( 692 +The other pin to SN50v3-LB's VDD pin 693 +))) 369 369 370 - [[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LHT65N%20LoRaWAN%20Temperature%20%26%20Humidity%20Sensor%20Manual/WebHome/image-20220523001219-11.png?width=627&height=97&rev=1.1||alt="图片-20220523001219-11.png"height="97"width="627"]]695 +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 PA8 will be at the VCC voltage. 371 371 372 - Usercan get this timefrom link:[[https:~~/~~/www.epochconverter.com/>>url:https://www.epochconverter.com/]]:697 +Door sensors have two types: (% style="color:blue" %)** NC (Normal close)**(%%) and (% style="color:blue" %)**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. 373 373 374 - Belowis the converterexample699 +When door sensor is shorted, there will extra power consumption in the circuit, the extra current is 3v3/R14 = 3v3/1Mohm = 3uA which can be ignored. 375 375 376 -[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/L HT65N%20LoRaWAN%20Temperature%20%26%20Humidity%20Sensor%20Manual/WebHome/image-20220523001219-12.png?width=720&height=298&rev=1.1||alt="图片-20220523001219-12.png"height="298" width="720"]]701 +[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/1656379283019-229.png?rev=1.1||alt="1656379283019-229.png"]] 377 377 378 - So, wecan useAT+TIMESTAMP=1611889405ordownlink3060137afd00toset thecurrent time2021– Jan~-~- 29 Friday 03:03:25703 +The above photos shows the two parts of the magnetic switch fitted to a door. 379 379 705 +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. 380 380 381 - === 2.5.3 SetDevice Time===707 +The command is: 382 382 709 +(% style="color:blue" %)**AT+INTMOD1=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]]**. **) 383 383 384 - Userneed to set(%style="color:blue" %)**SYNCMOD=1**(%%) toenablesyncimeviaMACcommand.711 +Below shows some screen captures in TTN V3: 385 385 386 - Once S31x-LB Joined LoRaWAN network,it will send the MACcommand (DeviceTimeReq) andthe serverwill reply with (DeviceTimeAns) to send the current time to31x-LB. IfS31x-LB failstoget the time from thever, S31x-LB will use the internaltimeand wait for next timerequest (AT+SYNCTDC to set the time requestperiod, defaultis10days).713 +[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/1656379339508-835.png?rev=1.1||alt="1656379339508-835.png"]] 387 387 388 -(% style="color:red" %)**Note: LoRaWAN Server need to support LoRaWAN v1.0.3(MAC v1.0.3) or higher to support this MAC command feature, Chirpstack,TTN V3 v3 and loriot support but TTN V3 v2 doesn't support. If server doesn't support this command, it will through away uplink packet with this command, so user will lose the packet with time request for TTN V3 v2 if SYNCMOD=1.** 389 389 716 +In **MOD=1**, user can use byte 6 to see the status for door open or close. TTN V3 decoder is as below: 390 390 391 -= ==2.5.4 DatalogUplinkpayload (FPORT~=3)===718 +door= (bytes[6] & 0x80)? "CLOSE":"OPEN"; 392 392 393 393 394 - TheDataloguplinkswillusebelowpayloadformat.721 +==== 2.3.3.6 I2C Interface (SHT20 & SHT31) ==== 395 395 396 -**Retrieval data payload:** 397 397 398 -(% border="1" cellspacing="5" style="background-color:#f2f2f2; width:510px" %) 399 -|=(% style="width: 80px;background-color:#D9E2F3" %)((( 400 -**Size(bytes)** 401 -)))|=(% style="width: 60px; background-color: rgb(217, 226, 243);" %)**2**|=(% style="width: 60px; background-color: rgb(217, 226, 243);" %)**2**|=(% style="width: 120px; background-color: rgb(217, 226, 243);" %)**2**|=(% style="width: 103px; background-color: rgb(217, 226, 243);" %)**1**|=(% style="width: 85px; background-color: rgb(217, 226, 243);" %)**4** 402 -|(% style="width:103px" %)**Value**|(% style="width:54px" %)((( 403 -[[Temp_Black>>||anchor="HTemperatureBlack:"]] 404 -)))|(% style="width:51px" %)[[Temp_White>>||anchor="HTemperatureWhite:"]]|(% style="width:89px" %)[[Temp_ Red or Temp _White>>||anchor="HTemperatureREDorTemperatureWhite:"]]|(% style="width:103px" %)Poll message flag & Ext|(% style="width:54px" %)[[Unix Time Stamp>>||anchor="H2.5.2UnixTimeStamp"]] 724 +The SDA and SCK are I2C interface lines. You can use these to connect to an I2C device and get the sensor data. 405 405 406 - **Pollmessage flag&Ext:**726 +We have made an example to show how to use the I2C interface to connect to the SHT20/ SHT31 Temperature and Humidity Sensor. 407 407 408 - [[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LHT65N%20LoRaWAN%20Temperature%20%26%20Humidity%20Sensor%20Manual/WebHome/image-20221006192726-1.png?width=754&height=112&rev=1.1||alt="图片-20221006192726-1.png" height="112" width="754"]]728 +(% style="color:red" %)**Notice: Different I2C sensors have different I2C commands set and initiate process, if user want to use other I2C sensors, User need to re-write the source code to support those sensors. SHT20/ SHT31 code in SN50v3-LB will be a good reference.** 409 409 410 -**No ACK Message**: 1: This message means this payload is fromn Uplink Message which doesn't get ACK from the server before ( for **PNACKMD=1** feature) 411 411 412 - **PollMessageFlag**:1:Thismessageis apoll messagereply.731 +Below is the connection to SHT20/ SHT31. The connection is as below: 413 413 414 - * Poll MessageFlagis set to 1.733 +[[image:image-20230610170152-2.png||height="501" width="846"]] 415 415 416 -* Each data entry is 11 bytes, to save airtime and battery, devices will send max bytes according to the current DR and Frequency bands. 417 417 418 - Forexample,inUS915band,themaxpayloadfordifferent DR is:736 +The device will be able to get the I2C sensor data now and upload to IoT Server. 419 419 420 - **a) DR0:** maxs 11bytessotryofdata738 +[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/1656379664142-345.png?rev=1.1||alt="1656379664142-345.png"]] 421 421 422 - **b)DR1:**maxis 53bytesso devices willupload4 entriesof data(total 44bytes)740 +Convert the read byte to decimal and divide it by ten. 423 423 424 -** c) DR2:** totalpayload includes 11 entries of data742 +**Example:** 425 425 426 - **d) DR3:**totalpayload includes22entries of data.744 +Temperature: Read:0116(H) = 278(D) Value: 278 /10=27.8℃; 427 427 428 - If devisedoesn'thavenydatainthepollingtime.Devicewilluplink 11 bytesof0746 +Humidity: Read:0248(H)=584(D) Value: 584 / 10=58.4, So 58.4% 429 429 748 +If you want to use other I2C device, please refer the SHT20 part source code as reference. 430 430 750 + 751 +==== 2.3.3.7 Distance Reading ==== 752 + 753 + 754 +Refer [[Ultrasonic Sensor section>>||anchor="H2.3.3.8UltrasonicSensor"]]. 755 + 756 + 757 +==== 2.3.3.8 Ultrasonic Sensor ==== 758 + 759 + 760 +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]] 761 + 762 +The SN50v3-LB 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. 763 + 764 +The working principle of this sensor is similar to the (% style="color:blue" %)**HC-SR04**(%%) ultrasonic sensor. 765 + 766 +The picture below shows the connection: 767 + 768 +[[image:image-20230512173903-6.png||height="596" width="715"]] 769 + 770 + 771 +Connect to the SN50v3-LB and run (% style="color:blue" %)**AT+MOD=2**(%%) to switch to ultrasonic mode (ULT). 772 + 773 +The ultrasonic sensor uses the 8^^th^^ and 9^^th^^ byte for the measurement value. 774 + 431 431 **Example:** 432 432 433 - If S31x-LB hasbelow datainsideFlash:777 +Distance: Read: 0C2D(Hex) = 3117(D) Value: 3117 mm=311.7 cm 434 434 435 -[[image:1682646494051-944.png]] 436 436 437 - Ifusersendsbelowdownlinkcommand: 3160065F9760066DA705780 +==== 2.3.3.9 Battery Output - BAT pin ==== 438 438 439 -Where : Start time: 60065F97 = time 21/1/19 04:27:03 440 440 441 - Stop time:60066DA7=time21/1/1905:27:03783 +The BAT pin of SN50v3-LB is connected to the Battery directly. If users want to use BAT pin to power an external sensor. User need to make sure the external sensor is of low power consumption. Because the BAT pin is always open. If the external sensor is of high power consumption. the battery of SN50v3-LB will run out very soon. 442 442 443 443 444 - **S31x-LBwilluplinkthispayload.**786 +==== 2.3.3.10 +5V Output ==== 445 445 446 -[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LHT65N%20LoRaWAN%20Temperature%20%26%20Humidity%20Sensor%20Manual/WebHome/image-20220523001219-13.png?width=727&height=421&rev=1.1||alt="图片-20220523001219-13.png" height="421" width="727"]] 447 447 448 -((( 449 -__**7FFF089801464160065F97**__ **__7FFF__ __088E__ __014B__ __41__ __60066009__** 7FFF0885014E41600660667FFF0875015141600662BE7FFF086B015541600665167FFF08660155416006676E7FFF085F015A41600669C67FFF0857015D4160066C1E 450 -))) 789 +SN50v3-LB will enable +5V output before all sampling and disable the +5v after all sampling. 451 451 452 -((( 453 -Where the first 11 bytes is for the first entry: 454 -))) 791 +The 5V output time can be controlled by AT Command. 455 455 456 -((( 457 -7FFF089801464160065F97 458 -))) 793 +(% style="color:blue" %)**AT+5VT=1000** 459 459 460 -((( 461 -**Ext sensor data**=0x7FFF/100=327.67 462 -))) 795 +Means set 5V valid time to have 1000ms. So the real 5V output will actually have 1000ms + sampling time for other sensors. 463 463 464 -((( 465 -**Temp**=0x088E/100=22.00 466 -))) 797 +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. 467 467 468 -((( 469 -**Hum**=0x014B/10=32.6 470 -))) 471 471 472 -((( 473 -**poll message flag & Ext**=0x41,means reply data,Ext=1 474 -))) 800 +==== 2.3.3.11 BH1750 Illumination Sensor ==== 475 475 476 -((( 477 -**Unix time** is 0x60066009=1611030423s=21/1/19 04:27:03 478 -))) 479 479 803 +MOD=1 support this sensor. The sensor value is in the 8^^th^^ and 9^^th^^ bytes. 480 480 481 - (% aria-label="数据 URI 图像图像小部件" 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:image/gif;base64,R0lGODlhAQABAPABAP///wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==||alt="数据 URI 图片" data-widget="image" draggable="true" height="15" role="presentation" title="单击并拖动以移动" width="15"]](% aria-label="数据 URI 图像图像小部件" 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:image/gif;base64,R0lGODlhAQABAPABAP///wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==||alt="数据 URI 图片" draggable="true" height="15" role="presentation" title="单击并拖动以移动" width="15"]](% aria-label="数据 URI 图像图像小部件" 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="单击并拖动以调整大小" %)的(% aria-label="数据 URI 图像图像小部件" 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:image/gif;base64,R0lGODlhAQABAPABAP///wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==||alt="数据 URI 图片" data-widget="image" draggable="true" height="15" role="presentation" title="单击并拖动以移动" width="15"]](% aria-label="数据 URI 图像图像小部件" 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:image/gif;base64,R0lGODlhAQABAPABAP///wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==||alt="数据 URI 图片" draggable="true"height="15"role="presentation" title="单击并拖动以移动"width="15"]](% aria-label="数据 URI 图像图像小部件" 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="单击并拖动以调整大小" %)的805 +[[image:image-20230512172447-4.png||height="416" width="712"]] 482 482 483 -== 2.6 Temperature Alarm Feature == 484 484 808 +[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/image-20220628110012-12.png?rev=1.1||alt="image-20220628110012-12.png" height="361" width="953"]] 485 485 486 -S31x-LB work flow with Alarm feature. 487 487 811 +==== 2.3.3.12 Working MOD ==== 488 488 489 -[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50v2-D20-D22-D23%20LoRaWAN%20Temperature%20Sensor%20User%20Manual/WebHome/image-20220623090437-1.png?rev=1.1||alt="图片-20220623090437-1.png"]] 490 490 814 +The working MOD info is contained in the Digital in & Digital Interrupt byte (7^^th^^ Byte). 491 491 492 - ==2.7FrequencyPlans==816 +User can use the 3^^rd^^ ~~ 7^^th^^ bit of this byte to see the working mod: 493 493 818 +Case 7^^th^^ Byte >> 2 & 0x1f: 494 494 495 -The S31x-LB uses OTAA mode and below frequency plans by default. If user want to use it with different frequency plan, please refer the AT command sets. 820 +* 0: MOD1 821 +* 1: MOD2 822 +* 2: MOD3 823 +* 3: MOD4 824 +* 4: MOD5 825 +* 5: MOD6 826 +* 6: MOD7 827 +* 7: MOD8 828 +* 8: MOD9 496 496 830 + 831 + 832 +== 2.4 Payload Decoder file == 833 + 834 + 835 +In TTN, use can add a custom payload so it shows friendly reading 836 + 837 +In the page (% style="color:#037691" %)**Applications ~-~-> Payload Formats ~-~-> Custom ~-~-> decoder**(%%) to add the decoder from: 838 + 839 +[[https:~~/~~/github.com/dragino/dragino-end-node-decoder/tree/main/SN50_v3-LB>>https://github.com/dragino/dragino-end-node-decoder/tree/main/SN50_v3-LB]] 840 + 841 + 842 +== 2.5 Frequency Plans == 843 + 844 + 845 +The SN50v3-LB uses OTAA mode and below frequency plans by default. If user want to use it with different frequency plan, please refer the AT command sets. 846 + 497 497 [[http:~~/~~/wiki.dragino.com/xwiki/bin/view/Main/End%20Device%20Frequency%20Band/>>http://wiki.dragino.com/xwiki/bin/view/Main/End%20Device%20Frequency%20Band/]] 498 498 499 499 500 -= 3. Configure S3 1x-LB =850 += 3. Configure SN50v3-LB = 501 501 502 502 == 3.1 Configure Methods == 503 503 504 504 505 -S3 1x-LB supports below configure method:855 +SN50v3-LB supports below configure method: 506 506 507 507 * AT Command via Bluetooth Connection (**Recommended**): [[BLE Configure Instruction>>http://wiki.dragino.com/xwiki/bin/view/Main/BLE%20Bluetooth%20Remote%20Configure/]]. 508 508 * AT Command via UART Connection : See [[UART Connection>>http://wiki.dragino.com/xwiki/bin/view/Main/UART%20Access%20for%20LoRa%20ST%20v4%20base%20model/#H2.3UARTConnectionforSN50v3basemotherboard]]. 509 509 * LoRaWAN Downlink. Instruction for different platforms: See [[IoT LoRaWAN Server>>http://wiki.dragino.com/xwiki/bin/view/Main/]] section. 510 510 861 + 862 + 511 511 == 3.2 General Commands == 512 512 513 513 ... ... @@ -521,10 +521,10 @@ 521 521 [[http:~~/~~/wiki.dragino.com/xwiki/bin/view/Main/End%20Device%20AT%20Commands%20and%20Downlink%20Command/>>http://wiki.dragino.com/xwiki/bin/view/Main/End%20Device%20AT%20Commands%20and%20Downlink%20Command/]] 522 522 523 523 524 -== 3.3 Commands special design for S3 1x-LB ==876 +== 3.3 Commands special design for SN50v3-LB == 525 525 526 526 527 -These commands only valid for S3 1x-LB, as below:879 +These commands only valid for SN50v3-LB, as below: 528 528 529 529 530 530 === 3.3.1 Set Transmit Interval Time === ... ... @@ -535,7 +535,7 @@ 535 535 (% style="color:blue" %)**AT Command: AT+TDC** 536 536 537 537 (% border="1" cellspacing="4" style="background-color:#f2f2f2; width:510px" %) 538 -|=(% style="width: 156px;background-color:#D9E2F3" %)**Command Example**|=(% style="width: 137px;background-color:#D9E2F3" %)**Function**|=(% style="background-color:#D9E2F3" %)**Response** 890 +|=(% style="width: 156px;background-color:#D9E2F3;color:#0070C0" %)**Command Example**|=(% style="width: 137px;background-color:#D9E2F3;color:#0070C0" %)**Function**|=(% style="background-color:#D9E2F3;color:#0070C0" %)**Response** 539 539 |(% style="width:156px" %)AT+TDC=?|(% style="width:137px" %)Show current transmit Interval|((( 540 540 30000 541 541 OK ... ... @@ -555,118 +555,170 @@ 555 555 * Example 1: Downlink Payload: 0100001E ~/~/ Set Transmit Interval (TDC) = 30 seconds 556 556 * Example 2: Downlink Payload: 0100003C ~/~/ Set Transmit Interval (TDC) = 60 seconds 557 557 910 + 911 + 558 558 === 3.3.2 Get Device Status === 559 559 560 560 561 -Send a LoRaWAN downlink to ask device send Alarmsettings.915 +Send a LoRaWAN downlink to ask the device to send its status. 562 562 563 -(% style="color:blue" %)**Downlink Payload: **(%%)0x26 01917 +(% style="color:blue" %)**Downlink Payload: 0x26 01** 564 564 565 -Sensor will upload Device Status via FPORT=5. See payload section for detail. 919 +Sensor will upload Device Status via **FPORT=5**. See payload section for detail. 566 566 567 567 568 -=== 3.3.3 Set TemperatureAlarm Threshold ===922 +=== 3.3.3 Set Interrupt Mode === 569 569 570 -* (% style="color:blue" %)**AT Command:** 571 571 572 - (%style="color:#037691"%)**AT+SHTEMP=min,max**925 +Feature, Set Interrupt mode for GPIO_EXIT. 573 573 574 -* When min=0, and max≠0, Alarm higher than max 575 -* When min≠0, and max=0, Alarm lower than min 576 -* When min≠0 and max≠0, Alarm higher than max or lower than min 927 +(% style="color:blue" %)**AT Command: AT+INTMOD1,AT+INTMOD2,AT+INTMOD3** 577 577 578 -Example: 929 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:510px" %) 930 +|=(% style="width: 155px;background-color:#D9E2F3;color:#0070C0" %)**Command Example**|=(% style="width: 197px;background-color:#D9E2F3;color:#0070C0" %)**Function**|=(% style="width: 158px;background-color:#D9E2F3;color:#0070C0" %)**Response** 931 +|(% style="width:154px" %)AT+INTMOD1=?|(% style="width:196px" %)Show current interrupt mode|(% style="width:157px" %)((( 932 +0 933 +OK 934 +the mode is 0 =Disable Interrupt 935 +))) 936 +|(% style="width:154px" %)AT+INTMOD1=2|(% style="width:196px" %)((( 937 +Set Transmit Interval 938 +0. (Disable Interrupt), 939 +~1. (Trigger by rising and falling edge) 940 +2. (Trigger by falling edge) 941 +3. (Trigger by rising edge) 942 +)))|(% style="width:157px" %)OK 943 +|(% style="width:154px" %)AT+INTMOD2=3|(% style="width:196px" %)((( 944 +Set Transmit Interval 945 +trigger by rising edge. 946 +)))|(% style="width:157px" %)OK 947 +|(% style="width:154px" %)AT+INTMOD3=0|(% style="width:196px" %)Disable Interrupt|(% style="width:157px" %)OK 579 579 580 - AT+SHTEMP=0,30 ~/~/ Alarmwhentemperature higher than30.949 +(% style="color:blue" %)**Downlink Command: 0x06** 581 581 582 - * (% style="color:blue"%)**Downlink Payload:**951 +Format: Command Code (0x06) followed by 3 bytes. 583 583 584 - (%style="color:#037691"%)**0x(0C01001E)**(%%)~/~/SetAT+SHTEMP=0,30953 +This means that the interrupt mode of the end node is set to 0x000003=3 (rising edge trigger), and the type code is 06. 585 585 586 -(% style="color:red" %)**(note: 3^^rd^^ byte= 0x00 for low limit(not set), 4^^th^^ byte = 0x1E for high limit: 30)** 955 +* Example 1: Downlink Payload: 06000000 **~-~-->** AT+INTMOD1=0 956 +* Example 2: Downlink Payload: 06000003 **~-~-->** AT+INTMOD1=3 957 +* Example 3: Downlink Payload: 06000102 **~-~-->** AT+INTMOD2=2 958 +* Example 4: Downlink Payload: 06000201 **~-~-->** AT+INTMOD3=1 587 587 588 588 589 -=== 3.3.4 Set Humidity Alarm Threshold === 590 590 591 - *(%style="color:blue"%)**AT Command:**962 +=== 3.3.4 Set Power Output Duration === 592 592 593 -(% style="color:#037691" %)**AT+SHHUM=min,max** 594 594 595 -* When min=0, and max≠0, Alarm higher than max 596 -* When min≠0, and max=0, Alarm lower than min 597 -* When min≠0 and max≠0, Alarm higher than max or lower than min 965 +Control the output duration 5V . Before each sampling, device will 598 598 599 - Example:967 +~1. first enable the power output to external sensor, 600 600 601 - AT+SHHUM=70,0~/~/ Alarmwhenhumiditylowerhan70%.969 +2. keep it on as per duration, read sensor value and construct uplink payload 602 602 603 - *(% style="color:blue"%)**DownlinkPayload:**971 +3. final, close the power output. 604 604 605 -(% style="color: #037691" %)**0x(0C02 46 00)**(%%) ~/~/ SetAT+SHTHUM=70,0973 +(% style="color:blue" %)**AT Command: AT+5VT** 606 606 607 -(% style="color:red" %)**(note: 3^^rd^^ byte= 0x46 for low limit (70%), 4^^th^^ byte = 0x00 for high limit (not set))** 975 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:510px" %) 976 +|=(% style="width: 155px;background-color:#D9E2F3;color:#0070C0" %)**Command Example**|=(% style="width: 197px;background-color:#D9E2F3;color:#0070C0" %)**Function**|=(% style="width: 158px;background-color:#D9E2F3;color:#0070C0" %)**Response** 977 +|(% style="width:154px" %)AT+5VT=?|(% style="width:196px" %)Show 5V open time.|(% style="width:157px" %)((( 978 +500(default) 979 +OK 980 +))) 981 +|(% style="width:154px" %)AT+5VT=1000|(% style="width:196px" %)((( 982 +Close after a delay of 1000 milliseconds. 983 +)))|(% style="width:157px" %)OK 608 608 985 +(% style="color:blue" %)**Downlink Command: 0x07** 609 609 610 - ===3.3.5SetAlarmInterval ===987 +Format: Command Code (0x07) followed by 2 bytes. 611 611 612 -The s hortest timeoftwoAlarm packet. (unit:min)989 +The first and second bytes are the time to turn on. 613 613 614 -* (% style="color:blue" %)**AT Command:** 991 +* Example 1: Downlink Payload: 070000 **~-~-->** AT+5VT=0 992 +* Example 2: Downlink Payload: 0701F4 **~-~-->** AT+5VT=500 615 615 616 -(% style="color:#037691" %)**AT+ATDC=30** (%%) ~/~/ The shortest interval of two Alarm packets is 30 minutes, Means is there is an alarm packet uplink, there won't be another one in the next 30 minutes. 617 617 618 -* (% style="color:blue" %)**Downlink Payload:** 619 619 620 - (% style="color:#037691"%)**0x(0D 00 1E)**(%%) **~-~--> **SetAT+ATDC=0x 00 1E = 30 minutes996 +=== 3.3.5 Set Weighing parameters === 621 621 622 622 623 - ===3.3.6GetAlarmsettings===999 +Feature: Working mode 5 is effective, weight initialization and weight factor setting of HX711. 624 624 1001 +(% style="color:blue" %)**AT Command: AT+WEIGRE,AT+WEIGAP** 625 625 626 -Send a LoRaWAN downlink to ask device send Alarm settings. 1003 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:510px" %) 1004 +|=(% style="width: 155px;background-color:#D9E2F3;color:#0070C0" %)**Command Example**|=(% style="width: 197px;background-color:#D9E2F3;color:#0070C0" %)**Function**|=(% style="width: 158px;background-color:#D9E2F3;color:#0070C0" %)**Response** 1005 +|(% style="width:154px" %)AT+WEIGRE|(% style="width:196px" %)Weight is initialized to 0.|(% style="width:157px" %)OK 1006 +|(% style="width:154px" %)AT+WEIGAP=?|(% style="width:196px" %)400.0|(% style="width:157px" %)OK(default) 1007 +|(% style="width:154px" %)AT+WEIGAP=400.3|(% style="width:196px" %)Set the factor to 400.3.|(% style="width:157px" %)OK 627 627 628 - *(% style="color:#037691" %)**DownlinkPayload:**(%%)0x0E 011009 +(% style="color:blue" %)**Downlink Command: 0x08** 629 629 630 - **Example:**1011 +Format: Command Code (0x08) followed by 2 bytes or 4 bytes. 631 631 632 - [[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50v2-D20-D22-D23%20LoRaWAN%20Temperature%20Sensor%20User%20Manual/WebHome/1655948182791-225.png?rev=1.1||alt="1655948182791-225.png"]]1013 +Use AT+WEIGRE when the first byte is 1, only 1 byte. When it is 2, use AT+WEIGAP, there are 3 bytes. 633 633 1015 +The second and third bytes are multiplied by 10 times to be the AT+WEIGAP value. 634 634 635 -**Explain:** 1017 +* Example 1: Downlink Payload: 0801 **~-~-->** AT+WEIGRE 1018 +* Example 2: Downlink Payload: 08020FA3 **~-~-->** AT+WEIGAP=400.3 1019 +* Example 3: Downlink Payload: 08020FA0 **~-~-->** AT+WEIGAP=400.0 636 636 637 -* Alarm & MOD bit is 0x7C, 0x7C >> 2 = 0x31: Means this message is the Alarm settings message. 638 638 639 -=== 3.3.7 Set Interrupt Mode === 640 640 1023 +=== 3.3.6 Set Digital pulse count value === 641 641 642 -Feature, Set Interrupt mode for GPIO_EXIT. 643 643 644 - (% style="color:blue"%)**ATCommand:AT+INTMOD**1026 +Feature: Set the pulse count value. 645 645 1028 +Count 1 is PA8 pin of mode 6 and mode 9. Count 2 is PA4 pin of mode 9. 1029 + 1030 +(% style="color:blue" %)**AT Command: AT+SETCNT** 1031 + 646 646 (% border="1" cellspacing="4" style="background-color:#f2f2f2; width:510px" %) 647 -|=(% style="width: 154px;background-color:#D9E2F3" %)**Command Example**|=(% style="width: 196px;background-color:#D9E2F3" %)**Function**|=(% style="width: 157px;background-color:#D9E2F3" %)**Response** 648 -|(% style="width:154px" %)AT+INTMOD=?|(% style="width:196px" %)Show current interrupt mode|(% style="width:157px" %)((( 649 -0 1033 +|=(% style="width: 155px;background-color:#D9E2F3;color:#0070C0" %)**Command Example**|=(% style="width: 197px;background-color:#D9E2F3;color:#0070C0" %)**Function**|=(% style="width: 158px;background-color:#D9E2F3;color:#0070C0" %)**Response** 1034 +|(% style="width:154px" %)AT+SETCNT=1,100|(% style="width:196px" %)Initialize the count value 1 to 100.|(% style="width:157px" %)OK 1035 +|(% style="width:154px" %)AT+SETCNT=2,0|(% style="width:196px" %)Initialize the count value 2 to 0.|(% style="width:157px" %)OK 1036 + 1037 +(% style="color:blue" %)**Downlink Command: 0x09** 1038 + 1039 +Format: Command Code (0x09) followed by 5 bytes. 1040 + 1041 +The first byte is to select which count value to initialize, and the next four bytes are the count value to be initialized. 1042 + 1043 +* Example 1: Downlink Payload: 090100000000 **~-~-->** AT+SETCNT=1,0 1044 +* Example 2: Downlink Payload: 0902000003E8 **~-~-->** AT+SETCNT=2,1000 1045 + 1046 + 1047 + 1048 +=== 3.3.7 Set Workmode === 1049 + 1050 + 1051 +Feature: Switch working mode. 1052 + 1053 +(% style="color:blue" %)**AT Command: AT+MOD** 1054 + 1055 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:510px" %) 1056 +|=(% style="width: 155px;background-color:#D9E2F3;color:#0070C0" %)**Command Example**|=(% style="width: 197px;background-color:#D9E2F3;color:#0070C0" %)**Function**|=(% style="width: 158px;background-color:#D9E2F3;color:#0070C0" %)**Response** 1057 +|(% style="width:154px" %)AT+MOD=?|(% style="width:196px" %)Get the current working mode.|(% style="width:157px" %)((( 650 650 OK 651 -the mode is 0 =Disable Interrupt 652 652 ))) 653 -|(% style="width:154px" %)AT+INTMOD=2|(% style="width:196px" %)((( 654 -Set Transmit Interval 655 -0. (Disable Interrupt), 656 -~1. (Trigger by rising and falling edge) 657 -2. (Trigger by falling edge) 658 -3. (Trigger by rising edge) 659 -)))|(% style="width:157px" %)OK 1060 +|(% style="width:154px" %)AT+MOD=4|(% style="width:196px" %)Set the working mode to 3DS18B20s.|(% style="width:157px" %)((( 1061 +OK 1062 +Attention:Take effect after ATZ 1063 +))) 660 660 661 -(% style="color:blue" %)**Downlink Command: 0x0 6**1065 +(% style="color:blue" %)**Downlink Command: 0x0A** 662 662 663 -Format: Command Code (0x0 6) followed by3bytes.1067 +Format: Command Code (0x0A) followed by 1 bytes. 664 664 665 -This means that the interrupt mode of the end node is set to 0x000003=3 (rising edge trigger), and the type code is 06. 1069 +* Example 1: Downlink Payload: 0A01 **~-~-->** AT+MOD=1 1070 +* Example 2: Downlink Payload: 0A04 **~-~-->** AT+MOD=4 666 666 667 -* Example 1: Downlink Payload: 06000000 ~/~/ Turn off interrupt mode 668 -* Example 2: Downlink Payload: 06000003 ~/~/ Set the interrupt mode to rising edge trigger 669 669 1073 + 670 670 = 4. Battery & Power Consumption = 671 671 672 672 ... ... @@ -679,24 +679,47 @@ 679 679 680 680 681 681 (% class="wikigeneratedid" %) 682 -User can change firmware SN50v3-LB to: 1086 +**User can change firmware SN50v3-LB to:** 683 683 684 684 * Change Frequency band/ region. 685 685 * Update with new features. 686 686 * Fix bugs. 687 687 688 -Firmware and changelog can be downloaded from : **[[Firmware download link>> url:https://www.dropbox.com/sh/kwqv57tp6pejias/AAAopYMATh1GM6fZ-VRCLrpDa?dl=0]]**1092 +**Firmware and changelog can be downloaded from :** **[[Firmware download link>>https://www.dropbox.com/sh/4rov7bcp6u28exp/AACt-wAySd4si5AXi8DBmvSca?dl=0]]** 689 689 1094 +**Methods to Update Firmware:** 690 690 691 -Methods to Update Firmware: 1096 +* (Recommanded way) OTA firmware update via wireless: **[[http:~~/~~/wiki.dragino.com/xwiki/bin/view/Main/Firmware%20OTA%20Update%20for%20Sensors/>>url:http://wiki.dragino.com/xwiki/bin/view/Main/Firmware%20OTA%20Update%20for%20Sensors/]]** 1097 +* Update through UART TTL interface: **[[Instruction>>url:http://wiki.dragino.com/xwiki/bin/view/Main/UART%20Access%20for%20LoRa%20ST%20v4%20base%20model/#H1.LoRaSTv4baseHardware]]**. 692 692 693 -* (Recommanded way) OTA firmware update via wireless: [[http:~~/~~/wiki.dragino.com/xwiki/bin/view/Main/Firmware%20OTA%20Update%20for%20Sensors/>>url:http://wiki.dragino.com/xwiki/bin/view/Main/Firmware%20OTA%20Update%20for%20Sensors/]] 694 -* Update through UART TTL interface.**[[Instruction>>url:http://wiki.dragino.com/xwiki/bin/view/Main/UART%20Access%20for%20LoRa%20ST%20v4%20base%20model/#H1.LoRaSTv4baseHardware]]**. 695 695 1100 + 696 696 = 6. FAQ = 697 697 1103 +== 6.1 Where can i find source code of SN50v3-LB? == 698 698 699 699 1106 +* **[[Hardware Source Files>>https://github.com/dragino/Lora/tree/master/LSN50/v3.0]].** 1107 +* **[[Software Source Code & Compile instruction>>https://github.com/dragino/SN50v3]].** 1108 + 1109 + 1110 + 1111 +== 6.2 How to generate PWM Output in SN50v3-LB? == 1112 + 1113 + 1114 +See this document: **[[Generate PWM Output on SN50v3>>https://www.dropbox.com/scl/fi/r3trcet2knujg40w0mgyn/Generate-PWM-Output-on-SN50v3.pdf?rlkey=rxsgmrhhrv62iiiwjq9sv10bn&dl=0]]**. 1115 + 1116 + 1117 +== 6.3 How to put several sensors to a SN50v3-LB? == 1118 + 1119 + 1120 +When we want to put several sensors to A SN50v3-LB, the waterproof at the grand connector will become an issue. User can try to exchange the grand connector to below type. 1121 + 1122 +[[Reference Supplier>>https://www.yscableglands.com/cable-glands/nylon-cable-glands/cable-gland-rubber-seal.html]]. 1123 + 1124 +[[image:image-20230810121434-1.png||height="242" width="656"]] 1125 + 1126 + 700 700 = 7. Order Info = 701 701 702 702 ... ... @@ -720,8 +720,11 @@ 720 720 * (% style="color:red" %)**20**(%%): With M20 waterproof cable hole 721 721 * (% style="color:red" %)**NH**(%%): No Hole 722 722 1150 + 1151 + 723 723 = 8. Packing Info = 724 724 1154 + 725 725 (% style="color:#037691" %)**Package Includes**: 726 726 727 727 * SN50v3-LB LoRaWAN Generic Node ... ... @@ -733,8 +733,11 @@ 733 733 * Package Size / pcs : cm 734 734 * Weight / pcs : g 735 735 1166 + 1167 + 736 736 = 9. Support = 737 737 738 738 739 739 * 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. 740 -* 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]] 1172 + 1173 +* Provide as much information as possible regarding your enquiry (product models, accurately describe your problem and steps to replicate it etc) and send a mail to [[support@dragino.cc>>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.cc]]
- image-20230512163509-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +1.5 MB - Content
- image-20230512164658-2.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +2.0 MB - Content
- image-20230512170701-3.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +2.5 MB - Content
- image-20230512172447-4.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +2.0 MB - Content
- image-20230512173758-5.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +2.1 MB - Content
- image-20230512173903-6.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +2.3 MB - Content
- image-20230512180609-7.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +2.3 MB - Content
- image-20230512180718-8.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +2.3 MB - Content
- image-20230512181814-9.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +2.2 MB - Content
- image-20230513084523-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +611.3 KB - Content
- image-20230513102034-2.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +607.1 KB - Content
- image-20230513103633-3.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +595.5 KB - Content
- image-20230513105207-4.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +384.7 KB - Content
- image-20230513105351-5.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +37.6 KB - Content
- image-20230513110214-6.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +172.7 KB - Content
- image-20230513111203-7.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +79.9 KB - Content
- image-20230513111231-8.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +64.9 KB - Content
- image-20230513111255-9.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +70.4 KB - Content
- image-20230513134006-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +1.9 MB - Content
- image-20230515135611-1.jpeg
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Xiaoling - Size
-
... ... @@ -1,0 +1,1 @@ 1 +948.0 KB - Content
- image-20230610162852-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +695.7 KB - Content
- image-20230610163213-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +695.4 KB - Content
- image-20230610170047-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +444.9 KB - Content
- image-20230610170152-2.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +359.5 KB - Content
- image-20230810121434-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Edwin - Size
-
... ... @@ -1,0 +1,1 @@ 1 +137.3 KB - Content
- image-20230811113449-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +973.1 KB - Content
- image-20230817170702-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +39.6 KB - Content
- image-20230817172209-2.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +1.3 MB - Content
- image-20230817173800-3.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +1.1 MB - Content
- image-20230817173830-4.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +508.5 KB - Content
- image-20230817173858-5.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Saxer - Size
-
... ... @@ -1,0 +1,1 @@ 1 +1.6 MB - Content