MGen / tests /common_utils /wav_utils.py
Datasculptor's picture
Duplicate from facebook/MusicGen
d4226c5
raw
history blame contribute delete
872 Bytes
# Copyright (c) Meta Platforms, Inc. and affiliates.
# All rights reserved.
#
# This source code is licensed under the license found in the
# LICENSE file in the root directory of this source tree.
from pathlib import Path
import typing as tp
import torch
import torchaudio
def get_white_noise(chs: int = 1, num_frames: int = 1):
wav = torch.randn(chs, num_frames)
return wav
def get_batch_white_noise(bs: int = 1, chs: int = 1, num_frames: int = 1):
wav = torch.randn(bs, chs, num_frames)
return wav
def save_wav(path: str, wav: torch.Tensor, sample_rate: int):
fp = Path(path)
kwargs: tp.Dict[str, tp.Any] = {}
if fp.suffix == '.wav':
kwargs['encoding'] = 'PCM_S'
kwargs['bits_per_sample'] = 16
elif fp.suffix == '.mp3':
kwargs['compression'] = 320
torchaudio.save(str(fp), wav, sample_rate, **kwargs)