基于某MATLAB地简单音乐合成

上传人:ni****g 文档编号:486415210 上传时间:2023-12-28 格式:DOC 页数:13 大小:171KB
返回 下载 相关 举报
基于某MATLAB地简单音乐合成_第1页
第1页 / 共13页
基于某MATLAB地简单音乐合成_第2页
第2页 / 共13页
基于某MATLAB地简单音乐合成_第3页
第3页 / 共13页
基于某MATLAB地简单音乐合成_第4页
第4页 / 共13页
基于某MATLAB地简单音乐合成_第5页
第5页 / 共13页
点击查看更多>>
资源描述

《基于某MATLAB地简单音乐合成》由会员分享,可在线阅读,更多相关《基于某MATLAB地简单音乐合成(13页珍藏版)》请在金锄头文库上搜索。

1、word数字信号处理课程设计说明书设计题目:基于MATLAB的简单音乐合成姓 名:专业年级:学 号:指导教师:时 间:2015年6月25日 精彩文档数字信号处理课程设计任务书题目基于MATLAB的简单音乐合成主要内容1、自学Matlab软件,了解相关编译语句;2、利用Matlab完成简单的音乐合成;3、分析仿真结果,得出合理结论。设计要求1、利用Matlab实现对自选乐曲的简单音乐合成,生成 .wav文件;2、给各个乐音加载包络,生成.wav,并显示音乐信号的包络图像;3、在音乐中加上二、三、四次谐波,基波幅度为1,高次谐波幅度分别为,并生成.wav文件。4、按要求完成设计报告。主要仪器设备1

2、、计算机1台,Matlab 仿真软件一套。主要参考文献1 高西全,丁玉美数字信号处理(第三版) M某某:某某电子科技大学,20082 程佩青. 数字信号处理教程(第四版) M:清华大学,20133 余成波等.数字信号处理与MATLAB实现(第二版) M:清华大学,2008课程设计进度安排起止时间、工作内容单人一组,每组选择不同乐曲进展音乐合成,每人1套实验环境。整个课程设计共1周20学时,具体安排如下:前期准备工作 4学时学习设计题目相关知识,查阅资料,掌握实现的原理;计划内上机14学时按要求,完成设计方案,编写并调试仿真程序;计划内上机2学时 结果验收,并完成课程设计报告。课程设计开始日期课

3、程设计完成日期指导教师签名:_目 录1 设计根底- 1 -1.1 MATLAB软件简介- 1 -1.2 乐曲解析- 1 -2 设计与实现- 2 -2.1 简单的音乐合成- 2 - 2 -2.1.2 Matlab 源代码- 2 -2.1.3 运行结果分析- 2 -2.2 除噪音,加包络- 2 -2.2.1 原理分析- 2 -2.2.2 Matlab 源代码- 2 -2.2.3 运行结果分析- 2 -2.3 加谐波- 2 -2.3.1 原理分析- 2 -2.3.2 Matlab 源代码- 2 -2.3.2 运行结果分析- 3 -3 总结与体会- 4 -4 参考文献- 5 -精彩文档1 设计根底1.

4、1 MATLAB软件简介MATLAB是matrix&laboratory两个词的组合,意为矩阵工厂矩阵实验室MATLAB工作界面。是由美国mathworks公司发布的主要面对科学计算、可视化以与交互式程序设计的高科技计算环境。它将数值分析、矩阵计算、科学数据可视化以与非线性动态系统的建模和仿真等诸多强大功能集成在一个易于使用的视窗环境中,为科学研究、工程设计以与必须进展有效数值计算的众多科学领域提供了一种全面的解决方案,并在很大程度上摆脱了传统非交互式程序设计语言如C、Fortran的编辑模式,代表了当今国际科学计算软件的先进水平。MATLAB和Mathematica、Maple并称为三大数学

5、软件。它在数学类科技应用软件中在数值计算方面首屈一指。MATLAB可以进展矩阵运算、绘制函数和数据、实现算法、创建用户界面、连接其他编程语言的程序等,主要应用于工程计算、控制设计、信号处理与通讯、图像处理、信号检测、金融建模设计与分析等领域。MATLAB的根本数据单位是矩阵,它的指令表达式与数学、工程中常用的形式十分相似,故用MATLAB来解算问题要比用C,FORTRAN等语言完成一样的事情简捷得多,并且MATLAB也吸收了像Maple等软件的优点,使MATLAB成为一个强大的数学软件。在新的版本中也参加了对C,FORTRAN,C+,JAVA的支持。可以直接调用,用户也可以将自己编写的实用程序

6、导入到MATLAB函数库中方便自己以后调用,此外许多的MATLAB爱好者都编写了一些经典的程序,用户可以直接进展下载就可以用。1.2 乐曲解析乐音的根本特征可以用基波频率、谐波频率和包络波形三个方面来描述,我们用大写英文字母 CDEFGAB 表示每个音的“音名或称为“音调,当指定某一音名时,它对应固定的基波信号频率。图 1 表示钢琴的键盘结构,并注明了每个琴键对应的音名和基波频率值。这些频率值是按“十二平均律计算导出,下面解释计算规如此:图 1-1 钢琴键盘和相应频率从图 1-1 可以看到,靠下边的 A 键称为小字组 A,它的频率值 fA0= 220Hz,而靠上面的另一个 A 键是小字一组 A

