# PLD Based Hardware Realization Of Digital Clock

Umashankar More<sup>#1</sup>, Biswajeet Sahoo<sup>#2</sup>, Sherly Shroff<sup>#3</sup>, Vineet Mehta<sup>#4</sup>

<sup>#</sup> Department of Electronics and Communication Engineering, MIT School of Engineering <u><sup>1</sup>umashankar.more@gmail.com</u>

> <sup>2</sup>biswajeet.1999sahoo@gmail.com <sup>3</sup>shroffsherly@gmail.com <sup>4</sup>vineetmehta26@gmail.com

## Abstract

A Digital Clock is a type of Clock that displays the time digitally, unlike the analog clock, where the time is indicated by the positions of rotating hands. TIME is a fundamental concept that it is very difficult to define. To measure time is needed something that will repeat itself at regular intervals. The number of intervals counted gives a quantitative measure of the duration [1]. The earliest references for the measurement of the time were the moon and sun. When the sun and the moon were not visible, it was impossible to know the exact time. So, clocks were developed to measure out the hours between checks with the sun and the moon. The process of measuring time has progressively become more accurate, and the devices more localized ever since. In today's

modern era, the time is predominately measured by mechanical, and recently by electronic clocks. In this project the attempt is made to realize digital clock hardware from reference of crystal oscillator clock input using Field Programmable Gate Array (FPGA) based prototyping method [2].

*Keywords*— Field Programmable Gate Array (FPGA), Application Specific IC(ASIC), Binary Coded decimal (BCD), Hardware Description Language (HDL), Verilog Hardware Description Language (VHDL).

I. INTRODUCTION

The objective of the digital clock is to display time digitally using seven segment display on FPGA Board. The digital clock designed is in 24hour format. It displays the time in format of hours: minutes: seconds. Figure 1.1 shows System Block Diagram. These days numerous applications in electronics and other technology are using digital technique to perform operations that were once performed by analogue

methods. Digital systems are more versatile and superior to that of the analogue method as they do not get affected by spurious fluctuation in voltage, have greater precision and accuracy and can store billions of bits of information in relatively small space [3]. Many developments have been done in designing prototypingplatforms so as to provide single chip solution for variety of applications. FPGA platform is of same kind to provide better performance and flexibility while implementation.



Figure 1.1. System Block Diagram

The FPGA arrangement, specified using HDL is similar to one used for Application Specific IC(ASIC)[4]. This project intends use of FPGA for the hardware implementation of Digital Clock. The FPGA and on-board clock generate timing signals. The proposed digital design uses processes viz. counting, comparing, incrementing and displaying clock output[3]. System block diagram shows that actually it is precise division of the clock of crystal oscillator, generated on board. This clock is divided for generating 1 Hz clock frequency. Derived 1 Hz clock signal is now reference clock of the system. It is used as fundamental time unit of our Digital Clock.

Block diagram shows that 2 digits are used for displaying each time unit viz. second, minute and hour. This leads to display total 24 hours clock. Binary Coded decimal (BCD) counters are used for each digit so as to display corresponding digits in the range of 0-9. 'Overflow signal' of preceding counter is clock of sub-sequent counter. Hence entire system is ripple BCD Counters having different threshold values. Interconnections between these counters is shown in figure 1.1. Each BCD counter data is displayed on 7 segment display with the help of BCD to 7 Segment Converter[1].

There are 3 blocks in total, namely Hours, Minutes and Seconds. Output of 1 second clock generator logic is 1 sec duration signal and applied to lower significant digit of seconds. Clock will become reset after 24 hours.

# II. METHODOLOGY

The clock of 50 MHz from the clock source of FPGA Board is divided using clock divider logic to get a period of 1 second. This 1 second signal is applied to our system as1 second signal periods. When number of seconds becomes 59 (begins with '0'), 'minutes' starts its counting. Consequently when 59 minutes (begins with '0'), are over, 'Hour' starts progressing. It counts till 23:59:59. After this it would be 00:00:00 which is indication of 24 i.e. zero hour. Digit wise it has been explained below in Figure 2.1. Flowchart of digital clock



