import torch from voice_changer.RVC.deviceManager.DeviceManager import DeviceManager from voice_changer.RVC.inferencer.Inferencer import Inferencer from infer_pack.models import ( # type:ignore SynthesizerTrnMs256NSFsid, ) class RVCInferencer(Inferencer): def loadModel(self, file: str, gpu: int): dev = DeviceManager.get_instance().getDevice(gpu) isHalf = DeviceManager.get_instance().halfPrecisionAvailable(gpu) cpt = torch.load(file, map_location="cpu") model = SynthesizerTrnMs256NSFsid(*cpt["config"], is_half=isHalf) model.eval() model.load_state_dict(cpt["weight"], strict=False) model = model.to(dev) if isHalf: model = model.half() self.model = model return self def infer( self, feats: torch.Tensor, pitch_length: torch.Tensor, pitch: torch.Tensor, pitchf: torch.Tensor, sid: torch.Tensor, ) -> torch.Tensor: return self.model.infer(feats, pitch_length, pitch, pitchf, sid)