mirror of
https://github.com/RVC-Project/Retrieval-based-Voice-Conversion-WebUI.git
synced 2025-01-19 21:00:11 +08:00
e9dd11bddb
* Optimize latency (#1259) * add attribute: configs/config.py Optimize latency: tools/rvc_for_realtime.py * new file: assets/Synthesizer_inputs.pth * fix: configs/config.py fix: tools/rvc_for_realtime.py * fix bug: infer/lib/infer_pack/models.py * new file: assets/hubert_inputs.pth new file: assets/rmvpe_inputs.pth modified: configs/config.py new features: infer/lib/rmvpe.py new features: tools/jit_export/__init__.py new features: tools/jit_export/get_hubert.py new features: tools/jit_export/get_rmvpe.py new features: tools/jit_export/get_synthesizer.py optimize: tools/rvc_for_realtime.py * optimize: tools/jit_export/get_synthesizer.py fix bug: tools/jit_export/__init__.py * Fixed a bug caused by using half on the CPU: infer/lib/rmvpe.py Fixed a bug caused by using half on the CPU: tools/jit_export/__init__.py Fixed CIRCULAR IMPORT: tools/jit_export/get_rmvpe.py Fixed CIRCULAR IMPORT: tools/jit_export/get_synthesizer.py Fixed a bug caused by using half on the CPU: tools/rvc_for_realtime.py * Remove useless code: infer/lib/rmvpe.py * Delete gui_v1 copy.py * Delete .vscode/launch.json * Delete jit_export_test.py * Delete tools/rvc_for_realtime copy.py * Delete configs/config.json * Delete .gitignore * Fix exceptions caused by switching inference devices: infer/lib/rmvpe.py Fix exceptions caused by switching inference devices: tools/jit_export/__init__.py Fix exceptions caused by switching inference devices: tools/rvc_for_realtime.py * restore * replace(you can undo this commit) * remove debug_print --------- Co-authored-by: Ftps <ftpsflandre@gmail.com> * Fixed some bugs when exporting ONNX model (#1254) * fix import (#1280) * fix import * lint * 🎨 同步 locale (#1242) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * Fix jit load and import issue (#1282) * fix jit model loading : infer/lib/rmvpe.py * modified: assets/hubert/.gitignore move file: assets/hubert_inputs.pth -> assets/hubert/hubert_inputs.pth modified: assets/rmvpe/.gitignore move file: assets/rmvpe_inputs.pth -> assets/rmvpe/rmvpe_inputs.pth fix import: gui_v1.py * feat(workflow): trigger on dev * feat(workflow): add close-pr on non-dev branch * Add input wav and delay time monitor for real-time gui (#1293) * feat(workflow): trigger on dev * feat(workflow): add close-pr on non-dev branch * 🎨 同步 locale (#1289) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * feat: edit PR template * add input wav and delay time monitor --------- Co-authored-by: 源文雨 <41315874+fumiama@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: RVC-Boss <129054828+RVC-Boss@users.noreply.github.com> * Optimize latency using scripted jit (#1291) * feat(workflow): trigger on dev * feat(workflow): add close-pr on non-dev branch * 🎨 同步 locale (#1289) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * feat: edit PR template * Optimize-latency-using-scripted: configs/config.py Optimize-latency-using-scripted: infer/lib/infer_pack/attentions.py Optimize-latency-using-scripted: infer/lib/infer_pack/commons.py Optimize-latency-using-scripted: infer/lib/infer_pack/models.py Optimize-latency-using-scripted: infer/lib/infer_pack/modules.py Optimize-latency-using-scripted: infer/lib/jit/__init__.py Optimize-latency-using-scripted: infer/lib/jit/get_hubert.py Optimize-latency-using-scripted: infer/lib/jit/get_rmvpe.py Optimize-latency-using-scripted: infer/lib/jit/get_synthesizer.py Optimize-latency-using-scripted: infer/lib/rmvpe.py Optimize-latency-using-scripted: tools/rvc_for_realtime.py * modified: infer/lib/infer_pack/models.py * fix some bug: configs/config.py fix some bug: infer/lib/infer_pack/models.py fix some bug: infer/lib/rmvpe.py * Fixed abnormal reference of logger in multiprocessing: infer/modules/train/train.py --------- Co-authored-by: 源文雨 <41315874+fumiama@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * Format code (#1298) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * 🎨 同步 locale (#1299) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * feat: optimize actions * feat(workflow): add sync dev * feat: optimize actions * feat: optimize actions * feat: optimize actions * feat: optimize actions * feat: add jit options (#1303) Delete useless code: infer/lib/jit/get_synthesizer.py Optimized code: tools/rvc_for_realtime.py * Code refactor + re-design inference ui (#1304) * Code refacor + re-design inference ui * Fix tabname * i18n jp --------- Co-authored-by: Ftps <ftpsflandre@gmail.com> * feat: optimize actions * feat: optimize actions * Update README & en_US locale file (#1309) * critical: some bug fixes (#1322) * JIT acceleration switch does not support hot update * fix padding bug of rmvpe in torch-directml * fix padding bug of rmvpe in torch-directml * Fix STFT under torch_directml (#1330) * chore(format): run black on dev (#1318) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * chore(i18n): sync locale on dev (#1317) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * feat: allow for tta to be passed to uvr (#1361) * chore(format): run black on dev (#1373) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * Added script for automatically download all needed models at install (#1366) * Delete modules.py * Add files via upload * Add files via upload * Add files via upload * Add files via upload * chore(i18n): sync locale on dev (#1377) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * chore(format): run black on dev (#1376) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * Update IPEX library (#1362) * Update IPEX library * Update ipex index * chore(format): run black on dev (#1378) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> --------- Co-authored-by: Chengjia Jiang <46401978+ChasonJiang@users.noreply.github.com> Co-authored-by: Ftps <ftpsflandre@gmail.com> Co-authored-by: shizuku_nia <102004222+ShizukuNia@users.noreply.github.com> Co-authored-by: Ftps <63702646+Tps-F@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: 源文雨 <41315874+fumiama@users.noreply.github.com> Co-authored-by: yxlllc <33565655+yxlllc@users.noreply.github.com> Co-authored-by: RVC-Boss <129054828+RVC-Boss@users.noreply.github.com> Co-authored-by: Blaise <133521603+blaise-tk@users.noreply.github.com> Co-authored-by: Rice Cake <gak141808@gmail.com> Co-authored-by: AWAS666 <33494149+AWAS666@users.noreply.github.com> Co-authored-by: Dmitry <nda2911@yandex.ru> Co-authored-by: Disty0 <47277141+Disty0@users.noreply.github.com>
191 lines
9.1 KiB
Python
191 lines
9.1 KiB
Python
import os
|
|
import sys
|
|
import contextlib
|
|
import torch
|
|
import intel_extension_for_pytorch as ipex # pylint: disable=import-error, unused-import
|
|
from .hijacks import ipex_hijacks
|
|
from .attention import attention_init
|
|
|
|
# pylint: disable=protected-access, missing-function-docstring, line-too-long
|
|
|
|
|
|
def ipex_init(): # pylint: disable=too-many-statements
|
|
try:
|
|
# Replace cuda with xpu:
|
|
torch.cuda.current_device = torch.xpu.current_device
|
|
torch.cuda.current_stream = torch.xpu.current_stream
|
|
torch.cuda.device = torch.xpu.device
|
|
torch.cuda.device_count = torch.xpu.device_count
|
|
torch.cuda.device_of = torch.xpu.device_of
|
|
torch.cuda.get_device_name = torch.xpu.get_device_name
|
|
torch.cuda.get_device_properties = torch.xpu.get_device_properties
|
|
torch.cuda.init = torch.xpu.init
|
|
torch.cuda.is_available = torch.xpu.is_available
|
|
torch.cuda.is_initialized = torch.xpu.is_initialized
|
|
torch.cuda.is_current_stream_capturing = lambda: False
|
|
torch.cuda.set_device = torch.xpu.set_device
|
|
torch.cuda.stream = torch.xpu.stream
|
|
torch.cuda.synchronize = torch.xpu.synchronize
|
|
torch.cuda.Event = torch.xpu.Event
|
|
torch.cuda.Stream = torch.xpu.Stream
|
|
torch.cuda.FloatTensor = torch.xpu.FloatTensor
|
|
torch.Tensor.cuda = torch.Tensor.xpu
|
|
torch.Tensor.is_cuda = torch.Tensor.is_xpu
|
|
torch.cuda._initialization_lock = torch.xpu.lazy_init._initialization_lock
|
|
torch.cuda._initialized = torch.xpu.lazy_init._initialized
|
|
torch.cuda._lazy_seed_tracker = torch.xpu.lazy_init._lazy_seed_tracker
|
|
torch.cuda._queued_calls = torch.xpu.lazy_init._queued_calls
|
|
torch.cuda._tls = torch.xpu.lazy_init._tls
|
|
torch.cuda.threading = torch.xpu.lazy_init.threading
|
|
torch.cuda.traceback = torch.xpu.lazy_init.traceback
|
|
torch.cuda.Optional = torch.xpu.Optional
|
|
torch.cuda.__cached__ = torch.xpu.__cached__
|
|
torch.cuda.__loader__ = torch.xpu.__loader__
|
|
torch.cuda.ComplexFloatStorage = torch.xpu.ComplexFloatStorage
|
|
torch.cuda.Tuple = torch.xpu.Tuple
|
|
torch.cuda.streams = torch.xpu.streams
|
|
torch.cuda._lazy_new = torch.xpu._lazy_new
|
|
torch.cuda.FloatStorage = torch.xpu.FloatStorage
|
|
torch.cuda.Any = torch.xpu.Any
|
|
torch.cuda.__doc__ = torch.xpu.__doc__
|
|
torch.cuda.default_generators = torch.xpu.default_generators
|
|
torch.cuda.HalfTensor = torch.xpu.HalfTensor
|
|
torch.cuda._get_device_index = torch.xpu._get_device_index
|
|
torch.cuda.__path__ = torch.xpu.__path__
|
|
torch.cuda.Device = torch.xpu.Device
|
|
torch.cuda.IntTensor = torch.xpu.IntTensor
|
|
torch.cuda.ByteStorage = torch.xpu.ByteStorage
|
|
torch.cuda.set_stream = torch.xpu.set_stream
|
|
torch.cuda.BoolStorage = torch.xpu.BoolStorage
|
|
torch.cuda.os = torch.xpu.os
|
|
torch.cuda.torch = torch.xpu.torch
|
|
torch.cuda.BFloat16Storage = torch.xpu.BFloat16Storage
|
|
torch.cuda.Union = torch.xpu.Union
|
|
torch.cuda.DoubleTensor = torch.xpu.DoubleTensor
|
|
torch.cuda.ShortTensor = torch.xpu.ShortTensor
|
|
torch.cuda.LongTensor = torch.xpu.LongTensor
|
|
torch.cuda.IntStorage = torch.xpu.IntStorage
|
|
torch.cuda.LongStorage = torch.xpu.LongStorage
|
|
torch.cuda.__annotations__ = torch.xpu.__annotations__
|
|
torch.cuda.__package__ = torch.xpu.__package__
|
|
torch.cuda.__builtins__ = torch.xpu.__builtins__
|
|
torch.cuda.CharTensor = torch.xpu.CharTensor
|
|
torch.cuda.List = torch.xpu.List
|
|
torch.cuda._lazy_init = torch.xpu._lazy_init
|
|
torch.cuda.BFloat16Tensor = torch.xpu.BFloat16Tensor
|
|
torch.cuda.DoubleStorage = torch.xpu.DoubleStorage
|
|
torch.cuda.ByteTensor = torch.xpu.ByteTensor
|
|
torch.cuda.StreamContext = torch.xpu.StreamContext
|
|
torch.cuda.ComplexDoubleStorage = torch.xpu.ComplexDoubleStorage
|
|
torch.cuda.ShortStorage = torch.xpu.ShortStorage
|
|
torch.cuda._lazy_call = torch.xpu._lazy_call
|
|
torch.cuda.HalfStorage = torch.xpu.HalfStorage
|
|
torch.cuda.random = torch.xpu.random
|
|
torch.cuda._device = torch.xpu._device
|
|
torch.cuda.classproperty = torch.xpu.classproperty
|
|
torch.cuda.__name__ = torch.xpu.__name__
|
|
torch.cuda._device_t = torch.xpu._device_t
|
|
torch.cuda.warnings = torch.xpu.warnings
|
|
torch.cuda.__spec__ = torch.xpu.__spec__
|
|
torch.cuda.BoolTensor = torch.xpu.BoolTensor
|
|
torch.cuda.CharStorage = torch.xpu.CharStorage
|
|
torch.cuda.__file__ = torch.xpu.__file__
|
|
torch.cuda._is_in_bad_fork = torch.xpu.lazy_init._is_in_bad_fork
|
|
# torch.cuda.is_current_stream_capturing = torch.xpu.is_current_stream_capturing
|
|
|
|
# Memory:
|
|
torch.cuda.memory = torch.xpu.memory
|
|
if "linux" in sys.platform and "WSL2" in os.popen("uname -a").read():
|
|
torch.xpu.empty_cache = lambda: None
|
|
torch.cuda.empty_cache = torch.xpu.empty_cache
|
|
torch.cuda.memory_stats = torch.xpu.memory_stats
|
|
torch.cuda.memory_summary = torch.xpu.memory_summary
|
|
torch.cuda.memory_snapshot = torch.xpu.memory_snapshot
|
|
torch.cuda.memory_allocated = torch.xpu.memory_allocated
|
|
torch.cuda.max_memory_allocated = torch.xpu.max_memory_allocated
|
|
torch.cuda.memory_reserved = torch.xpu.memory_reserved
|
|
torch.cuda.memory_cached = torch.xpu.memory_reserved
|
|
torch.cuda.max_memory_reserved = torch.xpu.max_memory_reserved
|
|
torch.cuda.max_memory_cached = torch.xpu.max_memory_reserved
|
|
torch.cuda.reset_peak_memory_stats = torch.xpu.reset_peak_memory_stats
|
|
torch.cuda.reset_max_memory_cached = torch.xpu.reset_peak_memory_stats
|
|
torch.cuda.reset_max_memory_allocated = torch.xpu.reset_peak_memory_stats
|
|
torch.cuda.memory_stats_as_nested_dict = torch.xpu.memory_stats_as_nested_dict
|
|
torch.cuda.reset_accumulated_memory_stats = (
|
|
torch.xpu.reset_accumulated_memory_stats
|
|
)
|
|
|
|
# RNG:
|
|
torch.cuda.get_rng_state = torch.xpu.get_rng_state
|
|
torch.cuda.get_rng_state_all = torch.xpu.get_rng_state_all
|
|
torch.cuda.set_rng_state = torch.xpu.set_rng_state
|
|
torch.cuda.set_rng_state_all = torch.xpu.set_rng_state_all
|
|
torch.cuda.manual_seed = torch.xpu.manual_seed
|
|
torch.cuda.manual_seed_all = torch.xpu.manual_seed_all
|
|
torch.cuda.seed = torch.xpu.seed
|
|
torch.cuda.seed_all = torch.xpu.seed_all
|
|
torch.cuda.initial_seed = torch.xpu.initial_seed
|
|
|
|
# AMP:
|
|
torch.cuda.amp = torch.xpu.amp
|
|
if not hasattr(torch.cuda.amp, "common"):
|
|
torch.cuda.amp.common = contextlib.nullcontext()
|
|
torch.cuda.amp.common.amp_definitely_not_available = lambda: False
|
|
try:
|
|
torch.cuda.amp.GradScaler = torch.xpu.amp.GradScaler
|
|
except Exception: # pylint: disable=broad-exception-caught
|
|
try:
|
|
from .gradscaler import (
|
|
gradscaler_init,
|
|
) # pylint: disable=import-outside-toplevel, import-error
|
|
|
|
gradscaler_init()
|
|
torch.cuda.amp.GradScaler = torch.xpu.amp.GradScaler
|
|
except Exception: # pylint: disable=broad-exception-caught
|
|
torch.cuda.amp.GradScaler = ipex.cpu.autocast._grad_scaler.GradScaler
|
|
|
|
# C
|
|
torch._C._cuda_getCurrentRawStream = ipex._C._getCurrentStream
|
|
ipex._C._DeviceProperties.major = 2023
|
|
ipex._C._DeviceProperties.minor = 2
|
|
|
|
# Fix functions with ipex:
|
|
torch.cuda.mem_get_info = lambda device=None: [
|
|
(
|
|
torch.xpu.get_device_properties(device).total_memory
|
|
- torch.xpu.memory_allocated(device)
|
|
),
|
|
torch.xpu.get_device_properties(device).total_memory,
|
|
]
|
|
torch._utils._get_available_device_type = lambda: "xpu"
|
|
torch.has_cuda = True
|
|
torch.cuda.has_half = True
|
|
torch.cuda.is_bf16_supported = lambda *args, **kwargs: True
|
|
torch.cuda.is_fp16_supported = lambda *args, **kwargs: True
|
|
torch.version.cuda = "11.7"
|
|
torch.cuda.get_device_capability = lambda *args, **kwargs: [11, 7]
|
|
torch.cuda.get_device_properties.major = 11
|
|
torch.cuda.get_device_properties.minor = 7
|
|
torch.cuda.ipc_collect = lambda *args, **kwargs: None
|
|
torch.cuda.utilization = lambda *args, **kwargs: 0
|
|
if hasattr(torch.xpu, "getDeviceIdListForCard"):
|
|
torch.cuda.getDeviceIdListForCard = torch.xpu.getDeviceIdListForCard
|
|
torch.cuda.get_device_id_list_per_card = torch.xpu.getDeviceIdListForCard
|
|
else:
|
|
torch.cuda.getDeviceIdListForCard = torch.xpu.get_device_id_list_per_card
|
|
torch.cuda.get_device_id_list_per_card = (
|
|
torch.xpu.get_device_id_list_per_card
|
|
)
|
|
|
|
ipex_hijacks()
|
|
attention_init()
|
|
try:
|
|
from .diffusers import ipex_diffusers
|
|
|
|
ipex_diffusers()
|
|
except Exception: # pylint: disable=broad-exception-caught
|
|
pass
|
|
except Exception as e:
|
|
return False, e
|
|
return True, None
|