CN113254259A - 一种用于改善低精度浮点数传输效率的方法 - Google Patents

一种用于改善低精度浮点数传输效率的方法 Download PDF

Info

Publication number
CN113254259A
CN113254259A CN202110505175.8A CN202110505175A CN113254259A CN 113254259 A CN113254259 A CN 113254259A CN 202110505175 A CN202110505175 A CN 202110505175A CN 113254259 A CN113254259 A CN 113254259A
Authority
CN
China
Prior art keywords
data
precision
decimal
reserved
recombined
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN202110505175.8A
Other languages
English (en)
Other versions
CN113254259B (zh
Inventor
庄未
张楠
黄用华
张瑞欣
林英鹏
孙永厚
刘夫云
黄美发
钟艳如
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Guilin University of Electronic Technology
Original Assignee
Guilin University of Electronic Technology
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Guilin University of Electronic Technology filed Critical Guilin University of Electronic Technology
Priority to CN202110505175.8A priority Critical patent/CN113254259B/zh
Publication of CN113254259A publication Critical patent/CN113254259A/zh
Application granted granted Critical
Publication of CN113254259B publication Critical patent/CN113254259B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/08Error detection or correction by redundancy in data representation, e.g. by using checking codes
    • G06F11/10Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
    • G06F11/1004Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's to protect a block of data words, e.g. CRC or checksum
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W28/00Network traffic management; Network resource management
    • H04W28/02Traffic management, e.g. flow control or congestion control
    • H04W28/06Optimizing the usage of the radio link, e.g. header compression, information sizing, discarding information
    • H04W28/065Optimizing the usage of the radio link, e.g. header compression, information sizing, discarding information using assembly or disassembly of packets
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/30Services specially adapted for particular environments, situations or purposes
    • H04W4/38Services specially adapted for particular environments, situations or purposes for collecting sensor information
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D30/00Reducing energy consumption in communication networks
    • Y02D30/70Reducing energy consumption in communication networks in wireless communication networks

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Quality & Reliability (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Compression, Expansion, Code Conversion, And Decoders (AREA)

Abstract

本发明公开一种用于改善低精度浮点数传输效率的方法,针对物联网中的传感器采集的低精度浮点型数据进行精度保留和归类,采用了对采集到的十进制整数进行每三位划分为一组的方法,将每三位十进制整数为一组的数据转换为二进制数据,再转换为十六进制数据,具有压缩率较高,冗余位较少,存储量少,不受压缩格式束缚等优势,尤其适用于低精度浮点数传输,可广泛用于物联网的数据处理等领域。

Description

一种用于改善低精度浮点数传输效率的方法
技术领域
本发明涉及物联网技术领域,具体涉及一种用于改善低精度浮点数传输效率的方法。
背景技术
信息传输技术在各个领域之中应用广泛,而在控制工程领域中,数据传输在通信过程中具有至关重要的作用。在物联网中,由于无线传输相较于有线传输相对容易受外界电磁干扰,因此如何快速有效的传输数据,对于物联网的数据的传输是非常关键的。例如监测移动机器人所采集信息,或者检测无人机的运行状态等。
公开号为CN111404907A的中国发明专利申请,公开了一种基于IEEE754格式的数据压缩传输方法,基于IEEE754双精度浮点型格式转化成8字节数据,对一组或多组8字节数据进行组装,打包成一帧完整压缩数据后,将数据进行发送。虽然该方法对浮点型数据进行重新整合、转换,在保证数据不失真的条件下,降低了数据传输的字节数量。但是受限于上述方法所采用的数据组装格式,导致数据存在部分冗余位,进一步导致压缩比的降低。
发明内容
本发明所要解决的是在移动设备进行数据无线传输时,针对部分低精度浮点数传输效率增加,降低传输压缩比的问题,提供一种用于改善低精度浮点数传输效率的方法,其在固定字节数下的压缩率更高,剩余的冗余位更少。
为解决上述问题,本发明是通过以下技术方案实现的:
一种用于改善低精度浮点数传输效率的方法,包括步骤如下:
步骤1、采集传感器的数据,并将所采集的数据统一转换为十进制数据,并对十进制数据进行精度保留,使各个十进制数据保留统一的精度;
步骤2、根据步骤1所得的保留精度后的十进制数据,确定重组数据的符号位,即:
步骤2.1、以传感器的标号从后往前的顺序,依次将每三个传感器所对应的保留精度后的十进制数据划分为一组;当该组中保留精度后的十进制数据为正数时标记为0,当该组中保留精度后的十进制数据为负数时标记为1,并根据该组保留精度后的十进制数据的三个正负数的标记所对应的二进制真值表,得到这该组保留精度后的十进制数据的符号位;
步骤2.2、对于每三个传感器为一组所余下传感器的保留精度后的十进制数据,分别判断该保留精度后的十进制数据是否满足
Figure BDA0003058115980000011
如果是,则该保留精度后的十进制数据的符号位为空;否则,进一步判断保留精度后的十进制数据为正数还是负数:如果是正数,则该保留精度后的十进制数据的符号位为0;如果是负数,则该保留精度后的十进制数据的符号位为1;
步骤2.3、按传感器的标号从后往前的顺序,将步骤2.1和2.2所得的符号位进行组合后得到重组数据的符号位;
步骤3、根据步骤1所得的保留精度后的十进制数据,确定重组数据的数据位,即:
步骤3.1、对于每三个传感器为一组所余下传感器的保留精度后的十进制数据,对其中满足
Figure BDA0003058115980000021
的保留精度后的十进制数据,采用下式对该保留精度后的十进制数据进行更新:
Figure BDA0003058115980000022
其中,n′表示更新后的保留精度后的十进制数据,n表示更新前的保留精度后的十进制数据,J表示更新前的保留精度后的十进制数据的整数位数,Sign(n)表示符号函数,
Figure BDA0003058115980000023
步骤3.2、对于每个保留精度后的十进制数据:
步骤3.2.1、根据保留精度后的十进制数据所对应的传感器的取值范围确定该保留精度后的十进制数据的预定整数位数,其中保留精度后的十进制数据的预定整数位数等于其所对应的传感器的取值范围的上下限中的较多位数;
步骤3.2.2、对保留精度后的十进制数据的整数部分的位数未达到其预定整数位数的,通过在该保留精度后的十进制数据的整数部分前补0的方式使其整数部分达到其预定整数位数;
步骤3.2.3、对保留精度后的十进制数据取绝对值,并去除小数点后,得到每个传感器的数据位;
步骤3.2.4、按传感器的标号从后往前的顺序,将步骤3.2.3所得的每个传感器的数据位进行组合后得到重组数据的数据位;
步骤4、将步骤2所得的重组数据的符号位在前,将步骤3所得的重组数据的数据位在后,对重组数据的符号位和重组数据的数据位进行组合,得到重组数据;
步骤5、将步骤4所得的重组数据按从后往前的顺序,每三个位一组分别转换为十二位的二进制数,并每组的十二位的二进制数的前两位舍弃后,变为十位的二进制数,将重组数据转换为二进制的重组数据;
步骤6、将步骤5所得的二进制的重组数据按从后往前的顺序,每八位位一组分别转换为十六进制的重组数据;
步骤7、将步骤6所得的十六进制的重组数据按字节依次相加,并取其最低位字节得到校验和;
步骤8、先将步骤6所得的十六进制的重组数据作为待传输数据的前部,将步骤7所得的校验和作为待传输数据的后部;再在待传输数据的前后分别加入数据头和数据尾,组装成一组完整的传输数据帧进行发送。
上述步骤2中,采用直接去除或四舍五入方法对十进制数据进行精度保留。
上述步骤5中,若重组数据的位数不为3的倍数,则需要在重组数据的前面通过0进行补全,使重组数据的位数变为3的倍数。
与现有技术相比,本发明针对物联网中的传感器采集的低精度浮点型数据进行精度保留和归类,采用了对采集到的十进制整数进行每三位划分为一组的方法,将每三位十进制整数为一组的数据转换为二进制数据,再转换为十六进制数据,具有压缩率较高,冗余位较少,存储量少,不受压缩格式束缚等优势,尤其适用于低精度浮点数传输,可广泛用于物联网的数据处理等领域。
附图说明
图1为一种用于改善低精度浮点数传输效率的方法的流程图;
图2为压缩数据(发送数据)与解压缩数据(接收数据)对比图。
具体实施方式
为使本发明的目的、技术方案和优点更加清楚明白,以下结合具体实施例和应用例,对本发明进一步详细说明。
一种用于改善低精度浮点数传输效率的方法,如图1所示,包括步骤如下:
步骤1、采集传感器的数据,并将所采集的数据统一转换为十进制数据,并对十进制数据进行精度保留,使各个十进制数据保留统一的精度。
多个传感器同时采集数据,通过传感器的取值范围,整理数据,统一为十进制数据。在本实施例中,传感器1~8所采集并统一转化为十进制的数据,且传感器1~8中采集的数据在监测时均不需要很高的精度,记为a1~a8,假设采集的数据a1~a8为-169.224、12.3014、736.489、53.2159、-462.364、-45.36、-99.3705、-65.24,如表1所示:
表1
数据 a<sub>1</sub> a<sub>2</sub> a<sub>3</sub> a<sub>4</sub>
-169.224 12.3014 736.489 53.2159
数据 a<sub>5</sub> a<sub>6</sub> a<sub>7</sub> a<sub>8</sub>
-462.364 -45.36 -99.3705 -65.24
在对部分数据进行监测时,并不需要很高的精度,此时可对步骤1)中得到的十进制数据进行精度保留,一般保留1~3位。在本实施例中,每个数据均保留小数点后一位精度(数据精度应根据实际需要来定,可采用直接去除或四舍五入的保留形式,此处采用直接去除的方式,仅作为举例说明),如表2所示:
表2
数据 a<sub>1</sub> a<sub>2</sub> a<sub>3</sub> a<sub>4</sub>
-169.2 12.3 736.4 53.2
数据 a<sub>5</sub> a<sub>6</sub> a<sub>7</sub> a<sub>8</sub>
-462.3 -45.3 -99.3 -65.2
步骤2、根据步骤1所得的保留精度后的十进制数据,确定重组数据的符号位。
步骤2.1、以传感器的标号从后往前的顺序,依次将每三个传感器所对应的保留精度后的十进制数据划分为一组;当该组中保留精度后的十进制数据为正数时标记为0,当该组中保留精度后的十进制数据为负数时标记为1,并根据该组保留精度后的十进制数据的三个正负数的标记所对应的二进制真值表,得到这该组保留精度后的十进制数据的符号位。
以三个保留精度后的十进制数据ai、aj、az(i≠j≠z)为一个组进行处理,当该组中的保留精度后的十进制数据为正数时标记为0,为负数时标记为1,并根据该组三个保留精度后的十进制数据的正负数标记得到该单元的符号位,如表3所示:
表3
Figure BDA0003058115980000041
步骤2.2、对于每三个传感器为一组所余下传感器的保留精度后的十进制数据,分别判断该保留精度后的十进制数据是否满足
Figure BDA0003058115980000042
如果是,则该保留精度后的十进制数据的符号位为空;否则,进一步判断保留精度后的十进制数据为正数还是负数:如果是正数,则该保留精度后的十进制数据的符号位为0;如果是负数,则该保留精度后的十进制数据的符号位为1。
步骤2.3、按传感器的标号从后往前的顺序,将步骤2.1和2.2所得的符号位进行组合后得到重组数据的符号位。
由于本实施例中的传感器的总数为8,则:首先,将a6-a8形成一组,其a6为负数,标记为0,a7为负数,标记为0,a8为负数,标记为0,则该组保留精度后的十进制数据的符号位为0。将a3-a5形成一组,其a3为正数,标记为1,a4为正数,标记为1,a5为负数,标记为0,则该组保留精度后的十进制数据的符号位为6。然后,对于余下的a2和a1进行判断:余下的a2满足
Figure BDA0003058115980000051
则a2的符号位为0;余下的a1满足
Figure BDA0003058115980000052
则a1的符号位为空。最后,按传感器的标号从后往前的顺序,将所得到符号位进行组合,得到重组数据的符号位为60。
步骤3、根据步骤1所得的保留精度后的十进制数据,确定重组数据的数据位。
步骤3.1、对于每三个传感器为一组所余下传感器的保留精度后的十进制数据,对其中为负数,且满足
Figure BDA0003058115980000053
的保留精度后的十进制数据,采用下式对该保留精度后的十进制数据进行更新:
Figure BDA0003058115980000054
其中,n′表示更新后的保留精度后的十进制数据,n表示更新前的保留精度后的十进制数据,J表示更新前的保留精度后的十进制数据的整数位数,Sign(n)表示符号函数,
Figure BDA0003058115980000055
在本实施例中,仅有a1 a2需要进行更新,而其他a3-a7不需要进行更新。根据公式计算更新后的a2
Figure BDA0003058115980000056
a1
Figure BDA0003058115980000057
此时,所得到的保留精度后的十进制数据如表4:
表4
数据 a<sub>1</sub> a<sub>2</sub> a<sub>3</sub> a<sub>4</sub>
669.2 12.3 736.4 53.2
数据 a<sub>5</sub> a<sub>6</sub> a<sub>7</sub> a<sub>8</sub>
-462.3 -45.3 -99.3 -65.2
步骤3.2、对于每个保留精度后的十进制数据,执行以下步骤:
步骤3.2.1、根据保留精度后的十进制数据所对应的传感器的取值范围确定该保留精度后的十进制数据的预定整数位数,其中保留精度后的十进制数据的预定整数位数等于其所对应的传感器的取值范围的上下限中的较多位数。
在本实施例中,a1、a3、a5、a7的取值范围为(-1000,1000),则a1、a3、a5、a7的整数位数为3;a2、a4、a6、a8的取值范围为(-100,100),则a2、a4、a6、a8的整数位数为2。
步骤3.2.2、对保留精度后的十进制数据的整数部分的位数未达到其预定整数位数的,通过在该保留精度后的十进制数据的整数部分前补0的方式使其整数部分达到其预定整数位数。
在本实施例中,仅a7的整数部分未达到其预定整数位数,因此需要用0进行补全,而其他a1-a6,a8的整数部分达到其预定整数位数,因此不需要用0进行补全。如表5所示:
表5
数据 a<sub>1</sub> a<sub>2</sub> a<sub>3</sub> a<sub>4</sub>
669.2 12.3 736.4 53.2
数据 a<sub>5</sub> a<sub>6</sub> a<sub>7</sub> a<sub>8</sub>
-462.3 -45.3 -099.3 -65.2
步骤3.2.3、对保留精度后的十进制数据取绝对值,并去除小数点后,得到每个传感器的数据位。
在本实施例中,每个传感器的数据位如表6所示:
表6
数据 a<sub>1</sub> a<sub>2</sub> a<sub>3</sub> a<sub>4</sub>
6692 123 7364 532
数据 a<sub>5</sub> a<sub>6</sub> a<sub>7</sub> a<sub>8</sub>
4623 453 0993 652
步骤3.2.4、按传感器的标号从后往前的顺序,将步骤3.2.3所得的每个传感器的数据位进行组合后得到重组数据的数据位。
在本实施例中,得到重组数据的数据位为:
6692123736453246234530993652
步骤4、将步骤2所得的重组数据的符号位在前,将步骤3所得的重组数据的数据位在后,对重组数据的符号位和重组数据的数据位进行组合,得到重组数据。
在本实施例中,得到重组数据位为:
606692123736453246234530993652
步骤5、将步骤4所得的重组数据按从后往前的顺序,每三个位一组分别转换为十二位的二进制数,并每组的十二位的二进制数的前两位舍弃后,变为十位的二进制数,将重组数据转换为二进制的重组数据。
十进制数据按三位一组分组:用最小位的二进制表示最大位的十进制,如下表7所示:
表7
Figure BDA0003058115980000061
Figure BDA0003058115980000071
经过2n≥10m可得:当n=10,m=3时可节约冗余位,使得利用空间最大化,所以按每三位为一组进行转换。
在本实施例中,将所有十进制数据去除小数点依次排开,从后往前按每三位一组。
6 0 6 6 9 2 1 2 3 7 3 6 4 5 3 2 4 6 2 3 4 5 3 0 9 9 3 6 5 2
将其转换为十位的二进制如表8所示:
表8
Figure BDA0003058115980000072
步骤6、将步骤5所得的二进制的重组数据按从后往前的顺序,每八位位一组分别转换为十六进制的重组数据。
将所有二进制数据从后往前依次按每八位二进制进行分组210=1024。在本实施例中,将所有二进制数据依次排开,从后往前按每八位一组。
1 0 0 1 0 1 1 1 1 0 1 0 1 0 1 1 0 1 0 0 0 0 0 1 1 1 1 0 1 1 1 0 1 1 1 0
0 0 0 0 0 1 1 1 0 0 0 1 0 1 0 0 1 1 1 0 0 1 1 0 0 0 1 1 1 0 1 0
1 0 1 0 0 0 0 1 0 0 1 0 1 1 1 1 1 0 0 0 0 1 1 0 1 0 0 0 1 1 0 0将其转换为十六进制的重组数据如表9所示:
表9
Figure BDA0003058115980000073
步骤7、将步骤6所得的十六进制的重组数据按字节依次相加,并取其最低位字节得到校验和。
校验和是判断一组数据是否准确,初始化校验和是每次压缩一帧完整数据前对校验位进行归零处理。
在本实施例中,校验和为:
9+7A+B4+1E+EE+7+14+E6+3A+A1+2F+86+8C=560。
步骤8、先将步骤6所得的十六进制的重组数据作为待传输数据的前部,将步骤7所得的校验和作为待传输数据的后部;再在待传输数据的前后分别加入数据头和数据尾,组装成一组完整的传输数据帧进行发送。
在本实施例中,传输数据帧如表10所示:
表10
Figure BDA0003058115980000081
当传感器所采集的数据经过上述步骤1-8的处理发送出去后,接收端执行如下步骤完成数据的解压缩过程:1)检验接收到的数据是否为一帧完整的数据,并检测接收到的一帧数据是否有正确的数据头和数据尾:若全是,则去除数据头和数据尾,并转至2)。否则,丢弃该数据,重新接收数据并判断是否符合要求。2)去除数据头和数据尾后,将剩余的字节数据从第一个依次相加至倒数第一个,比较其结果的低八位的数据与校验和是否相等,相等则表示正确,出去校验和即可得到一组完整并正确的数据。3)去除校验和,得到一组完整的十六进制字节数据。4)将十六进制字节数据转换为二进制数据。5)处理二进制数据的符号位和数据位,并二进制数据按每十位为一组依次转换为十进制整数数据。6)将得到的十进制整数,按压缩前的组装格式进行分离再重组,并按压缩前的方式处理十进制数据的精度和符号,得到压缩前的数据。
下面通过实验对本发明的性能进行验证:
根据需求所设置的参数取值范围如表11所示。
表11
Figure BDA0003058115980000082
本实验以16个参数为例,其中每个参数根据需求设置其有效范围和需要保留的精确度。a1~a16的初值设置如表12所示,其中a15、a16为时间值,a15初定值为0,a16为一个线性函数每次以1递增。
表12
数据变量名 a<sub>1</sub> a<sub>2</sub> a<sub>3</sub> a<sub>4</sub>
数据 -107.2 88.6 263.2 68.4
数据变量名 a<sub>5</sub> a<sub>6</sub> a<sub>7</sub> a<sub>8</sub>
数据 -854.8 14.0 -734.8 17.4
数据变量名 a<sub>9</sub> a<sub>10</sub> a<sub>11</sub> a<sub>12</sub>
数据 657.8 12.6 -664.5 83.6
数据变量名 a<sub>13</sub> a<sub>14</sub> a<sub>15</sub> a<sub>16</sub>
数据 -124.8 -17.6 0 x
确定初值,本实验采用在变量取值范围内随机发送数据,记录随机发送的数据,再对数据进行压缩和解压缩处理,再次记录解压缩后的数据。对比原始数据与解压缩后的数据,如图2的a1-a16所示,图中虚线代表压缩的数据、实线代表解压缩后的数据,由图可见,本发明保证了数据压缩的准确性、一致性。
如表13将本发明方法与现有方法(公开号为CN111404907A的中国发明专利申请)进行对比:
表13
程序 浮点数个数 字节数
现有方法 16 35byte
本发明方法 19 28byte
通过上述实验得出以下结论:当浮点数一样,采用本发明方式对数据进行压缩处理具有压缩比更高、冗余位更少的优点,解压缩后的数据也与压缩前的数据一致。同时,本发明方法可以改善低精度浮点数传输的效率。
需要说明的是,尽管以上本发明所述的实施例是说明性的,但这并非是对本发明的限制,因此本发明并不局限于上述具体实施方式中。在不脱离本发明原理的情况下,凡是本领域技术人员在本发明的启示下获得的其它实施方式,均视为在本发明的保护之内。

