rd_collect_theora.sh 1.4 KB

12345678910111213141516171819202122232425262728293031323334
  1. #!/bin/bash
  2. set -e
  3. if [ -z $RD_COLLECT_SUB ]; then
  4. echo "Please use: $(dirname $0)/rd_collect.sh <theora> *.y4m"
  5. exit 1
  6. fi
  7. FILE=$1
  8. BASENAME=$(basename $FILE)-$CODEC
  9. rm $BASENAME.out 2> /dev/null || true
  10. echo $BASENAME
  11. WIDTH=$(head -1 $FILE | cut -d\ -f 2 | tr -d 'W')
  12. HEIGHT=$(head -1 $FILE | cut -d\ -f 3 | tr -d 'H')
  13. for x in $(seq 63 -1 0); do
  14. V=$(echo $x | awk '{print $1*0.15873015873015}');
  15. $ENCODER_EXAMPLE -o $BASENAME.ogv -v $V -z 0 $FILE 2> $BASENAME-$x-enc.err >/dev/null
  16. $DUMP_VIDEO $BASENAME.ogv -c -o $BASENAME.y4m 2>/dev/null
  17. SIZE=$(wc -c $BASENAME.ogv | awk '{ print $1 }')
  18. $DUMP_PSNR $FILE $BASENAME.y4m > $BASENAME-$x-psnr.out 2> /dev/null
  19. FRAMES=$(cat $BASENAME-$x-psnr.out | grep ^0 | wc -l)
  20. PIXELS=$(($WIDTH*$HEIGHT*$FRAMES))
  21. PSNR=$(cat $BASENAME-$x-psnr.out | grep Total | tr -s ' ' | cut -d\ -f $((4+$PLANE*2)))
  22. PSNRHVS=$($DUMP_PSNRHVS $FILE $BASENAME.y4m 2> /dev/null | grep Total | tr -s ' ' | cut -d\ -f $((4+$PLANE*2)))
  23. SSIM=$($DUMP_SSIM $FILE $BASENAME.y4m 2> /dev/null | grep Total | tr -s ' ' | cut -d\ -f $((4+$PLANE*2)))
  24. FASTSSIM=$($DUMP_FASTSSIM -c $FILE $BASENAME.y4m 2> /dev/null | grep Total | tr -s ' ' | cut -d\ -f $((4+$PLANE*2)))
  25. rm $BASENAME.ogv $BASENAME.y4m $BASENAME-$x-enc.err $BASENAME-$x-psnr.out
  26. echo -$x $PIXELS $SIZE $PSNR $PSNRHVS $SSIM $FASTSSIM >> $BASENAME.out
  27. #tail -1 $BASENAME.out
  28. done