我正在申请大学音乐专业。我正在考虑的一个功能是在不改变音高的情况下减慢音乐播放速度。我已经在商业软件中看到了这一点,但找不到任何类似的库或开源应用程序。
- 那里有图书馆吗?
- 如何从各种文件格式从头开始完成这项工作?
注意:我在 java 中工作,但不反对改变语言。
时间延长是相当困难的。您越减慢或加快声音的速度,您获得的伪影就越多。如果你想知道它们听起来像什么,请听 Fat Boy Slim 的“The Rockafeller Skank”。有很多方法可以做到这一点,它们都有自己的长处和短处。数学会变得非常复杂。这就是为什么有这么多专有算法的原因。
这个页面比我能解释的更清楚一些,并链接到 Dirac 库。 http://www.dspdimension.com/admin/time-pitch-overview/
我找到了这个用于进行音高转换/时间拉伸的 Java 代码链接 http://www.adetorres.com/keychanger/KeyChangerReadme.html
我使用soundstretch来加快播客的速度,效果很好,但还没有在音乐上尝试过。
该站点解释了它是如何在物理世界中完成的: http://www.wendycarlos.com/other/Eltro-1967/index.html
我不知道你会如何在软件中模拟它......我会继续寻找
一种方法是在不改变源的采样率的情况下将采样率加倍。(低质量示例,但易于实现。注意:您也可以降低采样率)。
查看任何与相位声码器相关的数学。
另一种常见的方法是创建一个 fft bin 数组,用于存储预定声音间隔的数据。然后,您可以选择迭代箱的速度,并且您可以根据您的选择重新合成该音频数据,从而使您可以根据需要延长声音的一小段。
Audacity 开箱即用,而且是免费的。还有几个免费的 mp3 播放器插件。显然,使用 mp3 很容易做到,因为它已经在频域中编码。