Jump to content

Counter (digital)

From Wikipedia, the free encyclopedia
(Redirected from Digital counter)
Integrated circuit containing a digital counter (synchronous 4-bit decade counter, Signetics 74162N)

In digital logic, a counter is an electronic device which stores the number of times a particular event or process has occurred as indicated by a clock signal. The most common type is a sequential digital logic circuit with an input signal called the clock, and multiple output signals which collectively represent a number in the binary or BCD number system. Each pulse applied to the clock input causes the value stored in the counter to increment or decrement (increase or decrease by one).

A counter circuit is usually constructed of flip-flops, which store the count value, and in many cases, additional logic to effect particular counting sequences, qualify clocks and perform other functions.

Counters are widely used in digital circuits, and are implemented as stand-alone integrated circuits and also commonly incorporated into larger integrated circuits.

Common characteristics

[edit]

An electronic counter is a sequential logic circuit that has a clock input signal and a group of output signals that represent an integer "count" value. Upon each qualified clock edge, the circuit will increment (or decrement, depending on circuit design) the stored count. When the count reaches the end of the counting sequence (maximum count when incrementing; zero count when decrementing), the next clock will cause the count to overflow or underflow and the counting sequence will start over.

Digital counters use flip-flops to represent the current count and to retain the count between clocks. Depending on the type of counter, the output may be a direct representation of the count (a binary number), or it may be encoded. Examples of the latter include ring counters and counters that output Gray codes.

Many counters provide additional input signals to facilitate dynamic control of the counting sequence, such as:

  • Reset – sets count to zero. Some IC manufacturers name this signal "clear" or "master reset (MR)". Depending on the counter design, this signal may be asynchronous or synchronous.
  • Enable – allows or inhibits counting.
  • Direction – determines whether count will increment or decrement.
  • Data – parallel input data which represents a particular count value.
  • Load – copies parallel input data to the counter.

Some counters provide a Terminal Count output which indicates that the next clock will cause overflow or underflow. This is commonly used to implement counter cascading (combining two or more counters to create a single, larger counter) by connecting the Terminal Count output of one counter to the Enable input of the next counter.

Modulus

[edit]

The modulus of a counter is the number of states in its count sequence. A counter that has modulus value n is commonly referred to as a modulo-n or MOD-n counter. For example, a counter that counts up from 0 to 5 and then overflows is a MOD-6 counter because it has six states.

The maximum possible modulus of a counter is determined by the number of flip-flops. More specifically, a counter with n flip-flops has a maximum possible modulus of 2n. For example, a four-bit counter can have a modulus of up to 16 (24). Some counters (e.g., binary counters) include all possible states in their count sequences. Other counters, such as decade counters, omit one or more possible states from their counting sequences.

Binary counter

[edit]

A binary counter is a digital counter that counts and represents the count in binary. A binary counter is a MOD-2n counter, where n is the number of flip-flops used to store the count. For example, the illustrations below show the behavior of a 5-bit counter, which has 32 (25) states and is therefore a MOD-32 counter:

Decade counter

[edit]

A decade counter has ten states (0 to 9) and thus is a MOD-10 counter. Depending on its design, a decade counter may represent the count in binary-coded decimal or other binary encodings.

Synchronous vs. asynchronous

[edit]

Counters are broadly categorized as either synchronous or asynchronous. In synchronous counters, all flip-flops share a common clock and change state at the same time. In asynchronous counters, each flip-flop has a unique clock, and the flip-flop states change at different times.

Up/down counting

[edit]

An up/down counter is a digital counter which counts up or down as directed by a special input signal. In synchronous up/down counters, the control signal is a single digital input whose state indicates count direction (e.g., '1' = count up; '0' = count down). In asynchronous up/down counters the direction control may alternatively consist of two separate "up" and "down" clock inputs.

Counter types

[edit]

Counters are typically categorized by general architecture. For example:

Asynchronous binary (ripple) counter

[edit]

An asynchronous binary counter, or binary ripple counter, is a "chain" of toggle (T) flip-flops in which the least-significant flip-flop (bit 0) is clocked by an external signal (the counter input clock), and all other flip-flops are clocked by the output of the nearest, less significant flip-flop (e.g., bit 0 clocks the bit 1 flip-flop, bit 1 clocks bit 2, etc.). When implemented with discrete flip-flops, ripple counters are commonly implemented with JK flip-flops, with each flip-flop configured to toggle when clocked (i.e., J and K are both connected to logic high).

Schematic diagram of an n-bit ripple counter constructed from JK flip flops. In this counter, the first flip-flop is clocked by rising edges; all other flip-flops in the chain are clocked by falling clock edges.

Each flip-flop is effectively a one-bit counter which increments its count (by toggling its output) once per clock cycle. It counts from zero to one and then, when the next clock arrives, it will overflow and start its count sequence over again at zero. Each output state persists for a full input clock cycle, and consequently the frequency of each flip-flop's output signal is exactly half that of its input clock. Additional flip-flops may be added to the chain to form a counter of any arbitrary word size (number of bits), with the output frequency of each bit equal to exactly half the frequency of its nearest, less significant bit.

