Information AboutLfsr |
| CATEGORIES ABOUT LINEAR FEEDBACK SHIFT REGISTER | |
| digital registers | |
| cryptographic algorithms | |
| pseudorandom number generators | |
| SHOPPER'S DELIGHT | |
|
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. HOW IT WORKS The list of the bits positions that affect the next state is called the tap sequence. In the diagram below, the sequence is {Link without Title} .
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.
OUTPUT STREAM PROPERTIES
APPLICATIONS LFSR's can be implemented in hardware, and this makes them useful in applications that require very fast generation of a pseudo-random sequence, such as Direct-sequence Spread Spectrum radio. The Global Positioning System uses a LFSR to rapidly transmit a sequence that indicates high-precision relative time offsets. A DROP IN REPLACEMENT FOR GRAY CODE COUNTERS Some applications need to mark individual locations along a certain distance with unique values. For example, most Tape Measure s mark each inch or centimeter with a unique number using the Decimal numeral system. When computer index or framing locations need to be machine-readable, they are often marked using a LFSR sequence, because LFSR Counter s are simpler and faster than any other kind of binary counter. LFSRs are faster than the natural Binary counters or Gray Code counters. Given an output sequence you can construct a LFSR of minimal size by using the Berlekamp-Massey Algorithm . GALOIS LFSRS A Galois LFSR, or a LFSR in Galois configuration is a variation on typical LFSR design. 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.
USES IN CRYPTOGRAPHY LFSRs have long been used as a Pseudo-random Number Generator for use in Stream Cipher s (especially in Military cryptography), due to the ease of construction from simple Electromechanical or Electronic Circuits , long Period s, and very uniformly Distributed outputs. However the outputs of LFSRs are completely Linear , leading to fairly easy Cryptanalysis . 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 . USES IN DIGITAL BROADCASTING AND COMMUNICATIONS In order to keep digital transmissions from forming latent energy patterns that may disrupt other digital or analog transmissions -- linear feedback registers are used to create more randomness in the outgoing digital bitstream (this technique is referred to as Scrambling ). Digital broadcasting systems that use linear feedback registers
Other digital communications systems using LFSR:
SEE ALSO EXTERNAL LINKS
|