2023-05-29 23:52:23 +08:00
|
|
|
import soundfile
|
2023-08-28 15:08:31 +08:00
|
|
|
|
2023-08-29 15:14:11 +08:00
|
|
|
from ..infer.lib.infer_pack.onnx_inference import OnnxRVC
|
2023-05-29 23:52:23 +08:00
|
|
|
|
|
|
|
hop_size = 512
|
2023-05-30 15:22:53 +08:00
|
|
|
sampling_rate = 40000 # 采样率
|
|
|
|
f0_up_key = 0 # 升降调
|
|
|
|
sid = 0 # 角色ID
|
|
|
|
f0_method = "dio" # F0提取算法
|
|
|
|
model_path = "ShirohaRVC.onnx" # 模型的完整路径
|
2024-01-26 16:10:04 +08:00
|
|
|
vec_name = (
|
|
|
|
"vec-256-layer-9" # 内部自动补齐为 f"pretrained/{vec_name}.onnx" 需要onnx的vec模型
|
|
|
|
)
|
2023-05-30 15:22:53 +08:00
|
|
|
wav_path = "123.wav" # 输入路径或ByteIO实例
|
|
|
|
out_path = "out.wav" # 输出路径或ByteIO实例
|
2023-05-29 23:52:23 +08:00
|
|
|
|
2023-05-30 15:22:53 +08:00
|
|
|
model = OnnxRVC(
|
|
|
|
model_path, vec_path=vec_name, sr=sampling_rate, hop_size=hop_size, device="cuda"
|
|
|
|
)
|
2023-05-29 23:52:23 +08:00
|
|
|
|
|
|
|
audio = model.inference(wav_path, sid, f0_method=f0_method, f0_up_key=f0_up_key)
|
|
|
|
|
2023-05-30 15:22:53 +08:00
|
|
|
soundfile.write(out_path, audio, sampling_rate)
|