# Implementation of ADC in VLSI using AF-PWM

<sup>1</sup>Hara Prasad Tripathy, <sup>2</sup>Priyabrata Pattanaik <sup>3</sup>Susanta Kumar Kamilla

Abstract--- An integral part of sensor and potential applications is an analog to digital converter (ADCs). The realization of ADC by using "Pulse Width Modulation (PWM)" has been discussed in this work. A reference signal is required by this technique for comparing sampled input signal in analog format for generating "pulse width modulated signals". This ADC offers an advantage of extension to multiple sampling simultaneously. A cheap system based on microcontroller is built by this application. These designs are also characterised by low latency and fast response which makes them useful in biomedical applications in measuring single or multiple inputs.

Index Terms--- PWM, ADC, Duty cycle, Project Navigator, Modelsim ISE.

# I. INTRODUCTION

Any real time signal processing system has analog to digital conversion as the most inevitable parts where processing of data is done by computer software such as audio [1][2], and other applications related to sensors [3]. This paper presents an architecture of ADC based on "Pulse Width Modulation" or "Pulse Delay Modulation". The applications of PWM has been found in areas of "pulse coded modulation [4]", and the microcontrollers are used in controlling speed of a step motor [5]. This technique is powerful where variation of duty cycle of a square wave is done for achieving various functionality in above mentioned applications. Devices implemented in medical technology require combination of signal conditioning that includes filtering, amplifier, an ADC and a reference filtering for resolving sensor's signal. Not only small size but the ability of analog circuit to read output of a sensor should have low power for providing prolonged battery life and leads to larger number of readings in smaller time. A widespread popularity has been gained by small and low power consuming devices of medical industry because of small and faster available analogue ICs[6]. The pulse modulation is characterized in two different categories. One method is a "Pulse Width Modulation (PWM)", which finds applications widely such as "switch-mode power supplies (SMPS)". The cycle time of PWM is fixed but there is a variation in duty cycle based on the amplitude of an input signal. The value of pulse width is small for input amplitude of smaller values while it has a large value for larger amplitudes. The "pulse width modulator (PWM)" of analog or digital type is used for realizing such type of signal conversion. The density of pulse is varied based on amplitude of input signal for pulse modulation. This technique has every sample at modulator clock rate sample as a single pulse. The signals of large amplitude are converted and produces a result of large number

Department of Engineering, Siksha 'O' Anusandhan (Deemed to be University), Bhubaneswar, haraprasadtripathy@soa.ac.in, priyabratapattanaik@soa.ac.in, sushantakamilla@soa.ac.in

of samples that are at "high" state whereas signals having low amplitudes are met at a "low" state. There is no set time of cycle of this conversion of pulse but a pulse frequency is varied. The sampling of audio signal requires two categories of PWM: "naturally sampled PWM (NPWM) and uniformly sampled PWM (UPWM)". The comparison of low power signal (analog audio) is done with a carrier for creating NPWM in analog PWM modulator. Based on the type of modulation that is, single sided or double sided, a carrier signal is chosen either of sawtooth or triangle respectively. It is beneficial to use a PWM of three levels because it leads to the increase in full bridge configuration's efficiency but also complicating the control.

# **II. ANALOG TO DIGITAL CONVERTER**

A device for conversion of a "time varying continuous analog signal to a stream of zeros and ones for digitally processing it either by a digital signal processor or a digital computer. The inputs taken by ADCs [7] are input signal, reference signal and a clock signal. Figure 1 illustrates a block diagram.



Fig. 1 Block diagram of ADC (N-bit)

# **III. IMPLEMENTATION**

This paper presents the implementation of an 8-bit converter capable for conversion of an input analog signal into an 8-bits streams for generating after time Tref of a reference signal.



Fig. 2 Proposed block diagram of PWM ADC

The basic idea in the implementation of analog to digital converter is the conversion of an input signal into a PWM [8] signal. This is done by using a signal generator (triangular) and a comparator as illustrated in figure 2. The division

