### **Department of Electronics & Communication Engineering**

केन्द्रीय प्रौद्योगिकी संस्थान, कोकराझार Central Institute of Technology, Kokrajhar (A Centrally Funded Institute Under Ministry of HRD, Govt. of India) Kokrajhar, BTAD, Assam, INDIA, PIN-765570

# Implementation of Electronic Voting Machine with Multiple Preferences and Priority using VHDL



Under the supervision of

#### Mr. Kaushik Chandra Deva Sarma

(Asst.professor, Dept. of ECE)

A project word submitted by

Mr. Monoj DuttaGau-c-10/235Mr. Manash K HazarikaGau-c-10/L-317Mr. Anupam RajbongshiGau-c-10/260Mr. Suryakanta GhoseGau-c-10/217

### **Department of Electronics & Communication Engineering**



## **Certificate of Approval**

This is to certify that the work embodied in this project entitled Implementation of Electronic Voting Machine with Multiple Preferences and Priority using VHDL programming submitted by Mr. Monoj Dutta, Mr. Manash Hazarika, Mr. Anupam Rajbongshi, Mr. Suryakanta Ghose to the department of Electronics and Communication Engineering of Central Institute of Technology, Kokrajhar is carried out under our direct supervisions and guidance.

The project work hasbeen prepared as per the rules and regulation of Central Institute of Technology and I strongly recommend that this project work be accepted in partial fulfillment of the requirement for the degree of B.Tech.

Supervisor

2.111/13

(Mr. Kaushik Chandra Deva Sarma)

Assistant Professor, Dept. of ECE

Countersigned by

#### (Mr. Arindam Mukherjee)

HoD i/c ,Dept of ECE

## **Contents:**

| i. Abstractl                         |
|--------------------------------------|
| ii. Acknowledgement2                 |
| 1. Introduction                      |
| 2. Working of EVM4                   |
| 3. Introduction to VHDL7             |
| 4. Flow diagram of EVM8              |
| 5. Design of counter                 |
| 6. Design of comparator10            |
| 7. Test bench waveform               |
| 8. Result12                          |
| 9. RTL Schematic14                   |
| 10. Advantages and disadvantages16   |
| 11. Future enhancement17             |
| 12. Conclusion17                     |
| 13. Reference                        |
| 14. Appendix                         |
| i. Program of EVM19                  |
| ii. Software used: Xilinx ISE 9.1i26 |
| iii. Synthesis repot27               |
| iv. Timing report                    |
|                                      |

## **Abstract**

Traditional paper based voting procedure was very long and time-consuming process and very much prone to errors. Polling by Electronic Voting Machine (EVM) is a simple, safe and secure method that takes minimum of time. Current Electronic Voting Machine (EVMs) used in LOK SABHA and ASSEMBLY elections accepts only one vote from each voter. But in elections such as GRAMA PANCHAYATH and COOPERATIVE SOCIETIES, where each voter casts their votes to more than one candidate, available voting machines will not work. The paper presents a PROGRAMMABLE ELECTRONIC VOTING MACHINE that accepts one or more votes depending on requirement. Mode control is included in EVM, through which it is possible to set the EVM to accept more than one vote from each voter depending on the type of elections. The main advantage of this type of EVM is to avoid the invalid votes especially in co-operative society elections where each voter has to cast vote for nine candidates.

### ACKNOWLEDGEMENT

On the very outset of this report, we would like to extend our sincere and heartiest obligation towards all the personage who have helped us in this Endeavour. Without their active guidance, help, co-operation & encouragement, we would not have made headway in the project.

First and formost, we would like to express our sincere gratitude to our project guide, **Mr. Kaushik Chandra Deva Sarma (Asst. professor,Dept. of ECE,CIT,Kokrajhar)**. We are privileged to experience a sutained enthusiastic and involved interest from his side.He always fuelled our thoughts to think broad and out of box.

We would also like to thank Mr. Haradhan Chel(Asst. professor,Dept. of ECE,CIT,Kokrajhar) and Mr. Arindam Mukherjee (HoD i/c,Dept. of ECE, CIT, Kokrajhar), for giving us the chance to do this project.

Date: 21 Nov, 2013

0

63

63

0

0

63

0

69

0

222

Monoj Dutta (Gau-c-10/235) Manash K Hazarika (Gau-c-10/L-317) Anupam Rajbongshi (Gau-c-10/260) Suryakanta Ghose (Gau-c-10/217)

## Introduction

5

222

5-9

5

-9

-9

1

-

1 

P--0

2 -9

C. -9

C

2 -9

1 -9

