Matlab音频变速不变调、变调不变速(Phase Vocoder)

其他文章有讲过一些方法,有OLA、WSOLA算法、LSEE-MSTFTM、Phase Vocoder(相位声码器)等等,但都是讲了个大概,没一个能说清楚的,代码就更没有了。找了一个国外的Phase Vocoder变速、变调的方法,原理如下:

http://www.guitarpitchshifter.com/algorithm.html

代码如下:

http://www.guitarpitchshifter.com/matlab.html

其中变调部分(升降n个半音),可以拿来直接运行。

变速可以通过变调代码的前面一大半部分实现,其中变速的倍数用t来表示,t作为函数的输入,函数中的step修改如下:

step=12log_2^{\cfrac{1}{t}}\\ alpha=2^{\cfrac{step}{12}}(=-t)

主函数后面去掉

% Resample with linearinterpolation
outputTime = interp1((0:(length(outputTimeStretched)-1)),outputTimeStretched,(0:alpha:(length(outputTimeStretched)-1)),'linear');

% Return the result
outputVector = outputTime;

这样即可实现变速不变调和变调不变速。

具体原理,尤其是频率和相位部分真是太™难懂了,不如直接抄代码(逃

评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值