Last modified by Xiaoling on 2023/07/18 10:12

From version 203.1
edited by Edwin Chen
on 2022/10/06 19:30
Change comment: There is no comment for this version
To version 210.2
edited by Xiaoling
on 2022/10/18 14:20
Change comment: There is no comment for this version

Summary

Details

Page properties
Author
... ... @@ -1,1 +1,1 @@
1 -XWiki.Edwin
1 +XWiki.Xiaoling
Content
... ... @@ -62,6 +62,7 @@
62 62  * Datalog feature (Max 3328 records)
63 63  
64 64  
65 +
65 65  == 1.3 Specification ==
66 66  
67 67  
... ... @@ -87,6 +87,7 @@
87 87  * Operating Range: -55 °C ~~ 125 °C
88 88  
89 89  
91 +
90 90  = 2. Connect LHT65N to IoT Server =
91 91  
92 92  
... ... @@ -198,10 +198,9 @@
198 198  
199 199  
200 200  
203 +== 2.4 Uplink Payload   ( Fport~=2) ==
201 201  
202 -== 2.4 Uplink Payload ==
203 203  
204 -
205 205  (((
206 206  The uplink payload includes totally 11 bytes. Uplink packets use FPORT=2 and (% _mstvisible="3" style="color:#4f81bd" %)**every 20 minutes**(%%) send one uplink by default.
207 207  )))
... ... @@ -285,17 +285,13 @@
285 285  
286 286  When the uplink payload arrives TTNv3, it shows HEX format and not friendly to read. We can add LHT65N decoder in TTNv3 for friendly reading.
287 287  
288 -Below is the position to put the decoder and LHT65N decoder can be download from here:
289 +Below is the position to put the decoder and LHT65N decoder can be download from here: [[https:~~/~~/github.com/dragino/dragino-end-node-decoder>>https://github.com/dragino/dragino-end-node-decoder]]
289 289  
290 290  
291 -[[https:~~/~~/www.dropbox.com/sh/r2i3zlhsyrpavla/AAB1sZw3mdT0K7XjpHCITt13a?dl=0 >>https://www.dropbox.com/sh/r2i3zlhsyrpavla/AAB1sZw3mdT0K7XjpHCITt13a?dl=0||_msthash="315253" _msttexthash="3509064" _mstvisible="2"]]
292 -
293 -
294 294  [[image:image-20220522234118-10.png||_mstalt="451464" _mstvisible="3" height="353" width="729"]]
295 295  
296 296  
297 297  
298 -
299 299  === 2.4.2 BAT-Battery Info ===
300 300  
301 301  
... ... @@ -502,11 +502,11 @@
502 502  
503 503  be used to power the external ADC sensor; user can control the power on time for this
504 504  
505 -sensor by setting:
502 +(% style="color:blue" %)**sensor by setting:**
506 506  
507 -AT+EXT=6,timeout  (% _msthash="506085" _msttexthash="8782189" _mstvisible="3" style="color:red" %)**Time to power this sensor, from 0 ~~ 65535ms**
504 +**AT+EXT=6,timeout**  (% _msthash="506085" _msttexthash="8782189" _mstvisible="3" style="color:red" %)**Time to power this sensor, from 0 ~~ 65535ms**
508 508  
509 -For example:
506 +**For example:**
510 510  
511 511  AT+EXT=6,1000 will power this sensor for 1000ms before sampling the ADC value.
512 512  
... ... @@ -550,7 +550,7 @@
550 550  [[image:image-20220927095645-1.png||height="534" width="460"]]
551 551  
552 552  
553 -**Ext=2,Temperature Sensor(TMP117):**
550 +(% style="color:blue" %)**Ext=2,Temperature Sensor(TMP117):**
554 554  
555 555  [[image:image-20220906102307-7.png]]
556 556  
... ... @@ -561,7 +561,6 @@
561 561  
562 562  
563 563  
564 -
565 565  ==== 2.4.6.5 Ext~=4 Interrupt Mode (Since Firmware v1.3) ====
566 566  
567 567  
... ... @@ -570,7 +570,7 @@
570 570  
571 571  (% style="color:blue" %)**Interrupt Mode can be used to connect to external interrupt sensors such as:**
572 572  
573 -**Case 1: Door Sensor.** 3.3v Out for such sensor is just to detect Open/Close.
569 +(% style="color:#037691" %)**Case 1: Door Sensor.** (%%)3.3v Out for such sensor is just to detect Open/Close.
574 574  
575 575   In Open State, the power consumption is the same as if there is no probe
576 576  
... ... @@ -581,7 +581,7 @@
581 581  
582 582  Ext=4,Interrupt Sensor:
583 583  
584 -(% border="2" cellpadding="4" cellspacing="4" style="background-color:#ffffcc; color:green; height:6px; width:512px" %)
580 +(% border="1.5" cellpadding="4" cellspacing="4" style="background-color:#ffffcc; color:green; height:6px; width:512px" %)
585 585  |(% style="width:117px" %)(((
586 586  AT+EXT=4,1
587 587  )))|(% style="width:371px" %)(((
... ... @@ -625,6 +625,7 @@
625 625  
626 626  [[image:image-20220906101320-5.png||height="353" width="696"]]
627 627  
624 +
628 628  Ext=8, Counting Sensor ( 4 bytes):
629 629  
630 630  (% border="2" cellpadding="4" cellspacing="4" style="background-color:#ffffcc; color:green; height:6px; width:381px" %)
... ... @@ -660,52 +660,7 @@
660 660  A2 08 02 00 00 00 3C:  Same as AT+ SETCNT=60  (AT+ SETCNT = 4th byte and 5th byte and 6th byte and 7th byte)
661 661  
662 662  
663 -(% style="color:blue" %)**Modified ATWOOD command for external sensor TMP117 or DS18B20 temperature alarm.**
664 664  
665 -
666 -(% style="color:#037691" %)**AT+WMOD=parameter1,parameter2,parameter3,parameter4**
667 -
668 -(% style="color:#037691" %)**Parameter 1**(%%):  Alarm mode:
669 -
670 -0): Cancel
671 -
672 -1): Threshold alarm
673 -
674 -2): Fluctuation alarm
675 -
676 -
677 -(% style="color:#037691" %)** Parameter 2**(%%):  Sampling time. Unit: seconds, up to 255 seconds.
678 -
679 -(% style="color:red" %)**Note: When the collection time is less than 60 seconds and always exceeds the set alarm threshold, the sending interval will not be the collection time, but will be sent every 60 seconds.**
680 -
681 -
682 -(% style="color:#037691" %) **Parameter 3 and parameter 4:**
683 -
684 -1):  If Alarm Mode is set to 1: Parameter 3 and parameter 4 are valid, as before, they represent low temperature and high temperature.
685 -
686 -Such as AT+WMOD=1,60,45,105, it means high and low temperature alarm.
687 -
688 -
689 -2):  If Alarm Mode is set to 2: Parameter 3 is valid, which represents the difference between the currently collected temperature and the last uploaded temperature.
690 -
691 -Such as AT+WMOD=2,10,2,it means that it is a fluctuation alarm.
692 -
693 -If the difference between the current collected temperature and the last Uplin is ±2 degrees, the alarm will be issued.
694 -
695 -
696 -(% style="color:blue" %)** Downlink:**
697 -
698 -0xA5 00 ~-~- AT+WMOD=0.
699 -
700 -0xA5 01 0A 11 94 29 04 ~-~- AT+WMOD=1,10,45,105  (AT+WMOD = second byte, third byte, fourth and fifth bytes divided by 100, sixth and seventh bytes divided by 100 )
701 -
702 -0xA5 02 0A 02 ~-~- AT+WMOD=2,10,2  (AT+WMOD = second byte, third byte, fourth byte)
703 -
704 -0xA5 FF ~-~- After the device receives it, upload the current alarm configuration (FPORT=8). Such as 01 0A 11 94 29 04 or 02 0A 02.
705 -
706 -
707 -
708 -
709 709  == 2.5 Show data on Datacake ==
710 710  
711 711  
... ... @@ -768,9 +768,16 @@
768 768  
769 769  There are two methods:
770 770  
771 -1. IoT Server sends a downlink LoRaWAN command to [[poll the value>>||anchor="H2.6.4Pollsensorvalue"]] for specifying time range.
772 -1. Set [[PNACKMD=1>>||anchor="H4.13AutoSendNone-ACKmessages"]], LHT65N will wait for ACK for every uplink, when there is no LoRaWAN network, LHT65N will mark these records with non-ack message and store the sensor data, and it will send all messages (10s interval) after the network recovery. note: a) LHT65N will do ack check for data records sending to make sure every data arrive server. b) LHT65N will send data in CONFIRMED Mode when PNACKMD=1, but it won't re-transmit the same packet , it will just mark it as NONE-ACK and resend after network is detected.
723 +(% style="color:blue" %)**Method 1:** (%%)IoT Server sends a downlink LoRaWAN command to [[poll the value>>||anchor="H2.6.4Pollsensorvalue"]] for specified time range.
773 773  
725 +
726 +(% style="color:blue" %)**Method 2: **(%%)Set [[PNACKMD=1>>||anchor="H4.13AutoSendNone-ACKmessages"]], LHT65N will wait for ACK for every uplink, when there is no LoRaWAN network, LHT65N will mark these records with non-ack messages and store the sensor data, and it will send all messages (10s interval) after the network recovery.
727 +
728 +(% style="color:red" %)**Note for method 2:**
729 +
730 +* a) LHT65N will do an ACK check for data records sending to make sure every data arrive server.
731 +* b) LHT65N will send data in **CONFIRMED Mode** when PNACKMD=1, but LHT65N 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 LHT65N gets a ACK, LHT65N will consider there is a network connection and resend all NONE-ACK Message.
732 +
774 774  Below is the typical case for the auto-update datalog feature (Set PNACKMD=1)
775 775  
776 776  
... ... @@ -801,11 +801,11 @@
801 801  
802 802  
803 803  (((
804 -There are two ways to set device's time:
763 +(% style="color:blue" %)**There are two ways to set device's time:**
805 805  )))
806 806  
807 807  (((
808 -**~1. Through LoRaWAN MAC Command (Default settings)**
767 +**1.  Through LoRaWAN MAC Command (Default settings)**
809 809  )))
810 810  
811 811  (((
... ... @@ -1002,9 +1002,9 @@
1002 1002  (((
1003 1003  [[image:image-20221006192726-1.png||height="112" width="754"]]
1004 1004  
1005 -(% class="mark" %)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>>||anchor="H4.13AutoSendNone-ACKmessages"]] feature)
964 +(% class="mark" %)**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>>||anchor="H4.13AutoSendNone-ACKmessages"]] feature)
1006 1006  
1007 -(% class="mark" %)Poll Message Flag(%%): 1: This message is a poll message reply.
966 +(% class="mark" %)**Poll Message Flag**(%%): 1: This message is a poll message reply.
1008 1008  
1009 1009  
1010 1010  )))
... ... @@ -1055,7 +1055,7 @@
1055 1055  (((
1056 1056  (% _msthash="736725" _msttexthash="1065532" _mstvisible="3" %)
1057 1057  (((
1058 -a) DR0: max is 11 bytes so one entry of data
1017 +**a) DR0:** max is 11 bytes so one entry of data
1059 1059  )))
1060 1060  )))
1061 1061  )))
... ... @@ -1066,7 +1066,7 @@
1066 1066  (((
1067 1067  (% _msthash="736726" _msttexthash="3265665" _mstvisible="3" %)
1068 1068  (((
1069 -b) DR1: max is 53 bytes so devices will upload 4 entries of data (total 44 bytes)
1028 +**b) DR1:** max is 53 bytes so devices will upload 4 entries of data (total 44 bytes)
1070 1070  )))
1071 1071  )))
1072 1072  )))
... ... @@ -1077,7 +1077,7 @@
1077 1077  (((
1078 1078  (% _msthash="736727" _msttexthash="1454115" _mstvisible="3" style="text-align: left;" %)
1079 1079  (((
1080 -c) DR2: total payload includes 11 entries of data
1039 +**c) DR2:** total payload includes 11 entries of data
1081 1081  )))
1082 1082  )))
1083 1083  )))
... ... @@ -1088,7 +1088,7 @@
1088 1088  (((
1089 1089  (% _msthash="736728" _msttexthash="1483924" _mstvisible="3" style="text-align: left;" %)
1090 1090  (((
1091 -d) DR3: total payload includes 22 entries of data.
1050 +**d) DR3: **total payload includes 22 entries of data.
1092 1092  )))
1093 1093  )))
1094 1094  )))
... ... @@ -1099,7 +1099,7 @@
1099 1099  (((
1100 1100  (% _msthash="736729" _msttexthash="5848349" _mstvisible="3" style="text-align: left;" %)
1101 1101  (((
1102 -If devise doesnt have any data in the polling time. Device will uplink 11 bytes of 0   
1061 +If devise doesn't have any data in the polling time. Device will uplink 11 bytes of 0   
1103 1103  )))
1104 1104  )))
1105 1105  )))
... ... @@ -1200,17 +1200,42 @@
1200 1200  (((
1201 1201  (% style="color:red" %)**Note: alarm mode adds a little power consumption, and we recommend extending the normal read time when this feature is enabled.**
1202 1202  
1162 +
1163 +
1164 +=== 2.7.1 ALARM MODE ( Since v1.3.1 firmware) ===
1165 +
1166 +
1167 +(((
1168 +(% class="box infomessage" %)
1169 +(((
1170 +**AT+WMOD=3,**:  Enable/disable alarm mode. (0: Disabled, 1: Enabled Temperature Alarm for onboard temperature sensor)
1171 +
1172 +**AT+CITEMP=1**:  The interval between checking the alarm temperature. (In minutes)
1173 +
1174 +**AT+ARTEMP**:  Gets or sets the alarm range of the internal temperature sensor
1175 +
1176 +**AT+ARTEMP=? **:  Gets the alarm range of the internal temperature sensor(% _mstvisible="3" style="display:none" %)
1177 +
1178 +**AT+ARTEMP=45,105**:  Set the internal temperature sensor alarm range from 45 to 105.
1179 +
1180 +**AT+LEDALARM=1** :       Enable LED visual Alarm.
1181 +)))
1182 +)))
1183 +
1184 +
1203 1203  
1204 1204  )))
1205 1205  
1206 1206  (((
1207 -**AT COMMAND FOR ALARM MODE:**
1189 +=== 2.7.2 ALARM MODE ( Before v1.3.1 firmware) ===
1190 +
1191 +
1208 1208  )))
1209 1209  
1210 1210  (% _mstvisible="1" class="box infomessage" %)
1211 1211  (((
1212 1212  (((
1213 -**AT+WMOD=1**:  Enable/disable alarm mode. (0: Disabled, 1: Enabled)
1197 +**AT+WMOD=1**:  Enable/disable alarm mode. (0: Disabled, 1: Enabled Temperature Alarm for onboard temperature sensor)
1214 1214  )))
1215 1215  
1216 1216  (((
... ... @@ -1384,11 +1384,11 @@
1384 1384  
1385 1385  Format: Command Code (0x01) followed by 3 bytes time value.
1386 1386  
1387 -If the downlink payload=0100003C, it means set the END Nodes Transmit Interval to 0x00003C=60(S), while type code is 01.
1371 +If the downlink payload=0100003C, it means set the END Node's Transmit Interval to 0x00003C=60(S), while type code is 01.
1388 1388  
1389 -* **Example 1**: Downlink Payload: 0100001E ~/~/ Set Transmit Interval (TDC) = 30 seconds
1373 +* **Example 1**: Downlink Payload: 0100001E  ~/~/ Set Transmit Interval (TDC) = 30 seconds
1390 1390  
1391 -* **Example 2**: Downlink Payload: 0100003C ~/~/ Set Transmit Interval (TDC) = 60 seconds
1375 +* **Example 2**: Downlink Payload: 0100003C  ~/~/ Set Transmit Interval (TDC) = 60 seconds
1392 1392  
1393 1393  
1394 1394  
... ... @@ -1515,7 +1515,7 @@
1515 1515  
1516 1516  (% _msthash="315254" _msttexthash="298038" style="color:#4f81bd" %)**Downlink Command:**
1517 1517  
1518 -0x306007806000  ~/~/ Set timestamp to 0x(6007806000),Same as AT+TIMESTAMP=1611104352
1502 +0x306007806000  ~/~/  Set timestamp to 0x(6007806000),Same as AT+TIMESTAMP=1611104352
1519 1519  
1520 1520  
1521 1521  
... ... @@ -1557,7 +1557,7 @@
1557 1557  
1558 1558  (% _msthash="315257" _msttexthash="298038" style="color:#4f81bd" %)**Downlink Command:**
1559 1559  
1560 -**0x29 0A** ~/~/ Same as AT+SYNCTDC=0x0A
1544 +**0x29 0A**  ~/~/ Same as AT+SYNCTDC=0x0A
1561 1561  
1562 1562  
1563 1563  
... ... @@ -1608,7 +1608,7 @@
1608 1608  
1609 1609  (% style="color:#4f81bd" %)**Downlink Command: 0xA3**
1610 1610  
1611 -* Example: 0xA301 ~/~/Same as AT+CLRDTA
1595 +* Example: 0xA301  ~/~/  Same as AT+CLRDTA
1612 1612  
1613 1613  
1614 1614  
... ... @@ -1630,10 +1630,61 @@
1630 1630  
1631 1631  (% style="color:#4f81bd" %)**Downlink Command: 0x34**
1632 1632  
1633 -* Example: 0x3401 ~/~/Same as AT+PNACKMD=1
1617 +* Example: 0x3401  ~/~/  Same as AT+PNACKMD=1
1634 1634  
1635 1635  
1636 1636  
1621 +== 4.14 Modified ATWOOD command for external sensor TMP117 or DS18B20 temperature alarm ==
1622 +
1623 +
1624 +Feature: Set internal and external temperature sensor alarms.
1625 +
1626 +(% border="1" style="background-color:#ffffcc; color:green; width:450px" %)
1627 +|(%%)(% _msthash="1231737" _msttexthash="251862" _mstvisible="6" %)**Command Example**|(%%)(% _msthash="1231738" _msttexthash="116025" _mstvisible="6" %)**Function**|(%%)(% _msthash="1231739" _msttexthash="116831" _mstvisible="6" %)**Response**
1628 +|(%%)(% style="color:#037691" %)AT+WMOD=parameter1,parameter2,parameter3,parameter4|Set internal and external temperature sensor alarms|OK
1629 +
1630 +(% style="color:#037691" %)**AT+WMOD=parameter1,parameter2,parameter3,parameter4**
1631 +
1632 +(% style="color:#037691" %)**Parameter 1**(%%):  Alarm mode:
1633 +
1634 +0): Cancel
1635 +
1636 +1): Threshold alarm
1637 +
1638 +2): Fluctuation alarm
1639 +
1640 +
1641 +(% style="color:#037691" %)** Parameter 2**(%%):  Sampling time. Unit: seconds, up to 255 seconds.
1642 +
1643 +(% style="color:red" %)**Note: When the collection time is less than 60 seconds and always exceeds the set alarm threshold, the sending interval will not be the collection time, but will be sent every 60 seconds.**
1644 +
1645 +
1646 +(% style="color:#037691" %) **Parameter 3 and parameter 4:**
1647 +
1648 +1):  If Alarm Mode is set to 1: Parameter 3 and parameter 4 are valid, as before, they represent low temperature and high temperature.
1649 +
1650 +Such as AT+WMOD=1,60,45,105, it means high and low temperature alarm.
1651 +
1652 +
1653 +2):  If Alarm Mode is set to 2: Parameter 3 is valid, which represents the difference between the currently collected temperature and the last uploaded temperature.
1654 +
1655 +Such as AT+WMOD=2,10,2,it means that it is a fluctuation alarm.
1656 +
1657 +If the difference between the current collected temperature and the last Uplin is ±2 degrees, the alarm will be issued.
1658 +
1659 +
1660 +(% style="color:#4f81bd" %)**Downlink Command: 0xA5**
1661 +
1662 +0xA5 00 ~-~- AT+WMOD=0.
1663 +
1664 +0xA5 01 0A 11 94 29 04 ~-~- AT+WMOD=1,10,45,105  (AT+WMOD = second byte, third byte, fourth and fifth bytes divided by 100, sixth and seventh bytes divided by 100 )
1665 +
1666 +0xA5 02 0A 02 ~-~- AT+WMOD=2,10,2  (AT+WMOD = second byte, third byte, fourth byte)
1667 +
1668 +0xA5 FF ~-~- After the device receives it, upload the current alarm configuration (FPORT=8). Such as 01 0A 11 94 29 04 or 02 0A 02.
1669 +
1670 +
1671 +
1637 1637  = 5. Battery & How to replace =
1638 1638  
1639 1639  
... ... @@ -1703,7 +1703,6 @@
1703 1703  * (% style="background-color:yellow" %)**USB to TTL GND <~-~->GND**
1704 1704  * (% style="background-color:yellow" %)**USB to TTL RXD <~-~-> D+**
1705 1705  * (% style="background-color:yellow" %)**USB to TTL TXD <~-~-> A11**
1706 -* (% style="background-color:yellow" %)**USB to TTL 3.3V <~-~-> D-**
1707 1707  
1708 1708  (((
1709 1709  In PC, User needs to set serial tool(such as [[**putty**>>https://www.chiark.greenend.org.uk/~~sgtatham/putty/latest.html]], SecureCRT) baud rate to (% style="color:green" %)**9600**(%%) to access to access serial console for LHT65N. The AT commands are disable by default and need to enter password (default:(% style="color:green" %)**123456**) (%%)to active it. Timeout to input AT Command is 5 min, after 5-minute, user need to input password again. User can use AT+DISAT command to disable AT command before timeout.