2 -9

2 -9

00

0

6-2

6-2

6 3

5-9

6-1

3

3

9 6-3

2

2

8 3

2

6

-9

Elections in India are conducted almost exclusively by using electronic voting machines developed over the past two decades by a pair of government-owned companies. These devices, known in India as EVMs, have been praised for their simple design, ease of use, and reliability. The Electronic Voting Machine (EVM) consists of two interconnected units, the Ballot Unit where the voter casts his vote by pressing a button alongside the name of the candidate and symbol of the party for whom the person chooses to vote for and the Control Unit by which the polling official enables the Ballot Unit for the voter to cast his vote and where all related data like number of votes polled for each candidate, total number of votes cast etc. resides. EVMs reduce the time in both casting a vote and declaring the results compared to the old ballot paper system. The control unit can store the result in its memory for more than 10 years. Invalid votes can be greatly reduced by use of EVMs. Blank votes can be counted. Despite many advantages of EVMs, there are certain issues in terms of software and hardware

In the existing voting machines, number of candidates supported is limited to around 20 only, if number of candidates exceeds 20 we are supposed to use 2 voting machines. At present, EVMs are used only in LOK SABHA and ASSEMBLY elections (it accepts only 1 vote from each voter), but in elections such as GRAMA PANCHAYATH and COOPERATIVE SOCIETIES where each voter cast their votes to more than one candidate; available voting machines can not beused.

This paper presents a PROGRAMMABLE ELECTRONIC VOTING MACHINE that accepts one or more votes depending on our requirement. Here, we have included the mode control, through this we can set the EVM to accept more than one vote from each voter (it can accept 1 or 2 or 3 .... or n votes) depending on the type of elections [3].

. Our Contributions are mainly in designing priority and multiple weighted based voting, where a vote for multiple persons for a positions. Weights of preferences will be used to get final vote counting

The paper is organized as follows. First, working of present EVM is discussed, with its limitations in present Voting system Second, proposed work to overcome present EVM is discussed along with block diagram (modules) and working(in terms of state diagram.). Finally, simulation results, conclusion, and future work are presented.

### Working of EVM

EVM consists of mainly two interconnected units, ballot (implemented with FPGA/CPLD) and control unit (implemented with FPGA), and display module (LEDs) as given in figure 1. In the ballot unit, voter casts his/her vote by pressing a button alongside the name of the candidate and symbol of the party for whom the person chooses to vote. Control unit is given to the polling official, who enables the ballot unit for the voter to cast his vote, and all related data, like number of votes polled for each candidate, total number of votes cast, etc., resides in it. The controls such as ballot, count, result, clear, total, Nvotes, clk, and cd are used to control operations of control unit. Display module is used to display alphanumeric characters. MSB 2 digits are used to display candidate serial number and rest 4 digits are used to display the total number of votes casted for corresponding candidate.



#### Figure 1. Block Diagram of Programmable EVM

The process of voting is as follows. Once the validity of the voter has been ensured, the polling official enables the ballot unit and the voter is asked to go to the area where the ballot unit is placed. Then, the voter scrutinizes the names of the candidates or parties displayed on the ballot unit and cast his vote by pressing the blue button beside the chosen candidate's name or symbol. The corresponding LED is lit and an audible beep is heard confirming the registration of vote in the system. This process is repeated for the next voter. On operation of the "Result" button of the Control Unit, the display indicates the results of the poll including total number of votes cast and the number of votes polled for each candidate.

### (i) Ballot unit:



#### Figure 2. Circuit diagram of Ballot unit

The figure 2 shows the internal block diagram of the ballot unit of the programmable EVM. It consists of LEDs and push to on switches corresponding to the number of candidates on the ballot unit along with 220 ohms resistors in series used to drive the push to on switches, with the power supply of +5v.

The operation is as follows when the voter presses the blue button (one of sw0 to sw19) to cast the vote for his chosen candidate, the corresponding push to on switch gets closed, and a high signal is sent to the control unit, if this signal is enabled, then the counter gets incremented indicating the registration of the vote and the confirmation is done when the red LED glows (corresponding to pressed switch) and a beep sound is heard.

(ii) **Control Unit :**The 'Nvotes' is set by the presiding officer, which indicates the number of votes to be accepted from individual voters. 'Ballot' is also under the control of presiding officer, which is set to accept votes from voter. 'Clear' is set in order to store the votes registered for individual candidate in to FPGA ROM. When 'Result' is set high, number of votes accepted for each candidate, which is stored in ROM is displayed on multiplexed seven segment LED display.

7-Segment display



