To write a verilog code for 4bit adder and verify the functionality using Test bench.
Write Verilog Code
Verify the Functionality using Test-bench.
Functional Simulation: nclaunch Simulator (nclaunch)
To construct a 4-bit adder, need to chain together four 1-bit full adders. Each full adder computes the sum and carry for one bit of the two numbers. The carry-out from one adder feeds into the carry-in of the next adder in the sequence. This process adds the two 4-bit numbers bit by bit, with the carry propagating through each stage, resulting in a final sum and carry-out at the end.
To design a 1-bit full adder, the first step is to create a truth table that represents all possible combinations of the inputs (A, B, and CIN) and the corresponding outputs (Sum(S) and COUT).
Here’s the truth table for a 1-bit full adder:
- Sum (S):
S=A⊕B⊕CIN
Where ⊕ represents XOR.
- Carry out (COUT):
COUT=(A&B) | (CIN&(A^B))
In the Terminal, type gedit .v (ex: gedit 4bitadder.v).
A Blank Document opens up into which the following source code can be typed down.
Note : File name should be with HDL Extension
Three Codes shall be written for implementation of 4-bit Adder as follows,
• fa.v → Single Bit 3-Input Full Adder [Sub-Module / Function]
• fa_4bit.v → Top Module for Adding 4-bit Inputs.
• fa_4bit_test.v → Test bench
*/Program to design 4 bit adder by instantiating 1 bit Full adder.also add test bench program / Developed by: Register Number/
Invoke the cadence environment by type the below commands
tcsh (Invokes C-Shell)
source /cadence/install/cshrc (mention the path of the tools)
(The path of cshrc could vary depending on the installation destination)
After this you can see the window like below
To Launch Simulation tool
• linux:/> nclaunch -new& // “-new” option is used for invoking NCVERILOG for the first time for any design
or
• linux:/> nclaunch& // On subsequent calls to NCVERILOG
It will invoke the nclaunch window for functional simulation we can compile,elaborate and simulate it using Multiple Step .
Select Multiple Step and then select “Create cds.lib File” .
Click the cds.lib file and save the file by clicking on Save option
Save cds.lib file and select the correct option for cds.lib file format based on the HDL Language and Libraries used.
Select “Don’t include any libraries (verilog design)” from “New cds.lib file” and click on “OK” as in below figure .
• We are simulating verilog design without using any libraries
• A Click “OK” in the “nclaunch: Open Design Directory” window as shown in below figure
A ‘NCLaunch window’ appears as shown in figure below
Left side you can see the HDL files. Right side of the window has worklib and snapshots directories listed.
Worklib is the directory where all the compiled codes are stored while Snapshot will have output of elaboration which in turn goes for simulation .
To perform the function simulation, the following three steps are involved Compilation, Elaboration and Simulation.
Inputs: Supplied are Verilog design and test bench codes
Outputs: Compiled database created in mapped library if successful, generates report else error reported in log file
Steps for compilation:
- Create work/library directory (most of the latest simulation tools creates automatically)
- Map the work to library created (most of the latest simulation tools creates automatically)
- Run the compile command with compile options i.e Cadence IES command for compile: ncverilog +access+rwc -compile fa.v
Left side select the file and in Tools : launch verilog compiler with current selection will get enable. Click it to compile the code
Worklib is the directory where all the compiled codes are stored while Snapshot will have output of elaboration which in turn goes for simulation
After compilation it will come under worklib you can see in right side window
Select the test bench and compile it. It will come under worklib. Under Worklib you can see the module and test-bench.
The cds.lib file is an ASCII text file. It defines which libraries are accessible and where they are located. It contains statements that map logical library names to their physical directory paths. For this Design, you will define a library called “worklib”
Inputs: Top level design / test bench Verilog codes
Outputs: Elaborate database updated in mapped library if successful, generates report else error reported in log file
Steps for elaboration – Run the elaboration command with elaborate options
- It builds the module hierarchy
- Binds modules to module instances
- Computes parameter values
- Checks for hierarchical names conflicts
- It also establishes net connectivity and prepares all of this for simulation
After elaboration the file will come under snapshot. Select the test bench and elaborate it.
Step 3: Simulation: – Simulate with the given test vectors over a period of time to observe the output behaviour.
Inputs: Compiled and Elaborated top level module name
Outputs: Simulation log file, waveforms for debugging
Simulation allow to dump design and test bench signals into a waveform
Steps for simulation – Run the simulation command with simulator options
The functionality of a 4-bit adder was successfully verified using a test bench and simulated with the nclaunch tool.