International Journal of Psychosocial Rehabilitation, Vol. 23, Issue 05, 2019 ISSN: 1475-7192

is done with 2n of a clock signal that comes from an oscillator O. Here, n is the bit number in a converter. A triangular signal (TWG) is generated by using a divided signal. This is done for comparison of input signal for obtaining a PWM signal[9]. The output of a comparator is low as long as the input signal lies under a triangular signal whereas it goes high when above. When clock signal lies on another input of AND (P) then PWM is a gate signal. When the output is a comparator is high then counter (N) will count after the signal passes gate. The final result of conversion is represented at end of PWM signal's high state. Two signals are generated by a control logic block (CL) based on PWM and clock signals: "Load signal for storing data in the memory latch (M) and Reset signal for clearing the counter for the next measurement". The frequency of a triangle wave gives a "sampling rate" [10]. A PWM signal's duty cycle is computed as given below

$$\frac{A+U_X}{2A} = \frac{\frac{T_X}{2}}{\frac{T_{TW}}{2}}$$
$$T_X = \left\{\frac{T_{TW}}{2\left(1+\frac{U_X}{A}\right)}\right\}$$
(1)

The amplitude of a triangle signal is represented by A, the value of unknown input is denoted by Ux and the period of triangular signal is represented by TTW and high state period is represented by TX. The above equation can be reduced to

$$T_X = 2^n \frac{T_0}{2} \frac{1 + U_X}{A}$$
(2)

 $N_X$  is the total count number that are stored after  $T_X$ :

$$N_X = T_X / T_O \tag{3}$$

Equation 2 and 3 gives:

$$N_X = 2^{n-1} \frac{1+U_X}{A}$$
(4)

The result as shown by equation 4 is displaced binary code. Thus, we get 0 when an input voltage is equal to -A and 0 2n-1 is obtained when input is 0 and 2n is obtained when input is A.

#### **IV. ALIASING FREE PWM**

An amplitude signal  $a[n] \in [0,1]$  is transformed into a different width stream of two level pulses y[n] having a fixed period of pulse Tp by a digital PWM. The amplitude of a[n] has information in it which is encoded in pulses width y[n]. Asymmetrical pulses around centre of pulse period Tp comprised in pulse train y[n] is a widely used method of asymmetric double edge PWM. The pulse edges and transitions between levels 0 and 1 are determined after finding joining point of "amplitude signal a[n] and a triangular reference wave r[n]". Certain constraints should be fulfilled by a[n] for PWM method. There should be a smaller value of bandwidth of a[n] than a reference frequency fp=1/Tp. The value of amplitudes a[n] should fall within the interval ranging between [0,1]. Appropriate steps of pre-processing should be applied to asymmetric double edge PWM. The problem could be solved by adding bias and proper scaling for a signal of real value. PWM is done on signal's magnitude and subsequently phase modulation is applied[11]. A signal combiner is required after performing PWM separately on imaginary and real parts of a signal. The PWM operator which is free from aliasing is

$$P(a[n], r[n]) \text{ is}$$

$$P(a[n], r[n]) = \begin{cases} 1, \text{ for } a[n] \ge r[n] \\ 0, \text{ for } a[n] < r[n] \end{cases}$$
(5)

The PWM signal y[n] free from aliasing is given as below:

$$y[n] = a[n] + \sum_{k=1}^{\infty} \frac{2(-1)^k}{\prod k} \sin\left(\prod ka[n]\right) \cos(2 \prod k \frac{T_s}{T_p}n\right)$$
(6)

T<sub>s</sub> denotes the time period of the system.



### V. MODELLING IN PROJECT NAVIGATOR

A user friendly software which eases the complicated protocols of communication is Modelsim which are otherwise difficult to carry out. An interactive tool for implementing and synthesizing a design in particular device and family. The output is seen in the format of a waveform by designing a model in Xilinx project simulator and Modelsim[12].



Fig. 4 Schematic Diagram

