

# Direct Digital Synthesis Function Generator



**Asst. Prof. Dr. Sumek Wisayataksin**

**Department of Electronics Engineering  
Faculty of Engineering  
King Mongkut's Institute of Technology Ladkrabang**

# Overview

---

Digital Direct Synthesis Function Generator

# Specification and Requirement

1. Generate Sinusoidal Signal with frequency range from 10 Hz to 200 kHz.
2. Capable of generate Sinusoidal Signal with Peak-to-Peak voltage of 30 Volt.
3. Capable of generate Sinusoidal Signal with Offset from -5 Volt to 5 Volt.
4. Total harmonic distortion below 5% at all frequency.

# Block Diagram



# Digital Oscillator

---

An equation that can maintain signal without input

# Digital Oscillator



$$y[2] = \sin(B + B)$$

$$y[2] = \sin(B) \cos(B) + \sin(B) \cos(B)$$

$$y[2] = 2 \cos(B) y[1]$$

---


$$* \cos(A) \sin(B) = \frac{1}{2} [\sin(A + B) - \sin(A - B)]$$

# Digital Oscillator



$$y[3] = \sin(2B + B)$$

$$y[3] = \sin(2B) \cos(B) + \sin(B) \cos(2B)$$

$$y[3] = \cos(B) y[2] + \left( \frac{\sin(3B) - \sin(B)}{2} \right)$$

$$y[3] = \cos(B) y[2] + \left( \frac{y[3] - y[1]}{2} \right)$$

$$y[3] = 2\cos(B) y[2] - y[1]$$

---


$$*\cos(A)\sin(B) = \frac{1}{2}[\sin(A+B) - \sin(A-B)]$$

# Digital Oscillator



$$y[4] = \sin(3B + B)$$

$$y[4] = \sin(3B) \cos(B) + \sin(B) \cos(3B)$$

$$y[4] = \cos(B) y[3] + \left( \frac{\sin(4B) - \sin(2B)}{2} \right)$$

$$y[4] = \cos(B) y[3] + \left( \frac{y[4] - y[2]}{2} \right)$$

$$y[4] = 2\cos(B) y[3] - y[2]$$

$$y[n] = 2\cos(B) y[n - 1] - y[n - 2]$$

---


$$*\cos(A)\sin(B) = \frac{1}{2}[\sin(A+B) - \sin(A-B)]$$

# Block Diagram for D.E.

$$y[n] = 2\cos(B)y[n - 1] - y[n - 2]$$

$$y[0] = 0$$

$$y[1] = \sin(B)$$



# Example of D.E. using MATLAB (1)

- Generate sinusoidal signal with frequency of 853 kHz

```
f = 853e3;  
fs = 24e6;  
Ts = 1/fs;  
B = 2*pi*f*Ts  
  
alpha = 2*cos(B);  
beta = -1  
y(1) = 0;  
y(2) = sin(B);  
  
for i=3:500  
    y(i) = alpha*y(i-1) + beta*y(i-2);  
end
```



# Example of D.E. using MATLAB (2)

- Generate sinusoidal signal with frequency of 568 kHz

```
f = 568e3;  
fs = 24e6;  
Ts = 1/fs;  
B = 2*pi*f*Ts  
  
alpha = 2*cos(B);  
beta = -1  
y(1) = 0;  
y(2) = sin(B);  
  
for i=3:500  
    y(i) = alpha*y(i-1) + beta*y(i-2);  
end
```





# Phase-Locked Loop

---

A thing for generate various clock frequency.

# DDS Progress Update

Gowin FPGA



# Why Phase-Locked Loop?

- Phase-Locked Loop can be used to generate a clock at any frequency (How?).
- Because onboard Crystal Oscillator generate 27 MHz but we need 48 MHz clock for generate two 24 MHz clock (Why 48MHz?). So, we must use PLL to generate the desired clock.



# PLL Block



Note that “**reset**” is “Active High! Please make sure that you have already transform it before drive the reset signal to PLL module.

# PLL IP-Core Generation (2)



# PLL IP-Core Generation (2)

4. File Name
5. Verilog Module Name
6. Enable PLL External Reset
7. Set Output Frequency (48 MHz)
8. Set Input Frequency (27 MHz)
9. Press “Calculate” button
10. Enable “LOCK” signal



# Integrate PLL to RTL



```
pll_module pll(  
    .clkin  
    .reset  
    .clkout  
    .lock  
);
```

(External Clock),  
(~PLL Reset),  
(48 MHz Clock),  
(PLL Lock)

# Clock Divider

---

Just a Flip-flop block!

# PLL Summary

- Generate 48 MHz clock from 27 MHz clock from External Crystal Oscillation



# DDS Progress Update

Gowin FPGA



# Clock Divider Block Diagram

- The basic structure of Clock Divider is a Flip-Flop which can be accomplished the 90 degrees phase shift by using different clock polarity.



# DDS Clock System



# Clock Divider Summary

- Generate two clock which have a half frequency of PLL Clock.
- Two clock signal have the phase different of 90 degrees. (The lag one is for DAC Clock)



# Button Interface

---

Who cares about the button bounce?

# DDS Progress Update

Gowin FPGA



# Why we need button interface? (1)

- When we push the button, one thing that always annoy us is the bounce! (What cause?)



# Why we need button interface? (2)

- One way to solve this problem is just ignore it and “**Generate our own button push signal that last for a clock cycle**”!



# Bounce Ignorance

In order to ignore the bounce, here are simple solution.

- 1) Detect only falling edge of the button.
- 2) Ignore any falling edge for a period of time.



# Metastability



# Button Interface Summary

- Generate a pulse whenever the button is pushed (falling edge only) and ignore any falling edge signal for a short period of time.



# Button Interface Expected Behavior



Generate a pulse when detect the falling edge of ExtBTN



Reject button bounce

# Sampling Control

---

A block for control the time in difference equation!

# DDS Progress Update

Gowin FPGA



# Why we need Sampling Control (2)

- As we said before, we use sampling frequency ( $f_s$ ) of 24 MHz for own D.E. to generate any frequency of sinusoidal signal.
- For example, if we need to generate sinusoidal signal with frequency of 500kHz. We must use a parameter

$$\alpha = 2\cos\left(\frac{2\pi f}{f_s}\right) = 2\cos\left(\frac{2\pi(500k)}{24M}\right) = 0.9914$$

$$y[1] = \sin\left(\frac{2\pi f}{f_s}\right) = 2\sin\left(\frac{2\pi(500k)}{24M}\right) = 0.2611$$

# Why we need Sampling Control (2)

- What if we need to generate 50kHz signal without change the value of parameter as show earlier?

$$\alpha = 2\cos\left(\frac{2\pi f}{f_s}\right)$$
$$y[1] = \sin\left(\frac{2\pi f}{f_s}\right)$$

