Wave Generation in FPGA

Download as ehtml, pdf, or txt
Download as ehtml, pdf, or txt
You are on page 1of 3

Signal Generator using Direct Digital Synthesis ABSTRACT: Signal generators are generally large in size due to its

bulky hardware and it is not portable also. Also it can only generate particular set of waveforms. We cannot create any arbitrary waveform. Nowadays digital signal generators are available but still it is not reconfigurable and it cannot create any type of waveform we want. In our project we use FPGA to realize all the hardware parts of signal generator in a better way and we use a method called Direct Digital Synthesis to realize any type of waveform we want. We use a single chip to realize signal generator. Direct Digital Synthesis (DDS) is a method for digitally creating arbitrary waveforms from a single, fixed-frequency reference clock. DDS has many advantages over its analog counterpart and improved phase noise. It has precise control of the output phase across frequency switching transitions. The output of FPGA will be digital and this digital data is given to Digital-to-Analog Convertor (DAC). DAC converts the digitally created signal to analog form thus creating a versatile, flexible signal generator. The DAC and FPGA share a single clock source. Since we are using FPGA as a hardware part, in future easily upgrade the signal generator by altering the FPGA design. There is no need of extra cost to buy new signal generator unlike analog signal generator. Three main units of this project are Clock Source FPGA DAC

Introduction: Our project deals with the implementation of Direct Digital Synthesis using VHDL code in FPGA. DDS is a technique to generate the digital values of any waveform using digital components. Hence this can be easily implemented in FPGA using VHDL or Verilog HDL. FPGA IMPLEMENTATION OF DIRECT DIGITAL SYSNTHESIS

In our project, we created synthesizable vhdl code for generating various waveforms such as square wave, triangle wave, saw tooth wave, sine wave. The most critical part is the generation of sine wave. Here we used separate blocks for generation of each wave and a signal selector (similar to multiplexer) is used to select the required output waveform using select lines.

The implementation of DDS is divided into two distinct parts a discrete time phase generator (the accumulator) outputting a phase value ACC, and a phase to waveform converter outputting the desired DDS signal.

Phase Accumulator: Phase accumulator is nothing but a counter which resets periodically after n clock pulses. In our accumulator we used n = 512. Hence the period of each waveform will be equal to n clock pulses. The input to the phase accumulator is clock pulse (1 bit) and n value (8 bit).Output from the phase accumulator is an integer count (16 bit). If we increase this n value, the frequency of the generated wave can be decreased. This phase accumulator is common to all the blocks. Phase to waveform converter: Phase to waveform converter converts the phase value (count) into the wave form amplitude. This is also called phase to amplitude converter. This block will vary for each wave. Input to phase to waveform converter is phase count (16 bit) and n value. And the output is amplitude value wave_out (8 bit). Square wave:

The amplitude of the wave will be high for n/2 samples. Here we took high value as 127 corresponding to all ones. After n/2 cycles, the amplitude will be made low(0). Saw tooth wave: The amplitude should be increased to maximum for n samples and then reset to low. Maximum value is 127 and the low value is 0. The rate of increase is inversely proportional to n value. Triangular wave: The amplitude has to incremented to maximum till n/2 cycles (from all zeros to all ones). After n/2 cycles, the value has to be gradually decremented to all zeros again. Sine wave: The generation of sine wave is the most critical part in creating a DDS signal generator. There are many methods available to generate sine wave. They are 1. Taylor series Approximation 2. Table lookup. There are other methods available which are too complicated to implement in FPGA. 1. Taylor series Approximation The Taylor series of the sine function is: sin(x) = x - (x^3)/3! + (x^5)/5! - (x^7)/7! + ...

You might also like