实现一个基本的数字音乐合成器,并使用它来播放传统歌曲在一个三声音安排。指定采样率为2khz。保存歌曲作为MATLAB®时间表。
fs = 2 e3;t = 0:1 / fs: 0.3 - 1 / f;L = [0 130.81 146.83 164.81 174.61 196.00 220 246.94];M = [0 261.63 293.66 329.63 349.23 392.00 440 493.88];H = [0 523.25 587.33 659.25 698.46 783.99 880 987.77];注意= @ (f, g) (1 1 1) * sin(2 *π* (l (g) m (g) h (f)]的。* t);MEL = [3 2 1 2 3 3 3 0 2 2 2 2 0 3 5 5 0 3 2 1 2 3 3 3 3 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 1]+1;Acc = [3 0 5 0 3 0 3 3 2 0 2 2 3 0 5 5 3 0 5 3 3 3 0 2 3 0 1]+1;歌= [];为Kj = 1: song = [song note(mel(Kj),acc(Kj)) zeros(1,0,0.01*fs)];结束歌=歌曲' / (max (abs(歌曲))+ 0.1);%听到,输入声音(song,fs)曲调=时间表(秒((0:长度(歌曲)1)/ fs),歌曲);
开放信号分析仪并将时间表从Workspace浏览器拖到Signal表。点击显示网格创建一个2乘2的显示网格。选择顶部的两个显示器和左下角的显示器,单击光谱按钮,添加光谱视图。选择右下角显示,单击时频添加声谱图视图,单击时间删除时间视图。将歌曲拖到所有四个显示器上。选择右下角显示,并在光谱图Tab,指定时间分辨率为0.31秒(310毫秒),相邻段之间0%重叠。设置权限来 dB和 dB。
在分析仪选项卡上,单击重复的把这首歌复制三份。将副本重命名为高
,媒介
,低
通过双击的名字列。将副本移动到顶部两个位置,并显示左下角。
使用过滤器对重复信号进行预处理。
选择高
在signal表中单击它的名称。在分析仪选项卡上,单击高通滤波.在高通滤波选项卡出现时,输入一个450 Hz的通频带频率并将陡度增加到0.95。点击高通滤波.
选择媒介
在signal表中单击它的名称。在分析仪选项卡上,单击预处理▼并选择带通.在带通选项卡中,分别输入230hz和450hz作为上、下通频带频率。将陡度增加到0.95。点击带通.
选择低
在signal表中单击它的名称。在分析仪选项卡上,单击低通滤波器.在低通滤波器标签出现时,输入一个230 Hz的通频带频率,并将陡度增加到0.95。点击低通滤波器.
在三个包含过滤信号的显示器上:
通过清除其名称旁边的复选框来删除原始信号。
在显示选项卡上,单击时频添加一个声谱图视图,单击时间删除时间视图。
在光谱图选项卡,指定时间分辨率为0.31秒,相邻段之间的重叠为0%。设置权限来 dB和 dB。
通过点击它们来选择三个过滤的信号的名字列。在分析仪选项卡上,单击出口并将信号保存到一个mat文件中music.mat
.在MATLAB中,将文件加载到工作区中。画出这三个信号的频谱。
负载音乐pspectrum(低)在pspectrum(媒介)pspectrum(高)从
要听不同的声音,打字% sound(low.low,fs), pause(5), sound(medium.medium,fs), pause(5), sound(high.high,fs)