Figure3: Circuit diagram of control unit

n-votes

Clear

### Introduction to VHDL

The VHSIC Hardware Description Language is an industry standard language used to describe hardware from the abstract to the concrete level. VHDL resulted from work done in the '70s and early '80s by the U.S. Department of Defence.VHDL usage has risen rapidly since its inception and is used by literally tens of thousands of engineers around the globe to create sophisticated electronic products. VHDL is a powerful language with numerous language constructs that are capable ofdescribing very complex behaviour.

Learning all the features of VHDL is not a simple task. Complex features will be introduced in a simple form and then more complex usage will be described. In 1986, VHDL was proposed as an IEEE standard. It went through anumber of revisions and changes until it was adopted as the IEEE 1076 standard in December 1987.

**Entity:** - All designs are expressed in terms of entities. An entity is the most basic building block in a design. The uppermost level of the design is the top-level entity. If the design is hierarchical, then the top-level description will have lower-level descriptions contained in it. These lower-level descriptions will be lower-level entities contained in the top-level entity description.

Architecture: - All entities that can be simulated have an architecture description. The architecture describes the behavior of the entity. A single entity can have multiple architectures. One architecture might be behavioural while another might be a structural description of the design.

## **Flow Diagram of EVM**



### Design of counter

Counter is designed for incrementing the number of votes of each candidate after a voter cast his/her vote to a particular candidate



yes 9 9

no

yes

no

no

yes

no

no

no

no

Design of comparator: The control unit compares the total votes of each candidate and displays the candidate no. having maximum vote in the seven segment display.



