.word格式..专业.专注.淮阴工学院数字信号处理课程设计报告题目:基于MATLAB的双音多频拨号系统的仿真系(院):计算机工程学院专业:通信工程班级:学号:姓名:指导教师:顾相平学年学期:2013~2014学年第1学期.word格式..专业.专注.2013年12月15日.word格式..专业.专注.摘要双音多频(DualToneMultiFrequency,DTMF)信号是音频电话中的拨号信号,由美国AT&T贝尔公司实验室研制,并用于电话网络中。DTMF信号在电话中有两种作用,一个是用拨号信号去控制交换机接通被叫的用户电话机,另一个作用是控制电话机的各种动作,如播放留言、语音信箱等。MATLAB语言是一种广泛应用于工程计算及数值分析领域的新型高级语言,MATLAB功能强大、简单易学、编程效率高,深受广大科技工作者的欢迎。特别是MATLAB还具有信号分析工具箱,不需具备很强的编程能力,就可以很方便地进行信号分析、处理和设计。所以该课程设计利用MATLAB进行仿真,编写代码,运行程序,根据提示键入8位电话号码如12345678,回车后可以听见8位电话号码对应的DTMF信号的声音,并输出相应的8幅频谱图,最后显示检测到的电话号码12345678。说明DTMF信号的参数:采样频率、DFT的变换点数以及观测时间的确定原则。关键词多音双频频谱图采样频率.word格式..专业.专注..word格式..专业.专注.目录1引言..........................................................-6-2课程设计题目描述和要求........................................-7-3课程设计报告内容..............................................-8-3.1信号的产生及算法实现.....................................-8-3.2详细设计................................................-13-3.3结果分析................................................-17-总结...........................................................-18-.word格式..专业.专注.1引言双音多频(DualToneMultiFrequency,DTMF)信号是音频电话中的拨号信号,由美国AT&T贝尔公司实验室研制,并用于电话网络中。这种信号制式具有很高的拨号速度,且容易自动监测识别,很快就代替了原有的用脉冲计数方式的拨号制式。这种双音多频信号制式不仅用在电话网络中,还可以用于传输十进制数据的其它通信系统中,用于电子邮件和银行系统中。这些系统中用户可以用电话发送DTMF信号选择语音菜单进行操作。DTMF信号系统是一个典型的小型信号处理系统,它要用数字方法产生模拟信号并进行传输,其中还用到了D/A变换器;在接收端用A/D变换器将其转换成数字信号,并进行数字信号处理与识别。为了系统的检测速度并降低成本,还开发一种特殊的DFT算法,称为戈泽尔(Goertzel)算法,这种算法既可以用硬件(专用芯片)实现,也可以用软件实现。下面首先介绍双音多频信号的产生方法和检测方法,包括戈泽尔算法,最后进行模拟实验。下面先介绍电话中的DTMF信号的组成。在电话中,数字0~9的中每一个都用两个不同的单音频传输,所用的8个频率分成高频带和低频带两组,低频带有四个频率:679Hz,770Hz,852Hz和941Hz;高频带也有四个频率:1209Hz,1336Hz,1477Hz和1633Hz.。每一个数字均由高、低频带中各一个频率构成,例如1用697Hz和1209Hz两个频率,信号用)2sin()2sin(21tftf表示,其中Hzf6791,Hzf12092。这样8个频率形成16种不同的双频信号。具体号码以及符号对应的频率如表1所示。表中最后一列在电话中暂时未用。.word格式..专业.专注.表1双频拨号的频率分配列行1209Hz1336Hz1477Hz633Hz697Hz123A770Hz456B852Hz789C942Hz*0#DDTMF信号在电话中有两种作用,一个是用拨号信号去控制交换机接通被叫的用户电话机,另一个作用是控制电话机的各种动作,如播放留言、语音信箱等。2课程设计题目描述和要求DTMF(DoubleToneMultiFrequency,双音多频)信号是音频电话拨号信号,由美国AT&T贝尔实验室开发。作为实现电话号码快速可靠传输的一种技术,它具有很强的抗干扰能力和较高的传输速度,因此,可广泛用于电话通信系统中。但绝大部分是用作电话的音频拨号。另外,它也可以在数据通信系统中广泛地用来实现各种数据流和语音等信息的远程传输。这种拨号方法取代了脉冲拨号,在DTMF通信系统中共有8个频率,分为4个高频音和4个低频音.用1个高频音和1个低频音的组合来表示一个信号.这样,共能提供16种组合,分别代表16种信号.图一为电话按键与信号频率的对应关系。.word格式..专业.专注.图一DTMF编码各种DTMF信号的应用都离不开DTMF信号的检测,这是DTMF信号应用的关键。对它的检测,主要通过数字信号处理的算法以及硬件实现。本文主要通过MATLAB的软件编程来实现DTMF信号的仿真检测,从频域分析了快速傅立叶变换(FFT)和GOERTZEL两种方法,并对GOERTZEL算法进行了详细的推导,提出采用Goertzel算法来实现DTMF信号的检测。3课程设计报告内容3.1信号的产生及算法实现DTMF编码,是将电话拨号盘上的数字0~9,字母A~D,及*/E、#/F,共16个字符,用音频范围的8个频率表示出来。具体来说,将8个频率分为高频群和低频群两组,分别作为列频和行频。每一个键的频率模式由来自于列频和行频的两个频率叠加而成。DTMF信号所规定的指标是:传送/接收率为每秒10个数字,或每个数字100ms。每个数字传送过程中,信号必须存在至少45ms,且不得多于55ms,100ms里的其余时间是静音。124758*A3AB609C#D679HZ770HZ852HZ941HZ1290HZ1366HZ1477HZ1633HZ行频率列频率.word格式..专业.专注.1)、DTMF信号的产生假设时间连续的DTMF信号用)2sin()2sin()(21tftftx表示,式中21ff和是按照表1选择的两个频率,1f代表低频带中的一个频率,2f代表高频带中的一个频率。显然采用数字方法产生DTMF信号,方便而且体积小。下面介绍采用数字方法产生DTMF信号。规定用8KHz对DTMF信号进行采样,采样后得到时域离散信号为)8000/2sin()8000/2sin()(21nfnfnx形成上面序列的方法有两种,即计算法和查表法。用计算法求正弦波的序列值容易,但实际中要占用一些计算时间,影响运行速度。查表法是预先将正弦波的各序列值计算出来,寄存在存储器中,运行时只要按顺序和一定的速度取出便可。这种方法要占用一定的存储空间,但是速度快。因为采样频率是8000Hz,因此要求每125ms输出一个样本,得到的序列再送到D/A变换器和平滑滤波器,输出便是连续时间的DTMF信号。DTMF信号通过电话线路送到交换机。2)、DTMF信号的检测检测中采用了频域的方法,N点数据的DFT公式为:它的好处是可以得到DFT的所有N点的值。也就是通过DFT可以计算出信号中1,...,1,0)()]([)(10NkWnxnxDFTkXNnknN.word格式..专业.专注.所包含的频率成分。具体实现时,由于它的计算量非常大,因而主要使用它的快速算法——快速傅立叶变换(FFT)[3,4]。对上述产生的DTMF信号,经过200点FFT运算得到DTMF信号的频谱X(K)(如图二所示)。根据结果中两条谱线的位置K值可知其频率分别为820HZ和1290HZ,即对应了电话号码盘的数字“7”。从图中可以看出,FFT运算中出现了两个问题:1、由于数据的截断,带来了频谱泄漏误差;2、通过FFT运算,计算出了200点的频谱,而DTMF信号只需8个频率点,计算效率大大降低。为解决这个问题,文中采用了GOERTZEL算法[5]。图二“7”的DTMF编码FFT频谱GOERTZEL算法本身也是对DFT的快速运算,但可以有选择地计算个别点处的DFT,而对不需要的点不进行计算。GOERTZEL算法原理如下:GOERTZEL算法实质是一个两极点的IIR滤波器,其算法原理框图如图三所示:.word格式..专业.专注.图三GOERTZEL算法原理框图由图可知:)1()()()(0)2()1()2cos(2)()(2NveNvNykXNnnvnvNknxnvkkNjkkkkk具体推导如下:)()()(10)(DFTWnxkXNnNnkN令n=m10)()()(NmNmkNWmxkX=()knNXnW(n=N)所以对序列X(n)的DFT等价于X(n)与系统传递函数()knNhnW的第N个卷积值.X(n)Vk(n)kNwYk(n).word格式..专业.专注.对()knNhnW进行Z变换可得:11()1knHzWZ=)1(2cos211121ZWZkNZkN因此,H(z)可看作是级联型网络:2112cos211)(ZkNZzH12()(1)kNHzWZ因此)()2()1(2cos2)(nXnVnkVNnV其中V(-1)=V(-2)=0.()()(1)kNynVnWVn.因而,系统输出的功率谱为:)1()()2cos(2)1()()(222nvnvkNnvnvny其中n=N.word格式..专业.专注.图四“7”的DTMF编码GOERTZEL功率谱根据以上算法,使用MATLAB语言具体实现,程序如下:k=f/fn;vk(1)=0;vk(2)=0;fori1=1:8w=2*cos(2*pi*k(i1)/N);fori2=3:202vk(i2)=w.*vk(i2-1)-vk(i2-2)+x(i2);end;Xk(i1)=vk(202).^2+vk(201).^2-w*vk(202)*vk(201);end;程序运行结果如图四所示。从图中可以看出,利用GOERTZEL算法,只需计算出八个点的功率谱就可以进行拨号的判断,减少了运算量,提高了计算效率,使判断可以实时进行。3.2详细设计仿真界面图.word格式..专业.专注.DTMF信号的产生与识别仿真实验在MATLAB环境下进行,编写仿真程序,运行程序,送入8位电话号码,程序自动产生每一位号码数字相应的DTMF信号,并送出双频声音,再用DFT进行谱分析,显示每一位号码数字的DTMF信号的DFT幅度谱,安照幅度谱的最大值确定对应的频率,再安照频率确定每一位对应的号码数字,最后输出8位电话号码,程序名为exp8。程序分四段:第一段(2—7行)设置参数,并读入8位电话号码;第二段(9—20行)根据键入的6位电话号码产生时域离散DTMF信号,并连续发出8位号码对应的双音频声音;第三段(22—25行)对时域离散DTMF信号进行频率检测,画出幅度谱;第四段(26—33行)根据幅度谱的两个峰值,分别查找并确定输入8位电话号码。根据程序中的注释很容易分析编程思想和处理算法。程序清单如下:tm=[1,2,3,65;4,5,6,66;7,8,9,67;42,0,35,68];%DTMF信号代表的16个数.word格式..专业.专注.N=205;K=[18,20,22,24,31,34,38,42];f1=[697,770,852,941];%行频率向量f2=[1209,1336,1477,16