声音克隆GPT-SoVITS 2.0软件和详细的使用教程!

embedded/2024/12/22 23:46:37/

天命人,请允许我先蹭个热点!

原始声音:

播放

克隆声音:

播放

文章写了一半,被《黑神话悟空》刷屏了。突发奇想,用里面的声音来做个素材试试看。

B站捞了一点声音素材,随便剪一剪,训练一把过,没有调优,就直接拿来用了。

情绪还差点意思,音色克隆的还不错。

下面进入正题!

声音克隆项目迎来2.0版本了!

目前,这个软件,应该是我们能接触的最强的声音克隆软件。

主要特点是高效,简单,效果也好

快速模式,只要十秒音频,无需训练,直接克隆声音。

训练模型,也只要一分钟的左右的音频,十几分钟时间就能搞定。

本文,就不在过多介绍这个项目了,可以参考之前的两篇文章。

声音克隆:一个牛逼的新项目,入手难度低,相似度高!》

声音克隆: GPT-SoVITS软件更新+新教程!》

今天主要是告诉大家,软件更新了,然后软件和教程一并奉上。

软件更新

从年初发布一个版本,到现在已经过去大半年了,其中有不少更新。根据官网文档介绍。

V1版本的主要功能和V2版本的主要更新如下。

V1主要功能:

  • 由参考音频的情感、音色、语速控制合成音频的情感、音色、语速
  • 可以少量语音微调训练,也可不训练直接推理
  • 可以跨语种生成,即参考音频(训练集)和推理文本的语种为不同语种

V2主要更新:

  • 低音质参考音频合成出来音质更好
  • 底膜训练集增加到5k小时,zero shot性能更好音色更像,所需数据集更少
  • 增加了韩语和粤语,中日英韩粤5个语种均可跨语种合成
  • 更好的文本前端,V2中英文加入多音字优化。

当然,这只是主要更新,还有很多细节上的完善和优化。比如UI上使用起来明显简单了很多。优化了预设值,让整个训练过程,更不容易出错了。

使用教程

发一个软件很简单,只要复制黏贴就可以了。但是要把整个流程说清楚还是要花点时间。

离上一次写教程时间已经有很长了,我也是花了好一会儿才把整个流程回忆起来。我觉得有必要重写一个详细的使用教程,其实对我自己而言是详细的笔记。

脑子越来越不行了,常常想不起自己写的代码和文章,只能靠自己的笔记引导自己了。哈哈!

给未来的自己的看的文章,我肯定会写的比较认真。每个环节的输出输出关注点我都会写清楚。但是为了减少干扰,一些不必要,不影响主流程的旁支,我会砍掉。

抓主线,可以降低大家的脑力消耗。

开始前,简单的说一下,硬件需求。

推荐配置为:一台装有Windows11和英伟达独立显卡(显存6G+)的中高配电脑。

相比大语音模型和大的绘画模型,这个项目配置要求并不是很高。Linux和Mac用户可以看官方文档,用也是可以用滴,我就不专门做介绍了。

软件见文末,获取软件后,我就进入正题了。

整个使用过程可以分为素材预处理和微调训练两个部分,微调训练又分为数据格式化,模型微调,模型推理三个部分。

素材预处理

这个阶段不是核心阶段,但是也至关重要。首先我们需要准备一个段60秒左右的音频,我这里用的还是从别人那里搞来的那个音频,比较好用。(后来在整得悟空的旁白)

这个音频需要是单个人说话的音频,没有噪音,没有配音,没有背景音乐。

如果有的话,需要先进行预处理。这个软件也自带了一个使用UVR5进行人声伴奏分离,去混响,去延迟的工具。

如何得到一个干净的声音,其实也是一个复杂的问题。展开可以讲好多,所以就不展开了。

直接找一段干净的声音,把这个流程先跑通更重要。

另外,提一嘴,剪映的降噪和人声分离使用方便效果也不错。

当准备好声音之后,就可以开始进行预处理了。