Each flip-flop introduces a delay from input clock edge to output toggle. This causes the counter bits to change at different times, thus producing a ripple effect and making the count unstable as the counter input clock propagates through the circuit. The duration of this instability (the output settling time) is proportional to the number of flip-flops. This makes ripple counters unsuitable for use in synchronous circuits that require the counter to have a fast output settling time. Also, it is often impractical to use ripple counter output bits as clocks for external circuits because the ripple effect causes timing skew between the bits. Ripple counters are commonly used as general-purpose counters and clock frequency dividers in applications where the instantaneous count and timing skew is unimportant.

Synchronous binary counter

[edit]

The circuit shown below is an ascending (up-counting) four-bit synchronous binary counter implemented with JK flip-flops. Each bit of this counter is allowed to toggle when all of its less significant bits are at a logic high state. For example, upon clock rising edge bit 1 toggles if bit 0 is logic high; bit 2 toggles if bits 0 and 1 are both high; bit 3 toggles if bits 2, 1, and 0 are all high.

A 4-bit synchronous counter using JK flip-flops

Decade counter

[edit]
A circuit decade counter using JK Flip-flops (74LS112D)

A decade counter counts in decimal digits, rather than binary. A decade counter may have each (that is, it may count in binary-coded decimal, as the 7490 integrated circuit did) or other binary encodings. A decade counter is a binary counter designed to count to 1001 (decimal 9). An ordinary four-stage counter can be easily modified to a decade counter by adding a NAND gate as in the schematic to the right. Notice that FF2 and FF4 provide the inputs to the NAND gate. The NAND gate outputs are connected to the CLR input of each of the FFs.".[1] It counts from 0 to 9 and then resets to zero. The counter output can be set to zero by pulsing the reset line low. The count then increments on each clock pulse until it reaches 1001 (decimal 9). When it increments to 1010 (decimal 10), both inputs of the NAND gate go high. The result is that the NAND output goes low, and resets the counter to zero. D going low can be a CARRY OUT signal, indicating that there has been a count of ten.

Ring counter

[edit]

A ring counter is a circular shift register that is initiated such that only one of its flip-flops is the state one while others are in their zero states.

A ring counter is a shift register (a cascade connection of flip-flops) with the output of the last one connected to the input of the first, that is, in a ring. Typically, a pattern consisting of a single bit is circulated, so the state repeats every n clock cycles if n flip-flops are used.

Johnson counter

[edit]

A Johnson counter (or switch-tail ring counter, twisted ring counter, walking ring counter, or Möbius counter) is a modified ring counter, where the output from the last stage is inverted and fed back as input to the first stage.[2][3][4] The register repeatedly cycles through a sequence of bit-patterns, whose length is equal to twice that of the shift register.

4-bit Johnson counter using four D-type flip flops

Johnson counters are commonly used in finite state machines and specialized applications such as digital-to-analog conversion, etc. For example, the CMOS 4017 integrated circuit uses a 5-bit Johnson counter to cycle through 10 states, and thus implement a decade counter with encoded outputs:

Implementation

[edit]

Counters are implemented in a variety of ways, including as dedicated MSI and LSI integrated circuits, as embedded counters within ASICs, as general-purpose counter and timer peripherals in microcontrollers, and as IP blocks in FPGAs. In the latter case, a counter is typically instantiated by synthesizing it from a description written in VHDL, Verilog or some other hardware description language. For example, the following VHDL code describes a 32-bit up/down counter with clock enable and load capability:

entity bidirectional_counter is
port (                                      -- counter input/output signals:
  CLK         : in  std_logic;              --   clock
  RESET       : in  std_logic;              --   asynchronous reset
  ENABLE      : in  std_logic;              --   clock enable
  LOAD_ENABLE : in  std_logic;              --   load enable
  COUNT_UP    : in  std_logic;              --   '1' for up, '0' for down counting
  DATA_IN     : in  unsigned(31 downto 0);  --   value to load into counter
  DATA_OUT    : out unsigned(31 downto 0)   --   current counter value
);
end bidirectional_counter;

architecture behavioral of bidirectional_counter is
  signal counter : unsigned(31 downto 0) := (others => '0'); -- counter register
begin
  process(CLK, RESET)
  begin
    if RESET = '1' then             -- if counter reset is requested
      counter <= (others => '0');   --   reset the counter
    elsif rising_edge(CLK) then     -- else upon rising clock edge
      if ENABLE = '0' then          --   if clock is disabled
        null;                       --     do nothing
      elsif LOAD_ENABLE = '1' then  --   else if load is requested
        counter <= DATA_IN;         --     jam new value into counter
      elsif COUNT_UP = '1' then     --   else if up-counting
        counter <= counter + 1;     --     increment counter
      else                          --   else down-counting, so
        counter <= counter - 1;     --     decrement counter
      end if;
    end if;
  end process;
  DATA_OUT <= counter;    -- output current counter value
end behavioral;

See also

[edit]

References

[edit]
  1. ^ "Decade Counter". Integrated Publishing. Retrieved 19 Mar 2020.
  2. ^ Singh, Arun Kumar (2006). Digital Principles Foundation of Circuit Design and Application. New Age Publishers. ISBN 81-224-1759-0.
  3. ^ Horowitz, Paul; Hill, Winfield (1989). The Art of Electronics. Cambridge University Press. ISBN 0-521-37095-7.
  4. ^ Graf, Rudolf F (1999). Modern Dictionary of Electronics. Newnes. ISBN 0-7506-9866-7.
[edit]