- From the equation above, if we decrease the value of desired frequency by factor of 10. We should decrease the value of sampling frequency by the same factor to preserve the value of parameter.

# Why we need Sampling Control (3)

- So that we need a something for control how fast our D.E. will update the value to create a wide frequency range of sinusoidal signal without change the parameter  $\alpha$  and  $y[1]$ . (Why we not change the parameter instead?)



# Sampling Control Mode (1)

- We can assume that we have only the parameter  $\alpha$  and  $y[1]$  in range of 100 kHz to 100 MHz only. So, we will control the sampling frequency instead for generate low frequency sinusoidal signal.
- Assume that we have 5 different mode of operation which is
  - Mode 0 : Frequency Range of 100 kHz to 1 MHz (Generate Enable signal all the time)
  - Mode 1 : Frequency Range of 10 kHz to 100 kHz (Generate Enable signal every 10 clock cycles)
  - Mode 2 : Frequency Range of 1 kHz to 10 kHz (Generate Enable signal every 100 clock cycles)
  - Mode 3 : Frequency Range of 100 Hz to 1 kHz (Generate Enable signal every 1000 clock cycles)
  - Mode 4 : Frequency Range of 10 Hz to 100 Hz (Generate Enable signal every 10000 clock cycles)

# Sampling Control Mode (2)

- In order to change the mode, we use the button signal from “Button Interface” module to change.
  
- Requirement for Sampling Control Mode Change
  - Initial mode for our DDS after reset is mode 0 (100 kHz to 1MHz)
  - Whenever there is a pulse from button interface, the mode will be increase by 1.
  - When current mode is mode 4 (10 Hz to 100 Hz) and there is a pulse from button interface. The next mode will be back to mode 0.

# Sampling Control Ready Indication

- Before start the Oscillator Module (D.E.), for generate the sinusoidal signal, we need to take sometimes to wait our DDS system stable.
- So that we will create a “Ready” signal for tell the Oscillator Module to start the calculation.
- Requirement for Sampling Control Ready Indication
  - The reset value of Ready signal is 0 (Not ready)
  - Whenever there are 80 clock cycles passed after reset, Ready signal is 1 (Ready)

# Sampling Control Expected Behavior



A pulse of Ready signal after 80 clocks from RESET state



After detect pulse of button, Mode change from 0 to 1 and Enable signal change from constant to a pulse width period around 10 clock

# Sampling Control Summary

- Can change the mode whenever the button is pushed
- Can generate “Enable” signal by the requirement as show earlier.
- Can generate “Ready” signal whenever there are 80 clock cycles passed after reset.



# Fixed-point Number

---

Method for store decimal in binary number system.

# Fixed-point Number (1)

- Let's recall Binary Number System

| Bits      | 3 | 2 | 1 | 0 |
|-----------|---|---|---|---|
| Bit Value | 8 | 4 | 2 | 1 |

- If we want to convert  $5_{10}$  into 4-bit binary number system. The result will be like this

| Bits | Bit Value | $5_{10}$ Value |
|------|-----------|----------------|
| 3    | 8         | 0              |
| 2    | 4         | 1              |
| 1    | 2         | 0              |
| 0    | 1         | 1              |

# Fixed-point Number (2)

- However, what if we want to store the value of 0.375?
  - No, we cannot do that!

| Bits | Bit Value | $0.375_{10}$ Value |
|------|-----------|--------------------|
| 3    | 8         | 0                  |
| 2    | 4         | 0                  |
| 1    | 2         | 0                  |
| 0    | 1         | 0                  |

- There is no way to store decimal in standard binary number system.
- The solution for that problem is “Scale Up by  $2^n$ ” the value so that our binary number system can store.

# Fixed-point Number (3)

- If we choose to scale up by  $2^3$ , so that 0.375 will be 3. and its binary value will be  $0011_2$  instead of  $0000_2$  like the previous slide.
- Notice that not only decimal part is scaled up but also the integer part!! So the binary table value will be changed.

| Bits | Bit Value | $0.375_{10}$ Value |
|------|-----------|--------------------|
| 3    | 8         | 0                  |
| 2    | 4         | 0                  |
| 1    | 2         | 0                  |
| 0    | 1         | 0                  |

Before Value Scaled

| Bits | Bit Value | $0.375_{10} * 2^3$ Value |
|------|-----------|--------------------------|
| 3    | 8         | 0                        |
| 2    | 4         | 0                        |
| 1    | 2         | 1                        |
| 0    | 1         | 1                        |

After Value Scaled

# Fixed-point Number (4)

- The other way to think is the bit value is scale down!
- We will use same scaling factor from previous slide, that is,  $2^3$

| Bits | Bit Value | $0.375_{10}$ Value |
|------|-----------|--------------------|
| 3    | 8         | 0                  |
| 2    | 4         | 0                  |
| 1    | 2         | 0                  |
| 0    | 1         | 0                  |

Before Bit Value Scaled

| Bits | Bit Value / $2^3$ | $0.375_{10}$ Value |
|------|-------------------|--------------------|
| 3    | $8/2^3 = 1$       | 0                  |
| 2    | $4/2^3 = 0.5$     | 0                  |
| 1    | $2/2^3 = 0.25$    | 1                  |
| 0    | $1/2^3 = 0.125$   | 1                  |

After Bit Value Scaled

# Fixed-point Number Summary

- An operation that we “Scale Up the value” or “Scale Down the bit value” is the method for allow decimal number to store in binary number system which called Fixed-point Number System
- From previous slide, we scaled up the value by  $2^3$  so that, our “virtual” decimal point in binary system is at the left side of bit 3.



# Number Multiplication and its digits

- All of number multiplication, the maximum digits after multiplication will be double!
- Let say we have 2 digits decimal number system. For example, 99, 18, 27, 55. If we multiply 2 digits decimal number together. The result will have maximum of 4 digits decimal number!
- For example,  $99 * 99 = 9,801$   
2 dig    2 dig    4 dig

# Number Multiplication and its digits

- This also true with decimal point number.
- Let's say                    $99.99 * 99.99 = 9,998.0001$
- To summarize, any number system (Binary, Octal, Decimal, Hexadecimal) will have the double number of digits or bits of its original value after multiply.



# Oscillator Module

---

A module for calculate the Difference Equation.

# Selected Fixed-Point Value (1)

- In this project, we will use 32-bit binary number and use  $2^{29}$  as scaling factor.
- So that if we want to represent any base 10 number, we should multiply by  $2^{29}$
- The result Multiplication will be 64-bit but we will truncate to 32-bit.  
(Why)



# DDS Progress Update

Gowin FPGA



# Oscillator : Fix point decimal