预处理主要做两件事情:切割和转换

切割

切割是把一个长的音频文件,切割成若干段短的音频,方便后续处理。

具体操作如下图:

①输入音频文件地址

首先输入声音文件的地址,这个地址可以在文件管理器的地址栏复制。如果你有多个声音文件,这里可以填写文件夹的路径,如果你是单个,就写具体的单个文件的路径。

比如我这里用的是单个文件,名字叫nana.wav。所以我的路径,是以这个文件为结尾。

如果你是文件夹里放了很多声音文件,那么这里只要直接写到output这个文件夹就可以了。

当然,放音频的文件夹不一定是output,可以在任意位置,用任意名称。只要这里配置的路径正确即可。

②输入保存地址

这个地址会自动设置,最好不要改变。只要记住这个路径在output文件夹下面的slicer_opt文件里面就可以了。

③点击开启语音切割。

设置好两个地址之后,还有8参数可以调整,但是对于不懂的人来说,默认配置就是最佳配置,所以除非你知道他是干什么,否则就不要修改。

所以,只要设置好上面两个地址,然后直接点击巨大的黄色按钮就可以了。

运行结束之后,界面底部会显示“切割结束”。

为了验证操作是否真的成功,可以查看output\slicer_opt文件夹。

里面有很多wav文件,就证明这个步骤已经彻彻底底的成功了。

转换

其实就是ASR处理,生成音频文件对应的文字。然后生成一个带有声音文件地址,对应文字内容,对应语言类型的清单。保存在一个叫slicer_pot.list的文本文件里面。

ASR(Automatic Speech Recognition,即自动语音识别)是一种将语音信号转化为文本的技术。

具体操作如下图:

这个步骤,其实一切参数也是默认的,直接点击开启离线批量ASR按钮就可以了。

① 输入文件夹路径,就是我们上一步的输出文件夹路径,里面放的是音频片段。

②输出文件夹路径,执行完成后会在这里生成一个.list文件。

③ASR模型选择。中文默认用达摩ASR,英文用 OpenAI 的 Whisper 。

④ASR语音设置。中文汉语使用zh,粤语的话,使用yue。如果前面选的是Whisper,这里会有5种语言的候选项。

⑤开始离线批量ASR。点击按钮,就立马开始工作了。

这个过程并不会消耗太多,应该可以很快完成。

完成之后会在output\asr_opt下面生成一个叫slicer_opt.list的文本文件。

可以用任何文本工具打开,里面的内容大致如下:

output\slicer_opt\nana.wav_0000000000_0000133440.wav|slicer_opt|ZH|在十二岁以前呢,我从来没有想过自己会演戏。
output\slicer_opt\nana.wav_0000133440_0000288320.wav|slicer_opt|ZH|我八岁的时候,立志成为一个像马悠悠一样的大提琴演奏家。

可以看到,每行通过“|”符号分割成了四部分。这四部分分别是路径,slicer_opt,语言类型,文字内容。

后面的步骤会用到这个文件。

语音文本校对

这个步骤,其实对上一个步骤的补充。如果你的声音质量比较好,自动识别转换的效果也会相当不错,就不需要手动修改了。

如果你对识别效果没有信心,可以勾选“是否打开打标WebUI”。

勾选之前,需要先填写.list文件的路径。这个路径一般也是自动生成。如果你有多个项目,可以手动指定路径。

勾选之后,会自动打开一个新的网页。网页显示内容如下:

只要比对左边的文字和右边声音中说话的内容是否一致,一致就不用改。如果不一致,修改左边的文字内容。

全部检查修改完成之后,保存文件就好了。

数据格式化

素材预处理完成之后,就可以对生成的数据进行格式化了。

点击“1-GPT-SoVITS-TTS”这个标签页,切换到第二个大步骤的功能页面。

切换之后,需要修改一下实验名。命名没有特别要求,好记就行。最好是英文。

另外,可以看到显卡型号,版本默认勾选V2。

