【问题标题】:sox - pipe input broken?sox - 管道输入损坏?
【发布时间】:2020-03-27 23:31:17
【问题描述】:

我正在尝试使用 sox 输入命令来处理 sox 本身不支持的文件格式,而无需先转换所有输入。

我的最后一次尝试如下(在两种不同的 AAC 编码之间创建 diff 的频谱图):

sox -S -m \
    -v  1 -t s24 -r 48k -c 2 -L "|ffmpeg -i input_orig.aac -vn -f s24le -" \
    -v -1 -t s24 -r 48k -c 2 -L "|ffmpeg -i input_faac.aac -vn -f s24le -" \
    -n \
    spectrogram -x 1600 -y 480 -o diff.faac.png

但是,结果是频谱图只包含前几秒,所以我一定遗漏了一些东西。

但是什么?

更新

尝试使用单个管道进行更简单的测试以查看是否有效,但会导致相同的问题:

ffmpeg -hide_banner -i input_orig.aac -vn -f s24le - | sox -S -t s24 -c 2 -r 48k -L - -n spectrogram -x 480 -y 96 -o orig.pipe.png

结果:

...直接使用预先转换的文件(到 FLAC 或 WAV)执行此操作时,会产生正确的结果:

简单管道命令的输出:

Input File     : '-' (raw)
Channels       : 2
Sample Rate    : 48000
Precision      : 24-bit
Sample Encoding: 24-bit Signed Integer PCM

In:0.00% 00:00:00.00 [00:00:00.00] Out:0     [      |      ]        Clip:0    [aac @ 0x5643e7dc9940] Estimating duration from bitrate, this may be inaccurate
Input #0, aac, from 'input_orig.aac':
  Duration: 00:01:35.08, bitrate: 136 kb/s
    Stream #0:0: Audio: aac (LC), 48000 Hz, stereo, fltp, 136 kb/s
Stream mapping:
  Stream #0:0 -> #0:0 (aac (native) -> pcm_s24le (native))
Press [q] to stop, [?] for help
Output #0, s24le, to 'pipe:':
  Metadata:
    encoder         : Lavf58.20.100
    Stream #0:0: Audio: pcm_s24le, 48000 Hz, stereo, s32, 2304 kb/s
    Metadata:
      encoder         : Lavc58.35.100 pcm_s24le
In:0.00% 00:01:27.55 [00:00:00.00] Out:4.20M [!=====|=====!] Hd:0.0 Clip:0    size=   28110kB time=00:01:39.94 bitrate=2304.0kbits/s speed= 417x    
video:0kB audio:28110kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 0.000000%
In:0.00% 00:01:39.95 [00:00:00.00] Out:4.80M [!=====|======] Hd:0.0 Clip:0    
Done.

【问题讨论】:

    标签: sox


    【解决方案1】:

    经过更多的实验,我终于发现它只与sox谱图效果有关,因为它不能从输入中扣除持续时间,但它需要计算布局。

    显然,该要求没有记录在案。

    但是,要精确指定持续时间,我们必须为其提供输入的样本数。

    我为此使用ffprobejq

    ffprobe -v error -print_format json -select_streams a:0 -show_entries frame=nb_samples input_orig.aac \
        | jq --stream 'select(.[0][2] == "nb_samples")[1]' \
        | jq --slurp 'add'
    

    (是的,有更简单的方法,但它们无法扩展)

    ...这为我的输入文件提供了4797440 样本。

    现在它实际上可以在频谱图效果中添加-d 4797440s

    sox -S -m \
        -v  1 -t s24 -r 48k -c 2 -L "|ffmpeg -v error -i input_orig.aac -vn -f s24le -" \
        -v -1 -t s24 -r 48k -c 2 -L "|ffmpeg -v error -i input_faac.aac -vn -f s24le -" \
        -n \
        spectrogram -d 4797440s -x 1600 -y 480 -o diff.faac.png
    

    新结果:

    【讨论】:

      猜你喜欢
      • 2019-09-11
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2011-02-12
      • 2010-10-28
      • 2011-03-19
      • 1970-01-01
      相关资源
      最近更新 更多