当前位置: 首页 > news >正文

数字人部署之VITS+Wav2lip数据流转处理以提高实时性

一、模型
VITS模型训练教程VITS-从零开始微调(finetune)训练并部署指南-支持本地云端

Wav2lip是2D数字人,可参考训练嘴型同步模型Wav2Lip

PS:以上模型都是开源可用。

二. VITS数据处理问题

  1. VITS模型的输出为一维的numpy类型数据,官方开源代码中给出的处理方法为使用scipy.io.wavfile提供将numpy数据采样并存为音频文件,代码示例为
    if language is not None:text = language_marks[language] + text + language_marks[language]speaker_id = speaker_ids[spk]stn_tst = get_text(text, hps, False)with no_grad():x_tst = stn_tst.unsqueeze(0).to(device)x_tst_lengths = LongTensor([stn_tst.size(0)]).to(device)sid = LongTensor([speaker_id]).to(device)audio = net_g.infer(x_tst, x_tst_lengths, sid=sid, noise_scale=noise_scale, noise_scale_w=noise_scale_w,length_scale=1.0 / length)[0][0, 0].data.cpu().float().numpy()del stn_tst, x_tst, x_tst_lengths, sidwavf.write(str(output_dir)+"/"+output_name+".wav",hps.data.sampling_rate,audio)

但是如果要将该模型作为数字人的音频克隆输出,上述代码的保存方式对于实时性形成较大阻碍,我们应该考虑如何不写入文件直接传输到如Web前端进行播放音频。经过思考,若前端使用如下代码解析音频,

<div><audio id="audio" controls autoplay style="display: none;"></audio>
</div>const audioEl = document.querySelector('audio')
audioEl.src= "data:audio/mp3;base64,"+ messageData

该前端不可解析numpy类型数据,并且如果直接将numpy类型音频数据直接转为字节类型数据并回传到前端也是不可行的。我们仔细阅读开源模型提供的解决方案中出现的wavf.write函数,发现,我们可以直接从该函数的实现进行稍微修改,即可实现numpy类型音频数据不写入文件直接传输到如Web前端进行播放音频,修改结果如下所示

    # 采样header_e = b'RIFF'header_m = b'\x00\x00\x00\x00'# 音频参数fs = 16000format_tag = 0x0003channels = 1bit_depth = _audio.dtype.itemsize * 8bytes_per_second = fs * ( bit_depth // 8) * channelsblock_align = channels * (bit_depth // 8)fmt_chunk_data = struct.pack('<HHIIHH', format_tag, channels, fs, bytes_per_second, block_align, bit_depth)fmt_chunk_data += b'\x00\x00'header_l = b'WAVEfmt ' + struct.pack('<I', len(fmt_chunk_data)) + fmt_chunk_data + b'fact' + struct.pack('<II', 4, _audio.shape[0])# numpy类型音频数据data = b'data'pre_data = struct.pack('<I', _audio.nbytes)audio_data = header_e + header_m + header_l + data + pre_data + _audio.ravel().view('b').datasize = len(audio_data)_len = struct.pack('<I', size - 8)audio_data = header_e + _len + header_l + data + pre_data + _audio.ravel().view('b').data

上述代码的最后一行生成的audio_data 变量即为可回传到前端进行正常播放的音频字节信息。由此也可以看出为什么直接将numpy类型音频数据直接转为字节类型数据并回传到前端也是不可行的,其原因在于音频数据存在固定保存结构。

三、VITS输出结构驱动Wav2lip

  1. 由于VITS模型的输出为numpy类型的音频数据,Wav2lip按照官方给出的开源处理方式为输入一个音频文件,然后将该音频文件以numpy形式进行读取,然后转成梅尔图谱的形式,与图片进行batch_size匹配后输入到网络中驱动相关帧的嘴型变化。如果直接读取音频文件将会是一个耗时的任务,为此,我们应该直接将VITS的numpy类型数据直接传入到Wav2lip,从而跳过读取文件和形成numpy类型的数据过程,减少工程实现上的时间。
  2. 针对Wav2lip模型的优化方案
    后续给出。
http://www.lryc.cn/news/229634.html

相关文章:

  • GPT 学习法:复杂文献轻松的完美理解、在庞大的不确性中找到确定性
  • 前端简单的爱心形状
  • acwing算法基础之数学知识--求数a的欧拉函数值phi(a)
  • Jenkins的介绍与相关配置
  • 开源网安受邀参加网络空间安全合作与发展论坛,为软件开发安全建设献计献策
  • arcgis提取栅格有效边界
  • 后端接口性能优化分析-问题发现问题定义
  • 中国首个通过ASIL D认证的IP发布,国产芯片供应商的机会来了
  • [单片机课程设计报告汇总] 单片机设计报告常用硬件元器件描述
  • Docker学习——⑧
  • 力扣刷题第二十一天--栈与队列
  • Python基础-解释器安装
  • MySQL(14):视图
  • Blazor 附件上传和下载功能
  • Git 安装配置
  • Center Smoothing Certified Robustness for Networks with Structured Outputs
  • C#几种截取字符串的方法
  • 【PG】PostgreSQL高可用方案repmgr部署(非常详细)
  • Linux Makefile配置问题
  • k8s篇之underlay网络和overlay区别
  • 掉瓶子小游戏
  • Elasticsearch7 入门 进阶
  • 你是怎么封装微信小程序的数据请求的?
  • C++ vector中capacity()和size() 的区别
  • 【Redis】redis-server和redis-cli
  • 【系统架构设计】架构核心知识: 2.4 系统建模过程和系统设计
  • 企业电子招标采购系统源码之从供应商管理到采购招投标、采购合同、采购执行的全过程数字化管理
  • ubantu libssl.so.1.1: cannot open shared object file
  • python matlplotlib/seaborn 绘制曲线的平均值标准差阴影图
  • 【Linux基础IO篇】深入理解文件系统、动静态库