The present description addresses the field of Radio Frequency IDentification (RFID) systems, and more specifically, to RFID tags able to generate random numbers.
Radio Frequency IDentification (RFID) systems typically include RFID tags and RFID readers (the latter are also known as RFID reader/writers or RFID interrogators). RFID systems can be used in many ways for locating and identifying objects to which the tags are attached. RFID systems are particularly useful in product-related and service-related industries for tracking large numbers of objects being processed, inventoried, or handled. In such cases, an RFID tag is usually attached to an individual item, or to its package.
In principle, RFID techniques entail using an RFID reader to interrogate one or more RFID tags. The reader transmitting a Radio Frequency (RF) wave performs the interrogation. A tag that senses the interrogating RF wave responds by transmitting back another RF wave. The tag generates the transmitted back RF wave either originally, or by reflecting back a portion of the interrogating RF wave in a process known as backscatter. Backscatter may take place in a number of ways.
The reflected back RF wave may further encode data stored internally in the tag, such as a number. The response is demodulated and decoded by the reader, which thereby identifies, counts, or otherwise interacts with the associated item. The decoded data can denote a serial number, a price, a date, a destination, other attribute(s), any combination of attributes, and so on.
An RFID tag typically includes an antenna system, a power management section, a radio section, and frequently a logical section, a memory, or both. In earlier RFID tags, the power management section included a energy storage device, such as a battery. RFID tags with an energy storage device are known as active tags. Advances in semiconductor technology have miniaturized the electronics so much that an RFID tag can be powered solely by the RF signal it receives. Such RFID tags do not include an energy storage device, and are called passive tags.
Some RFID communication protocols require tags to generate and use random numbers in some occasions. In other words, generate and use numbers that are different every time, and where one is not predictable from the previous ones.
A first such occasion can be when tags are being inventoried by an RFID reader, as can be required by a number of communication protocols. The random numbers assign each tag a number, as if by lottery. Then each tag responds only when its number comes up. This prevents many tags from responding at once, which in turn permits them to be accessed individually, while the other tags in the group are silent.
A second such occasion is for enhancing security. When it is a tag's turn to respond, it can give out its proposed “handle”, which operates as a custom nickname. Then the reader can use the nickname to call on the tag and receive its other information, such as an identifying code. This way the reader does not have to use the tag's code, for calling on it. This enhances security in the communication, in that a hypothetical rogue eavesdropping device need not just listen to the reader, but would also have to listen to the tag. This is harder on the rogue device, because the reader transmits with much more power than the tag.
A third such occasion is for encryption. A tag can use a random number as a key for encryption, when transmitting its own information. This would make it even harder on the hypothetical rogue eavesdropping device, even if it listened to the tag itself.
Generating random numbers is a challenge for RFID tags. Solutions given in the prior art include schemes where a sequence of random numbers is repeated, which is also known as pseudo-random number generation. These schemes can be ineffective when multiple tags are to be read at once, or if rogue readers become sophisticated. For example, knowing the structure of a tag circuit could reveal the pattern behind pseudo random numbers. True random numbers may perform better in these regards.
The invention overcomes the challenge of the prior art.
Random number generators for RFID tags and methods are described. Random numbers are generated based on noise, which is inherently unpredictable. In some such embodiments a noise-based signal is generated from noise, and then digitized.
These and other features and advantages of the invention will be better understood in view of the Detailed Description and drawings, in which:
Certain details are set forth below to provide a sufficient understanding of the invention. However, it will be clear to one skilled in the art that the invention may be practiced without these particular details. Moreover, the particular embodiments of the present invention described herein are provided by way of example and should not be used to limit the scope of the invention to these particular embodiments. In other instances, well-known circuits, control signals, timing protocols, and software operations have not been shown in detail in order to avoid unnecessarily obscuring the invention.
Reader 110 and tag 120 exchange data via wave 112 and wave 126. In a session of such an exchange, each encodes, modulates, and transmits data to the other, and each receives, demodulates, and decodes data from the other. The data is modulated onto, and decoded from, RF waveforms, as will be seen in more detail below.
Encoding the data can be performed in a number of different ways. For example, protocols are devised to communicate in terms of symbols, also called RFID symbols. A symbol for communicating can be a delimiter, a calibration symbol, and so on. Further symbols can be implemented for ultimately exchanging binary data, such as “0” and “1”, if that is desired.
Tag 120 can be a passive tag or an active tag, i.e. having its own power source. Where tag 120 is a passive tag, it is powered from wave 112.
Tag 220 is formed on a substantially planar inlay 222, which can be made in many ways known in the art. Tag 220 also includes two antenna segments 227, which are usually flat and attached to inlay 222. Antenna segments 227 are shown here forming a dipole, but many other embodiments using any number of antenna segments are possible.
Tag 220 also includes an electrical circuit, which is preferably implemented in an integrated circuit (IC) 224. IC 224 is also arranged on inlay 222, and electrically coupled to antenna segments 227. Only one method of coupling is shown, while many are possible.
In operation, a signal is received by antenna segments 227, and communicated to IC 224. IC 224 both harvests power, and responds if appropriate, based on the incoming signal and its internal state. In order to respond by replying, IC 224 modulates the reflectance of antenna segments 227, which generates the backscatter from a wave transmitted by the reader. Coupling together and uncoupling antenna segments 227 can modulate the reflectance, as can a variety of other means.
In the embodiment of
Circuit 330 includes at least two antenna connections 332, 333, which are suitable for coupling to one or more antenna segments (not shown in
Antenna connections 332, 333 may be made in any suitable way, such as pads and so on. In a number of embodiments more than two antenna connections are used, especially in embodiments where more antenna segments are used.
Circuit 330 includes a section 335. Section 335 may be implemented as shown, for example as a group of nodes for proper routing of signals. In some embodiments, section 335 may be implemented otherwise, for example to include a receive/transmit switch that can route a signal, and so on.
Circuit 330 also includes a Power Management Unit (PMU) 341. PMU 341 may be implemented in any way known in the art, for harvesting raw RF power received via antenna connections 332, 333. In some embodiments, PMU 341 includes at least one rectifier, and so on.
In operation, an RF wave received via antenna connections 332, 333 becomes received by PMU 341 as a signal. The signal is used for both harvesting its power and decoding it.
Circuit 330 additionally includes a demodulator 342. Demodulator 342 demodulates an RF signal received via antenna connections 332, 333. Demodulator 342 may be implemented in any way known in the art, for example including an attenuator stage, amplifier stage, and so on.
Circuit 330 further includes a processing block 343. Processing block 343 receives the demodulated signal from demodulator 342, and may perform operations. In addition, it may generate an output signal for transmission.
Processing block 343 may be implemented in any way known in the art. For example, processing block 343 may include a number of components, such as a processor, a memory, a decoder, an encoder, and so on.
Processing block 343 also includes a random number generator system RNGS 344, which is noise-based. In other words, RNGS 344 outputs a sequence of random numbers, whose randomness is determined by electrical noise. RNGS 344 is described in more detail later in this document.
Circuit 330 additionally includes a modulator 346. Modulator 346 modulates an output signal generated by processing block 343. The modulated signal is transmitted by driving antenna connections 332, 333, and therefore driving the load presented by the coupled antenna segment or segments. Modulator 346 may be implemented in any way known in the art, for example including a driver stage, amplifier stage, and so on.
In one embodiment, demodulator 342 and modulator 346 may be combined in a single transceiver circuit. In another embodiment, modulator 346 may include a backscatter transmitter or an active transmitter. In yet other embodiments, demodulator 342 and modulator 346 are part of processing block 343.
It will be recognized at this juncture that circuit 330 can also be the circuit of an RFID reader according to the invention, without needing PMU 341. Indeed, an RFID reader can typically be powered differently, such as from a wall outlet, a battery, and so on. Additionally, when circuit 330 is configured as a reader, processing block 343 may have additional Inputs/Outputs (I/O) to a terminal, network, or other such devices or connections.
RNG 402 outputs a signal that encodes a sequence 406 of random numbers. For purposes of this document, the shorthand can be used that a random number generator outputs the random numbers themselves. In digital system implementations, the numbers are a series of digital bits 0 and 1.
The random number sequence 406 is received by the other circuit 408, which is suitable for using it for a number of processes, such as inventorying, enhanced security, encryption, and so on.
Optionally, RNG 402 may also receive a clock signal CLOCK. In one embodiment, outputting sequence 406 occurs responsive to the clock signal CLOCK.
RNG 402 includes a noise-controlled component 420, and optionally other components, such as other component 411. Component 420 generates a noise-dependent output. The signal that encodes sequence 406 of random numbers is formed from the noise-dependent output. In some embodiments, this noise-dependent output is a signal of a first series of random numbers. In some of those embodiments, this first series is sequence 406 itself.
Component 420 may be implemented in a number of ways. A number of those are described below.
In the embodiment of
Component 420 also includes a digitizer 427, which may generate random numbers from noise-based signal NBS. Digitizer 427 may be made in any way known in the art. Some embodiments include analog to digital converters, comparators, logic devices such as logic gates configured to receive analog inputs, etc.
In some embodiments, a pseudo random number generator (PRNG) is also used in conjunction with the noise-controlled component 420 to generate the random numbers. A PRNG can be made in any way known in the art. One such way is, for example by feedback shift registers formed by series of flip-flops, e.g. a linear feedback shift register or a non-linear feedback shift register. Two such embodiments for using PRNGs are now described.
Combiner 560 can be made in any suitable way. One such way is with logic gates, such as for example using an XOR gate.
PRNG 650 may use the noise-dependent output of component 420 in a number of ways. Two such ways are described below.
Noise controlled component 420 can be made in any suitable way. Two such ways are now described.
Comparator 927 may be adapted to compare the variable noise-based signal NBS to a threshold, and to generate random numbers based on the comparison. Additionally, comparator 927 may also be adapted to amplify the output signal in cases where the noise signal may be small or difficult to detect.
The sampler 912 is a circuit that can optionally be configured to sample the variable noise-based digital signal NBDS generated by the comparator 927. While the sampler may be implemented by any means, one possible way is to sample the variable signal NBDS over time. Sampler 912 may then generate binary digits 906 based on the sampling.
In one embodiment at least one flip-flop 1027 receives a signal CLK2 from the oscillator 1024 and additionally another clock signal CLK1, to generate an unpredictable output of random sequence 1006. Sequence 1006 may optionally be further shifted through a linear feedback shift register for scrambling, and so on.
Oscillator 1024 may be implemented in any way known in the art. For example, it can be free running, and most free running oscillators are noisy to some extent. It is also preferred that CLK2 be not even be a small rational multiple or fraction of the CLK1 clock signal. For example, if CLK1 is at 1MHz, oscillator 1024 might be set such that CLK2 is 837 kHz, or 3.711 MHz, but not 1 MHz or 3 MHz or 500 kHz.
In addition, the rates of generation can be implemented in different ways. For example, random sequence 1006 may be generated at a first rate. Random numbers may then be shifted through the linear feedback shift register at a second rate. The second rate can be faster than the first rate.
As described in the- preceding embodiments, RNG 402 generates a sequence 406 of random numbers. This can be implemented in a number of ways, based on the noise-based signal NBS. In some instances the noise-based signal NBS is considered as generated by itself, and in others as added to a baseline signal. In the latter instances, the baseline signal is considered to be noise sensitive.
The noise-based signal NBS can be generated in a number of ways. One such way is for the NBS to be a voltage, which is generated at a sampling node of a circuit. Another way is for signal NBS to be a current, and so on.
Regardless of whether a voltage or a current, in some further embodiments, the noise-based signal NBS may additionally be adjusted in response to sequence 406 itself. This would ensure, for example, a sampling based on the noise source, and not any other interference. Such an example is now described.
It will be observed that, in many of the individual steps described below, noise is added inherently. These include sampling, multiplying or copying the NBS value, along with comparison. In fact, comparison itself has noise both in the threshold and in the circuits that do the comparison. This inherent inclusion of noise is underscored by explicitly including the word “noise” in some of the boxes below.
In diagram 1100, at step 1110 the signal NBS is compared to a suitable threshold signal VT, which is a voltage or a current depending on NBS. The comparison is used to determine what will be the next generated random digit, i.e. 0 or 1.
If at step 1110 signal NBS is less than threshold VT, then at a next step 1120, an output of 0 is generated. Then at an optional next step 1130 signal NBS is adjusted, e.g. by being multiplied by a parametric factor K1. Then execution returns to step 1110.
If at step 1110 signal NBS is greater than threshold VT, then at a next step 1140, an output of 1 is generated. Then at an optional next step 1150 signal NBS is adjusted, e.g. by being multiplied by a parametric factor K2, and reduced by a parametric signal V1. Then execution returns to step 1110.
Through this process, signal NBS undergoes different values that depend on noise. The parameters K1, K2, and V1 can be adjusted so that these values are above and below VT for approximately equal times. Alternative embodiments may include maintaining the voltage of the variable signal NBS within a minimum and maximum value as needed for generating random numbers.
Circuit 1220 is a switched capacitor circuit. It includes a capacitor C2 between nodes 1248, 1252. A first switch 1280 is provided between node 1248 and a node 1244, and a second switch 1280 is provided between node 1252 and a sampling node 1260. Switches 1280 are turned on and off, for example according to a first clock CLK1. It need not be the same clock for both, and its period can be variable.
The whole operation, including the charging and discharging capacitor C2 generates a noise-based voltage NBV at a sampling node 1260. Noise-based voltage NBV operates as the above described noise-based signal NBS.
A comparator 1227 samples noise-based voltage NBV, and accordingly generates signals that encode a Random Bit Sequence 1206. The bit is generated according to the result of the comparison. As implemented here, the threshold is set at half the power-supply voltage. In general, the threshold can be any of a range of values dictated by the capacitor ratios. Different combinations of capacitor value ratios and thresholds will change the performance of the circuit; particularly poor choices will make the circuit generate non-random numbers (generally all 0s or all 1s).
In addition, the signals that encode sequence 1206 are used to charge (or not charge) capacitor C2 at node 1248, via a switch 1292.
Additional components are provided for operation of circuit 1220. It should be kept in mind that their values can be adjusted to affect the generation of sequence 1206, similarly to how parameters K1, K2 and Vi can be adjusted in flow diagram 1100 above.
Circuit 1220 includes capacitors C1, C3 between a ground and nodes 1244, 1260 respectively. In addition, a buffer 1236 buffers noise-based voltage NBV, and provides a buffered output signal to nodes 1244, 1256, via switches 1290. Switches 1290, and also switch 1292, can operate from the same clock CLK2, although that is not necessary. Equally, the period of clock CLK2 is another adjustable parameter, as per the above.
It will be further appreciated that sequence 1206 can be a long string of unpredictable digits. A problem is that the first few of these digits can be deterministic, i.e. the same every time, until the effect of noise takes over and makes them truly random. Noise can come from the operation of the components themselves, such as switches 1280, 1290, and 1292, and also from the comparator, buffer, and power supply, cosmic rays, etc.
At step 1310 a variable noise-based signal NBS is generated. Then at step 1330 random numbers are generated based on signal NBS.
The random numbers may be generated by any suitable method, including the methods described above. Additionally, the random numbers may be scrambled to further randomize the output sequence, as previously mentioned.
As described above, there may be the problem that the initial numbers are more deterministic, before the effects of noise take over to truly generate random numbers. This can be addressed in a number of ways, which involve discarding something generated initially. Discarding can be timed to take place over a number of clock cycles, and so on. As for what to discard, two examples are described below.
At an optional intermediate step 1320, an initial portion of signal NBS is discarded. This will prevent generating random numbers from that portion of the signal, which could be deterministic.
At an alternate optional intermediate step 1340, some of the initial generated numbers are themselves discarded. An example is shown below.
In the embodiments where discarding is described above, digits 1440 can be discarded. This is either by discarding the digits, or the signal that generated them. Then the output digits 1460 can be presented as the random numbers.
For discarding to work better, digits 1440 should be generated quickly, so that digits 1460 can be the output. This is not a problem with the above described embodiments, that can generate numbers quickly.
From the foregoing it will be appreciated that, although specific embodiments of the invention have been described herein for purposes of illustration, various modifications may be made without deviating from the spirit and scope of the invention. Accordingly, the invention is not limited except as by the appended claims.
This application claims the benefit of U.S. Provisional Application 60/667,180 entitled “RFID tags generating RNs based on noise”, filed Mar. 30, 2005, which is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
60667180 | Mar 2005 | US |