|
|
|
|
|
""" |
|
@File : spec.py |
|
@Time : 2023/8/8 下午5:10 |
|
@Author : waytan |
|
@Contact : [email protected] |
|
@License : (C)Copyright 2023, Tencent |
|
@Desc : Spec |
|
""" |
|
|
|
import torch as th |
|
|
|
|
|
def spectro(x, n_fft=512, hop_length=None, pad=0): |
|
*other, length = x.shape |
|
x = x.reshape(-1, length) |
|
is_mps = x.device.type == 'mps' |
|
if is_mps: |
|
x = x.cpu() |
|
z = th.stft(x, |
|
n_fft * (1 + pad), |
|
hop_length or n_fft // 4, |
|
window=th.hann_window(n_fft).to(x), |
|
win_length=n_fft, |
|
normalized=True, |
|
center=True, |
|
return_complex=True, |
|
pad_mode='reflect') |
|
_, freqs, frame = z.shape |
|
return z.view(*other, freqs, frame) |
|
|
|
|
|
def ispectro(z, hop_length=None, length=None, pad=0): |
|
*other, freqs, frames = z.shape |
|
n_fft = 2 * freqs - 2 |
|
z = z.view(-1, freqs, frames) |
|
win_length = n_fft // (1 + pad) |
|
is_mps = z.device.type == 'mps' |
|
if is_mps: |
|
z = z.cpu() |
|
x = th.istft(z, |
|
n_fft, |
|
hop_length, |
|
window=th.hann_window(win_length).to(z.real), |
|
win_length=win_length, |
|
normalized=True, |
|
length=length, |
|
center=True) |
|
_, length = x.shape |
|
return x.view(*other, length) |
|
|