Figure 2.1. Flowchart of Digital Clock

Initialise the Least Significant Digit (LSD) and Most Significant Digit (MSD) of second, minute and hour to 00:00:00. Then clock pulse triggers an increase in the second's LSD. After every clock pulse an increment of unity is addition in the second's LSD. After getting the maximum value of 9, increment is in the second's MSD. Then again, we start the count at second's LSD Simultaneously LSD also keeps updating where it again increases till 9. After that there is again an increment in the MSD of second. After repeating the same loop in the MSD there is increment till the value is set to 5. Then after that the loop will forward with LSD of minute. It will follow the same loop for the LSD and MSD of the minute and hour. The increment will be done when the LSD of minute reaches to 9 and MSD reaches to 5. Similarly, for hours LSD of hour reaches to 3 and MSD reaches to 2. After all the time reaches to 23:59:59 the clock will reset and all the LSD and MSD of second, minute and hour will initialise to 00:00:00 again. This Process continues.

### **III. SYSTEM DESIGN**

### A. CALCULATIONS:

On board clock of 50MHz is working as master clock.

In 1 second of time 50 X  $10^6$  number of pulses of 50 MHz will be passed. Then, duration of 1 period of 50 MHz clock is 0.02µs. A pulse comprises of an 'ON' time of 0.5 Sec and 'OFF' time of 0.5 Sec. Therefore, number of pulses in each of them will be 2,49,99,999.

It implies that in a period of 1 second, we get two transitions and time between two successive transitions will be 0.5 Second and number of pulses passing through ON and OFF time is 2,49,99,999. Therefore, binary code of 2,49,99,999 is 1011111010111100000111111 for on time (rising edge) of 0.5 sec and off time (falling edge) of 0.5 sec.

## B. RTL Schematic



Figure: - 3.1. RTL Schematic of Digital Clock

There are 2 input pins which are connected to FPGA board. The 'clock' is pin for the 50 MHz master clock of FPGA Board and the 'reset' is the master reset which connected to system.

At output side, we have 8 output signals. Six signals of 7 bits each are sec\_LSD, sec\_MSD, min\_LSD, min\_MSD, hour\_LSD, hour\_MSD. Each seven bits signal is seven segment output connected to seven segment display. Seven segment display is connected in common anode configuration. The pins receive the 7-segment data from the BCD to seven segment block as shown in figure 1.1. Rest of the 2 pins are showing 'day' and 'one second clock' respectively.

The figure 3.1. shows the 8-input pins which are connected to FPGA along with one clock for clock signal and a reset pin. Then there are 6 output pin that is connected to 7 segment led display. There are six registers in total which includes 2 separate register for each block i.e. 2 for hours (Hin0, H\_in1), 2 for minutes (M\_in0, M\_in1) and 2 for seconds (S\_in0, S\_in1) as well. When S\_in0 is 9 and S\_in1 is 5, then S\_in1 and S\_in0 values are made to zero and M\_in0 value is incremented. If M\_in1 is 5 and M\_in0 is 9 then M\_in1 and M\_in0 values are made to zero and H\_in0 is incremented. If H\_in1 is 2 and H\_in0 is 4 then H\_in1 and H\_in0 is made to zero and thus the count continues.

In the figure 3.2. we get more detail explanation of the RTL schematic and a verification for the figure 1.1 i.e. the block diagram. By this figure we get to know that 1 sec clock is given to the BCD counter of 9 (sec LSD) then after these 9 counts the overflow signal is sent to the BCD counter of 5 (sec MSD) and the overflow signal becomes clock for the BCD counter 5. Same method is implemented for the minutes and hours. The BCD counter are of 5,9,2 and 3. After the overflow signal is generated by the MSD of hour (BCD counter of 3) the overflow signal is given to the day pin. Simultaneously the value stored in the BCD counters are shown in 7 segment led display by the output pins i.e. sec\_LSD, sec\_MSD, min\_LSD, min\_MSD, hour\_LSD, hour\_MSD.



Figure 3.2. Combination of all the blocks in Digital Clock

