

# Key Design Features

- Synthesizable, technology independent VHDL IP Core
- 16-bit signed input and output data samples
- Accepts either complex or real inputs
- Precision Digital Down Converter with 80 dB SFDR
- DDS Frequency resolution of F<sub>s</sub> / 2<sup>32</sup>
- DDS Phase resolution of 2pi / 2<sup>12</sup>
- Programmable tone centre frequency and detection bandwidth
- Detection bandwidth range from 0.005 to 0.03 x F<sub>S</sub>
- Choice of low pass filter responses
- Typical FPGA sample rates of up to 200 MHz<sup>1</sup>

# **Applications**

- Touch tone decoding (e.g. DTMF tones)
- Precision frequency monitoring and control
- Complex digital down conversion
- FSK / OOK / ASK demodulation

#### Generic Parameters

| Generic name | Description                                                                  | Туре                | Valid range                                              |
|--------------|------------------------------------------------------------------------------|---------------------|----------------------------------------------------------|
| gain         | Internal gain setting<br>(compensates for low<br>amplitude input<br>signals) | integer             | 0: x 1<br>1: x 2<br>2: x 4<br>3: x 8                     |
| dithering    | Enable phase dithering in DDS component                                      | boolean             | TRUE / FALSE                                             |
| seed         | Seed for random<br>number generator in<br>DDS component                      | std_logic<br>vector | 0 < seed < 2 <sup>32</sup>                               |
| use_complex  | Enable complex or real data samples                                          | boolean             | TRUE: use ports i_in and q_in  FALSE: use port i_in only |
| filter_type  | Low-pass filter response type                                                | integer             | 0: min B/W<br>3: max B/W                                 |
| threshold    | Tone detect threshold                                                        | integer             | 0 to 65535                                               |

# **Block Diagram**



Figure 1: Tone decoder architecture

## **Pin-out Description**

| Pin name         | 1/0 | Description                                                                   | Active state |
|------------------|-----|-------------------------------------------------------------------------------|--------------|
| clk              | in  | Sample clock                                                                  | rising edge  |
| reset            | in  | Asynchronous reset                                                            | low          |
| en               | in  | clock enable                                                                  | high         |
| phase_inc [31:0] | in  | Phase increment as an unsigned 32-bit number (controls tone centre frequency) | data         |
| i_in [15:0]      | in  | Real (In-phase) input data samples as a 16-bit signed number                  | data         |
| q_in [15:0]      | in  | Imaginary (Quadrature) input data samples as a 16-bit signed number           | data         |
| i_out [15:0]     | out | Output data samples as a 16-bit signed number                                 | data         |
| q_out [15:0]     | out | Output data samples as a 16-bit signed number                                 | data         |
| mag_out[15:0]    | out | Magnitude of complex output                                                   | data         |
| tone_present     | out | Tone present flag                                                             | high         |

# **General Description**

TONE\_DEC is a precision tone decoder with the capacity to support either real or complex data samples. Samples are first mixed-down to baseband before subsequent filtering and tone detection. Figure 1 shows the basic architecture and signal paths.

The centre frequency of the tone is fully programmable and is generated by a local oscillator (DDS). The DDS has an SFDR of better than 80 dBs (with phase dithering) and a theoretical SNR of approximately 100 dBs.

<sup>1</sup> Xilinx® Virtex 6 FPGA used as a benchmark



After down-conversion, the I and Q signal paths are filtered to remove components above the tone of interest. The characteristics of these filters may be changed depending on the desired detection bandwidth and response time.

Finally, a power function is used to compute the relative magnitude of the signal after filtering. If the complex input signal contains the tone of interest, then the relative output magnitude, <code>mag\_out</code>, will be greater. The generic parameter <code>threshold</code>, is a 16-bit unsigned integer that generates the <code>tone\_present</code> flag when the magnitude has reached a sufficient level.

#### Tone centre frequency

The frequency of the local oscillator is controlled by the signal *phase\_inc*. The phase increment may be calculated using the formula:

