java 音频分析工具_代码分析JAVA中PCM人声音频变声处理

项目中需要用到对PCM人声音频数据进行变声处理。苦苦挣扎了一周终于找到了纯java实现的一套框架——TarsosDSP。功能非常强大!可以实时音频处理!当然我只用到了对文件处理。实际上逻辑是一样的

TarsosDSP的github地址:https://github.com/JorenSix/TarsosDSP 将它整合至自己的项目工程。

具体Java工具类代码:

/**

* 变声

* @param rawPcmInputStream 原始PCM数据输入流

* @param speedFactor 变速率 (0,2) 大于1为加快语速,小于1为放慢语速

* @param rateFactor 音调变化率 (0,2) 大于1为降低音调(深沉),小于1为提升音调(尖锐)

* @return 变声后的PCM数据输入流

*/

public static InputStream speechPitchShift(final InputStream rawPcmInputStream,doublwww.cppcns.come speedFactor,double rateFactor) {

TarsosDSPAudioFormat format = new TarsosDSPAudioFormat(16000,16,1,true,false);

AudioInputStream inputStream = new AudioInputStream(rawPcmInputStream, JVMAudioInputStream.toAudioFormat(format),AudioSystem.NOT_SPECIFIED);

JVMAudioInputStream stream = new JVMAudioInputStream(inputStream);

WaveformSimilarityBasedOverlapAdd w = new WaveformSimilarityBasedOverlapAdd(WaveformSimilarityBasedOverlapAdd.Parameters.speechDefaults(speedFactor, 16000));

int inputBufferSize = w.getInputBufferSize();

int overlap = w.getOverlap();

AudioDispatcher dispatcher = new AudioDispatcher(stream, inputBufferSize ,overlap);

w.setDispatcher(dispatcher);

AudioOutputToByhttp://www.cppcns.comteArray out = new AudioOutputToByteArray();

dispatcher.addAudioProcessor(w);

dispatcher.addAudioProcessor(new RateTransposer(rateFactor));

dispatcher.addAudioProcessor(out);

dispatcher.run();

return new ByteArrayInputStream(out.getData());

}

其中数据转录器(AudioOutputToByteArray)代码如下:

public class AudioOutputToByteArray implements AudioProcesshttp://www.cppcns.comor {

private boolean isDone = false;

private byte[] out = null;

private ByteArrayOutputStream bos;

public AudioOutputToByteArray() {

bos = new ByteArrayOutputStream();

}

public byte[] getData() {

while (!isDone && out == null) {

try {

Thread.sleep(10);

} catch (InterruptedException ignored) {}

}

return out;

}

@Override

public boolean process(AudioEvent audioEvent) {

bos.write(audioEvent.getByteBuffer(),0,audioEvent.getByteBuffer().length);

return true;

}

@Override

public void processingFinished() {

out = bos.toByteArray().clone();

bos = null;

isDone = true;

}

}

可以通过这个工具方法播放音频:

/**

* 播放PCM

*

* 不要在非桌面环境调用。。。鬼知道会发生什么

* @param rawPcmInputStream 原始PCM数据输入流

* @throws LineUnavailableException

*/

public static void play(final InputStream rawPcmInputStream) throws LineUnavailableException {

TarsosDSPAudioFormat format = new TarsosDSPAudioFormat(16000,16,1,true,false);

AudioInputStream inputStream = new AudioInputStream(rawPcmInputStrjAqNyLeam, JVMAudioInputStream.toAudioFormat(format),AudioSystem.NOT_SPECIFIED);

JVMAudioInputStream stream = new JVMAudioInputStream(inputStream);

AudioDispatcher dispatcher = new AudioDispatcjAqNyLher(stream, 1024 ,0);

dispatcher.addAudioProcessor(new AudioPlayer(format,1024));

dispatcher.run();

}

本文标题: 代码分析JAVA中PCM人声音频变声处理

本文地址: http://www.cppcns.com/ruanjian/java/217743.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值