另外还有G和D这两个预训练模型的路径,这里会自动设置,无需修改。

开始之前先到GPT_SoVITS\pretrained_models文件下面确认一下,已经包含如下的模型文件。

正常情况下,一键运行包里面已经包含了这些模型,你只要知道,下面的步骤需要用的模型放在这里就可以了。

然后继续往下看,这里又分成了三个TAB,分别是格式化,微调训练,推理。

下面我们要做的是格式化。

格式化需要指定两个路径,一个是标注文件地址,一个切割后音频文件所在地址。

同时也分成了三个小步骤,这里实际操作比较简单。

所有参数会自动生成。只要点击左下方的“开启一键三连”按钮即可。

执行日志如下:

执行过程如上,就证明运行正常,如果出现Error就是正面出错了。错误一般是路径问题导致!

执行成功之后,logs/nana文件下会出现1-6的文件夹和文件。

文件夹nana是我们上面填写的实验名。

日志和文件生成全部正常,就可以进行下一步了。

微调训练

总的来说,前面的所有步骤,都是准备工作。准备工作做完之后,终于进入正题了。

正题就是训练,这个训练其实是基于预训练模型的微调训练。这里需要做两类训练,一个是SoVITS训练,一个是GPT训练。

点击1B-微调训练切换到微调界面,然后按下图进行操作。

SoVITS训练和 GPT训练的具体操作如下:

这两个训练,会需要用到显卡,相对来说是整个过程中耗时比较多的部分。

有英伟达独立显卡,显卡还可以的情况下,其实也很快。比如在3060下面,只要几分钟就搞定了。

相对动不动就几个小时,几天,几个月的训练。这个微调可以说是极速微调了。

这个步骤也有一些参数,其实大部分情况下无需修改,可以适当调Batch_size 和total_epoch。数值偏离预设值很大的尝试,基本没什么必要。

这两个训练,不分前后,可以单独训练。

SoVITS训练日志如下:

训练过程成中会生成 logs_s2文件夹。

GPT训练训练日志如下:

训练过程成中会生成 logs_s1文件夹。

训练完成之后,页面上会有“XX训练完成”的提示。页面提示不一定准确,可以看黑色日志窗口,只要没有出现error,exception这些异常提示,输出内容简单清晰,那就是成功。

运行成功之后会生成对应的模型。

模型保存路径如下:

我们使用的是V2训练,所以保存模型的文件夹以V2结尾。如果训练配置中,配置的为V1版本,模型就会保存在上面的文件夹中了。

这一切,都是全自动完成,无需你手动创建文件。

打开这两个文件夹,确认里面已经生成了模型文件。就基本证明微调训练成功了,接下来就是验证微调效果。

推理

所谓推理,其实就是应用训练好的模型。

点击1C-推理切换到微调界面,然后按下图进行操作:

①刷新模型路径,这个别忘了点。只有刷新后才能看到自己训练的模型。

②选择GPT模型,一般选数字最大的,比如这里的e15。

③选择SoVITS模型,同样道理,选尾巴上数字最大的模型。

④勾选开启TTS推理界面,勾选后会自动跳出一个新的界面。

在跳出的新界面中,依旧有刷新模型和模型列表选项。前面设置过,这里就不用设置了。如果你有很多模型的情况下,可以在这个界面单独切换模型。

在这个界面中,主要完成两个操作,一个是设置参考声,一个是填写文字合成克隆声音。

参考声音设置:

在③的地方上传一个几秒钟的声音文件作为参考声音,然后在④的地方输入这个参考声音对应的文本内容。这一部分的设置就算完成了。

④这里的操作也并非必须,不填也不会爆炸。

参考声音,可以从前面切割好的音频文件中随便选一个。当然最好选清晰且有代表性的片段。所谓代表性,就是最能体现这个克隆对象音色的部分。

设置好参考对象之后,就可以生成克隆声音了。

具体设置如下:

①输入文本,就是输入要合成的内容。稍微长点也没关系,会自动切割处理。

