Copiando o áudio de um quicktime com ffmpeg

0

Estou tentando copiar apenas o áudio de um modo rápido.

>"C:\Program Files\ffmpeg\bin\ffmpeg.exe" -y -i a.mov -vn -acodec pcm_s16le a.wav

Aqui está minha saída. Desculpe pela formatação.

ffmpeg version N-66673-gf0d1b3a Copyright (c) 2000-2014 the FFmpeg developers
  built on Oct  6 2014 22:10:42 with gcc 4.9.1 (GCC)
  configuration: --enable-gpl --enable-version3 --disable-w32threads --enable-avisynth --enable-bzlib --enable-fontconfig --enable-frei0r --enable-gnutls --enable-iconv --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --enable-libfreetype --enable-libgme --enable-libgsm --enable-libilbc --enable-libmodplug --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-librtmp --enable-libschroedinger --enable-libsoxr --enable-libspeex --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvo-aacenc --enable-libvo-amrwbenc --enable-libvorbis
 --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxavs --enable-libxvid --enable-zlib
  libavutil      54.  9.100 / 54.  9.100
  libavcodec     56.  3.101 / 56.  3.101
  libavformat    56.  7.104 / 56.  7.104
  libavdevice    56.  1.100 / 56.  1.100
  libavfilter     5.  1.102 /  5.  1.102
  libswscale      3.  1.100 /  3.  1.100
  libswresample   1.  1.100 /  1.  1.100
  libpostproc    53.  1.100 / 53.  1.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'a.mov':
  Metadata:
    major_brand     : qt
    minor_version   : 512
    compatible_brands: qt
    encoder         : Lavf56.7.104
  Duration: 00:00:02.44, start: 0.021333, bitrate: 761 kb/s
    Stream #0:0(eng): Video: h264 (High) (avc1 / 0x31637661), yuv420p, 1280x720,
 628 kb/s, 24 fps, 24 tbr, 12288 tbn, 48 tbc (default)
    Metadata:
      handler_name    : DataHandler
      encoder         : Lavc56.3.101 libx264
    Stream #0:1(eng): Audio: aac (mp4a / 0x6134706D), 48000 Hz, stereo, fltp, 129 kb/s (default)
    Metadata:
      handler_name    : DataHandler
Output #0, wav, to 'a.wav':
  Metadata:
    major_brand     : qt
    minor_version   : 512
    compatible_brands: qt
    ISFT            : Lavf56.7.104
    Stream #0:0(eng): Audio: pcm_s16le ([1][0][0][0] / 0x0001), 48000 Hz, stereo
, s16, 1536 kb/s (default)
    Metadata:
      handler_name    : DataHandler
      encoder         : Lavc56.3.101 pcm_s16le
Stream mapping:
  Stream #0:1 -> #0:0 (aac (native) -> pcm_s16le (native))
Press [q] to stop, [?] for help
size=     460kB time=00:00:02.45 bitrate=1536.3kbits/s
video:0kB audio:460kB subtitle:0kB other streams:0kB global headers:0kB muxing o
verhead: 0.016559%

Um arquivo wav é gerado. No entanto, se você levar o arquivo wav e o quicktime original para o Pro Tools, verá que o arquivo wav não corresponde ao tempo no quicktime original. O áudio no arquivo wav é aproximadamente um quadro e meio atrasado.

Eu tentei definir a taxa de bits e a frequência manualmente.

"C:\Program Files\ffmpeg\bin\ffmpeg.exe" -y -i a.mov -b:a 87k -ar 48000 -acodec pcm_s16le -vn a.wav



"C:\Program Files\ffmpeg\bin\ffmpeg.exe" -y -i a.mov -ar 48000 -acodec pcm_s16le -vn a_did_not_set_bitrate.wav

Nenhum comando fez diferença. Alguém já encontrou esse problema antes? Alguma idéia de como resolvê-lo?

Editar:

Apenas notei algo estranho na saída. No início, a duração foi definida para:

Duration: 00:00:02.44

Depois que o wav foi gerado, o tempo foi registrado como:

time=00:00:02.45

A hora extra foi adicionada ao arquivo wav?

Adição 26/4/16:

Interessante.

