# 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) | |