A ring counter is a type of counter composed of a type of circular shift register. The output of the last shift register is fed to the input of the first register. The Hamming distance of an Overbeck counter is 2, the Hamming distance of a Johnson counter is 1.
There are two types of ring counters:
- A straight ring counter or Overbeck counter (most probably named after Wilcox Pratt Overbeck) connects the output of the last shift register to the first shift register input and circulates a single one (or zero) bit around the ring. For example, in a 4-register one-hot counter, with initial register values of 1000, the repeating pattern is: 1000, 0100, 0010, 0001, 1000... . Note that one of the registers must be pre-loaded with a 1 (or 0) in order to operate properly.
- A twisted ring counter, also called switch-tail ring counter, walking ring counter, Johnson counter (from using Libaw-Craig code aka Johnson code, named after Robert Royce Johnson - the patent holder) or Möbius counter (from its abstract similarities with Möbius bands, named after August Ferdinand Möbius), connects the complement of the output of the last shift register to the input of the first register and circulates a stream of ones followed by zeros around the ring. For example, in a 4-register counter, with initial register values of 0000, the repeating pattern is: 0000, 1000, 1100, 1110, 1111, 0111, 0011, 0001, 0000...
Johnson counters are often favoured, not just because they offer twice as many count states from the same number of shift registers, but because they are able to self-initialise from the all-zeros state, without requiring the first count bit to be injected externally at start-up. The Johnson counter generates a Gray code, a code in which adjacent states differ by only one bit.
Four-bit ring counter sequences
|Straight ring/Overbeck counter||Twisted ring/Johnson counter|
Johnson and Overbeck counters
A Johnson counter is a ring with an inversion; here is a 4-bit Johnson counter:
Note the inversion of the Q signal from the last shift register before feeding back to the first D input, making this a Johnson counter.
Ring counters are used in hardware logic design (e.g. ASIC and FPGA design) to create complicated finite state machines. A binary counter will require an adder circuit which is substantially more complex than a ring counter. Additionally, the worst case propagation delay on an adder circuit will be proportional to the number of bits in the code (due to the carry propagation). The propagation delay of a ring counter will be a constant regardless of the number of bits in the code. The complex combinational logic of an adder can create timing errors which may result in erratic hardware performance. Last, ring counters with Hamming distance 2(or more) allow the detection of single bit upsets that can occur in hazardous environments.
The disadvantage of ring counters is that they are lower density codes. A binary counter can represent 2^N states, where N is the number of bits in the code, whereas an Overbeck counter can represent only N states and a Johnson counter can represent only 2N states. This may be an important consideration in hardware implementations where registers are more expensive than combinational logic (e.g. FPGA).
- Counter (digital)
- Ring oscillator
- Linear feedback shift register
- File:4 Bit Ring Counter.svg
- File:Code Libaw-Craig.svg
- Crowe, John; Hayes-Gill, Barrie (1998). Introduction to Digital Electronics. Newnes. p. 161. ISBN 0-340-64570-9.
- Mohamed Rafiquzzaman. Fundamentals of digital logic and microcomputer design, John Wiley and Sons, 2005, p. 166.
- B. Somanathan Nair, Digital electronics and logic design, PHI Learning Pvt. Ltd., 2004, p. 134.