Claims (3)

1.一种用于改善低精度浮点数传输效率的方法,其特征是,包括步骤如下:
步骤1、采集传感器的数据,并将所采集的数据统一转换为十进制数据,并对十进制数据进行精度保留,使各个十进制数据保留统一的精度;
步骤2、根据步骤1所得的保留精度后的十进制数据,确定重组数据的符号位,即:
步骤2.1、以传感器的标号从后往前的顺序,依次将每三个传感器所对应的保留精度后的十进制数据划分为一组;当该组中保留精度后的十进制数据为正数时标记为0,当该组中保留精度后的十进制数据为负数时标记为1,并根据该组保留精度后的十进制数据的三个正负数的标记所对应的二进制真值表,得到这该组保留精度后的十进制数据的符号位;
步骤2.2、对于每三个传感器为一组所余下传感器的保留精度后的十进制数据,分别判断该保留精度后的十进制数据是否满足
Figure FDA0003058115970000011
如果是,则该保留精度后的十进制数据的符号位为空;否则,进一步判断保留精度后的十进制数据为正数还是负数:如果是正数,则该保留精度后的十进制数据的符号位为0;如果是负数,则该保留精度后的十进制数据的符号位为1;
步骤2.3、按传感器的标号从后往前的顺序,将步骤2.1和2.2所得的符号位进行组合后得到重组数据的符号位;
步骤3、根据步骤1所得的保留精度后的十进制数据,确定重组数据的数据位,即:
步骤3.1、对于每三个传感器为一组所余下传感器的保留精度后的十进制数据,对其中满足
Figure FDA0003058115970000012
的保留精度后的十进制数据,采用下式对该保留精度后的十进制数据进行更新:
Figure FDA0003058115970000013
其中,n′表示更新后的保留精度后的十进制数据,n表示更新前的保留精度后的十进制数据,J表示更新前的保留精度后的十进制数据的整数位数,Sign(n)表示符号函数,
Figure FDA0003058115970000014
步骤3.2、对于每个保留精度后的十进制数据:
步骤3.2.1、根据保留精度后的十进制数据所对应的传感器的取值范围确定该保留精度后的十进制数据的预定整数位数,其中保留精度后的十进制数据的预定整数位数等于其所对应的传感器的取值范围的上下限中的较多位数;
步骤3.2.2、对保留精度后的十进制数据的整数部分的位数未达到其预定整数位数的,通过在该保留精度后的十进制数据的整数部分前补0的方式使其整数部分达到其预定整数位数;
步骤3.2.3、对保留精度后的十进制数据取绝对值,并去除小数点后,得到每个传感器的数据位;
步骤3.2.4、按传感器的标号从后往前的顺序,将步骤3.2.3所得的每个传感器的数据位进行组合后得到重组数据的数据位;
步骤4、将步骤2所得的重组数据的符号位在前,将步骤3所得的重组数据的数据位在后,对重组数据的符号位和重组数据的数据位进行组合,得到重组数据;
步骤5、将步骤4所得的重组数据按从后往前的顺序,每三个位一组分别转换为十二位的二进制数,并每组的十二位的二进制数的前两位舍弃后,变为十位的二进制数,将重组数据转换为二进制的重组数据;
步骤6、将步骤5所得的二进制的重组数据按从后往前的顺序,每八位位一组分别转换为十六进制的重组数据;
步骤7、将步骤6所得的十六进制的重组数据按字节依次相加,并取其最低位字节得到校验和;
步骤8、先将步骤6所得的十六进制的重组数据作为待传输数据的前部,将步骤7所得的校验和作为待传输数据的后部;再在待传输数据的前后分别加入数据头和数据尾,组装成一组完整的传输数据帧进行发送。
2.根据权利要求1所述的一种用于改善低精度浮点数传输效率的方法,其特征是,步骤2中,采用直接去除或四舍五入方法对十进制数据进行精度保留。
3.根据权利要求1所述的一种用于改善低精度浮点数传输效率的方法,其特征是,步骤5中,若重组数据的位数不为3的倍数,则需要在重组数据的前面通过0进行补全,使重组数据的位数变为3的倍数。
CN202110505175.8A 2021-05-10 2021-05-10 一种用于改善低精度浮点数传输效率的方法 Active CN113254259B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110505175.8A CN113254259B (zh) 2021-05-10 2021-05-10 一种用于改善低精度浮点数传输效率的方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110505175.8A CN113254259B (zh) 2021-05-10 2021-05-10 一种用于改善低精度浮点数传输效率的方法