| End Time:<br>1000 ns |       | 50       | -     | 150      | 1     | 250     | 1      | 350                   |        | 450      |         | 550    |            | 650   |       | 750   |       | 850   |       | 950.0 |
|----------------------|-------|----------|-------|----------|-------|---------|--------|-----------------------|--------|----------|---------|--------|------------|-------|-------|-------|-------|-------|-------|-------|
| II ok                | 0 -   |          | 1     |          | F     | -       |        | - 1                   | -      |          | -       |        | -          | -     | -     | -     | -     | 1     | -     | -     |
| All dr               | 0     |          | -     |          | -     |         | -      | 1                     | -      |          |         |        | -          |       | -     |       | _     |       | -     | -     |
| 📕 ds                 | 0     |          |       |          | -     |         |        |                       |        |          | 1.0     |        | 1          |       | 1     | -     | 11    |       | -     | -     |
| E 🕅 count(3:0)       | 418   |          | 4h0   |          | X     | 100     | 476    | 5                     | X      | 1999     | 4%7     | 2.23   | Y          | 1     |       |       | 418   |       | -     |       |
| al max_vote_         | 1. (  |          | 119   |          |       | -       | 12-16  | 1220                  |        | 200      | 10h222  | (Cale  |            | 10000 |       |       |       | -     | -     | -     |
| a max_vole_          | LC    | 131011   |       | 1118     | 1     |         |        |                       |        |          | 10h222  |        | 1000       |       |       |       | 0.000 |       | -     | -     |
| a max_vote_          | 1. (  | Contrale | 3.00  |          | . 2.1 | 1       | 120    | Q.C.                  | 1702.0 |          | 10%222  | 202    | 10         |       |       |       | 10,25 | 02.43 | 112   | -     |
| at the all           | 7500  |          | 19.32 |          |       | 2587    |        |                       |        |          | 7100    | 1.     |            |       | 100   | 7.00  | 1117  | -     |       | -     |
| X d2060              | 7800  | C.C.C.S  |       |          |       | Section | 1-12   |                       |        |          | 7100    | -      | -          | 11.   |       |       | 1.44  | -     |       | -     |
| K 4316.01            | 7100  |          |       |          |       |         |        | 252                   | 1000   |          | 71100   |        | The second | 1000  | -     | -     |       |       |       | -     |
| QE 6415.01           | 7h00  |          | -     | 10.417.2 | 100   |         | 1.3077 | and the second second |        | 120-20   | 71100   |        | 101        | 100   | -     |       |       |       |       | -     |
| 副的                   | 7h00  | 10218    |       |          |       | 92. C   |        | -                     | 0.20   | 100      | 7h00    | 10010  |            |       | -     |       | 1     |       | 1     | -     |
| DK 06/50/            | 7h00  |          |       | 19.25    |       |         |        |                       |        |          | 7h00    | 1.070  |            |       | 12.76 |       |       |       |       | -     |
| K 0/201              | 370   | 12/2/2   | 360   |          | X     |         | 3h1    | 316                   | X      | SIR CO   | 3112    |        | X          |       | 3113  |       | 7     |       | Jhg   | -     |
| K con 19 01          | 1     |          |       | 1        |       |         |        |                       | 19.10  | 2019     | 10hZZZ  | 5.27   |            |       |       |       |       | -     |       | -     |
| ₩ cd2 9.0            | 1_    | 6.600    | 1     |          |       |         |        | Stilles               | 1      |          | 1011222 |        |            |       |       |       |       |       | 1242  | -     |
| a cq3[3:0]           | 1. (  |          | 212   |          | 1.4   |         | 125.2  | 174.74                |        |          | 10h222  | 112.3  | 100        | 1     | -     |       |       |       |       | -     |
| ₹ cd4[8.0]           | 1_    | ID: N    |       |          |       |         |        | 100                   |        | 1.189 10 | 10h722  | 22315  | in the     | REA   |       | 1.00  |       |       |       | 1     |
| al cd5[9.0]          | 1. (  | 1.1.1    |       | 1.2      |       |         | 1000   | 1.20                  | 1125   | Ner al   | 10%222  |        |            | 1.57  | -     | 1.0   |       | 10.00 |       | -     |
| (coelect)            | 1_ (  |          |       | Jul 23   |       | 1207    | 1493   |                       | 20/200 | 10.30    | 1011222 | 5123   | Chief      | 100   |       |       | 10120 | 1.1   | 10.11 | -     |
| ₩ co7j9:0]           | 1. (  | 15-218   |       | 100      | 199   | Car lin | -      | 100                   |        | 101707   | 10%222  | 10-12- |            | -     |       | 19-10 | 1     | -     | 11557 | -     |
| N costen             | 1_ (  | -        |       | 1706     | 13.0  | 1014    |        |                       | 240    |          | 10%222  |        |            |       |       | 0160  |       | 10 V. |       | -     |
| () ( calibia)        | 1.    |          |       | 12 miles |       |         |        | 7                     |        |          | 101222  | 1      | 1963       |       |       |       | -     |       |       |       |
| . ,                  | 1. 11 | Here and |       |          |       |         |        | 10-                   |        |          |         |        |            | 2011  | 1     |       | E     | 1     |       |       |

## **Result**

Simulation of behavioral model of Electronic Voting Machine with Multiple preferences and priority has been performed for 1000ns. Each clock(clk) pulse cycle has 50 ns rise and fall time. The simulation generated from the test bench waveform is shown in figure4.





翻





### Advantages of Electronic Voting:

6.4

6

6 4

6

6 3

6.9

69

69

6.9

1111811111

6

One of the advantages of electronic voting is that, in most cases, most ballots will be tabulated into the results. Paper-based voting machines can actually miss ballots because of human error in placing the paper-based ballot in the machine.

Another advantage is obviously the ease of tabulating the results. All counting and ordering is done by a machine, quickly and efficiently, and without human error.

DRE voting machines also have the advantage of never running out of paper ballots at a polling center, since the computer can count an unlimited number of ballots. They also can provide multiple languages to users who may not have English as a first language. This cannot be achieved through a paper-based system.

There are also advantages when dealing with people with disabilities, such as blindness. Electronic voting machines can provide headphones to read off instructions to the blind user. Also other tools can be added to these electronic voting machines to help with other disabilities such as people with limited mobility or the elderly.

### Disadvantages of Electronic Voting:

Also, besides tampering with the machines electronically, machines could be tampered physically, with foreign software being uploaded into the machine by someone trying to corrupt the election results.

Another disadvantage of electronic voting systems could be the overall costs. Software, machines, installations, proper software protection, and validation of results could be expensive; even more expensive than paper-based machines.

There could also be just a general error in the system, without any outsider tampering. Computer software and systems can have problems that may delay or even halt voting, or may cause errors in calculations. Future Enhancement of this project involves the security section of the EVM. The security section of the EVM is one of the main parts of the project where each voter will hold an indivisual voting card and his/her finger print will be the password. The computer will scan the identity of the voter and then the polling officer will allow the voter to cast his/her vote if found illegible.

## Conclusion

In earlier elections, we as a voter, casted vote to our favourite candidate by putting the stamp against his/her name and then folding the ballot paper as per a prescribed method before putting it in the Ballot box. This is a long, time-consuming process and very much prone to errors. Polling by Electronic Voting Machine (EVM) is a simple, safe and secure method that takes minimum of time. In this article, Programmable EVM that accepts more than one vote from individual voter, depending on type of elections, is presented. This voting machine has an advantage that it can be used in all kinds of elections like grampanchyat, Co-operative societies, assembly elections etc. It can also consider priority as weightage when voter has capability to provide multiple preferences.

## References

[1].Basic VLSI Design by Douglas A. Puncknell & Kamran Eshraghian
[2].http://www.xilinx.com/itp/xilinx10/books/docs/qst/qst.pdf
[3]. www.xilinx.com ISE Tutorial in Depth Chapter2, Chapter 3
[4]. www.xilinx.com ISE Tutorial in Depth Chapter4, Chapter 5, Chapter 6
[5].http://www.ece.wpi.edu/spartan3\_Tutorial.pdf, accessed date- Mar 5 2103
[6].http://www.belIndia.com/BELWebsite/images/EVM\_Features.pdf

### Appendix

i. program for Electronic Voting Machine

library IEEE;

use IEEE.STD\_LOGIC\_1164.ALL;

use IEEE.STD\_LOGIC\_ARITH.ALL;

use IEEE.STD\_LOGIC\_UNSIGNED.ALL;

---- Uncomment the following library declaration if instantiating

---- any Xilinx primitives in this code.

--library UNISIM;

--use UNISIM.VComponents.all;

entityevm is

Port ( clk : in STD\_LOGIC;

clr: in STD\_LOGIC;

cls: in STD\_LOGIC;

count : in STD\_LOGIC\_VECTOR(3 downto 0);

max1,max2,max3: inout STD\_LOGIC\_VECTOR(9 downto 0);

d1,d2,d3,d4,d5,d6: out STD\_LOGIC\_VECTOR(6 downto 0);

n:in STD\_LOGIC\_VECTOR(2 downto 0);

cd1,cd2,cd3,cd4,cd5,cd6,cd7,cd8,cd9,cd10,cd11,cd12,cd13,cd14,cd15: inout STD\_LOGIC\_VECTOR (9 downto 0));

endevm;

architecture Behavioral of evm is

process(clk,clr,count,n,cls, cd1,cd2,cd3,cd4,cd5,cd6,cd7,cd8,cd9,cd10,cd11,cd12,cd13,cd14,cd15,max1,max2,max3)

if(clk='1' and clk'event) then

if (clr='1') then

cd1<="0000000000";cd2<="0000000000";cd3<="0000000000"; cd4<="0000000000";cd5<="0000000000";cd6<="0000000000"; cd7<="0000000000";cd8<="0000000000";cd9<="0000000000"; cd10<="0000000000";cd11<="0000000000";cd12<="0000000000";

cd13<="0000000000";cd14<="0000000000";cd15<="0000000000";

max1<="00000000000";max2<="0000000000";max3<="0000000000";

d1<="0000000";d2<="0000000";d3<="0000000";

d4<="0000000";d5<="0000000";d6<="0000000";

end if:

if ( n="01") then

if (count="0001") then

cd1<=cd1+1;

elsif (count="0010") then

cd2<=cd2+1;

elsif (count="0011") then

cd3<=cd3+1;



elsif (count="0100") then

cd4<-cd4+1,

elsif (count="0101") then

cd5<=cd5+1;

end if;

elsif (n="10") then

if (count="0110") then

cd6<=cd6+1;

elsif (count="0111") then

cd7<=cd7+1:

elsif (count="1000") then

cd8<=cd8+1;

elsif (count="1001") then

cd9<=cd9+1;

elsif (count="1010") then

cd10<=cd10+1;

end if;

elsif (n="11") then

if (count="1011") then

cd11<=cd11+1;

elsif (count="1100") then

cd12<=cd12+1;

elsif (count="1101") then

cd13<=cd13+1;

elsif (count="1110") then

e

cd14<=cd14+1; elsif (couni-"1111") then cd15<=cd15+1;

end if;

end if;

#### end if,

if (n="01") then

max1<=cd1;

d1<="0000000";

d2<="0110000";

#### if (max1=cd2)then

d1<="1001111";

d2<="10011111";

elsif(max1<cd2)then

 $max1 \le cd2;$ 

d1<="0000000";

d2<="1101101";

elsif(max1=cd3)then

d1<="10011111";

d2<="1001111";

elsif(max1<cd3)then

max1<=cd3;

d1<="0000000";

d2<="1111001";



elsif (max1=cd4)then

d1<-"1001111",

d2<="1001111";

elsif(max1<cd4)then

max1<=cd4;

d1<="0000000";

d2<="0110011";

elsif (max1=cd5)then

d1<="1001111";

d2<="1001111";

elsif(max1<cd5)then

max1<=cd5;

d1<="0000000";

d2<="1011011";

end if;

end if;

1111111111

6

if (n="10") then

max2<=cd6;

d3<="0000000";

d4<="10111111";

if(max2=cd7)then

d3<="1001111";

d4<="1001111";

elsif(max2<cd7)then

max2<=cd7;

d3<="0000000";

d4<="1110000";

#### elsif(max2=cd8)then

d3<="1001111";

d4<="10011111";

elsif(max2<cd8)then

max2<=cd8;

d3<="0000000";

d4<="11111111";

elsif(max2=cd9)then

d3<="1001111";

d4<="1001111";

elsif(max2<cd9)then

max2<=cd9;

d3<="0000000";

d4<="1111011";

elsif(max2=cd10)then

d3<="10011111";

d4<="1001111";

elsif(max2<cd10)then

max2<=cd10;

d3<="0110000";

d4<="0000000";

end if;

69

09

5.9

5 3

5.9

5.9

6.9

5.9

5.9

6.9

59

5 4

64

5.9

5.9

6.9

6.9

6.9

6.9

5.5

6.9

c 9

6.9

5.9

6.9

6.9

6.3

6.9

111111111

c

if ( n="11") then

end if,

max3<=cd11;

d5<="0110000";

d6<="0110000";

if(max3=cd12)then

d5<="1001111";

d6<="1001111";

elsif(max3<cd12)then

max3<=cd12;

d5<="0110000";

d6<="1101101";

elsif(max3=cd13)then

d5<="1001111";

d6<="1001111";

elsif(max3<cd13)then

max3<=cd13;

d5<="0110000";

d6<="1111001";

elsif(max3=cd14)then

d5<="1001111";

d6<="1001111";

elsif(max3<cd14)then



max3<=cd14; d5<-"0110000",

d6<="0110011";

elsif(max3=cd15)then

d5<="1001111";

d6<="1001111";

elsif(max3<cd15)then

max3<=cd15;

d5<="0110000";

d6<="1011011";

end if;

end if;

end if;

end process;

end Behavioral;

#### ii. Xilinx 9.1i

Xilinx ISE(Integrated Software Environment) is a software tool produced by Xilinx for synthesis and analysis of HDL designs, enabling the developer to synthesize ("compile") their designs, perform timing analysis, examine RTL diagrams, simulate a design's reaction to different stimuli, and configure the target device with the programmer.

### Synthesis report:

Release 9.1i - xst J.30

Copyright (c) 1995-2007 Xilinx, Inc. All rights reserved. --> Parameter TMPDIR set to ./xst/projnav.tmp CPU: 0.00 / 0.10 s | Elapsed: 0.00 / 0.00 s --> Parameter xsthdpdir set to ./xst CPU: 0.00 / 0.10 s | Elapsed: 0.00 / 0.00 s --> Reading design: evm.prj TABLE OF CONTENTS 1) Synthesis Options Summary 2) HDL Compilation 3) Design Hierarchy Analysis 4) HDL Analysis 5) HDL Synthesis 5.1) HDL Synthesis Report 6) Advanced HDL Synthesis 6.1) Advanced HDL Synthesis Report 7) Low Level Synthesis 8) Partition Report 9) Final Report . Synthesis Options Summary ---- Source Parameters Input File Name : "evm.prj" Input Format : mixed Ignore Synthesis Constraint File : NO

