Project Icon

LPCNet

低复杂度神经语音合成与压缩算法

LPCNet是一种基于WaveRNN的低复杂度语音合成算法实现。通过结合线性预测技术,该项目在普通CPU上实现高质量语音合成,并支持1.6 kb/s的超低比特率压缩。LPCNet提供开源代码用于语音合成和编码研究,包括模型训练、优化以及实时包损失隐藏等功能,为语音技术研究和应用奠定基础。

LPCNet

基于WaveRNN的LPCNet算法的低复杂度实现,详见以下论文:

关于LPCNet在编码/PLC应用方面的内容,请参阅:

简介

这是一个正在进行中的软件项目,旨在通过将线性预测技术应用于WaveRNN来研究低CPU复杂度的语音合成和压缩算法。在具有SIMD支持(目前支持SSE2、SSSE3、AVX、AVX2/FMA、NEON)的普通CPU上(约3 GFLOP)可以合成高质量语音。该代码还支持1.6 kb/s的超低比特率压缩。

这个BSD许可的软件使用C语言和Python/Keras编写。对于训练,建议使用GTX 1080 Ti或更好的显卡。

此软件是基于LPCNet/WaveRNN的语音合成和编码的开源起点。

使用现有软件

您可以使用以下命令构建代码:

./autogen.sh
./configure
make

请注意,autogen.sh脚本用于从Git构建,并将自动下载最新模型(模型太大,无法放入Git)。默认情况下,LPCNet将尝试使用AVX*/Neon上的8位点积指令来加速推理。要禁用此功能(例如,为了避免重新训练时的量化效应),请向configure脚本添加--disable-dot-product。LPCNet在ARMv7架构上尚未完全实现某些整数操作,因此目前在32位ARM上编译时也需要使用--disable-dot-product。

强烈建议在运行configure之前设置CFLAGS环境变量以启用AVX或NEON,否则不会进行矢量化,代码运行速度会非常慢。在最新的x86 CPU上,可以使用类似以下的命令:

export CFLAGS='-Ofast -g -march=native'

在ARM上,可以使用以下命令启用Neon:

export CFLAGS='-Ofast -g -mfpu=neon'

虽然不是严格要求,但-Ofast标志将有助于自动矢量化,特别是对于在没有-ffast-math(由-Ofast启用)的情况下无法优化的点积运算。此外,在x86上使用-falign-loops=32已被证明有帮助。

您可以使用lpcnet_demo应用程序测试LPCNet的功能。要编码文件:

./lpcnet_demo -encode input.pcm compressed.bin

其中input.pcm是以16 kHz采样的16位(机器字节序)PCM文件。原始压缩数据(无头)写入compressed.bin,每40毫秒数据包包含8字节。

要解码:

./lpcnet_demo -decode compressed.bin output.pcm

其中output.pcm也是16位、16 kHz的PCM文件。

或者,您可以使用-features替代-encode,使用-synthesis替代-decode来运行未压缩的分析/合成。 同样的功能也以库的形式提供。有关API,请参见include/lpcnet.h。

要尝试丢包隐藏(PLC),首先需要一个PLC模型,可以通过以下方式获取:

./download_model.sh plc-3b1eab4

或(用于PLC挑战提交):

./download_model.sh plc_challenge

可以使用以下命令测试PLC:

./lpcnet_demo -plc_file noncausal_dc error_pattern.txt input.pcm output.pcm

其中error_pattern.txt是一个文本文件,每个20毫秒数据包对应一个条目,1表示"数据包丢失",0表示"数据包未丢失"。 noncausal_dc是非因果(5毫秒前瞻)且对DC偏移进行特殊处理的版本。也可以使用"noncausal"、"causal"或"causal_dc"。

训练新模型

此代码库也适用于研究,可以训练新模型。以下是具体步骤:

  1. 设置带有GPU的Keras系统。

  2. 生成训练数据:

    ./dump_data -train input.s16 features.f32 data.s16
    

    其中第一个文件包含16 kHz 16位原始PCM音频(无头),其他文件是输出文件。该程序使用不同的滤波器多次处理数据,以生成大量训练数据。

  3. 现在您已经有了文件,使用以下命令进行训练:

    python3 training_tf2/train_lpcnet.py features.f32 data.s16 model_name
    

    它将为每次迭代生成一个h5文件,以model_name作为前缀。如果出现"Failed to allocate RNN reserve space"消息而停止,请尝试为train_lpcnet.py指定更小的--batch-size。

  4. 您可以使用Python和GPU卡合成语音(非常慢):

    ./dump_data -test test_input.s16 test_features.f32
    ./training_tf2/test_lpcnet.py lpcnet_model_name.h5 test_features.f32 test.s16
    
  5. 或在CPU上使用C语言(C推理速度更快): 首先提取模型文件nnet_data.h和nnet_data.c

    ./training_tf2/dump_lpcnet.py lpcnet_model_name.h5
    

    并将生成的nnet_data.*文件移动到src/目录。 然后只需重新构建软件并按上述说明使用lpcnet_demo。

训练用语音材料

可以从开放语音和语言资源获取适合的训练材料。有关合适的训练数据的详细信息,请参阅datasets.txt文件。

进一步阅读

  1. LPCNet:DSP增强的神经语音合成
  2. 使用LPCNet实现1.6 kb/s的实时宽带神经声码器
  3. 示例模型文件(请检查兼容性):https://media.xiph.org/lpcnet/data/
项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号