$$\Phi_{INC} = (F_{OUT} * 2^{32}) / F_{S}$$

Where  $F_{\text{OUT}}$  is the desired waveform output frequency and  $F_{\text{S}}$  is the sampling frequency. Note that an *integer* value for the phase increment must be used. As an example, consider a 100 MHz sample clock with a desired local oscillator frequency of 6.197 MHz. The phase increment would be calculated as (6.197 \*  $2^{32}$ ) / 100 + 0.5 = 266159123. The minimum and maximum local oscillator frequencies are given by the following formulas:

$$F_{MIN} = F_S / 2^{32}$$
 ,  $F_{MAX} = F_S / 2$ 

As an example, a 100 MHz sample clock would allow a minimum local oscillator frequency of 0.0233 Hz. Conversely, the maximum frequency the local oscillator can generate is given by the Nyquist / Shannon sampling theorem ( $F_{\rm S}$  / 2).

#### Low pass I/Q filters

After digital down conversion, the I and Q paths are filtered using a pair of IIR filters. Note that as these filters are recursive in nature, then the resulting output phase is non-linear. This must be taken into consideration if subsequent signal processing is to be done on the complex outputs.

In total, there are four separate filter responses that may be selected using the generic parameter *filter\_type*. Figure 2 shows the different filter responses for each setting.

Filter (a) is characterized by a very narrow bandwidth and a long impulse response time. Conversely, filter (d) has a much wider bandwidth with a shorter response time. The table below outlines these parameters in more detail.

| Filter type | -3dB cutoff frequency        | Approximate<br>Response time |
|-------------|------------------------------|------------------------------|
| 0 : (a)     | 0.005 * (F <sub>s</sub> / 2) | 300 samples                  |
| 1: (b)      | 0.01 * (F <sub>S</sub> /2)   | 150 samples                  |
| 2 : (c)     | 0.02 * (F <sub>S</sub> / 2)  | 75 samples                   |
| 3 : (d)     | 0.03 * (F <sub>S</sub> / 2)  | 50 samples                   |



Figure 2: Low-pass filter responses. The -3dB cutoff points are: (a) 0.005, (b) 0.001, (c) 0.02 and (d) 0.03 rads/sample

Note that it is important that the full 16-bit dynamic range of the tone decoder inputs is used in order for the low-pass filters to function optimally. For input samples with lower numbers of significant bits, the generic *gain* parameter may be adjusted accordingly.

# **Functional Timing**

Figure 3 shows the operation of the tone decoder during normal operation. In this particular example, the *threshold* has been set to 0x400 and *use\_complex* has been set to *false*. This means that only the 'I' signal path is used with 'Q' unused.

Notice that the *tone\_present* flag is asserted high when the output magnitude exceeds the threshold. The threshold value may be adjusted in order to alter the sensitivity of detection circuit. This may be necessary depending on the input signal dynamic range and the chosen filter type. The waveforms also show the action of the clock-enable signal *en*.



Samples are clocked on a rising clock-edge when en is high.



Figure 3: Tone decoder signal timing showing tone\_present flag and the action of clock-enable

#### Source File Description

All source files are provided as text files coded in VHDL. The following table gives a brief description of each file.

| Source file        | Description                      |
|--------------------|----------------------------------|
| sincos16.vhd       | SIN/COS look-up table            |
| dds16.vhd          | 16-bit DDS component             |
| ddc16.vhd          | 16-bit digital down converter    |
| iir_biquad.vhd     | IIR filter                       |
| lpf.vhd            | Dual-channel low-pass I/Q filter |
| tone_dec.vhd       | Top-level component              |
| tone_dec_bench.vhd | Top-level test bench             |

## **Functional Testing**

An example VHDL testbench is provided for use in a suitable VHDL simulator. The compilation order of the source code is as follows:

- 1. sincos16.vhd
- dds16.vhd
- 3. ddc16.vhd
- 4. iir\_biquad.vhd
- 5. lpf.vhd
- 6. tone\_dec.vhd
- 7. tone\_dec\_bench.vhd

