最新消息: USBMI致力于为网友们分享Windows、安卓、IOS等主流手机系统相关的资讯以及评测、同时提供相关教程、应用、软件下载等服务。

双音频(DTMF)信号的产生与检测

IT圈 admin 26浏览 0评论

2024年5月2日发(作者:长义)

XXXXXXX大学

题目:双音频(

业 论 文 (设 计)

DTMF)信号的产生与检测

学生姓名

学 号

专 业 电子信息工程

班 级 2008级1班

指导教师

学 部 计算机科学与电气工程

答辩日期 2012年5月19日

黑龙江东方学院本科生毕业论文(设计)任务书

姓名

学号

专业班级 电子信息工程08级1班

毕业论文(设计)题目:双音频(DTMF)信号的产生与检测

毕业论文(设计)的立题依据

双音多频DTMF(Dual Tone Multi-Frequency)信令在全世界范围内得到广泛应用。

DTMF作为实现电话号码快速可靠传输的一种技术,它具有很强的抗干扰能力和较高的传

输速度,因此,可广泛用于电话通信系统中。

主要内容及要求

1、利用DTMF信号产生的原理合成数字1,其合成公式是

x

1

t

sin

2

697t

sin

2

1209t

分析其时域波形和频谱;

2、生成各个按键信号;

3、利用fft分析0~9十个数字拨号信息的频谱,观察频谱图中的峰值点的幅值以及它们出

现的位置。根据谱峰的幅值和位置,识别各DTMF信号所对应对应的数字;

4、编写Goertzel算法的程序,识别各DTMF信号所对应对应的数字;

进度安排

12月12日

12月13日~12月29日

12月30 日~1 月17日

1 月18日~2 月26日

2 月27日~3 月27日

3 月28日~4 月8 日

4 月9 日~4 月17日

4 月18日~4 月22日

4 月23日~5 月3 日

5 月4 日~5 月9 日

5 月10日~5 月18日

5 月19日

选题

接受指导老师的指导

拟定论文大纲

搜集、查阅、整理相关资料

初稿形成

初稿审定

第一次修改

第一次审定

第二次修改

定稿

论文评阅小组评审论文(设计)

毕业论文(设计)答辩

学生签字:

指导教师签字:

年 月 日

黑龙江东方学院本科毕业论文(设计)

双音频(DTMF)信号的产生与检测

摘 要

双音多频DTMF(Dual Tone Multi-Frequency)信令在全世界范围内得到广泛应

用,DTMF信令的产生与检测集成到含有数字信号处理器(DSP)的系统中,是一项

较有价值的工程应用。DTMF作为实现电话号码快速可靠传输的一种技术,它具有很

强的抗干扰能力和较高的传输速度,因此,可广泛用于电话通信系统中。但绝大部分

是用作电话的音频拨号,另外,它也可以在数据通信系统中广泛地用来实现各种数据

流和语音等信息的远程传输,研究其在MATLAB下的仿真实现有助于其具体系统的

优化设计。本文给出一种实现方案,主要阐述了DTMF的原理及如何在Matlab上产

生DTMF信号,并对用Goertzel算法提取的频谱进行分析,然后,得到用Goertzel算

法在白噪声的环境下对输入的DTMF信号提取频谱信息,最后,根据提取的频谱信息

对输入信号进行检测解码。

关键词

双音多频DTMF;Goertzel算法;Matlab

-I-

黑龙江东方学院本科毕业论文(设计)

Dual Tone Multi-frequency (DTMF) Signal Generation

and Detection

Abstract

DTMF (Dual Tone Multi-Frequency) signaling in the widely used worldwide, signaling

the DTMF generation and detection integrated with digital signal processor (DSP) system, is

a more value engineering. DTMF telephone number as to achieve a fast and reliable

transmission technology, it has a strong anti-interference ability and high transmission speed,

it can be widely used for telephone communication system. But the vast majority of

telephone tone dialing is used. In addition, it can also be in the data communication system

widely used to achieve a variety of data streams and remote transmission of voice and other

information. Under study in the MATLAB Simulation helps optimize the design of their

specific paper presents a realization of the program, mainly on the principle of

DTMF and how to generate DTMF signals in Matlab, and extracted with Goertzel algorithm

to analyze the spectrum, and then, get with the Goertzel algorithm in the context of white

noise on the input of the DTMF spectrum information signal extraction, and finally,

according to information extracted from the input signal spectrum to detect decoding.

Keywords:

Dual tone multi-frequency;Goertzel algorithm;Matlab

-II-

摘 要 ....................................................................................................................................... I

Abstract ........................................................................................................................................ II

第1章 绪 论 .......................................................................................................................... 1

1.1 引言 .................................................................................................................................. 1

1.2 课题意义 .......................................................................................................................... 1

第2章 基本原理 .......................................................................................................................... 3

2.1 自动电话的制式 .............................................................................................................. 3

2.2 DTMF技术 ........................................................................................................................ 5

2.3 Goertzel算法 ...................................................................................................................... 5

2.4 Matlab简介 ........................................................................................................................ 7

2.5 本章小结 .......................................................................................................................... 8

第3章 DTMF信号产生与检测 ................................................................................................... 9

3.1 DTMF信号的产生 ............................................................................................................ 9

3.2 DTMF信号的检测 .......................................................................................................... 10

3.2.1 DTMF信号检测方法 ............................................................................................... 10

3.2.2 DTMF信号有效性的检测 ....................................................................................... 12

3.3 本章小结 ........................................................................................................................ 13

第4章 Matlab仿真 .................................................................................................................... 14

4.1 设计程序(见附录) .................................................................................................... 14

4.2 Matlab仿真 ...................................................................................................................... 14

4.3 本章小结 ........................................................................................................................ 17

结 论 .................................................................................................................................... 18

参考文献 .................................................................................................................................... 19

附 录 .................................................................................................................................... 20

致 谢 .................................................................................................................................... 29

黑龙江东方学院本科毕业论文(设计)

双音频(DTMF)信号的产生与检测

第1章 绪 论

1.1 引言

电话中的双音多频信号(DTMF)有两种用途:一是用于双音多频信号的拨号,

去控制交换机接通被叫的用户话机;二是利用双音多频信号遥控电话机各种动作,如

播放留言、语音信箱等,并可以通过附加一些电路来是实现遥控家电设备的开启关闭

等智能功能。前者解决双音多频信号的发送和编码,后者是双音多频信号的接收和解

码。这些东西都离不开DTMF信号的正确检测。目前,大多数的DTMF信号的检测均采

用专用的发送、接收芯片,这种解码的原理都依赖于计算输入信号的过零率。但这种

方法有很大的局限性,无法检测多路DTMF信号,当混有语音和噪声时,专用芯片检

测往往出现误差,如果音频信号频率改变应用于别的系统时,专用的芯片就发挥不了

作用。所以,用硬件实现DTMF信号的检测并不是一种很好的选择

[1]

信息化已经成为社会发展的大趋势,信息化是以数字化为背景的,而DSP技术则

是数字化最重要的基本技术之一。在过去的短短的二十来年里,DSP处理器的性能得

到很大改善,软件和开发工具也得到相应的发展,价格却大幅度地下降,从而得到越来

越广泛的应用。通信领域(移动通信的交换设备、基站和手机,网络的路由和交换设

备,智能天线,软件无线电,IP电话等),雷达和声纳系统,巡航导弹、灵巧炸弹及各

种武器系统,自动测试系统,医疗诊断设备(CT、核磁共振、B超等),计算机及其外

设,消费类电子设备(VCD、DVD、HDTV、机顶盒、MP3、家庭影院系统、数字照相

机和摄象机等),机器人及各种自动控制系统,等等,应用范围不胜枚举

[2]

1.2 课题意义

DTMF(Dual Tone Multi Frequency)中文译为双音多频信号,最初由美国AT&T贝尔

公司实验室研制,用于音频电话网络中的拨号信号。一方面这种信号有非在常高的拨号

速度,另一方面它便于自动检测识别及电话业务的扩展,所以很快代替了原有的脉冲计

数方式的拨号形式在这里不得不提一下电话交换机的发展历史。自1876年美国贝尔发

明电话以来,电话交换技术发展主要经历了三个阶段:人工交换、机电交换、电子交

换。早在1878年就出现了人工供电制交换机,它借助话务员进行话务接续。15年后步进

-1-

黑龙江东方学院本科毕业论文(设计)

制的交换机问世,这种交换机属于“直接控制”方式,用户通过话机拨号脉冲直接控制

步进接续器做升降和旋转动作。从而自动完成用户间的接续。这种交换机虽然实现了

自动接续,但存在着速度慢、效率低、杂音大与机械磨损严重等特点。直到1938年发明

了纵横制交换机由直接控制过渡到间接控制方式,随后又出现了电子交换机及程控交换

机等。用户的拨号脉冲不再直接控制接线器动作,而先由记发器接收、存储,然后通过

标志器驱动接线器,以完成用户间接续

[3]

DTMF双音多频拨号和解码在通信系统及其它方面有着广泛的应用。DTMF信号

是便于标志器记取的是标识信号,所以可以不采用不稳定的脉冲计数方式,逐步发展、

到数字号码标识,所以快速,稳定灵活的DTMF音频拨号方式取代了脉冲拨号方式。电

子交换机程控交换机。话网中常用的信令,无论是家用电话、移动电话还是程控交换

机,多采用DTMF信号发送接收号码

[4]

语音芯片的应用前景也十分广阔,目前语音芯片已应用于微型固体录音机、通

讯、电话、车船、飞机黑匣子、有声电子信函、语音信箱、高级玩具等。此外,还可

以利用语音芯片开发出“会说话”的电压表、电流表等语音型智能仪器仪表以及“会

说话的电子称”、“出租车自动语音报价器”、“多路语音报警系统”等新颖电子电

器产品。

该项设计可促进我们学习开发电子、通信产品的技术,培养和锻炼我们电子电路设

计调试、文献资料检索、电路图绘制等多方面的能力和素质,同时也帮助我们熟练掌握

常用双音多频信号编解码器和语音芯片的工作原理和使用方法,具有很强的实践指导意

义和实用价值

[5]

-2-

黑龙江东方学院本科毕业论文(设计)

第2章 基本原理

2.1 自动电话的制式

要弄清双音频的来龙去脉,必须从电话的制式谈起。

最早的电话机是带有一个“手摇把”的,后来慢慢的开始出现了“磁石电话”、

“供电电话”、一直发展到现在人们广泛使用的“自动电话”。由于“磁石电话”、

“供电电话”早已淘汰,因此我们重点要谈的是自动电话的制式。

从自动电话的制式来分,可分为“脉冲制式”及“双音频制式”两种。所谓“脉

冲制式”,就是拨号的时候电话机发出的是一串一串的“无电流脉冲”。比如拨号码

“1”时,发出去的是一个“无电流脉冲”,也就是一个“断电脉冲”,拨号码“2”

时,发出去的是两个连续的“无电流脉冲”,拨号码“0”时,发出去的是十个连续的

“无电流脉冲”。如图2-1所示是脉冲电话机拨武汉区号721时线路上出现的脉冲图

[6]

线路电流 第一个无电流脉冲

第一串脉冲7个脉冲

开始拨号拨“0”

待机状态

拨“1”

“2

图2-1 脉冲电话机拨号的脉冲图谱

从图2-1中可以看出,待机状态下线路上是没有电流的,摘机后线路上才有电

流,拨号时,拨的号码是几,线路上就出现几个连续的、没有电流的脉冲间隙,比如

拨2的时候,就好像电话线被快速的断开了两次一样,因此老式的电话机还能用拍打

叉簧的办法拨号。老式带有“拨号盘”的电话机就是脉冲电话。

-3-

黑龙江东方学院本科毕业论文(设计)

脉冲电话容易出现拨错号的现象,当线路接触不良,刮风时线路接头时通断时,

就会出现错号。另外脉冲信号经过长途线路传送以后,由于线路电感和电容的影响,

脉冲波形会发生严重畸变,本来上升沿和下降沿都是很陡的波形,传到对方以后很可

能完全变样引起误判,因此这种电话也逐渐被淘汰

[7]

所谓“双音频制式”,就是拨电话的时候,拨每一个号码,发出去的都是由两个

不同频率的音频信号组合起来的双音频信号。如拨“0”的时候,发出去的两个音频信

号分别是941HZ和1336HZ,拨“9”的时候发出去的两个音频信号分别是952HZ和

1477HZ等等。我们用电话进行拨号时都能从听筒中听到一种按键的声音,这种声音

其实就是由两个不同的频率组合成的复合音。每个号码都是由两个音频信号组合起来

的,因此叫“双音频”。图2-2列出了每个号码与双音频频率的对应关系

[8]

我们可以将脉冲拨号与双音多频拨号的性能进行一个比较:

(1)脉冲信号在线路传输中容易产生波形畸变,可能产生错号。

(2)脉冲信号的幅度较容易产生线间干扰。

(3)脉冲拨号速度慢。

例如:拨打电话号码590850,它所用的时间为:

(5+9+10+8+5+10)×100+800×5=8700ms=8.7s

号码与频率对应关系

1

4

7

*

2

5

8

0

3

6

9

#

A

B

C

D

697

770

852

941

1209 1336 1477 1633

图2-2 号码与频率对应关系

如果电话号码越长,所用的时间越长,占用交换机的时间也长,这就使程控交换

机接续速度快的优点得不到发挥,从而影响了交换机的接通率。

双音多频电话机是两个单音频来代表一个数字,因此,采用音频信号传送的速度

-4-

黑龙江东方学院本科毕业论文(设计)

快,它发送的每位号码所用的时间都是相同的,它的发号速度主要取决于打电话者的

拨号速度。现在还以拨打电话号码590850为例,在双音多频方式下,单频持续时间为

120ms,位间隔为108ms,则拨打上述电话号码所需的时间为

120×6+108×5=1260ms=1.26s。

可见,脉冲拨号所用的时间是双音多频拨号的8.7s/1.26s=6.4倍

[9]

2.2 DTMF技术

由以上分析可知,采用双音多频信号,可以提高电路的抗干扰能力,减少交换机

的接续差错,从而提高交换机的接通率。同时我们也可以知道DTMF技术就是用两个

特定的单音频组合信号来代表数字信号以实现其功能的一种编码技术。两个单音频的

频率不同,代表的数字或实现的功能也不同。这种电话机中通常有16个按键,其中有

10个数字键0~9和6个功能键*、#、A、B、C、D。由于按照组合原理,一般应有8

种不同的单音频信号。因此可采用的频率也有8种,故称之为多频,又因它采用从8

种频率中任意抽出2种进行组合来进行编码,所以又称之为“8中取2”的编码技术

[10]

根据CCITT的建议,国际上采用的多种频率为687Hz、770Hz、852Hz、941Hz、

1209Hz、1336Hz、1477Hz和1633Hz等8种。用这8种频率可形成16种不同的组

合,从而代表16种不同的数字或功能键,具体组合如表2-1所示。

表2-1 键值频率组合表

697

770

852

941

1209

1

4

7

*

1336

2

5

8

0

1477

3

6

6

#

1633

A

B

C

D

DTMF信号由电话键盘使用相同幅度的两个不同的高频和低频来产生。拨号的时

候,需要将每一个号码都转换成一对双音频信号,这种转换叫做编码;解(译)码,

就是将接收到的双音频信号重新还原成数据信号

[11]

2.3 Goertzel算法

Goertzel算法执行离散傅立叶变换(Discrete Fourier Transform),这个算法较为精

简,而且每个频率只需要一个实数系数就可以决定值的振幅;但是,正确计算数值振

-5-

黑龙江东方学院本科毕业论文(设计)

幅和相位时需要复数系数,故需要较复杂的程序,借助只计算音调频率的振幅而忽略

相位的计算,我们可以简化DTMF信号的译码工作。此外,Goertzel算法只要获得任何

采样就可以立刻处理,不必获得全部采样之后才处理,可明显地提高速度。Goertzel算

法是DTMF信号检测的核心,它利用二极点的IIR滤波器计算离散傅立叶变换值,快速

有效的提取输入信号的频谱信息。

Goertzel算法利用了相位因子{W

N

k

}的周期性,允许我们将DFT的计算表示为线性

滤波运算,因W

N

-kN

=1,我们可以利用该因子乘上DFT,于是,可得

X(k)W

kN

N

m0

x(m)W

N1

km

N

k(Nm)

x(m)W

N

(2-1)

m0

N1

注意:式(2-1)为卷积形式,的确,如果我们定义序列y

k

(n)为

k(nm)

y

k

(n)

x(m)W

N

(2-2)

m0

N1

很清楚,y

k

(n)是长度为N的有限时宽输入序列x(n)与滤波器的卷积,并且滤波器的

冲激响应为:

h

k

(n)W

N

k(nm)

u(n)

(2-3)

当n=N时,该滤波器的输出为DFT在频率W

k

=2πk/N处的值,亦即

(2-4)

如同将(2-3)与式(2-4)相比较就可验证一样,冲激响应为h

k

(n)的滤波器,他的

系数函数可表示为

H

k

(z)

1

1W

N

k

z1

(2-5)

该滤波器在单位圆上的频率W

k

=2πk/N处有一个极点。因此,通过将输入的数据组

输入到N个单极点并行滤波器(谐振器)组就可计算整个N点DFT,其中,每一滤波器

在响应的DFT频率上有一个极点。

我们可以利用对应于式(2-5)给定的滤波器的差分方程来递推计算y

k

(n),而不是

按式(2-1)通过卷积来实现DFT的计算,因此我们有

y

k

n

W

N

y

k

n1

x

n

(2-6)

初始条件:y

k

(-1)=0

所期望的输出是X(k)=y

k

(N),其中k=0,1,…,N-1,为了完成这一计算,我们可以一

次计算并储存相位因子W

N

-k[12]

-6-

黑龙江东方学院本科毕业论文(设计)

通过将具有复共轭极点的谐波器结合成对,就可以避开式(2-6)所固有的复数乘法

和加法,这就产生了具有两个极点的的滤波器,其系统函数为

1W

N

k

z

1

H

k

(z)

12cos(2

k/N)z

1

z

2

该系统的直接型Ⅱ实现如图2-3所示:

(2-7)

x(n)

v

k

(n)

y

k

(n)

+ +

z

1

2

k

N

2cos

W

n

k

+

z

1

-1

图2-3 用于计算DFT的两极点谐振器的直接型Ⅱ实现

该系统可以用差分方程描述为

v

k

(n)2cos(2

k/N)v

k

(n1)v

k

(n2)x(n)

(2-8)

y

k

(n)v

k

(n)W

n

k

v

k

(n1)

(2-9)

初始条件为

v

k

(1)v

k

(2)0

对n=0,1,…,N,式(2-8)中的递推关系可迭代进行。但式(2-9)中的程序仅当n=N时计

算一次,每迭代需要一次实数乘法和两次加法。因此,对实输入序列x(n),该算法通

过N+1次实数乘法不仅得到X(k),而且由于对称性也得到X(N-k)的值。

当值M相对较小时,比如

Mlog

2

N

,Goertzel算法特别有吸引力,在其他情况

下,FFT算法更为有效

[13]

2.4 Matlab简介

MATLAB是由美国mathworks公司发布的主要面对科学计算、可视化以及交

互式程序设计的高科技计算环境。它将数值分析、矩阵计算、科学数据可视化以

-7-

黑龙江东方学院本科毕业论文(设计)

及非线性动态系统的建模和仿真等诸多强大功能集成在一个易于使用的视窗环境

中,为科学研究、工程设计以及必须进行有效数值计算的众多科学领域提供了一

种全面的解决方案,并在很大程度上摆脱了传统非交互式程序设计语言(如C、

Fortran)的编辑模式,代表了当今国际科学计算软件的先进水平

[14]

MATLAB和Mathematica、Maple并称为三大数学软件。它在数学类科技应

用软件中在数值计算方面首屈一指。MATLAB可以进行矩阵运算、绘制函数和数

据、实现算法、创建用户界面、连接其他编程语言的程序等,主要应用于工程计

算、控制设计、信号处理与通讯、图像处理、信号检测、金融建模设计与分析等

领域

[12]

MATLAB的基本数据单位是矩阵,它的指令表达式与数学、工程中常用的形式十

分相似,故用MATLAB来解算问题要比用C,FORTRAN等语言完成相同的事情简捷

得多,并且MATLAB也吸收了像Maple等软件的优点,使MATLAB成为一个强大的

数学软件。在新的版本中也加入了对C,FORTRAN,C++,JAVA的支持。可以直接

调用,用户也可以将自己编写的实用程序导入到MATLAB函数库中方便自己以后调

用,此外许多的MATLAB爱好者都编写了一些经典的程序,用户可以直接进行下载就

可以用

[15]

2.5 本章小结

音频分析利用时域分析、频域分析、失真分析等方法为手段,通过测量各类音频

参数来评价音频系统的性能。音频分析是一种综合性的分析,涉及到众多的测试仪

器,对于普通用户而言,需要根据其感兴趣的参数合理的选择测试仪器,很难建立完

整的音频测试分析系统。

-8-

黑龙江东方学院本科毕业论文(设计)

第3章 DTMF信号产生与检测

3.1 DTMF信号的产生

号码与频率对应关系

1

4

7

*

2

5

8

0

3

6

9

#

A

B

C

D

697

770

852

941

1209 1336 1477 1633

图3-1 号码与频率关系

根据CCITT建议,国际上采用697Hz、770Hz、852z、941Hz、1209Hz、1336Hz、

1477Hz、1633Hz 8个频率,并将其分成两个群,即低频群和高频群。从低频群和高频群

中任意抽出一个频率进行叠加组合,具有16种组合形式,让其代表数字和功率,如下图

电话机键盘的频率矩阵所列

[16]

当按下某个键时,所得到的按键信号是由相应两个频率的正弦信号相加而成。

x

k

为DTMF信号,产生方式为:

x

k

Asin

W

h

k

Bsin

W

l

k

(3-1)

式中

W

h

=

2f

h

/

f

sam

W

l

=2∏

f

l

/

f

sam

分别表示高频和低频频率,A、B分别为低群

和高频群样值的量化基线。电话信号的典型抽样频率为

f

sam

=8kHZ。CCITT对DTMF

信号规定的指标是,传送/接收率为每秒10个数字,即每个数字100ms。代表数字的

音频信号必须持续至少45ms,但不超过55ms。100ms内其他时间为静音(无信号),以

便区别连续的两个按键信号

[17]

-9-

黑龙江东方学院本科毕业论文(设计)

开始

生成行频正弦序列

生成列频正弦序列

行频正弦序列与列频正弦学序列叠加

D/A变换

滤波

信号发送

图3-2 DTMF信号产生流程图

3.2 DTMF信号的检测

3.2.1 DTMF信号检测方法

DTMF解码即是在输入信号中搜索出有效的行频和列频。计算数字信号的频谱可

以采用DFT及其快速算法FFT,而在实现DTMF解码时,采用Goertzel算法要比FFT更

快。通过FFT可以计算得到信号所有谱线,了解信号整个频域信息,而对于DTMF信号

只用关心其8个行频/列频及其二次谐波信息即可(二次谐波的信息用于将DTMF信号

与声音信号区别开)。此时Goertzel算法能更加快速的在输入信号中提取频谱信息

[18]

相对于DTMF编码过程,DTMF的解码过程复杂得多。DTMF的解码主要完成对有

效行列频率的检测以及对按键的判决。和以往模拟电路通过过零检测来检测有效频率

相比,采用DSP可以从频域直接分析有效频率的存在。在检测DTMF信号时,不但要检

测出DTMF的基波信息,而且还要考虑其二次谐波的信息。贝尔试验室所特意选定的这

8个频率,只在基波有较高的能量;而在相同的基波上有较高能量的话音信号在其二次谐

波上也叠加有较高的能量。因此检测二次谐波的作用就是区别DTMF起后发送,解码

-10-

黑龙江东方学院本科毕业论文(设计)

时DSP则采用改进的Goertzel算法,从频域搜索两个正弦波的存在。因此检测二次谐波

的作用就是区别DTMF信号和话音信号

[19]

DTMF信号的解码是基于Goertzel算法。我们不需要计算全部频域信息,只需要计

算需要的频域的信息,而FFT需要计算全部的频域信息。理论上证明当计算的点数小于

log

2

N时,Goertzel算法比FFT更有效

[20]

在输入信号中检测DTMF信号,并将其转换为实际的数字,这一解码过程本质是

连续的过程,需要在输入的数据信号流中连续地搜索DTMF信号频谱的存在。整个检

测过程分

两步:

(1)采用Goertzel算法在输入信号中提取频谱信息,计算出八个基频和八个二次

谐波幅度的平方值。

(2)根据这些频率幅度平方值与所确定的各个门限值相比较,确定输入信号中是

否是有DTMF信号并映射出双音多频信号的数字信息作检测结果的有效性检查

[21]

-11-

黑龙江东方学院本科毕业论文(设计)

开始

采集信号

读入采样点数N,基频对应点K

调用Goertzel计算信号DFT模,画幅度谱

N

幅度谱峰是否大于检

测门限

Y

输出相应行号与列号

输出行列号对应号码

结束

图3-3 DTMF信号识别流程图

3.2.2 DTMF信号有效性的检测

得到了DTMF信号的基波以及二次谐波的频谱平方信息后,需要通过一系列检测

才能确定信号的有效性:

(1) DTMF信号的强度是否足够大,行列频率分量平方幅度和是否高于规定的门

限值。

(2) 如果DTMF信号存在,比较行列频率的最大频率分量差值,因为电话线具有

低通特性,列频比行频衰减得要厉害。因此,要设置一门限值。

(3) 分别在行列频率组比较频谱分量,最强的谱线至少要比其他音频信号高一

个门限值。

(4) 二次谐波分量是否小于某个值。

-12-

黑龙江东方学院本科毕业论文(设计)

(5) 判断DTMF信号是否包含稳定的数字信息,只有数字信息被连续检测到两

次,才认为是数字信息是稳定的。

最后要检测数字信息之后是否有停顿状态,只有这样将当前的数字作为有效

[22]

3.3 本章小结

在输入信号中检测DTMF信号,并将其转换为实际的数字,这一解码过程本质是

连续的过程,需要在输入的数据信号流中连续地搜索DTMF信号频谱的存在。整个检

测过程分两步:首先采用Goertzel算法在输入信号中提取频谱信息;接着作检测结果

的有效性检查。

-13-

黑龙江东方学院本科毕业论文(设计)

第4章 Matlab仿真

4.1 设计程序(见附录)

4.2 Matlab仿真

DTMF信号的产生比较简单,可直接利用两行频、列频的正弦函数的叠加实现,

DTMF信号(电话拨号“5”为例)波形如图4-1所示:

图4-1 电话号码“5”的时域波形图

电话号码“5”的幅度谱如下图所示:

图4-2 电话号码“5”的幅度谱

我采用的DTMF信号检测的原理是分析信号的频谱特性来分辨不同信息。整个检

测过程分两步:首先采用Goertzel算法在输入信号中提取频谱信息;接着分析频谱信

息,提取输入的DTMF信号,计算数字信号的频谱可以采用DFT及其快速算法

FFT,而在实现DTMF解码时,由于计算量的限制必须采用更高效的算法。由于

DTMF信号只用关心其8个行频/列频的频谱信息,这为设计更优的算法提供了思路。

经过前面的介绍Goertzel算法达到了我们的设计要求,本毕业设计采用Goertzel算法

对双音多频信号进行检测,如图4-3所示,电话号码“5”的Goertzel算法检测频谱图。

-14-

黑龙江东方学院本科毕业论文(设计)

图4-3 电话号码“5”的检测频谱图

说明:图4-1,4-2,4-3是在信噪比SNR=10,采样点数N=205的情况下得到的。

当采样点N=205时,误码率Pe与信噪比SNR的关系图如下图所示:

图4-4 Pe-SNR关系图

由图4-4可知,当采样点数一定时,信噪比越大误码率越低。

当SNR=10时误码率Pe与采样点数N的关系如下图所示:

-15-

黑龙江东方学院本科毕业论文(设计)

图4-5 Pe-N关系图

由图4-5可知,当信噪比一定时,采样点数越大误码率越低。

Pe-SNR-N关系的3D图如图4-6所示:

图4-6 Pe-SNR-N关系图

-16-

黑龙江东方学院本科毕业论文(设计)

整个仿真过程的gui界面如图4-7所示:

图4-7 仿真gui界面

4.3 本章小结

采用DTMF信号检测的原理是分析信号的频谱特性来分辨不同信息。整个检测过

程分两步:首先采用Goertzel算法在输入信号中提取频谱信息;接着分析频谱信息,

提取输入的DTMF信号,计算数字信号的频谱可以采用DFT及其快速算法FFT,而

在实现DTMF解码时,由于计算量的限制必须采用更高效的算法。

-17-

黑龙江东方学院本科毕业论文(设计)

结 论

双音多频DTMF信号不仅用于多数国家的电话网络中,还广泛应用于传输十进制

数据的其他通信系统如电子邮件及银行等,本文就DTMF信号检测中的算法原理及主

要参数选择进行了理论分析,并给出了基于MATLAB的DTMF信号处理系统仿真实

例。基于Goertzel算法,可以在PC机中通过MATLAB语言实现DTMF的编解码。试

验结果表明基于MATLAB的DTMF编解码具有速度快、精度高、稳定性好以及便于

灵活应用等特点.而利用MATLAB语言,可以较好地、快速地进行算法的仿真,对

系统的快速开发起到了推动作用。通过此次设计,我们对DTMF的基础知识有了个比

较深刻的了解,掌握了DTMF的信号产生及信号检验的原理及方法,并熟悉了用

Matlab语言对DTMF的编程的方法,我们定会总结设计方法,掌握理论知识,

汲取经验教训,为进一步掌握DSP的设计,Matlab的使用打下基础。

-18-

黑龙江东方学院本科毕业论文(设计)

参考文献

[1] 周良权,方向乔.《数字电子技术基础》.北京:高等教育出版社,2002.12.

[2] 吕国泰,吴项.《电子技术》.北京:高等教育出版社,2001.5.

[3] 陈明义.《电子技术课程设计使用教程》.中南大学出版社,2002.6.(1).

[4] 《程控交换实验指导书》.钟山学院内部资料.

[5] 刘爱霞.《语音编程.远程控制试验板》.中国.深圳.51测试网.

[6] 奥法尼德斯.《信号处理导论》.清华大学出版社,1999.1.

[7] 《信号与系统分析及MATLAB实现》.电子工业出版社,梁红等.

[8] 陈怀琛.MATLAB及其在理工课程中的应用指南[M].西安电子科技大学出

社,2000.

[9] 奥本海姆.《SIGNALS&SYSTEMS信号与系统》.清华大学出版社,1999.1.

[10] 董爱民.DTMF技术及检测算法研究.计算机与网络.2007.23.

[11] 《长春理工大学学报》.第三卷,第一期.

[12] 丁玉美,高西全.《数字信号处理》(第二版).西安电子科技大学出版社,2001.1.

[13] 戴悟僧.数字信号处理导论[M].上海科学技求出版社,2000.8.

[14] 陈怀琛.MATLAB及其在理工课程中的应用指南[M].西安电子科技大学出版社,2000.

[15] 葛建新.《DTMF(双音多频)技术浅析》.河北省电子信息产品监督检验院.

[16] 《DTMF信号的产生与解码算法研究》.信息技术2008年第11期.

[17] 金鑫春,汪一鸣.《Goertzel算法下DTMF信号检测及参数优化》.

[18] Stan M R,Burleson W -invert coding for low-power I/ Transactions on VLSI

.3no.l.1995.49-58.

[19] Weste N,Eshraghian ples of CMOS VLSI De 2sign.A Systems

g,MA:Addison–Wesley Publishing Company,1988.

[20] Mehta H,Owens R M,Irwin Issues in GrayCode -VLSI-96,pp.178-

180,Amea,IA,March 1996.

[21] 魏克新,王云亮,陈志敏.MATLAB语言与自动控制系统[M].北京:机械工业出版社,1998.

[22] 刘志俭.Matlab应用程序接口用户指南[M].北京:科学出版社,2000.

-19-

黑龙江东方学院本科毕业论文(设计)

附 录

function varargout = DTMF(varargin)

% DTMF M-file for

% DTMF, by itself, creates a new DTMF or raises the existing

% singleton*.

% H = DTMF returns the handle to a new DTMF or the handle to

% the existing singleton*.

% DTMF('CALLBACK',hObject,eventData,handles,...) calls the local

% function named CALLBACK in DTMF.M with the given input arguments.

% DTMF('Property','Value',...) creates a new DTMF or raises the

% existing singleton*. Starting from the left, property value pairs are

% applied to the GUI before DTMF_OpeningFcn gets called. An

% unrecognized property name or invalid value makes property application

% stop. All inputs are passed to DTMF_OpeningFcn via varargin.

% *See GUI Options on GUIDE's Tools menu. Choose "GUI allows only one

% instance to run (singleton)".

% See also: GUIDE, GUIDATA, GUIHANDLES

% Edit the above text to modify the response to help DTMF

% Begin initialization code - DO NOT EDIT

gui_Singleton = 1;

gui_State = struct('gui_Name', mfilename, ...

'gui_Singleton', gui_Singleton, ...

'gui_OpeningFcn', @DTMF_OpeningFcn, ...

'gui_OutputFcn', @DTMF_OutputFcn, ...

'gui_LayoutFcn', [] , ...

'gui_Callback', []);

if nargin && ischar(varargin{1})

gui__Callback = str2func(varargin{1});

end

if nargout

[varargout{1:nargout}] = gui_mainfcn(gui_State, varargin{:});

else

-20-

黑龙江东方学院本科毕业论文(设计)

gui_mainfcn(gui_State, varargin{:});

end

% End initialization code - DO NOT EDIT

% --- Executes just before DTMF is made visible.

function DTMF_OpeningFcn(hObject, eventdata, handles, varargin)

% This function has no output args, see OutputFcn.

% hObject handle to figure

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

% varargin command line arguments to DTMF (see VARARGIN)

% Choose default command line output for DTMF

= hObject;

% Update handles structure

guidata(hObject, handles);

% UIWAIT makes DTMF wait for user response (see UIRESUME)

% uiwait(1);

% --- Outputs from this function are returned to the command line.

function varargout = DTMF_OutputFcn(hObject, eventdata, handles)

% varargout cell array for returning output args (see VARARGOUT);

% hObject handle to figure

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

set(_SNR,'string',);

set(_nGoertzel,'string',zel);

% Get default command line output from handles structure

varargout{1} = ;

% --- Executes on slider movement.

function slider_SNR_Callback(hObject, eventdata, handles)

% hObject handle to slider_SNR (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

-21-

黑龙江东方学院本科毕业论文(设计)

% Hints: get(hObject,'Value') returns position of slider

%get(hObject,'Min') and get(hObject,'Max') to determine range of slider

=get(hObject,'Value'); %returns position of slider

guidata(hObject,handles);

set(_SNR,'string',);

% --- Executes during object creation, after setting all properties.

function slider_SNR_CreateFcn(hObject, eventdata, handles)

% hObject handle to slider_SNR (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles empty - handles not created until after all CreateFcns called

=10;

guidata(hObject,handles);

% Hint: slider controls usually have a light gray background.

if isequal(get(hObject,'BackgroundColor'), get(0,'defaultUicontrolBackgroundColor'))

set(hObject,'BackgroundColor',[.9 .9 .9]);

end

% --- Executes during object creation, after setting all properties.

function text_SendNumber_CreateFcn(hObject, eventdata, handles)

% hObject handle to text_SendNumber (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles empty - handles not created until after all CreateFcns called

% --- Executes on button press in key1.

function key1_Callback(hObject, eventdata, handles)

% hObject handle to key1 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='1';PressKeyDown(hObject,handles);

% --- Executes on button press in key2.

function key2_Callback(hObject, eventdata, handles)

% hObject handle to key2 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

-22-

黑龙江东方学院本科毕业论文(设计)

='2';PressKeyDown(hObject,handles);

% --- Executes on button press in key3.

function key3_Callback(hObject, eventdata, handles)

% hObject handle to key3 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='3';PressKeyDown(hObject,handles);

% --- Executes on button press in keyA.

function keyA_Callback(hObject, eventdata, handles)

% hObject handle to keyA (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='A';PressKeyDown(hObject,handles);

% --- Executes on button press in key4.

function key4_Callback(hObject, eventdata, handles)

% hObject handle to key4 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='4';PressKeyDown(hObject,handles);

% --- Executes on button press in key5.

function key5_Callback(hObject, eventdata, handles)

% hObject handle to key5 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='5';PressKeyDown(hObject,handles);

% --- Executes on button press in key6.

function key6_Callback(hObject, eventdata, handles)

% hObject handle to key6 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='6';PressKeyDown(hObject,handles);

-23-

黑龙江东方学院本科毕业论文(设计)

% --- Executes on button press in keyB.

function keyB_Callback(hObject, eventdata, handles)

% hObject handle to keyB (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='B';PressKeyDown(hObject,handles);

% --- Executes on button press in keyC.

function keyC_Callback(hObject, eventdata, handles)

% hObject handle to keyC (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='C';PressKeyDown(hObject,handles);

% --- Executes on button press in key9.

function key9_Callback(hObject, eventdata, handles)

% hObject handle to key9 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='9';PressKeyDown(hObject,handles);

% --- Executes on button press in key8.

function key8_Callback(hObject, eventdata, handles)

% hObject handle to key8 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='8';PressKeyDown(hObject,handles);

% --- Executes on button press in key7.

function key7_Callback(hObject, eventdata, handles)

% hObject handle to key7 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='7';PressKeyDown(hObject,handles);

% --- Executes on button press in keystar.

function keystar_Callback(hObject, eventdata, handles)

-24-

黑龙江东方学院本科毕业论文(设计)

% hObject handle to keystar (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='*';PressKeyDown(hObject,handles);

% --- Executes on button press in key0.

function key0_Callback(hObject, eventdata, handles)

% hObject handle to key0 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='0';PressKeyDown(hObject,handles);

% --- Executes on button press in keysharp.

function keysharp_Callback(hObject, eventdata, handles)

% hObject handle to keysharp (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='#';PressKeyDown(hObject,handles);

% --- Executes on button press in keyD.

function keyD_Callback(hObject, eventdata, handles)

% hObject handle to keyD (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='D';PressKeyDown(hObject,handles);

%PressKeyDown.m

function PressKeyDown(hObject,handles)

%²úÉúÎÞÔëÐźÅ

=DTMF_Tone_Generartor();

%¼ÓÔë

one=Noise_Adder(,);

%·ÅÒô

sound(one,8000);

%ÏÔʾ·¢Ë͵Ä×Ö·û

set(_SendNumber,'string',);

-25-

黑龙江东方学院本科毕业论文(设计)

%%

%¼ÓÔëºóʱÓò²¨ÐÎ

set(gcf,'CurrentAxes',_NoiseTone);

plot(1:800,one);grid;

ylabel('ʱÓò²¨ÐÎ');

%%

%ƵÓò²¨ÐÎ

spectrum=fft(one);

spectrum=fftshift(spectrum);%¼ÆËãÐźŵÄƵÆ×

N=length(spectrum);

nStep=(2*pi)/(N-1);

w=-pi:nStep:pi;

set(gcf,'CurrentAxes',_Spectrum);

plot(w/(2*pi)*8000,abs(spectrum));grid;

ylabel('·ù¶ÈÆ×');

%%

%Goertzel½âÂë

[ected spectrumGeortzel ertzel]=

DTMF_Goertzel_Detector(one,zel);

%ÏÔʾ¼ì²âµ½µÄ×Ö·û

set(_DetectNumber,'string',ected);

%»-Goertzel8µãµÄƵÆ×ͼ

set(gcf,'CurrentAxes',_Goertzel);

stem(1:8,spectrumGeortzel);grid;

ylabel('GoertzelƵÆ×');

%Goertzel¼ì²âËã·¨ËùÓÃʱ¼ä

set(_timeGoertzel,'string',ertzel);

guidata(hObject,handles);

% --- Executes on button press in button_Analyse_Pe_SNR.

function button_Analyse_Pe_SNR_Callback(hObject, eventdata, handles)

% hObject handle to button_Analyse_Pe_SNR (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

-26-

黑龙江东方学院本科毕业论文(设计)

% handles structure with handles and user data (see GUIDATA)

Analyser_Pe_SNR(,,zel);

% --- Executes on slider movement.

function slider_nGoertzel_Callback(hObject, eventdata, handles)

% hObject handle to slider_nGoertzel (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

% Hints: get(hObject,'Value') returns position of slider

% get(hObject,'Min') and get(hObject,'Max') to determine range of slider

zel=fix(get(hObject,'Value')); %returns position of slider

if zel<2

zel=2;

end

guidata(hObject,handles);

set(_nGoertzel,'string',zel);

% --- Executes during object creation, after setting all properties.

function slider_nGoertzel_CreateFcn(hObject, eventdata, handles)

% hObject handle to slider_nGoertzel (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles empty - handles not created until after all CreateFcns called

zel=205;

guidata(hObject,handles);

% Hint: slider controls usually have a light gray background.

if isequal(get(hObject,'BackgroundColor'), get(0,'defaultUicontrolBackgroundColor'))

set(hObject,'BackgroundColor',[.9 .9 .9]);

end

% --- Executes on button press in button_Analyse_Pe_N.

function button_Analyse_Pe_N_Callback(hObject, eventdata, handles)

% hObject handle to button_Analyse_Pe_N (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

Analyser_Pe_N(,,);

-27-

黑龙江东方学院本科毕业论文(设计)

% --- Executes on button press in button_Analyser_3D.

function button_Analyser_3D_Callback(hObject, eventdata, handles)

% hObject handle to button_Analyser_3D (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

Analyser_3D(,);

-28-

黑龙江东方学院本科毕业论文(设计)

致 谢

感谢我的母校。是它为我提供了良好的学习环境和优异的师资力量。先进的教学

设备;兢兢业业的老师;辛勤学习的学生;正是这样的良好环境才造就了我院一届届

优秀的毕业生,为社会为国家提供了一批批优秀的人才。

感谢我的导师XX老师。是他们以严谨的作风,认真负责的工作态度对我的论文

写作进行指导。在写开题报告的时间里老师不辞辛苦的讲解才使得我的设计顺利的进

行。从设计的选题到资料的搜集直至最后设计的修改的整个过程中,花费了夏宇老师

很多的宝贵时间和精力,在此向导师表示衷心地感谢!导师严谨的治学态度,开拓进

取的精神和高度的责任心都将使学生受益终生,毕业设计中我们得到了许多方面的帮

助和支持。

感谢教过我的各科讲师。是他们一步步把我带进知识的殿堂,一点点教会我各种

文化,更重要的是教会我如何处事,如何为人。

感谢我的父母,是他们含辛茹苦的把我养育成人,也是他们不计回报的给了我学

习的机会,使我才有了这样精彩的人生。

感谢我的同学、朋友,是他们为我营造了一个温暖的“大家庭”,让我感受到友情

的真谛与力量,也在不断的进步。

在未来的道路上,我一定会更加努力,不辜负学校、老师以及父母的期望,兢兢

业业做事,堂堂正正做人,为社会,为他人,更是为自己充分发挥每一份力量。

-29-

2024年5月2日发(作者:长义)

XXXXXXX大学

题目:双音频(

业 论 文 (设 计)

DTMF)信号的产生与检测

学生姓名

学 号

专 业 电子信息工程

班 级 2008级1班

指导教师

学 部 计算机科学与电气工程

答辩日期 2012年5月19日

黑龙江东方学院本科生毕业论文(设计)任务书

姓名

学号

专业班级 电子信息工程08级1班

毕业论文(设计)题目:双音频(DTMF)信号的产生与检测

毕业论文(设计)的立题依据

双音多频DTMF(Dual Tone Multi-Frequency)信令在全世界范围内得到广泛应用。

DTMF作为实现电话号码快速可靠传输的一种技术,它具有很强的抗干扰能力和较高的传

输速度,因此,可广泛用于电话通信系统中。

主要内容及要求

1、利用DTMF信号产生的原理合成数字1,其合成公式是

x

1

t

sin

2

697t

sin

2

1209t

分析其时域波形和频谱;

2、生成各个按键信号;

3、利用fft分析0~9十个数字拨号信息的频谱,观察频谱图中的峰值点的幅值以及它们出

现的位置。根据谱峰的幅值和位置,识别各DTMF信号所对应对应的数字;

4、编写Goertzel算法的程序,识别各DTMF信号所对应对应的数字;

进度安排

12月12日

12月13日~12月29日

12月30 日~1 月17日

1 月18日~2 月26日

2 月27日~3 月27日

3 月28日~4 月8 日

4 月9 日~4 月17日

4 月18日~4 月22日

4 月23日~5 月3 日

5 月4 日~5 月9 日

5 月10日~5 月18日

5 月19日

选题

接受指导老师的指导

拟定论文大纲

搜集、查阅、整理相关资料

初稿形成

初稿审定

第一次修改

第一次审定

第二次修改

定稿

论文评阅小组评审论文(设计)

毕业论文(设计)答辩

学生签字:

指导教师签字:

年 月 日

黑龙江东方学院本科毕业论文(设计)

双音频(DTMF)信号的产生与检测

摘 要

双音多频DTMF(Dual Tone Multi-Frequency)信令在全世界范围内得到广泛应

用,DTMF信令的产生与检测集成到含有数字信号处理器(DSP)的系统中,是一项

较有价值的工程应用。DTMF作为实现电话号码快速可靠传输的一种技术,它具有很

强的抗干扰能力和较高的传输速度,因此,可广泛用于电话通信系统中。但绝大部分

是用作电话的音频拨号,另外,它也可以在数据通信系统中广泛地用来实现各种数据

流和语音等信息的远程传输,研究其在MATLAB下的仿真实现有助于其具体系统的

优化设计。本文给出一种实现方案,主要阐述了DTMF的原理及如何在Matlab上产

生DTMF信号,并对用Goertzel算法提取的频谱进行分析,然后,得到用Goertzel算

法在白噪声的环境下对输入的DTMF信号提取频谱信息,最后,根据提取的频谱信息

对输入信号进行检测解码。

关键词

双音多频DTMF;Goertzel算法;Matlab

-I-

黑龙江东方学院本科毕业论文(设计)

Dual Tone Multi-frequency (DTMF) Signal Generation

and Detection

Abstract

DTMF (Dual Tone Multi-Frequency) signaling in the widely used worldwide, signaling

the DTMF generation and detection integrated with digital signal processor (DSP) system, is

a more value engineering. DTMF telephone number as to achieve a fast and reliable

transmission technology, it has a strong anti-interference ability and high transmission speed,

it can be widely used for telephone communication system. But the vast majority of

telephone tone dialing is used. In addition, it can also be in the data communication system

widely used to achieve a variety of data streams and remote transmission of voice and other

information. Under study in the MATLAB Simulation helps optimize the design of their

specific paper presents a realization of the program, mainly on the principle of

DTMF and how to generate DTMF signals in Matlab, and extracted with Goertzel algorithm

to analyze the spectrum, and then, get with the Goertzel algorithm in the context of white

noise on the input of the DTMF spectrum information signal extraction, and finally,

according to information extracted from the input signal spectrum to detect decoding.

Keywords:

Dual tone multi-frequency;Goertzel algorithm;Matlab

-II-

摘 要 ....................................................................................................................................... I

Abstract ........................................................................................................................................ II

第1章 绪 论 .......................................................................................................................... 1

1.1 引言 .................................................................................................................................. 1

1.2 课题意义 .......................................................................................................................... 1

第2章 基本原理 .......................................................................................................................... 3

2.1 自动电话的制式 .............................................................................................................. 3

2.2 DTMF技术 ........................................................................................................................ 5

2.3 Goertzel算法 ...................................................................................................................... 5

2.4 Matlab简介 ........................................................................................................................ 7

2.5 本章小结 .......................................................................................................................... 8

第3章 DTMF信号产生与检测 ................................................................................................... 9

3.1 DTMF信号的产生 ............................................................................................................ 9

3.2 DTMF信号的检测 .......................................................................................................... 10

3.2.1 DTMF信号检测方法 ............................................................................................... 10

3.2.2 DTMF信号有效性的检测 ....................................................................................... 12

3.3 本章小结 ........................................................................................................................ 13

第4章 Matlab仿真 .................................................................................................................... 14

4.1 设计程序(见附录) .................................................................................................... 14

4.2 Matlab仿真 ...................................................................................................................... 14

4.3 本章小结 ........................................................................................................................ 17

结 论 .................................................................................................................................... 18

参考文献 .................................................................................................................................... 19

附 录 .................................................................................................................................... 20

致 谢 .................................................................................................................................... 29

黑龙江东方学院本科毕业论文(设计)

双音频(DTMF)信号的产生与检测

第1章 绪 论

1.1 引言

电话中的双音多频信号(DTMF)有两种用途:一是用于双音多频信号的拨号,

去控制交换机接通被叫的用户话机;二是利用双音多频信号遥控电话机各种动作,如

播放留言、语音信箱等,并可以通过附加一些电路来是实现遥控家电设备的开启关闭

等智能功能。前者解决双音多频信号的发送和编码,后者是双音多频信号的接收和解

码。这些东西都离不开DTMF信号的正确检测。目前,大多数的DTMF信号的检测均采

用专用的发送、接收芯片,这种解码的原理都依赖于计算输入信号的过零率。但这种

方法有很大的局限性,无法检测多路DTMF信号,当混有语音和噪声时,专用芯片检

测往往出现误差,如果音频信号频率改变应用于别的系统时,专用的芯片就发挥不了

作用。所以,用硬件实现DTMF信号的检测并不是一种很好的选择

[1]

信息化已经成为社会发展的大趋势,信息化是以数字化为背景的,而DSP技术则

是数字化最重要的基本技术之一。在过去的短短的二十来年里,DSP处理器的性能得

到很大改善,软件和开发工具也得到相应的发展,价格却大幅度地下降,从而得到越来

越广泛的应用。通信领域(移动通信的交换设备、基站和手机,网络的路由和交换设

备,智能天线,软件无线电,IP电话等),雷达和声纳系统,巡航导弹、灵巧炸弹及各

种武器系统,自动测试系统,医疗诊断设备(CT、核磁共振、B超等),计算机及其外

设,消费类电子设备(VCD、DVD、HDTV、机顶盒、MP3、家庭影院系统、数字照相

机和摄象机等),机器人及各种自动控制系统,等等,应用范围不胜枚举

[2]

1.2 课题意义

DTMF(Dual Tone Multi Frequency)中文译为双音多频信号,最初由美国AT&T贝尔

公司实验室研制,用于音频电话网络中的拨号信号。一方面这种信号有非在常高的拨号

速度,另一方面它便于自动检测识别及电话业务的扩展,所以很快代替了原有的脉冲计

数方式的拨号形式在这里不得不提一下电话交换机的发展历史。自1876年美国贝尔发

明电话以来,电话交换技术发展主要经历了三个阶段:人工交换、机电交换、电子交

换。早在1878年就出现了人工供电制交换机,它借助话务员进行话务接续。15年后步进

-1-

黑龙江东方学院本科毕业论文(设计)

制的交换机问世,这种交换机属于“直接控制”方式,用户通过话机拨号脉冲直接控制

步进接续器做升降和旋转动作。从而自动完成用户间的接续。这种交换机虽然实现了

自动接续,但存在着速度慢、效率低、杂音大与机械磨损严重等特点。直到1938年发明

了纵横制交换机由直接控制过渡到间接控制方式,随后又出现了电子交换机及程控交换

机等。用户的拨号脉冲不再直接控制接线器动作,而先由记发器接收、存储,然后通过

标志器驱动接线器,以完成用户间接续

[3]

DTMF双音多频拨号和解码在通信系统及其它方面有着广泛的应用。DTMF信号

是便于标志器记取的是标识信号,所以可以不采用不稳定的脉冲计数方式,逐步发展、

到数字号码标识,所以快速,稳定灵活的DTMF音频拨号方式取代了脉冲拨号方式。电

子交换机程控交换机。话网中常用的信令,无论是家用电话、移动电话还是程控交换

机,多采用DTMF信号发送接收号码

[4]

语音芯片的应用前景也十分广阔,目前语音芯片已应用于微型固体录音机、通

讯、电话、车船、飞机黑匣子、有声电子信函、语音信箱、高级玩具等。此外,还可

以利用语音芯片开发出“会说话”的电压表、电流表等语音型智能仪器仪表以及“会

说话的电子称”、“出租车自动语音报价器”、“多路语音报警系统”等新颖电子电

器产品。

该项设计可促进我们学习开发电子、通信产品的技术,培养和锻炼我们电子电路设

计调试、文献资料检索、电路图绘制等多方面的能力和素质,同时也帮助我们熟练掌握

常用双音多频信号编解码器和语音芯片的工作原理和使用方法,具有很强的实践指导意

义和实用价值

[5]

-2-

黑龙江东方学院本科毕业论文(设计)

第2章 基本原理

2.1 自动电话的制式

要弄清双音频的来龙去脉,必须从电话的制式谈起。

最早的电话机是带有一个“手摇把”的,后来慢慢的开始出现了“磁石电话”、

“供电电话”、一直发展到现在人们广泛使用的“自动电话”。由于“磁石电话”、

“供电电话”早已淘汰,因此我们重点要谈的是自动电话的制式。

从自动电话的制式来分,可分为“脉冲制式”及“双音频制式”两种。所谓“脉

冲制式”,就是拨号的时候电话机发出的是一串一串的“无电流脉冲”。比如拨号码

“1”时,发出去的是一个“无电流脉冲”,也就是一个“断电脉冲”,拨号码“2”

时,发出去的是两个连续的“无电流脉冲”,拨号码“0”时,发出去的是十个连续的

“无电流脉冲”。如图2-1所示是脉冲电话机拨武汉区号721时线路上出现的脉冲图

[6]

线路电流 第一个无电流脉冲

第一串脉冲7个脉冲

开始拨号拨“0”

待机状态

拨“1”

“2

图2-1 脉冲电话机拨号的脉冲图谱

从图2-1中可以看出,待机状态下线路上是没有电流的,摘机后线路上才有电

流,拨号时,拨的号码是几,线路上就出现几个连续的、没有电流的脉冲间隙,比如

拨2的时候,就好像电话线被快速的断开了两次一样,因此老式的电话机还能用拍打

叉簧的办法拨号。老式带有“拨号盘”的电话机就是脉冲电话。

-3-

黑龙江东方学院本科毕业论文(设计)

脉冲电话容易出现拨错号的现象,当线路接触不良,刮风时线路接头时通断时,

就会出现错号。另外脉冲信号经过长途线路传送以后,由于线路电感和电容的影响,

脉冲波形会发生严重畸变,本来上升沿和下降沿都是很陡的波形,传到对方以后很可

能完全变样引起误判,因此这种电话也逐渐被淘汰

[7]

所谓“双音频制式”,就是拨电话的时候,拨每一个号码,发出去的都是由两个

不同频率的音频信号组合起来的双音频信号。如拨“0”的时候,发出去的两个音频信

号分别是941HZ和1336HZ,拨“9”的时候发出去的两个音频信号分别是952HZ和

1477HZ等等。我们用电话进行拨号时都能从听筒中听到一种按键的声音,这种声音

其实就是由两个不同的频率组合成的复合音。每个号码都是由两个音频信号组合起来

的,因此叫“双音频”。图2-2列出了每个号码与双音频频率的对应关系

[8]

我们可以将脉冲拨号与双音多频拨号的性能进行一个比较:

(1)脉冲信号在线路传输中容易产生波形畸变,可能产生错号。

(2)脉冲信号的幅度较容易产生线间干扰。

(3)脉冲拨号速度慢。

例如:拨打电话号码590850,它所用的时间为:

(5+9+10+8+5+10)×100+800×5=8700ms=8.7s

号码与频率对应关系

1

4

7

*

2

5

8

0

3

6

9

#

A

B

C

D

697

770

852

941

1209 1336 1477 1633

图2-2 号码与频率对应关系

如果电话号码越长,所用的时间越长,占用交换机的时间也长,这就使程控交换

机接续速度快的优点得不到发挥,从而影响了交换机的接通率。

双音多频电话机是两个单音频来代表一个数字,因此,采用音频信号传送的速度

-4-

黑龙江东方学院本科毕业论文(设计)

快,它发送的每位号码所用的时间都是相同的,它的发号速度主要取决于打电话者的

拨号速度。现在还以拨打电话号码590850为例,在双音多频方式下,单频持续时间为

120ms,位间隔为108ms,则拨打上述电话号码所需的时间为

120×6+108×5=1260ms=1.26s。

可见,脉冲拨号所用的时间是双音多频拨号的8.7s/1.26s=6.4倍

[9]

2.2 DTMF技术

由以上分析可知,采用双音多频信号,可以提高电路的抗干扰能力,减少交换机

的接续差错,从而提高交换机的接通率。同时我们也可以知道DTMF技术就是用两个

特定的单音频组合信号来代表数字信号以实现其功能的一种编码技术。两个单音频的

频率不同,代表的数字或实现的功能也不同。这种电话机中通常有16个按键,其中有

10个数字键0~9和6个功能键*、#、A、B、C、D。由于按照组合原理,一般应有8

种不同的单音频信号。因此可采用的频率也有8种,故称之为多频,又因它采用从8

种频率中任意抽出2种进行组合来进行编码,所以又称之为“8中取2”的编码技术

[10]

根据CCITT的建议,国际上采用的多种频率为687Hz、770Hz、852Hz、941Hz、

1209Hz、1336Hz、1477Hz和1633Hz等8种。用这8种频率可形成16种不同的组

合,从而代表16种不同的数字或功能键,具体组合如表2-1所示。

表2-1 键值频率组合表

697

770

852

941

1209

1

4

7

*

1336

2

5

8

0

1477

3

6

6

#

1633

A

B

C

D

DTMF信号由电话键盘使用相同幅度的两个不同的高频和低频来产生。拨号的时

候,需要将每一个号码都转换成一对双音频信号,这种转换叫做编码;解(译)码,

就是将接收到的双音频信号重新还原成数据信号

[11]

2.3 Goertzel算法

Goertzel算法执行离散傅立叶变换(Discrete Fourier Transform),这个算法较为精

简,而且每个频率只需要一个实数系数就可以决定值的振幅;但是,正确计算数值振

-5-

黑龙江东方学院本科毕业论文(设计)

幅和相位时需要复数系数,故需要较复杂的程序,借助只计算音调频率的振幅而忽略

相位的计算,我们可以简化DTMF信号的译码工作。此外,Goertzel算法只要获得任何

采样就可以立刻处理,不必获得全部采样之后才处理,可明显地提高速度。Goertzel算

法是DTMF信号检测的核心,它利用二极点的IIR滤波器计算离散傅立叶变换值,快速

有效的提取输入信号的频谱信息。

Goertzel算法利用了相位因子{W

N

k

}的周期性,允许我们将DFT的计算表示为线性

滤波运算,因W

N

-kN

=1,我们可以利用该因子乘上DFT,于是,可得

X(k)W

kN

N

m0

x(m)W

N1

km

N

k(Nm)

x(m)W

N

(2-1)

m0

N1

注意:式(2-1)为卷积形式,的确,如果我们定义序列y

k

(n)为

k(nm)

y

k

(n)

x(m)W

N

(2-2)

m0

N1

很清楚,y

k

(n)是长度为N的有限时宽输入序列x(n)与滤波器的卷积,并且滤波器的

冲激响应为:

h

k

(n)W

N

k(nm)

u(n)

(2-3)

当n=N时,该滤波器的输出为DFT在频率W

k

=2πk/N处的值,亦即

(2-4)

如同将(2-3)与式(2-4)相比较就可验证一样,冲激响应为h

k

(n)的滤波器,他的

系数函数可表示为

H

k

(z)

1

1W

N

k

z1

(2-5)

该滤波器在单位圆上的频率W

k

=2πk/N处有一个极点。因此,通过将输入的数据组

输入到N个单极点并行滤波器(谐振器)组就可计算整个N点DFT,其中,每一滤波器

在响应的DFT频率上有一个极点。

我们可以利用对应于式(2-5)给定的滤波器的差分方程来递推计算y

k

(n),而不是

按式(2-1)通过卷积来实现DFT的计算,因此我们有

y

k

n

W

N

y

k

n1

x

n

(2-6)

初始条件:y

k

(-1)=0

所期望的输出是X(k)=y

k

(N),其中k=0,1,…,N-1,为了完成这一计算,我们可以一

次计算并储存相位因子W

N

-k[12]

-6-

黑龙江东方学院本科毕业论文(设计)

通过将具有复共轭极点的谐波器结合成对,就可以避开式(2-6)所固有的复数乘法

和加法,这就产生了具有两个极点的的滤波器,其系统函数为

1W

N

k

z

1

H

k

(z)

12cos(2

k/N)z

1

z

2

该系统的直接型Ⅱ实现如图2-3所示:

(2-7)

x(n)

v

k

(n)

y

k

(n)

+ +

z

1

2

k

N

2cos

W

n

k

+

z

1

-1

图2-3 用于计算DFT的两极点谐振器的直接型Ⅱ实现

该系统可以用差分方程描述为

v

k

(n)2cos(2

k/N)v

k

(n1)v

k

(n2)x(n)

(2-8)

y

k

(n)v

k

(n)W

n

k

v

k

(n1)

(2-9)

初始条件为

v

k

(1)v

k

(2)0

对n=0,1,…,N,式(2-8)中的递推关系可迭代进行。但式(2-9)中的程序仅当n=N时计

算一次,每迭代需要一次实数乘法和两次加法。因此,对实输入序列x(n),该算法通

过N+1次实数乘法不仅得到X(k),而且由于对称性也得到X(N-k)的值。

当值M相对较小时,比如

Mlog

2

N

,Goertzel算法特别有吸引力,在其他情况

下,FFT算法更为有效

[13]

2.4 Matlab简介

MATLAB是由美国mathworks公司发布的主要面对科学计算、可视化以及交

互式程序设计的高科技计算环境。它将数值分析、矩阵计算、科学数据可视化以

-7-

黑龙江东方学院本科毕业论文(设计)

及非线性动态系统的建模和仿真等诸多强大功能集成在一个易于使用的视窗环境

中,为科学研究、工程设计以及必须进行有效数值计算的众多科学领域提供了一

种全面的解决方案,并在很大程度上摆脱了传统非交互式程序设计语言(如C、

Fortran)的编辑模式,代表了当今国际科学计算软件的先进水平

[14]

MATLAB和Mathematica、Maple并称为三大数学软件。它在数学类科技应

用软件中在数值计算方面首屈一指。MATLAB可以进行矩阵运算、绘制函数和数

据、实现算法、创建用户界面、连接其他编程语言的程序等,主要应用于工程计

算、控制设计、信号处理与通讯、图像处理、信号检测、金融建模设计与分析等

领域

[12]

MATLAB的基本数据单位是矩阵,它的指令表达式与数学、工程中常用的形式十

分相似,故用MATLAB来解算问题要比用C,FORTRAN等语言完成相同的事情简捷

得多,并且MATLAB也吸收了像Maple等软件的优点,使MATLAB成为一个强大的

数学软件。在新的版本中也加入了对C,FORTRAN,C++,JAVA的支持。可以直接

调用,用户也可以将自己编写的实用程序导入到MATLAB函数库中方便自己以后调

用,此外许多的MATLAB爱好者都编写了一些经典的程序,用户可以直接进行下载就

可以用

[15]

2.5 本章小结

音频分析利用时域分析、频域分析、失真分析等方法为手段,通过测量各类音频

参数来评价音频系统的性能。音频分析是一种综合性的分析,涉及到众多的测试仪

器,对于普通用户而言,需要根据其感兴趣的参数合理的选择测试仪器,很难建立完

整的音频测试分析系统。

-8-

黑龙江东方学院本科毕业论文(设计)

第3章 DTMF信号产生与检测

3.1 DTMF信号的产生

号码与频率对应关系

1

4

7

*

2

5

8

0

3

6

9

#

A

B

C

D

697

770

852

941

1209 1336 1477 1633

图3-1 号码与频率关系

根据CCITT建议,国际上采用697Hz、770Hz、852z、941Hz、1209Hz、1336Hz、

1477Hz、1633Hz 8个频率,并将其分成两个群,即低频群和高频群。从低频群和高频群

中任意抽出一个频率进行叠加组合,具有16种组合形式,让其代表数字和功率,如下图

电话机键盘的频率矩阵所列

[16]

当按下某个键时,所得到的按键信号是由相应两个频率的正弦信号相加而成。

x

k

为DTMF信号,产生方式为:

x

k

Asin

W

h

k

Bsin

W

l

k

(3-1)

式中

W

h

=

2f

h

/

f

sam

W

l

=2∏

f

l

/

f

sam

分别表示高频和低频频率,A、B分别为低群

和高频群样值的量化基线。电话信号的典型抽样频率为

f

sam

=8kHZ。CCITT对DTMF

信号规定的指标是,传送/接收率为每秒10个数字,即每个数字100ms。代表数字的

音频信号必须持续至少45ms,但不超过55ms。100ms内其他时间为静音(无信号),以

便区别连续的两个按键信号

[17]

-9-

黑龙江东方学院本科毕业论文(设计)

开始

生成行频正弦序列

生成列频正弦序列

行频正弦序列与列频正弦学序列叠加

D/A变换

滤波

信号发送

图3-2 DTMF信号产生流程图

3.2 DTMF信号的检测

3.2.1 DTMF信号检测方法

DTMF解码即是在输入信号中搜索出有效的行频和列频。计算数字信号的频谱可

以采用DFT及其快速算法FFT,而在实现DTMF解码时,采用Goertzel算法要比FFT更

快。通过FFT可以计算得到信号所有谱线,了解信号整个频域信息,而对于DTMF信号

只用关心其8个行频/列频及其二次谐波信息即可(二次谐波的信息用于将DTMF信号

与声音信号区别开)。此时Goertzel算法能更加快速的在输入信号中提取频谱信息

[18]

相对于DTMF编码过程,DTMF的解码过程复杂得多。DTMF的解码主要完成对有

效行列频率的检测以及对按键的判决。和以往模拟电路通过过零检测来检测有效频率

相比,采用DSP可以从频域直接分析有效频率的存在。在检测DTMF信号时,不但要检

测出DTMF的基波信息,而且还要考虑其二次谐波的信息。贝尔试验室所特意选定的这

8个频率,只在基波有较高的能量;而在相同的基波上有较高能量的话音信号在其二次谐

波上也叠加有较高的能量。因此检测二次谐波的作用就是区别DTMF起后发送,解码

-10-

黑龙江东方学院本科毕业论文(设计)

时DSP则采用改进的Goertzel算法,从频域搜索两个正弦波的存在。因此检测二次谐波

的作用就是区别DTMF信号和话音信号

[19]

DTMF信号的解码是基于Goertzel算法。我们不需要计算全部频域信息,只需要计

算需要的频域的信息,而FFT需要计算全部的频域信息。理论上证明当计算的点数小于

log

2

N时,Goertzel算法比FFT更有效

[20]

在输入信号中检测DTMF信号,并将其转换为实际的数字,这一解码过程本质是

连续的过程,需要在输入的数据信号流中连续地搜索DTMF信号频谱的存在。整个检

测过程分

两步:

(1)采用Goertzel算法在输入信号中提取频谱信息,计算出八个基频和八个二次

谐波幅度的平方值。

(2)根据这些频率幅度平方值与所确定的各个门限值相比较,确定输入信号中是

否是有DTMF信号并映射出双音多频信号的数字信息作检测结果的有效性检查

[21]

-11-

黑龙江东方学院本科毕业论文(设计)

开始

采集信号

读入采样点数N,基频对应点K

调用Goertzel计算信号DFT模,画幅度谱

N

幅度谱峰是否大于检

测门限

Y

输出相应行号与列号

输出行列号对应号码

结束

图3-3 DTMF信号识别流程图

3.2.2 DTMF信号有效性的检测

得到了DTMF信号的基波以及二次谐波的频谱平方信息后,需要通过一系列检测

才能确定信号的有效性:

(1) DTMF信号的强度是否足够大,行列频率分量平方幅度和是否高于规定的门

限值。

(2) 如果DTMF信号存在,比较行列频率的最大频率分量差值,因为电话线具有

低通特性,列频比行频衰减得要厉害。因此,要设置一门限值。

(3) 分别在行列频率组比较频谱分量,最强的谱线至少要比其他音频信号高一

个门限值。

(4) 二次谐波分量是否小于某个值。

-12-

黑龙江东方学院本科毕业论文(设计)

(5) 判断DTMF信号是否包含稳定的数字信息,只有数字信息被连续检测到两

次,才认为是数字信息是稳定的。

最后要检测数字信息之后是否有停顿状态,只有这样将当前的数字作为有效

[22]

3.3 本章小结

在输入信号中检测DTMF信号,并将其转换为实际的数字,这一解码过程本质是

连续的过程,需要在输入的数据信号流中连续地搜索DTMF信号频谱的存在。整个检

测过程分两步:首先采用Goertzel算法在输入信号中提取频谱信息;接着作检测结果

的有效性检查。

-13-

黑龙江东方学院本科毕业论文(设计)

第4章 Matlab仿真

4.1 设计程序(见附录)

4.2 Matlab仿真

DTMF信号的产生比较简单,可直接利用两行频、列频的正弦函数的叠加实现,

DTMF信号(电话拨号“5”为例)波形如图4-1所示:

图4-1 电话号码“5”的时域波形图

电话号码“5”的幅度谱如下图所示:

图4-2 电话号码“5”的幅度谱

我采用的DTMF信号检测的原理是分析信号的频谱特性来分辨不同信息。整个检

测过程分两步:首先采用Goertzel算法在输入信号中提取频谱信息;接着分析频谱信

息,提取输入的DTMF信号,计算数字信号的频谱可以采用DFT及其快速算法

FFT,而在实现DTMF解码时,由于计算量的限制必须采用更高效的算法。由于

DTMF信号只用关心其8个行频/列频的频谱信息,这为设计更优的算法提供了思路。

经过前面的介绍Goertzel算法达到了我们的设计要求,本毕业设计采用Goertzel算法

对双音多频信号进行检测,如图4-3所示,电话号码“5”的Goertzel算法检测频谱图。

-14-

黑龙江东方学院本科毕业论文(设计)

图4-3 电话号码“5”的检测频谱图

说明:图4-1,4-2,4-3是在信噪比SNR=10,采样点数N=205的情况下得到的。

当采样点N=205时,误码率Pe与信噪比SNR的关系图如下图所示:

图4-4 Pe-SNR关系图

由图4-4可知,当采样点数一定时,信噪比越大误码率越低。

当SNR=10时误码率Pe与采样点数N的关系如下图所示:

-15-

黑龙江东方学院本科毕业论文(设计)

图4-5 Pe-N关系图

由图4-5可知,当信噪比一定时,采样点数越大误码率越低。

Pe-SNR-N关系的3D图如图4-6所示:

图4-6 Pe-SNR-N关系图

-16-

黑龙江东方学院本科毕业论文(设计)

整个仿真过程的gui界面如图4-7所示:

图4-7 仿真gui界面

4.3 本章小结

采用DTMF信号检测的原理是分析信号的频谱特性来分辨不同信息。整个检测过

程分两步:首先采用Goertzel算法在输入信号中提取频谱信息;接着分析频谱信息,

提取输入的DTMF信号,计算数字信号的频谱可以采用DFT及其快速算法FFT,而

在实现DTMF解码时,由于计算量的限制必须采用更高效的算法。

-17-

黑龙江东方学院本科毕业论文(设计)

结 论

双音多频DTMF信号不仅用于多数国家的电话网络中,还广泛应用于传输十进制

数据的其他通信系统如电子邮件及银行等,本文就DTMF信号检测中的算法原理及主

要参数选择进行了理论分析,并给出了基于MATLAB的DTMF信号处理系统仿真实

例。基于Goertzel算法,可以在PC机中通过MATLAB语言实现DTMF的编解码。试

验结果表明基于MATLAB的DTMF编解码具有速度快、精度高、稳定性好以及便于

灵活应用等特点.而利用MATLAB语言,可以较好地、快速地进行算法的仿真,对

系统的快速开发起到了推动作用。通过此次设计,我们对DTMF的基础知识有了个比

较深刻的了解,掌握了DTMF的信号产生及信号检验的原理及方法,并熟悉了用

Matlab语言对DTMF的编程的方法,我们定会总结设计方法,掌握理论知识,

汲取经验教训,为进一步掌握DSP的设计,Matlab的使用打下基础。

-18-

黑龙江东方学院本科毕业论文(设计)

参考文献

[1] 周良权,方向乔.《数字电子技术基础》.北京:高等教育出版社,2002.12.

[2] 吕国泰,吴项.《电子技术》.北京:高等教育出版社,2001.5.

[3] 陈明义.《电子技术课程设计使用教程》.中南大学出版社,2002.6.(1).

[4] 《程控交换实验指导书》.钟山学院内部资料.

[5] 刘爱霞.《语音编程.远程控制试验板》.中国.深圳.51测试网.

[6] 奥法尼德斯.《信号处理导论》.清华大学出版社,1999.1.

[7] 《信号与系统分析及MATLAB实现》.电子工业出版社,梁红等.

[8] 陈怀琛.MATLAB及其在理工课程中的应用指南[M].西安电子科技大学出

社,2000.

[9] 奥本海姆.《SIGNALS&SYSTEMS信号与系统》.清华大学出版社,1999.1.

[10] 董爱民.DTMF技术及检测算法研究.计算机与网络.2007.23.

[11] 《长春理工大学学报》.第三卷,第一期.

[12] 丁玉美,高西全.《数字信号处理》(第二版).西安电子科技大学出版社,2001.1.

[13] 戴悟僧.数字信号处理导论[M].上海科学技求出版社,2000.8.

[14] 陈怀琛.MATLAB及其在理工课程中的应用指南[M].西安电子科技大学出版社,2000.

[15] 葛建新.《DTMF(双音多频)技术浅析》.河北省电子信息产品监督检验院.

[16] 《DTMF信号的产生与解码算法研究》.信息技术2008年第11期.

[17] 金鑫春,汪一鸣.《Goertzel算法下DTMF信号检测及参数优化》.

[18] Stan M R,Burleson W -invert coding for low-power I/ Transactions on VLSI

.3no.l.1995.49-58.

[19] Weste N,Eshraghian ples of CMOS VLSI De 2sign.A Systems

g,MA:Addison–Wesley Publishing Company,1988.

[20] Mehta H,Owens R M,Irwin Issues in GrayCode -VLSI-96,pp.178-

180,Amea,IA,March 1996.

[21] 魏克新,王云亮,陈志敏.MATLAB语言与自动控制系统[M].北京:机械工业出版社,1998.

[22] 刘志俭.Matlab应用程序接口用户指南[M].北京:科学出版社,2000.

-19-

黑龙江东方学院本科毕业论文(设计)

附 录

function varargout = DTMF(varargin)

% DTMF M-file for

% DTMF, by itself, creates a new DTMF or raises the existing

% singleton*.

% H = DTMF returns the handle to a new DTMF or the handle to

% the existing singleton*.

% DTMF('CALLBACK',hObject,eventData,handles,...) calls the local

% function named CALLBACK in DTMF.M with the given input arguments.

% DTMF('Property','Value',...) creates a new DTMF or raises the

% existing singleton*. Starting from the left, property value pairs are

% applied to the GUI before DTMF_OpeningFcn gets called. An

% unrecognized property name or invalid value makes property application

% stop. All inputs are passed to DTMF_OpeningFcn via varargin.

% *See GUI Options on GUIDE's Tools menu. Choose "GUI allows only one

% instance to run (singleton)".

% See also: GUIDE, GUIDATA, GUIHANDLES

% Edit the above text to modify the response to help DTMF

% Begin initialization code - DO NOT EDIT

gui_Singleton = 1;

gui_State = struct('gui_Name', mfilename, ...

'gui_Singleton', gui_Singleton, ...

'gui_OpeningFcn', @DTMF_OpeningFcn, ...

'gui_OutputFcn', @DTMF_OutputFcn, ...

'gui_LayoutFcn', [] , ...

'gui_Callback', []);

if nargin && ischar(varargin{1})

gui__Callback = str2func(varargin{1});

end

if nargout

[varargout{1:nargout}] = gui_mainfcn(gui_State, varargin{:});

else

-20-

黑龙江东方学院本科毕业论文(设计)

gui_mainfcn(gui_State, varargin{:});

end

% End initialization code - DO NOT EDIT

% --- Executes just before DTMF is made visible.

function DTMF_OpeningFcn(hObject, eventdata, handles, varargin)

% This function has no output args, see OutputFcn.

% hObject handle to figure

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

% varargin command line arguments to DTMF (see VARARGIN)

% Choose default command line output for DTMF

= hObject;

% Update handles structure

guidata(hObject, handles);

% UIWAIT makes DTMF wait for user response (see UIRESUME)

% uiwait(1);

% --- Outputs from this function are returned to the command line.

function varargout = DTMF_OutputFcn(hObject, eventdata, handles)

% varargout cell array for returning output args (see VARARGOUT);

% hObject handle to figure

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

set(_SNR,'string',);

set(_nGoertzel,'string',zel);

% Get default command line output from handles structure

varargout{1} = ;

% --- Executes on slider movement.

function slider_SNR_Callback(hObject, eventdata, handles)

% hObject handle to slider_SNR (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

-21-

黑龙江东方学院本科毕业论文(设计)

% Hints: get(hObject,'Value') returns position of slider

%get(hObject,'Min') and get(hObject,'Max') to determine range of slider

=get(hObject,'Value'); %returns position of slider

guidata(hObject,handles);

set(_SNR,'string',);

% --- Executes during object creation, after setting all properties.

function slider_SNR_CreateFcn(hObject, eventdata, handles)

% hObject handle to slider_SNR (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles empty - handles not created until after all CreateFcns called

=10;

guidata(hObject,handles);

% Hint: slider controls usually have a light gray background.

if isequal(get(hObject,'BackgroundColor'), get(0,'defaultUicontrolBackgroundColor'))

set(hObject,'BackgroundColor',[.9 .9 .9]);

end

% --- Executes during object creation, after setting all properties.

function text_SendNumber_CreateFcn(hObject, eventdata, handles)

% hObject handle to text_SendNumber (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles empty - handles not created until after all CreateFcns called

% --- Executes on button press in key1.

function key1_Callback(hObject, eventdata, handles)

% hObject handle to key1 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='1';PressKeyDown(hObject,handles);

% --- Executes on button press in key2.

function key2_Callback(hObject, eventdata, handles)

% hObject handle to key2 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

-22-

黑龙江东方学院本科毕业论文(设计)

='2';PressKeyDown(hObject,handles);

% --- Executes on button press in key3.

function key3_Callback(hObject, eventdata, handles)

% hObject handle to key3 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='3';PressKeyDown(hObject,handles);

% --- Executes on button press in keyA.

function keyA_Callback(hObject, eventdata, handles)

% hObject handle to keyA (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='A';PressKeyDown(hObject,handles);

% --- Executes on button press in key4.

function key4_Callback(hObject, eventdata, handles)

% hObject handle to key4 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='4';PressKeyDown(hObject,handles);

% --- Executes on button press in key5.

function key5_Callback(hObject, eventdata, handles)

% hObject handle to key5 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='5';PressKeyDown(hObject,handles);

% --- Executes on button press in key6.

function key6_Callback(hObject, eventdata, handles)

% hObject handle to key6 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='6';PressKeyDown(hObject,handles);

-23-

黑龙江东方学院本科毕业论文(设计)

% --- Executes on button press in keyB.

function keyB_Callback(hObject, eventdata, handles)

% hObject handle to keyB (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='B';PressKeyDown(hObject,handles);

% --- Executes on button press in keyC.

function keyC_Callback(hObject, eventdata, handles)

% hObject handle to keyC (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='C';PressKeyDown(hObject,handles);

% --- Executes on button press in key9.

function key9_Callback(hObject, eventdata, handles)

% hObject handle to key9 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='9';PressKeyDown(hObject,handles);

% --- Executes on button press in key8.

function key8_Callback(hObject, eventdata, handles)

% hObject handle to key8 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='8';PressKeyDown(hObject,handles);

% --- Executes on button press in key7.

function key7_Callback(hObject, eventdata, handles)

% hObject handle to key7 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='7';PressKeyDown(hObject,handles);

% --- Executes on button press in keystar.

function keystar_Callback(hObject, eventdata, handles)

-24-

黑龙江东方学院本科毕业论文(设计)

% hObject handle to keystar (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='*';PressKeyDown(hObject,handles);

% --- Executes on button press in key0.

function key0_Callback(hObject, eventdata, handles)

% hObject handle to key0 (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='0';PressKeyDown(hObject,handles);

% --- Executes on button press in keysharp.

function keysharp_Callback(hObject, eventdata, handles)

% hObject handle to keysharp (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='#';PressKeyDown(hObject,handles);

% --- Executes on button press in keyD.

function keyD_Callback(hObject, eventdata, handles)

% hObject handle to keyD (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

='D';PressKeyDown(hObject,handles);

%PressKeyDown.m

function PressKeyDown(hObject,handles)

%²úÉúÎÞÔëÐźÅ

=DTMF_Tone_Generartor();

%¼ÓÔë

one=Noise_Adder(,);

%·ÅÒô

sound(one,8000);

%ÏÔʾ·¢Ë͵Ä×Ö·û

set(_SendNumber,'string',);

-25-

黑龙江东方学院本科毕业论文(设计)

%%

%¼ÓÔëºóʱÓò²¨ÐÎ

set(gcf,'CurrentAxes',_NoiseTone);

plot(1:800,one);grid;

ylabel('ʱÓò²¨ÐÎ');

%%

%ƵÓò²¨ÐÎ

spectrum=fft(one);

spectrum=fftshift(spectrum);%¼ÆËãÐźŵÄƵÆ×

N=length(spectrum);

nStep=(2*pi)/(N-1);

w=-pi:nStep:pi;

set(gcf,'CurrentAxes',_Spectrum);

plot(w/(2*pi)*8000,abs(spectrum));grid;

ylabel('·ù¶ÈÆ×');

%%

%Goertzel½âÂë

[ected spectrumGeortzel ertzel]=

DTMF_Goertzel_Detector(one,zel);

%ÏÔʾ¼ì²âµ½µÄ×Ö·û

set(_DetectNumber,'string',ected);

%»-Goertzel8µãµÄƵÆ×ͼ

set(gcf,'CurrentAxes',_Goertzel);

stem(1:8,spectrumGeortzel);grid;

ylabel('GoertzelƵÆ×');

%Goertzel¼ì²âËã·¨ËùÓÃʱ¼ä

set(_timeGoertzel,'string',ertzel);

guidata(hObject,handles);

% --- Executes on button press in button_Analyse_Pe_SNR.

function button_Analyse_Pe_SNR_Callback(hObject, eventdata, handles)

% hObject handle to button_Analyse_Pe_SNR (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

-26-

黑龙江东方学院本科毕业论文(设计)

% handles structure with handles and user data (see GUIDATA)

Analyser_Pe_SNR(,,zel);

% --- Executes on slider movement.

function slider_nGoertzel_Callback(hObject, eventdata, handles)

% hObject handle to slider_nGoertzel (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

% Hints: get(hObject,'Value') returns position of slider

% get(hObject,'Min') and get(hObject,'Max') to determine range of slider

zel=fix(get(hObject,'Value')); %returns position of slider

if zel<2

zel=2;

end

guidata(hObject,handles);

set(_nGoertzel,'string',zel);

% --- Executes during object creation, after setting all properties.

function slider_nGoertzel_CreateFcn(hObject, eventdata, handles)

% hObject handle to slider_nGoertzel (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles empty - handles not created until after all CreateFcns called

zel=205;

guidata(hObject,handles);

% Hint: slider controls usually have a light gray background.

if isequal(get(hObject,'BackgroundColor'), get(0,'defaultUicontrolBackgroundColor'))

set(hObject,'BackgroundColor',[.9 .9 .9]);

end

% --- Executes on button press in button_Analyse_Pe_N.

function button_Analyse_Pe_N_Callback(hObject, eventdata, handles)

% hObject handle to button_Analyse_Pe_N (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

Analyser_Pe_N(,,);

-27-

黑龙江东方学院本科毕业论文(设计)

% --- Executes on button press in button_Analyser_3D.

function button_Analyser_3D_Callback(hObject, eventdata, handles)

% hObject handle to button_Analyser_3D (see GCBO)

% eventdata reserved - to be defined in a future version of MATLAB

% handles structure with handles and user data (see GUIDATA)

Analyser_3D(,);

-28-

黑龙江东方学院本科毕业论文(设计)

致 谢

感谢我的母校。是它为我提供了良好的学习环境和优异的师资力量。先进的教学

设备;兢兢业业的老师;辛勤学习的学生;正是这样的良好环境才造就了我院一届届

优秀的毕业生,为社会为国家提供了一批批优秀的人才。

感谢我的导师XX老师。是他们以严谨的作风,认真负责的工作态度对我的论文

写作进行指导。在写开题报告的时间里老师不辞辛苦的讲解才使得我的设计顺利的进

行。从设计的选题到资料的搜集直至最后设计的修改的整个过程中,花费了夏宇老师

很多的宝贵时间和精力,在此向导师表示衷心地感谢!导师严谨的治学态度,开拓进

取的精神和高度的责任心都将使学生受益终生,毕业设计中我们得到了许多方面的帮

助和支持。

感谢教过我的各科讲师。是他们一步步把我带进知识的殿堂,一点点教会我各种

文化,更重要的是教会我如何处事,如何为人。

感谢我的父母,是他们含辛茹苦的把我养育成人,也是他们不计回报的给了我学

习的机会,使我才有了这样精彩的人生。

感谢我的同学、朋友,是他们为我营造了一个温暖的“大家庭”,让我感受到友情

的真谛与力量,也在不断的进步。

在未来的道路上,我一定会更加努力,不辜负学校、老师以及父母的期望,兢兢

业业做事,堂堂正正做人,为社会,为他人,更是为自己充分发挥每一份力量。

-29-

发布评论

评论列表 (0)

  1. 暂无评论