Publications (2)

Publication Number Publication Date
CN113254259A true CN113254259A (zh) 2021-08-13
CN113254259B CN113254259B (zh) 2024-03-22

Family

ID=77222477

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110505175.8A Active CN113254259B (zh) 2021-05-10 2021-05-10 一种用于改善低精度浮点数传输效率的方法

Country Status (1)

Country Link
CN (1) CN113254259B (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN115460163A (zh) * 2022-08-18 2022-12-09 深圳市千岩科技有限公司 数据处理方法、装置、电子设备以及存储介质
CN117220687A (zh) * 2023-03-01 2023-12-12 山东华科信息技术有限公司 分布式能源并网监测的数据解压缩方法

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060047733A1 (en) * 2004-08-26 2006-03-02 Calpont Corporation Method for representing integer and floating point numbers in a binary orderable format
US20070050436A1 (en) * 2005-08-26 2007-03-01 International Business Machines Corporation Order-preserving encoding formats of floating-point decimal numbers for efficient value comparison
CN102938685A (zh) * 2012-11-15 2013-02-20 大连理工大学 一种基于变长编码的无线传感器网络数据压缩方法
CN105634499A (zh) * 2015-12-30 2016-06-01 广东工业大学 一种基于新短浮点型数据的数据转换方法
CN106779733A (zh) * 2016-11-22 2017-05-31 中食安电子商务服务有限公司 10位十进制编码转化为可检错二进制编码的方法
US9703967B1 (en) * 2011-03-08 2017-07-11 Ciphercloud, Inc. System and method to anonymize data transmitted to a destination computing device
CN111404907A (zh) * 2020-03-10 2020-07-10 桂林电子科技大学 一种基于ieee754格式的数据压缩传输方法
US20200235751A1 (en) * 2019-01-21 2020-07-23 Eric B. Olsen Residue number systems and methods for arithmetic error detection and correction

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060047733A1 (en) * 2004-08-26 2006-03-02 Calpont Corporation Method for representing integer and floating point numbers in a binary orderable format
US20070050436A1 (en) * 2005-08-26 2007-03-01 International Business Machines Corporation Order-preserving encoding formats of floating-point decimal numbers for efficient value comparison
US9703967B1 (en) * 2011-03-08 2017-07-11 Ciphercloud, Inc. System and method to anonymize data transmitted to a destination computing device
CN102938685A (zh) * 2012-11-15 2013-02-20 大连理工大学 一种基于变长编码的无线传感器网络数据压缩方法
CN105634499A (zh) * 2015-12-30 2016-06-01 广东工业大学 一种基于新短浮点型数据的数据转换方法
CN106779733A (zh) * 2016-11-22 2017-05-31 中食安电子商务服务有限公司 10位十进制编码转化为可检错二进制编码的方法
US20200235751A1 (en) * 2019-01-21 2020-07-23 Eric B. Olsen Residue number systems and methods for arithmetic error detection and correction
CN111404907A (zh) * 2020-03-10 2020-07-10 桂林电子科技大学 一种基于ieee754格式的数据压缩传输方法

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
刘玉庆;高旭泽;李晓航;: "一种对C语言浮点数进制转换的处理方法", 科技经济导刊, no. 08, 15 March 2020 (2020-03-15) *
向和平;: "ArcSDE压缩二进制存储格式的研究与改进", 现代测绘, no. 05, 25 September 2011 (2011-09-25) *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN115460163A (zh) * 2022-08-18 2022-12-09 深圳市千岩科技有限公司 数据处理方法、装置、电子设备以及存储介质
CN117220687A (zh) * 2023-03-01 2023-12-12 山东华科信息技术有限公司 分布式能源并网监测的数据解压缩方法

Also Published As

Publication number Publication date
CN113254259B (zh) 2024-03-22

Similar Documents

Publication Publication Date Title
CN113254259A (zh) 一种用于改善低精度浮点数传输效率的方法
CN105634499B (zh) 一种基于新短浮点型数据的数据转换方法
CN107836083B (zh) 用于语义值数据压缩和解压缩的方法、设备和系统
EP1258998B1 (en) Method and apparatus for data compression of network packets employing per-packet hash tables
CN112953550B (zh) 数据压缩的方法、电子设备及存储介质
US8902090B2 (en) Compressing and decompressing signal data
US7688233B2 (en) Compression for deflate algorithm
US20070279261A1 (en) Method and apparatus for lossless run-length data encoding
CN105099843B (zh) 针对车辆通信总线的运行时间压缩方法
US7671767B2 (en) LIFO radix coder for electrical computers and digital data processing systems
CA2038414A1 (en) Apparatus and method for very high data rate-compression incorporating lossless data compression and expansion
CN108810553B (zh) 一种基于稀疏化处理的移动节点监测数据序列压缩方法
CN112527754A (zh) 基于按位变长存储的数值型数据压缩方法及系统
CN116033034B (zh) 一种无线收发平台用数据处理系统
US20130018856A1 (en) Compression of bitmaps and values
US6778109B1 (en) Method for efficient data encoding and decoding
CN112134568A (zh) 一种有损的数据压缩、解压缩方法及其系统
Yazdani et al. Protocols to reduce CPS sensor traffic using smart indexing and edge computing support
CN117240409A (zh) 一种用于智能手机与智能穿戴设备的数据处理方法
CN1615590A (zh) 数字信息信号的数据压缩和扩展
CN111404907A (zh) 一种基于ieee754格式的数据压缩传输方法
CN110719105A (zh) 一种测试向量的无损压缩和解压缩方法
CN111431538B (zh) 一种嵌入式系统的数据压缩方法、系统及存储介质
CN115664426B (zh) 一种探地雷达数据的实时无损压缩方法及系统
CN112200301B (zh) 卷积计算装置及方法

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant