- 1、本文档共15页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
双音多频通信设计的Matlab仿真双音多频通信设计的Matlab仿真
双音多频(DTMF)通信设计的MATLAB仿真
摘要:讨论以MATLAB作为仿真工具产生DTMF信号,并用FFT算法、DFT算法、卷积法及迭代法来对DTMF信号进行解码。
关键词:FFT;DFT;频谱分析;卷积;滤波;差分方程;MATLAB
0 引 言
双音多频(DTMF:Double Tone Multi-Frequency)是按键电话通信,也广泛应用于电子邮件和银行系统中。用户可从电话发送DTMF信号来选择菜单进行操作。DTMF信号容易用软件产生和解码。MATLAB是一个高度集成的软件系统,通过交互式的命令(语句)可以十分简便地实现许多复杂的数值计算。
本文采用MATLAB作为仿真工具产生DTMF信号,并用FFT算法、DFT算法、卷积法及迭代法来对DTMF信号进行解码,由此得出:时域和频域是研究信号的两个窗口,其中信号处理大都在时域中进行,而信号分析往往在频域中比较方便直观。且数字信号处理技术中的DFT、FFT、卷积、滤波、差分方程这几个概念之间有内在联系。
1 DTMF信号的产生
DTMF是数字音频信号,在DTMF通信系统中共有8个频率,分为4个高频音和4个低频音,用一个高频音和一个低频音的组合表示一个信号,这样共有16种组合,分别代表16种信号,如表1所示:
fH(Hz)
fL(Hz)
1209
1336
1477
1633 697 1 2 3 A 770 4 5 6 B 852 7 8 9 C 941 * 0 # D 表1 DTMF信号组合表
例如,当按下数字键“1”时,则产生低频697Hz和高频1209Hz这两个正弦信号的迭加。由于语音信号的最高频率为4KHz,根据奈奎斯特取样定理,取样频率fs应大于或等于原信号最高频率fc的两倍,即
fs≥2fc (1)
才能保证取样后的信号不失真,所以电话音频信号在数字信号处理时,取样频率fs为
2×4k=8kHz,这里,每个数字信号持续时间为100ms,后面加上100ms的间隔时间(用0表示)。上述DTMF信号产生方法如下:
建立拨号数字的表矩阵,用查表法(查表1)求用户所按数字键对应的高、低频音。
为简化起见,仅允许选择“0-9”这十个键,在开始时还可拨空信号。
产生相应的DTMF信号及间隔时间。
由于fs=8kHz,各信号持续时间为100ms,因此在程序中每个信号取800点,间隔时间也取800点,结果存入数组中。
(3)画图并监听产生的DTMF信号。
程序如下:
%[程序1], DTMF信号的产生
clear %清除内存
TAB=[941 1336;697 1209;697 1336;697 1477;770 1209;770 1336;770 1477;852 1209;852 1336;852 1477];%拨号数字表矩阵
n=input(n=); %DTMF信号的个数
l=input(n0=);%空信号点数
for i=1:n
k=input(0~9);%输入的数字键
fL=TAB(k+1,1); %k对应的低频音
fH=TAB(k+1,2); %k对应的高频音
n1=800;fs=8000;%产生k对应的DTMF信号,取样频率8kHz,每个信号共1600点,其中,
j=0:1:n1-1; 前800点为信号持续时间,后800点为间隔时间,结果存入数组out中。
x=sin(2*pi*fL*j/fs)+sin(2*pi*fH*j/fs);
out(1600*(i-1)+1+l:1600*i-800+l)=x;
out(1600*i-799+l:1600*i+l)=0;
end
out=out./2; %out数组中每个数据除以2
subplot(211); plot(out); %绘图并监听DTMF信号。
sound(out,fs)
wavwrite(out,fs,D2.wav);%out另存入声音文件
程序结果:
例如:若要产生数字键“1”所对应的DTMF信号,且开始时有200点空信号,则程序运行如下:
询问: 输入:
n= 1
n0= 200
1
得图1:
图1 DTMF信号图
图1中,前200点为空信号,第201-1000点为键“1”对应的DTMF信号,第1001-1800点为间隔时间。
您可能关注的文档
最近下载
- 新人教版高中数学必修第一册全册单元测试卷(原卷+解析).pdf VIP
- 爱德华消防主机操作手册.doc VIP
- 包皮过长健康宣教PPT.pptx
- 高血压病的防治知识讲座含内容.pptx VIP
- 风能发电系统 漂浮式海上风力发电机组一体化计算分析导则及编制说明.pdf VIP
- 2024年北京市普通高中学业水平等级性考试地理试卷(含答案).pdf VIP
- 生猪屠宰兽医卫生检验人员考试题库5份(含答案).docx
- 2017款长城哈弗M6-2017款1.5T手动自动两驱蓝标_汽车使用手册用户操作图解驾驶车主车辆说明书电子版.pdf VIP
- 二月闹肠胀气(宝宝哭闹护理手册).pdf
- 马来酸阿伐曲泊帕片-药品临床应用解读.pptx VIP
文档评论(0)