Recherche avancée

Médias (3)

Mot : - Tags -/pdf

Autres articles (111)

  • Publier sur MédiaSpip

    13 juin 2013

    Puis-je poster des contenus à partir d’une tablette Ipad ?
    Oui, si votre Médiaspip installé est à la version 0.2 ou supérieure. Contacter au besoin l’administrateur de votre MédiaSpip pour le savoir

  • Script d’installation automatique de MediaSPIP

    25 avril 2011, par

    Afin de palier aux difficultés d’installation dues principalement aux dépendances logicielles coté serveur, un script d’installation "tout en un" en bash a été créé afin de faciliter cette étape sur un serveur doté d’une distribution Linux compatible.
    Vous devez bénéficier d’un accès SSH à votre serveur et d’un compte "root" afin de l’utiliser, ce qui permettra d’installer les dépendances. Contactez votre hébergeur si vous ne disposez pas de cela.
    La documentation de l’utilisation du script d’installation (...)

  • Ajouter des informations spécifiques aux utilisateurs et autres modifications de comportement liées aux auteurs

    12 avril 2011, par

    La manière la plus simple d’ajouter des informations aux auteurs est d’installer le plugin Inscription3. Il permet également de modifier certains comportements liés aux utilisateurs (référez-vous à sa documentation pour plus d’informations).
    Il est également possible d’ajouter des champs aux auteurs en installant les plugins champs extras 2 et Interface pour champs extras.