The amplitude of reference signal is equal to input signal whereas frequency of input signal is 1 MHz and reference signal is 50 MHz, both being sinusoidal signal. A PWM signal is generated by comparing both signals with each other and generating a stream of 0s and 1s with varying duration[13]. This PWM signal behaves as gate signal to incoming clock signal at a frequency of 126.9 MHz and in the form of a clock signal, final output is fed to a counter with maximum count of 32. After every time period, counter is reset in order to get a digital code for every sample. A positive edge detector is used for detecting rising edge of digitized signal for resetting the value of count after a reference clock's time period[14].



Fig. 5 RTL Schematic

Thus, it is seen that the shape of digital output waveform is similar to an input signal. The peaks of these triangular waveforms are joined for getting an input signal's waveform. It leads to the digitization of input waveform and

conversion into a digital code[6]. The digitization of corresponding PWM free from aliasing is shown in figure 6. Figure 5 illustrates a RTL diagram at a frequency of 126.9 MHz.

|                    |          | 0.000 ms                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name               | Value    | 0 ns  200 ns  400 ns  600 ns  600 ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ► 💐 analog_in[7:0] | 00101000 | 00103000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ► 📑 cigital(7:0]   | 00101000 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ► 📑 ±1(7.0)        | 66666666 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ► 💐 t2(7:0)        | 00000000 | (management and management an |
| ► 📑 triangle[7:0]  | 11111011 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ▶ 💐 sine[7:0]      | 00001111 | Concernant and a concernant                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ► 😽 cos(7.0)       | 01110111 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| l y                | 0        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 📲 dk               | 1        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 13 2               | 1        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ► 📷 r(7:0)         | 11001110 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 16 nt              | 0        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 📷 en               | 1        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

Fig. 6 Waveform of PWM free from aliasing (ADC)



Fig. 7 Testbench of AF-PWM

The value of inputs are "clk=1, rst=0, en=1, k=1, n(7:0)=11001110" are applied to a circuit. The value of digital output and analog input are same which shows the conversion of ADC without any quantization error.

| BLOCK     | AREA<br>(cells) | POWER<br>(mW) | DELAY<br>(ns) |
|-----------|-----------------|---------------|---------------|
| PWM based | 2.10            |               |               |
| ADC       | 2.49            | 0.153         | 7.880         |

Table I Area, Power and Delay in PWM

| Device Utilization Summary |            |  |  |  |  |  |  |
|----------------------------|------------|--|--|--|--|--|--|
| tilization                 | Note(s)    |  |  |  |  |  |  |
| 11%                        |            |  |  |  |  |  |  |
| 11%                        |            |  |  |  |  |  |  |
| 18%                        |            |  |  |  |  |  |  |
| 100%                       |            |  |  |  |  |  |  |
| 0%                         |            |  |  |  |  |  |  |
| 13%                        |            |  |  |  |  |  |  |
|                            |            |  |  |  |  |  |  |
|                            |            |  |  |  |  |  |  |
| 67%                        |            |  |  |  |  |  |  |
| 12%                        |            |  |  |  |  |  |  |
|                            |            |  |  |  |  |  |  |
|                            | 67%<br>12% |  |  |  |  |  |  |

Fig. 8 Reports of area after realization

| Sece .          |            | 0      | 000  | Port (0) | Und .     | Anite     | (Siction (S) | See    | Samay    | idi .  | Gyune     | Quecet  |
|-----------------|------------|--------|------|----------|-----------|-----------|--------------|--------|----------|--------|-----------|---------|
| 10              | (pater)    |        | is . | 0.000    | 1         | -         | -            | Source | (blage   | Gent/A | Cores (R) | Gret W  |
| Pat             | citi       | 11 127 | ¢    | 0.00     | 12        | 35        | 1            | kor    | 120      | 0110   | - 80      | 005     |
| hoisys          | 1500       | \$7    | ń.   | 000      | 6         | -         | -            | locax. | 150      | 007    | 0.00      | 107     |
| Tera Grate      | Catteria   | 1 D    |      | 0.15     | 8         | - 18      | 8            | - ImS  | 250      | 0302   | 140       | 022     |
| hoom            | ipcs'      | 1 Lo   | 17   | 020      |           |           |              |        |          |        |           |         |
| Speed Gode      | 4          | 加      | 1    | - 皇翔     |           |           |              |        |          | Teta . | Gyanc.    | Quescet |
|                 |            |        |      |          |           |           |              | Sept   | Form (A) | 183    | 125       | 023     |
| Externet        | _          |        |      | Ĩ        | Beche TJA | No: Arbet | Andin Terp   |        |          |        |           |         |
| Ardent Terry C  | <b>3</b> 1 |        | hend | hpite    | C10)      | 9         | R            |        |          |        |           |         |
| Line sutter TAT | 6          |        |      |          | - 23      | 733       | 37           |        |          |        |           |         |
| Later 18,07     | 14         |        |      |          |           |           |              |        |          |        |           |         |
| How (LPA)       | 0          |        |      |          |           |           |              |        |          |        |           |         |
|                 | tin in     |        |      |          |           |           |              |        |          |        |           |         |
| Dandetation     |            |        |      |          |           |           |              |        |          |        |           |         |
| PACOLOTON       | 112688     |        |      |          |           |           |              |        |          |        |           |         |
|                 |            |        |      |          |           |           |              |        |          |        |           |         |

Fig. 9 Reports of power after realization

Destination Clock: clk rising

| Celliin-Sout | fanout | Gate<br>Delay | Net<br>Delay | Logical Name (Net Name)                 |
|--------------|--------|---------------|--------------|-----------------------------------------|
| TOCE 1C->Q   | 2      | 0.120         | 1.216        | as 0 (an 0)                             |
| MIT2:10->0   | 1      | 0.551         | 0.000        | Madd sine lut<0> (Madd sine lat<0>)     |
| MIXCY:3->0   | 1      | 0.500         | 0.000        | Madd sins cyc0> (Madd sine cyc0>)       |
| MUXCY101->0  | 1      | 0.064         | 0.000        | Madd sine cycl> (Madd sine cycl>)       |
| MIXCY:CI->0  | 1      | 0.064         | 0.000        | Madd sins cy<2> (Madd sins cy<2>)       |
| NUKCY:CI-SO  | 1      | 0.064         | 0.000        | Madd_sine_cy<3> (Madd_sine_cy<3>)       |
| HUXCY:CI->0  | 1      | 0.064         | 0.000        | Madd sine cyc4> (Madd sine cyc4>)       |
| MUXCY:CI->0  | 1      | 0.064         | 0.000        | Madd sine cy<5> (Madd sine cyc5>)       |
| MINCY:CI->0  | 0      | 0.064         | 0.000        | Madd_sins_cy<6> (Madd_sine_cyc6>)       |
| XORCY:CI->Q  | 9      | 0.904         | 1.319        | Medd_mine_wor<7> (mine_7_00UF)          |
| IUTZ:II->0   | 1      | 0.951         | 0,000        | Macoum_cosr_lut(4> (Macoum_cosr_lut(4>) |
| NUXCY:5->0   | 1      | 0.100         | 0.000        | Maccum cost cyci> (Maccum cost cycis)   |
| MUNCY:CI->0  | 1      | 0.064         | 0,000        | Maccum cost_cy<5> (Maccum_cost_cy<5>)   |
| MUXCY:CI->0  | 0      | 0.064         | 0.000        | Maccum cost cycl> (Maccum cost cycls)   |
| XORCY:CI->0  | 1      | 0.904         | 0.000        | Macoum_cosr_wor(7> (Result<7>)          |
| TTO FAT      |        | 0.203         |              | cosr 7                                  |

Fig. 10 Reports of delay after realization

The comparison of performance result is done and denoted in a table form. The table includes delay, power consumption and area of ADC based on AF PWM. The context of "Analog to Digital conversion" is represented by output format by using a method of "Pulse Width Modulation (PWM)"[15].

## VI. CONCLUSION

This paper presents an architecture for analog to digital converter that is based on concepts of "Pulse Width Modulation (PWM)". This conversion contains an intermediary step which involves conversion to a PWM signal, which can be known as a quantity time conversion. The information about input signal is carried by each PWM states (high or low). There will be a displacement in binary or inverted binary code in output by selecting between low or high state. Sample and Hold Circuit is not required by this architecture and is faster in comparison with other architectures for ADC. Such ADC offers an advantage of extending multiple sampling simultaneously.

#### REFERENCES

- M. F. Ul Haque, M. T. Pasha, and T. Johansson, "Aliasing-Compensated Polar PWM Transmitter," IEEE Trans. Circuits Syst. II Express Briefs, 2017.
- [2] E. Fogleman, I. Galton, W. Huff, and H. Jensen, "3.3-V single-poly CMOS audio ADC delta-sigma modulator with 98-dB peak SINAD and 105-dB peak SFDR," IEEE J. Solid-State Circuits, 2000.
- [3] Z. Song and D. V. Sarwate, "The frequency spectrum of pulse width modulated signals," Signal Processing, 2003.
- [4] L. W. Couch, "Pulse code modulation," in Mobile Communications Handbook, Third Edition, 2017.
- [5] H. K. Khalil, "High-Gain Observers in Feedback Control: Application to Permanent Magnet Synchronous Motors," IEEE Control Syst., 2017.

- [6] O. Tanovic, R. Ma, and K. H. Teo, "Simultaneous power encoding and upconversion for all-digital transmitters using digital PWM," in Asia-Pacific Microwave Conference Proceedings, APMC, 2018.
- [7] M. J. M. Pelgrom, Analog-to-digital conversion. 2010.
- [8] A. Kwasinski, P. T. Krein, and P. L. Chapman, "Time domain comparison of pulse-width modulation schemes," IEEE Power Electron. Lett., 2003.
- [9] J. S. Walling and D. J. Allstot, "Pulse-width modulated CMOS power amplifiers," in IEEE Microwave Magazine, 2011.
- [10] J. (2016). U. P. D. for M.-C. M. M. N. I. C. L. https://doi. org/10. 1109/LCOMM. 2016. 257169. Han, Y., & Lee et al., "Subcarrier Allocation for OFDM With Index Modulation," IEEE Communications Letters. 2016.
- [11] A. Stanitzki and J. Christoph Scheytt, "Discrete-time RF phase and pulse width modulation for power efficient switch-mode transmitter," in IEEE - 2011 Semiconductor Conference Dresden: Technology, Design, Packaging, Simulation and Test, SCD 2011 - International Conference, Workshop and Table-Top Exhibition, 2011.
- [12] J. (2016). U. P. D. for M.-C. M. M. N. I. C. L. https://doi. org/10. 1109/LCOMM. 2016. 257169. Han, Y., & Lee et al., "Optimal Constellation Design for Indoor <inline-formula> <img src="/images/tex/30425.gif" alt="2\times 2"> </inline-formula> MIMO Visible Light Communications," IEEE Communications Letters. 2016.
- [13] L. Ding, R. Hezar, and S. Erez, "Modeling and predistortion for digital transmitters based on delta-sigma and pulse-width modulation," in IEEE MTT-S International Microwave Symposium Digest, 2016, vol. 2016-August.
- [14] K. Hausmair, S. Chi, P. Singerl, and C. Vogel, "Aliasing-free digital pulse-width modulation for burst-mode RF transmitters," IEEE Trans. Circuits Syst. I Regul. Pap., 2013.
- [15] J. Kim, J. Hwang, E. Song, and S. Y. Kim, "Analysis of radio frequency interference due to high speed digital signals," in 2017 IEEE Electrical Design of Advanced Packaging and Systems Symposium, EDAPS 2017, 2018, vol. 2018-January, pp. 1–3.