欢迎来到冰豆网! | 帮助中心 分享价值,成长自我!
冰豆网
全部分类
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • 党团工作>
  • ImageVerifierCode 换一换
    首页 冰豆网 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    基于MATLAB的简单音乐合成.docx

    • 资源ID:5107941       资源大小:26.24KB        全文页数:10页
    • 资源格式: DOCX        下载积分:12金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要12金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    基于MATLAB的简单音乐合成.docx

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

    2、7、0.2424,并生成.wav 文件。4、 按要求完成设计报告。主要仪器设备1、计算机1台,Matlab仿真软件一套。主要4 TV, 参考文献1高西全,丁玉美数字信号处理(第三版)M 西安:西安电子科技大 学出版社,20082程佩青.数字信号处理教程(第四版)M.北京:清华大学出版社,20133余成波等.数字信号处理及MATLA实现(第二版)M.北京:清华大学 出版社,2008课程设计进度安排(起止时间、工作内容)单人一组,每组选择不同乐曲进行音乐合成,每人 1套实验环境。整个课程设计 共1周20学时,具体安排如下:前期准备工作4学时 学习设计题目相关知识,查阅资料,掌握实现的原理; 计划内

    3、上机14学时 按要求,完成设计方案,编写并调试仿真程序; 计划内上机2学时 结果验收,并完成课程设计报告。课程设计开始日期 2015.06.23 课程设计完成日期 2015.06.301设计基础 1.1MATLAB软件简介 1.2乐曲解析 2设计与实现 2.1简单的音乐合成 2.1.1原理分析 2.1.2Matlab 源代码 2.1.3运行结果分析 2.2除噪音,加包络 2.2.1原理分析 2.2.2Matlab 源代码 2.2.3运行结果分析 2.3加谐波 2.3.1原理分析 2.3.2Matlab 源代码 2.3.2运行结果分析 3总结与体会 4参考文献 1 设计基础1.1MATLAB 软

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

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

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

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

    8、134频率261.293.329.261.261.293.329.261.329.349.23636663636366636363乐音5345频率392329.349.39263 23在确定了各乐音的频率之后需要确定每个乐音的持续时间。每小节有两拍,一拍的时 间是0.5此部分乐音的持续时间见表1-2部分乐音对应的时间:表1-2 部分乐音对应的时间乐音1231123134时间0.50.50.50.50.50.50.50.50.50.5乐音45345时间0.510.50.51而在MATLA中表示乐音所用的抽样频率为fs=8000Hz,也就是所1s钟内有8000个点, 抽样点数的多少就可表示出每个乐

    9、音的持续时间的长短。 用一个行向量来存储这段音乐对应的抽样点,在用sou nd函数播放即可。根据以上分析在MATLA中编写如下程序:soun d_1_1.mclear;clc;fs=8000; %t样频率f=261.63 293.66 329.63 261.63 261.63 293.66 329.63 261.63 329.63 349.23392 329.63 349.23 392;%各个乐音对应的频率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=le ngth(t

    10、ime); %这段音乐的总抽样点数east=zeros(1,N); %用east向量来储存抽样点n=1;for num=1:N %利用循环产生抽样数据,nun表示乐音编号t=1/fs:1/fs:time(num)/fs; %产生第nun个乐音的抽样点east( n:n+time( nu m)-1)=si n(2*pi*f( nu m)*t);沖由样点对应的幅值n=n+time( nu m);end2 设计与实现2.1 简单的音乐合成根据两只老虎片段的简谱和“十二平均律”计算出该片段中各个乐音的频率, 在 MATLAB 中生成幅度为 1 、抽样频率为 8000kHz 的正弦信号表示这些乐音。请用

    11、 sound 函数播放每个乐音,听一听音调是否正确,最后用这一系列乐音信号拼出两只 老虎片段,注意控制每个乐音持续的时间要符合节拍,用 sound 函数播放合成的乐 音。2.12 Matlab 源代码clear;clc;fs=8000; %抽样频率f=261.63 293.66 329.63 261.63 261.63 293.66 329.63 261.63 329.63 349.23392 329.63 349.23 392;%各个乐音对应的频率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 ;

    12、% 各个乐音的抽样点数 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); %播放音乐2.1.3 运行结果分析初步合成的音乐音调符合曲谱,能听出两只老虎的旋律。2.2除噪音,加包络2.2.1 原理分析你一定注意到 (1) 的乐曲中相邻乐音之间有“啪”的杂声,这是由于相位不连续 产生了高频分量。这种

    13、噪声严重影响合成音乐的质量,丧失真实感,下面通过加包络 来消噪音。最简单的包络为指数衰减。最简单的指数衰减是对每个音乘以 e t 因子,在实验 1.5t中首先加的是e .的衰减,这种衰减方法使用的是相同速度的衰减,但是发现噪音 并没有完全消除,播放的音乐效果不是很好,感觉音乐起伏性不强。于是采用不同速 度的衰减,根据乐音持续时间的长短来确定衰减的快慢,乐音持续时间越长,衰减的 越慢,持续时间越短,衰减的越快。2.2.2Matlab 源代码clear;clc;fs=8000; %抽样频率f=261.63 293.66 329.63 261.63 261.63 293.66 329.63 261.

    14、63 329.63349.23 392 329.63 349.23 392; % 各个乐音对应的频率;%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表示乐音编号t=1/fs:1/fs:(time(num)/fs; %产生第 num个乐音的抽样点P=zeros(1,time( num);

    15、 %助存储包络数据的向量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); %产生包络线抽样点fork=1:4P(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(nu

    16、m);%给第num个乐音加上包络n=n+time(num);endsound(laohu ,8000);plot( laohu );wavwrite( laohu , laohu 2)2.2.3 运行结果分析 播放后可以听出噪音已经消除,同时因为不同时长的乐音衰减的快慢不一样,音乐听起来更有起伏感,如图为 2-1 波形图。图 2-1 laohu1 加包络波形图2.3 加谐波2.3.1 原理分析在音乐中加上二、 三、四次谐波, 基波幅度为 1,高次谐波幅度分别为 0.2 、0.3 、0.1。2.3.2 Matlab 源代码clear;clc;fs=8000; %抽样频率f=261.63 293.

    17、66 329.63 261.63 261.63 293.66 329.63 261.63 329.63349.23 392 329.63 349.23 392; % 各个乐音对应的频率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); n=1;%这段音乐的总抽样点数%用 east 向量来储存抽样点for num=1:N%利用循环产生抽样数据,num表示乐音编号%各个乐音对应的频率t=1/fs:1/fs:(time(num

    18、)/fs;%产生第num个乐音的抽样点%励存储包络数据的向量P=zeros(1,time(num);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);%包络线端点对应的横坐标%包络线端点对应的纵坐标%产生包络线抽样点fork=1:4P(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);endm=1 0.3 0.2; 激形幅值矩

    19、阵ss=zeros(1,le ngth(t);for i=1:le ngth(m)ss=ss+m(i)*si n( 2*i*pi*f( num)*t); %加谐波endlaohu( n:n+time( nu m)-1)=ss.*P(1:time( nu m);9給第num个乐音加上包络laohu (n:n+time( nu m)-1)=si n(2*pi*f( nu m)*t).*P(1:time( num);9給第num个乐音加上包络n=n+time( nu m);endsou nd(laohu,8000);plot(laohu);wavwrite(laohu, laohu 3)2.3.2运

    20、行结果分析音乐中加上二、三、四次谐波,基波幅度为 1,高次谐波幅度分别为0.2、0.3、0.1,如图为2-2波形图。图2-1 laohu2加谐波波形图3总结与体会通过这次的课程设计,加深了我们对数字信号处理所学知识的了解,增强了我们 对教学知识的运用和主动研究的能力。让我们掌握信号处理过程的仿真设计方法。 通过模仿老师所给的例题和所收集的资料例题,编写 Matlab仿真程序,主要利用matlab软件来实现对乐音信号的仿真,从而加深我们对模拟信号数字化处理的理解, 了解音乐信号时间特性、频率特性变化所带来的影响,初步学会改善音乐播放效果。 在运用所学知识和学习 Matlab软件的同时也学习到音乐

    21、的基本组成4参考文献1王力宁.MATLAB与通信仿真M.北京:人民邮电出版社,19992陈亚勇等.MATLAB信号处理详解M.北京:人民邮电出版社,20013高西全,丁玉美数字信号处理(第三版)M.西安:西安电子科技大学出版社, 20084程佩青 . 数字信号处理教程 (第四版 ) M 北京:清华大学出版社, 2013 余成波等数字信号处理及MATLAB实现(第二版)M.北京:清华大学出 版社, 2008 美Vinay K.lngle、John G.Proakis .数字信号处理 应用 Matla b(第 3版) M 北京:科学出版社, 20127关于目录的生成:参考“”, “目录”标题两字 ( 宋体,小二,加粗,居中, 段前段后 1 行 ) ;目录正文部分,全选编辑 ( 宋体 +Times new Roman ,小四, 1.25 倍行距 )补充说明:这是一次小论文,不要求各位同学能够一步到位,排版编 辑多么的漂亮,但是可以当作是下学期毕业设计论文的一次练习,一个学 习的过程,希望大家能尽可能用心做好。期末评分时,老师关键看的是论 文的内容,章节的安排。所以请同学们抓紧时间完成,能做多少做多少, 做到哪步算哪步,只要你回头检查时,可以无愧道“我尽力了” !


    注意事项

    本文(基于MATLAB的简单音乐合成.docx)为本站会员主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2022 冰点文档网站版权所有

    经营许可证编号:鄂ICP备2022015515号-1

    收起
    展开