Serial Adder using Mealy and Moore FSM in VHDL

The serial adder is a digital circuit in which bits are added a pair at a time.

Block Diagram for Serial Adder
Fig: Block Diagram for Serial Adder

Let A and B be two unsigned numbers to be added to produce Sum = A + B. In this we are using three shift registers which are used to hold A, B and Sum. Now in each clock cycle, a pair of bits is added by the adder FSM and at the end of the cycle, the resulting sum is shifted into the Sum register.

Mealy type FSM for serial adder:

Let G and H denote the states where the carry-in-values are 0 and 1. Output value s depends on both the state and the present value of inputs a and b.

In state G and H:

Input valuationOutput (s)State
000FSM will remain in same state G
01,101FSM will remain in same state G
110FSM moves to state H
01,100FSM will remain in same state H
111FSM will remain in same state H
001FSM moves to state G
State Diagram for Mealy type serial adder FSM
Fig: State Diagram for Mealy type serial adder FSM

A single Flip-Flop is needed to represent the two states. The next state and output equations are:

Y = ab + ay + by

s = a ⊕ b ⊕ y

 State table for the Mealy type serial adder FSM
Fig: State table for the Mealy type serial adder FSM
State-assigned table for the Mealy type serial adder FSM
Fig: State-assigned table for the Mealy type serial adder FSM
Circuit for Mealy type serial adder FSM
Fig: Circuit for Mealy type serial adder FSM

The flip-flop can be cleared by the Reset signal at the start of the addition operation.

Moore type FSM for serial adder:

In a Moore type FSM, output depends only on the present state. Since in both states, G and H, it is possible to produce two different outputs depending on the valuations of the inputs a and b, a Moore type FSM will need more than two states. Therefore we will four states namely: G0, G1, H0 and H1.

State Diagram for Moore type serial adder FSM
Fig: State Diagram for Moore type serial adder FSM

The next state and output equations are:

Y1 = a ⊕ b ⊕ y2

Y2 = ab + by2 + by2

s = y1

State table for the Moore type serial adder FSM
Fig: State table for the Moore type serial adder FSM
State-assigned table for the Moore type serial adder FSM
Fig: State-assigned table for the Moore type serial adder FSM
Circuit for Moore type serial adder FSM
Fig: Circuit for Moore type serial adder FSM

The only difference between circuits of Mealy and Moore type FSM for serial adder is that in Moore type FSM circuit, output signal is passed through an extra flip-flop and thus delayed by one clock cycle with respect to the Mealy type FSM circuit.

References: Fundamentals of Digital Logic with VHDL Design

10 thoughts on “Serial Adder using Mealy and Moore FSM in VHDL”

Leave a Reply to Sevak Cancel Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.