3 # automatic regression test for ffmpeg
7 # Even in the 21st century some diffs do not support -u.
8 diff -u "$0" "$0" > /dev/null 2>&1
15 diff -w "$0" "$0" > /dev/null 2>&1
17 diff_cmd="$diff_cmd -w"
24 logfile="$datadir/ffmpeg.regression"
28 if [ "$1" = "mpeg4" ] ; then
30 elif [ "$1" = "mpeg" ] ; then
33 elif [ "$1" = "ac3" ] ; then
35 elif [ "$1" = "huffyuv" ] ; then
37 elif [ "$1" = "mpeg2thread" ] ; then
39 elif [ "$1" = "snow" ] ; then
41 elif [ "$1" = "snowll" ] ; then
43 elif [ "$1" = "libavtest" ] ; then
45 logfile="$datadir/libav.regression"
95 tiny_psnr="./tiny_psnr"
97 benchfile="$datadir/ffmpeg.bench"
98 bench="$datadir/bench.tmp"
99 bench2="$datadir/bench2.tmp"
100 raw_src="$3/%02d.pgm"
101 raw_dst="$datadir/out.yuv"
102 raw_ref="$datadir/ref.yuv"
104 pcm_dst="$datadir/out.wav"
105 pcm_ref="$datadir/ref.wav"
106 if [ X"`echo | md5sum 2> /dev/null`" != X ]; then
107 do_md5sum() { md5sum -b $1; }
108 elif [ -x /sbin/md5 ]; then
109 do_md5sum() { /sbin/md5 -r $1 | sed 's# \**\./# *./#'; }
111 do_md5sum() { echo No md5sum program found; }
114 # create the data directory if it does not exist
117 FFMPEG_OPTS="-y -flags +bitexact -dct fastint -idct simple -ab 64k"
123 echo $ffmpeg $FFMPEG_OPTS $*
124 $ffmpeg $FFMPEG_OPTS -benchmark $* > $bench 2> /tmp/ffmpeg$$
125 egrep -v "^(Stream|Press|Input|Output|frame| Stream| Duration|video:)" /tmp/ffmpeg$$ || true
127 do_md5sum $f >> $logfile
128 if [ $f = $raw_dst ] ; then
129 $tiny_psnr $f $raw_ref >> $logfile
130 elif [ $f = $pcm_dst ] ; then
131 $tiny_psnr $f $pcm_ref 2 >> $logfile
135 expr "`cat $bench`" : '.*utime=\(.*s\)' > $bench2
136 echo `cat $bench2` $f >> $benchfile
143 echo $ffmpeg $FFMPEG_OPTS $*
144 $ffmpeg $FFMPEG_OPTS -benchmark $* > $bench 2> /tmp/ffmpeg$$
145 egrep -v "^(Stream|Press|Input|Output|frame| Stream| Duration|video:)" /tmp/ffmpeg$$ || true
147 if [ $f = $raw_dst ] ; then
148 $tiny_psnr $f $raw_ref >> $logfile
149 elif [ $f = $pcm_dst ] ; then
150 $tiny_psnr $f $pcm_ref 2 >> $logfile
154 expr "`cat $bench`" : '.*utime=\(.*s\)' > $bench2
155 echo `cat $bench2` $f >> $benchfile
162 echo $ffmpeg $FFMPEG_OPTS $* -f crc $datadir/ffmpeg.crc
163 $ffmpeg $FFMPEG_OPTS $* -f crc $datadir/ffmpeg.crc > /tmp/ffmpeg$$ 2>&1
164 egrep -v "^(Stream|Press|Input|Output|frame| Stream| Duration|video:|ffmpeg version| configuration| built)" /tmp/ffmpeg$$ || true
166 echo "$f `cat $datadir/ffmpeg.crc`" >> $logfile
173 echo $ffmpeg $FFMPEG_OPTS $*
174 $ffmpeg $FFMPEG_OPTS -benchmark $* > $bench 2> /tmp/ffmpeg$$
175 egrep -v "^(Stream|Press|Input|Output|frame| Stream| Duration|video:)" /tmp/ffmpeg$$ || true
177 expr "`cat $bench`" : '.*utime=\(.*s\)' > $bench2
178 echo `cat $bench2` $f >> $benchfile
183 do_ffmpeg $raw_dst -y $1 -i $file -f rawvideo $2 $raw_dst
189 do_ffmpeg $file -y $2 -f $3 -i $raw_src $4 $file
195 do_ffmpeg $file -y -ab 128k -ac 2 -f s16le -i $pcm_src $3 $file
200 do_ffmpeg $pcm_dst -y -i $file -f wav $pcm_dst
205 file=${outfile}libav.$1
206 do_ffmpeg $file -t 1 -y -qscale 10 -f pgmyuv -i $raw_src -f s16le -i $pcm_src $2 $file
207 do_ffmpeg_crc $file -i $file $3
213 file=${outfile}libav.$1
214 do_ffmpeg $file -t 1 -y -qscale 10 -f pgmyuv -i $raw_src -f image2pipe $file
215 do_ffmpeg_crc $file -f image2pipe -i $file
220 file=${outfile}libav%02d.$1
221 $ffmpeg -t 0.5 -y -qscale 10 -f pgmyuv -i $raw_src $2 $3 $file
222 do_ffmpeg_crc $file $3 -i $file
228 file=${outfile}libav.$1
229 do_ffmpeg $file -t 1 -y -qscale 10 -f s16le -i $pcm_src $file
230 do_ffmpeg_crc $file -i $file
233 echo "ffmpeg regression test" > $logfile
234 echo "ffmpeg benchmarks" > $benchfile
236 ###################################
237 # generate reference for quality check
238 do_ffmpeg_nocheck $raw_ref -y -f pgmyuv -i $raw_src -an -f rawvideo $raw_ref
239 do_ffmpeg_nocheck $pcm_ref -y -ab 128k -ac 2 -ar 44100 -f s16le -i $pcm_src -f wav $pcm_ref
241 ###################################
242 if [ -n "$do_mpeg" ] ; then
244 do_video_encoding mpeg1.mpg "-qscale 10" pgmyuv "-f mpeg1video"
248 ###################################
249 if [ -n "$do_mpeg2" ] ; then
251 do_video_encoding mpeg2.mpg "-qscale 10" pgmyuv "-vcodec mpeg2video -f mpeg1video"
254 # mpeg2 encoding intra vlc qprd
255 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"
261 do_video_encoding mpeg2.mpg "-qscale 10" pgmyuv "-vcodec mpeg2video -idct int -dct int -f mpeg1video"
262 do_video_decoding "-idct int"
264 # mpeg2 encoding interlaced
265 do_video_encoding mpeg2i.mpg "-qscale 10" pgmyuv "-vcodec mpeg2video -f mpeg1video -flags +ildct+ilme"
271 ###################################
272 if [ -n "$do_mpeg2thread" ] ; then
273 # mpeg2 encoding interlaced
274 do_video_encoding mpeg2thread.mpg "-qscale 10" pgmyuv "-vcodec mpeg2video -f mpeg1video -bf 2 -flags +ildct+ilme -threads 2"
279 # mpeg2 encoding interlaced using intra vlc
280 do_video_encoding mpeg2threadivlc.mpg "-qscale 10" pgmyuv "-vcodec mpeg2video -f mpeg1video -bf 2 -flags +ildct+ilme -flags2 +ivlc -threads 2"
285 # mpeg2 encoding interlaced
286 file=${outfile}mpeg2reuse.mpg
287 do_ffmpeg $file -y -sameq -me_threshold 256 -mb_threshold 1024 -i ${outfile}mpeg2thread.mpg -vcodec mpeg2video -f mpeg1video -bf 2 -flags +ildct+ilme -threads 4 $file
293 ###################################
294 if [ -n "$do_msmpeg4v2" ] ; then
296 do_video_encoding msmpeg4v2.avi "-qscale 10" pgmyuv "-an -vcodec msmpeg4v2"
300 ###################################
301 if [ -n "$do_msmpeg4" ] ; then
303 do_video_encoding msmpeg4.avi "-qscale 10" pgmyuv "-an -vcodec msmpeg4"
307 ###################################
308 if [ -n "$do_wmv1" ] ; then
310 do_video_encoding wmv1.avi "-qscale 10" pgmyuv "-an -vcodec wmv1"
314 ###################################
315 if [ -n "$do_wmv2" ] ; then
317 do_video_encoding wmv2.avi "-qscale 10" pgmyuv "-an -vcodec wmv2"
321 ###################################
322 if [ -n "$do_h261" ] ; then
324 do_video_encoding h261.avi "-qscale 11" pgmyuv "-s 352x288 -an -vcodec h261"
328 ###################################
329 if [ -n "$do_h263" ] ; then
331 do_video_encoding h263.avi "-qscale 10" pgmyuv "-s 352x288 -an -vcodec h263"
335 ###################################
336 if [ -n "$do_h263p" ] ; then
338 do_video_encoding h263p.avi "-qscale 2 -flags +umv+aiv+aic" pgmyuv "-s 352x288 -an -vcodec h263p -ps 300"
342 ###################################
343 if [ -n "$do_mpeg4" ] ; then
345 do_video_encoding odivx.mp4 "-flags +mv4 -mbd bits -qscale 10" pgmyuv "-an -vcodec mpeg4"
349 ###################################
350 if [ -n "$do_huffyuv" ] ; then
352 do_video_encoding huffyuv.avi "" pgmyuv "-an -vcodec huffyuv -pix_fmt yuv422p"
353 do_video_decoding "" "-strict -2 -pix_fmt yuv420p"
356 ###################################
357 if [ -n "$do_rc" ] ; then
359 do_video_encoding mpeg4-rc.avi "-b 400k -bf 2" pgmyuv "-an -vcodec mpeg4"
363 ###################################
364 if [ -n "$do_mpeg4adv" ] ; then
366 do_video_encoding mpeg4-adv.avi "-qscale 9 -flags +mv4+part+aic+trell -mbd bits -ps 200" pgmyuv "-an -vcodec mpeg4"
370 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"
374 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"
378 do_video_encoding mpeg4-Q.avi "-qscale 7 -flags +mv4+qpel -mbd 2 -bf 2 -cmp 1 -subcmp 2" pgmyuv "-an -vcodec mpeg4"
382 ###################################
383 if [ -n "$do_mpeg4thread" ] ; then
385 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"
389 ###################################
390 if [ -n "$do_mp4psp" ] ; then
392 do_video_encoding mpeg4-PSP.mp4 "-vb 768k -s 320x240" psp "-ar 24000 -ab 32k -i $raw_src"
395 ###################################
396 if [ -n "$do_error" ] ; then
398 do_video_encoding error-mpeg4-adv.avi "-qscale 7 -flags +mv4+part+aic -mbd rd -ps 250 -error 10" pgmyuv "-an -vcodec mpeg4"
402 ###################################
403 if [ -n "$do_mpeg4nr" ] ; then
405 do_video_encoding mpeg4-nr.avi "-qscale 8 -flags +mv4 -mbd rd -nr 200" pgmyuv "-an -vcodec mpeg4"
409 ###################################
410 if [ -n "$do_mpeg1b" ] ; then
412 do_video_encoding mpeg1b.mpg "-qscale 8 -bf 3 -ps 200" pgmyuv "-an -vcodec mpeg1video -f mpeg1video"
416 ###################################
417 if [ -n "$do_mjpeg" ] ; then
419 do_video_encoding mjpeg.avi "-qscale 10" pgmyuv "-an -vcodec mjpeg -pix_fmt yuvj420p"
420 do_video_decoding "" "-pix_fmt yuv420p"
423 ###################################
424 if [ -n "$do_ljpeg" ] ; then
426 do_video_encoding ljpeg.avi "" pgmyuv "-an -vcodec ljpeg -strict -1"
430 ###################################
431 if [ -n "$do_jpegls" ] ; then
433 do_video_encoding jpegls.avi "" pgmyuv "-an -vcodec jpegls -vtag MJPG"
434 do_video_decoding "" "-pix_fmt yuv420p"
437 ###################################
438 if [ -n "$do_rv10" ] ; then
440 do_video_encoding rv10.rm "-qscale 10" pgmyuv "-an"
444 ###################################
445 if [ -n "$do_rv20" ] ; then
447 do_video_encoding rv20.rm "-qscale 10" pgmyuv "-vcodec rv20 -an"
451 ###################################
452 if [ -n "$do_asv1" ] ; then
454 do_video_encoding asv1.avi "-qscale 10" pgmyuv "-an -vcodec asv1"
458 ###################################
459 if [ -n "$do_asv2" ] ; then
461 do_video_encoding asv2.avi "-qscale 10" pgmyuv "-an -vcodec asv2"
465 ###################################
466 if [ -n "$do_flv" ] ; then
468 do_video_encoding flv.flv "-qscale 10" pgmyuv "-an -vcodec flv"
472 ###################################
473 if [ -n "$do_ffv1" ] ; then
475 do_video_encoding ffv1.avi "-strict -2" pgmyuv "-an -vcodec ffv1"
479 ###################################
480 if [ -n "$do_snow" ] ; then
482 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"
483 do_video_decoding "" "-s 352x288"
486 ###################################
487 if [ -n "$do_snowll" ] ; then
489 do_video_encoding snow53.avi "-strict -2" pgmyuv "-an -vcodec snow -qscale .001 -pred 1 -flags +mv4+qpel"
493 ###################################
494 if [ -n "$do_dv" ] ; then
496 do_video_encoding dv.dv "-dct int" pgmyuv "-s pal -an"
497 do_video_decoding "" "-s cif"
500 ###################################
501 if [ -n "$do_dv50" ] ; then
503 do_video_encoding dv.dv "-dct int" pgmyuv "-s pal -pix_fmt yuv422p -an"
504 do_video_decoding "" "-s cif -pix_fmt yuv420p"
508 ###################################
509 if [ -n "$do_svq1" ] ; then
511 do_video_encoding svq1.mov "" pgmyuv "-an -vcodec svq1 -qscale 3 -pix_fmt yuv410p"
512 do_video_decoding "" "-pix_fmt yuv420p"
515 ###################################
516 if [ -n "$do_mp2" ] ; then
518 do_audio_encoding mp2.mp2 "-ar 44100"
520 $tiny_psnr $pcm_dst $pcm_ref 2 1924 >> $logfile
523 ###################################
524 if [ -n "$do_ac3" ] ; then
526 do_audio_encoding ac3.rm "" -vn
530 ###################################
531 if [ -n "$do_g726" ] ; then
533 do_audio_encoding g726.wav "-ar 44100" "-ab 32k -ac 1 -ar 8000 -acodec g726"
537 ###################################
538 if [ -n "$do_adpcm_ima_wav" ] ; then
540 do_audio_encoding adpcm_ima.wav "-ar 44100" "-acodec adpcm_ima_wav"
544 ###################################
545 if [ -n "$do_adpcm_ms" ] ; then
547 do_audio_encoding adpcm_ms.wav "-ar 44100" "-acodec adpcm_ms"
551 ###################################
552 if [ -n "$do_adpcm_yam" ] ; then
554 do_audio_encoding adpcm_yam.wav "-ar 44100" "-acodec adpcm_yamaha"
558 ###################################
559 if [ -n "$do_flac" ] ; then
561 do_audio_encoding flac.flac "-ar 44100" "-acodec flac -compression_level 2"
565 ###################################
566 if [ -n "$do_wma" ] ; then
568 do_audio_encoding wmav1.asf "-ar 44100" "-acodec wmav1"
569 do_ffmpeg_nomd5 $pcm_dst -y -i $file -f wav $pcm_dst
570 $tiny_psnr $pcm_dst $pcm_ref 2 8192 >> $logfile
572 do_audio_encoding wmav2.asf "-ar 44100" "-acodec wmav2"
573 do_ffmpeg_nomd5 $pcm_dst -y -i $file -f wav $pcm_dst
574 $tiny_psnr $pcm_dst $pcm_ref 2 8192 >> $logfile
577 ###################################
578 #if [ -n "$do_vorbis" ] ; then
580 #disabled because its broken
581 #do_audio_encoding vorbis.asf "-ar 44100" "-acodec vorbis"
585 ###################################
586 # libavformat testing
587 ###################################
589 if [ -n "$do_libavtest" ] ; then
595 do_libav asf "-acodec mp2" "-r 25"
598 file=${outfile}libav.rm
599 do_ffmpeg $file -t 1 -y -qscale 10 -f pgmyuv -i $raw_src -f s16le -i $pcm_src $file
601 #do_ffmpeg_crc $file -i $file
619 do_libav mov "-acodec pcm_alaw"
622 #do_libav nut "-acodec mp2"
625 do_libav dv "-ar 48000 -r 25 -s pal -ac 2"
628 do_libav gxf "-ar 48000 -r 25 -s pal -ac 1"
633 #file=${outfile}libav.mjpeg
634 #do_ffmpeg $file -t 1 -y -qscale 10 -f pgmyuv -i $raw_src $file
635 #do_ffmpeg_crc $file -i $file
638 do_streamed_images pbm
641 do_streamed_images pgm
644 do_streamed_images ppm
647 file=${outfile}libav.gif
648 do_ffmpeg $file -t 1 -y -qscale 10 -f pgmyuv -i $raw_src -pix_fmt rgb24 $file
649 #do_ffmpeg_crc $file -i $file
652 file=${outfile}libav.y4m
653 do_ffmpeg $file -t 1 -y -qscale 10 -f pgmyuv -i $raw_src $file
654 #do_ffmpeg_crc $file -i $file
658 # pgm (we do not do md5 on image files yet)
661 # ppm (we do not do md5 on image files yet)
664 # jpeg (we do not do md5 on image files yet)
665 do_image_formats jpg "-flags +bitexact -dct fastint -idct simple -pix_fmt yuvj420p" "-f image2"
692 # pix_fmt conversions
693 conversions="yuv420p yuv422p yuv444p yuyv422 yuv410p yuv411p yuvj420p \
694 yuvj422p yuvj444p rgb24 bgr24 rgb32 rgb565 rgb555 gray monow \
696 for pix_fmt in $conversions ; do
697 file=${outfile}libav-${pix_fmt}.yuv
698 do_ffmpeg_nocheck $file -r 1 -t 1 -y -f pgmyuv -i $raw_src \
699 -f rawvideo -s 352x288 -pix_fmt $pix_fmt $raw_dst
700 do_ffmpeg $file -f rawvideo -s 352x288 -pix_fmt $pix_fmt -i $raw_dst \
701 -f rawvideo -s 352x288 -pix_fmt yuv444p $file
704 fi # [ -n "$do_libavtest" ]
708 if $diff_cmd "$logfile" "$reffile" ; then
710 echo Regression test succeeded.
714 echo Regression test: Error.