②设置参数,参数一般不用改,输入的是中文,语言就选中文。怎么切,是指点文本切割的方式,语速可以根据自己的需要调整。K,P,T参数一般不用调。

③合成语音,点击按钮,一会儿就搞定了。

④播放语音,最后点击播放验证效果。

到这里,整个声音克隆的准备,微调,合成就已经完成了。GPT-SoVITS的声音克隆,是基于文本转语音的克隆方式,而不是直接改变语音的音色。直接改变音色,我们一般归类为变声,比如我们之前介绍的RVC项目,这个项目类似的功能还在“施工中”可以期待一下。

因为我常年倒腾这些项目,已经练就了一些被动避坑技能。所以在使用这个项目的过程中非常丝滑,并没有遇到任何问题。所以也没有太多异常处理建议。如果你们遇到了,可以留言,或者阅读官方手册。

从拿到软件,开始自己跑demo,记录完整的过程,写文章,修改内容,花了三天时间,打了4000多字。看到这里的可以动动手指哦。

收工收工,玩得愉快!

软件和官方文档

见博客文末:声音克隆GPT-SoVITS 2.0软件和详细的使用教程! – 托尼不是塔克


http://www.ppmy.cn/embedded/99547.html

相关文章

Tomcat安装部署

简介 Tomcat 是由 Apache 开发的一个 Servlet 容器,实现了对 Servlet 和 JSP 的支持,并提供了作为Web服务器的一些特有功能,如Tomcat管理和控制平台、安全域管理和Tomcat阀等。 简单来说,Tomcat是一个WEB应用程序的托管平台&…

计算机视觉实战详解:从基础到前沿

引言: 计算机视觉是人工智能领域中最激动人心的分支之一。它赋予机器以"眼睛",使其能够理解和处理视觉信息。本专栏旨在带领读者从基础知识出发,逐步深入计算机视觉的核心概念和实际应用,最终掌握前沿技术。无论您是初学者还是有一定基础的开发者,这个专栏都将为您提…

Android笔试面试题AI答之Kotlin(16)

文章目录 74. 解释何时需要泛型类型形参约束 ?示例 75. Kotlin reified实化类参数的原理 ?内联函数(Inline Functions)类型具体化(Type Specialization)实化类参数(Reified Type Parameters&…

html+css+js实现登录界面设计

在现代网页设计中,创建一个功能齐全且用户友好的登录页面是至关重要的。本文将介绍如何使用 HTML 和 CSS 创建一个简单而有效的登录页面,包括验证码、记住密码选项及忘记密码链接。 1. HTML 结构 我们将从 HTML 代码开始,构建一个包含登录表…

LINUX考试知识点总结

一.填空题 1. 文件权限 — rwx rwx rwx 文件 类型 user group other d rwx rwx rwx 文件夹 2.文件编辑器的基本操作 w保存 q退出 q!强制退出 3.文件链接命令 软链接:ln -s 目标 链接名 硬链接:ln 4.创建文件/文件夹 touch mkdir 5.文件不同对比…

把握国产替代机遇,水浸传感器厂家哪家强?

一旦发生漏水,不仅会影响到人们的正常生活,更会导致一些工业生产场景出现重大财产损失。因此,水浸传感器成为了保障安全生产必不可缺的一环。水浸传感器厂家哪家强? 水浸传感器的历史可以追溯到上世纪60年代,等到80年代…

GitFlow的四个分支

GitFlow中有四个分支: 常规分支:master & develop master主分支储存正式发布的历史,develop开发分支作为功能开发集成分支功能分支:feature 每个feature分支都对应一个要实现的具体功能或者改进点,这样可以保持每…

django学习入门系列之第九点《MySQL命令介绍三》

文章目录 数据行操作1 新增数据2 删除数据3 修改数据4 查询数据 小节往期回顾 数据行操作 1 新增数据 insert into 表名(列名,列名) values(值,值) insert into 表名(列名,列名) values(值,值),(值&#…