0

0

如何正确使用 librosa.resample 进行音频重采样(16kHz)

碧海醫心

碧海醫心

发布时间:2025-12-29 14:19:31

|

727人浏览过

|

来源于php中文网

原创

如何正确使用 librosa.resample 进行音频重采样(16kHz)

librosa 0.10+ 版本中 `librosa.resample` 已改为仅支持关键字参数(keyword-only),必须显式传入 `orig_sr` 和 `target_sr`,否则会报错“takes 1 positional argument but 3 were given”。本文详解正确调用方式、多通道处理技巧及实用注意事项。

在使用 wav2vec2 等预训练模型进行语音微调时,确保所有音频统一为 16 kHz 采样率 是关键前提。而从 torchaudio.load() 加载的音频往往原始采样率各异(如 44.1 kHz、48 kHz 或 8 kHz),需通过重采样对齐。许多用户在迁移到较新版本的 librosa(≥0.10.0)后,因沿用旧版位置参数写法(如 librosa.resample(y, sr, 16000))触发如下错误:

TypeError: resample() takes 1 positional argument but 3 were given

这是因为新版 librosa.resample 显式要求所有参数(除音频数组 y 外)必须以命名参数形式传入,其函数签名如下:

def resample(
    y: np.ndarray,
    *,
    orig_sr: float,
    target_sr: float,
    res_type: str = "soxr_hq",
    fix: bool = True,
    scale: bool = False,
    axis: int = -1,
    **kwargs
) -> np.ndarray:

其中 * 表示其后所有参数均为 keyword-only —— 这是导致错误的根本原因。

✅ 正确用法(适配 mono 与 stereo):

import librosa
import numpy as np

# 假设 database['audio'] 是 list of 1D/2D numpy arrays,database['psr'] 是对应原始采样率列表
new_audios = []
new_sr = []

for i, (audio_signal, original_sr) in enumerate(zip(database['audio'], database['psr'])):
    audio_signal = np.asarray(audio_signal)

    # 处理单通道(mono)
    if audio_signal.ndim == 1:
        resampled = librosa.resample(
            y=audio_signal,
            orig_sr=original_sr,
            target_sr=16000
        )

    # 处理多通道(stereo 或更多),逐通道重采样并保持形状
    elif audio_signal.ndim == 2:
        resampled_channels = []
        for ch in audio_signal:
            ch_resampled = librosa.resample(
                y=ch,
                orig_sr=original_sr,
                target_sr=16000
            )
            resampled_channels.append(ch_resampled)
        resampled = np.stack(resampled_channels, axis=0)

    else:
        raise ValueError(f"Unsupported audio dimensionality: {audio_signal.ndim} at index {i}")

    new_audios.append(resampled)
    new_sr.append(16000)

# 更新数据字典
database['audio'] = new_audios
database['newsr'] = new_sr

⚠️ 注意事项与最佳实践:

  • 不要混用 torchaudio 与 librosa 的重采样逻辑:torchaudio.transforms.Resample 更高效且原生支持 Tensor,若全程使用 PyTorch 生态,推荐优先采用:

    DubbingX智声云配
    DubbingX智声云配

    多情绪免费克隆AI音频工具

    下载
    from torchaudio.transforms import Resample
    resampler = Resample(orig_freq=original_sr, new_freq=16000)
    resampled_tensor = resampler(speech_array)  # speech_array: torch.Tensor, shape [C, T]
  • 避免 librosa.resample 对长音频的内存峰值:该函数内部会将信号上采样至 LCM 频率,对超长语音(>30s)可能引发 OOM。此时建议分段处理或改用 scipy.signal.resample_poly(需手动设计抗混叠滤波器)。

  • res_type="soxr_hq" 是默认高质量选项,但依赖 soxr 库(需 pip install pysoundfile 或 conda install -c conda-forge soxr)。若环境受限,可降级为 "kaiser_best" 或 "polyphase",精度略低但无额外依赖。

  • 始终验证重采样结果:检查输出长度是否合理(近似按 len_in * 16000 / orig_sr 缩放),并用 librosa.get_duration(y=resampled, sr=16000) 校验时长一致性。

总结:librosa.resample 的关键字参数强制策略提升了 API 可读性与健壮性。只需将 librosa.resample(y, sr, 16000) 统一替换为 librosa.resample(y, orig_sr=sr, target_sr=16000),即可彻底解决报错,并为 wav2vec2 微调构建稳定、合规的 16 kHz 音频流水线。

相关专题

更多
pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

332

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

397

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

736

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

337

2025.07.23

pytorch是干嘛的
pytorch是干嘛的

pytorch是一个基于python的深度学习框架,提供以下主要功能:动态图计算,提供灵活性。强大的张量操作,实现高效处理。自动微分,简化梯度计算。预构建的神经网络模块,简化模型构建。各种优化器,用于性能优化。想了解更多pytorch的相关内容,可以阅读本专题下面的文章。

427

2024.05.29

Python AI机器学习PyTorch教程_Python怎么用PyTorch和TensorFlow做机器学习
Python AI机器学习PyTorch教程_Python怎么用PyTorch和TensorFlow做机器学习

PyTorch 是一种用于构建深度学习模型的功能完备框架,是一种通常用于图像识别和语言处理等应用程序的机器学习。 使用Python 编写,因此对于大多数机器学习开发者而言,学习和使用起来相对简单。 PyTorch 的独特之处在于,它完全支持GPU,并且使用反向模式自动微分技术,因此可以动态修改计算图形。

5

2025.12.22

Golang 命令行工具(CLI)开发实战
Golang 命令行工具(CLI)开发实战

本专题系统讲解 Golang 在命令行工具(CLI)开发中的实战应用,内容涵盖参数解析、子命令设计、配置文件读取、日志输出、错误处理、跨平台编译以及常用CLI库(如 Cobra、Viper)的使用方法。通过完整案例,帮助学习者掌握 使用 Go 构建专业级命令行工具与开发辅助程序的能力。

1

2025.12.29

ip地址修改教程大全
ip地址修改教程大全

本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

162

2025.12.26

压缩文件加密教程汇总
压缩文件加密教程汇总

本专题整合了压缩文件加密教程,阅读专题下面的文章了解更多详细教程。

52

2025.12.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Java 教程
Java 教程

共578课时 | 38.9万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号