| -   | 9    |
|-----|------|
| -4  | 9    |
| 4   | 9    |
| 4   | 9    |
| 4   |      |
| 4   |      |
| - 4 |      |
| 4   |      |
| - 4 |      |
| - 4 | 1    |
| 4   | )    |
| 4   |      |
|     | 1    |
|     | 1    |
| 9   |      |
| 9   |      |
| 9   | 1    |
| 29  | 1    |
| -   | 1    |
|     | >    |
|     | 1    |
| -9  |      |
|     | 0    |
|     | 0    |
| 7   |      |
| -   | L    |
| -   | K    |
| 7   | R    |
| 9   | H    |
| 9   | в    |
| T   | Ci   |
| T   | V    |
| T   | -    |
| 3   |      |
| T   | -0-4 |
| 60  |      |

| 1                      |                               |            |
|------------------------|-------------------------------|------------|
| Target Paramete        | rs                            |            |
| Output File Name       | : "evm"                       |            |
| Output Format          | : NGC                         |            |
| Target Device          | : CoolRunner XPLA3 CPLDs      |            |
| Source Options         |                               |            |
| Top Module Name        | : evm                         |            |
| Automatic FSM Extra    | ction :YES                    |            |
| FSM Encoding Algorit   | thm : Auto                    |            |
| Safe Implementation    | : No                          |            |
| CASE Implementation    | cz<br>n Style : Full-Parallel | T          |
| Mux Extraction         | : YES                         |            |
| Resource Sharing       | : YES                         |            |
| Target Options         |                               | 1          |
| Add IO Buffers         | : YES                         |            |
| MACRO Preserve         | YES                           |            |
| XOR Preserve           | : YES                         | 1          |
| Equivalent register Re | moval : YES                   |            |
| General Options        |                               |            |
| Optimization Goal      | : Speed                       | 1          |
| Optimization Effort    | :1                            |            |
| Library Search Order   | : evm.lso                     |            |
| Keep Hierarchy         | : YES                         |            |
| RTL Output             | : Yes                         | 1          |
| Hierarchy Separator    | :/                            | 1          |
| Bus Delimiter          | :0                            | l hi<br>Ta |
| Case Specifier         | : maintain                    |            |
| /erilog 2001           | : YES                         | 1          |
|                        |                               |            |
|                        |                               |            |
|                        | 78                            | 14         |

