Changes for page SDI-12-LB/LS -- SDI-12 to LoRaWAN Converter User Manual
Last modified by Mengting Qiu on 2025/07/03 15:42
From version 43.1
edited by Bei Jinggeng
on 2023/02/22 14:42
on 2023/02/22 14:42
Change comment:
There is no comment for this version
Summary
-
Page properties (2 modified, 0 added, 0 removed)
-
Attachments (0 modified, 0 added, 7 removed)
Details
- Page properties
-
- Author
-
... ... @@ -1,1 +1,1 @@ 1 -XWiki. Bei1 +XWiki.Xiaoling - Content
-
... ... @@ -3,7 +3,6 @@ 3 3 4 4 **Table of Contents:** 5 5 6 -{{toc/}} 7 7 8 8 9 9 ... ... @@ -22,40 +22,32 @@ 22 22 == 1.1 What is SDI-12 to LoRaWAN Converter == 23 23 24 24 25 -((( 26 -The Dragino (% style="color:blue" %)**SDI-12-LB**(%%) is a (% style="color:blue" %)**SDI-12 to LoRaWAN Converter **(%%)designed for Smart Agriculture solution. 27 -))) 24 +The Dragino **SDI-12-LB** is a **SDI-12 to LoRaWAN Converter **designed for Smart Agriculture solution. 28 28 29 -((( 30 30 SDI-12 (Serial Digital Interface at 1200 baud) is an asynchronous [[serial communications>>url:https://en.wikipedia.org/wiki/Serial_communication]] protocol for intelligent sensors that monitor environment data. SDI-12 protocol is widely used in Agriculture sensor and Weather Station sensors. 31 -))) 32 32 33 -((( 34 -SDI-12-LB has SDI-12 interface and support 12v output to power external SDI-12 sensor. It can get the environment data from SDI-12 sensor and sends out the data via LoRaWAN wireless protocol. 35 -))) 28 +**SDI-12-LB** has SDI-12 interface and support 12v output to power external SDI-12 sensor. It can get the environment data from SDI-12 sensor and sends out the data via LoRaWAN wireless protocol. 36 36 37 -((( 38 -The LoRa wireless technology used in SDI-12-LB allows device 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. 39 -))) 30 +The LoRa wireless technology used in **SDI-12-LB** allows device 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. 40 40 41 -((( 42 -SDI-12-LB is powered by (% style="color:blue" %)**8500mAh Li-SOCI2 battery**(%%), it is designed for long term use up to 5 years. 43 -))) 32 +**SDI-12-LB** is powered by **8500mAh Li-SOCI2 battery**, it is designed for long term use up to 5 years. 44 44 45 -((( 46 -Each SDI-12-LB is pre-load with a set of unique keys for LoRaWAN registrations, register these keys to local LoRaWAN server and it will auto connect after power on. 47 -))) 34 +Each **SDI-12-LB** is pre-load with a set of unique keys for LoRaWAN registrations, register these keys to local LoRaWAN server and it will auto connect after power on. 48 48 49 49 50 50 [[image:image-20230201084414-1.png||height="464" width="1108"]] 51 51 52 52 40 + 41 + 42 + 43 + 53 53 == 1.2 Features == 54 54 55 55 56 56 * LoRaWAN 1.0.3 Class A 57 57 * Ultra-low power consumption 58 -* Controllable 3.3v,5v and 12v output to power external sensor49 +* Controllable 5v and 12v output to power external sensor 59 59 * SDI-12 Protocol to connect to SDI-12 Sensor 60 60 * Monitor Battery Level 61 61 * Bands: CN470/EU433/KR920/US915/EU868/AS923/AU915/IN865 ... ... @@ -65,22 +65,21 @@ 65 65 * Downlink to change configure 66 66 * 8500mAh Battery for long term use 67 67 68 - 69 69 == 1.3 Specification == 70 70 71 71 72 - (% style="color:#037691" %)**Micro Controller:**62 +**Micro Controller:** 73 73 74 74 * MCU: 48Mhz ARM 75 75 * Flash: 256KB 76 76 * RAM: 64KB 77 77 78 - (% style="color:#037691" %)**Common DC Characteristics:**68 +**Common DC Characteristics:** 79 79 80 80 * Supply Voltage: 2.5v ~~ 3.6v 81 81 * Operating Temperature: -40 ~~ 85°C 82 82 83 - (% style="color:#037691" %)**LoRa Spec:**73 +**LoRa Spec:** 84 84 85 85 * Frequency Range, Band 1 (HF): 862 ~~ 1020 Mhz 86 86 * Max +22 dBm constant RF output vs. ... ... @@ -87,19 +87,19 @@ 87 87 * RX sensitivity: down to -139 dBm. 88 88 * Excellent blocking immunity 89 89 90 - (% style="color:#037691" %)**Current Input Measuring :**80 +**Current Input Measuring :** 91 91 92 92 * Range: 0 ~~ 20mA 93 93 * Accuracy: 0.02mA 94 94 * Resolution: 0.001mA 95 95 96 - (% style="color:#037691" %)**Voltage Input Measuring:**86 +**Voltage Input Measuring:** 97 97 98 98 * Range: 0 ~~ 30v 99 99 * Accuracy: 0.02v 100 100 * Resolution: 0.001v 101 101 102 - (% style="color:#037691" %)**Battery:**92 +**Battery:** 103 103 104 104 * Li/SOCI2 un-chargeable battery 105 105 * Capacity: 8500mAh ... ... @@ -107,12 +107,11 @@ 107 107 * Max continuously current: 130mA 108 108 * Max boost current: 2A, 1 second 109 109 110 - (% style="color:#037691" %)**Power Consumption**100 +**Power Consumption** 111 111 112 112 * Sleep Mode: 5uA @ 3.3v 113 113 * LoRa Transmit Mode: 125mA @ 20dBm, 82mA @ 14dBm 114 114 115 - 116 116 == 1.4 Connect to SDI-12 Sensor == 117 117 118 118 ... ... @@ -123,9 +123,9 @@ 123 123 == 1.5 Sleep mode and working mode == 124 124 125 125 126 - (% 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.115 +**Deep Sleep Mode: **Sensor doesn't have any LoRaWAN activate. This mode is used for storage and shipping to save battery life. 127 127 128 - (% 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.117 +**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. 129 129 130 130 131 131 == 1.6 Button & LEDs == ... ... @@ -134,20 +134,20 @@ 134 134 [[image:1675212633011-651.png]] 135 135 136 136 126 + 137 137 (% border="1" cellspacing="4" style="background-color:#f7faff; color:black; width:510px" %) 138 -|=(% style="width: 167px;" %)**Behavior on ACT**|=(% style="width: 1 09px;" %)**Function**|=(% style="width: 231px;" %)**Action**139 -|(% style="width:167px" %)Pressing ACT between 1s < time < 3s|(% style="width:1 09px" %)Send an uplink|(% style="width:231px" %)(((128 +|=(% style="width: 167px;" %)**Behavior on ACT**|=(% style="width: 117px;" %)**Function**|=(% style="width: 225px;" %)**Action** 129 +|(% style="width:167px" %)Pressing ACT between 1s < time < 3s|(% style="width:117px" %)Send an uplink|(% style="width:225px" %)((( 140 140 If sensor is already Joined to LoRaWAN network, sensor will send an uplink packet, (% style="color:blue" %)**blue led** (%%)will blink once. 141 141 Meanwhile, BLE module will be active and user can connect via BLE to configure device. 142 142 ))) 143 -|(% style="width:167px" %)Pressing ACT for more than 3s|(% style="width:1 09px" %)Active Device|(% style="width:231px" %)(((133 +|(% style="width:167px" %)Pressing ACT for more than 3s|(% style="width:117px" %)Active Device|(% style="width:225px" %)((( 144 144 (% style="color:green" %)**Green led**(%%) will fast blink 5 times, device will enter (% style="color:#037691" %)**OTA mode**(%%) for 3 seconds. And then start to JOIN LoRaWAN network. 145 145 (% style="color:green" %)**Green led**(%%) will solidly turn on for 5 seconds after joined in network. 146 146 Once sensor is active, BLE module will be active and user can connect via BLE to configure device, no matter if device join or not join LoRaWAN network. 147 147 ))) 148 -|(% style="width:167px" %)Fast press ACT 5 times.|(% style="width:1 09px" %)Deactivate Device|(% style="width:231px" %)(% style="color:red" %)**Red led**(%%) will solid on for 5 seconds. Means SDI-12-LB is in Deep Sleep Mode.138 +|(% 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 PS-LB is in Deep Sleep Mode. 149 149 150 - 151 151 == 1.7 Pin Mapping == 152 152 153 153 ... ... @@ -171,6 +171,9 @@ 171 171 == 1.9 Mechanical == 172 172 173 173 163 + 164 + 165 + 174 174 [[image:image-20230201090139-2.png]] 175 175 176 176 [[image:image-20230201090139-3.png]] ... ... @@ -183,7 +183,7 @@ 183 183 == 2.1 How it works == 184 184 185 185 186 -The SDI-12-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 activate the SDI-12-LB. It will automatically join the network via OTAA and start to send the sensor value. The default uplink interval is 20 minutes.178 +The SDI-12-LB 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 need to input the OTAA keys in the LoRaWAN IoT server and activate the SDI-12-LB. It will automatically join the network via OTAA and start to send the sensor value. The default uplink interval is 20 minutes. 187 187 188 188 189 189 == 2.2 Quick guide to connect to LoRaWAN server (OTAA) == ... ... @@ -198,47 +198,51 @@ 198 198 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. 199 199 200 200 201 - (% style="color:blue" %)**Step 1**(%%): Create a device in TTN with the OTAA keys from SDI-12-LB.193 +**Step 1**: Create a device in TTN with the OTAA keys from SDI-12-LB. 202 202 203 203 Each SDI-12-LB is shipped with a sticker with the default device EUI as below: 204 204 205 205 206 -[[image:image-20230 201152430-20.jpeg]]198 +[[image:image-20230131134744-2.jpeg]] 207 207 208 208 201 + 202 + 203 + 209 209 You can enter this key in the LoRaWAN Server portal. Below is TTN screen shot: 210 210 211 211 212 - (% style="color:blue" %)**Register the device**207 +**Register the device** 213 213 214 214 [[image:1675213652444-622.png]] 215 215 216 216 217 - (% style="color:blue" %)**Add APP EUI and DEV EUI**212 +**Add APP EUI and DEV EUI** 218 218 219 219 220 220 [[image:1675213661769-223.png]] 221 221 222 222 223 - (% style="color:blue" %)**Add APP EUI in the application**218 +**Add APP EUI in the application** 224 224 225 225 226 226 [[image:1675213675852-577.png]] 227 227 228 228 229 - (% style="color:blue" %)**Add APP KEY**224 +**Add APP KEY** 230 230 231 231 [[image:1675213686734-883.png]] 232 232 233 233 234 - (% style="color:blue" %)**Step 2**(%%): Activate on SDI-12-LB229 +**Step 2**: Activate on SDI-12-LB 235 235 236 236 237 237 Press the button for 5 seconds to activate the SDI-12-LB. 238 238 239 -(% style="color:green" %)**Green led**(%%) will fast blink 5 times, device will enter (% style="color:blue" %)**OTA mode** (%%)for 3 seconds. And then start to JOIN LoRaWAN network. (% style="color:green" %)**Green led**(%%) will solidly turn on for 5 seconds after joined in network. 240 240 235 +**Green led** will fast blink 5 times, device will enter **OTA mode** for 3 seconds. And then start to JOIN LoRaWAN network. **Green led** will solidly turn on for 5 seconds after joined in network. 241 241 237 + 242 242 [[image:1675213704414-644.png]] 243 243 244 244 ... ... @@ -258,6 +258,7 @@ 258 258 The following is the display information on the serial port and the server. 259 259 260 260 257 + 261 261 [[image:image-20230201091027-6.png]] 262 262 263 263 ... ... @@ -264,16 +264,15 @@ 264 264 [[image:image-20230201091027-7.png||height="261" width="1179"]] 265 265 266 266 264 +==== **al! ~-~- Get SDI-12 sensor Identification** ==== 267 267 268 -==== (% style="color:blue" %)**al! ~-~- Get SDI-12 sensor Identification**(%%) ==== 269 269 270 - 271 271 * AT Command: AT+ADDRI=aa 272 272 * LoRaWAN Downlink(prefix 0xAA00): AA 00 aa 273 273 274 - (% style="color:#037691" %)**Parameter: **(%%)aa: ASCII value of SDI-12 sensor address in downlink or HEX value in AT Command)270 +**Parameter: **aa: ASCII value of SDI-12 sensor address in downlink or HEX value in AT Command) 275 275 276 - (% style="color:blue" %)**Example :(%%)AT+ADDRI=0 ( Equal to downlink: 0x AA 00 30)272 +**Example : **AT+ADDRI=0 ( Equal to downlink: 0x AA 00 30) 277 277 278 278 279 279 The following is the display information on the serial port and the server. ... ... @@ -285,31 +285,30 @@ 285 285 [[image:image-20230201091257-9.png||height="225" width="1242"]] 286 286 287 287 288 -==== (% style="color:blue" %)**aM!,aMC!, aM1!- aM9!, aMC1!- aMC9!**(%%)====284 +==== **aM!,aMC!, aM1!- aM9!, aMC1!- aMC9!** ==== 289 289 290 290 291 - (% style="color:red" %)**aM! **(%%): Start Non-Concurrent Measurement287 +**aM! **: Start Non-Concurrent Measurement 292 292 293 - (% style="color:red" %)**aMC! **(%%): Start Non-Concurrent Measurement – Request CRC289 +**aMC! **: Start Non-Concurrent Measurement – Request CRC 294 294 295 - (% style="color:red" %)**aM1!- aM9! **(%%): Additional Measurements291 +**aM1!- aM9! **: Additional Measurements 296 296 297 - (% style="color:red" %)**aMC1!- aMC9!**(%%): Additional Measurements – Request CRC293 +**aMC1!- aMC9!** : Additional Measurements – Request CRC 298 298 299 299 300 300 * AT Command : AT+ADDRM=0,1,0,1 301 - 302 302 * LoRaWAN Downlink(prefix 0xAA01): 0xAA 01 30 01 00 01 303 303 304 304 Downlink:AA 01 aa bb cc dd 305 305 306 - (% style="color:#037691" %)**aa**(%%): SDI-12 sensor address.301 +**aa**: SDI-12 sensor address. 307 307 308 - (% style="color:#037691" %)**bb**(%%): 0: no CRC, 1: request CRC303 +**bb**: 0: no CRC, 1: request CRC 309 309 310 - (% style="color:#037691" %)**cc**(%%): 1-9: Additional Measurement, 0: no additional measurement305 +**cc**: 1-9: Additional Measurement, 0: no additional measurement 311 311 312 - (% style="color:#037691" %)**dd**(%%): delay (in second) to send(% style="color:#037691" %)__**aD0!**__(%%)to get return.307 +**dd**: delay (in second) to send **aD0!** to get return. 313 313 314 314 315 315 The following is the display information on the serial port and the server. ... ... @@ -322,16 +322,16 @@ 322 322 323 323 324 324 325 -==== (% style="color:blue" %)**aC!, aCC!, aC1!- aC9!, aCC1!- aCC9! **(%%)====320 +==== **aC!, aCC!, aC1!- aC9!, aCC1!- aCC9! ** ==== 326 326 327 327 328 - (% style="color:red" %)**aC!**(%%): Start Concurrent Measurement323 +**aC!** : Start Concurrent Measurement 329 329 330 - (% style="color:red" %)**aCC!**(%%): Start Concurrent Measurement – Request CRC325 +**aCC!** : Start Concurrent Measurement – Request CRC 331 331 332 - (% style="color:red" %)**aC1!- aC9!**(%%): Start Additional Concurrent Measurements327 +**aC1!- aC9!** : Start Additional Concurrent Measurements 333 333 334 - (% style="color:red" %)**aCC1!- aCC9!**(%%): Start Additional Concurrent Measurements – Request CRC329 +**aCC1!- aCC9!** : Start Additional Concurrent Measurements – Request CRC 335 335 336 336 337 337 * AT Command : AT+ADDRC=0,1,0,1 ... ... @@ -340,13 +340,13 @@ 340 340 341 341 Downlink: AA 02 aa bb cc dd 342 342 343 - (% style="color:#037691" %)**aa**(%%): SDI-12 sensor address.338 +**aa**: SDI-12 sensor address. 344 344 345 - (% style="color:#037691" %)**bb**(%%): 0: no CRC, 1: request CRC340 +**bb**: 0: no CRC, 1: request CRC 346 346 347 - (% style="color:#037691" %)**cc**(%%): 1-9: Additional Measurement, 0: no additional measurement342 +**cc**: 1-9: Additional Measurement, 0: no additional measurement 348 348 349 - (% style="color:#037691" %)**dd**(%%): delay (in second) to send(% style="color:#037691" %)__**aD0!**__(%%)____to get return.344 +**dd**: delay (in second) to send **aD0!** to get return. 350 350 351 351 352 352 The following is the display information on the serial port and the server. ... ... @@ -358,11 +358,11 @@ 358 358 [[image:image-20230201091954-13.png||height="203" width="1117"]] 359 359 360 360 356 +(% style="display:none" %) (%%) 361 361 358 +==== **aR0!- aR9!, aRC0!- aRC9!** ==== 362 362 363 -==== (% style="color:blue" %)**aR0!- aR9!, aRC0!- aRC9!**(%%) ==== 364 364 365 - 366 366 Start Continuous Measurement 367 367 368 368 Start Continuous Measurement – Request CRC ... ... @@ -373,18 +373,19 @@ 373 373 374 374 Downlink: AA 03 aa bb cc dd 375 375 376 - (% style="color:#037691" %)**aa**(%%): SDI-12 sensor address.371 +**aa**: SDI-12 sensor address. 377 377 378 - (% style="color:#037691" %)**bb**(%%): 0: no CRC, 1: request CRC373 +**bb**: 0: no CRC, 1: request CRC 379 379 380 - (% style="color:#037691" %)**cc**(%%): 1-9: Additional Measurement, 0: no additional measurement375 +**cc**: 1-9: Additional Measurement, 0: no additional measurement 381 381 382 - (% style="color:#037691" %)**dd**(%%): delay (in second) to send(% style="color:#037691" %)__**aD0!**__(%%)to get return.377 +**dd**: delay (in second) to send **aD0!** to get return. 383 383 384 384 385 385 The following is the display information on the serial port and the server. 386 386 387 387 383 + 388 388 [[image:image-20230201092208-14.png]] 389 389 390 390 ... ... @@ -391,7 +391,7 @@ 391 391 [[image:image-20230201092208-15.png||height="214" width="1140"]] 392 392 393 393 394 -=== 2.3.2 Advance SDI-12 Debug command === 390 +=== 2.3.2 Advance SDI-12 Debug command === 395 395 396 396 397 397 This command can be used to debug all SDI-12 command. ... ... @@ -399,20 +399,20 @@ 399 399 400 400 LoRaWAN Downlink: A8 aa xx xx xx xx bb cc 401 401 402 - (% style="color:#037691" %)**aa **(%%): total SDI-12 command length398 +**aa **: total SDI-12 command length 403 403 404 - (% style="color:#037691" %)**xx **(%%): SDI-12 command400 +**xx **: SDI-12 command 405 405 406 - (% style="color:#037691" %)**bb **(%%): Delay to wait for return402 +**bb **: Delay to wait for return 407 407 408 - (% style="color:#037691" %)**cc **(%%): 0: don't uplink return to LoRaWAN, 1: Uplink return to LoRaWAN on FPORT=100404 +**cc **: 0: don't uplink return to LoRaWAN, 1: Uplink return to LoRaWAN on FPORT=100 409 409 410 410 411 - (% style="color:blue" %)**Example: **(%%)AT+CFGDEV =0RC0!,1407 +**Example: **AT+CFGDEV =0RC0!,1 412 412 413 - (% style="color:#037691" %)**0RC0! **(%%): SDI-12 Command,409 +**0RC0! **: SDI-12 Command, 414 414 415 - (% style="color:#037691" %)**1 **(%%): Delay 1 second. ( 0: 810 mini-second)411 +**1 **: Delay 1 second. ( 0: 810 mini-second) 416 416 417 417 Equal Downlink: 0xA8 05 30 52 43 30 21 01 01 418 418 ... ... @@ -423,9 +423,11 @@ 423 423 [[image:image-20230201092355-16.png]] 424 424 425 425 426 -[[image:image-20230201092355-17.png||height="426" width="1135"]] 422 +[[image:image-20230201092355-17.png||height="426" width="1135"]] 427 427 428 428 425 + 426 + 429 429 === 2.3.3 Convert ASCII to String === 430 430 431 431 ... ... @@ -434,7 +434,7 @@ 434 434 AT+CONVFORM ( Max length: 80 bytes) 435 435 436 436 437 - (% style="color:blue" %)**Example:**435 +**Example:** 438 438 439 439 1) AT+CONVFORM=0, string Convert String from String to ASCII 440 440 ... ... @@ -446,6 +446,10 @@ 446 446 [[image:1675214856590-846.png]] 447 447 448 448 447 + 448 + 449 + 450 + 449 449 === 2.3.4 Define periodically SDI-12 commands and uplink. === 450 450 451 451 ... ... @@ -454,31 +454,31 @@ 454 454 User can define max 15 SDI-12 Commands (AT+COMMAND1 ~~ AT+COMMANDF). On each uplink period (TDC time, default 20 minutes), SDI-12-LB will send these SDI-12 commands and wait for return from SDI-12 sensors. SDI-12-LB will then combine these returns and uplink via LoRaWAN. 455 455 456 456 457 -* (% style="color:blue" %)**AT Command:**459 +* ** AT Command:** 458 458 459 - (% style="color:#037691" %)**AT+COMMANDx=var1,var2,var3,var4.**461 +**AT+COMMANDx=var1,var2,var3,var4.** 460 460 461 - (% style="color:red" %)**var1**(%%): SDI-12 command , for example: 0RC0!463 +**var1**: SDI-12 command , for example: 0RC0! 462 462 463 - (% style="color:red" %)**var2**(%%): Wait timeout for return. (unit: second)465 +**var2**: Wait timeout for return. (unit: second) 464 464 465 - (% style="color:red" %)**var3**(%%): Whether to send //addrD0!// to get return after var2 timeout. 0: Don't Send //addrD0! //; 1: Send //addrD0!//.467 +**var3**: Whether to send //addrD0!// to get return after var2 timeout. 0: Don't Send //addrD0! //; 1: Send //addrD0!//. 466 466 467 - (% style="color:red" %)**var4**(%%): validation check for return. If return invalid, SDI-12-LB will resend this command. Max4retries.469 +**var4**: validation check for return. If return invalid, SDI-12-LB will resend this command. Max 2 retries. 468 468 469 - (% style="color:red" %)**0 **(%%)No validation check;471 +**0 ** No validation check; 470 470 471 - (% style="color:red" %)**1**(%%)Check if return chars are printable char(0x20 ~~ 0x7E);473 +**1** Check if return chars are printable char(0x20 ~~ 0x7E); 472 472 473 - (% style="color:red" %)**2**(%%)Check if there is return from SDI-12 sensor475 +**2** Check if there is return from SDI-12 sensor 474 474 475 - (% style="color:red" %)**3**(%%)Check if return pass CRC check ( SDI-12 command var1 must include CRC request);477 +**3** Check if return pass CRC check ( SDI-12 command var1 must include CRC request); 476 476 477 477 478 -Each AT+COMMANDx is followed by a (% style="color:blue" %)**AT+DATACUT**(%%)command. AT+DATACUT command is used to take the useful string from the SDI-12 sensor so the final payload will have the minimum length to uplink.480 +Each AT+COMMANDx is followed by a **AT+DATACUT** command. AT+DATACUT command is used to take the useful string from the SDI-12 sensor so the final payload will have the minimum length to uplink. 479 479 480 480 481 - (% style="color:blue" %)**AT+DATACUTx**(%%): This command defines how to handle the return from AT+COMMANDx, max return length is 100 bytes.483 +**AT+DATACUTx** : This command defines how to handle the return from AT+COMMANDx, max return length is 100 bytes. 482 482 483 483 (% border="1" style="background-color:#f7faff; width:436px" %) 484 484 |(% style="width:433px" %)((( ... ... @@ -486,64 +486,64 @@ 486 486 487 487 **a**: length for the return of AT+COMMAND 488 488 489 -**b**: 491 +**b**: 1: grab valid value by byte, max 6 bytes. 2: grab valid value by bytes section, max 3 sections. 490 490 491 491 **c**: define the position for valid value. 492 492 ))) 493 493 494 -For example, if return from AT+COMMAND1 is “013METER TER12 112T12-00024895 <CR><LF>” , Below AT+DATACUT1 will get different result to combine payload:496 +For example, if return from AT+COMMAND1 is “013METER TER12 112T12-00024895” , Below AT+DATACUT1 will get different result to combine payload: 495 495 496 496 497 497 (% border="1" cellspacing="4" style="background-color:#f7faff; width:510px" %) 498 -| =(% style="width:64px;" %)**AT+DATACUT1 value**|=(% style="width:44px;" %)**Final Result to combine Payload**499 -|(% style="width:1 64px" %)34,1,1+2+3|(% style="width:344px" %)0D 00 01 30 31 33500 -|(% style="width:1 64px" %)34,2,1~~8+12~~16|(% style="width:344px" %)0D 00 01 30 31 33 4D 45 54 45 52 54 45 52 31 32501 -|(% style="width:1 64px" %)34,2,1~~34|(% style="width:344px" %)0D 00 01 30 31 33 4D 45 54 45 52 20 20 20 54 45 52 31 32 20 31 31 32 54 31 32 2D 30 30 30 32 34 38 39 35 0D 0A500 +|(% style="width:170px" %)**AT+DATACUT1 value**|(% style="width:338px" %)**Final Result to combine Payload** 501 +|(% style="width:170px" %)34,1,1+2+3|(% style="width:338px" %)0D 00 01 30 31 33 502 +|(% style="width:170px" %)34,2,1~~8+12~~16|(% style="width:338px" %)0D 00 01 30 31 33 4D 45 54 45 52 54 45 52 31 32 503 +|(% style="width:170px" %)34,2,1~~34|(% style="width:338px" %)0D 00 01 30 31 33 4D 45 54 45 52 20 20 20 54 45 52 31 32 20 31 31 32 54 31 32 2D 30 30 30 32 34 38 39 35 0D 0A 502 502 503 -* (% style="color:blue" %)** Downlink Payload:**505 +* ** Downlink Payload:** 504 504 505 - (% style="color:blue" %)**0xAF**(%%)downlink command can be used to set AT+COMMANDx or AT+DATACUTx.507 +**0xAF** downlink command can be used to set AT+COMMANDx or AT+DATACUTx. 506 506 507 507 508 - (% style="color:red" %)**Note : if user use AT+COMMANDx to add a new command, he also need to send AT+DATACUTx downlink.**510 +**Note : if user use AT+COMMANDx to add a new command, he also need to send AT+DATACUTx downlink.** 509 509 510 510 511 -Format: ** (% style="color:#037691" %)AF MM NN LL XX XX XX XX YY(%%)**513 +Format: ** AF MM NN LL XX XX XX XX YY** 512 512 513 513 Where: 514 514 515 -* (% style="color:#037691" %)**MM **(%%): the AT+COMMAND or AT+DATACUT to be set. Value from 01 ~~ 0F,516 -* (% style="color:#037691" %)**NN **(%%): 1: set the AT+COMMAND value ; 2: set the AT+DATACUT value.517 -* (% style="color:#037691" %)**LL **(%%): The length of AT+COMMAND or AT+DATACUT command518 -* (% style="color:#037691" %)**XX XX XX XX **(%%): AT+COMMAND or AT+DATACUT command519 -* (% style="color:#037691" %)**YY **(%%): If YY=0, SDI-12-LBwill execute the downlink command without uplink; if YY=1, SDI-12-LBwill execute an uplink after got this command.517 +* **MM **: the AT+COMMAND or AT+DATACUT to be set. Value from 01 ~~ 0F, 518 +* **NN **: 1: set the AT+DATACUT value ; 2: set the AT+DATACUT value. 519 +* **LL **: The length of AT+COMMAND or AT+DATACUT command 520 +* **XX XX XX XX **: AT+COMMAND or AT+DATACUT command 521 +* **YY **: If YY=0, RS485-LN will execute the downlink command without uplink; if YY=1, RS485-LN will execute an uplink after got this command. 520 520 521 -(% style="color:blue" %)**Example:** 522 522 524 +**Example:** 525 + 523 523 [[image:image-20230201094129-18.png]] 524 524 525 525 529 +**Clear SDI12 Command** 526 526 527 -(% style="color:blue" %)**Clear SDI12 Command** 528 - 529 529 The AT+COMMANDx and AT+DATACUTx settings are stored in special location, user can use below command to clear them. 530 530 531 531 532 -* (% style="color:#037691" %)**AT Command:**534 +* ** AT Command:** 533 533 534 - (% style="color:#4f81bd" %)**AT+CMDEAR=mm,nn**(%%)mm: start position of erase ,nn: stop position of erase536 +**~ AT+CMDEAR=mm,nn** mm: start position of erase ,nn: stop position of erase 535 535 536 536 537 537 Etc. AT+CMDEAR=1,10 means erase AT+COMMAND1/AT+DATACUT1 to AT+COMMAND10/AT+DATACUT10 538 538 539 539 540 -* (% style="color:#037691" %)** Downlink Payload:**542 +* ** Downlink Payload:** 541 541 542 - (% style="color:#4f81bd" %)**0x09 aa bb**(%%)same as AT+CMDEAR=aa,bb544 +**~ 0x09 aa bb** same as AT+CMDEAR=aa,bb 543 543 544 544 545 545 546 - (% style="color:blue" %)**command combination**548 +**command combination** 547 547 548 548 Below shows a screen shot how the results combines together to a uplink payload. 549 549 ... ... @@ -552,26 +552,26 @@ 552 552 553 553 If user don't want to use DATACUT for some command, he simply want to uplink all returns. AT+ALLDATAMOD can be set to 1. 554 554 555 - (% style="color:blue" %)**AT+ALLDATAMOD**(%%)will simply get all return and don't do CRC check as result for SDI-12 command. AT+DATACUTx command has higher priority, if AT+DATACUTx has been set, AT+ALLDATAMOD will be ignore for this SDI-12 command.557 +**AT+ALLDATAMOD** will simply get all return and don’t do CRC check as result for SDI-12 command. AT+DATACUTx command has higher priority, if AT+DATACUTx has been set, AT+ALLDATAMOD will be ignore for this SDI-12 command. 556 556 557 557 558 - (% style="color:#4f81bd" %)**For example: **(%%)as below photo, AT+ALLDATAMOD=1, but AT+DATACUT1 has been set, AT+DATACUT1 will be still effect the result.560 +**For example: ** as below photo, AT+ALLDATAMOD=1, but AT+DATACUT1 has been set, AT+DATACUT1 will be still effect the result. 559 559 560 560 561 561 [[image:1675215782925-448.png]] 562 562 563 563 564 -If AT+ALLDATAMOD=1, (% style="color:#4f81bd" %)**FX,X**(%%)will be added in the payload, FX specify which command is used and X specify the length of return. for example in above screen, F1 05 means the return is from AT+COMMAND1 and the return is 5 bytes.566 +If AT+ALLDATAMOD=1, **FX,X** will be added in the payload, FX specify which command is used and X specify the length of return. for example in above screen, F1 05 means the return is from AT+COMMAND1 and the return is 5 bytes. 565 565 566 566 567 567 568 - (% style="color:blue" %)**Compose Uplink**570 +**Compose Uplink** 569 569 570 - (% style="color:#4f81bd" %)**AT+DATAUP=0**572 +**AT+DATAUP=0** 571 571 572 -Compose the uplink payload with value returns in sequence and send with **__A SIGNLE UPLINK__**.574 +Compose the uplink payload with value returns in sequence and send with A SIGNLE UPLINK. 573 573 574 -Final Payload is **__Battery Info+PAYVER + VALID Value from RETURN1 + Valid Value from RETURN2 + … + RETURNx__**576 +Final Payload is Battery Info+PAYVER + VALID Value from RETURN1 + Valid Value from RETURN2 + … + RETURNx 575 575 576 576 Where PAYVER is defined by AT+PAYVER, below is an example screen shot. 577 577 ... ... @@ -579,12 +579,14 @@ 579 579 [[image:1675215828102-844.png]] 580 580 581 581 582 - (% style="color:#4f81bd" %)**AT+DATAUP=1**584 +**AT+DATAUP=1** 583 583 584 -Compose the uplink payload with value returns in sequence and send with **__Multiply UPLINKs__**.586 +Compose the uplink payload with value returns in sequence and send with Multiply UPLINKs. 585 585 586 -Final Payload is __**Battery Info+PAYVER + PAYLOAD COUNT + PAYLOAD# + DATA**__588 +Final Payload is 587 587 590 +__**Battery Info+PAYVER + PAYLOAD COUNT + PAYLOAD# + DATA**__ 591 + 588 588 1. Battery Info (2 bytes): Battery voltage 589 589 1. PAYVER (1 byte): Defined by AT+PAYVER 590 590 1. PAYLOAD COUNT (1 byte): Total how many uplinks of this sampling. ... ... @@ -594,7 +594,7 @@ 594 594 [[image:1675215848113-696.png]] 595 595 596 596 597 - (% style="color:red" %)**Notice: the Max bytes is according to the max support bytes in different Frequency Bands for lowest SF. As below:**601 +**Notice: the Max bytes is according to the max support bytes in different Frequency Bands for lowest SF. As below:** 598 598 599 599 * For AU915/AS923 bands, if UplinkDwell time=0, max 51 bytes for each uplink ( so 51 -5 = 46 max valid date) 600 600 * For AU915/AS923 bands, if UplinkDwell time=1, max 11 bytes for each uplink ( so 11 -5 = 6 max valid date). ... ... @@ -601,36 +601,45 @@ 601 601 * For US915 band, max 11 bytes for each uplink ( so 11 -5 = 6 max valid date). 602 602 * For all other bands: max 51 bytes for each uplink ( so 51 -5 = 46 max valid date). 603 603 604 - (% style="color:red" %)**When AT+DATAUP=1, the maximum number of segments is 15, and the maximum total number of bytes is 1500;**608 +**~ When AT+DATAUP=1, the maximum number of segments is 15, and the maximum total number of bytes is 1500;** 605 605 606 - (% style="color:red" %)**When AT+DATAUP=1 and AT+ADR=0, the maximum number of bytes of each payload is determined by the DR value.**610 +**~ When AT+DATAUP=1 and AT+ADR=0, the maximum number of bytes of each payload is determined by the DR value.** 607 607 608 608 609 -== 2.4 Uplink Payload == 613 +== 2.4 Uplink Payload == 610 610 611 -=== 2.4.1 Device Payload, FPORT~=5 === 612 612 616 +Uplink payloads have two types: 613 613 618 +* Distance Value: Use FPORT=2 619 +* Other control commands: Use other FPORT fields. 620 + 621 +The application server should parse the correct value based on FPORT settings. 622 + 623 + 624 +2.4.1 Device Payload, FPORT=5 625 + 614 614 Include device configure status. Once SDI-12-LB Joined the network, it will uplink this message to the server. 615 615 628 + 616 616 Users can also use the downlink command(0x26 01) to ask SDI-12-LB to resend this uplink. 617 617 618 -(% border="1" cellspacing="4" style="background-color:#f7faff; width:420px" %) 631 + 632 +(% border="1" cellspacing="4" style="background-color:#f7faff; width:437px" %) 619 619 |(% colspan="6" style="width:434px" %)**Device Status (FPORT=5)** 620 -|(% style="width:1 14px" %)**Size(bytes)**|(% style="width:39px" %)**1**|(% style="width:80px" %)**2**|(% style="width:89px" %)**1**|(% style="width:59px" %)**1**|(% style="width:37px" %)**2**621 -|(% style="width:1 14px" %)**Value**|(% style="width:39px" %)Sensor Model|(% style="width:80px" %)Firmware Version|(% style="width:89px" %)Frequency Band|(% style="width:59px" %)Sub-band|(% style="width:37px" %)BAT634 +|(% style="width:102px" %)**Size (bytes)**|(% style="width:67px" %)**1**|(% style="width:80px" %)**2**|(% style="width:89px" %)**1**|(% style="width:52px" %)**1**|(% style="width:44px" %)**2** 635 +|(% style="width:102px" %)**Value**|(% style="width:67px" %)Sensor Model|(% style="width:80px" %)Firmware Version|(% style="width:89px" %)Frequency Band|(% style="width:52px" %)Sub-band|(% style="width:44px" %)BAT 622 622 623 623 Example parse in TTNv3 624 624 625 625 [[image:1675215946738-635.png]] 626 626 641 +**Sensor Model**: For SDI-12-LB, this value is 0x17 627 627 628 - (% style="color:#037691" %)**SensorModel**(%%):For SDI-12-LB,this valueis0x17643 +**Firmware Version**: 0x0100, Means: v1.0.0 version 629 629 630 - (% style="color:#037691" %)**FirmwareVersion**(%%):0x0100, Means:v1.0.0 version645 +**Frequency Band**: 631 631 632 -(% style="color:#037691" %)**Frequency Band**: 633 - 634 634 *0x01: EU868 635 635 636 636 *0x02: US915 ... ... @@ -660,7 +660,7 @@ 660 660 *0x0e: MA869 661 661 662 662 663 - (% style="color:#037691" %)**Sub-Band**:676 +**Sub-Band**: 664 664 665 665 AU915 and US915:value 0x00 ~~ 0x08 666 666 ... ... @@ -669,7 +669,7 @@ 669 669 Other Bands: Always 0x00 670 670 671 671 672 - (% style="color:#037691" %)**Battery Info**:685 +**Battery Info**: 673 673 674 674 Check the battery voltage. 675 675 ... ... @@ -678,9 +678,10 @@ 678 678 Ex2: 0x0B49 = 2889mV 679 679 680 680 681 -=== 2.4.2 Uplink Payload, FPORT~=2 === 694 +1. 695 +11. 696 +111. Uplink Payload, FPORT=2 682 682 683 - 684 684 There are different cases for uplink. See below 685 685 686 686 * SDI-12 Debug Command return: FPORT=100 ... ... @@ -687,24 +687,30 @@ 687 687 688 688 * Periodically Uplink: FPORT=2 689 689 690 -(% border="1" cellspacing="4" style="background-color:#f7faff; width:500px" %) 691 -|=(% style="width: 90px;" %)((( 692 -**Size(bytes)** 693 -)))|=(% style="width: 80px;" %)**2**|=(% style="width: 90px;" %)**1**|=(% style="width: 240px;" %)**Length depends on the return from the commands** 694 -|(% style="width:93px" %)**Value**|(% style="width:83px" %)((( 704 +|((( 705 +**Size** 706 + 707 +**(bytes)** 708 +)))|**2**|**1**|**Length depends on the return from the commands** 709 +|**Value**|((( 695 695 Battery(mV) 711 + 696 696 & 713 + 697 697 Interrupt_Flag 698 -)))|(% style="width:91px" %)[[PAYLOAD_VER>>||anchor="H3.6Setthepayloadversion"]]|(% style="width:212px" %)((( 699 -If the valid payload is too long and exceed the maximum support. 715 +)))|[[PAYLOAD_VER>>path:#Probe_Model]]|((( 716 +If the valid payload is too long and exceed the maximum support 717 + 700 700 Payload length in server,server will show payload not provided in the LoRaWAN server. 701 701 ))) 702 702 703 -[[image: 1675216282284-923.png]]721 +[[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image034.png]] 704 704 705 705 706 -=== 2.4.3 Battery Info === 707 707 725 +1. 726 +11. 727 +111. Battery Info 708 708 709 709 Check the battery voltage for SDI-12-LB. 710 710 ... ... @@ -713,12 +713,14 @@ 713 713 Ex2: 0x0B49 = 2889mV 714 714 715 715 716 -=== 2.4.4 Interrupt Pin === 736 +1. 737 +11. 738 +111. Interrupt Pin 717 717 740 +This data field shows if this packet is generated by **Interrupt Pin** or not. [[Click here>>path:#Int_mod]] for the hardware and software set up. Note: The Internet Pin is a separate pin in the screw terminal. See [[pin mapping>>path:#pins]]. 718 718 719 -This data field shows if this packet is generated by (% style="color:#037691" %)**Interrupt Pin**(%%) or not. [[Click here>>||anchor="H3.2SetInterruptMode"]] for the hardware and software set up. Note: The Internet Pin is a separate pin in the screw terminal. See [[pin mapping>>||anchor="H1.7PinMapping"]]. 720 720 721 - **Example:**743 +Example: 722 722 723 723 Ex1: 0x0B45:0x0B&0x80= 0x00 Normal uplink packet. 724 724 ... ... @@ -725,127 +725,242 @@ 725 725 Ex2: 0x8B49:0x8B&0x80= 0x80 Interrupt Uplink Packet. 726 726 727 727 728 -=== 2.4.5 Payload version === 750 +1. 751 +11. 752 +111. Payload version 729 729 730 -The version number of the payload, mainly used for decoding. The default is 01. 731 731 732 732 733 -=== 2.4.6 Decode payload in The Things Network === 734 734 735 735 758 +1. 759 +11. 760 +111. Decode payload in The Things Network 761 + 736 736 While using TTN network, you can add the payload format to decode the payload. 737 737 738 -[[image: 1675216779406-595.png]]764 +[[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image035.png]] 739 739 740 740 741 741 There is no fix payload decoder in LoRaWAN server because the SDI-12 sensors returns are different. User need to write the decoder themselves for their case. 742 742 743 -SDI-12-LB TTN Payload Decoder: [[https:~~/~~/github.com/dragino/dragino-end-node-decoder>>url:https://github.com/dragino/dragino-end-node-decoder]] 744 744 770 +下面的解码生成超链接放进去. 745 745 746 - == 2.5 UplinkInterval==772 +function Decoder(bytes, port) { 747 747 774 + if(port==5) 748 748 749 - TheSDI-12-LBby default uplink the sensor data every 20 minutes. User can change this interval by AT Command or LoRaWAN Downlink Command. See this link:776 + { 750 750 751 - [[http:~~/~~/wiki.dragino.com/xwiki/bin/view/Main/End%20Device%20AT%20Commands%20and%20Downlink%20Command/#H4.1ChangeUplinkInterval>>http://wiki.dragino.com/xwiki/bin/view/Main/End%20Device%20AT%20Commands%20and%20Downlink%20Command/#H4.1ChangeUplinkInterval]]]]778 + var freq_band; 752 752 780 + var sub_band; 753 753 754 - ==2.6ExamplesToSet SDI commands. ==782 + var sensor; 755 755 756 -=== 2.6.1 Examples 1 === 757 757 758 - COM portandSDI-12sensorcommunication converted to SDI-12-LB and SDI-12sensor communication.785 + if(bytes[0]==0x17) 759 759 760 - [[image:image-20230222143809-1.png||height="564"width="729"]]787 + sensor= "SDI12-LB"; 761 761 762 -1)The AT+COMMANDx command is applied to the red arrow part, and sends the SDI12 command to the SDI12 sensor: 763 763 764 - a.Sendthefirstcommandandgetthefirstreply:790 + var firm_ver= (bytes[1]&0x0f)+'.'+(bytes[2]>>4&0x0f)+'.'+(bytes[2]&0x0f); 765 765 766 -AT+COMMANDx=1I!,0,0,1 767 767 768 - b.Sendthesecondcommandand gettheecond reply:793 + if(bytes[3]==0x01) 769 769 770 - AT+COMMANDx=2I!,0,0,1795 + freq_band="EU868"; 771 771 772 - c.Sendthethirdcommandandgetthethird reply:797 + else if(bytes[3]==0x02) 773 773 774 - AT+COMMANDx=3I!,0,0,1799 + freq_band="US915"; 775 775 776 - d.Sendthefourthcommandandgetthe fourth reply:801 + else if(bytes[3]==0x03) 777 777 778 - AT+COMMANDx=4I!,0,0,1803 + freq_band="IN865"; 779 779 780 - e.Sendthefifthcommandplusthesixthcommand, get thesixth reply:805 + else if(bytes[3]==0x04) 781 781 782 - AT+COMMANDx=1M!,2,1,1807 + freq_band="AU915"; 783 783 784 - f.Sendtheseventhcommandplustheeighthcommand, get theeighth reply:809 + else if(bytes[3]==0x05) 785 785 786 - AT+COMMANDx=2M!,2,1,1811 + freq_band="KZ865"; 787 787 788 - g.Sendtheninthcommandplusthetenthcommand, get the tenth reply:813 + else if(bytes[3]==0x06) 789 789 790 - AT+COMMANDx=3M!,1,1,1815 + freq_band="RU864"; 791 791 792 - h.Sendtheeleventhcommandplusthetwelfth command, getthe twelfth reply:817 + else if(bytes[3]==0x07) 793 793 794 - AT+COMMANDx=4M!,1,1,1819 + freq_band="AS923"; 795 795 821 + else if(bytes[3]==0x08) 796 796 797 - 2) TheAT+DATACUTxcommandisappliedtothegreenarrow part, receivingandcut out data from theSDI12sensor:823 + freq_band="AS923_1"; 798 798 799 - a.Thefirstreply,all34characters: ”113TRUEBNERSMT100038220303182331<CR><LF>”825 + else if(bytes[3]==0x09) 800 800 801 - Cutoutallcharacters:AT+ALLDATAMOD=1orAT+DATACUTx=34,2,1~~34;827 + freq_band="AS923_2"; 802 802 803 - b. Thesixthreply,all31characters:”1+19210+1.04+0.00+22.49+11.75<CR><LF>”829 + else if(bytes[3]==0x0A) 804 804 805 - Cutoutallcharacters:AT+ALLDATAMOD=1orAT+DATACUTx=31,2,1~~31;831 + freq_band="AS923_3"; 806 806 807 - c. Theeighthreply,all31characters:”2+18990+1.08+0.00+22.24+11.80<CR><LF>”833 + else if(bytes[3]==0x0F) 808 808 809 - Cutoutallcharacters:AT+ALLDATAMOD=1orAT+DATACUTx=31,2,1~~31;835 + freq_band="AS923_4"; 810 810 811 - d. Thetenthreply,all15characters:”3-2919.8+24.0<CR><LF>”837 + else if(bytes[3]==0x0B) 812 812 813 - Cutoutallcharacters:AT+ALLDATAMOD=1orAT+DATACUTx=15,2,1~~15;839 + freq_band="CN470"; 814 814 815 - e. Thetwelfthreply,all25characters:”4+30.8+22.84+4.7+954.38<CR><LF>”841 + else if(bytes[3]==0x0C) 816 816 817 - Partialcut,thecutsensoraddressandthefirst two parameters:AT+DATACUTx=25,2,1~~12, cut out the character field”4+30.8+22.84”.843 + freq_band="EU433"; 818 818 819 -(% class="wikigeneratedid" %) 820 -== == 845 + else if(bytes[3]==0x0D) 821 821 822 - ==2.7Frequency Plans==847 + freq_band="KR920"; 823 823 849 + else if(bytes[3]==0x0E) 824 824 825 - TheSDI-12-LBusesOTAAmodeandbelowfrequency plansby default. If user want to use it withdifferent frequency plan, please refer theAT command sets.851 + freq_band="MA869"; 826 826 827 -[[http:~~/~~/wiki.dragino.com/xwiki/bin/view/Main/End%20Device%20Frequency%20Band/>>url:http://wiki.dragino.com/xwiki/bin/view/Main/End%20Device%20Frequency%20Band/]] 828 828 854 + if(bytes[4]==0xff) 829 829 830 - ==2.8FirmwareChangeLog==856 + sub_band="NULL"; 831 831 858 + else 832 832 860 + sub_band=bytes[4]; 861 + 862 + 863 + var bat= (bytes[5]<<8 | bytes[6])/1000; 864 + 865 + 866 + return { 867 + 868 + SENSOR_MODEL:sensor, 869 + 870 + FIRMWARE_VERSION:firm_ver, 871 + 872 + FREQUENCY_BAND:freq_band, 873 + 874 + SUB_BAND:sub_band, 875 + 876 + BAT:bat, 877 + 878 + } 879 + 880 + } 881 + 882 + else if(port==100) 883 + 884 + { 885 + 886 + var datas_sum={}; 887 + 888 + for(var j=0;j<bytes.length;j++) 889 + 890 + { 891 + 892 + var datas= String.fromCharCode(bytes[j]); 893 + 894 + if(j=='0') 895 + 896 + datas_sum.datas_sum=datas; 897 + 898 + else 899 + 900 + datas_sum.datas_sum+=datas; 901 + 902 + } 903 + 904 + 905 + return datas_sum; 906 + 907 + } 908 + 909 + else 910 + 911 + { 912 + 913 + var decode={}; 914 + 915 + decode.EXTI_Trigger= (bytes[0] & 0x80)? "TRUE":"FALSE"; 916 + 917 + decode.BatV= ((bytes[0]<<8 | bytes[1])&0x7FFF)/1000; 918 + 919 + decode.Payver= bytes[2]; 920 + 921 + for(var i=3;i<bytes.length;i++) 922 + 923 + { 924 + 925 + var data= String.fromCharCode(bytes[i]); 926 + 927 + if(i=='3') 928 + 929 + decode.data_sum=data; 930 + 931 + else 932 + 933 + decode.data_sum+=data; 934 + 935 + } 936 + 937 + return decode; 938 + 939 + } 940 + 941 + 942 +} 943 + 944 + 945 +1. 946 +11. Uplink Interval 947 + 948 +The SDI-12-LB by default uplink the sensor data every 20 minutes. User can change this interval by AT Command or LoRaWAN Downlink Command. See this link: 949 + 950 +[[http:~~/~~/wiki.dragino.com/index.php?title=End_Device_AT_Commands_and_Downlink_Commands#Change_Uplink_Interval>>url:http://wiki.dragino.com/index.php?title=End_Device_AT_Commands_and_Downlink_Commands#Change_Uplink_Interval]] 951 + 952 + 953 + 954 +1. 955 +11. Frequency Plans 956 + 957 +The SDI12-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. 958 + 959 + 960 +[[https:~~/~~/wiki.dragino.com/index.php?title=End_Device_Frequency_Band>>url:https://wiki.dragino.com/index.php?title=End_Device_Frequency_Band]] 961 + 962 + 963 + 964 +1. 965 +11. Firmware Change Log 966 + 833 833 **Firmware download link:** 834 834 835 -[[https:~~/~~/www.dropbox.com/sh/ qrbgbikb109lkiv/AACBR-v_ZhZAMengcY7Nsa1ja?dl=0>>https://www.dropbox.com/sh/qrbgbikb109lkiv/AACBR-v_ZhZAMengcY7Nsa1ja?dl=0]]969 +[[https:~~/~~/www.dropbox.com/sh/gf1glloczbzz19h/AABbuYI4WY6VdAmpXo6o1V2Ka?dl=0>>url:https://www.dropbox.com/sh/gf1glloczbzz19h/AABbuYI4WY6VdAmpXo6o1V2Ka?dl=0]] 836 836 837 837 838 -= 3. Configure SDI-12-LB via AT Command or LoRaWAN Downlink = 839 839 973 +1. Configure SDI-12-LB via AT Command or LoRaWAN Downlink 840 840 841 841 Use can configure SDI-12-LB via AT Command or LoRaWAN Downlink. 842 842 843 -* AT Command Connection: See [[FAQ>> ||anchor="H7.FAQ"]].844 -* LoRaWAN Downlink instruction for different platforms: See [[IoT LoRaWAN Server>>http://wiki.dragino.com/xwiki/bin/view/Main/]] section.977 +* AT Command Connection: See [[FAQ>>path:#AT_COMMAND]]. 978 +* LoRaWAN Downlink instruction for different platforms: 845 845 980 +[[http:~~/~~/wiki.dragino.com/index.php?title=Main_Page#Use_Note_for_Server>>url:http://wiki.dragino.com/index.php?title=Main_Page#Use_Note_for_Server]] 981 + 982 + 846 846 There are two kinds of commands to configure SDI-12-LB, they are: 847 847 848 -* (% style="color:blue" %)**General Commands**.985 +* **General Commands**. 849 849 850 850 These commands are to configure: 851 851 ... ... @@ -854,237 +854,255 @@ 854 854 855 855 They are same for all Dragino Device which support DLWS-005 LoRaWAN Stack. These commands can be found on the wiki: 856 856 857 -[[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/]]994 +[[http:~~/~~/wiki.dragino.com/index.php?title=End_Device_Downlink_Command>>url:http://wiki.dragino.com/index.php?title=End_Device_Downlink_Command]] 858 858 859 859 860 -* (% style="color:blue" %)**Commands special design for SDI-12-LB**997 +* **Commands special design for SDI-12-LB** 861 861 862 862 These commands only valid for SDI-12-LB, as below: 863 863 864 864 865 -== 3.1 Set Transmit Interval Time == 866 866 1003 +1. 1004 +11. Set Transmit Interval Time 867 867 868 868 Feature: Change LoRaWAN End Node Transmit Interval. 869 869 870 - (% style="color:blue" %)**AT Command: AT+TDC**1008 +**AT Command: AT+TDC** 871 871 872 -(% border="1" cellspacing="4" style="background-color:#f7faff; color:black; width:510px" %) 873 -|=(% style="width: 156px;" %)**Command Example**|=(% style="width: 137px;" %)**Function**|=**Response** 874 -|(% style="width:156px" %)AT+TDC=?|(% style="width:137px" %)Show current transmit Interval|((( 1010 +|**Command Example**|**Function**|**Response** 1011 +|AT+TDC=?|Show current transmit Interval|((( 875 875 30000 1013 + 876 876 OK 1015 + 877 877 the interval is 30000ms = 30s 878 878 ))) 879 -| (% style="width:156px" %)AT+TDC=60000|(% style="width:137px" %)Set Transmit Interval|(((1018 +|AT+TDC=60000|Set Transmit Interval|((( 880 880 OK 1020 + 881 881 Set transmit interval to 60000ms = 60 seconds 882 882 ))) 883 883 884 - (% style="color:blue" %)**Downlink Command: 0x01**1024 +**Downlink Command: 0x01** 885 885 886 - 887 887 Format: Command Code (0x01) followed by 3 bytes time value. 888 888 889 -If the downlink payload=0100003C, it means set the END Node 's Transmit Interval to 0x00003C=60(S), while type code is 01.1028 +If the downlink payload=0100003C, it means set the END Node’s Transmit Interval to 0x00003C=60(S), while type code is 01. 890 890 891 -* Example 1: Downlink Payload: 0100001E 892 -* Example 2: Downlink Payload: 0100003C 1030 +* Example 1: Downlink Payload: 0100001E ~/~/ Set Transmit Interval (TDC) = 30 seconds 1031 +* Example 2: Downlink Payload: 0100003C ~/~/ Set Transmit Interval (TDC) = 60 seconds 893 893 1033 +1. 1034 +11. Set Interrupt Mode 894 894 895 -== 3.2 Set Interrupt Mode == 896 - 897 - 898 898 Feature, Set Interrupt mode for GPIO_EXIT. 899 899 900 - (% style="color:blue" %)**AT Command: AT+INTMOD**1038 +**AT Command: AT+INTMOD** 901 901 902 -(% border="1" cellspacing="4" style="background-color:#f7faff; color:black; width:510px" %) 903 -|=(% style="width: 156px;" %)**Command Example**|=(% style="width: 187px;" %)**Function**|=(% style="width: 165px;" %)**Response** 904 -|(% style="width:156px" %)AT+INTMOD=?|(% style="width:187px" %)Show current interrupt mode|(% style="width:165px" %)((( 1040 +|**Command Example**|**Function**|**Response** 1041 +|AT+INTMOD=?|Show current interrupt mode|((( 905 905 0 1043 + 906 906 OK 907 -the mode is 0 = Disable Interrupt 1045 + 1046 +the mode is 0 = No interruption 908 908 ))) 909 -| (% style="width:156px" %)AT+INTMOD=2|(% style="width:187px" %)(((1048 +|AT+INTMOD=2|((( 910 910 Set Transmit Interval 911 -0. (Disable Interrupt), 912 -~1. (Trigger by rising and falling edge) 913 -2. (Trigger by falling edge) 914 -3. (Trigger by rising edge) 915 -)))|(% style="width:165px" %)OK 916 916 917 -(% style="color:blue" %)**Downlink Command: 0x06** 1051 +1. (Disable Interrupt), 1052 +1. (Trigger by rising and falling edge), 1053 +1. (Trigger by falling edge) 1054 +1. (Trigger by rising edge) 1055 +)))|OK 918 918 1057 +**Downlink Command: 0x06** 1058 + 919 919 Format: Command Code (0x06) followed by 3 bytes. 920 920 921 921 This means that the interrupt mode of the end node is set to 0x000003=3 (rising edge trigger), and the type code is 06. 922 922 923 -* Example 1: Downlink Payload: 06000000 924 -* Example 2: Downlink Payload: 06000003 1063 +* Example 1: Downlink Payload: 06000000 ~/~/ Turn off interrupt mode 1064 +* Example 2: Downlink Payload: 06000003 ~/~/ Set the interrupt mode to rising edge trigger 925 925 1066 +1. 1067 +11. Set the output time 926 926 927 -== 3.3 Set the output time == 928 - 929 - 930 930 Feature, Control the output 3V3 , 5V or 12V. 931 931 932 - (% style="color:blue" %)**AT Command: AT+3V3T**1071 +**AT Command: AT+3V3T** 933 933 934 -(% border="1" cellspacing="4" style="background-color:#f7faff; color:black; width:474px" %) 935 -|=(% style="width: 154px;" %)**Command Example**|=(% style="width: 201px;" %)**Function**|=(% style="width: 116px;" %)**Response** 936 -|(% style="width:154px" %)AT+3V3T=?|(% style="width:201px" %)Show 3V3 open time.|(% style="width:116px" %)((( 1073 +|**Command Example**|**Function**|**Response** 1074 +|AT+3V3T=?|Show 3V3 open time.|((( 937 937 0 1076 + 938 938 OK 939 939 ))) 940 -| (% style="width:154px" %)AT+3V3T=0|(% style="width:201px" %)Normally open 3V3 power supply.|(% style="width:116px" %)(((1079 +|AT+3V3T=0|Normally open 3V3 power supply.|((( 941 941 OK 1081 + 942 942 default setting 943 943 ))) 944 -| (% style="width:154px" %)AT+3V3T=1000|(% style="width:201px" %)Close after a delay of 1000 milliseconds.|(% style="width:116px" %)(((1084 +|AT+3V3T=1000|Close after a delay of 1000 milliseconds.|((( 945 945 OK 1086 + 1087 + 946 946 ))) 947 -| (% style="width:154px" %)AT+3V3T=65535|(% style="width:201px" %)Normally closed 3V3 power supply.|(% style="width:116px" %)(((1089 +|AT+3V3T=65535|Normally closed 3V3 power supply.|((( 948 948 OK 1091 + 1092 + 949 949 ))) 950 950 951 - (% style="color:blue" %)**AT Command: AT+5VT**1095 +**AT Command: AT+5VT** 952 952 953 -(% border="1" cellspacing="4" style="background-color:#f7faff; color:black; width:470px" %) 954 -|=(% style="width: 155px;" %)**Command Example**|=(% style="width: 196px;" %)**Function**|=(% style="width: 114px;" %)**Response** 955 -|(% style="width:155px" %)AT+5VT=?|(% style="width:196px" %)Show 5V open time.|(% style="width:114px" %)((( 1097 +|**Command Example**|**Function**|**Response** 1098 +|AT+5VT=?|Show 5V open time.|((( 956 956 0 1100 + 957 957 OK 958 958 ))) 959 -| (% style="width:155px" %)AT+5VT=0|(% style="width:196px" %)Normally closed 5V power supply.|(% style="width:114px" %)(((1103 +|AT+5VT=0|Normally closed 5V power supply.|((( 960 960 OK 1105 + 961 961 default setting 962 962 ))) 963 -| (% style="width:155px" %)AT+5VT=1000|(% style="width:196px" %)Close after a delay of 1000 milliseconds.|(% style="width:114px" %)(((1108 +|AT+5VT=1000|Close after a delay of 1000 milliseconds.|((( 964 964 OK 1110 + 1111 + 965 965 ))) 966 -| (% style="width:155px" %)AT+5VT=65535|(% style="width:196px" %)Normally open 5V power supply.|(% style="width:114px" %)(((1113 +|AT+5VT=65535|Normally open 5V power supply.|((( 967 967 OK 1115 + 1116 + 968 968 ))) 969 969 970 - (% style="color:blue" %)**AT Command: AT+12VT**1119 +**AT Command: AT+12VT** 971 971 972 -(% border="1" cellspacing="4" style="background-color:#f7faff; color:black; width:443px" %) 973 -|=(% style="width: 156px;" %)**Command Example**|=(% style="width: 199px;" %)**Function**|=(% style="width: 83px;" %)**Response** 974 -|(% style="width:156px" %)AT+12VT=?|(% style="width:199px" %)Show 12V open time.|(% style="width:83px" %)((( 1121 +|**Command Example**|**Function**|**Response** 1122 +|AT+12VT=?|Show 12V open time.|((( 975 975 0 1124 + 976 976 OK 977 977 ))) 978 -| (% style="width:156px" %)AT+12VT=0|(% style="width:199px" %)Normally closed 12V power supply.|(% style="width:83px" %)OK979 -| (% style="width:156px" %)AT+12VT=500|(% style="width:199px" %)Close after a delay of 500 milliseconds.|(% style="width:83px" %)(((1127 +|AT+12VT=0|Normally closed 12V power supply.|OK 1128 +|AT+12VT=500|Close after a delay of 500 milliseconds.|((( 980 980 OK 1130 + 1131 + 981 981 ))) 982 982 983 - (% style="color:blue" %)**Downlink Command: 0x07**1134 +**Downlink Command: 0x07** 984 984 985 985 Format: Command Code (0x07) followed by 3 bytes. 986 986 987 987 The first byte is which power, the second and third bytes are the time to turn on. 988 988 989 -* Example 1: Downlink Payload: 070101F4 **~-~-->**990 -* Example 2: Downlink Payload: 0701FFFF **~-~-->**AT+3V3T=65535991 -* Example 3: Downlink Payload: 070203E8 **~-~-->**AT+5VT=1000992 -* Example 4: Downlink Payload: 07020000 **~-~-->**AT+5VT=0993 -* Example 5: Downlink Payload: 070301F4 **~-~-->**AT+12VT=500994 -* Example 6: Downlink Payload: 07030000 **~-~-->**AT+12VT=01140 +* Example 1: Downlink Payload: 070101F4 -> AT+3V3T=500 1141 +* Example 2: Downlink Payload: 0701FFFF -> AT+3V3T=65535 1142 +* Example 3: Downlink Payload: 070203E8 -> AT+5VT=1000 1143 +* Example 4: Downlink Payload: 07020000 -> AT+5VT=0 1144 +* Example 5: Downlink Payload: 070301F4 -> AT+12VT=500 1145 +* Example 6: Downlink Payload: 07030000 -> AT+12VT=0 995 995 1147 +1. 1148 +11. Set the all data mode 996 996 997 -== 3.4 Set the all data mode == 998 - 999 - 1000 1000 Feature, Set the all data mode. 1001 1001 1002 - (% style="color:blue" %)**AT Command: AT+ALLDATAMOD**1152 +**AT Command: AT+ALLDATAMOD** 1003 1003 1004 -(% border="1" cellspacing="4" style="background-color:#f7faff; width:437px" %) 1005 -|=**Command Example**|=**Function**|=**Response** 1154 +|**Command Example**|**Function**|**Response** 1006 1006 |AT+ALLDATAMOD=?|Show current all data mode|((( 1007 1007 0 1157 + 1158 + 1008 1008 OK 1009 1009 ))) 1010 1010 |AT+ALLDATAMOD=1|Set all data mode is 1.|OK 1011 1011 1012 - (% style="color:blue" %)**Downlink Command: 0xAB**1163 +**Downlink Command: 0xAB** 1013 1013 1014 1014 Format: Command Code (0xAB) followed by 1 bytes. 1015 1015 1016 -* Example 1: Downlink Payload: AB 00 1017 -* Example 2: Downlink Payload: AB 01 1167 +* Example 1: Downlink Payload: AB 00 ~/~/ AT+ALLDATAMOD=0 1168 +* Example 2: Downlink Payload: AB 01 ~/~/ AT+ALLDATAMOD=1 1018 1018 1170 +1. 1171 +11. Set the splicing payload for uplink 1019 1019 1020 -== 3.5 Set the splicing payload for uplink == 1021 - 1022 - 1023 1023 Feature, splicing payload for uplink. 1024 1024 1025 - (% style="color:blue" %)**AT Command: AT+DATAUP**1175 +**AT Command: AT+DATAUP** 1026 1026 1027 -(% border="1" cellspacing="4" style="background-color:#f7faff; width:510px" %) 1028 -|=(% style="width: 154px;" %)**Command Example**|=(% style="width: 266px;" %)**Function**|=**Response** 1029 -|(% style="width:154px" %)AT+DATAUP =?|(% style="width:266px" %)Show current splicing payload for uplink mode|((( 1177 +|**Command Example**|**Function**|**Response** 1178 +|AT+DATAUP =?|Show current splicing payload for uplink mode|((( 1030 1030 0 1180 + 1181 + 1031 1031 OK 1032 1032 ))) 1033 -| (% style="width:154px" %)AT+DATAUP =0|(% style="width:266px" %)(((1184 +|AT+DATAUP =0|((( 1034 1034 Set splicing payload for uplink mode is 0. 1186 + 1187 + 1035 1035 )))|((( 1036 1036 OK 1190 + 1191 + 1037 1037 ))) 1038 -|(% style="width:154px" %)AT+DATAUP =1|(% style="width:266px" %)Set splicing payload for uplink mode is 1 , and the each splice uplink is sent sequentially.|OK 1039 -|(% style="width:154px" %)AT+DATAUP =1,20000|(% style="width:266px" %)((( 1040 -Set splicing payload for uplink mode is 1, and the uplink interval of each splice to 20000 milliseconds. 1193 +|AT+DATAUP =1|Set splicing payload for uplink mode is 1 , and the each splice uplink is sent sequentially.|OK 1194 +|AT+DATAUP =1,20000|((( 1195 +Set splicing payload for uplink mode is 1, and the uplink interval of each splice to 20000 milliseconds. 1196 + 1197 + 1041 1041 )))|OK 1042 1042 1043 - (% style="color:blue" %)**Downlink Command: 0xAD**1200 +**Downlink Command: 0xAD** 1044 1044 1045 1045 Format: Command Code (0xAD) followed by 1 bytes or 5 bytes. 1046 1046 1047 -* Example 1: Downlink Payload: AD 00 1048 -* Example 2: Downlink Payload: AD 01 1049 -* Example 3: Downlink Payload: AD 01 00 00 14 1204 +* Example 1: Downlink Payload: AD 00 ~/~/ AT+DATAUP=0 1205 +* Example 2: Downlink Payload: AD 01 ~/~/ AT+DATAUP =1 1206 +* Example 3: Downlink Payload: AD 01 00 00 14~/~/ AT+DATAUP =1,20000 1050 1050 1051 1051 This means that the interval is set to 0x000014=20S 1052 1052 1053 1053 1054 -== 3.6 Set the payload version == 1211 +1. 1212 +11. Set the payload version 1055 1055 1056 - 1057 1057 Feature, Set the payload version. 1058 1058 1059 - (% style="color:blue" %)**AT Command: AT+PAYVER**1216 +**AT Command: AT+PAYVER** 1060 1060 1061 -(% border="1" cellspacing="4" style="background-color:#f7faff; width:437px" %) 1062 -|=(% style="width: 158px;" %)**Command Example**|=(% style="width: 192px;" %)**Function**|=**Response** 1063 -|(% style="width:158px" %)AT+PAYVER=?|(% style="width:192px" %)Show current payload version|((( 1218 +|**Command Example**|**Function**|**Response** 1219 +|AT+PAYVER=?|Show current payload version|((( 1064 1064 1 1221 + 1222 + 1065 1065 OK 1066 1066 ))) 1067 -| (% style="width:158px" %)AT+PAYVER=5|(% style="width:192px" %)Set payload version is 5.|OK1225 +|AT+PAYVER=5|Set payload version is 5.|OK 1068 1068 1069 - (% style="color:blue" %)**Downlink Command: 0xAE**1227 +**Downlink Command: 0xAE** 1070 1070 1071 1071 Format: Command Code (0xAE) followed by 1 bytes. 1072 1072 1073 -* Example 1: Downlink Payload: AE 01 1074 -* Example 2: Downlink Payload: AE 05 1231 +* Example 1: Downlink Payload: AE 01 ~/~/ AT+PAYVER=1 1232 +* Example 2: Downlink Payload: AE 05 ~/~/ AT+PAYVER=5 1075 1075 1234 +1. Battery & how to replace 1235 +11. Battery Type 1076 1076 1077 - =4.Battery&how to replace=1237 +SDI-12-LB is equipped with a [[8500mAH ER26500 Li-SOCI2 battery>>url:https://www.dragino.com/downloads/index.php?dir=datasheet/Battery/ER26500/]]. The battery is un-rechargeable battery with low discharge rate targeting for 8~~10 years use. This type of battery is commonly used in IoT target for long-term running, such as water meter. 1078 1078 1079 -== 4.1 Battery Type == 1080 1080 1081 - 1082 -SDI-12-LB is equipped with a [[8500mAH ER26500 Li-SOCI2 battery>>https://www.dropbox.com/sh/w9l2oa3ytpculph/AAAPtt-apH4lYfCj-2Y6lHvQa?dl=0]]. The battery is un-rechargeable battery with low discharge rate targeting for 8~~10 years use. This type of battery is commonly used in IoT target for long-term running, such as water meter. 1083 - 1084 - 1085 1085 The discharge curve is not linear so can’t simply use percentage to show the battery level. Below is the battery performance. 1086 1086 1087 -[[image: 1675234124233-857.png]]1242 +[[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image036.png]] 1088 1088 1089 1089 1090 1090 Minimum Working Voltage for the SDI-12-LB: ... ... @@ -1092,25 +1092,31 @@ 1092 1092 SDI-12-LB: 2.45v ~~ 3.6v 1093 1093 1094 1094 1095 -== 4.2 Replace Battery == 1250 +1. 1251 +11. Replace Battery 1096 1096 1097 - 1098 1098 Any battery with range 2.45 ~~ 3.6v can be a replacement. We recommend to use Li-SOCl2 Battery. 1099 1099 1100 1100 And make sure the positive and negative pins match. 1101 1101 1102 1102 1103 -== 4.3 Power Consumption Analyze == 1104 1104 1259 +1. 1260 +11. Power Consumption Analyze 1105 1105 1106 1106 Dragino Battery powered product are all runs in Low Power mode. We have an update battery calculator which base on the measurement of the real device. User can use this calculator to check the battery life and calculate the battery life if want to use different transmit interval. 1107 1107 1264 + 1108 1108 Instruction to use as below: 1109 1109 1110 -(% style="color:blue" %)**Step 1:**(%%) Downlink the up-to-date DRAGINO_Battery_Life_Prediction_Table.xlsx from: [[https:~~/~~/www.dropbox.com/sh/zwex6i331j5oeq2/AACIMf9f_v2qsJ39CuMQ5Py_a?dl=0>>https://www.dropbox.com/sh/zwex6i331j5oeq2/AACIMf9f_v2qsJ39CuMQ5Py_a?dl=0]] 1111 1111 1112 - (% style="color:blue" %)**Step2:**(%%)Openand choose1268 +Step 1: Downlink the up-to-date DRAGINO_Battery_Life_Prediction_Table.xlsx from: 1113 1113 1270 +[[https:~~/~~/www.dragino.com/downloads/index.php?dir=LoRa_End_Node/Battery_Analyze/>>url:https://www.dragino.com/downloads/index.php?dir=LoRa_End_Node/Battery_Analyze/]] 1271 + 1272 + 1273 +Step 2: Open it and choose 1274 + 1114 1114 * Product Model 1115 1115 * Uplink Interval 1116 1116 * Working Mode ... ... @@ -1117,47 +1117,56 @@ 1117 1117 1118 1118 And the Life expectation in difference case will be shown on the right. 1119 1119 1281 +[[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image037.png]] 1120 1120 1121 -[[image:1675234155374-163.png]] 1122 1122 1123 - 1124 1124 The battery related documents as below: 1125 1125 1126 -* [[Battery Dimension>>http s://www.dropbox.com/s/ox5g9njwjle7aw3/LSN50-Battery-Dimension.pdf?dl=0]],1127 -* [[Lithium-Thionyl Chloride Battery datasheet, Tech Spec>>http s://www.dropbox.com/sh/d4oyfnp8o94180o/AABQewCNSh5GPeQH86UxRgQQa?dl=0]]1128 -* [[Lithium-ion Battery-Capacitor datasheet>>http s://www.dropbox.com/s/791gjes2lcbfi1p/SPC_1520_datasheet.jpg?dl=0]], [[Tech Spec>>https://www.dropbox.com/s/4pkepr9qqqvtzf2/SPC1520%20Technical%20Specification20171123.pdf?dl=0]]1286 +* [[Battery Dimension>>url:http://www.dragino.com/downloads/index.php?dir=datasheet/Battery/&file=LSN50-Battery-Dimension.pdf]], 1287 +* [[Lithium-Thionyl Chloride Battery>>url:http://www.dragino.com/downloads/downloads/datasheet/Battery/ER18505_datasheet-EN.pdf]] datasheet, [[Tech Spec>>url:http://www.dragino.com/downloads/downloads/datasheet/Battery/ER18505_datasheet_PM-ER18505-S-02-LF_EN.pdf]] 1288 +* [[Lithium-ion Battery-Capacitor datasheet>>url:http://www.dragino.com/downloads/downloads/datasheet/Battery/SPC_1520_datasheet.jpg]], [[Tech Spec>>url:http://www.dragino.com/downloads/downloads/datasheet/Battery/SPC1520%20Technical%20Specification20171123.pdf]] 1129 1129 1130 -[[image:image-20230201145019-19.png]] 1290 +|((( 1291 +JST-XH-2P connector 1292 +))) 1131 1131 1294 +[[image:file:///C:/Users/93456/AppData/Local/Temp/msohtmlclip1/01/clip_image038.png]] 1132 1132 1133 -=== 4.3.1 Battery Note === 1134 1134 1135 1135 1298 +1. 1299 +11. 1300 +111. Battery Note 1301 + 1136 1136 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. 1137 1137 1138 1138 1139 -=== 4.3.2 Replace the battery === 1305 +1. 1306 +11. 1307 +111. Replace the battery 1140 1140 1309 +You can change the battery in the SDI-12-LB.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. 1141 1141 1142 -You can change the battery in the SDI-12-LB.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. 1143 1143 1144 -The default battery pack of SDI-12-LB includes a ER26500 plus super capacitor. If user can 't find this pack locally, they can find ER26500 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)1312 +The default battery pack of SDI-12-LB includes a ER26500 plus super capacitor. If user can’t find this pack locally, they can find ER26500 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) 1145 1145 1146 1146 1147 -= 5. Remote Configure device = 1148 1148 1149 -== 5.1 Connect via BLE == 1150 1150 1151 1151 1152 -Please see this instruction for how to configure via BLE: [[http:~~/~~/wiki.dragino.com/xwiki/bin/view/Main/BLE%20Bluetooth%20Remote%20Configure/>>url:http://wiki.dragino.com/xwiki/bin/view/Main/BLE%20Bluetooth%20Remote%20Configure/]] 1153 1153 1319 +1. Remote Configure device 1320 +11. Connect via BLE 1154 1154 1155 - ==5.2ATCommandSet==1322 +Please see this instruction for how to configure via BLE: 1156 1156 1324 +[[http:~~/~~/wiki.dragino.com/xwiki/bin/view/Main/BLE%20Bluetooth%20Remote%20Configure/>>url:http://wiki.dragino.com/xwiki/bin/view/Main/BLE%20Bluetooth%20Remote%20Configure/]] 1157 1157 1158 1158 1159 -= 6. OTA firmware update = 1327 +1. 1328 +11. AT Command Set 1160 1160 1330 +1. OTA firmware update 1161 1161 1162 1162 Please see this link for how to do OTA firmware update. 1163 1163 ... ... @@ -1164,59 +1164,23 @@ 1164 1164 [[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/]] 1165 1165 1166 1166 1167 -= 7. FAQ = 1168 1168 1169 -== 7.1 How to use AT Command to access device? == 1170 1170 1171 1171 1172 -See: [[http:~~/~~/wiki.dragino.com/xwiki/bin/view/Main/UART%20Access%20for%20LoRa%20ST%20v4%20base%20model/#H1.LoRaSTv4baseHardware>>url:http://wiki.dragino.com/xwiki/bin/view/Main/UART%20Access%20for%20LoRa%20ST%20v4%20base%20model/#H1.LoRaSTv4baseHardware]] 1173 1173 1174 1174 1175 -== 7.2 How to update firmware via UART port? == 1176 1176 1177 1177 1178 -See: [[http:~~/~~/wiki.dragino.com/xwiki/bin/view/Main/UART%20Access%20for%20LoRa%20ST%20v4%20base%20model/#H1.LoRaSTv4baseHardware>>url:http://wiki.dragino.com/xwiki/bin/view/Main/UART%20Access%20for%20LoRa%20ST%20v4%20base%20model/#H1.LoRaSTv4baseHardware]] 1179 1179 1180 1180 1181 - == 7.3How to change the LoRa FrequencyBands/Region? ==1346 +1. Order Info 1182 1182 1348 +**Package Includes**: 1183 1183 1184 -You can follow the instructions for [[how to upgrade image>>doc:Main.Firmware Upgrade Instruction for STM32 base products.WebHome]]. 1185 -When downloading the images, choose the required image file for download. 1350 +* SDI-12-LB SDI-12 to LoRaWAN Converter 1186 1186 1352 +**Dimension and weight**: 1187 1187 1188 -= 8. Order Info = 1189 - 1190 - 1191 -((( 1192 -(% style="color:blue" %)**Part Number: SDI-12-LB-XXX** 1193 -))) 1194 - 1195 -((( 1196 -XXX: The default frequency band 1197 -))) 1198 - 1199 -((( 1200 -(% style="color:red" %)**AS923**(%%): LoRaWAN AS923 band 1201 -(% style="color:red" %)**AU915**(%%): LoRaWAN AU915 band 1202 -(% style="color:red" %)**EU433**(%%): LoRaWAN EU433 band 1203 -(% style="color:red" %)**EU868**(%%): LoRaWAN EU868 band 1204 -(% style="color:red" %)**KR920**(%%): LoRaWAN KR920 band 1205 -(% style="color:red" %)**US915**(%%): LoRaWAN US915 band 1206 -(% style="color:red" %)**IN865**(%%): LoRaWAN IN865 band 1207 -(% style="color:red" %)**CN470**(%%): LoRaWAN CN470 band 1208 -))) 1209 - 1210 - 1211 -= 9. Packing Info = 1212 - 1213 - 1214 -(% style="color:#037691" %)**Package Includes**: 1215 - 1216 -* SDI-12-LB SDI-12 to LoRaWAN Converter x 1 1217 - 1218 -(% style="color:#037691" %)**Dimension and weight**: 1219 - 1220 1220 * Device Size: cm 1221 1221 * Device Weight: g 1222 1222 * Package Size / pcs : cm ... ... @@ -1223,11 +1223,12 @@ 1223 1223 * Weight / pcs : g 1224 1224 1225 1225 1226 -= 10. Support = 1227 1227 1361 +1. Support 1228 1228 1229 1229 * 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. 1364 +* 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 1230 1230 1231 - * 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]]1366 +[[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]] 1232 1232 1233 1233
- 1675216282284-923.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.Xiaoling - Size
-
... ... @@ -1,1 +1,0 @@ 1 -47.0 KB - Content
- 1675216779406-595.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.Xiaoling - Size
-
... ... @@ -1,1 +1,0 @@ 1 -59.2 KB - Content
- 1675234124233-857.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.Xiaoling - Size
-
... ... @@ -1,1 +1,0 @@ 1 -75.8 KB - Content
- 1675234155374-163.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.Xiaoling - Size
-
... ... @@ -1,1 +1,0 @@ 1 -138.2 KB - Content
- image-20230201145019-19.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.Xiaoling - Size
-
... ... @@ -1,1 +1,0 @@ 1 -82.2 KB - Content
- image-20230201152430-20.jpeg
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.Xiaoling - Size
-
... ... @@ -1,1 +1,0 @@ 1 -16.5 KB - Content
- image-20230222143809-1.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.Bei - Size
-
... ... @@ -1,1 +1,0 @@ 1 -322.1 KB - Content