>"C:\Program Files\ffmpeg\bin\ffprobe.exe" -select_streams a -read_intervals %+#1 -show_entries packet=pts_time a.mov
ffprobe version N-66673-gf0d1b3a Copyright (c) 2007-2014 the FFmpeg developers
  built on Oct  6 2014 22:10:42 with gcc 4.9.1 (GCC)
  configuration: --enable-gpl --enable-version3 --disable-w32threads --enable-av
isynth --enable-bzlib --enable-fontconfig --enable-frei0r --enable-gnutls --enab
le-iconv --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --
enable-libfreetype --enable-libgme --enable-libgsm --enable-libilbc --enable-lib
modplug --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrw
b --enable-libopenjpeg --enable-libopus --enable-librtmp --enable-libschroedinge
r --enable-libsoxr --enable-libspeex --enable-libtheora --enable-libtwolame --en
able-libvidstab --enable-libvo-aacenc --enable-libvo-amrwbenc --enable-libvorbis
 --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-
libx265 --enable-libxavs --enable-libxvid --enable-zlib
  libavutil      54.  9.100 / 54.  9.100
  libavcodec     56.  3.101 / 56.  3.101
  libavformat    56.  7.104 / 56.  7.104
  libavdevice    56.  1.100 / 56.  1.100
  libavfilter     5.  1.102 /  5.  1.102
  libswscale      3.  1.100 /  3.  1.100
  libswresample   1.  1.100 /  1.  1.100
  libpostproc    53.  1.100 / 53.  1.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'a.mov':
  Metadata:
    major_brand     : qt
    minor_version   : 512
    compatible_brands: qt
    encoder         : Lavf56.7.104
  Duration: 00:00:02.44, start: 0.021333, bitrate: 761 kb/s
    Stream #0:0(eng): Video: h264 (High) (avc1 / 0x31637661), yuv420p, 1280x720,
 628 kb/s, 24 fps, 24 tbr, 12288 tbn, 48 tbc (default)
    Metadata:
      handler_name    : DataHandler
      encoder         : Lavc56.3.101 libx264
    Stream #0:1(eng): Audio: aac (mp4a / 0x6134706D), 48000 Hz, stereo, fltp, 12
9 kb/s (default)
    Metadata:
      handler_name    : DataHandler
[PACKET]
pts_time=-0.021333
[/PACKET]

Tentando quebrar esse comando.

"C:\Program Files\ffmpeg\bin\ffprobe.exe" -select_streams a -read_intervals %+#1 -show_entries packet=pts_time a.mov

Pelo que eu posso dizer, significa ler um pacote dos fluxos de áudio e mostrar o Tempo PTS, que eu acho que se refere a um timestamp de apresentação.

Isso significa que o áudio está começando antes do vídeo? Talvez esteja começando 0,021333 segundos antes do vídeo.

Inclusão 27/4/16:

Executando o mesmo comando com v para -select_streams yields:

[PACKET]
pts_time=0.000000
[/PACKET]
    
por Christopher Spears 21.04.2016 / 02:28

2 respostas

1

O problema é que o seu arquivo QuickTime contém um ajuste interno que o FFMPEG ignora, a menos que você execute explicitamente o ajuste no arquivo entrada por meio da opção -ss.

Você pode ver que o arquivo do QuickTime na verdade inicia 0,021333 ms no arquivo pelo "start: 0.021333" nesta linha:

 Duration: 00:00:02.44, start: 0.021333, bitrate: 761 kb/s

Para corrigir isso, tente o seguinte comando:

"C:\Program Files\ffmpeg\bin\ffmpeg.exe" -y -ss 0.021333 -i a.mov -vn -acodec pcm_s16le a.wav

Por favor, note que a opção -ss deve estar antes do arquivo de entrada (-i) para que isso funcione corretamente.

No meu programa, chamo FFProbe, obtenho o deslocamento e, em seguida, aplico-o ao comando FFMPEG para garantir que não haja problemas de sincronização. Eu acredito que o que você está procurando é "start_time" no FFProbe.

Boa sorte!

    
por 18.07.2016 / 22:00
0

Tente isto:

Primeiro, extraia o áudio para o contêiner bruto

ffmpeg.exe -y -i a.mov -vn -acodec copy a.aac

Se você puder usar isso no Pro Tools, está pronto. Mais,

ffmpeg.exe -y -i a.aac -acodec pcm_s16le a.wav
    
por 21.04.2016 / 07:12