| -   |   |
|-----|---|
|     |   |
| -9  |   |
| 3   |   |
| -   |   |
| 3   |   |
|     |   |
| 3   |   |
| -   |   |
| 1   |   |
| -   |   |
| 3   |   |
| - 9 |   |
|     |   |
| - 9 |   |
| 3   |   |
| -   |   |
| 3   |   |
| -   |   |
| 3   | R |
| - 9 |   |
| 2   |   |
| 6.9 |   |
| t   |   |
| -   | L |

| Other Options                                                                                                 |     |
|---------------------------------------------------------------------------------------------------------------|-----|
| Clock Enable : YES                                                                                            |     |
| wysiwyg                                                                                                       |     |
|                                                                                                               | === |
| * HDL Compilation *                                                                                           |     |
| Compiling vhdl file "C:/Users/MK/Desktop/v.machine/evm.vhd" in Library work.                                  |     |
| Entity <evm> compiled.</evm>                                                                                  |     |
| Entity <evm> (Architecture <behavioral>) compiled.</behavioral></evm>                                         |     |
| * Design Hierarchy Analysis *                                                                                 |     |
| Analyzing hierarchy for entity <evm> in library <work> (architecture <behavioral>).</behavioral></work></evm> | :== |
|                                                                                                               | =   |
| * HDL Analysis *                                                                                              |     |
| Analyzing Entity <evm> in library <work> (Architecture <behavioral>).</behavioral></work></evm>               |     |
| Entity <evm> analyzed. Unit <evm> generated.</evm></evm>                                                      |     |
| * HDL Synthesis *                                                                                             |     |
| Performing bidirectional port resolution                                                                      | :== |
| Summary:                                                                                                      |     |
| inferred 3 Counter(s).                                                                                        |     |
| inferred 12 Adder/Subtractor(s).                                                                              |     |
| inferred 24 Comparator(s).                                                                                    |     |
| Unit <evm> synthesized.</evm>                                                                                 |     |
|                                                                                                               |     |
|                                                                                                               |     |

