12音的基础音一拍为440Hz,每2^(1/12)个基础音升一个音律,这里使用声音的采样率为8192来播放,
要模拟音律,就好比弹钢琴时,刚按下键时,声音音量大,之后慢慢变小到消失
这些声音波形,使用linspace函数将x的点收集起来
x = linspace(0,2*pi,8192);
在gen_wave.m文件中,将函数名改成gen_wave,完整代码如下:
function y = gen_wave( tone,rhythm )Fs = 8192;x = linspace(0,2*pi*rhythm,floor(Fs*rhythm));temp = 440*2^(tone/12)*x;y = sin(temp).*(1-x/(rhythm*2*pi));
end
再新建一个script1.m脚本文件,测试一下音律播放,声音播放采用sound函数
Fs = 8192;y = [gen_wave(0,1)];
for i=1:12y = [y,gen_wave(i,1)];
endsound(y,Fs);
来看下播放的波形,调用plot函数来画一下
plot(y);
本文发布于:2024-01-28 21:13:55,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170644764010326.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |