X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;ds=sidebyside;f=tests%2Fregression.sh;h=7580e866f4f7e00bc7b473989b77667ad6152ab9;hb=afebe2f7cac1e23ea5b198cfe5bfabf5e7f1105f;hp=85c9e28ee1f95bfc37e3b6cd2b398d3a2e75ac25;hpb=2d1e5071e221738c666adf9f5d25c1a2606e1e90;p=ffmpeg diff --git a/tests/regression.sh b/tests/regression.sh index 85c9e28ee1f..7580e866f4f 100755 --- a/tests/regression.sh +++ b/tests/regression.sh @@ -4,7 +4,7 @@ # # #set -x -# Even in the 21st century some diffs are not supporting -u. +# Even in the 21st century some diffs do not support -u. diff -u "$0" "$0" > /dev/null 2>&1 if [ $? -eq 0 ]; then diff_cmd="diff -u" @@ -19,12 +19,12 @@ fi set -e -datadir="./data" +datadir="./tests/data" logfile="$datadir/ffmpeg.regression" outfile="$datadir/a-" -# tests to do +# tests to run if [ "$1" = "mpeg4" ] ; then do_mpeg4=y elif [ "$1" = "mpeg" ] ; then @@ -41,7 +41,7 @@ elif [ "$1" = "snow" ] ; then elif [ "$1" = "snowll" ] ; then do_snowll=y elif [ "$1" = "libavtest" ] ; then - do_libav=y + do_libavtest=y logfile="$datadir/libav.regression" outfile="$datadir/b-" else @@ -69,6 +69,8 @@ else do_adpcm_ima_wav=y do_adpcm_ms=y do_flac=y + do_wma=y + do_vorbis=y do_rc=y do_mpeg4adv=y do_mpeg4thread=y @@ -85,18 +87,21 @@ else do_adpcm_yam=y do_dv=y do_dv50=y + do_flashsv=y fi # various files -ffmpeg="../ffmpeg_g" -tiny_psnr="./tiny_psnr" +ffmpeg="./ffmpeg_g" +tiny_psnr="tests/tiny_psnr" reffile="$2" benchfile="$datadir/ffmpeg.bench" +bench="$datadir/bench.tmp" +bench2="$datadir/bench2.tmp" raw_src="$3/%02d.pgm" raw_dst="$datadir/out.yuv" raw_ref="$datadir/ref.yuv" -pcm_src="asynth1.sw" +pcm_src="tests/asynth1.sw" pcm_dst="$datadir/out.wav" pcm_ref="$datadir/ref.wav" if [ X"`echo | md5sum 2> /dev/null`" != X ]; then @@ -107,7 +112,7 @@ else do_md5sum() { echo No md5sum program found; } fi -# create the data directory if it does not exists +# create the data directory if it does not exist mkdir -p $datadir FFMPEG_OPTS="-y -flags +bitexact -dct fastint -idct simple" @@ -117,7 +122,7 @@ do_ffmpeg() f="$1" shift echo $ffmpeg $FFMPEG_OPTS $* - $ffmpeg $FFMPEG_OPTS -benchmark $* > $datadir/bench.tmp 2> /tmp/ffmpeg$$ + $ffmpeg $FFMPEG_OPTS -benchmark $* > $bench 2> /tmp/ffmpeg$$ egrep -v "^(Stream|Press|Input|Output|frame| Stream| Duration|video:)" /tmp/ffmpeg$$ || true rm -f /tmp/ffmpeg$$ do_md5sum $f >> $logfile @@ -128,8 +133,27 @@ do_ffmpeg() else wc -c $f >> $logfile fi - expr "`cat $datadir/bench.tmp`" : '.*utime=\(.*s\)' > $datadir/bench2.tmp - echo `cat $datadir/bench2.tmp` $f >> $benchfile + expr "`cat $bench`" : '.*utime=\(.*s\)' > $bench2 + echo `cat $bench2` $f >> $benchfile +} + +do_ffmpeg_nomd5() +{ + f="$1" + shift + echo $ffmpeg $FFMPEG_OPTS $* + $ffmpeg $FFMPEG_OPTS -benchmark $* > $bench 2> /tmp/ffmpeg$$ + egrep -v "^(Stream|Press|Input|Output|frame| Stream| Duration|video:)" /tmp/ffmpeg$$ || true + rm -f /tmp/ffmpeg$$ + if [ $f = $raw_dst ] ; then + $tiny_psnr $f $raw_ref >> $logfile + elif [ $f = $pcm_dst ] ; then + $tiny_psnr $f $pcm_ref 2 >> $logfile + else + wc -c $f >> $logfile + fi + expr "`cat $bench`" : '.*utime=\(.*s\)' > $bench2 + echo `cat $bench2` $f >> $benchfile } do_ffmpeg_crc() @@ -148,11 +172,11 @@ do_ffmpeg_nocheck() f="$1" shift echo $ffmpeg $FFMPEG_OPTS $* - $ffmpeg $FFMPEG_OPTS -benchmark $* > $datadir/bench.tmp 2> /tmp/ffmpeg$$ + $ffmpeg $FFMPEG_OPTS -benchmark $* > $bench 2> /tmp/ffmpeg$$ egrep -v "^(Stream|Press|Input|Output|frame| Stream| Duration|video:)" /tmp/ffmpeg$$ || true rm -f /tmp/ffmpeg$$ - expr "`cat $datadir/bench.tmp`" : '.*utime=\(.*s\)' > $datadir/bench2.tmp - echo `cat $datadir/bench2.tmp` $f >> $benchfile + expr "`cat $bench`" : '.*utime=\(.*s\)' > $bench2 + echo `cat $bench2` $f >> $benchfile } do_video_decoding() @@ -169,7 +193,7 @@ do_video_encoding() do_audio_encoding() { file=${outfile}$1 - do_ffmpeg $file -y -ab 128 -ac 2 -f s16le -i $pcm_src $3 $file + do_ffmpeg $file -y -ab 128k -ac 2 -f s16le -i $pcm_src $3 $file } do_audio_decoding() @@ -195,9 +219,9 @@ do_streamed_images() do_image_formats() { file=${outfile}libav%02d.$1 - $ffmpeg -t 0.5 -y -qscale 10 -f pgmyuv -i $raw_src $2 $3 $file + $ffmpeg -t 0.5 -y -qscale 10 -f pgmyuv -i $raw_src $2 $3 -flags +bitexact $file do_ffmpeg_crc $file $3 -i $file - + do_md5sum ${outfile}libav02.$1 >> $logfile } do_audio_only() @@ -213,35 +237,29 @@ echo "ffmpeg benchmarks" > $benchfile ################################### # generate reference for quality check do_ffmpeg_nocheck $raw_ref -y -f pgmyuv -i $raw_src -an -f rawvideo $raw_ref -do_ffmpeg_nocheck $pcm_ref -y -ab 128 -ac 2 -ar 44100 -f s16le -i $pcm_src -f wav $pcm_ref +do_ffmpeg_nocheck $pcm_ref -y -ab 128k -ac 2 -ar 44100 -f s16le -i $pcm_src -f wav $pcm_ref ################################### if [ -n "$do_mpeg" ] ; then -# mpeg1 encoding +# mpeg1 do_video_encoding mpeg1.mpg "-qscale 10" pgmyuv "-f mpeg1video" - -# mpeg1 decoding do_video_decoding fi ################################### if [ -n "$do_mpeg2" ] ; then -# mpeg2 encoding +# mpeg2 do_video_encoding mpeg2.mpg "-qscale 10" pgmyuv "-vcodec mpeg2video -f mpeg1video" - -# mpeg2 decoding do_video_decoding -# mpeg2 encoding using intra vlc -do_video_encoding mpeg2ivlc.mpg "-qscale 10" pgmyuv "-vcodec mpeg2video -f mpeg1video -flags2 +ivlc" +# mpeg2 encoding intra vlc qprd +do_video_encoding mpeg2ivlc-qprd.mpg "-vb 500k -bf 2 -flags +trell+qprd+mv0 -flags2 +ivlc -cmp 2 -subcmp 2 -mbd rd" pgmyuv "-vcodec mpeg2video -f mpeg2video" # mpeg2 decoding do_video_decoding -# mpeg2 encoding +# mpeg2 do_video_encoding mpeg2.mpg "-qscale 10" pgmyuv "-vcodec mpeg2video -idct int -dct int -f mpeg1video" - -# mpeg2 decoding do_video_decoding "-idct int" # mpeg2 encoding interlaced @@ -275,64 +293,50 @@ fi ################################### if [ -n "$do_msmpeg4v2" ] ; then -# msmpeg4 encoding +# msmpeg4 do_video_encoding msmpeg4v2.avi "-qscale 10" pgmyuv "-an -vcodec msmpeg4v2" - -# msmpeg4v2 decoding do_video_decoding fi ################################### if [ -n "$do_msmpeg4" ] ; then -# msmpeg4 encoding +# msmpeg4 do_video_encoding msmpeg4.avi "-qscale 10" pgmyuv "-an -vcodec msmpeg4" - -# msmpeg4 decoding do_video_decoding fi ################################### if [ -n "$do_wmv1" ] ; then -# wmv1 encoding +# wmv1 do_video_encoding wmv1.avi "-qscale 10" pgmyuv "-an -vcodec wmv1" - -# wmv1 decoding do_video_decoding fi ################################### if [ -n "$do_wmv2" ] ; then -# wmv2 encoding +# wmv2 do_video_encoding wmv2.avi "-qscale 10" pgmyuv "-an -vcodec wmv2" - -# wmv2 decoding do_video_decoding fi ################################### if [ -n "$do_h261" ] ; then -# h261 encoding +# h261 do_video_encoding h261.avi "-qscale 11" pgmyuv "-s 352x288 -an -vcodec h261" - -# h261 decoding do_video_decoding fi ################################### if [ -n "$do_h263" ] ; then -# h263 encoding +# h263 do_video_encoding h263.avi "-qscale 10" pgmyuv "-s 352x288 -an -vcodec h263" - -# h263 decoding do_video_decoding fi ################################### if [ -n "$do_h263p" ] ; then -# h263p encoding +# h263p do_video_encoding h263p.avi "-qscale 2 -flags +umv+aiv+aic" pgmyuv "-s 352x288 -an -vcodec h263p -ps 300" - -# h263p decoding do_video_decoding fi @@ -340,8 +344,6 @@ fi if [ -n "$do_mpeg4" ] ; then # mpeg4 do_video_encoding odivx.mp4 "-flags +mv4 -mbd bits -qscale 10" pgmyuv "-an -vcodec mpeg4" - -# mpeg4 decoding do_video_decoding fi @@ -349,8 +351,6 @@ fi if [ -n "$do_huffyuv" ] ; then # huffyuv do_video_encoding huffyuv.avi "" pgmyuv "-an -vcodec huffyuv -pix_fmt yuv422p" - -# huffyuv decoding do_video_decoding "" "-strict -2 -pix_fmt yuv420p" fi @@ -358,8 +358,6 @@ fi if [ -n "$do_rc" ] ; then # mpeg4 rate control do_video_encoding mpeg4-rc.avi "-b 400k -bf 2" pgmyuv "-an -vcodec mpeg4" - -# mpeg4 rate control decoding do_video_decoding fi @@ -367,53 +365,38 @@ fi if [ -n "$do_mpeg4adv" ] ; then # mpeg4 do_video_encoding mpeg4-adv.avi "-qscale 9 -flags +mv4+part+aic+trell -mbd bits -ps 200" pgmyuv "-an -vcodec mpeg4" - -# mpeg4 decoding do_video_decoding # mpeg4 do_video_encoding mpeg4-qprd.avi "-b 450k -bf 2 -flags +mv4+trell+qprd+mv0 -cmp 2 -subcmp 2 -mbd rd" pgmyuv "-an -vcodec mpeg4" - -# mpeg4 decoding do_video_decoding # mpeg4 do_video_encoding mpeg4-adap.avi "-b 550k -bf 2 -flags +mv4+trell+mv0 -cmp 1 -subcmp 2 -mbd rd -scplx_mask 0.3" pgmyuv "-an -vcodec mpeg4" - -# mpeg4 decoding do_video_decoding -fi -################################### -if [ -n "$do_mpeg4thread" ] ; then # mpeg4 -do_video_encoding mpeg4-thread.avi "-b 500k -flags +mv4+part+aic+trell -mbd bits -ps 200 -bf 2" pgmyuv "-an -vcodec mpeg4 -threads 2" - -# mpeg4 decoding +do_video_encoding mpeg4-Q.avi "-qscale 7 -flags +mv4+qpel -mbd 2 -bf 2 -cmp 1 -subcmp 2" pgmyuv "-an -vcodec mpeg4" do_video_decoding fi ################################### -if [ -n "$do_mpeg4adv" ] ; then +if [ -n "$do_mpeg4thread" ] ; then # mpeg4 -do_video_encoding mpeg4-Q.avi "-qscale 7 -flags +mv4+qpel -mbd 2 -bf 2 -cmp 1 -subcmp 2" pgmyuv "-an -vcodec mpeg4" - -# mpeg4 decoding +do_video_encoding mpeg4-thread.avi "-b 500k -flags +mv4+part+aic+trell -mbd bits -ps 200 -bf 2" pgmyuv "-an -vcodec mpeg4 -threads 2" do_video_decoding fi ################################### if [ -n "$do_mp4psp" ] ; then # mp4 PSP style -do_video_encoding mpeg4-PSP.mp4 "-b 768k -s 320x240" psp "-ar 24000 -ab 32 -i $raw_src" +do_video_encoding mpeg4-PSP.mp4 "-vb 768k -s 320x240" psp "-ar 24000 -ab 32k -i $raw_src" fi ################################### if [ -n "$do_error" ] ; then # damaged mpeg4 do_video_encoding error-mpeg4-adv.avi "-qscale 7 -flags +mv4+part+aic -mbd rd -ps 250 -error 10" pgmyuv "-an -vcodec mpeg4" - -# damaged mpeg4 decoding do_video_decoding fi @@ -421,8 +404,6 @@ fi if [ -n "$do_mpeg4nr" ] ; then # noise reduction do_video_encoding mpeg4-nr.avi "-qscale 8 -flags +mv4 -mbd rd -nr 200" pgmyuv "-an -vcodec mpeg4" - -# mpeg4 decoding do_video_decoding fi @@ -430,8 +411,6 @@ fi if [ -n "$do_mpeg1b" ] ; then # mpeg1 do_video_encoding mpeg1b.mpg "-qscale 8 -bf 3 -ps 200" pgmyuv "-an -vcodec mpeg1video -f mpeg1video" - -# mpeg1 decoding do_video_decoding fi @@ -439,8 +418,6 @@ fi if [ -n "$do_mjpeg" ] ; then # mjpeg do_video_encoding mjpeg.avi "-qscale 10" pgmyuv "-an -vcodec mjpeg -pix_fmt yuvj420p" - -# mjpeg decoding do_video_decoding "" "-pix_fmt yuv420p" fi @@ -448,8 +425,6 @@ fi if [ -n "$do_ljpeg" ] ; then # ljpeg do_video_encoding ljpeg.avi "" pgmyuv "-an -vcodec ljpeg -strict -1" - -# ljpeg decoding do_video_decoding fi @@ -457,8 +432,6 @@ fi if [ -n "$do_jpegls" ] ; then # jpeg ls do_video_encoding jpegls.avi "" pgmyuv "-an -vcodec jpegls -vtag MJPG" - -# jpeg ls decoding do_video_decoding "" "-pix_fmt yuv420p" fi @@ -466,8 +439,6 @@ fi if [ -n "$do_rv10" ] ; then # rv10 encoding do_video_encoding rv10.rm "-qscale 10" pgmyuv "-an" - -# rv10 decoding do_video_decoding fi @@ -475,8 +446,6 @@ fi if [ -n "$do_rv20" ] ; then # rv20 encoding do_video_encoding rv20.rm "-qscale 10" pgmyuv "-vcodec rv20 -an" - -# rv20 decoding do_video_decoding fi @@ -484,8 +453,6 @@ fi if [ -n "$do_asv1" ] ; then # asv1 encoding do_video_encoding asv1.avi "-qscale 10" pgmyuv "-an -vcodec asv1" - -# asv1 decoding do_video_decoding fi @@ -493,8 +460,6 @@ fi if [ -n "$do_asv2" ] ; then # asv2 encoding do_video_encoding asv2.avi "-qscale 10" pgmyuv "-an -vcodec asv2" - -# asv2 decoding do_video_decoding fi @@ -502,8 +467,6 @@ fi if [ -n "$do_flv" ] ; then # flv encoding do_video_encoding flv.flv "-qscale 10" pgmyuv "-an -vcodec flv" - -# flv decoding do_video_decoding fi @@ -511,126 +474,127 @@ fi if [ -n "$do_ffv1" ] ; then # ffv1 encoding do_video_encoding ffv1.avi "-strict -2" pgmyuv "-an -vcodec ffv1" - -# ffv1 decoding do_video_decoding fi ################################### if [ -n "$do_snow" ] ; then -# snow encoding +# snow do_video_encoding snow.avi "-strict -2" pgmyuv "-an -vcodec snow -qscale 2 -flags +qpel -me iter -dia_size 2 -cmp 12 -subcmp 12 -s 128x64" - -# snow decoding do_video_decoding "" "-s 352x288" fi ################################### if [ -n "$do_snowll" ] ; then -# snow encoding +# snow do_video_encoding snow53.avi "-strict -2" pgmyuv "-an -vcodec snow -qscale .001 -pred 1 -flags +mv4+qpel" - -# snow decoding do_video_decoding fi ################################### if [ -n "$do_dv" ] ; then -# dv encoding +# dv do_video_encoding dv.dv "-dct int" pgmyuv "-s pal -an" - -# dv decoding do_video_decoding "" "-s cif" fi ################################### if [ -n "$do_dv50" ] ; then -# dv50 encoding +# dv50 do_video_encoding dv.dv "-dct int" pgmyuv "-s pal -pix_fmt yuv422p -an" - -# dv50 decoding do_video_decoding "" "-s cif -pix_fmt yuv420p" fi ################################### if [ -n "$do_svq1" ] ; then -# svq1 encoding +# svq1 do_video_encoding svq1.mov "" pgmyuv "-an -vcodec svq1 -qscale 3 -pix_fmt yuv410p" +do_video_decoding "" "-pix_fmt yuv420p" +fi -# svq1 decoding +################################### +if [ -n "$do_flashsv" ] ; then +# svq1 +do_video_encoding flashsv.flv "" pgmyuv "-an -vcodec flashsv " do_video_decoding "" "-pix_fmt yuv420p" fi ################################### if [ -n "$do_mp2" ] ; then -# mp2 encoding +# mp2 do_audio_encoding mp2.mp2 "-ar 44100" - -# mp2 decoding do_audio_decoding $tiny_psnr $pcm_dst $pcm_ref 2 1924 >> $logfile fi ################################### if [ -n "$do_ac3" ] ; then -# ac3 encoding +# ac3 do_audio_encoding ac3.rm "" -vn - -# ac3 decoding #do_audio_decoding fi ################################### if [ -n "$do_g726" ] ; then -# g726 encoding -do_audio_encoding g726.wav "-ar 44100" "-ab 32 -ac 1 -ar 8000 -acodec g726" - -# g726 decoding +# g726 +do_audio_encoding g726.wav "-ar 44100" "-ab 32k -ac 1 -ar 8000 -acodec g726" do_audio_decoding fi ################################### if [ -n "$do_adpcm_ima_wav" ] ; then -# encoding +# adpcm ima do_audio_encoding adpcm_ima.wav "-ar 44100" "-acodec adpcm_ima_wav" - -# decoding do_audio_decoding fi ################################### if [ -n "$do_adpcm_ms" ] ; then -# encoding +# adpcm ms do_audio_encoding adpcm_ms.wav "-ar 44100" "-acodec adpcm_ms" - -# decoding do_audio_decoding fi ################################### if [ -n "$do_adpcm_yam" ] ; then -# encoding +# adpcm yamaha do_audio_encoding adpcm_yam.wav "-ar 44100" "-acodec adpcm_yamaha" - -# decoding do_audio_decoding fi ################################### if [ -n "$do_flac" ] ; then -# encoding +# flac do_audio_encoding flac.flac "-ar 44100" "-acodec flac -compression_level 2" - -# decoding do_audio_decoding fi ################################### -# libav testing +if [ -n "$do_wma" ] ; then +# wmav1 +do_audio_encoding wmav1.asf "-ar 44100" "-acodec wmav1" +do_ffmpeg_nomd5 $pcm_dst -y -i $file -f wav $pcm_dst +$tiny_psnr $pcm_dst $pcm_ref 2 8192 >> $logfile +# wmav2 +do_audio_encoding wmav2.asf "-ar 44100" "-acodec wmav2" +do_ffmpeg_nomd5 $pcm_dst -y -i $file -f wav $pcm_dst +$tiny_psnr $pcm_dst $pcm_ref 2 8192 >> $logfile +fi + +################################### +#if [ -n "$do_vorbis" ] ; then +# vorbis +#disabled because it is broken +#do_audio_encoding vorbis.asf "-ar 44100" "-acodec vorbis" +#do_audio_decoding +#fi + +################################### +# libavformat testing ################################### -if [ -n "$do_libav" ] ; then +if [ -n "$do_libavtest" ] ; then # avi do_libav avi @@ -650,8 +614,8 @@ do_libav mpg # mpegts do_libav ts -# swf (decode audio only) -do_libav swf "-acodec mp2" +# swf +do_libav swf -an # ffm do_libav ffm @@ -671,6 +635,13 @@ do_libav dv "-ar 48000 -r 25 -s pal -ac 2" # gxf do_libav gxf "-ar 48000 -r 25 -s pal -ac 1" +# nut +do_libav nut "-acodec mp2" + +# mkv +do_libav mkv + + #################### # streamed images # mjpeg @@ -699,13 +670,25 @@ do_ffmpeg $file -t 1 -y -qscale 10 -f pgmyuv -i $raw_src $file #################### # image formats -# pgm (we do not do md5 on image files yet) +# pgm do_image_formats pgm -# ppm (we do not do md5 on image files yet) +# ppm do_image_formats ppm -# jpeg (we do not do md5 on image files yet) +# bmp +do_image_formats bmp + +# tga +do_image_formats tga + +# tiff +do_image_formats tiff "-pix_fmt rgb24" + +# sgi +do_image_formats sgi + +# jpeg do_image_formats jpg "-flags +bitexact -dct fastint -idct simple -pix_fmt yuvj420p" "-f image2" #################### @@ -734,9 +717,9 @@ do_audio_only voc #################### # pix_fmt conversions -conversions="yuv420p yuv422p yuv444p yuv422 yuv410p yuv411p yuvj420p \ - yuvj422p yuvj444p rgb24 bgr24 rgba32 rgb565 rgb555 gray monow \ - monob pal8" +conversions="yuv420p yuv422p yuv444p yuyv422 yuv410p yuv411p yuvj420p \ + yuvj422p yuvj444p rgb24 bgr24 rgb32 rgb565 rgb555 gray monow \ + monob pal8 yuv440p yuvj440p" for pix_fmt in $conversions ; do file=${outfile}libav-${pix_fmt}.yuv do_ffmpeg_nocheck $file -r 1 -t 1 -y -f pgmyuv -i $raw_src \ @@ -745,7 +728,7 @@ for pix_fmt in $conversions ; do -f rawvideo -s 352x288 -pix_fmt yuv444p $file done -fi +fi # [ -n "$do_libavtest" ]