资料介绍
射频识别(RFID)技术是一种非接触式的自动识别技术,通常由读写器、电子标签和计算机数据管理系统三部分组成,通过DSRC短程通信技术进行数据传输和交换。RFID系统工作时,如果遇到两个以上电子标签都在读写器信号的覆盖范围内,则各个电子标签会同时对读写器发出信号,从而造成各电子标签间数据的碰撞,使读写器不能正常读取各个电子标签内的有关数据,这就是RFID系统中的多路存取问题。因此只有解决好电子标签的碰撞问题,才能使RFID系统正常工作,而解决电子标签防碰撞问题的关键是优化的防碰撞算法。
现有的RFID防碰撞算法都是基于TDMA算法,可划分为Aloha防碰撞算法和基于二进制搜索BS(Binary search)算法两大类。Aloha是一种随机接入算法,这种算法多采取“标签先发言”的方式,即标签一旦进入阅读器的阅读区域就自动向阅读器发送其自身的ID,随即标签和阅读器间开始通信。在标签发送数据的过程中,若有其他标签也在发送数据,将发生信号重叠从而导致完全冲突或部分冲突,阅读器检测接收到的信号来判断有无冲突。如果发生冲突,阅读器将发送命令让标签停止发送,随机等待一段时间后再重新发起查询。该算法特点是:算法简单、便于实现,适用于低成本RFID系统。但是由于该算法的时隙是随机分配的,当大量标签并存时,帧冲突严重。而基于BS算法是通过多次比较,不断筛选出不同的标签号,时分复用地进行读写器和射频卡之间的信号交换,以一个独特的序列号识别射频卡为基础。为了从一组射频卡中选出其中的一个,读写器需要发出一个请求命令,有意识地将射频卡序列号传输时的数据碰撞引导到读写器上,即让读写器来判断是否发生碰撞。如发生碰撞,则缩小范围进行进一步搜索。这类算法虽然识别效率高,但是算法比较复杂,识别时间较长。本文在二进制防碰撞算法的基础上提出一种改进的防碰撞算法。
1两种典型的二进制防碰撞算法的分析
1.1二进制搜索算法
实现BS算法系统的必要前提是能够辨认出在读写器中数据冲突位的准确位置,因此必须选用合适的编码。曼彻斯特编码能够按位识别出碰撞位,这样可以根据碰撞的位置,按一定的规则重新搜索标签。因此,使用曼彻斯特编码是实现二进制搜索防碰撞算法的必要前提。BS算法的工作流程如下:
(1)电子标签进入读写器的作用范围时,读写器发送命令REQUEST(≤11111111),所有满足此条件的电子标签响应此命令,并将自己的EPC号传给读写器。
(2)读写器对比电子标签响应的EPC码相同位数上的数,根据Manchester编码规则,若出现不一致现象,即可判断出该比特位有碰撞。
(3)当确定有碰撞后,将此次发生碰撞的最高位置“0”,最高碰撞位之前的比特位不变,最高碰撞位后的所有比特位都置“1”,并产生新的请求命令REQUEST,依次排除序列号大的标签,直到读写器对比电子标签响应的序列号中相同位数上的数完全一致时,则说明无碰撞。此时,使用选择命令(SELECT)选出一个唯一的标签。
(4)选出唯一的标签后,使用READ-DATA命令完成读写器与该电子标签的数据交换。并使用选择命令(UNSELECT)进入“无声”状态,此时在读写器范围内不再响应(重新进入读写器范围可再次响应)。为了重新激活电子标签,必须进行复位操作。
(5)重复前4个步骤,并选择剩余的电子标签数据交换。多次循环后即可完成所有电子标签的读取。
1.2动态二进制搜索算法(DBS)
在BS搜索算法中,从读写器和单个电子标签的数据流可以看出,读写器发出的请求命令中,最高碰撞位后的所有比特位都被置“1”,对标签的识别不能提供任何的信息。而标签返回的数据中,最高碰撞位以前的比特位及最高碰撞位不包含给读写器的补充信息,因为这些位是已知且给定的,属于多余的重复信息。基于此人们提出了动态二进制搜索算法(DBS),当读写器检测到碰撞后,下一次读写器在请求命令中只发送搜索序列号中的最高位和最高碰撞位之间的部分作为搜索依据,然后中断传输,所有在与最高位和最高碰撞位之间的部分相同的电子标签响应并送回它们序列号的剩余各位,即最高碰撞位之后的比特位作为应答。因此,DBS算法避免了序列号中多余部分的传输,数据传输时间明显缩短。DBS算法较BS算法在传输数据量和所需时间上可减少50%。
2改进的二进制搜索算法
2.1算法约定
鉴于BS算法的缺点,本文提出了一种改进的二进制搜索算法,算法约定如下:
(1)采用曼彻斯特编码的电子标签序列号每个比特位上的取值不是“0”就是“1”。因此,如果当读写器探测到仅有一位碰撞位时,读写器不需要发送请求命令,可以直接识别出2个标签。
(2)读写器如果检测到有N个碰撞位,则说明这N个碰撞位的比特位对读写器来说是未知的,而其他的比特位对读写器来说是已知的。因此读写器只需要对未知的碰撞位处理,而不需要传输那些已知的比特位,从而减少传输时延。
为了便于描述以及实现该算法,给出如下防碰撞命令:
①查询命令request(DX,MX;DX1,MX1)。参数DX、DX1分别为检测到碰撞位的最高位和次高位,参数MX、MX1为0、1的二维排列组合,例如检测到1?1?00?1,那么读写器发送request(D6,0;D4,0)符合条件的标签响应并返回冲突位及相关信息。
②退出选择命令unselect.取消事先选中的电子标签,使标签进入“无声”状态。在这种状态下标签完全是非激活的,对收到的request命令不做应答。为了重新激活标签,必须暂时离开读写器的作用范围,然后再次进入该读写器范围。
2.2算法原理
下面以读写器作用范围内的8个编码为8 bit的标签为例说明该算法,8个标签的编码如下:tag1:01001000,tag2:01010100,tag3:01011010,tag4:01000000,tag5:01000010,
tag6:01010000,tag7:01001010,tag8:01011000.
(1)request≤11111111命令,读写器作用范围内的所有标签应答,读写器译码的结果为010????0碰撞位为D4,D3,D2,D1,最高碰撞位为D4,次高碰撞位为D3,因此下次查询命令为request(D4,0;D3,0)。
(2)读写器发送查询命令request(D4,0;D3,0),标签通过比较各自的D4、D3位,与之相同的标签则发送自己的相关信息给读写器。通过比较后标签4和标签5响应,编码后得到010000?0,读写器检测到仅只有一位碰撞,可以直接识别出标签4和标签5.读写器正确识别它们之后,执行unselect命令,使标签4和标签5处于“无声”状态。
(3)读写器发送查询命令request(D4,0;D3,1),标签1和标签7响应,编码后得到010010?0,读写器检测到仅只有一位碰撞,可以直接识别出标签1和标签7.读写器正确识别它们之后,执行unselect命令,使标签1和标签7处于“无声”状态。
(4)读写器发送查询命令request(D4,1;D3,0),标签2和标签6响应,编码后得到01010?00,读写器检测到仅只有一位碰撞,可以直接识别出标签2和标签6.读写器正确识别它们之后,执行unselect命令,使标签1和标签7处于“无声”状态。
(5)读写器发送查询命令request(D4,1;D3,1),标签3和标签8响应,编码后得到010110?0,读写器检测到仅只有一位碰撞,可以直接识别出标签3和标签8.读写器正确识别它们之后,执行unselect命令,使标签1和标签7处于“无声”状态。至此,读写器作用范围内的所有标签都别正确识别完毕。算法流程如图1所示。
3算法性能比较
假设读写器作用范围内有N个电子标签,则BS算法完成所有标签识别的搜索命令次数S(N)为:
通过理论和仿真比较,采用改进后的二进制搜索算法较其他两个算法有三个方面的优势:其一减少了查询标签次数,使计算时间减小;其二减少了系统数据传输量,提高了标签的识别速率;其三较大地提高了系统的吞吐率。
本文对BS算法及DBS算法过程进行了分析,找出了其中的不足之处,在此基础上提出了一种改进的二进制搜索算法,并通过Matlab仿真得到该算法的查询次数和吞吐率方面的数据。通过实验数据表明,该改进算法可以减少系统的查询次数,提高系统的吞吐率。从而验证了该改进算法的优越性。
现有的RFID防碰撞算法都是基于TDMA算法,可划分为Aloha防碰撞算法和基于二进制搜索BS(Binary search)算法两大类。Aloha是一种随机接入算法,这种算法多采取“标签先发言”的方式,即标签一旦进入阅读器的阅读区域就自动向阅读器发送其自身的ID,随即标签和阅读器间开始通信。在标签发送数据的过程中,若有其他标签也在发送数据,将发生信号重叠从而导致完全冲突或部分冲突,阅读器检测接收到的信号来判断有无冲突。如果发生冲突,阅读器将发送命令让标签停止发送,随机等待一段时间后再重新发起查询。该算法特点是:算法简单、便于实现,适用于低成本RFID系统。但是由于该算法的时隙是随机分配的,当大量标签并存时,帧冲突严重。而基于BS算法是通过多次比较,不断筛选出不同的标签号,时分复用地进行读写器和射频卡之间的信号交换,以一个独特的序列号识别射频卡为基础。为了从一组射频卡中选出其中的一个,读写器需要发出一个请求命令,有意识地将射频卡序列号传输时的数据碰撞引导到读写器上,即让读写器来判断是否发生碰撞。如发生碰撞,则缩小范围进行进一步搜索。这类算法虽然识别效率高,但是算法比较复杂,识别时间较长。本文在二进制防碰撞算法的基础上提出一种改进的防碰撞算法。
1两种典型的二进制防碰撞算法的分析
1.1二进制搜索算法
实现BS算法系统的必要前提是能够辨认出在读写器中数据冲突位的准确位置,因此必须选用合适的编码。曼彻斯特编码能够按位识别出碰撞位,这样可以根据碰撞的位置,按一定的规则重新搜索标签。因此,使用曼彻斯特编码是实现二进制搜索防碰撞算法的必要前提。BS算法的工作流程如下:
(1)电子标签进入读写器的作用范围时,读写器发送命令REQUEST(≤11111111),所有满足此条件的电子标签响应此命令,并将自己的EPC号传给读写器。
(2)读写器对比电子标签响应的EPC码相同位数上的数,根据Manchester编码规则,若出现不一致现象,即可判断出该比特位有碰撞。
(3)当确定有碰撞后,将此次发生碰撞的最高位置“0”,最高碰撞位之前的比特位不变,最高碰撞位后的所有比特位都置“1”,并产生新的请求命令REQUEST,依次排除序列号大的标签,直到读写器对比电子标签响应的序列号中相同位数上的数完全一致时,则说明无碰撞。此时,使用选择命令(SELECT)选出一个唯一的标签。
(4)选出唯一的标签后,使用READ-DATA命令完成读写器与该电子标签的数据交换。并使用选择命令(UNSELECT)进入“无声”状态,此时在读写器范围内不再响应(重新进入读写器范围可再次响应)。为了重新激活电子标签,必须进行复位操作。
(5)重复前4个步骤,并选择剩余的电子标签数据交换。多次循环后即可完成所有电子标签的读取。
1.2动态二进制搜索算法(DBS)
在BS搜索算法中,从读写器和单个电子标签的数据流可以看出,读写器发出的请求命令中,最高碰撞位后的所有比特位都被置“1”,对标签的识别不能提供任何的信息。而标签返回的数据中,最高碰撞位以前的比特位及最高碰撞位不包含给读写器的补充信息,因为这些位是已知且给定的,属于多余的重复信息。基于此人们提出了动态二进制搜索算法(DBS),当读写器检测到碰撞后,下一次读写器在请求命令中只发送搜索序列号中的最高位和最高碰撞位之间的部分作为搜索依据,然后中断传输,所有在与最高位和最高碰撞位之间的部分相同的电子标签响应并送回它们序列号的剩余各位,即最高碰撞位之后的比特位作为应答。因此,DBS算法避免了序列号中多余部分的传输,数据传输时间明显缩短。DBS算法较BS算法在传输数据量和所需时间上可减少50%。
2改进的二进制搜索算法
2.1算法约定
鉴于BS算法的缺点,本文提出了一种改进的二进制搜索算法,算法约定如下:
(1)采用曼彻斯特编码的电子标签序列号每个比特位上的取值不是“0”就是“1”。因此,如果当读写器探测到仅有一位碰撞位时,读写器不需要发送请求命令,可以直接识别出2个标签。
(2)读写器如果检测到有N个碰撞位,则说明这N个碰撞位的比特位对读写器来说是未知的,而其他的比特位对读写器来说是已知的。因此读写器只需要对未知的碰撞位处理,而不需要传输那些已知的比特位,从而减少传输时延。
为了便于描述以及实现该算法,给出如下防碰撞命令:
①查询命令request(DX,MX;DX1,MX1)。参数DX、DX1分别为检测到碰撞位的最高位和次高位,参数MX、MX1为0、1的二维排列组合,例如检测到1?1?00?1,那么读写器发送request(D6,0;D4,0)符合条件的标签响应并返回冲突位及相关信息。
②退出选择命令unselect.取消事先选中的电子标签,使标签进入“无声”状态。在这种状态下标签完全是非激活的,对收到的request命令不做应答。为了重新激活标签,必须暂时离开读写器的作用范围,然后再次进入该读写器范围。
2.2算法原理
下面以读写器作用范围内的8个编码为8 bit的标签为例说明该算法,8个标签的编码如下:tag1:01001000,tag2:01010100,tag3:01011010,tag4:01000000,tag5:01000010,
tag6:01010000,tag7:01001010,tag8:01011000.
(1)request≤11111111命令,读写器作用范围内的所有标签应答,读写器译码的结果为010????0碰撞位为D4,D3,D2,D1,最高碰撞位为D4,次高碰撞位为D3,因此下次查询命令为request(D4,0;D3,0)。
(2)读写器发送查询命令request(D4,0;D3,0),标签通过比较各自的D4、D3位,与之相同的标签则发送自己的相关信息给读写器。通过比较后标签4和标签5响应,编码后得到010000?0,读写器检测到仅只有一位碰撞,可以直接识别出标签4和标签5.读写器正确识别它们之后,执行unselect命令,使标签4和标签5处于“无声”状态。
(3)读写器发送查询命令request(D4,0;D3,1),标签1和标签7响应,编码后得到010010?0,读写器检测到仅只有一位碰撞,可以直接识别出标签1和标签7.读写器正确识别它们之后,执行unselect命令,使标签1和标签7处于“无声”状态。
(4)读写器发送查询命令request(D4,1;D3,0),标签2和标签6响应,编码后得到01010?00,读写器检测到仅只有一位碰撞,可以直接识别出标签2和标签6.读写器正确识别它们之后,执行unselect命令,使标签1和标签7处于“无声”状态。
(5)读写器发送查询命令request(D4,1;D3,1),标签3和标签8响应,编码后得到010110?0,读写器检测到仅只有一位碰撞,可以直接识别出标签3和标签8.读写器正确识别它们之后,执行unselect命令,使标签1和标签7处于“无声”状态。至此,读写器作用范围内的所有标签都别正确识别完毕。算法流程如图1所示。
3算法性能比较
假设读写器作用范围内有N个电子标签,则BS算法完成所有标签识别的搜索命令次数S(N)为:
通过理论和仿真比较,采用改进后的二进制搜索算法较其他两个算法有三个方面的优势:其一减少了查询标签次数,使计算时间减小;其二减少了系统数据传输量,提高了标签的识别速率;其三较大地提高了系统的吞吐率。
本文对BS算法及DBS算法过程进行了分析,找出了其中的不足之处,在此基础上提出了一种改进的二进制搜索算法,并通过Matlab仿真得到该算法的查询次数和吞吐率方面的数据。通过实验数据表明,该改进算法可以减少系统的查询次数,提高系统的吞吐率。从而验证了该改进算法的优越性。
下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- 射频识别技术中如何进行电子标签防碰撞 8次下载
- 如何实现RFID系统上行链路的多标签冲突检测算法 3次下载
- RFID应用系统的电子标签防碰撞算法研究说明 10次下载
- 改进型的帧时隙算法 1次下载
- 基于多比特识别的射频识别标签防碰撞算法 3次下载
- 无线射频识别读写器系统防碰撞算法 0次下载
- 基于RFID防碰撞系统算法改进 1次下载
- 基于RFID防碰撞算法研究 3次下载
- RFID系统中基于中继传感器的协同防碰撞算法_孙晓玲 1次下载
- RFID系统中电子标签天线分类及设计 25次下载
- 新的自调整多叉树RFID防碰撞算法的FPGA实现 2次下载
- RFID防碰撞问题的产生分析 50次下载
- UHF频段RFID系统防碰撞算法研究
- RFID防碰撞算法研究与改进
- 基于BIBD(4,2,1)的RFID防碰撞算法
- RFID超高频电子标签有何优势?如何挑选? 135次阅读
- 基于电子标签和物联网实现工业企业物联网系统的设计 3827次阅读
- 使用RFID标签的安防监控系统设计 1357次阅读
- 基于DES算法的RFID怎样设计安全系统 1162次阅读
- rfid基础上的Q值防碰撞算法怎样去改善 2599次阅读
- fireflyNFC电子标签贴纸简介 1545次阅读
- dfrobotUHF RFID 电子标签贴简介 1574次阅读
- 电子标签的发展趋势是怎么样的 7647次阅读
- 三分钟看懂RFID多标签阅读时防碰撞技术 8283次阅读
- RFID系统中多电子标签防碰撞改进算法详细教程 5599次阅读
- 超详细讲解!RFID射频技术,电子标签/无线射频识别/电子条码原理 2.2w次阅读
- RFID系统分类与电子标签分类分析研究 2178次阅读
- 基于Hilbert分形结构的电子标签天线设计及性能影响简介 3276次阅读
- RFID 技术的工程测试挑战解析 1132次阅读
- RFID电子标签应用与技术教程 4921次阅读
下载排行
本周
- 1电子电路原理第七版PDF电子教材免费下载
- 0.00 MB | 1490次下载 | 免费
- 2单片机典型实例介绍
- 18.19 MB | 93次下载 | 1 积分
- 3S7-200PLC编程实例详细资料
- 1.17 MB | 27次下载 | 1 积分
- 4笔记本电脑主板的元件识别和讲解说明
- 4.28 MB | 18次下载 | 4 积分
- 5开关电源原理及各功能电路详解
- 0.38 MB | 10次下载 | 免费
- 6基于AT89C2051/4051单片机编程器的实验
- 0.11 MB | 4次下载 | 免费
- 7基于单片机和 SG3525的程控开关电源设计
- 0.23 MB | 3次下载 | 免费
- 8基于单片机的红外风扇遥控
- 0.23 MB | 3次下载 | 免费
本月
- 1OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234313次下载 | 免费
- 2PADS 9.0 2009最新版 -下载
- 0.00 MB | 66304次下载 | 免费
- 3protel99下载protel99软件下载(中文版)
- 0.00 MB | 51209次下载 | 免费
- 4LabView 8.0 专业版下载 (3CD完整版)
- 0.00 MB | 51043次下载 | 免费
- 5555集成电路应用800例(新编版)
- 0.00 MB | 33562次下载 | 免费
- 6接口电路图大全
- 未知 | 30320次下载 | 免费
- 7Multisim 10下载Multisim 10 中文版
- 0.00 MB | 28588次下载 | 免费
- 8开关电源设计实例指南
- 未知 | 21539次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935053次下载 | 免费
- 2protel99se软件下载(可英文版转中文版)
- 78.1 MB | 537791次下载 | 免费
- 3MATLAB 7.1 下载 (含软件介绍)
- 未知 | 420026次下载 | 免费
- 4OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234313次下载 | 免费
- 5Altium DXP2002下载入口
- 未知 | 233046次下载 | 免费
- 6电路仿真软件multisim 10.0免费下载
- 340992 | 191183次下载 | 免费
- 7十天学会AVR单片机与C语言视频教程 下载
- 158M | 183277次下载 | 免费
- 8proe5.0野火版下载(中文版免费下载)
- 未知 | 138039次下载 | 免费
评论
查看更多