In Digital clock is consisting of 2 parts i.e. is the clock and bcd to hex converter. We see the RTL schematic in figure 3.1. and in figure 3.2. it shows detailing of RTL schematic and parts used. The 6 output pins receive the from bcd to hex block and the 1 sec clock output is received by the master clock which uses the 50MHz clock of FPGA and converts it to 1 second which is used.

# IV. RESULT

Device utilization summary:

Selected Device: 3s250ecp132-5 FPGA

| Number of Slices            | 57 out of 2448  | 2%  |
|-----------------------------|-----------------|-----|
| rumber of Shees.            | STOLEOF 2110    | 270 |
| Number of Slice Flip Flops: | 56 out of 4896  | 1%  |
| Number of 4 input LUTs:     | 110 out of 4896 | 2%  |
| Number of IOs:              | 46              |     |
| Number of bonded IOBs:      | 46 out of 92    | 50% |
| Number of GCLKs:            | 1 out of 24     | 4%  |

# Table 4.1. Device utilization summary

The waveform shows that there are various signals i.e. master clock, master reset, sec\_LSD, sec\_MSD, min\_LSD, min\_MSD, hour\_LSD, hour\_MSD, one\_sec clock, day and clock period. The sec\_LSD, sec\_MSD, min\_LSD, min\_MSD, hour\_LSD, hour\_MSD are receiving the 7-segment data.

Initially in the sec\_LSD the value stored was 1000000 i.e. 0 on 7 segment sec\_LSD and after a delay of  $0.02\mu s$ , the value stored increases to 1111001 i.e. 1.

In the second waveform we see that sec\_LSD the value stored was 0010000 i.e. 9 on 7 segment sec\_LSD and in next subsequent clock cycle it reset and there is advancement in the sec\_MSD. The value of sec\_MSD advances after 10 secs.

|                |          |                  | 1.00000000000 s |         |          |         |         |         |         |
|----------------|----------|------------------|-----------------|---------|----------|---------|---------|---------|---------|
| Name           | Value    | 0 s              | 1s              | 2s      | 3s       | 4s      | 5s      | 6s      | 7s      |
| Lig clk        | 0        |                  |                 |         |          |         |         |         |         |
| lig rst        | 0        |                  |                 |         |          |         |         |         |         |
| h_lsd[6:0]     | 1000000  |                  |                 |         | 1000000  |         |         |         |         |
| h_msd[6:0]     | 1000000  |                  |                 |         | 1000000  |         |         |         |         |
| m_lsd[6:0]     | 1000000  |                  |                 |         | 1000000  |         |         |         |         |
| ▶ 🌄 m_msd[6:0] | 1000000  | C                |                 |         | 1000000  |         |         |         |         |
| s_lsd[6:0]     | 1111001  | 1000000          | 1111001 )       | 0100100 | 0110000  | 0011001 | 0010010 | 0000010 | 1111000 |
| ▶ 📷 s_msd[6:0] | 1000000  | <u> </u>         |                 |         | 1000000  |         |         |         |         |
| 🖓 day          | 0        |                  |                 |         |          |         |         |         |         |
| le clk_period  | 20000 ps |                  |                 |         | 20000 ps |         |         |         |         |
|                |          |                  |                 |         |          |         |         |         |         |
|                |          |                  |                 |         |          |         |         |         |         |
|                |          | 1                |                 |         |          |         |         |         |         |
|                |          |                  |                 |         |          |         |         |         |         |
|                |          | 1                |                 |         |          |         |         |         |         |
|                |          | 1                |                 |         |          |         |         |         |         |
|                |          | 1                |                 |         |          |         |         |         |         |
|                |          |                  |                 |         |          |         |         |         |         |
|                |          |                  |                 |         |          |         |         |         |         |
|                |          |                  |                 |         |          |         |         |         |         |
|                |          |                  |                 |         |          |         |         |         |         |
|                |          |                  |                 |         |          |         |         |         |         |
|                |          |                  |                 |         |          |         |         |         |         |
|                |          |                  |                 |         |          |         |         |         |         |
|                |          | X1: 1.0000000000 | 00 s            |         |          |         |         |         |         |

