

# Electronic Voting Machine (EVM)

- let us design a EVM - 10 candidate vote counter
- sync vote counter that tallies votes for candidates 0-9.
- on each rising clk edge, when not in reset, module examines the 4-bit vote ip and increments the corresponding 8-bit counter (Count 0...count 9)
- Reset clears all counters.
- so its a single-cycle per-vote counting and no debouncing & no-duplicating protocol
- Code structure
  - ports : clk, rst (active high), vote[3:0] input, outputs count 0..., count 9 (each 8 bit)
  - Sequential Block :-

always @ (posedge clk or posedge rst)

if (rst) begin

count0 <= 0;

count1 <= 0;

!

count9 <= 0;

end

else begin

case (vote)

'd0 : count0 <= count0 + 1;

'd1 : count1 <= count1 + 1;

!

} case x <= 0

'd9 : count9 <= count9 + 1;

endcase

increment  
when  
asserted:

## Behavioural note

- Each CLK with valid vote value increments candidate's counter once
- If vote is held steady across multiple CLKs, counter keeps incrementing each CLK
- Clock are 8-bit here - max 255 votes per candidate; will wrap on overflow

(for high population vote)

- More bit counter can be used
  - OR a trigger counter can also be added (such that whenever the counter reaches 255 then it will trigger a counter once)
- cascaded counter look



- No IP validation, debouncing authentication or vote acknowledgement
- All this are minimal counting logic