Skip to main content

Binary Adder Circuits

Binary Adder Circuits

What You will Learn

  • You will understand the theory of binary addition using half adders and full adders.
  • You will learn to realize parallel adder on the simulator.

Objectives

  • The task is to build half adder and full adder circuits with logic gates both on Qucs and to verify their truth tables.
  • To develop a four bit adder using Qucs and to perform binary addition with it.
  • Half Adder Circuits

    Half adder receives two input bits ($X_n$ and $Y_n$) and produces the sum of the two ($S_n$) and the carry output ($C_n$). It does not add the carry from the previous stage and hence By the inspection of the truth table of half adder in the table below.
    Truth table of a half adder
    $X_n$ $Y_n$ $S_n$ $C_n$
    $0$ $0$ $0$ $0$
    $0$ $1$ $1$ $0$
    $1$ $0$ $1$ $0$
    $1$ $1$ $0$ $1$
    The sum bit and the carry bit are designed as \begin{align} S_{n}&=X_{n}\oplus Y_{n}\\ C_{n}&=X_{n}.Y_{n} \end{align}

    Implementation of Half Adder in QUCS

    See the QUCS schematic below. Wire up the circuit using the digital components. ($\fbox{Components}$ $\longrightarrow $ $\fbox{Digital Components}$). Drop the digital switches to simulate the inut signals. Give $Y$ with double the frequency of $X$. Drop $\fbox{Digital Simulation}$ onto the schematic window and run the simulation. Once the simulation is completed, drop $\fbox{tabular}$ on the display window to observe the truth table, as shown below. You may also observe the waveforms.

    Full Adder Circuit

    The full adder block adds two input bits ($X_{n}$, $Y_{n}$) and the carry output ($C_{n-1}$) from the previous adder block and produces the sum bit $S_{n}$ and the carry output ($C_n$). The truth table is shown below.

    Truth table of a full adder
    $X_n$ $Y_n$ $C_{n-1}$ $S_n$ $C_n$
    $0$ $0$ $0$ $0$ $0$
    $0$ $0$ $1$ $1$ $0$
    $0$ $1$ $0$ $1$ $0$
    $0$ $1$ $1$ $0$ $1$
    $1$ $0$ $0$ $1$ $0$
    $1$ $0$ $1$ $0$ $1$
    $1$ $1$ $0$ $0$ $1$
    $1$ $1$ $1$ $1$ $1$

    The K-map reduction yields the sum bit $S_{n}$ as \begin{align*} S_{n}&=C_{n-1}.(\overline{X_{n}}.\overline{Y_{n}}+X_{n}.Y_{n}) +\overline{C_{n-1}.}(\overline{X_{n}}.Y_{n}+X_{n}.\overline{Y_{n}})\\ &=A_{n}\oplus B_{n} \oplus C_{n-1} \end{align*} The carry bit $C_{n}$ is obtained by reducing the K-map as \begin{align*} C_{n}=X_{n}.Y_{n}+Y_{n}.C_{n-1}+X_{n}.C_{n-1} \end{align*}

    Simulation of Full Adder on QUCS

    See the QUCs schematic for the full adder given below. Wire up this circuit and perform the digital simulation. Observe the tabular and waveform outputs on the display window.

    Now that we understood the operation of the full adder block it is time we use it as a subcircuit to develop multibit parallel adder.

    Four Bit Parallel Adder

    A multibit adder is realized using a full adder which is realized as a subcircuit. You need to start a project to work with subcircuits. Go to $\fbox{project}$ $\longrightarrow$ $\fbox{new project}$ and give a suitable name to the project and save the project. All relevant files and subcircuits should reside in this project folder or directory.

    Generation of Full Adder Subcircuit

    Replace the signals from the previous full adder circuit with input and output ports. You delete the signals in the schematic. Go to $\fbox{insert}$ $\longrightarrow $ $\fbox{port}$ to insert a port in the schematic. By default, it is an analog port. Right click on it and change the type as input or output digital port. See the modified schematic below.

    Now add this block (saved as .sch file) to the project as $\fbox{Project}$ $\longrightarrow$ $\fbox{Add files to project}$ Now start a fresh page and drop the already made full adder subcircuit four times and wire up a four bit full adder as shown below.
    It should be noted that the carry input of the first stage is an input port. The carry output of all stages are connected to the carry input of the next stage. The completed fourbit adder is shown below.

    Simulation of Four Bit Full Adder

    Several digital sources are connected to the input lines to test the four bit adder for different input combinations. Run the digital simulation and drop $\fbox{Tabular}$ in the display window. Select the bit patterns $a_{3}a_{2}a_{1}a_{0}$, $b_{3}b_{2}b_{1}b_{0}$ and $C_{out}S_{3}S_{2}S_{1}S_{0}$. Observe that the latter pattern is the sum of the two four bit patterns. A sample of the tabular output is shown below. Verify the operation.

    What You Learned

  • You understood the theory of binary addition.
  • You learned to use subcircuit for rapid prototyping
  • You realized half adder, full adder and four bit parallel adder on the simulator
  • Comments

    Popular posts from this blog

    RC Integrator and Differentiator using QUCS

    RC Integrator and Differentiator using QUCS Dr. Hari V S Department of Electronics and Communication College of Engineering Karunagappally What You will Learn You will understand the operation of simple integrator and differentiator circuits using QUCS You will learn the frequency response characteristics of integrator and differentiator by dint of ac simulation. Theory Differentiator is a high pass circuit that produces the time derivative of the input signal at the output. The circuit is shown below. \begin{equation} \nonumber v_{o}=I_{o}R=RC\frac{d(v_{s}-v_{o})}{dt}\\ ...

    Generation of Signals using MATLAB/Python

    Generation of Signals using MATLAB/Python Dr. Hari V S Department of Electronics and Communication College of Engineering Karunagappally What You will Learn You will learn about various energy signals and their generation using MATLAB and python. Signal Generation using MATLAB MATLAB arrays are used to generate finite energy signals. It should be understood that the signals so generated are discrete in time and amplitude. Sinusoidal Signal Consider the sinusoidal signal $x=sin(t)$, which is nothing but a single tone, with the help of the MATLAB code below. t=linspace(0,10,5000); x=sin(t); plot(t,x); grid; The execution of the code will result in the signal, shown below. Amplitude Modulated Signal The above low frequency tone is used to modulate a sinusoidal carrier $y$ of ten times the original frequency. i.e. $y=sin(10t)$. The amplitude modulated signal $am(t)$ is obtained as \begin{equation} am(t)=x*y+y \end{equation}Su...

    Voltage Divider Circuit using QUCS

    SPICE Simulation of Voltage Divider Dr. Hari V S Department of Electronics and Communication College of Engineering Karunagappally What You will Learn You will wire up a voltage divider network using QUCS You will learn to perform DC, AC and transient simulations on the developed circuit. you will learn to observe, store and export the data from the display ( .dpl ) file. Experiment Launch QUCS. Go to Components in the left pane and select the item Lumped Components . Drag and drop a resistor onto the schematic window. Right click on on to and go to Edit properties and make the resistance 1 k&#937 Right click, copy and paste this resistor twice. Connect the three resistors in series by wires, selected by pressing Cntrl+E . Go to Components in the left pane and select Sources &#8594 ac Voltage Source . Drag and drop the source onto the schematics window. Right click on the source and change ...