CN109002743B - 标签盘点的防冲突方法、读写器 - Google Patents

标签盘点的防冲突方法、读写器 Download PDF

Info

Publication number
CN109002743B
CN109002743B CN201810815992.1A CN201810815992A CN109002743B CN 109002743 B CN109002743 B CN 109002743B CN 201810815992 A CN201810815992 A CN 201810815992A CN 109002743 B CN109002743 B CN 109002743B
Authority
CN
China
Prior art keywords
session
state
inventory
value
label
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.)
Active
Application number
CN201810815992.1A
Other languages
English (en)
Other versions
CN109002743A (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.)
Shenzhen Chengcheng Information Co ltd
Original Assignee
Chainway Information Technology Co ltd
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 Chainway Information Technology Co ltd filed Critical Chainway Information Technology Co ltd
Priority to CN201810815992.1A priority Critical patent/CN109002743B/zh
Publication of CN109002743A publication Critical patent/CN109002743A/zh
Application granted granted Critical
Publication of CN109002743B publication Critical patent/CN109002743B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • G06K7/10009Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation sensing by radiation using wavelengths larger than 0.1 mm, e.g. radio-waves or microwaves
    • G06K7/10316Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation sensing by radiation using wavelengths larger than 0.1 mm, e.g. radio-waves or microwaves using at least one antenna particularly designed for interrogating the wireless record carriers
    • G06K7/10356Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation sensing by radiation using wavelengths larger than 0.1 mm, e.g. radio-waves or microwaves using at least one antenna particularly designed for interrogating the wireless record carriers using a plurality of antennas, e.g. configurations including means to resolve interference between the plurality of antennas

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Health & Medical Sciences (AREA)
  • Toxicology (AREA)
  • General Health & Medical Sciences (AREA)
  • Electromagnetism (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Artificial Intelligence (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)
  • Near-Field Transmission Systems (AREA)

Abstract

本发明公开了一种标签盘点的防冲突方法、读写器。方法包括:读写器检测识别范围内标签的密集度;根据标签的密集度调整盘点周期的长度,其中,在标签密集时延长盘点周期以减少单位时间内读取标签的次数,在标签稀疏时缩短盘点周期以增加单位时间内读取标签的次数。本发明技术方案可用于解决标签盘点时的冲突、碰撞问题,实现高效、无漏、连续读取标签。

Description

标签盘点的防冲突方法、读写器
技术领域
本发明涉及射频识别技术领域,具体涉及一种标签盘点的防冲突方法、读写器和标签盘点系统。
背景技术
射频识别(Radio Frequency Identification,RFID)是一种自动识别技术,是构建物联网的关键技术。RFID系统主要由读写器和应答器构成。应答器主要由天线、耦合元件及芯片组成,一般来说用标签作为应答器,每个标签具有唯一的电子产品代码,附着在物体上标识目标对象。读写器,或称为阅读器,主要由天线、耦合元件及芯片组成,是读取和/或写入标签信息的设备,可设计为可移动的手持设备或固定设备。
RFID技术在各个领域,特别是在物流、零售、服装等领域的应用,越来越广泛,但同时要求越来越高,特别是手持设备上的RFID,需要对不确定数量的标签,例如单标签、少量标签或者多标签甚至大量标签进行无漏读、连续、高效率的盘点。RFID应用于多标签的场景时,若2个或2个以上标签同时与读写器通信,由于无源RFID标签共用一个传输信道,标签之间的碰撞冲突将导致标签不能与读写器正常通信。因此,防冲突方法一直是RFID中重要研究内容之一。
基于随机数产生器的时隙算法是一种常用的防冲突算法。采用时隙算法,在进行大量标签盘点时需要控制标签返回数据的时隙,让时隙大一些,可以减少标签返回数据的冲突,但是这样在读取单标签或者少量标签的时候会有读取标签不连续现象,即,标签几秒才读取到一次数据;而为了让读取少量标签数据连续,需要把标签返回数据的时隙减小,但这样,在盘点大量标签时就会出现严重的标签冲突现象,导致盘点标签不全漏读的问题。
目前现有的解决办法是在读取少量标签时设置一种工作模式,在盘点大量标签时又设置另一种工作模式,但是这样在移动的手持设备使用上很不方便并且效率低,两种工作模式的切换并不能很好的适应标签数量的变化,不能较好的解决标签冲突问题。
发明内容
本发明实施例提供一种标签盘点的防冲突方法、读写器和标签盘点系统,用于解决标签盘点时的冲突、碰撞问题,实现高效、无漏、连续读取标签。
为解决上述技术问题,采用如下技术方案:
本发明第一方面,提供一种标签盘点的防冲突方法,包括:读写器检测识别范围内标签的密集度;根据标签的密集度调整盘点周期的长度,其中,在标签密集时延长盘点周期以减少单位时间内读取标签的次数,在标签稀疏时缩短盘点周期以增加单位时间内读取标签的次数。
一种可能的实现方式中,读写器检测识别范围内标签的密集度,包括:从盘点周期的第1个时隙起,对无标签应答随机数的次数进行统计得到时隙空闲次数RN16TO,以及,对标签未正确返回EPC号的次数进行统计得到标签冲突次数EPCTO;估算表征标签密集度的参数Value=A×RN16TO-B×EPCTO,A和B均为大于0的整数。
一种可能的实现方式中,根据标签的密集度调整盘点周期的长度,包括:根据表征标签密集度的参数Value和设定的阈值threshold调整Q值,Q值决定盘点周期的长度;其中,若Value≥threshold,则将Q值减1;若Value≤-threshold,则将Q值加1;若-threshold<Value<threshold,则Q值保持不变;threshold=C×Q;Q为大于0的整数,C为正数;发送QueryAdjust命令,将调整后的Q值发送给标签。
一种可能的实现方式中,所述方法具体包括:读写器发送包含参数Q的Query命令,开启一个盘点周期,一个盘点周期包括2Q个时隙,并将参数Query_Slot置入自身的时隙计数器,Query_Slot的初始值为2Q-1;标签获取参数Q,从(0,2Q-1)范围内选取一个随机数Tag_Slot置入自身的时隙计数器;Tag_Slot为0的标签应答随机数RN16,Tag_Slot不为0的标签处于静默状态;读写器存储表示时隙空闲次数的变量RN16TO,若没有标签应答随机数,则将变量RN16TO加1;读写器发送ACK命令,该ACK命令携带收到的随机数RN16,收到ACK命令的对应标签应答EPC号,对应标签是指该ACK命令携带的随机数RN16所属的标签;读写器存储表示标签冲突次数的变量EPCTO和表示标签盘点数量的变量TagNumber,若标签返回错误的EPC号或不返回EPC号则变量EPCTO加1,若标签返回正确的EPC号则变量TagNumber加1;估算表征标签密集度的参数Value=RN16TO-4×EPCTO,并设置阈值threshold=Q/2;判断Abs(Value)≥threshold是否成立,并进一步判断Q值是否为0;在Q值不等于0时,根据表征标签密集度的参数Value和设定的阈值threshold进行Q值调整:其中,若Value≥threshold,则将Q值减1;若Value≤-threshold,则将Q值加1;若-threshold<Value<threshold,则Q值保持不变;读写器发送QueryAdjust命令,将调整后的Q值发送给标签;在Q值为0时,退出盘点。
一种可能的实现方式中,进一步判断Q值是否为0之前,还包括:若Abs(Value)<threshold,判断否收到退出命令Cancel或者是否达到盘点时间Query_Time,若是,则退出盘点,否则,判断Query_Slot是否为0;若Abs(Value)<threshold,且Query_Slot不为0,则发送Query Rep命令,同时Query_Slot的计数值减1;Tag_Slot为0且已应答EPC的标签收到Query Rep命令后,从默认的第一状态转移至第二状态;Tag_Slot不为0的标签收到QueryRep命令后,将自身的Tag_Slot计数值减1;若Abs(Value)<threshold,且Query_Slot为0,执行判断Q值是否为0的步骤;其中,标签为第一状态时参与标签盘点,标签为第二状态时不参与标签盘点且达到预设的持续时间后自行转移至第一状态。
一种可能的实现方式中,Query命令还包含状态标记A和时间参数session,状态标记A用于指示标签使自身处于第一状态,时间参数session用于指示标签转移到第二状态后应保持的持续时间;所述方法还包括:一个盘点周期结束后,获取变量TagNumber的值,根据TagNumber的值设定下一个盘点周期中的时间参数session,时间参数session与变量TagNumber正相关。
本发明第二方面提供一种用于标签盘点的读写器,包括:检测模块,用于检测识别范围内标签的密集度;调整模块,用于根据标签的密集度调整盘点周期的长度,包括在标签密集时延长盘点周期以减少单位时间读取标签的次数,在标签稀疏时缩短盘点周期以增加单位时间读取标签的次数。
一种可能的实现方式中,所述检测模块包括:统计单元,用于从盘点周期的第1个时隙起,对无标签应答随机数的次数进行统计得到时隙空闲次数RN16TO,以及,对标签未正确返回EPC号的次数进行统计得到标签冲突次数EPCTO;估算单元,用于估算表征标签密集度的参数Value=A×RN16TO-B×EPCTO,A和B均为大于0的整数。
一种可能的实现方式中,所述调整模块包括:Q值调整单元,用于根据表征标签密集度的参数Value和设定的阈值threshold调整Q值,Q值决定盘点周期的长度;其中,若Value≥threshold,则将Q值减1;若Value≤-threshold,则将Q值加1;若-threshold<Value<threshold,则Q值保持不变;threshold=C×Q;Q为大于0的整数,C为正数;命令发送单元,用于发送QueryAdjust命令,将调整后的Q值发送给标签。
本发明第三方面提供一种标签盘点系统,包括读写器和多个标签,所述读写器,用于:发送包含参数Q的Query命令,开启一个盘点周期,一个盘点周期包括2Q个时隙,并将参数Query_Slot置入时隙计数器,Query_Slot的初始值为2Q-1;所述标签,用于:获取参数Q,从(0,2Q-1)范围内选取一个随机数Tag_Slot置入自身的时隙计数器;Tag_Slot为0的标签应答随机数RN16,Tag_Slot不为0的标签处于静默状态;所述读写器还用于:存储表示时隙空闲次数的变量RN16TO,若没有标签应答,则将变量RN16TO加1;发送ACK命令,该ACK命令携带收到的随机数RN16;所述标签,还用于:收到ACK命令且该ACK命令中携带的随机数RN16属于自己时,应答EPC号;所述读写器还用于:存储表示标签冲突次数的变量EPCTO和表示标签盘点数量的变量TagNumber,若标签返回错误的EPC号或不返回EPC号则变量EPCTO加1,若标签返回正确的EPC号则变量TagNumber加1;所述读写器还用于:估算表征标签密集度的参数Value=RN16TO-4×EPCTO,并设置阈值threshold=Q/2;判断Abs(Value)≥threshold是否成立,并进一步判断Q值是否为0;在Q值不等于0时,根据标签密集度和设定的阈值threshold进行Q值调整:其中,若Value≥threshold,则将Q值减1;若Value≤-threshold,则将Q值加1;若-threshold<Value<threshold,则Q值保持不变;发送QueryAdjust命令,将调整后的Q值发送给标签;在Q值为0时,退出盘点。
值得说明的是,本文中:
RN16TO是时隙空闲次数,若该时隙没有标签应答,则RN16TO加1。RN16TO越大,表示空闲的时隙数越多,说明标签的数量越少,标签越稀疏。
TagNumber是标签盘点数量,其原理是:假设某时隙有一个标签应答随机数RN16,读写器收到并正确解析该随机数RN16后,会将该随机数RN16携带在ACK命令中发送给标签;标签收到ACK命令并解析其中的随机数RN16属于自己时,应答EPC号。读写器收到正确的EPC号,表示成功盘点到一个标签,则将TagNumber加1,于是TagNumber可用来表示成功盘点的标签的数量。
EPCTO是标签冲突次数,其原理是:
假设某时隙有两个或以上标签应答,则读写器会在该时隙收到两个或以上随机数RN16,导致读写器无法正确解析收到的随机数RN16;于是读写器发送的ACK命令将携带一个错误的随机数RN16,这样就不会有标签返回EPC号;因此,标签不返回EPC号就可以表示该时隙有标签冲突,则将EPCTO加1。
另外,假设某个周期虽然只有一个标签正确应答,并不与其它标签冲突,但因为某些因素例如环境干扰等因素,导致读写器未收到正确的EPC号,本文中仍将其视为标签冲突,将EPCTO加1计数,因为对没有正确收到EPC的标签发送NAK命令,此标签收到NAK命令后,该标签的状态和冲突标签的状态变成一样,下一个QueryAdjust命令来的时候重新调整标签的Tag_Slot,等待再次发送RN16的机会,这样就保证了这个错误EPC的标签不会被漏读。
EPCTO越大,表示标签冲突的次数越多,说明标签的数量越多,也就是说标签越密集。
可见,变量RN16TO和EPCTO分别可以表示标签的稀疏程度和密集程度,将这两个变量加权比较,即可用来表征标签的密集度。可用数学公式来表达表征标签密集度的参数Value=A×RN16TO-B×EPCTO,A和B均为大于0的整数。实践发现,当A=1,B=4时,可以较真实的反映标签的密集度。
以上,本发明实施例提供了一种标签盘点的防冲突解决方案,包括防冲突方法、读写器和标签盘点系统。本发明技术方案是基于动态Q值调整算法提出的改进方案。动态Q值调整算法属于时隙算法的范畴,是解决标签冲突问题常用的方法之一,该算法中Q值决定盘点周期的长度。
本发明技术方案,通过调整盘点周期的长度来解决或减少标签冲突,调整的依据是标签的密集度,该方法实现了实时检测标签的密集度,进而,实时调整盘点周期的长度,实现在标签密集时延长盘点周期以减少单位时间内读取标签的次数,在标签稀疏时缩短盘点周期以增加单位时间内读取标签的次数,以此解决标签盘点时的冲突、碰撞问题,取得高效、无漏、连续读取标签的效果。
相对于现有的在两种工作模式之间切换的方案,本发明实现了对盘点周期的更细微、更精准的调整,使盘点周期总能适应于标签数量或者说标签密集度而得到随时的调整,从而减少标签碰撞冲突,实现更高效的标签盘点。
附图说明
为了更清楚地说明本发明实施例技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其它的附图。
图1是本发明一个实施例提供的标签盘点的防冲突方法的流程示意图;
图2是本发明实施例中执行方法的一个盘点周期的流程示意图;
图3是本发明实施例中session参数的状态转换图;
图4是本发明一个实施例提供的读写器的结构示意图;
图5是本发明一个实施例提供的标签盘点系统的结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本发明方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分的实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本发明保护的范围。
本发明的说明书和权利要求书及上述附图中的术语“第一”、“第二”、“第三”等是用于区别不同的对象,而不是用于描述特定顺序。此外,术语“包括”和“具有”以及它们任何变形,意图在于覆盖不排他的包含。例如包含了一系列步骤或单元的过程、方法、系统、产品或设备没有限定于已列出的步骤或单元,而是可选地还包括没有列出的步骤或单元,或可选地还包括对于这些过程、方法、产品或设备固有的其它步骤或单元。
下面通过具体实施例,分别进行详细的说明。
为解决现有技术问题,本发明实施例提供一种用于标签盘点的防冲突解决方案,该方案是基于动态Q值调整算法提出的改进方案。动态Q值调整算法属于时隙算法的范畴,是解决标签冲突问题常用的方法之一。
本发明技术方案的核心思想是,根据读写器可识别磁场范围内的可识别标签的密集度,动态调整盘点参数,达到减少标签冲突并能全部盘点的目的,属于超高频(UltraHigh Frequency,UHF)RFID射频识别技术领域。
为实现上述目的,本发明实施例提供一种标签盘点的防冲突方法、读写器和标签盘点系统。标签盘点系统包括读写器和多个标签。本文中的标签,是指RFID标签、射频标签或电子标签,简称为标签(Tag)。本文中的读写器,也称为阅读器(Reader),可以是UHF读写器。本文中的标签盘点系统,是一种RFID系统。本发明实施例技术可用于物流、零售、服装等各种领域。
请参考图1,本发明一个实施例提供一种标签盘点的防冲突方法,可包括:
A1、读写器检测识别范围内标签的密集度。
读写器的磁场范围即为其识别范围,基于动态Q值调整算法,读写器与识别范围内的标签进行通信并交互信息,读写器可通过交互的信息统计计算,获取表征标签的密集度的参数。
A2、根据标签的密集度调整盘点周期的长度,其中,在标签密集时延长盘点周期以减少单位时间内读取标签的次数,在标签稀疏时缩短盘点周期以增加单位时间内读取标签的次数。
读写器可通过调整Q值来调整盘点周期。在动态Q值调整算法中,Q值决定一个盘点周期的时隙计数,而时隙的多少决定了盘点周期的长度。因此,可通过增大Q值来延长盘点周期,或通过减小Q值来缩短盘点周期。
一些可行的实现方式中,步骤A1可包括:从盘点周期的第1个时隙起,对无标签应答随机数的次数进行统计得到时隙空闲次数RN16TO,以及,对标签未正确返回EPC号的次数进行统计得到标签冲突次数EPCTO;估算表征标签密集度的参数Value=A×RN16TO-B×EPCTO,A和B均为大于0的整数。
一些可行的实现方式中,步骤A2可包括:根据表征标签密集度的参数Value和设定的阈值threshold调整Q值,Q值决定盘点周期的长度;其中,若Value≥threshold,则将Q值减1;若Value≤-threshold,则将Q值加1;若-threshold<Value<threshold,则Q值保持不变;threshold=C×Q;Q为大于0的整数,C为正数;发送QueryAdjust命令,将调整后的Q值发送给标签。
优选的方式中,可选择A=1,B=4,使Value=RN16TO-4×EPCTO;以及,可选择Threshold=Q/2;以实现更好的盘点效果。
如上,根据本发明实施例提出的方法,读写器自动检测磁场范围内标签的密集度,并根据标签密集度设置阈值,自动、动态调整射频工作参数以实现无漏读、连续、高效率的盘点。在标签少的时候改变参数让标签在单位时间内读取的次数增加以达到读取连续的效果;在标签多的时候改变参数让标签在单位时间内读取的次数减少以减少标签数据的冲突达到高效效率、无漏读的效果。
下面通过一个具体应用例对本发明方法进行详细说明:
首先,对动态Q值调整算法使用到的命令做一个简单介绍,以便于理解。
Query命令:Query命令用于初始化一个盘点过程,开启一个盘点周期,决定哪些标签参与本盘点周期,这里“盘点周期”定义为连续两个Query命令之间的时间。Query命令包含一个时隙计数参数Q。整个盘点周期被划分为2Q个时隙(或称为时槽)。当接收到一条Query命令时,被盘点的标签应在(0,2Q–1)范围内选出一个整数为随机数,并将这个随机数置入它们的时隙计数器。随机数选到零值的标签立即应答一个随机数RN16。选到非零数的标签等待下一条QueryAdjust或QueryRep命令。
QueryAdjust命令:该命令用于调整Q值。标签在接收一条QueryAdjust命令时,首先调整Q值(增加、减少或不变),然后在(0,2Q–1)范围内选出一个随机数RN16,置入它们的时隙计数器。随机数选到零值的标签立即应答。选到非零值的标签等待下一条QueryAdjust或QueryRep命令。
QueryRep命令:选到非零值的标签每接收到一条QueryRep命令后,即将它们的时隙计数器减1。当它们的时隙计数器减到零时,标签立即应答一个随机数RN16。读写器发一次QueryRep命令,意味着进入下一个时隙。
其次,介绍本实施例中防冲突方法的流程。
请参考图2,一个盘点周期的流程可包括以下步骤:
0、开始:读写器初始化各参数。
1、读写器发送包含参数Q的Query命令,该命令还可以包括状态标记和时间参数session。可选的,Q=4,状态标记为A,session为S1。
A用于指示标签的状态为第一状态,标签的第二状态用状态标记B表示。标记为A的标签参与盘点过程;标记为B的标签不参与盘点过程,不应答读写器。Session用于指示标签转为第二状态后的持续时间,达到该时间后标签自动转移回第一状态。Session可以设定若干个时间值,如S0、S1、S2、S3,具体在后文说明。标签刚上电默认处于第一状态,默认的状态标记为A。
Query命令,开启一个盘点周期,一个盘点周期包括2的Q次方个时隙,用0表示第1个时隙,标签最大产生的时隙(slot)即为2Q-1。可用参数Query_Slot表示当前最大的时隙,其初始值为2Q-1,Query_Slot这个参数值为后面发送Query_Rep命令的次数做依据。读写器将参数Query_Slot置入自身的时隙计数器,Query_Slot的初始值为2Q-1。
2、标签收到Query命令或QueryAdjust命令后,获取Q值,并根据Q值,标签的slot随机产生0≤Tag_Slot≤(2Q-1)的随机数,slot值是标签是否可以应答的依据。标签将选择的随机数Tag_Slot置入自身的时隙计数器,每收到一次QueryRep命令,即,每过1个时隙,该时隙计数器的值减1。
3、Tag_Slot为0的标签应答RN16,RN16是16位的随机数;Tag_Slot不为0的标签处于静默状态,一直等到Tag_Slot为0才可以应答;没有标签应答随机数,则读写器存储的变量RN16TO加1计数。RN16TO表示时隙空闲次数,用于统计无标签应答的次数。
4、读写器收到标签返回的正确RN16,则应答ACK(Acknowledgement,确认)命令给该标签,ACK命令中可携带该标签的RN16使得只有该标签可收到,以指示该标签应答EPC(Electronic Product Code,电子产品代码)号。
若该标签返回错误的EPC号或者不返回EPC号,则读写器存储的变量EPCTO加1。EPCTO表示标签冲突次数,用于统计标签冲突的次数。若标签返回正确的EPC号,读写器收到返回正确EPC号,则读写器存储的变量TagNumber加1。TagNumber表示标签盘点数量,用于统计收到正确EPC号的标签数量,然后可通过串口DMA发送给与读写器通信的主机。
可选的,标签返回EPC号的同时可返回一个循环冗余校验(Cyclic RedundancyCheck,CRC)号码,读写器可根据收到的CRC判断收到的EPC号是否正确。
5、通过RN16TO和EPCTO与阈值的关系来估算和判断标签的密集度。
经过理论推理以及各种环境的多次试验,得到如下较优选的关系式:
Abs(Value)≥threshold,式中,Value=RN16TO-4×EPCTO;
该关系式中,threshold为设定阈值,优选等于当前使用的Q值的一半即threshold=Q/2;Abs(Value)表示对Value取绝对值。
当然,这个公式不是唯一的,可以根据具体应用场合或者个人的试验结果得出其他的关系,本发明的核心是算法的思想,具体的参数值或者参数对应关系是可选的。
本步骤中,判断是否满足上述阈值条件:满足阈值条件则进入步骤9进行下一步判断;没有满足阈值条件则进入步骤6。
6、若Abs(Value)<threshold,判断是否收到退出命令Cancel或者是否达到盘点时间Query_Time,若是,则退出盘点,否则,进入步骤7。本步骤为盘点周期中断的出口。
7、判断Query_Slot是否为0,不为0说明在产生随机数范围内,还是有标签的slot不为0,也就是可能还有标签没有应答。
8、Query_Slot不为0,则发送Query Rep命令,同时Query_Slot计数值减1;Tag_Slot为0且已经应答EPC的标签收到Query Rep命令后,标志A反转为B,即,从默认的第一状态转移至第二状态,状态改变后持续时间如表1。如表1所示,本文的一个实施例给出4种可选择设定的持续时间。
Tag_Slot不为0的标签收到Query Rep命令后,标签本身的Tag_Slot值减1。然后返回步骤3。
9、判断Query_Q值是否为0,即判断Q值是否为0。Q值等于0则说明此次盘点周期结束,退出盘点。Q值不等于0则通过判断阈值条件,调整Q值,具体如步骤10。
10、Query_Q不等于0,则进入对参数RN16TO和EPCTO与阈值条件的判断,以确定对Q值如何从新调整,它们的关系分为以下三种:
a、-threshold<Value<threshold,可以解释为冲突系数和无标签返回量系数相当,Q值保持不变,再用原来的Q值参数进行盘点。
b、Value≥threshold,表示无标签返回的系数远大于冲突的系数,说明标签比较稀疏,也就是说标签比较少,需要缩小范围,所以再次盘点的Q值在Query_Q值基础上减1。
c、Value≤threshold,表示冲突系数远大于无标签返回系数,说明标签比较密集,标签量比较大需要Q值在Query_Q值基础上再加1,以减少标签冲突。
调整过的Q值通过QueryAdjust命令发送给标签群中的每个标签。
若记调整后的Q值为Q1,则步骤4中没有返回EPC的所有标签,也就是标记为A并且Tag_Slot大于0的标签,重新产生slot值为0≤Tag_Slot≤(2Q1-1)的随机数,置入自身的时隙计数器;Tag_Slot为0并且标记为A的标签,收到QueryAdjust命令后其标记也会反转为B,转移到第二状态。然后算法回到步骤2。
需要注意,图2中用2^Q表示2的Q次方,用2^Q1表示2的Q1次方。
以上,对本发明实施例方法的一个盘点周期的流程进行了描述。
由上可见,在盘点过程中读写器会根据磁场识别范围内的标签的密集度动态调整Q值的参数以达到高效率、无漏读盘点标签群。算法中有个关键点就是在通过阈值判断标签冲突系数时的公式:Value=A×RN16TO-B×EPCTO。优选的,Abs(RN16TO-4*EPCTO)>=threshold,其中Threshold=当前使用的Q值除以2,RN16TO、EPCTO和threshold之间的关系是本发明通过大量实验和仿真得到的结果,这个公式是可以根据应用环境或者使用条件调整它们之间的关系的。
本发明实施例方法,还可以包括调整时间参数session的步骤。可以通过上一个盘点周期获取的统计信息,来调整下一个盘点周期中的时间参数session。一种实施方式中,一个盘点周期结束后,读写器可获取变量TagNumber的值,根据TagNumber的值设定下一个盘点周期中的时间参数session,时间参数session与变量TagNumber正相关。
在一个具体的应用场景中,上述方法还可包括:
(1)在盘点开始发送Query命令时选择参数:Query_Q=4,标志为A(长时间断电刚上电默认的标记是A),session为S1,session参数的选取是根据表1,各个具体session中标记保持的时间决定的,因为刚开始还不知道标签具体数量,所以选择S1最合适。
表1 session参数的取值
session 标记的持续时间
S0 不确定(时间很短一般小于200毫秒)
S1 500毫秒<持续时间<5秒
S2 2秒<持续时间
S3 2秒<持续时间
(2)设置好参数后运用算法盘点,一个盘点周期结束后,得到步骤4中TagNumber的参数值即成功盘点到的标签数量。对TagNumber的数量分为以下三个数量级:a、TagNumber<=10;b、10<TagNumber<=90;c、TagNumber>90。
一个盘点周期结束后,重新进行新的盘点周期时可根据TagNumber的数量对新的session参数进行调整,使得在标签数量大时,要标记保持的时间比较久以减少冲突,增加吞吐量更高效率的盘点标签;在标签数量比较少时,要标记保持的时间短,以便可以在比较短的时间内重复盘点,达到连续盘点的效果,不然如果只有一两张标签,好几秒钟才盘点到一次,会误认为设备性能出现问题。session参数的状态转换图如图3所示。
(3)一个盘点周期结束后,根据TagNumber的数量调整session参数,再进行一个新的盘点周期,循环盘点,不断的自动调整工作参数。这样的算法在手持移动设备中非常实用,因为手持移动设备是不断移动来盘点标签的,标签会有时多时少的情况,就很好的解决了问题,大大的提高了效率。
以上,对本发明实施例提供的用于标签盘点的防冲突方法进行了说明。
为便于实施本发明技术方案,下面还提供相关的装置和系统。
请参考图4,本发明的一个实施例,提供一种用于标签盘点的读写器,包括:
检测模块41,用于检测识别范围内标签的密集度;
调整模块42,用于根据标签的密集度调整盘点周期的长度,包括在标签密集时延长盘点周期以减少单位时间读取标签的次数,在标签稀疏时缩短盘点周期以增加单位时间读取标签的次数。
在一个实施例中,所述检测模块41可包括:
统计单元4101,用于从盘点周期的第1个时隙起,对无标签应答随机数的次数进行统计得到时隙空闲次数RN16TO,以及,对标签未正确返回EPC号的次数进行统计得到标签冲突次数EPCTO;
估算单元4102,用于估算表征标签密集度的参数Value=A×RN16TO-B×EPCTO,A和B均为大于0的整数。
在一个实施例中,所述调整模块42可包括:
Q值调整单元4201,用于根据表征标签密集度的参数Value和设定的阈值threshold调整Q值,Q值决定盘点周期的长度;其中,若Value≥threshold,则将Q值减1;若Value≤-threshold,则将Q值加1;若-threshold<Value<threshold,则Q值保持不变;threshold=C×Q;Q为大于0的整数,C为正数;
命令发送单元4202,用于发送QueryAdjust命令,将调整后的Q值发送给标签。
关于本实施例读写器的更多的说明,请参考前文方法实施例中的描述。
请参考图5,本发明的一个实施例,还提供一种标签盘点系统,包括读写器51和多个标签52,其特征在于,
所述读写器51,用于:发送包含参数Q的Query命令,开启一个盘点周期,一个盘点周期包括2Q个时隙,并将参数Query_Slot置入时隙计数器,Query_Slot的初始值为2Q-1;
所述标签52,用于:获取参数Q,从(0,2Q-1)范围内选取一个随机数Tag_Slot置入自身的时隙计数器;Tag_Slot为0的标签应答随机数RN16,Tag_Slot不为0的标签处于静默状态;
所述读写器51还用于:存储表示时隙空闲次数的变量RN16TO,若没有标签应答,则将变量RN16TO加1;发送ACK命令,该ACK命令携带收到的随机数RN16;
所述标签52,还用于:收到ACK命令且该ACK命令中携带的随机数RN16属于自己时,应答EPC号;
所述读写器51还用于:存储表示标签冲突次数的变量EPCTO和表示标签盘点数量的变量TagNumber,若标签返回错误的EPC号或不返回EPC号则变量EPCTO加1,若标签返回正确的EPC号则变量TagNumber加1;
所述读写器51还用于:估算表征标签密集度的参数Value=RN16TO-4×EPCTO,并设置阈值threshold=Q/2;判断Abs(Value)≥threshold是否成立,并进一步判断Q值是否为0;在Q值不等于0时,根据标签密集度和设定的阈值threshold进行Q值调整:其中,若Value≥threshold,则将Q值减1;若Value≤-threshold,则将Q值加1;若-threshold<Value<threshold,则Q值保持不变;发送QueryAdjust命令,将调整后的Q值发送给标签;在Q值为0时,退出盘点。
关于本实施例系统的更多的说明,请参考前文方法实施例中的描述。
综上,本发明实施例提供了一种用于标签盘点的防冲突解决方案,通过调整盘点周期的长度来解决或减少标签冲突,调整的依据是标签的密集度,该方法实现了实时检测标签的密集度,进而,实时调整盘点周期的长度,实现在标签密集时延长盘点周期以减少单位时间内读取标签的次数,在标签稀疏时缩短盘点周期以增加单位时间内读取标签的次数,以此解决标签盘点时的冲突、碰撞问题,取得高效、无漏、连续读取标签的效果。
相对于现有的在两种工作模式之间切换的方案,本发明实现了对盘点周期的更细微、更精准的调整,使盘点周期总能适应于标签数量或者说标签密集度而得到随时的调整,从而减少标签碰撞冲突,实现更高效的标签盘点。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详细描述的部分,可以参见其它实施例的相关描述。
上述实施例仅用以说明本发明的技术方案,而非对其限制;本领域的普通技术人员应当理解:其依然可以对上述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围。

Claims (2)

1.一种标签盘点的防冲突方法,其特征在于,包括:
读写器检测识别范围内标签的密集度;
根据标签的密集度调整盘点周期的长度,其中,在标签密集时延长盘点周期以减少单位时间内读取标签的次数,在标签稀疏时缩短盘点周期以增加单位时间内读取标签的次数;
所述方法具体包括:
读写器发送包含参数Q的Query命令,
Query命令还包含状态标记A和时间参数session,状态标记A用于指示标签使自身处于第一状态,时间参数session用于指示标签转移到第二状态后应保持的持续时间;所述方法还包括:一个盘点周期结束后,获取变量TagNumber的值,根据TagNumber的值设定下一个盘点周期中的时间参数session,时间参数session与变量TagNumber正相关;
所述根据TagNumber的值设定下一个盘点周期中的时间参数session具体包括:
若上一个盘点周期的session的状态为S1,且上一个盘点周期的TagNumber>90时,将下一个盘点周期的session的状态设定为S2;若上一个盘点周期的session的状态为S1,且上一个盘点周期的TagNumber≤10,则将下一个盘点周期的session的状态设定为S0;若上一个盘点周期的session的状态为S0,且上一个盘点周期的TagNumber>10,则将下一个盘点周期的session的状态设定为S1;若上一个盘点周期的session的状态为S2,且上一个盘点周期的TagNumber≤90,则将下一个盘点周期的session的状态设定为S1;
其中,session的状态为S0时,标记的持续时间小于200毫秒;session的状态为S1时,标记的持续时间在500毫秒至5秒之间;session的状态为S2时,标记的持续时间大于2秒。
2.一种读写器,其特征在于,包括:
检测模块,用于检测识别范围内标签的密集度;
调整模块,用于根据标签的密集度调整盘点周期的长度,包括在标签密集时延长盘点周期以减少单位时间读取标签的次数,在标签稀疏时缩短盘点周期以增加单位时间读取标签的次数;
命令发送单元,用于发送包含参数Q的Query命令,Query命令还包含状态标记A和时间参数session,状态标记A用于指示标签使自身处于第一状态,时间参数session用于指示标签转移到第二状态后应保持的持续时间;所述调整模块,还用于一个盘点周期结束后,获取变量TagNumber的值,根据TagNumber的值设定下一个盘点周期中的时间参数session,时间参数session与变量TagNumber正相关;
所述根据TagNumber的值设定下一个盘点周期中的时间参数session具体包括:
若上一个盘点周期的session的状态为S1,且上一个盘点周期的TagNumber>90时,将下一个盘点周期的session的状态设定为S2;若上一个盘点周期的session的状态为S1,且上一个盘点周期的TagNumber≤10,则将下一个盘点周期的session的状态设定为S0;若上一个盘点周期的session的状态为S0,且上一个盘点周期的TagNumber>10,则将下一个盘点周期的session的状态设定为S1;若上一个盘点周期的session的状态为S2,且上一个盘点周期的TagNumber≤90,则将下一个盘点周期的session的状态设定为S1;
其中,session的状态为S0时,标记的持续时间小于200毫秒;session的状态为S1时,标记的持续时间在500毫秒至5秒之间;session的状态为S2时,标记的持续时间大于2秒。
CN201810815992.1A 2018-07-24 2018-07-24 标签盘点的防冲突方法、读写器 Active CN109002743B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810815992.1A CN109002743B (zh) 2018-07-24 2018-07-24 标签盘点的防冲突方法、读写器

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810815992.1A CN109002743B (zh) 2018-07-24 2018-07-24 标签盘点的防冲突方法、读写器

Publications (2)

Publication Number Publication Date
CN109002743A CN109002743A (zh) 2018-12-14
CN109002743B true CN109002743B (zh) 2022-01-25

Family

ID=64596207

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810815992.1A Active CN109002743B (zh) 2018-07-24 2018-07-24 标签盘点的防冲突方法、读写器

Country Status (1)

Country Link
CN (1) CN109002743B (zh)

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110135211B (zh) * 2019-04-01 2022-02-18 山东华翼微电子技术股份有限公司 一种能够快速准确盘存rfid射频标签数量的方法及装置
CN111611819B (zh) * 2020-05-26 2023-10-31 成都睿畜电子科技有限公司 一种用于uhf群扫盘点系统的天线自检方法
CN113283260B (zh) * 2021-07-21 2021-10-01 深圳市成为信息技术有限公司 多通道读写器通道智能切换的方法、读写器及存储介质
CN113554137B (zh) * 2021-09-17 2021-12-17 江苏东大集成电路系统工程技术有限公司 标签盘存方法、读写器、存储介质及计算机设备
CN113657131B (zh) * 2021-10-20 2022-02-11 深圳市成为信息技术有限公司 Uhf手持终端的标签盘点方法及uhf手持终端

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106022185A (zh) * 2016-05-09 2016-10-12 天津理工大学 一种基于连续检测机制适用于EPC Gen2协议的防冲突算法

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8149120B2 (en) * 2007-03-30 2012-04-03 Intel Corporation Temporary non-responsive state for RFID tags
CN106682555B (zh) * 2016-12-16 2019-08-16 重庆川仪自动化股份有限公司 一种rfid读写器读取参数的自适应设定方法及装置
CN107895131B (zh) * 2017-11-06 2021-08-13 厦门印天电子科技有限公司 一种符合iso15693协议的rfid标签盘点方法

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106022185A (zh) * 2016-05-09 2016-10-12 天津理工大学 一种基于连续检测机制适用于EPC Gen2协议的防冲突算法

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
基于ZYNQ-7000平台的多协议UHF RFID读写器软件设计;干慧娜;《中国优秀硕士学位论文全文数据库 信息科技辑》;20160315;第12至14、39、45至48、69页,图3-15、3-16、4-19 *

Also Published As

Publication number Publication date
CN109002743A (zh) 2018-12-14

Similar Documents

Publication Publication Date Title
CN109002743B (zh) 标签盘点的防冲突方法、读写器
Vogt Efficient object identification with passive RFID tags
US8077013B2 (en) RFID reader Q-parameter aided by RF power measurement
Cheng et al. Analysis and simulation of RFID anti-collision algorithms
US8120494B1 (en) RFID readers and systems with antenna switching upon detecting too few tags and methods
KR20080058068A (ko) 태그의 수 추정 및 충돌 방지 시스템과 그 추정 및 충돌방지 방법
KR20070048071A (ko) 슬롯 알로하 기반 알에프아이디 시스템에서의 태그 개수추정방법
Yihong et al. Multiple-bits-slot reservation aloha protocol for tag identification
CN109446857A (zh) 基于快速动态帧时隙的标签防碰撞方法及系统
CN102024163B (zh) 一种带有分组预览机制的防碰撞方法
Kawakita et al. Anti-collision performance of Gen2 air protocol in random error communication link
Xu et al. Negotiate power and performance in the reality of RFID systems
Hessar et al. Energy based performance evaluation of passive EPC Gen 2 class 1 RFID systems
Yoon et al. ISS-TCA: An identified slot scan-based tag collection algorithm for performance improvement in active RFID systems
Chen A new RFID anti-collision algorithm for the EPCglobal UHF class-1 generation-2 standard
US20150317500A1 (en) Method, apparatus and system for collecting tags using bit map in rfid system
Bang et al. Identification of RFID tags in dynamic framed slotted ALOHA
CN107506674A (zh) 基于时隙预测的aloha防碰撞方法
CN114186572A (zh) 一种基于冲突时隙协调的未知标签识别方法及系统
US11120232B2 (en) Early collision detection and handling in CDMA-based RFID systems
Ahmad An improved accelerated frame slotted ALOHA (AFSA) algorithm for tag collision in RFID
JP2009514311A (ja) リーダを介してトランスポンダからデータを読み取る方法、トランスポンダ、及びリーダ
Song et al. An improved reader anti-collision algorithm based on pulse protocol with slot occupied probability in dense reader mode
Nazir et al. Optimal dynamic frame-slotted Aloha
Liu et al. A fast and stable anti-collision algorithm for the EPCglobal UHF Class 1 Generation 2 standard

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
CP01 Change in the name or title of a patent holder
CP01 Change in the name or title of a patent holder

Address after: 518000 Floor 9, plant 2, Daqian industrial plant, Longchang Road, district 67, Bao'an District, Shenzhen, Guangdong Province

Patentee after: Shenzhen Chengcheng Information Co.,Ltd.

Address before: 518000 Floor 9, plant 2, Daqian industrial plant, Longchang Road, district 67, Bao'an District, Shenzhen, Guangdong Province

Patentee before: CHAINWAY INFORMATION TECHNOLOGY Co.,Ltd.