7、,它的频率值是 fA1= 440Hz。两者为二倍频率关系,即 fA1 相当于 fA0 的二次谐波。也称为 8 度音或倍频程 Octave(即我们画频响特性图时所用的术语“倍频程)。根据两只老虎简谱和十二平均律计算出该小节每个乐音的频率,在MATLAB中生成幅度为1,抽样频率为8000kHz的正弦信号表示这些乐音,用sound播放合成的音乐图1-2 乐曲两只老虎曲谱由图可知两只老虎的曲调定为C,即1=C,对应的频率为261.63Hz,据此可以计算出其他乐音的频率,类推计算出各乐音对应的频率见表1-1 局部乐音对应的频率:表1-1 局部乐音对应的频率乐音1231123134频率乐音5345频率39

8、2392在确定了各乐音的频率之后需要确定每个乐音的持续时间。每小节有两拍,一拍的时间是0.5此局部乐音的持续时间见表1-2局部乐音对应的时间:表1-2 局部乐音对应的时间乐音1231123134时间乐音45345时间11而在MATLAB中表示乐音所用的抽样频率为fs=8000Hz,也就是所1s钟内有8000个点,抽样点数的多少就可表示出每个乐音的持续时间的长短。用一个行向量来存储这段音乐对应的抽样点,在用sound函数播放即可。根据以上分析在MATLAB中编写如下程序:clear;clc;fs=8000;%抽样频率f=261.63293.66329.63261.63261.63293.6632

9、9.63261.63329.63349.23 392329.63349.23392; %各个乐音对应的频率time=fs*0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,1,0.5,0.5,1;%各个乐音的抽样点数N=length(time);%这段音乐的总抽样点数east=zeros(1,N);%用east向量来储存抽样点n=1;for num=1:N%利用循环产生抽样数据,num表示乐音编号 t=1/fs:1/fs:time(num)/fs;%产生第num个乐音的抽样点east(n:n+time(num)-1)=sin(2*pi*f(num)*t);%抽样点

10、对应的幅值 n=n+time(num);endsound(east,8000);%播放音乐2 设计与实现2.1 简单的音乐合成根据两只老虎片段的简谱和“十二平均律计算出该片段中各个乐音的频率,在 MATLAB 中生成幅度为 1、抽样频率为 8000kHz 的正弦信号表示这些乐音。请用 sound 函数播放每个乐音,听一听音调是否正确,最后用这一系列乐音信号拼出两只老虎片段,注意控制每个乐音持续的时间要符合节拍,用 sound 函数播放合成的乐音。2.12 Matlab 源代码clear;clc;fs=8000;%抽样频率f=261.63293.66329.63261.63261.63293.6

11、6329.63261.63329.63349.23 392329.63349.23392; %各个乐音对应的频率time=fs*0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,1,0.5,0.5,1;%各个乐音的抽样点数N=length(time);n=1;for num=1:N%利用循环产生抽样数据,num表示乐音编号 t=1/fs:1/fs:time(num)/fs;%产生第num个乐音的抽样点east(n:n+time(num)-1)=sin(2*pi*f(num)*t);%抽样点对应的幅值 n=n+time(num);endsound(east,8000

12、);%播放音乐2.1.3 运行结果分析初步合成的音乐音调符合曲谱,能听出两只老虎的旋律。2.2 除噪音,加包络2.2.1 原理分析你一定注意到(1)的乐曲中相邻乐音之间有“啪的杂声,这是由于相位不连续产生了高频分量。这种噪声严重影响合成音乐的质量,丧失真实感,下面通过加包络来消噪音。最简单的包络为指数衰减。最简单的指数衰减是对每个音乘以因子,在实验中首先加的是的衰减,这种衰减方法使用的是一样速度的衰减,但是发现噪音并没有完全消除,播放的音乐效果不是很好,感觉音乐起伏性不强。于是采用不同速度的衰减,根据乐音持续时间的长短来确定衰减的快慢,乐音持续时间越长,衰减的越慢,持续时间越短,衰减的越快。2

13、.2.2 Matlab 源代码clear;clc;fs=8000;%抽样频率f=261.63293.66329.63261.63261.63293.66329.63261.63329.63349.23 392 329.63349.23392; %各个乐音对应的频率time=fs*0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,1,0.5,0.5,1;%各个乐音的抽样点数%各个乐音对应的频率N=length(time);%这段音乐的总抽样点数xio=zeros(1,N);%用east向量来储存抽样点n=1;for num=1:N%利用循环产生抽样数据,num表示乐

14、音编号 t=1/fs:1/fs:(time(num)/fs;%产生第num个乐音的抽样点 P=zeros(1,time(num);%P为存储包络数据的向量L=(time(num)*0 1/5 3/8 5/8 1;%包络线端点对应的横坐标 T=0 1.5 1 1 0;%包络线端点对应的纵坐标 s=1; b=1:1:time(num);%产生包络线抽样点 for k=1:4 P(s:L(k+1)-1)=(T(k+1)-T(k)/(L(k+1)-L(k)*(b(s:L(k+1)-1)-L(k+1)*ones(1,L(k+1)-s)+T(k+1)*ones(1,L(k+1)-s);%包络线直线方程通式 s=L(k+1); endlaohu(n:n+time(num)-1)=sin(2*pi*f(num)*t).*P(1:time(num);%给第num个乐音加上包络 n=n+time(num);endsound(laoh

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号