SOX 的采样率误差

Posted

技术标签:

【中文标题】SOX 的采样率误差【英文标题】:sampling rate error with SOX 【发布时间】:2015-04-22 00:21:40 【问题描述】:

我正在使用以下转换代码,使用 SOX 将所有原始文件转换为 16 KHZ、16 位、单声道格式的 wav 文件。我使用了以下代码

我使用了以下代码

#!/bin/bash
OutDir=converted 
for input in "$@"   
   do sox -S $input -r 16000 -c 1 -b 16 -w -s -t raw "$OutDir/$(basename $input)" 
done

尽管我提到了采样率 -r 16000,但仍观察到以下错误

bsnayak@ubuntu:~/MLLR/input$ ls
an251-fash-b.raw  an254-fash-b.raw  cen1-fash-b.raw  cen4-fash-b.raw  cen7-fash-b.raw  convert.sh
an253-fash-b.raw  an255-fash-b.raw  cen2-fash-b.raw  cen5-fash-b.raw  converted
bsnayak@ubuntu:~/MLLR/input$ ./convert.sh /home/bsnayak/MLLR/input/*.raw 
sox FAIL formats: bad input format for file `/home/bsnayak/MLLR/input/an251-fash-b.raw': sampling rate was not specified
sox FAIL formats: bad input format for file `/home/bsnayak/MLLR/input/an253-fash-b.raw': sampling rate was not specified
sox FAIL formats: bad input format for file `/home/bsnayak/MLLR/input/an254-fash-b.raw': sampling rate was not specified
sox FAIL formats: bad input format for file `/home/bsnayak/MLLR/input/an255-fash-b.raw': sampling rate was not specified
sox FAIL formats: bad input format for file `/home/bsnayak/MLLR/input/cen1-fash-b.raw': sampling rate was not specified
sox FAIL formats: bad input format for file `/home/bsnayak/MLLR/input/cen2-fash-b.raw': sampling rate was not specified
sox FAIL formats: bad input format for file `/home/bsnayak/MLLR/input/cen4-fash-b.raw': sampling rate was not specified
sox FAIL formats: bad input format for file `/home/bsnayak/MLLR/input/cen5-fash-b.raw': sampling rate was not specified
sox FAIL formats: bad input format for file `/home/bsnayak/MLLR/input/cen7-fash-b.raw': sampling rate was not specified

欢迎提出建议。

使用followinf命令解决:

#!/bin/bash

SAVEIF=$IFS
IFS=$(echo -en "\n\b")

for file in $(ls *raw)
do
  name=$file%%.raw

  sox -S -V -r 16k -e signed -c 1 -b 16  $name.raw $name.wav
done
IFS=$SAVEIFS

【问题讨论】:

【参考方案1】:

sox 的命令行要求文件选项位于它们所应用的文件名之前。您没有在 $input 之前放置任何参数,所以 sox 不知道输入文件的格式是什么。

假设输入文件是 16k、16 位有符号和 1 个通道,那么将文件参数重新排列到输入文件之前将使您摆脱错误。您还需要通过附加 .wav 扩展名来指示输出格式是 wav:

sox -S  -r 16000 -c 1 -b 16 -w -s -t raw $input "$OutDir/$(basename $input).wav"

默认情况下,输入格式将复制到输出格式中,除非您通过在输出文件名之前添加参数来明确覆盖它。

【讨论】:

我也是这样做的。谢谢

以上是关于SOX 的采样率误差的主要内容,如果未能解决你的问题,请参考以下文章

在 Ubuntu 中转换音频文件采样率的脚本

音频重采样

音频重采样实现原理

什么是音频视频比特率,采样率,讲的很不错

libfdk_aac音频采样率和编码字节数注意

如何获得本机(硬件支持)音频采样率以避免内部采样率转换?