How to convert fraction to integer 32 bit

Ex.  $0.42458 \times 2^{29} = 227,944,651 = 0x0D9628CB$   
 $-0.74214 \times 2^{29} = -398,433,378 = 0xE840639E$

# Selected Fixed-Point Value (2)

- When we use multiplication operator in this project. The result must be truncated to 32-bit with this form.



# Oscillator : Fraction Multiplier

```
reg [31:0] a;
```

```
reg [31:0] b;
```

```
reg [63:0] c;
```

```
reg [31:0] out1_a;
```



```
always@(*) begin // combi
    c      <= $signed(a)*$signed(b);
    out1_a <= c[60:29];
end
```

# Oscillator Module Summary

- Can change generate  $y[n - 1]$  and  $y[n - 2]$
- Can set the value of  $y[n - 1]$  to Initial Condition from Input port whenever the “Ready” signal from Oscillator Module is 0
- Can calculate the value of  $y[n]$ ,  $y[n - 1]$ ,  $y[n - 2]$  whenever the “Enable” signal from Oscillator Module is 1



# Oscillator : How to Generate Delay



$$\text{init1} = 2^{29} \sin\left(\frac{2\pi f_s}{f_c}\right) = 2^{29} \sin\left(\frac{2\pi 0.73M}{24M}\right) * 0.95 = 96,878,045$$

$$\text{init2} = 2^{29} 2 \cos\left(\frac{2\pi f_s}{f_c}\right) = 2^{30} \cos\left(\frac{2\pi 0.73M}{24M}\right) = 1,054,193,702$$

|                                  |               |
|----------------------------------|---------------|
| out <= out1_a-out2;              | // combi      |
| out1 <= out;                     | // sequential |
| out2 <= out1;                    | // sequential |
| c <= \$signed(a)*\$signed(out1); | // combi      |
| out1_a <= c[60:29];              | // combi      |

# Oscillator Module Expected Behavior

- Please note that the signal into this port  $\alpha, y[1]$  will be set manually when we declare this module.

```
  Osc_module osc_mod (
    .CLK          (FgCLK),
    .RESETn      (FgRESETn),
    .Enable       (DDSEnable),
    .Ready        (DDSReady),
    .init1        (32'd96878045),
    .init2        (32'd1054193702),
    .out1         (out1),
    .out2         (out2)
);
```



# Oscillator Module Expected Behavior



If there is no error, the output of DDSOut1 will be sinusoidal.



If the mode change from 0 to 1, the sinusoidal will be dilate by the factor of 10

# Interpolator Module

---

Smooth out the discontinuity!

# DDS Progress Update

Gowin FPGA



# Why we need interpolation? (1)

- In this project, we decrease the sampling period in order to generate lower sinusoidal frequency. So, that the output of low frequency signal will look like step function.
- The term interpolation is used to describe something that fill the gap between two data.
- So, we need to fill the gap between each sampling period by the straight line so that our output sinusoidal wave not look like step function too much.

# Interpolation Calculation (1)

- In order to calculate the line for fill the gap. First, we should create find the slope of the line we want to create.



# Interpolation Calculation (2)

- So that we can find that  $\Delta y = \frac{y[n-1] - y[n-2]}{n}$



# Interpolation



$$diff = \frac{out1 - out2}{n}$$

$$out[i] = out[i - 1] + diff$$

$$n=1 ; 1/n = 1$$

$$n=10 ; 1/n = 0.1*2^{29} = 53687091$$

$$n=100 ; 1/n = 0.01*2^{29} = 5368709$$

$$n=1000 ; = 536871$$

$$n=10000 ; = 53687$$

# Interpolator Module Summary

- Can generate output with interpolated value.
- Can passthrough the input value whenever the interpolation is not required (Mode 0)
- Can update the value whenever the output from “Digital Oscillator” is change (Enable = 1)



# Interpolation



## Cal diff when count == 1

# Interpolator Module Expected Behavior



If there are no any error, the result from Interpolator will look like the same as Output from Digital Oscillator except for the smoothness

# Rotary Encoder

---

Knob for change frequency.

# Progress Update

Gowin FPGA



# Why we need rotary encoder?

- In order to change the frequency, we choose rotary encoder as a frequency selector.
- The operation of frequency selection can be described by the “counter” which is used for select the  $\alpha$ ,  $\beta$ ,  $y[0]$  for that frequency and use “Rotary Encoder” to change the “counter” value up and down.



# How Rotary Encoder work? (1)

- The rotary consist of two inputs (Rot\_A, Rot\_B) and the waveform will look like this.



- When the knob was going to rotate in Clockwise Direction, output A will be “LOW” first. After the knob was rotated successfully, the B will be “LOW” and vice versa.

# How Rotary Encoder work? (2)

- After detect the rotation direction of rotary encoder, update the “Address” variable which have the range from 0 to 1800 by 1.
- When detect the CW direction, increase the “Address” variable by the factor below and decrease in another direction.
- Furthermore, this module will consist of 3 mode which are
  - Mode 0 : Update the “Address” value by factor of 1
  - Mode 1 : Update the “Address” value by factor of 10
  - Mode 2 : Update the “Address” value by factor of 100
- The mode will change by press the Rotary Button (Rot\_C)

# Rotary Encoder Module Summary

- Can change the value of “Address” by factor respect to the current rotary mode.
- Increase or decrease “Address” value whenever detection the CW and CCW direction respectively.
- Can change the mode using the button.
- Can generate “FreqChng” signal whenever there is no rotation for 100 ms.



# Rotary Encoder Expected Behavior



Rot\_B down first means Rotary rotated in CW Direction. So, Address will increase by 1 (Mode 0)

```
`define SIM

`ifdef SIM
    parameter RD_FREQ = 2400;
`else
    parameter RD_FREQ = 2400000; // 100 ms
```

# Lookup Table

---

A table for Alpha and Beta constant

# LUT Generator

$$\sin\left(\frac{2\pi f_{osc}}{f_s}\right)2^{29}$$

$f_{osc} = 100 ; 14,053,228; 0x00D66F6C$

000.0 0000 1101 0110 0110 1111 011 0 | 1100

$f_{osc} = 1000 ; 138,948,413; 0x08482F3D$

000.0 1000 0100 1000 0010 1111 001 1 | 1101

$$\cos\left(\frac{2\pi f_{osc}}{f_s}\right)2^{29}$$

$f_{osc} = 100 ; 536,686,951; 0x1FFD3167$

000.1 111 1 1111 1101 0011 0001 0110 011 | 1

$f_{osc} = 1000 ; 518,578,552; 0x1EE8E178$

000.1 111 0 1110 1000 1110 0001 0111 100 | 0

# LUT Generator

- Run the code on the left to generate the Coefficient file.
- The file we have generated will be use as “Table” for select the constant according to “Address” from Rotary Encoder Module.

```
import math

