A linear feedback shift register (LFSR) is a shift register whose input bit is a linear function of its previous state.
The only linear functions of single bits are xor and inverse-xor; thus it is a shift register whose input bit is driven by the exclusive-or (xor) of some bits of the overall shift register value.
The initial value of the LFSR is called the seed, and because the operation of the register is deterministic, the sequence of values produced by the register is completely determined by its current (or previous) state. Likewise, because the register has a finite number of possible states, it must eventually enter a repeating cycle. However, a LFSR with a well-chosen feedback function can produce a sequence of bits which appears random and which has a very long cycle.
Applications of LFSRs include generating pseudo-random numbers, pseudo-noise sequences, fast digital counters, and whitening sequences. Both hardware and software implementations of LFSRs are common.
The list of the bits positions that affect the next state is called the tap sequence. In the diagram below, the sequence is *.
The sequence of numbers generated by a LFSR can be considered a binary numeral system just as valid as Gray code or the natural binary code.
The tap sequence of an LFSR can be represented as a polynomial mod 2. This means that the coefficients of the polynomial must be 1's or 0's. This is called the feedback polynomial or characteristic polynomial. For example, if the taps are at the 16th, 14th, 13th and 11th bits (as below), the resulting LFSR polynomial is
The 'one' in the polynomial does not correspond to a tap. The powers of the terms represent the tapped bits, counting from the left.
The animation below is erroneous. In one stage of the cycle the values of the taps do not correspond to the values stored in bit positions 14 and 16. The values of the taps rather than the values in the bit positions are then used to calculate the code, thus propagating the error into the feedback. This occurs when the last 3 bits are 100.
The Global Positioning System uses a LFSR to rapidly transmit a sequence that indicates high-precision relative time offsets.
In Galois configuration, when the system is clocked, bits that are not taps are shifted as normal. The taps, on the other hand, are XOR'd with the new output, which also becomes the new input. To generate the same sequence, the order of the taps is the reverse of the order for the conventional LFSR.
Three general methods are employed to reduce this problem in LFSR based stream ciphers
Important LFSR-based stream ciphers include A5/1, A5/2, E0 and the shrinking generator.
Digital broadcasting systems that use linear feedback registers
Other digital communications systems using LFSR:
Digital circuits | Cryptographic algorithms | Pseudorandom number generators
Linear rückgekoppeltes Schieberegister | Vikipedio:Projekto matematiko/Lineara retrokupla ŝova registro | LFSR
This article is licensed under the GNU Free Documentation License.
It uses material from the
"Linear feedback shift register".
Home Page • arts • business • computers • games • health • hospitals • home • kids & teens • news • physicians • recreation• reference • regional • science • shopping • society • sports • world