| HDL Synthesis Report        |       |  |
|-----------------------------|-------|--|
| Macro Statistics            |       |  |
| # Adders/Subtractors        | : 12  |  |
| 10-bit adder                | : 12  |  |
| # Counters                  | :3    |  |
| 10-bit up counter           | : 3   |  |
| # Registers                 | :21   |  |
| 10-bit register             | : 15  |  |
| 7-bit register              | : 6   |  |
| # Comparators               | : 24  |  |
| 10-bit comparator equal     | : 12  |  |
| 10-bit comparator less      | : 12  |  |
| Advanced HDL Synthesis Repo | rt    |  |
| Macro Statistics            |       |  |
| Adders/Subtractors          | : 12  |  |
| 10-bit adder                | : 12  |  |
| Counters                    | : 3   |  |
| l0-bit up counter           | : 3   |  |
| Registers                   | : 192 |  |
| lip-Flops                   | : 192 |  |
| Comparators                 | :12   |  |
| 0-bit comparator equal      | :12   |  |
|                             |       |  |
|                             |       |  |

**Final Results** 

63

63

63

| 1     | 9  |   |
|-------|----|---|
| . 6   | 9  |   |
|       |    |   |
| - 4   | 3  |   |
|       | 1  |   |
| - 4   | 9  |   |
| 1.2   |    |   |
|       | 9  |   |
|       | 9  |   |
|       | 1  |   |
| - 6   | 9  |   |
|       |    |   |
|       | 9  |   |
| 1.2   | 9  | 1 |
|       | 2  |   |
| 6     | 9  |   |
|       |    | 1 |
| - 6   | 9  | 1 |
|       | E  |   |
| 9     | 9  |   |
| 1     | 9  |   |
|       | 2  | 1 |
| - 6   | 9  | 1 |
|       | r  |   |
| 14    | 9  |   |
| 1.0   |    | 1 |
| 9     | 9  |   |
| 1     |    |   |
| -     | 9  |   |
| 1.00  | 9  |   |
|       | 1  | 1 |
| - 4   | 9  |   |
|       |    |   |
| 9     | 9  |   |
| 1     |    |   |
| 1     | 2  | 1 |
| 1     | 4  | 1 |
|       | r  |   |
| 1     | 9  | 1 |
|       |    | 1 |
| 3     | 9  |   |
| -     |    |   |
|       | 2  |   |
| 1     | 4  |   |
|       | ľ. | ļ |
| 9     | 9  |   |
| -     |    |   |
| 9     | 9  | 1 |
| G     |    | 1 |
| 1     | 3  | 1 |
| d     | 4  | ł |
|       |    |   |
| S     | 3  |   |
|       |    |   |
| Par a | 9  |   |
| C     | 4  |   |
| 9     | 9  | 1 |
| C     | -  |   |
|       | 1  |   |
| 6     | >  | l |
| 1     |    |   |
| 9     | 2  | Į |