f = open("coefficient.mi", "w")

f.write("#File_format=Hex\n")
f.write("#Address_depth=1024\n")
f.write("#Data_width=48\n") 2048

n = 100
for i in range(0, 1024):
    alpha = math.sin(2*math.pi*n/24000) * 0.95
    alpha = round(alpha * 1073741824, 0)
    alpha = int(alpha) >> 5 - 4 536870912

    y1 = math.cos(2*math.pi*n/24000)
    y1 = round(y1 * 1073741824, 0) 536870912
    y1 = (int(y0) & 0x03FFFFFF) >> 2 - 1
                                0x01FFFFFF

    if (n <= 1000):
        f.write("%06x%06x \n" % (alpha, y1))
        n = n + 1 - 0.5
    else :
        f.write("%06x%06x \n" % (0, 0))
        n = n + 1 - 0.5
```

# ROM IP-Core Generation (1)



# ROM IP-Core Generation (2)

4. File Name
5. Verilog Module Name
6. Set Address Depth to **2048**
7. Set Data Width to 48
8. Set Reset Mode to Asynchronous
9. Select the “Coefficient” file that we generated before.



# Lookup Table and ROM Module



```
romcoef_module romcoefmod(  
    .clk    (clk),  
    .reset  (~resetn),  
    .ce     (1'd1),  
    .ad     (Rotary Address),  
    .dout   (Coefficient),  
);
```

# Generate sin1x, cos2x

$$\sin\left(\frac{2\pi f_{osc}}{f_s}\right)2^{29}$$

$$\cos\left(\frac{2\pi f_{osc}}{f_s}\right)2^{29}$$

$f_{osc} = 100 ; 14,053,228; 0x00D66F6C$

**000.0 0000 1101 0110 0110 1111 011 0 | 1100**

$f_{osc} = 1000 ; 138,948,413; 0x08482F3D$

**000.0 1000 0100 1000 0010 1111 001 1 | 1101**

$f_{osc} = 100 ; 536,686,951; 0x1FFD3167$

**000.1 11 11 1111 1101 0011 0001 0110 01 11**

$f_{osc} = 1000 ; 518,578,552; 0x1EE8E178$

**000.1 11 10 1110 1000 1110 0001 0111 10 00**

wire [31:0] sin1x;

wire [31:0] cos2x;

assign sin1x = { 4'b0000 , coef[47:24] , 4'b0000 };

assign cos2x = { 6'b001111, coef[23:0] , 2'b00 };

# Oscillator Module Revised

---

Updated Version of Oscillator Module

# Updated Version for Oscillator Module



- Add “FreqChng” input port for Oscillator Module
- Whenever the “FreqChng” is 1, the Oscillator Module will set the parameter for D.E. by this value

$$y[0] = 0$$

$$y[1] = \text{init1 from LUT}$$

$$\alpha = \text{init2 from LUT}$$

# Updated Version for Oscillator Module

```
osc_module osc_mod (
    .CLK          (FgCLK),
    .RESETn      (FgRESETn),
    .Enable       (DDSEnable),
    .Ready        (DDSReady),
    .init1        (32'd96878045),
    .init2        (32'd1054193702),
    .freqchgn    (freqchgn),
    .out1         (out1),
    .out2         (out2)
);
```

sin1x  
cos2x

# zero crossing check

case 2.1



case 2.2



mode 0-3

00000000 00xxxxxx xxxxxxxx xxxxXXXXXX  
1111111111 11xxxxxx xxxxxxxx xxxxXXXXXX

mode 4

00000000 0xxxxXXX xxxXXXXX xxxxXXXXXX  
1111111111 1xxxxXXX xxxXXXXX xxxxXXXXXX

# zero crossing check

## Condition for update wait (Sequential)

```
if      (freqchng==1)      update_wait =1  
else if (do_update==1)    update_wait = 0
```

## Condition for zero cross (combination)

```
if (mode!=4) and (out1[31:22]==10'b0000000000) | (out1[31:22]==10'b1111111111) OR  
          (out1[31:23]== 9'b000000000) | (out1[31:23]== 9'b111111111)  
zcross = 1 else zcross = 0
```

## Condition for direction (combination)

```
if (out2[31]==1) dir = 1 else dir = 0
```

## Condition for doing update (Combination)

---

```
If (zcross & update_wait) do_update = 1 else do_update = 0
```

# Update Case 2.1 & 2.2

case 2.1



$\text{out2}[31] = 0$

case 2.2



$\text{out1}$

$\text{out2}[31] = 0$

```
input [31:0] out1;  
input [31:0] out2;  
sine  = ( $\text{out2}[31]==1'b1$ ) ? sin1x : ~sin1x+1;  
cos2x is the same as before.
```

# Frequency Update



# Offset Binary <-> 2's complement

| $A_{IN^+} - A_{IN^-}$<br>(2V Range) | D15-D0<br>(OFFSET BINARY) | D15-D0<br>(2's COMPLEMENT) |
|-------------------------------------|---------------------------|----------------------------|
| >1.000000V                          | 1111 1111 1111 11XX       | 0111 1111 1111 11XX        |
| +0.999970V                          | 1111 1111 1111 1111       | 0111 1111 1111 1111        |
| +0.999939V                          | 1111 1111 1111 1110       | 0111 1111 1111 1110        |
| +0.999909V                          | 1111 1111 1111 1101       | 0111 1111 1111 1101        |
| +0.999978V                          | 1111 1111 1111 1100       | 0111 1111 1111 1100        |
| +0.000030V                          | 1000 0000 0000 0001       | 0000 0000 0000 0001        |
| +0.000000V                          | 1000 0000 0000 0000       | 0000 0000 0000 0000        |
| +0.000030V                          | 0111 1111 1111 1111       | 1111 1111 1111 1111        |
| +0.000061V                          | 0111 1111 1111 1110       | 1111 1111 1111 1110        |
| -0.999878V                          | 0000 0000 0000 0011       | 1000 0000 0000 0011        |
| -0.999909V                          | 0000 0000 0000 0010       | 1000 0000 0000 0010        |
| -0.999939V                          | 0000 0000 0000 0001       | 1000 0000 0000 0001        |
| -1.000000V                          | 0000 0000 0000 0000       | 1000 0000 0000 0000        |
| <-1.000000V                         | 0000 0000 0000 00XX       | 1000 0000 0000 00XX        |

# DAC clock output



# DAC clock output (Sine Wave)



# Summary



# Hardware Schematic

---

# Power Supply



# Analog and Digital Ground Plane



# FPGA



Tang NANO 9k

|           |    |             |    |
|-----------|----|-------------|----|
| osc_out11 | 1  | 38 - IOB31B | 48 |
| osc_out10 | 2  | 37 - IOB31A | 47 |
| osc_out9  | 3  | 36 - IOB29B | 46 |
| osc_out8  | 4  | 39 - IOB33A | 45 |
| osc_out7  | 5  | 25 - IOB8A  | 44 |
| osc_out6  | 6  | 26 - IOB8B  | 43 |
| osc_out5  | 7  | 27 - IOB11A | 42 |
| osc_out4  | 8  | 28 - IOB11B | 41 |
| osc_out3  | 9  | 29 - IOB13A | 40 |
| osc_out2  | 10 | 30 - IOB13B | 39 |
| osc_out1  | 11 | 33 - IOB23A | 38 |
| osc_out0  | 12 | 34 - IOB23B | 37 |
| dac_clk   | 13 | 40 - IOB33B | 36 |
| Sw Mode   | 14 | 35 - IOB29A | 35 |
|           | 15 | 41 - IOB41A | 34 |
|           | 16 | 42 - IOB41B | 33 |
|           | 17 | 51 - IOR17B | 32 |
|           | 18 | 53 - IOR15B | 31 |
|           | 19 | 54 - IOR15A | 30 |
|           | 20 | 55 - IOR14B | 29 |
|           | 21 | 56 - IOR14A | 28 |
|           | 22 | 57 - IOR13A | 27 |
|           | 23 | 68 - IOT42B | 26 |
|           | 24 | 69 - IOT42A | 25 |



# Mode Switch and Rotary



# Digital to Analog Converter



# Digital to Analog Convertor

## FUNCTIONAL DESCRIPTION

Figure 39 shows a simplified block diagram of the AD9762. The AD9762 consists of a large PMOS current source array that is capable of providing up to 20 mA of total current. The array is divided into 31 equal currents that make up the 5 most significant bits (MSBs). The next 4 bits or middle bits consist of 15 equal current sources whose value is 1/16th of an MSB current source. The remaining LSBs are binary weighted fractions of the middle-bits current sources. Implementing the middle and lower bits with current sources, instead of an R-2R ladder, enhances its dynamic performance for multitone or low amplitude signals and helps maintain the DAC's high output impedance (i.e., >100 kΩ).

All of these current sources are switched to one or the other of the two output nodes (i.e., I<sub>OUTA</sub> or I<sub>OUTB</sub>) via PMOS differential current switches. The switches are based on a new architecture that drastically improves distortion performance. This new switch architecture reduces various timing errors and provides matching complementary drive signals to the inputs of the differential current switches.

The analog and digital sections of the AD9762 have separate power supply inputs (i.e., AVDD and DVDD) that can operate independently over a 2.7 volt to 5.5 volt range. The digital section, which is capable of operating up to a 125 MSPS clock rate, consists of edge-triggered latches and segment decoding logic circuitry. The analog section includes the PMOS current sources, the associated differential switches, a 1.20 V bandgap voltage reference and a reference control amplifier.

The full-scale output current is regulated by the reference control amplifier and can be set from 2 mA to 20 mA via an external resistor, R<sub>SET</sub>. The external resistor, in combination with both the reference control amplifier and voltage reference V<sub>REFIO</sub>, sets the reference current I<sub>REF</sub>, which is mirrored over to the segmented current sources with the proper scaling factor. The full-scale current, I<sub>OUTFS</sub>, is thirty-two times the value of I<sub>REF</sub>.

## DAC TRANSFER FUNCTION

The AD9762 provides complementary current outputs, I<sub>OUTA</sub> and I<sub>OUTB</sub>. I<sub>OUTA</sub> will provide a near full-scale current output, I<sub>OUTFS</sub>, when all bits are high (i.e., DAC CODE = 4095) while I<sub>OUTB</sub>, the complementary output, provides no current. The current output appearing at I<sub>OUTA</sub> and I<sub>OUTB</sub> is a function of both the input code and I<sub>OUTFS</sub> and can be expressed as:

$$I_{OUTA} = (DAC\ CODE/4096) \times I_{OUTFS} \quad (1)$$

$$I_{OUTB} = (4095 - DAC\ CODE)/4096 \times I_{OUTFS} \quad (2)$$

where DAC CODE = 0 to 4095 (i.e., Decimal Representation).

As mentioned previously, I<sub>OUTFS</sub> is a function of the reference current I<sub>REF</sub>, which is nominally set by a reference voltage V<sub>REFIO</sub> and external resistor R<sub>SET</sub>. It can be expressed as:

$$I_{OUTFS} = 32 \times I_{REF} \quad (3)$$

$$\text{where } I_{REF} = V_{REFIO}/R_{SET} \quad (4)$$

The two current outputs will typically drive a resistive load directly or via a transformer. If dc coupling is required, I<sub>OUTA</sub> and I<sub>OUTB</sub> should be directly connected to matching resistive loads, R<sub>LOAD</sub>, which are tied to analog common, ACOM. Note, R<sub>LOAD</sub> may represent the equivalent load resistance seen by I<sub>OUTA</sub> or I<sub>OUTB</sub> as would be the case in a doubly terminated 50 Ω or 75 Ω cable. The single-ended voltage output appearing at the I<sub>OUTA</sub> and I<sub>OUTB</sub> nodes is simply :

$$V_{OUTA} = I_{OUTA} \times R_{LOAD} \quad (5)$$

$$V_{OUTB} = I_{OUTB} \times R_{LOAD} \quad (6)$$

Note the full-scale value of V<sub>OUTA</sub> and V<sub>OUTB</sub> should not exceed the specified output compliance range to maintain specified distortion and linearity performance.

The differential voltage, V<sub>DIFF</sub>, appearing across I<sub>OUTA</sub> and I<sub>OUTB</sub> is:

$$V_{DIFF} = (I_{OUTA} - I_{OUTB}) \times R_{LOAD} \quad (7)$$

Substituting the values of I<sub>OUTA</sub>, I<sub>OUTB</sub>, and I<sub>REF</sub>; V<sub>DIFF</sub> can be expressed as:

$$V_{DIFF} = \{(2 \text{ DAC CODE} - 4095)/4096\} \times (32 R_{LOAD}/R_{SET}) \times V_{REFIO} \quad (8)$$

These last two equations highlight some of the advantages of operating the AD9762 differentially. First, the differential operation will help cancel common-mode error sources associated with I<sub>OUTA</sub> and I<sub>OUTB</sub> such as noise, distortion and dc offsets. Second, the differential code dependent current and subsequent voltage, V<sub>DIFF</sub>, is twice the value of the single-ended voltage output (i.e., V<sub>OUTA</sub> or V<sub>OUTB</sub>), thus providing twice the signal power to the load.

Note, the gain drift temperature performance for a single-ended (V<sub>OUTA</sub> and V<sub>OUTB</sub>) or differential output (V<sub>DIFF</sub>) of the AD9762 can be enhanced by selecting temperature tracking resistors for R<sub>LOAD</sub> and R<sub>SET</sub> due to their ratiometric relationship as shown in Equation 8.



# Differential Amplifier & LPF



# Differential Amplifier



When resistors,  $R_1 = R_2$  and  $R_3 = R_4$  the above transfer function for the differential amplifier can be simplified to the following expression:

**Differential Amplifier Equation**

$$V_{OUT} = \frac{R_3}{R_1} (V_2 - V_1)$$

$$f = \frac{3300}{390} (v_2 - v_1) = 8.46(v_2 - v_1)$$

# Low pass filter

Second-order Active Low Pass Filter Circuit



$$A_v = 1 + \frac{R_2}{R_1}$$

$$f_c = \frac{1}{2\pi \sqrt{R_3 R_4 C_1 C_2}}$$

$$f = \frac{1}{2\pi R C} = \frac{1}{2\pi(390)(100p)} = 4 \text{ MHz}$$

# Summing Amp (Attenuator and DC Offset)



# DDS Case







# Chip Implementation



# Implementation Checklist

1. Correct Function -> Logic Simulation 

2. Synthesizable Code -> Synthesis Tool 

3. Place and Route -> Floorplan and Synthesis Tool 

---

# Timing Constraint



# Timing Constraint Setup



# Timing Constraint Setup



# Timing Constraint Setup



# Timing Constraint Setup



# Set False Path



# I/O Setup

Tang NANO 9k

|           |    |             |             |    |
|-----------|----|-------------|-------------|----|
| osc out11 | 1  | 38 - IOB31B | 63 - IOR5A  | 48 |
| osc out10 | 2  | 37 - IOB31A | 86 - IOT8A  | 47 |
| osc out9  | 3  | 36 - IOB29B | 85 - IOT8B  | 46 |
| osc out8  | 4  | 39 - IOB33A | 84 - IOT10A | 45 |
| osc out7  | 5  | 25 - IOB8A  | 83 - IOT10B | 44 |
| osc out6  | 6  | 26 - IOB8B  | 82 - IOT11A | 43 |
| osc out5  | 7  | 27 - IOB11A | 81 - IOT11B | 42 |
| osc out4  | 8  | 28 - IOB11B | 80 - IOT12A | 41 |
| osc out3  | 9  | 29 - IOB13A | 79 - IOT12B | 40 |
| osc out2  | 10 | 30 - IOB13B | 77 - IOT37A | 39 |
| osc out1  | 11 | 33 - IOB23A | 76 - IOT37B | 38 |
| osc out0  | 12 | 34 - IOB23B | 75 - IOT38A | 37 |
| dac clk   | 13 | 40 - IOB33B | 74 - IOT38B | 36 |
| Sw Mode   | 14 | 35 - IOB29A | 73 - IOT39A | 35 |
|           | 15 | 41 - IOB41A | 72 - IOT39B | 34 |
|           | 16 | 42 - IOB41B | 71 - IOT41A | 33 |
|           | 17 | 51 - IOR17B | 70 - IOT41B | 32 |
|           | 18 | 53 - IOR15B | 5V          | 31 |
|           | 19 | 54 - IOR15A | 48 - IOR24B | 30 |
|           | 20 | 55 - IOR14B | 49 - IOR24A | 29 |
|           | 21 | 56 - IOR14A | 31 - IOB15A | 28 |
| Rot C     | 22 | 57 - IOR13A | 32 - IOB15B | 27 |
| Rot B     | 23 | 68 - IOT42B | GND         | 26 |
| Rot A     | 24 | 69 - IOT42A | 3V3         | 25 |

3V3  
GND



XTAL



# I/O Setup



# Synthesis Report

GOWIN FPGA Designer - [C:\Users\Cloudie\Documents\Gowin\fpga\DDS\_project\impl\gwsynthesis\DDS\_project\_syn.rpt.html]

File Edit Project Tools Window Help

Process

- Design Summary
- User Constraints
  - FloorPlanner
  - Timing Constraints Editor
- Synthesize
  - Synthesis Report**
  - Netlist File
- Place & Route
  - Place & Route Report
  - Timing Analysis Report
  - Ports & Pins Report
  - Power Analysis Report
- Program Device

**Synthesis Messages**

**Synthesis Details**

**Resource**

- Resource Usage Summary
- Resource Utilization Summary

**Timing**

- Clock Summary
- Max Frequency Summary
- Detail Timing Paths Information

**Timing**

**Clock Summary:**

| Clock Name                                  | Type      | Period | Frequency(MHz) | Rise  | Fall   | Source               | Master        | Object                   |
|---------------------------------------------|-----------|--------|----------------|-------|--------|----------------------|---------------|--------------------------|
| input_clk_27M                               | Base      | 37.037 | 27.0           | 0.000 | 18.519 |                      |               | input_clk_27M_ibuf/I     |
| CLK_DIV_module/fg_clk_1                     | Base      | 20.000 | 50.0           | 0.000 | 10.000 |                      |               | CLK_DIV_module/Fg_CLK    |
| CLK_DIV_module/n9_6                         | Base      | 20.000 | 50.0           | 0.000 | 10.000 |                      |               | CLK_DIV_module/n9_s2/C   |
| PLL_module/rpll_inst/CLKOUT.default_gen_clk | Generated | 20.833 | 48.0           | 0.000 | 10.417 | input_clk_27M_ibuf/I | input_clk_27M | PLL_module/rpll_inst/CLK |

**Max Frequency Summary:**

| No. | Clock Name              | Constraint | Actual Fmax | Logic Level | Entity |
|-----|-------------------------|------------|-------------|-------------|--------|
| 1   | input_clk_27M           | 27.0(MHz)  | 69.4(MHz)   | 11          | TOP    |
| 2   | CLK_DIV_module/fg_clk_1 | 50.0(MHz)  | 37.4(MHz)   | 18          | TOP    |

**Detail Timing Paths Information**

Path 1

Path Summary:

Design Process Hierarchy Start Page Design Summary dds\_top.v DDS\_project.tr.html DDS\_project\_syn.rpt.html

Console

```
Running power analysis.....  
[100%] Power analysis completed  
Generate file "C:\Users\Cloudie\Documents\Gowin\fpga\DDS_project\impl\pnr\DDS_project.power.html" completed  
Generate file "C:\Users\Cloudie\Documents\Gowin\fpga\DDS_project\impl\pnr\DDS_project.pin.html" completed  
Generate file "C:\Users\Cloudie\Documents\Gowin\fpga\DDS_project\impl\pnr\DDS_project.rpt.html" completed  
Generate file "C:\Users\Cloudie\Documents\Gowin\fpga\DDS_project\impl\pnr\DDS_project.rpt.txt" completed  
Generate file "C:\Users\Cloudie\Documents\Gowin\fpga\DDS_project\impl\pnr\DDS_project.tr.html" completed  
Sat Jul 06 01:33:50 2024
```

%

Console Message

# Timing Analysis Report

GOWIN FPGA Designer - [C:\Users\Cloudie\Documents\Gowin\fpga\DDS\_project\impl\pnr\DDS\_project.tr.html]

File Edit Project Tools Window Help

Process

- Design Summary
- User Constraints
  - FloorPlanner
  - Timing Constraints Editor
- Synthesize
  - Synthesis Report
  - Netlist File
- Place & Route
  - Place & Route Report
  - Timing Analysis Report
  - Ports & Pins Report
  - Power Analysis Report
- Program Device

Timing Messages

Timing Summaries

- STA Tool Run Summary
- Clock Summary
- Max Frequency Summary
- Total Negative Slack Summary

Timing Details

- Path Slacks Table
- Setup Paths Table
- Hold Paths Table
- Recovery Paths Table
- Removal Paths Table
- Minimum Pulse Width Table

Timing Report By Analysis Type

- Setup Analysis Report
- Hold Analysis Report
- Recovery Analysis Report
- Removal Analysis Report
- Minimum Pulse Width Report
- High Fanout Nets Report
- Route Congestions Report

Timing Exceptions Report

- Setup Analysis Report
- Hold Analysis Report
- Recovery Analysis Report

Timing Summaries

**STA Tool Run Summary:**

|                                     |                      |
|-------------------------------------|----------------------|
| Setup Delay Model                   | Slow 1.14V 85C C6/15 |
| Hold Delay Model                    | Fast 1.26V 0C C6/15  |
| Numbers of Paths Analyzed           | 2310                 |
| Numbers of Endpoints Analyzed       | 701                  |
| Numbers of Falling Endpoints        | 1                    |
| Numbers of Setup Violated Endpoints | 0                    |
| Numbers of Hold Violated Endpoints  | 0                    |

**Clock Summary:**

| Clock Name | Type      | Period | Frequency(MHz) | Rise  | Fall   | Source                      | Master  | Objects                     |
|------------|-----------|--------|----------------|-------|--------|-----------------------------|---------|-----------------------------|
| CLK_27M    | Base      | 36.000 | 27.778         | 0.000 | 18.000 |                             |         | input_clk_27M               |
| CLK_PLL    | Base      | 20.833 | 48.001         | 0.000 | 10.000 |                             |         | PLL_module/rpll_inst/CLKOUT |
| CLK_24M    | Generated | 41.666 | 24.000         | 0.000 | 20.833 | PLL_module/rpll_inst/CLKOUT | CLK_PLL | CLK_DIV_module/Fg_CLK_s/Q   |

**Max Frequency Summary:**

| NO. | Clock Name | Constraint  | Actual Fmax  | Logic Level | Entity |
|-----|------------|-------------|--------------|-------------|--------|
| 1   | CLK_27M    | 27.778(MHz) | 69.151(MHz)  | 11          | TOP    |
| 2   | CLK_PLL    | 48.001(MHz) | 670.005(MHz) | 2           | TOP    |
| 3   | CLK_24M    | 24.000(MHz) | 31.452(MHz)  | 18          | TOP    |

**Total Negative Slack Summary:**

Design Page Start Page Design Summary dds\_top.v DDS\_project.tr.html

Console

```
Running power analysis.....  
[100%] Power analysis completed  
Generate file "C:\Users\Cloudie\Documents\Gowin\fpga\DDS_project\impl\pnr\DDS_project.power.html" completed  
Generate file "C:\Users\Cloudie\Documents\Gowin\fpga\DDS_project\impl\pnr\DDS_project.pin.html" completed  
Generate file "C:\Users\Cloudie\Documents\Gowin\fpga\DDS_project\impl\pnr\DDS_project.rpt.html" completed  
Generate file "C:\Users\Cloudie\Documents\Gowin\fpga\DDS_project\impl\pnr\DDS_project.rpt.txt" completed  
Generate file "C:\Users\Cloudie\Documents\Gowin\fpga\DDS_project\impl\pnr\DDS_project.tr.html" completed  
Sat Jul 06 01:33:50 2024
```

%

Console Message

# Ports & Pins Report

GOWIN FPGA Designer - [C:\Users\Cloudie\Documents\Gowin\fpga\DDS\_project\impl\pnr\DDS\_project.pin.html]

File Edit Project Tools Window Help

Process Design Summary User Constraints FloorPlanner Timing Constraints Editor Synthesis Synthesis Report Netlist File Place & Route Place & Route Report Timing Analysis Report Ports & Pins Report Power Analysis Report Program Device

Created Time Sat Jul 06 01:53:45 2024 Legal Announcement Copyright (C)2014-2023 Gowin Semiconductor Corporation. All rights reserved.

Pin Messages Pin Details

Pinout by Port Name All Package Pins

**Pin Details**

**Pinout by Port Name:**

| Port Name                  | Diff Pair | Loc./Bank | Constraint | Dir. | Site     | IO Type   | Drive | Pull Mode | PCI Clamp | Hysteresis | Open Drain | Vr |
|----------------------------|-----------|-----------|------------|------|----------|-----------|-------|-----------|-----------|------------|------------|----|
| input_clk_27M              |           | 52/1      | Y          | in   | IOR17[A] | LVC MOS33 | NA    | UP        | ON        | NONE       | NA         | NA |
| input_RESET_gen            |           | 4/3       | Y          | in   | IOL5[A]  | LVC MOS18 | NA    | UP        | ON        | NONE       | NA         | NA |
| input_BTN_mode             |           | 35/2      | Y          | in   | IOB29[A] | LVC MOS33 | NA    | UP        | ON        | NONE       | NA         | NA |
| input_Rot_A                |           | 69/1      | Y          | in   | IOT42[A] | LVC MOS33 | NA    | UP        | ON        | NONE       | NA         | NA |
| input_Rot_B                |           | 68/1      | Y          | in   | IOT42[B] | LVC MOS33 | NA    | UP        | ON        | NONE       | NA         | NA |
| input_BTN_step             |           | 57/1      | Y          | in   | IOR13[A] | LVC MOS33 | NA    | UP        | ON        | NONE       | NA         | NA |
| output_Dac_CLK             |           | 40/2      | Y          | out  | IOB33[B] | LVC MOS33 | 8     | UP        | NA        | NA         | OFF        | NA |
| output_interp_unsigned[0]  |           | 34/2      | Y          | out  | IOB23[B] | LVC MOS33 | 8     | UP        | NA        | NA         | OFF        | NA |
| output_interp_unsigned[1]  |           | 33/2      | Y          | out  | IOB23[A] | LVC MOS33 | 8     | UP        | NA        | NA         | OFF        | NA |
| output_interp_unsigned[2]  |           | 30/2      | Y          | out  | IOB13[B] | LVC MOS33 | 8     | UP        | NA        | NA         | OFF        | NA |
| output_interp_unsigned[3]  |           | 29/2      | Y          | out  | IOB13[A] | LVC MOS33 | 8     | UP        | NA        | NA         | OFF        | NA |
| output_interp_unsigned[4]  |           | 28/2      | Y          | out  | IOB11[B] | LVC MOS33 | 8     | UP        | NA        | NA         | OFF        | NA |
| output_interp_unsigned[5]  |           | 27/2      | Y          | out  | IOB11[A] | LVC MOS33 | 8     | UP        | NA        | NA         | OFF        | NA |
| output_interp_unsigned[6]  |           | 26/2      | Y          | out  | IOB8[B]  | LVC MOS33 | 8     | UP        | NA        | NA         | OFF        | NA |
| output_interp_unsigned[7]  |           | 25/2      | Y          | out  | IOB8[A]  | LVC MOS33 | 8     | UP        | NA        | NA         | OFF        | NA |
| output_interp_unsigned[8]  |           | 39/2      | Y          | out  | IOB33[A] | LVC MOS33 | 8     | UP        | NA        | NA         | OFF        | NA |
| output_interp_unsigned[9]  |           | 36/2      | Y          | out  | IOB29[B] | LVC MOS33 | 8     | UP        | NA        | NA         | OFF        | NA |
| output_interp_unsigned[10] |           | 37/2      | Y          | out  | IOB31[A] | LVC MOS33 | 8     | UP        | NA        | NA         | OFF        | NA |
| output_interp_unsigned[11] |           | 38/2      | Y          | out  | IOB31[B] | LVC MOS33 | 8     | UP        | NA        | NA         | OFF        | NA |

**All Package Pins:**

| Loc./Bank | Signal | Dir. | Site    | IO Type   | Drive | Pull Mode | PCI Clamp | Hysteresis | Open Drain | Vref | S |
|-----------|--------|------|---------|-----------|-------|-----------|-----------|------------|------------|------|---|
| 3/3       | -      | in   | IOT2[A] | LVC MOS18 | NA    | UP        | ON        | NONE       | NA         | NA   | N |
| 88/3      | -      | in   | IOT5[A] | LVC MOS18 | NA    | UP        | ON        | NONE       | NA         | NA   | N |

Design Process Hierarchy Start Page Design Summary DDS\_top.v DDS\_project.tr.html DDS\_project\_syn.rpt.html DDS\_project.pin.html

# DDS Specification

200KHz

1. มีเอาท์พุทเป็นสัญญาณไซน์ที่ความถี่ตั้งแต่ 50 Hz ถึง ~~1 MHz~~. แรงดันเอาท์พุทตั้งแต่ 1 Vpp ถึง 10 Vpp
3. ต้องมีแรงดันออฟเซทเป็นไม่เกิน 30 mV ที่เอาท์พุท (สามารถปรับแรงดันออฟเซทเป็นค่าอื่น ๆ ได้หรือไม่ก็ได้)
4. คุณสมบัติของสัญญาณไซน์ที่สร้างได้จะต้องมี Total Harmonic Distortion (THD-F) ที่ Harmonic ที่ 1-4 น้อยกว่า 5% ตลอดช่วงความถี่ที่แรงดัน 10 Vpp
6. ไม่จำกัดวิธีการปรับความถี่, แอมเพลจูดและออฟเซท สามารถควบคุมจากการจัดการดิจิทัลหรืออนาล็อกก็ได้

# DDS Evaluation



---

# Total Harmonic Distortion (THD)



$$THD = \frac{\sqrt{v_2^2 + v_3^2 + v_4^2}}{v_1}$$

กรณี nibble 3 Harmonics

# วิธีวัดค่า THD จากสโคป



$$THD = \frac{\sqrt{v_2^2 + v_3^2 + v_4^2}}{v_1} = \sqrt{\frac{(v_2)^2}{(v_1)^2} + \frac{(v_3)^2}{(v_1)^2} + \frac{(v_4)^2}{(v_1)^2}}$$

เนื่องจาก  $v_2$  มีค่าสูงสุดเทียบกับ  $v_3$  และ  $v_4$  สมมุติให้  $v_3$  และ  $v_4$  เท่ากับ  $v_2$

$$THD \approx \sqrt{3 \frac{(v_2)^2}{(v_1)^2}} = \sqrt{3(10^{\frac{(y_2-y_1)}{10}})} \quad \xrightarrow{\text{คิดเป็นเบอร์เซ็นต์}} \quad THD \approx 100 * \sqrt{3 * (10^{\frac{(y_2-y_1)}{10}})}$$

$$y_2 - y_1 = 10 \log(v_2)^2 - 10 \log(v_1)^2$$

หน่วย dB

$$\frac{y_2 - y_1}{10} = \log(v_2)^2 - \log(v_1)^2$$

$$\frac{y_2 - y_1}{10} = \log\left(\frac{v_2}{v_1}\right)^2$$

$$10^{\frac{(y_2-y_1)}{10}} = \frac{(v_2)^2}{(v_1)^2}$$

สมการที่ 2

ในโปรเจคนี้วัดแค่ noise สามแท่งแรก

# Evaluation Table

## ສัญญาณໃช້

|                             | 50 Hz | 100 Hz | 1 KHz | 10 KHz | 100 KHz | 200 KHz |
|-----------------------------|-------|--------|-------|--------|---------|---------|
| แรงดันເອາຫຼິກ<br>(1-10 Vpp) |       |        |       |        |         |         |
|                             | ຜ່ານ  |        |       |        |         |         |
| แรงดันອອີເະທ<br>(<30 mv)    |       |        |       |        |         |         |
|                             | ຜ່ານ  |        |       |        |         |         |
| Distortion (THD)<br>(<5%)   |       |        |       |        |         |         |
|                             | ຜ່ານ  |        |       |        |         |         |

# Experiment results in the report

- Sine Wave  $10v_{PP}$  @200KHz, 100KHz, 10KHz, 1KHz, 100Hz, 50Hz
- Sine Wave  $1v_{PP}$  @200KHz, 100KHz, 10KHz, 1KHz, 100Hz, 50Hz
- Sine Wave  $10V_{PP}$   $\pm 5V$  offset @200KHz
- FFT result of sine Wave  $10v_{PP}$  @ 200KHz, 100KHz, 10KHz, 1KHz, 100Hz, 50Hz