LFCC¶
- class torchaudio.transforms.LFCC(sample_rate: int = 16000, n_filter: int = 128, f_min: float = 0.0, f_max: Optional[float] = None, n_lfcc: int = 40, dct_type: int = 2, norm: str = 'ortho', log_lf: bool = False, speckwargs: Optional[dict] = None)[source]¶
从音频信号创建线性频率倒谱系数。
默认情况下,这会在 DB 标度的线性滤波频谱图上计算 LFCC。这不是教科书式的实现,但在此实现是为了与 librosa 保持一致性。
此输出取决于输入频谱图中的最大值,因此对于分割成片段的音频剪辑与完整剪辑可能会返回不同的值。
- 参数:
sample_rate (int, 可选) – 音频信号的采样率。 (默认:
16000
)n_filter (int, 可选) – 要应用的线性滤波器数量。 (默认:
128
)n_lfcc (int, 可选) – 要保留的 lfc 系数数量。 (默认:
40
)f_min (float, 可选) – 最小频率。 (默认:
0.
)f_max (float 或 None, 可选) – 最大频率。 (默认:
None
)dct_type (int, 可选) – 要使用的 DCT(离散余弦变换)类型。 (默认:
2
)norm (str, 可选) – 要使用的范数。 (默认:
"ortho"
)log_lf (bool, 可选) – 是否使用 log-lf 频谱图而不是 db 标度。 (默认:
False
)speckwargs (dict 或 None, 可选) – Spectrogram 的参数。 (默认:
None
)
- 示例
>>> waveform, sample_rate = torchaudio.load("test.wav", normalize=True) >>> transform = transforms.LFCC( >>> sample_rate=sample_rate, >>> n_lfcc=13, >>> speckwargs={"n_fft": 400, "hop_length": 160, "center": False}, >>> ) >>> lfcc = transform(waveform)
另请参阅
torchaudio.functional.linear_fbanks()
- 用于生成滤波器组的函数。- 使用
LFCC
的教程