Chapter 17 Goertzel Algorithm

Slides:



Advertisements
Similar presentations
Chapter 19 Fast Fourier Transform (FFT) (Theory and Implementation)
Advertisements

Chapter 7 Linear Assembly
Chapter 11 Interfacing C and Assembly Code
Chapter 14 Finite Impulse Response (FIR) Filters
Chapter 17 DTMF generation and detection Dual Tone Multiple Frequency
Chapter 15 Infinite Impulse Response (IIR) Filters
Chapter 19 Fast Fourier Transform
DFT & FFT Computation.
Adders Used to perform addition, subtraction, multiplication, and division (sometimes) Half-adder adds rightmost (least significant) bit Full-adder.
1 Copyright © 2010, Elsevier Inc. All rights Reserved Fig 2.1 Chapter 2.
By D. Fisher Geometric Transformations. Reflection, Rotation, or Translation 1.
1 Retransmission Repeat: Simple Retransmission Permutation Can Resolve Overlapping Channel Collisions Li (Erran) Li Bell Labs, Alcatel-Lucent Joint work.
Jeopardy Q 1 Q 6 Q 11 Q 16 Q 21 Q 2 Q 7 Q 12 Q 17 Q 22 Q 3 Q 8 Q 13
Jeopardy Q 1 Q 6 Q 11 Q 16 Q 21 Q 2 Q 7 Q 12 Q 17 Q 22 Q 3 Q 8 Q 13
Title Subtitle.
DIVIDING INTEGERS 1. IF THE SIGNS ARE THE SAME THE ANSWER IS POSITIVE 2. IF THE SIGNS ARE DIFFERENT THE ANSWER IS NEGATIVE.
Addition Facts
DCSP-4: Modem Jianfeng Feng Department of Computer Science Warwick Univ., UK
TMS320C6xx Architecture C6xx
Chapter 9 Bootloader.
Lecture 11: Algorithms and Time Complexity I Discrete Mathematical Structures: Theory and Applications.
Solve Multi-step Equations
0 - 1 © 2007 Texas Instruments Inc, Content developed in partnership with Tel-Aviv University From MATLAB ® and Simulink ® to Real Time with TI DSPs Dual.
Monika Gope Lecturer IICT, KUET
Digital Filter Banks The digital filter bank is set of bandpass filters with either a common input or a summed output An M-band analysis filter bank is.
Discrete Controller Design
How To Use Google Forms to Create A Test Quick Easy Self-Graded!! Instant Reports.
ABC Technology Project
©2004 Brooks/Cole FIGURES FOR CHAPTER 7 MULTI-LEVEL GATE CIRCUITS NAND AND NOR GATES Click the mouse to move to the next page. Use the ESC key to exit.
IPIM, IST, José Bioucas, Convolution Operators Spectral Representation Bandlimited Signals/Systems Inverse Operator Null and Range Spaces Sampling,
Squares and Square Root WALK. Solve each problem REVIEW:
David Walker Ottawa TMG Users Group 15 March 2014.
David Hansen and James Michelussi
CS101: Introduction to Computer programming
Addition 1’s to 20.
25 seconds left…...
The Fundamental Theorem of Algebra
Chapter 18 Discrete Cosine Transform. Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2004 Chapter 18, Slide 2 Learning Objectives  Introduction.
S. Awad, Ph.D. M. Corless, M.S.E.E. E.C.E. Department University of Michigan-Dearborn Laplace Transform Math Review with Matlab: Fundamentals.
1 DREAM PLAN IDEA IMPLEMENTATION. 2 3 Introduction to Image Processing Dr. Kourosh Kiani
Week 1.
Chapter 20 This chapter provides a series of applications. There is no daughter cards with the DSK6713 and DSK6416 Part 1: Applications using the PCM3003.
We will resume in: 25 Minutes.
Chapter 16 Adaptive Filters
Computer Vision Lecture 7: The Fourier Transform
Chapter 8 Improving the User Interface
Math Review with Matlab:
Storey: Electrical & Electronic Systems © Pearson Education Limited 2004 OHT 18.1 Transient Behaviour  Introduction  Charging Capacitors and Energising.
1 General Structural Equation (LISREL) Models Week 3 #2 A.Multiple Group Models with > 2 groups B.Relationship to ANOVA, ANCOVA models C.Introduction to.
Details.L and.S units TMS320C6000 Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2004.
Lecture 6 Programming the TMS320C6x Family of DSPs.
Assembly and Linear Assembly Evgeny Kirshin, 05/10/2011
TMS320C6000 Architectural and Programming Overview.
Chapter 14 Finite Impulse Response (FIR) Filters.
0 - 1 © 2010 Texas Instruments Inc Practical Audio Experiments using the TMS320C5505 USB Stick “Sine Waves” Texas Instruments University Programme Teaching.
Dual Tone Multi-Frequency System Michael Odion Okosun Farhan Mahmood Benjamin Boateng Project Participants: Dial PulseDTMF.
Chapter 17 Goertzel Algorithm Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 17, Slide 2 Learning Objectives  Introduction.
Chapter 15 Infinite Impulse Response (IIR) Filters.
Chapter 19 Fast Fourier Transform (FFT) (Theory and Implementation)
Chapter 7 Linear Assembly. Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 7, Slide 2 Learning Objectives  Comparison of programming.
Zhongguo Liu_Biomedical Engineering_Shandong Univ. Chapter 8 The Discrete Fourier Transform Zhongguo Liu Biomedical Engineering School of Control.
Real time DSP Professors: Eng. Julian S. Bruno Eng. Jerónimo F. Atencio Sr. Lucio Martinez Garbino.
Copyright © 2003 Texas Instruments. All rights reserved. DSP C5000 Chapter 17 DTMF generation and detection Dual Tone Multiple Frequency.
Fast Fourier Transforms. 2 Discrete Fourier Transform The DFT pair was given as Baseline for computational complexity: –Each DFT coefficient requires.
Lecture 09b Finite Impulse Response (FIR) Filters
بسم الله الرحمن الرحيم Digital Signal Processing Lecture 14 FFT-Radix-2 Decimation in Frequency And Radix -4 Algorithm University of Khartoum Department.
Chapter 7 Linear Assembly
Chapter 17 Goertzel Algorithm
Chapter 9 Computation of the Discrete Fourier Transform
Chapter 15 Infinite Impulse Response (IIR) Filters
Presentation transcript:

Chapter 17 Goertzel Algorithm

Learning Objectives Introduction to DTMF signaling and tone generation. DTMF tone detection techniques and the Goertzel algorithm. Implementation of the Goertzel algorithm for tone detection in both fixed and floating point. Hand optimisation of assembly code.

Introduction The Goertzel algorithm is mainly used to detect tones for Dual Tone Multi-Frequency (DTMF) applications. DTMF is predominately used for push-button digital telephone sets which are an alternative to rotary telephone sets. DTMF has now been extended to electronic mail and telephone banking systems in which users select options from a menu by sending DTMF signals from a telephone.

DTMF Signaling In a DTMF signaling system a combination of two frequency tones represents a specific digit, character (A, B, C or D) or symbol (* or #). Two types of signal processing are involved: Coding or generation. Decoding or detection. For coding, two sinusoidal sequences of finite length are added in order to represent a digit, character or symbol as shown in the following example.

DTMF Tone Generation 1 2 3 6 5 4 7 8 9 # * A B C D 1 2 3 A 4 5 6 B 7 8 * A B C D 1209Hz 1336Hz 1477Hz 1633Hz 697Hz 770Hz 852Hz 941Hz 1 2 3 A 4 5 6 B 7 8 9 C * # D Output 770 770 770 770 1336 1336 1336 1336 Freq (Hz) Example: Button 5 results in a 770Hz and a 1336Hz tone being generated simultaneously.

DTMF Tone Generation Click on keypad to generate the sound. 1 2 3 A 1 1209Hz 1336Hz 1477Hz 1633Hz 1 2 3 A 697Hz 1 2 3 A 4 4 5 5 6 6 B B 770Hz 7 7 8 8 9 9 C 852Hz C * # D 941Hz * # D Click on keypad to generate the sound.

DTMF Tone Detection Detection of tones can be achieved by using a bank of filters or using the Discrete Fourier Transform (DFT or FFT). However, the Goertzel algorithm is more efficient for this application. The Goertzel algorithm is derived from the DFT and exploits the periodicity of the phase factor, exp(-j*2k/N) to reduce the computational complexity associated with the DFT, as the FFT does. With the Goertzel algorithm only 16 samples of the DFT are required for the 16 tones (\Links\Goertzel Theory.pdf).

Goertzel Algorithm Implementation To implement the Goertzel algorithm the following equations are required: These equations lead to the following structure:

Goertzel Algorithm Implementation

Goertzel Algorithm Implementation Finally we need to calculate the constant, k. The value of this constant determines the tone we are trying to detect and is given by: Where: ftone = frequency of the tone. fs = sampling frequency. N is set to 205. Now we can calculate the value of the coefficient 2cos(2**k/N).

Goertzel Algorithm Implementation Frequency k Coefficient (decimal) (Q15) 1633 42 0.559454 0x479C 1477 38 0.790074 0x6521 1336 34 1.008835 0x4090* 1209 31 1.163138 0x4A70* 941 24 1.482867 0x5EE7* 852 22 1.562297 0x63FC* 770 20 1.635585 0x68B1* 697 18 1.703275 0x6D02* N = 205 fs = 8kHz * The decimal values are divided by 2 to be represented in Q15 format. This has to be taken into account during implementation.

Goertzel Algorithm Implementation Feedback Feedforward Qn = x(n) - Qn-2 + coeff*Qn-1; 0n<N = sum1 + prod1 Where: coeff = 2cos(2k/N) The feedback section has to be repeated N times (N=205).

Goertzel Algorithm Implementation Feedback Feedforward Since we are only interested in detecting the presence of a tone and not the phase we can detect the square of the magnitude: |Yk(N) |2 = Q2(N) + Q2(N-1) - coeff*Q(N)*Q(N-1) Where: coeff = 2*cos(2**k/N)

Goertzel Algorithm Implementation void Goertzel (void) { static short delay; static short delay_1 = 0; static short delay_2 = 0; static int N = 0; static int Goertzel_Value = 0; int I, prod1, prod2, prod3, sum, R_in, output; short input; short coef_1 = 0x4A70; // For detecting 1209 Hz R_in = mcbsp0_read(); // Read the signal in input = (short) R_in; input = input >> 4; // Scale down input to prevent overflow prod1 = (delay_1*coef_1)>>14; delay = input + (short)prod1 - delay_2; delay_2 = delay_1; delay_1 = delay; N++; if (N==206) prod1 = (delay_1 * delay_1); prod2 = (delay_2 * delay_2); prod3 = (delay_1 * coef_1)>>14; prod3 = prod3 * delay_2; Goertzel_Value = (prod1 + prod2 - prod3) >> 15; Goertzel_Value <<= 4; // Scale up value for sensitivity N = 0; delay_1 = delay_2 = 0; } output = (((short) R_in) * ((short)Goertzel_Value)) >> 15; mcbsp0_write(output& 0xfffffffe); // Send the signal out return; ‘C’ code

Goertzel Algorithm Implementation .def _gz .sect "mycode" _gz .cproc input, coeff, count, mask2 .reg delay1, delay2, x, gzv .reg prod1, prod2, prod3, sum1, sum2 zero delay1 zero delay2 loop: ldh *input++, x mpy delay1, coeff, prod1 shr prod1, 14, prod1 sub x, delay2, sum1 mv delay1, delay2 add sum1, prod1, delay1 [count] sub count,1,count [count] b loop mpy delay1, delay1, prod1 mpy delay2, delay2, prod2 add prod1, prod2, sum1 mpy delay1, coeff, prod3 shr prod3, 14, prod3 mpy prod3, delay2, prod3 sub sum1,prod3, sum1 shr sum1, 15, gzv .return gzv .endproc Linear assembly (fixed-point)

Goertzel Algorithm Implementation .def _gz .sect "mycode" _gz .cproc input1, coeff, count, mask2 .reg delay1, delay2, x, gzv,test,y .reg prod1, prod2, prod3, sum1, sum2 zero delay1 zero delay2 loop: ldw *input1++, x mpysp delay1, coeff, prod1 subsp x, delay2, sum1 mv delay1, delay2 addsp sum1, prod1, delay1 [count] sub count,1,count [count] b loop mpysp delay1, delay1, prod1 mpysp delay2, delay2, prod2 addsp prod1, prod2, sum1 mpysp delay1, coeff, prod3 mpysp prod3, delay2, prod3 subsp sum1,prod3, sum1 .return sum1 .endproc Linear assembly (floating-point)

Hand Optimisation Implementation of: Cycle 1 2 3 4 5 6 7 8 9 10 11 Qn = [(coeff*Qn-1)>> 14 + x(n)] - Qn-2 Cycle 1 2 3 4 5 6 7 8 9 10 11 LDH ADD SUB MPY SHR Qn-2=Qn-1 MV Qn-1=Qn MV

Hand Optimisation Implementation of: Cycle 1 2 3 4 5 6 7 8 9 10 11 Qn = [(coeff*Qn-1)>> 14] + [x(n) - Qn-2] Cycle 1 2 3 4 5 6 7 8 9 10 11 LDH SUB Qn-1=Qn ADD MPY SHR Qn-2=Qn-1 MV

Hand Optimisation Now let us consider adding a second iteration. 1 2 3 4 5 6 7 8 9 10 11 LDH SUB ADD MPY SHR MV Now let us consider adding a second iteration. When can we start the “MPY” of the second iteration? Qn = [(coeff*Qn-1)>> 14] + [x(n) - Qn-2]

Hand Optimisation 1 2 3 4 5 6 7 8 9 10 11 LDH SUB ADD MPY MPY SHR MV We have to wait until the add has finished as the result of iteration 1 is one of the inputs to the multiply performed in iteration 2. Qn = [(coeff*Qn-1)>> 14] + [x(n) - Qn-2]

Hand Optimisation 1 2 3 4 5 6 7 8 9 10 11 LDH LDH SUB SHR ADD SUB MV ADD MPY MPY SHR MV The other instructions then follow in the same order. Finally the load of x[1] must have occurred before the sub, therefore the load must take place in cycle 5.

Goertzel Algorithm Implementation Hand optimised assembly (fixed-point): ; PIPED LOOP PROLOG LDH .D1T1 *A0++(4),A3 || [ A1] SUB .L1 A1,0x1,A1 [ A1] B .S1 loop NOP 1 ; PIPED LOOP KERNEL loop: MPY .M2 B4,B5,B6 [ A1] SUB .L1 A1,0x1,A1 || LDH .D1T1 *A0++(4),A3 MV .L1X B4,A4 || SUB .D1 A3,A4,A3 || SHR .S2 B6,0xe,B4 || [ A1] B .S1 loop ADD .L2X A3,B4,B4

Testing the Implementation Signal Gen DSK PC Osc/Spec Analyser The input signal is modulated with the square magnitude and sent to the codec. Therefore when the frequency of the input signal corresponds to the detection frequency, the input tone appears at the output.

Goertzel Code Code location: Projects: Code\Chapter 17 - Goertzel Algorithm Projects: Fixed Point in C: \Goertzel_C_Fixed\ Fixed Point in C with EDMA: \Goertzel_C_Fixed_EDMA\ Fixed Point in Linear Asm: \Goertzel_Sa_Fixed\ Floating Point in Linear Asm: \Goertzel_Sa_Float\

Chapter 17 Goertzel Algorithm - End -