| RT  | L Top Level Outpu  | t File Name : evm.ngr    |
|-----|--------------------|--------------------------|
| To  | p Levei Output Fii | e Name : evm             |
| OL  | itput Format       | : NGC                    |
| Op  | timization Goal    | : Speed                  |
| Ke  | ep Hierarchy       | : YES                    |
| Ta  | rget Technology    | : CoolRunner XPLA3 CPLDs |
| Ma  | acro Preserve      | : YES                    |
| xc  | R Preserve         | : YES                    |
| Clo | ock Enable         | : YES                    |
| wy  | siwyg              | : NO                     |
| De  | sign Statistics    |                          |
| #1  | Os                 | : 232                    |
| Ce  | II Usage :         |                          |
| # E | BELS               | : 4466                   |
| #   | AND2               | : 1397                   |
| #   | AND3               | : 253                    |
| #   | AND4               | : 53                     |
| #   | AND8               | : 12                     |
| #   | GND                | :1                       |
| #   | INV                | : 1619                   |
| #   | OR2                | : 732                    |
| #   | OR3                | : 90                     |
| #   | OR4                | : 52                     |
| #   | OR8                | :2                       |
| #   | XOR2               | : 255                    |
| # F | lipFlops/Latches   | : 220                    |
| #   | FDCE               | : 220                    |
|     |                    |                          |

|     | ۹  |
|-----|----|
|     | 7  |
|     | 4  |
|     | T  |
|     | 49 |
|     |    |
|     | 3  |
|     | 1  |
|     | 4  |
|     |    |
|     | 49 |
|     |    |
|     | 49 |
|     | 1. |
|     | -9 |
|     | -  |
|     | 2  |
|     | 4  |
|     | 1  |
| 1   | 9  |
|     | 1  |
|     |    |
|     |    |
| 1   | 9  |
|     | 1  |
| 1   | 9  |
|     |    |
| 5   | 9  |
|     |    |
| 5   | 9  |
|     |    |
|     | 9  |
|     |    |
|     | 9  |
| 1.0 | 9  |
|     |    |
| 1.0 | 9  |
|     |    |
| 0   | 9  |
|     |    |
| 9   | 9  |
|     |    |
| -   |    |
| 100 |    |
| -   | 9  |
| 0   | A  |
|     |    |
| 0   |    |
|     |    |
| S   | 9  |
|     |    |
| 6   | 9  |
| 0   |    |
| 6   | 9  |
| 0   | 9  |
| -   | 3  |
| 6   | 3  |
|     | -  |
| 5   | 9  |
|     |    |
| 5   | 9  |
| -   |    |
| 6   | 9  |
| 6   |    |
| -   |    |
| 6   |    |
|     |    |
| 0   | 5  |
|     |    |

| #1 | O Buffers       | : 232                       |
|----|-----------------|-----------------------------|
| #  | IBUF            | : 10                        |
| #  | OBUF            | : 222                       |
| CP | U : 7.25 / 7.36 | s   Elapsed : 8.00 / 8.00 s |

Total memory usage is 162036 kilobytes