Sur d’autres sites (11162)

  • GStreamer with MPEG-TS Video4Linux ATSC/DVB Recording

    21 juin 2013, par Dustin Oprea

    I'm having an impossible time setting up a filtergraph to read from a recording that I made from my DVB video4linux device. Any help would be vastly appreciated.

    How I made the recording :

    To tune the channel :

    azap -c ~/channels.conf "Florida"

    To record the channel :

    cat /dev/dvb/adapter0/dvr0 > /tmp/test

    This is the way that recordings must be made (I can not use any GST DVB plugins to do this for me).

    I used tstools to identify that the recording is a TS stream :

    tstools/bin$ ./stream_type ~/recordings/20130129-202049
    Reading from /home/dustin/recordings/20130129-202049
    It appears to be Transport Stream

    ...but that there are no PAT/PMT frames :

    tstools/bin$ ./tsinfo ~/recordings/20130129-202049
    Reading from /home/dustin/recordings/20130129-202049
    Scanning 10000 TS packets

    Found 0 PAT packets and 0 PMT packets in 10000 TS packets

    I was able to produce a single ES (elementary stream) stream, by running ts2es :

    tstools/bin$ ./ts2es -pid 97 ~/recordings/20130129-202049 ~/recordings/20130129-202049.es
    Reading from /home/dustin/recordings/20130129-202049
    Writing to   /home/dustin/recordings/20130129-202049.es
    Extracting packets for PID 0061 (97)
    !!! 4 bytes ignored at end of file - not enough to make a TS packet
    Extracted 219258 of 248113 TS packets

    I am able to play the ES stream (even though the video is frozen on the first frame) :

    gst-launch-0.10 filesrc location=~/recordings/20130129-202049.es ! decodebin2 ! autovideosink
    gst-launch-0.10 filesrc location=~/recordings/20130129-202049.es ! decodebin2 ! xvimagesink
    gst-launch-0.10 playbin2 uri=file:///home/dustin/recordings/20130129-202049.es

    No matter what I do, though, I can't get the original TS file to open. However, it opens in Mplayer/FFMPEG, perfectly (but not VLC). This is the output of FFMPEG :

    ffmpeg -i 20130129-202049

    ffmpeg version 0.8.5-4:0.8.5-0ubuntu0.12.04.1, Copyright (c) 2000-2012 the Libav developers
     built on Jan 24 2013 18:03:14 with gcc 4.6.3
    *** THIS PROGRAM IS DEPRECATED ***
    This program is only provided for compatibility and will be removed in a future release. Please use avconv instead.
    [mpeg2video @ 0x9be7be0] mpeg_decode_postinit() failure
       Last message repeated 4 times
    [mpegts @ 0x9be3aa0] max_analyze_duration reached
    [mpegts @ 0x9be3aa0] PES packet size mismatch
    Input #0, mpegts, from '20130129-202049':
     Duration: 00:03:39.99, start: 9204.168844, bitrate: 1696 kb/s
       Stream #0.0[0x61]: Video: mpeg2video (Main), yuv420p, 528x480 [PAR 40:33 DAR 4:3], 15000 kb/s, 30.57 fps, 29.97 tbr, 90k tbn, 59.94 tbc
       Stream #0.1[0x64]: Audio: ac3, 48000 Hz, stereo, s16, 192 kb/s
    At least one output file must be specified

    This tells us that the video stream has PID 0x61 (97).

    I have been trying for a few days, so the following are only examples of a couple of attempts. I'll provide the playbin2 example first, since I know that thousands of people will respond, insisting that I just use that. It doesn't work.

    gst-launch-0.10 playbin2 uri=file:///home/dustin/recordings/20130129-202049

    Setting pipeline to PAUSED ...
    Pipeline is PREROLLING ...
    ERROR: from element /GstPlayBin2:playbin20/GstURIDecodeBin:uridecodebin0/GstDecodeBin2:decodebin20/GstMpegTSDemux:mpegtsdemux0: Could not determine type of stream.
    Additional debug info:
    gstmpegtsdemux.c(2931): gst_mpegts_demux_sink_event (): /GstPlayBin2:playbin20/GstURIDecodeBin:uridecodebin0/GstDecodeBin2:decodebin20/GstMpegTSDemux:mpegtsdemux0:
    No valid streams found at EOS
    ERROR: pipeline doesn't want to preroll.
    Setting pipeline to NULL ...
    Freeing pipeline ...

    It fails [probably] because no PID has been specified with which to find the video (the "EOS" error, I think).

    Naturally, I tried the following to start by demuxing the TS format. I believe it's the "es-pids" property that receives the PID in the absence of PMT information (which tstools said there weren't any, above), but I tried "program-number", too, just in case. gst-inspect indicates that one is hex and the other is decimal :

    gst-launch-0.10 -v filesrc location=20130129-202049 ! mpegtsdemux es-pids=0x61 ! fakesink
    gst-launch-0.10 -v filesrc location=20130129-202049 ! mpegtsdemux program-number=97 ! fakesink

    Output :

    gst-launch-0.10 filesrc location=20130129-202049 ! mpegtsdemux es-pids=0x61 ! fakesink
    Setting pipeline to PAUSED ...
    Pipeline is PREROLLING ...
    ERROR: from element /GstPipeline:pipeline0/GstMpegTSDemux:mpegtsdemux0: Could not determine type of stream.
    Additional debug info:
    gstmpegtsdemux.c(2931): gst_mpegts_demux_sink_event (): /GstPipeline:pipeline0/GstMpegTSDemux:mpegtsdemux0:
    No valid streams found at EOS
    ERROR: pipeline doesn't want to preroll.
    Setting pipeline to NULL ...
    Freeing pipeline ...
    dustin@dustinmicro:~/recordings$ gst-launch-0.10 -v filesrc location=20130129-202049 ! mpegtsdemux es-pids=0x61 ! fakesink
    Setting pipeline to PAUSED ...
    Pipeline is PREROLLING ...
    ERROR: from element /GstPipeline:pipeline0/GstMpegTSDemux:mpegtsdemux0: Could not determine type of stream.
    Additional debug info:
    gstmpegtsdemux.c(2931): gst_mpegts_demux_sink_event (): /GstPipeline:pipeline0/GstMpegTSDemux:mpegtsdemux0:
    No valid streams found at EOS
    ERROR: pipeline doesn't want to preroll.
    Setting pipeline to NULL ...
    Freeing pipeline ...
    dustin@dustinmicro:~/recordings$ gst-launch-0.10 -v filesrc location=20130129-202049 ! mpegtsdemux es-pids=0x61 ! fakesink
    Setting pipeline to PAUSED ...
    Pipeline is PREROLLING ...
    ERROR: from element /GstPipeline:pipeline0/GstMpegTSDemux:mpegtsdemux0: Could not determine type of stream.
    Additional debug info:
    gstmpegtsdemux.c(2931): gst_mpegts_demux_sink_event (): /GstPipeline:pipeline0/GstMpegTSDemux:mpegtsdemux0:
    No valid streams found at EOS
    ERROR: pipeline doesn't want to preroll.
    Setting pipeline to NULL ...
    Freeing pipeline ...

    However, when I try mpegpsdemux (for program streams (PS), as opposed to transport streams (TS)), I get further :

    gst-launch-0.10 filesrc location=20130129-202049 ! mpegpsdemux ! fakesink

    Setting pipeline to PAUSED ...
    Pipeline is PREROLLING ...

    (gst-launch-0.10:14805): GStreamer-CRITICAL **: gst_event_new_new_segment_full: assertion `position != -1' failed

    (gst-launch-0.10:14805): GStreamer-CRITICAL **: gst_mini_object_ref: assertion `mini_object != NULL' failed

    (gst-launch-0.10:14805): GStreamer-CRITICAL **: gst_pad_push_event: assertion `event != NULL' failed
    Pipeline is PREROLLED ...
    Setting pipeline to PLAYING ...
    New clock: GstSystemClock

    (gst-launch-0.10:14805): GStreamer-CRITICAL **: gst_event_new_new_segment_full: assertion `position != -1' failed

    (gst-launch-0.10:14805): GStreamer-CRITICAL **: gst_mini_object_ref: assertion `mini_object != NULL' failed

    (gst-launch-0.10:14805): GStreamer-CRITICAL **: gst_pad_push_event: assertion `event != NULL' failed

    (gst-launch-0.10:14805): GStreamer-CRITICAL **: gst_event_new_new_segment_full: assertion `position != -1' failed

    (gst-launch-0.10:14805): GStreamer-CRITICAL **: gst_mini_object_ref: assertion `mini_object != NULL' failed

    (gst-launch-0.10:14805): GStreamer-CRITICAL **: gst_pad_push_event: assertion `event != NULL' failed

    (gst-launch-0.10:14805): GStreamer-CRITICAL **: gst_event_new_new_segment_full: assertion `position != -1' failed

    (gst-launch-0.10:14805): GStreamer-CRITICAL **: gst_mini_object_ref: assertion `mini_object != NULL' failed

    (gst-launch-0.10:14805): GStreamer-CRITICAL **: gst_pad_push_event: assertion `event != NULL' failed


    ...


    Got EOS from element "pipeline0".
    Execution ended after 1654760008 ns.
    Setting pipeline to PAUSED ...
    Setting pipeline to READY ...
    Setting pipeline to NULL ...
    Freeing pipeline ...

    I'll still get the same problem whenever I use the mpegtsdemux, even if it follows mpegpsdemux, above.

    I don't understand this, since I haven't even picked a PID yet.

    What am I doing wrong ?

    Dustin

  • FFMPEG - Converting any kind of file to Mp4 compatible with IOS and Flash

    5 février 2013, par arashaga

    I am struggling with FFmpeg whithing Drupal Video Module to produce files to MP4 that is compatible with IOS and Flash Player10 and up.
    I have used the following commands so far, please note that the variables starting with " !" are placeholders and will be replaces with the proper items :

    FFmpeg -strict experimental -y -i !videofile -pass 1 -s !widthx!height -b:v 500k -threads 0 -vcodec libx264 -vf "pad=!paddingwidth:!paddingheight:!paddingleft:!paddingtop:000000" -preset slow -an !convertfile

    FFmpeg -strict experimental -y -i !videofile -pass 2 -s !widthx!height -b:v 500k -threads 0 -vcodec libx264 -vf "pad=!paddingwidth:!paddingheight:!paddingleft:!paddingtop:000000" -preset slow -acodec aac -ab 128k !convertfile

    The above command produce an error as :

    error executing command for rendering preset HTML5 MP4, command #1 :

    nice -n 19 /usr/bin/ffmpeg/ffmpeg -y -i '80137db8c3_1334836277_int_tr_19.mp4' -s 176x100 -b:v 500k -threads 0 -vcodec libx264 -preset slow -acodec aac -ab 128k '/converted/80137db8c3_1334836277_int_tr_19.mp4' 2>&1

    Output:

    ffmpeg version git-2013-02-01-5a67e30 Copyright (c) 2000-2013 the FFmpeg developers
     built on Feb  1 2013 14:23:14 with gcc 4.6 (Ubuntu/Linaro 4.6.3-1ubuntu5)
     configuration: --enable-gpl --enable-libass --enable-libfaac --enable-libfdk-aac --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-librtmp --enable-libtheora --enable-libvorbis --enable-libvpx --enable-libx264 --enable-nonfree --enable-version3
     libavutil      52. 17.100 / 52. 17.100
     libavcodec     54. 91.100 / 54. 91.100
     libavformat    54. 61.104 / 54. 61.104
     libavdevice    54.  3.103 / 54.  3.103
     libavfilter     3. 35.100 /  3. 35.100
     libswscale      2.  2.100 /  2.  2.100
     libswresample   0. 17.102 /  0. 17.102
     libpostproc    52.  2.100 / 52.  2.100
    Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '80137db8c3_1334836277_int_tr_19.mp4':
     Metadata:
       major_brand     : mp42
       minor_version   : 0
       compatible_brands: isommp42
       creation_time   : 2011-03-28 00:12:26
     Duration: 00:02:01.14, start: 0.000000, bitrate: 703 kb/s
       Stream #0:0(und): Video: h264 (Constrained Baseline) (avc1 / 0x31637661), yuv420p, 640x360 [SAR 1:1 DAR 16:9], 601 kb/s, 29.96 fps, 29.92 tbr, 1k tbn, 59.83 tbc
       Metadata:
         creation_time   : 1970-01-01 00:00:00
         handler_name    : VideoHandler
       Stream #0:1(und): Audio: aac (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 96 kb/s
       Metadata:
         creation_time   : 2011-03-28 00:12:27
         handler_name    : (C) 2007 Google Inc. v08.13.2007.
    [libx264 @ 0x34ec060] using SAR=100/99
    [libx264 @ 0x34ec060] using cpu capabilities: MMX2 SSE2Fast SSSE3 FastShuffle SSE4.2 AVX
    [libx264 @ 0x34ec060] profile High, level 2.0
    [libx264 @ 0x34ec060] 264 - core 129 r2245 bc13772 - H.264/MPEG-4 AVC codec - Copyleft 2003-2013 - http://www.videolan.org/x264.html - options: cabac=1 ref=5 deblock=1:0:0 analyse=0x3:0x113 me=umh subme=8 psy=1 psy_rd=1.00:0.00 mixed_ref=1 me_range=16 chroma_me=1 trellis=1 8x8dct=1 cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=-2 threads=12 lookahead_threads=1 sliced_threads=0 nr=0 decimate=1 interlaced=0 bluray_compat=0 constrained_intra=0 bframes=3 b_pyramid=2 b_adapt=2 b_bias=0 direct=3 weightb=1 open_gop=0 weightp=2 keyint=250 keyint_min=25 scenecut=40 intra_refresh=0 rc_lookahead=50 rc=abr mbtree=1 bitrate=500 ratetol=1.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4 ip_ratio=1.40 aq=1:1.00
    The encoder 'aac' is experimental but experimental codecs are not enabled, add '-strict -2' if you want to use it.
    Alternatively use the non experimental encoder 'libfaac'.

    Another command that I used is :

    FFmpeg -i !videofile -an -pass 1 -vcodec libx264 -preset slow -b 500k -threads auto !convertfile

    FFMpeg -y -i !videofile -acodec libfaac -ab 128k -pass 2 -vcodec libx264 -preset slow -b 500k -threads auto !convertfile

    Output for the first pass :

    Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'comiccon.mp4':
     Metadata:
       major_brand     : isom
       minor_version   : 512
       compatible_brands: mp41
       creation_time   : 2012-08-15 17:12:37
     Duration: 01:17:15.93, start: 0.000000, bitrate: 706 kb/s
       Stream #0:0(eng): Video: h264 (Constrained Baseline) (avc1 / 0x31637661), yuv420p, 640x360 [SAR 1:1 DAR 16:9], 636 kb/s, 30 fps, 30 tbr, 90k tbn, 60 tbc
       Metadata:
         creation_time   : 2012-08-15 17:12:37
         handler_name    : VideoHandler
       Stream #0:1(eng): Audio: aac (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 63 kb/s
       Metadata:
         creation_time   : 2012-08-15 17:12:37
         handler_name    : SoundHandler
    Please use -b:a or -b:v, -b is ambiguous

    using SAR=1/1
    [libx264 @ 0x1c39be0] using cpu capabilities: MMX2 SSE2Fast SSSE3 FastShuffle SSE4.2 AVX
    [libx264 @ 0x1c39be0] profile Main, level 3.0
    [libx264 @ 0x1c39be0] 264 - core 129 r2245 bc13772 - H.264/MPEG-4 AVC codec - Copyleft 2003-2013 - http://www.videolan.org/x264.html - options: cabac=1 ref=1 deblock=1:0:0 analyse=0x1:0 me=dia subme=2 psy=1 psy_rd=1.00:0.00 mixed_ref=0 me_range=16 chroma_me=1 trellis=0 8x8dct=0 cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=0 threads=12 lookahead_threads=2 sliced_threads=0 nr=0 decimate=1 interlaced=0 bluray_compat=0 constrained_intra=0 bframes=3 b_pyramid=2 b_adapt=2 b_bias=0 direct=3 weightb=1 open_gop=0 weightp=2 keyint=250 keyint_min=25 scenecut=40 intra_refresh=0 rc_lookahead=50 rc=abr mbtree=1 bitrate=500 ratetol=1.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4 ip_ratio=1.40 aq=1:1.00
    Output #0, mp4, to 'comiccon.mp4':
     Metadata:
       major_brand     : isom
       minor_version   : 512
       compatible_brands: mp41
       encoder         : Lavf54.61.104
       Stream #0:0(eng): Video: h264 ([33][0][0][0] / 0x0021), yuv420p, 640x360 [SAR 1:1 DAR 16:9], q=-1--1, pass 1, 500 kb/s, 15360 tbn, 30 tbc
       Metadata:
         creation_time   : 2012-08-15 17:12:37
         handler_name    : VideoHandler
    Stream mapping:
     Stream #0:0 -> #0:0 (h264 -> libx264)
    Press [q] to stop, [?] for help
    frame=139078 fps=279 q=32766.0 Lsize=  286145kB time=01:17:15.86 bitrate= 505.6kbits/s    
    video:284758kB audio:0kB subtitle:0 global headers:0kB muxing overhead 0.487000%
    [libx264 @ 0x1c39be0] frame I:656   Avg QP:19.51  size: 21457
    [libx264 @ 0x1c39be0] frame P:76006 Avg QP:22.19  size:  3141
    [libx264 @ 0x1c39be0] frame B:62416 Avg QP:26.38  size:   621
    [libx264 @ 0x1c39be0] consecutive B-frames: 32.3% 17.5% 18.6% 31.6%
    [libx264 @ 0x1c39be0] mb I  I16..4: 24.5%  0.0% 75.5%
    [libx264 @ 0x1c39be0] mb P  I16..4:  7.5%  0.0%  0.0%  P16..4: 40.5%  0.0%  0.0%  0.0%  0.0%    skip:52.1%
    [libx264 @ 0x1c39be0] mb B  I16..4:  1.4%  0.0%  0.0%  B16..8: 12.0%  0.0%  0.0%  direct: 2.9%  skip:83.7%  L0:41.1% L1:41.6% BI:17.3%
    [libx264 @ 0x1c39be0] final ratefactor: 23.45
    [libx264 @ 0x1c39be0] direct mvs  spatial:95.3% temporal:4.7%
    [libx264 @ 0x1c39be0] coded y,uvDC,uvAC intra: 37.6% 42.8% 11.8% inter: 8.9% 8.2% 0.5%
    [libx264 @ 0x1c39be0] i16 v,h,dc,p: 43% 28% 19% 10%
    [libx264 @ 0x1c39be0] i4 v,h,dc,ddl,ddr,vr,hd,vl,hu: 36% 21% 11%  6%  4%  5%  4%  6%  6%
    [libx264 @ 0x1c39be0] i8c dc,h,v,p: 57% 19% 20%  4%
    [libx264 @ 0x1c39be0] Weighted P-Frames: Y:1.4% UV:0.5%
    [libx264 @ 0x1c39be0] kb/s:503.18

    output for the second pass :

    Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'comiccon.mp4':
     Metadata:
       major_brand     : isom
       minor_version   : 512
       compatible_brands: mp41
       creation_time   : 2012-08-15 17:12:37
     Duration: 01:17:15.93, start: 0.000000, bitrate: 706 kb/s
       Stream #0:0(eng): Video: h264 (Constrained Baseline) (avc1 / 0x31637661), yuv420p, 640x360 [SAR 1:1 DAR 16:9], 636 kb/s, 30 fps, 30 tbr, 90k tbn, 60 tbc
       Metadata:
         creation_time   : 2012-08-15 17:12:37
         handler_name    : VideoHandler
       Stream #0:1(eng): Audio: aac (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 63 kb/s
       Metadata:
         creation_time   : 2012-08-15 17:12:37
         handler_name    : SoundHandler
    Please use -b:a or -b:v, -b is ambiguous
    [libx264 @ 0x3247f80] using SAR=1/1
    [libx264 @ 0x3247f80] using cpu capabilities: MMX2 SSE2Fast SSSE3 FastShuffle SSE4.2 AVX
    [libx264 @ 0x3247f80] profile High, level 3.0
    [libx264 @ 0x3247f80] 264 - core 129 r2245 bc13772 - H.264/MPEG-4 AVC codec - Copyleft 2003-2013 - http://www.videolan.org/x264.html - options: cabac=1 ref=5 deblock=1:0:0 analyse=0x3:0x113 me=umh subme=8 psy=1 psy_rd=1.00:0.00 mixed_ref=1 me_range=16 chroma_me=1 trellis=1 8x8dct=1 cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=-2 threads=12 lookahead_threads=2 sliced_threads=0 nr=0 decimate=1 interlaced=0 bluray_compat=0 constrained_intra=0 bframes=3 b_pyramid=2 b_adapt=2 b_bias=0 direct=3 weightb=1 open_gop=0 weightp=2 keyint=250 keyint_min=25 scenecut=40 intra_refresh=0 rc_lookahead=50 rc=2pass mbtree=1 bitrate=500 ratetol=1.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4 cplxblur=20.0 qblur=0.5 ip_ratio=1.40 aq=1:1.00
    Output #0, mp4, to 'comiccon.mp4':
     Metadata:
       major_brand     : isom
       minor_version   : 512
       compatible_brands: mp41
       encoder         : Lavf54.61.104
       Stream #0:0(eng): Video: h264 ([33][0][0][0] / 0x0021), yuv420p, 640x360 [SAR 1:1 DAR 16:9], q=-1--1, pass 2, 500 kb/s, 15360 tbn, 30 tbc
       Metadata:
         creation_time   : 2012-08-15 17:12:37
         handler_name    : VideoHandler
       Stream #0:1(eng): Audio: aac ([64][0][0][0] / 0x0040), 44100 Hz, stereo, s16, 128 kb/s
       Metadata:
         creation_time   : 2012-08-15 17:12:37
         handler_name    : SoundHandler
    Stream mapping:
     Stream #0:0 -> #0:0 (h264 -> libx264)
     Stream #0:1 -> #0:1 (aac -> libfaac)
    Press [q] to stop, [?] for help
    frame=139078 fps=206 q=32766.0 Lsize=  357252kB time=01:17:15.93 bitrate= 631.3kbits/s    
    video:282992kB audio:69592kB subtitle:0 global headers:0kB muxing overhead 1.324238%
    [libx264 @ 0x3247f80] frame I:656   Avg QP:19.61  size: 20433
    [libx264 @ 0x3247f80] frame P:76006 Avg QP:23.07  size:  2996
    [libx264 @ 0x3247f80] frame B:62416 Avg QP:26.23  size:   780
    [libx264 @ 0x3247f80] consecutive B-frames: 32.3% 17.5% 18.6% 31.6%
    [libx264 @ 0x3247f80] mb I  I16..4: 17.2% 37.8% 44.9%
    [libx264 @ 0x3247f80] mb P  I16..4:  2.9%  3.7%  1.2%  P16..4: 30.3%  6.1%  3.4%  0.0%  0.0%    skip:52.5%
    [libx264 @ 0x3247f80] mb B  I16..4:  0.5%  0.6%  0.3%  B16..8: 25.9%  2.2%  0.5%  direct: 0.9%  skip:69.3%  L0:51.4% L1:43.0% BI: 5.7%
    [libx264 @ 0x3247f80] 8x8 transform intra:45.9% inter:51.5%
    [libx264 @ 0x3247f80] direct mvs  spatial:85.5% temporal:14.5%
    [libx264 @ 0x3247f80] coded y,uvDC,uvAC intra: 47.3% 49.2% 13.5% inter: 9.0% 9.4% 0.5%
    [libx264 @ 0x3247f80] i16 v,h,dc,p: 38% 27% 13% 22%
    [libx264 @ 0x3247f80] i8 v,h,dc,ddl,ddr,vr,hd,vl,hu: 29% 16% 14%  5%  5%  7%  7%  8%  9%
    [libx264 @ 0x3247f80] i4 v,h,dc,ddl,ddr,vr,hd,vl,hu: 31% 15%  9%  6%  7%  8%  7%  8%  8%
    [libx264 @ 0x3247f80] i8c dc,h,v,p: 49% 22% 20%  8%
    [libx264 @ 0x3247f80] Weighted P-Frames: Y:1.4% UV:0.5%
    [libx264 @ 0x3247f80] ref P L0: 79.3% 10.4%  6.8%  1.6%  1.2%  0.7%  0.0%
    [libx264 @ 0x3247f80] ref B L0: 93.6%  4.8%  1.2%  0.3%
    [libx264 @ 0x3247f80] ref B L1: 96.6%  3.4%
    [libx264 @ 0x3247f80] kb/s:500.06

    The above command produces the file correctly however it cannot be played in flash player. One thing that I noticed is this may happen if the input file is mp4 as well. This command is executed for users uploading files, so the input file could be any format.

    Below is the information about my FFmpeg version :

    ffmpeg version git-2013-02-01-5a67e30 Copyright (c) 2000-2013 the
    FFmpeg developers built on Feb 1 2013 14:23:14 with gcc 4.6
    (Ubuntu/Linaro 4.6.3-1ubuntu5) configuration : —enable-gpl
    —enable-libass —enable-libfaac —enable-libfdk-aac —enable-libmp3lame —enable-libopencore-amrnb —enable-libopencore-amrwb —enable-librtmp —enable-libtheora —enable-libvorbis —enable-libvpx —enable-libx264 —enable-nonfree —enable-version3 libavutil 52. 17.100 / 52. 17.100
    libavcodec 54. 91.100 / 54. 91.100
    libavformat 54. 61.104 / 54. 61.104
    libavdevice 54. 3.103 / 54. 3.103
    libavfilter 3. 35.100 / 3. 35.100
    libswscale 2. 2.100 / 2. 2.100
    libswresample 0. 17.102 / 0. 17.102
    libpostproc 52. 2.100 / 52. 2.1

    Thanks,

  • ffmpeg : avi to mp4 (h.264/aac) - sound yes, image no

    21 février 2013, par user1711384

    working with ffmpeg at a conversion (any file to mp4 (h.264/aac)) :

    exec("ffmpeg -y -i testdatei.avi -i logo.jpg -filter_complex overlay=15:15,scale=-1:720 -c:v libx264 -profile:v baseline -preset medium -b:v 880k -g 10 -pass 1 -an -f mp4 -movflags faststart /dev/null && \ ", $output1);
    var_dump($output1);
    exec("ffmpeg -y -i testdatei.avi -i logo.jpg -filter_complex overlay=15:15,scale=-1:720 -c:v libx264 -profile:v baseline -preset medium -b:v 880k -g 10 -pass 2 -c:a libfdk_aac -b:a 128k -movflags faststart xxx.mp4 2>&1", $output2);
    var_dump($output2);

    With a mpeg and wmv-file its working. With 2 differenz AVIs it didnt work, logfiles from path 1 arent generated and output1 is empty, output2 of course generates an error. After removing -profile:v baseline in both commands, the videofile is successfull generates, but its not possible to play it in jwplayer (sound yes, but no image).

    This is the content of output1 :

    array(0) {
    }
    array(59) {
     [0]=>
     string(83) "ffmpeg version git-2013-02-20-39b0393 Copyright (c) 2000-2013 the FFmpeg developers"
     [1]=>
     string(75) "  built on Feb 20 2013 12:06:36 with gcc 4.6 (Ubuntu/Linaro 4.6.3-1ubuntu5)"
     [2]=>
     string(297) "  configuration: --enable-gpl --enable-libass --enable-libfaac --enable-libfdk-aac --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libspeex --enable-librtmp --enable-libtheora --enable-libvorbis --enable-libvpx --enable-libx264 --enable-nonfree --enable-version3"
     [3]=>
     string(40) "  libavutil      52. 17.102 / 52. 17.102"
     [4]=>
     string(40) "  libavcodec     54. 92.100 / 54. 92.100"
     [5]=>
     string(40) "  libavformat    54. 63.100 / 54. 63.100"
     [6]=>
     string(40) "  libavdevice    54.  3.103 / 54.  3.103"
     [7]=>
     string(40) "  libavfilter     3. 38.103 /  3. 38.103"
     [8]=>
     string(40) "  libswscale      2.  2.100 /  2.  2.100"
     [9]=>
     string(40) "  libswresample   0. 17.102 /  0. 17.102"
     [10]=>
     string(40) "  libpostproc    52.  2.100 / 52.  2.100"
     [11]=>
     string(37) "[avi @ 0x23e4d80] non-interleaved AVI"
     [12]=>
     string(54) "Guessed Channel Layout for  Input Stream #0.1 : stereo"
     [13]=>
     string(36) "Input #0, avi, from 'testdatei.avi':"
     [14]=>
     string(11) "  Metadata:"
     [15]=>
     string(47) "    date            : 2013-02-21T14:06:32+01:00"
     [16]=>
     string(54) "    encoder         : Adobe Premiere Pro CS6 (Windows)"
     [17]=>
     string(61) "  Duration: 00:00:07.57, start: 0.000000, bitrate: 30330 kb/s"
     [18]=>
     string(120) "    Stream #0:0: Video: dvvideo (dvsd / 0x64737664), yuv411p, 720x480 [SAR 8:9 DAR 4:3], 29.97 tbr, 29.97 tbn, 29.97 tbc"
     [19]=>
     string(91) "    Stream #0:1: Audio: pcm_s16le ([1][0][0][0] / 0x0001), 48000 Hz, stereo, s16, 1536 kb/s"
     [20]=>
     string(34) "Input #1, image2, from 'logo.jpg':"
     [21]=>
     string(54) "  Duration: 00:00:00.04, start: 0.000000, bitrate: N/A"
     [22]=>
     string(71) "    Stream #1:0: Video: mjpeg, yuvj444p, 170x82, 25 tbr, 25 tbn, 25 tbc"
     [23]=>
     string(35) "[libx264 @ 0x23e9640] using SAR=8/9"
     [24]=>
     string(88) "[libx264 @ 0x23e9640] using cpu capabilities: MMX2 SSE2Fast SSSE3 FastShuffle SSE4.2 AVX"
     [25]=>
     string(75) "[libx264 @ 0x23e9640] profile High 4:4:4 Predictive, level 3.1, 4:4:4 8-bit"
     [26]=>
     string(720) "[libx264 @ 0x23e9640] 264 - core 129 r2 bc13772 - H.264/MPEG-4 AVC codec - Copyleft 2003-2013 - http://www.videolan.org/x264.html - options: cabac=1 ref=3 deblock=1:0:0 analyse=0x3:0x113 me=hex subme=7 psy=1 psy_rd=1.00:0.00 mixed_ref=1 me_range=16 chroma_me=1 trellis=1 8x8dct=1 cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=4 threads=12 lookahead_threads=2 sliced_threads=0 nr=0 decimate=1 interlaced=0 bluray_compat=0 constrained_intra=0 bframes=3 b_pyramid=2 b_adapt=1 b_bias=0 direct=1 weightb=1 open_gop=0 weightp=2 keyint=10 keyint_min=1 scenecut=40 intra_refresh=0 rc_lookahead=10 rc=2pass mbtree=1 bitrate=880 ratetol=1.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4 cplxblur=20.0 qblur=0.5 ip_ratio=1.40 aq=1:1.00"
     [27]=>
     string(29) "Output #0, mp4, to 'xxx.mp4':"
     [28]=>
     string(11) "  Metadata:"
     [29]=>
     string(47) "    date            : 2013-02-21T14:06:32+01:00"
     [30]=>
     string(35) "    encoder         : Lavf54.63.100"
     [31]=>
     string(139) "    Stream #0:0: Video: h264 ([33][0][0][0] / 0x0021), yuv444p, 1080x720 [SAR 8:9 DAR 4:3], q=-1--1, pass 2, 880 kb/s, 11988 tbn, 29.97 tbc"
     [32]=>
     string(85) "    Stream #0:1: Audio: aac ([64][0][0][0] / 0x0040), 48000 Hz, stereo, s16, 128 kb/s"
     [33]=>
     string(15) "Stream mapping:"
     [34]=>
     string(49) "  Stream #0:0 (dvvideo) -> overlay:main (graph 0)"
     [35]=>
     string(50) "  Stream #1:0 (mjpeg) -> overlay:overlay (graph 0)"
     [36]=>
     string(42) "  scale (graph 0) -> Stream #0:0 (libx264)"
     [37]=>
     string(47) "  Stream #0:1 -> #0:1 (pcm_s16le -> libfdk_aac)"
     [38]=>
     string(31) "Press [q] to stop, [?] for help"
     [39]=>
     string(226) "frame=   79 fps=0.0 q=30.0 size=     291kB time=00:00:02.58 bitrate= 922.4kbits/s    
    frame=  162 fps=162 q=30.0 size=     620kB time=00:00:05.33 bitrate= 952.9kbits/s    
    Starting second pass: moving header on top of the file"
     [40]=>
     string(85) "frame=  227 fps=154 q=32766.0 Lsize=     958kB time=00:00:07.59 bitrate=1033.5kbits/s"
     [41]=>
     string(79) "video:829kB audio:120kB subtitle:0 global headers:0kB muxing overhead 0.986027%"
     [42]=>
     string(61) "[libx264 @ 0x23e9640] frame I:23    Avg QP:19.11  size: 31383"
     [43]=>
     string(61) "[libx264 @ 0x23e9640] frame P:68    Avg QP:23.91  size:  1240"
     [44]=>
     string(61) "[libx264 @ 0x23e9640] frame B:136   Avg QP:20.27  size:   310"
     [45]=>
     string(67) "[libx264 @ 0x23e9640] consecutive B-frames: 19.8%  0.9%  0.0% 79.3%"
     [46]=>
     string(53) "[libx264 @ 0x23e9640] mb I  I16..4: 18.8% 68.4% 12.8%"
     [47]=>
     string(106) "[libx264 @ 0x23e9640] mb P  I16..4:  0.3%  0.3%  0.0%  P16..4: 10.7%  2.3%  0.8%  0.0%  0.0%    skip:85.6%"
     [48]=>
     string(134) "[libx264 @ 0x23e9640] mb B  I16..4:  0.0%  0.0%  0.0%  B16..8:  9.1%  0.1%  0.0%  direct: 0.1%  skip:90.7%  L0:41.2% L1:58.6% BI: 0.2%"
     [49]=>
     string(59) "[libx264 @ 0x23e9640] 8x8 transform intra:68.3% inter:97.5%"
     [50]=>
     string(80) "[libx264 @ 0x23e9640] coded y,u,v intra: 53.7% 26.9% 30.8% inter: 0.5% 0.2% 0.3%"
     [51]=>
     string(51) "[libx264 @ 0x23e9640] i16 v,h,dc,p: 70% 17%  1% 11%"
     [52]=>
     string(88) "[libx264 @ 0x23e9640] i8 v,h,dc,ddl,ddr,vr,hd,vl,hu: 28% 25% 18%  4%  3%  4%  4%  6%  8%"
     [53]=>
     string(88) "[libx264 @ 0x23e9640] i4 v,h,dc,ddl,ddr,vr,hd,vl,hu: 33% 29%  8%  4%  6%  6%  5%  5%  4%"
     [54]=>
     string(55) "[libx264 @ 0x23e9640] Weighted P-Frames: Y:0.0% UV:0.0%"
     [55]=>
     string(55) "[libx264 @ 0x23e9640] ref P L0: 75.9%  5.1% 11.3%  7.7%"
     [56]=>
     string(49) "[libx264 @ 0x23e9640] ref B L0: 96.0%  3.1%  0.9%"
     [57]=>
     string(43) "[libx264 @ 0x23e9640] ref B L1: 95.8%  4.2%"
     [58]=>
     string(33) "[libx264 @ 0x23e9640] kb/s:895.99"
    }

    Output2 :

    array(59) {
     [0]=>
     string(83) "ffmpeg version git-2013-02-20-39b0393 Copyright (c) 2000-2013 the FFmpeg developers"
     [1]=>
     string(75) "  built on Feb 20 2013 12:06:36 with gcc 4.6 (Ubuntu/Linaro 4.6.3-1ubuntu5)"
     [2]=>
     string(297) "  configuration: --enable-gpl --enable-libass --enable-libfaac --enable-libfdk-aac --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libspeex --enable-librtmp --enable-libtheora --enable-libvorbis --enable-libvpx --enable-libx264 --enable-nonfree --enable-version3"
     [3]=>
     string(40) "  libavutil      52. 17.102 / 52. 17.102"
     [4]=>
     string(40) "  libavcodec     54. 92.100 / 54. 92.100"
     [5]=>
     string(40) "  libavformat    54. 63.100 / 54. 63.100"
     [6]=>
     string(40) "  libavdevice    54.  3.103 / 54.  3.103"
     [7]=>
     string(40) "  libavfilter     3. 38.103 /  3. 38.103"
     [8]=>
     string(40) "  libswscale      2.  2.100 /  2.  2.100"
     [9]=>
     string(40) "  libswresample   0. 17.102 /  0. 17.102"
     [10]=>
     string(40) "  libpostproc    52.  2.100 / 52.  2.100"
     [11]=>
     string(37) "[avi @ 0x23e4d80] non-interleaved AVI"
     [12]=>
     string(54) "Guessed Channel Layout for  Input Stream #0.1 : stereo"
     [13]=>
     string(36) "Input #0, avi, from 'testdatei.avi':"
     [14]=>
     string(11) "  Metadata:"
     [15]=>
     string(47) "    date            : 2013-02-21T14:06:32+01:00"
     [16]=>
     string(54) "    encoder         : Adobe Premiere Pro CS6 (Windows)"
     [17]=>
     string(61) "  Duration: 00:00:07.57, start: 0.000000, bitrate: 30330 kb/s"
     [18]=>
     string(120) "    Stream #0:0: Video: dvvideo (dvsd / 0x64737664), yuv411p, 720x480 [SAR 8:9 DAR 4:3], 29.97 tbr, 29.97 tbn, 29.97 tbc"
     [19]=>
     string(91) "    Stream #0:1: Audio: pcm_s16le ([1][0][0][0] / 0x0001), 48000 Hz, stereo, s16, 1536 kb/s"
     [20]=>
     string(34) "Input #1, image2, from 'logo.jpg':"
     [21]=>
     string(54) "  Duration: 00:00:00.04, start: 0.000000, bitrate: N/A"
     [22]=>
     string(71) "    Stream #1:0: Video: mjpeg, yuvj444p, 170x82, 25 tbr, 25 tbn, 25 tbc"
     [23]=>
     string(35) "[libx264 @ 0x23e9640] using SAR=8/9"
     [24]=>
     string(88) "[libx264 @ 0x23e9640] using cpu capabilities: MMX2 SSE2Fast SSSE3 FastShuffle SSE4.2 AVX"
     [25]=>
     string(75) "[libx264 @ 0x23e9640] profile High 4:4:4 Predictive, level 3.1, 4:4:4 8-bit"
     [26]=>
     string(720) "[libx264 @ 0x23e9640] 264 - core 129 r2 bc13772 - H.264/MPEG-4 AVC codec - Copyleft 2003-2013 - http://www.videolan.org/x264.html - options: cabac=1 ref=3 deblock=1:0:0 analyse=0x3:0x113 me=hex subme=7 psy=1 psy_rd=1.00:0.00 mixed_ref=1 me_range=16 chroma_me=1 trellis=1 8x8dct=1 cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=4 threads=12 lookahead_threads=2 sliced_threads=0 nr=0 decimate=1 interlaced=0 bluray_compat=0 constrained_intra=0 bframes=3 b_pyramid=2 b_adapt=1 b_bias=0 direct=1 weightb=1 open_gop=0 weightp=2 keyint=10 keyint_min=1 scenecut=40 intra_refresh=0 rc_lookahead=10 rc=2pass mbtree=1 bitrate=880 ratetol=1.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4 cplxblur=20.0 qblur=0.5 ip_ratio=1.40 aq=1:1.00"
     [27]=>
     string(29) "Output #0, mp4, to 'xxx.mp4':"
     [28]=>
     string(11) "  Metadata:"
     [29]=>
     string(47) "    date            : 2013-02-21T14:06:32+01:00"
     [30]=>
     string(35) "    encoder         : Lavf54.63.100"
     [31]=>
     string(139) "    Stream #0:0: Video: h264 ([33][0][0][0] / 0x0021), yuv444p, 1080x720 [SAR 8:9 DAR 4:3], q=-1--1, pass 2, 880 kb/s, 11988 tbn, 29.97 tbc"
     [32]=>
     string(85) "    Stream #0:1: Audio: aac ([64][0][0][0] / 0x0040), 48000 Hz, stereo, s16, 128 kb/s"
     [33]=>
     string(15) "Stream mapping:"
     [34]=>
     string(49) "  Stream #0:0 (dvvideo) -> overlay:main (graph 0)"
     [35]=>
     string(50) "  Stream #1:0 (mjpeg) -> overlay:overlay (graph 0)"
     [36]=>
     string(42) "  scale (graph 0) -> Stream #0:0 (libx264)"
     [37]=>
     string(47) "  Stream #0:1 -> #0:1 (pcm_s16le -> libfdk_aac)"
     [38]=>
     string(31) "Press [q] to stop, [?] for help"
     [39]=>
     string(226) "frame=   79 fps=0.0 q=30.0 size=     291kB time=00:00:02.58 bitrate= 922.4kbits/s    
    frame=  162 fps=162 q=30.0 size=     620kB time=00:00:05.33 bitrate= 952.9kbits/s    
    Starting second pass: moving header on top of the file"
     [40]=>
     string(85) "frame=  227 fps=154 q=32766.0 Lsize=     958kB time=00:00:07.59 bitrate=1033.5kbits/s"
     [41]=>
     string(79) "video:829kB audio:120kB subtitle:0 global headers:0kB muxing overhead 0.986027%"
     [42]=>
     string(61) "[libx264 @ 0x23e9640] frame I:23    Avg QP:19.11  size: 31383"
     [43]=>
     string(61) "[libx264 @ 0x23e9640] frame P:68    Avg QP:23.91  size:  1240"
     [44]=>
     string(61) "[libx264 @ 0x23e9640] frame B:136   Avg QP:20.27  size:   310"
     [45]=>
     string(67) "[libx264 @ 0x23e9640] consecutive B-frames: 19.8%  0.9%  0.0% 79.3%"
     [46]=>
     string(53) "[libx264 @ 0x23e9640] mb I  I16..4: 18.8% 68.4% 12.8%"
     [47]=>
     string(106) "[libx264 @ 0x23e9640] mb P  I16..4:  0.3%  0.3%  0.0%  P16..4: 10.7%  2.3%  0.8%  0.0%  0.0%    skip:85.6%"
     [48]=>
     string(134) "[libx264 @ 0x23e9640] mb B  I16..4:  0.0%  0.0%  0.0%  B16..8:  9.1%  0.1%  0.0%  direct: 0.1%  skip:90.7%  L0:41.2% L1:58.6% BI: 0.2%"
     [49]=>
     string(59) "[libx264 @ 0x23e9640] 8x8 transform intra:68.3% inter:97.5%"
     [50]=>
     string(80) "[libx264 @ 0x23e9640] coded y,u,v intra: 53.7% 26.9% 30.8% inter: 0.5% 0.2% 0.3%"
     [51]=>
     string(51) "[libx264 @ 0x23e9640] i16 v,h,dc,p: 70% 17%  1% 11%"
     [52]=>
     string(88) "[libx264 @ 0x23e9640] i8 v,h,dc,ddl,ddr,vr,hd,vl,hu: 28% 25% 18%  4%  3%  4%  4%  6%  8%"
     [53]=>
     string(88) "[libx264 @ 0x23e9640] i4 v,h,dc,ddl,ddr,vr,hd,vl,hu: 33% 29%  8%  4%  6%  6%  5%  5%  4%"
     [54]=>
     string(55) "[libx264 @ 0x23e9640] Weighted P-Frames: Y:0.0% UV:0.0%"
     [55]=>
     string(55) "[libx264 @ 0x23e9640] ref P L0: 75.9%  5.1% 11.3%  7.7%"
     [56]=>
     string(49) "[libx264 @ 0x23e9640] ref B L0: 96.0%  3.1%  0.9%"
     [57]=>
     string(43) "[libx264 @ 0x23e9640] ref B L1: 95.8%  4.2%"
     [58]=>
     string(33) "[libx264 @ 0x23e9640] kb/s:895.99"
    }

    Do you have a idea, why avi makes problems ? what could be a solution ?