The VHDL testbench instantiates the tone decoder component and also a separate DDS that provides the source input signal. The tone frequency of the source signal may be modified by adjusting the phase increment of the DDS accordingly.

In the example test provided, the tone decoder is configured to use filter type '1' with the magnitude threshold set to 1024. The system clock period is set to 100 MHz.

The tone frequency is set to 3MHz and the test sequences through a series of tones in 2 us intervals. The sequence is: 1 MHz, 2 MHz, 3 MHz, 4 MHz, 5 MHz, 4 MHz, 3 MHz ... etc.

The simulation must be run for at least 1 ms during which time the output magnitude samples will be captured to a text file called <code>tone\_dec\_out.txt</code>.

### Synthesis and Implementation

The files required for synthesis and the design hierarchy is shown below:

- tone dec.vhd
  - O ddc16.vhd
    - dds16.vhd
      - sincos16.vhd
  - Ipf.vhd
    - iir\_biquad.vhd

The VHDL IP Core is designed to be technology independent. However, as a benchmark, synthesis results have been provided for the Xilinx® Virtex 6 and Spartan 6 FPGA devices. Synthesis results for other FPGAs and technologies can be provided on request.

Note that setting the parameter *use\_complex* to 'false' will result in a saving of hardware multiplier components.

Trial synthesis results are shown with the generic parameters set to: gain = 0, seed = 0x14FFDE78, dithering = true, use\_complex = false, filter\_type = 0, threshold = 1024.

Resource usage is specified after place and route.

#### VIRTEX 6

| Resource type            | Quantity used |
|--------------------------|---------------|
| Slice register           | 328           |
| Slice LUT                | 452           |
| Block RAM                | 1             |
| DSP48                    | 18            |
| Occupied slices          | 156           |
| Clock frequency (approx) | 200 MHz       |

#### SPARTAN 6

| Resource type            | Quantity used |
|--------------------------|---------------|
| Slice register           | 324           |
| Slice LUT                | 416           |
| Block RAM                | 2             |
| DSP48                    | 18            |
| Occupied slices          | 138           |
| Clock frequency (approx) | 120 MHz       |



# Revision History

| Revision | Change description                                                                                           | Date       |
|----------|--------------------------------------------------------------------------------------------------------------|------------|
| 1.0      | Initial revision                                                                                             | 29/10/2009 |
| 1.1      | Updated block diagram                                                                                        | 17/03/2010 |
| 1.2      | Modified the DDS LUT to use 12-bits internally in order to reduce Block RAM usage. Updated synthesis results | 29/12/2011 |
| 1.3      | Added the gain generic parameter and optimized the IIR filter for speed                                      | 25/02/2015 |
|          |                                                                                                              |            |
|          |                                                                                                              |            |
|          |                                                                                                              |            |

# **X-ON Electronics**

Largest Supplier of Electrical and Electronic Components

Click to view similar products for Development Software category:

Click to view products by Zipcores manufacturer:

Other Similar products are found below:

SRP004001-01 SW163052 SYSWINEV21 WS01NCTF1E W128E13 SW89CN0-ZCC IP-UART-16550 MPROG-PRO535E AFLCF-08-LX-CE060-R21 WS02-CFSC1-EV3-UP SYSMAC-STUDIO-EIPCPLR 1120270005 SW006021-2H ATATMELSTUDIO 2400573 2702579 2988609 SW006022-DGL 2400303 88970111 DG-ACC-NET-CD 55195101-101 55195101-102 SW1A-W1C MDK-ARM SW006021-2NH B10443 SW006021-1H SW006021-2 SW006023-2 SW007023 MIKROE-730 MIKROE-2401 MIKROE-499 MIKROE-722 MIKROE-724 MIKROE-726 MIKROE-728 MIKROE-732 MIKROE-734 MIKROE-736 MIKROE-738 MIKROE-744 MIKROE-928 MIKROE-936 1120270002 1120270003 1120275015 NT-ZJCAT1-EV4