Figure 4.4. Waveforms of Digital Clock presenting 1 second in S\_LSD

|                      |         |                       |                  |             |         |                |          | 12.624 | 080350000 s |
|----------------------|---------|-----------------------|------------------|-------------|---------|----------------|----------|--------|-------------|
| Name                 | Value   | 7s                    | 8 s              | 9s          | 10 s    | 11s            | 12 s     |        | 13 s        |
| La clk 1<br>La rst 0 |         |                       |                  |             |         |                |          |        |             |
| ▶ 📑 h_lsd[6:0] 10    | 000000  |                       |                  | 1000000     |         |                |          |        |             |
| h_msd[6:0] 10        | 000000  |                       |                  | 1000000     |         |                |          |        |             |
| ▶ m_lsd[6:0] 10      | 000000  |                       |                  | 1000000     |         |                |          |        |             |
| ▶ ■ m_msd[6:0] 10    | 000000  |                       |                  | 1000000     |         |                |          |        |             |
| ▶ ■ s_lsd[6:0] 01    | 100100  | 0 X 1111000           | <u>x 0000000</u> | X 0010000   | 1000000 | <u>1111001</u> | 0100100  |        |             |
| ▶ =  s_msa(6:0)      | 111001  | -                     | 100000           | + · · · · · | *       | 1111001        | -        | 1      |             |
| La dk period         | 0000 pc |                       |                  | 20000.05    |         |                | <u> </u> |        |             |
| La cic_period        | 0000 ps |                       |                  | 20000 ps    |         |                | <u> </u> | 1      |             |
|                      |         |                       |                  |             |         |                |          |        |             |
|                      |         |                       |                  |             |         |                |          |        |             |
|                      |         |                       |                  |             |         |                |          |        |             |
|                      |         |                       |                  |             |         |                |          |        |             |
|                      |         |                       |                  |             |         |                |          |        |             |
|                      |         |                       |                  |             |         |                |          |        |             |
|                      |         |                       |                  |             |         |                |          |        |             |
|                      |         |                       |                  |             |         |                |          |        |             |
|                      |         |                       |                  |             |         |                |          |        |             |
|                      |         |                       |                  |             |         |                |          |        |             |
|                      |         |                       |                  |             |         |                |          |        |             |
|                      |         |                       | 1                | 1           |         |                |          |        |             |
|                      | X1: 12. | X1: 12.624080350000 s |                  |             |         |                |          |        |             |



### V. CONCLUSIONS

In this paper, Digital Clock displays time in secs, minutes and 24 hours. Digital Clock has implemented and verified in HDL language. By division of the counter maximum clock frequency of system is improved. The Digital Clock is designed by creating HDL codes and synthesizing them using a simulation and synthesis tool. Quite precisely 1 second clock is obtained from master clock of 50 MHz using clock divider by setting the 25-bit counter i.e. '1011111010111100000111111' and 24 hours digital clock is presented in 00H:00M:00S display format.

### Acknowledgment

The success and final outcome of this project required a lot of guidance and assistance from many people and we are extremely privileged to have got this all along the completion of our project. All that we have done is only due to such supervision and assistance and we would not forget to thank them.

We are thankful and fortunate enough to get constant encouragement, support and guidance from all Teaching staffs of Electronics and Communication department which helped us in successfully completing our project work. Also, we would like to extend our sincere esteems to all staff in laboratory for their timely support.

## REFERENCES

[1] <u>"The History of the Digital Watch"</u>. <u>h2g2</u> (April 30, 2003) from the original on November 6, 2015. Retrieved 2015-11-07.

[2] A. Jaafar; N. Soin; S. Wan Muhammad Hatta, "An educational FPGA design process flow using Xilinx ISE 13.3 project navigator for students". IEEE 2017 Annual Conference.

[3] Essays, UK. (November 2018). Digital Clock Implementation with FPGA. Retrieved from https://www.ukdiss.com/examples/digital-clock-implementation-with-fpga.php?vref=1.

[4] https://www.xilinx.com/support/documentation/data\_sheets/ds160.pdf.