#!/bin/sh # File: # nightly_speed.sh # Decription: # Configure, build, and run AV1 encoder/decoder for each experimental tool. # Display the encoder/decode run time # Preassumption: # 1) Assume all script files are in ~/Dev/sandbox/libvpx/scripts # Note: # See encoder config output if set, # verbose=-v #set -x # LBD or HBD # Note: # Standard bit depth: # 1) profile=0 # 2) bitdepth= # High bit depth: # 1) profile=2 # 2) bitdepth="--bit-depth=10/12" if [ "$#" -ne 4 ]; then root_dir=~/Dev/av1d profile=0 pdfps=1 html_log_file=log.html else root_dir=$1 profile=$2 pdfps=$3 html_log_file=$4 fi log_path=~/Dev/log if [ "$profile" == "2" ]; then bitdepth="--bit-depth=10" fi if [ "$profile" == "0" ]; then bitdepth= fi code_dir=$root_dir/aom build_dir=$root_dir/release test_dir=~/Dev/nightly script_dir=~/Dev/sandbox/libvpx/scripts . $script_dir/video_sequence.sh # General options codec="--codec=av1" verbose= core_id=1 exp_tool=experimental cd $root_dir/aom commit=`git log --pretty=%h -1` cd $test_dir elog=av1enc_log_p_$profile.txt dlog=av1dec_log_p_$profile.txt bstream=av1_p_$profile.$commit.webm if [ $exp_tool == intrabc ] || [ $exp_tool == palette ] || [ $exp_tool == palette_delta_encoding ] || [ $exp_tool == palette_throughput ]; then tune_content="--tune-content=screen" else tune_content= fi if [ $exp_tool == ext_tile ]; then col_num=1 else col_num=0 fi laginframes=19 taskset -c $core_id ./aomenc $verbose -o /dev/shm/"$bstream" $video $codec --limit=$frames --profile=$profile $bitdepth --fps=$fps $tune_content --target-bitrate=$bitrate --skip=0 -p 2 --good --cpu-used=0 --lag-in-frames=$laginframes --min-q=0 --max-q=63 --auto-alt-ref=1 --kf-max-dist=150 --kf-min-dist=0 --drop-frame=0 --static-thresh=0 --bias-pct=50 --minsection-pct=0 --maxsection-pct=2000 --arnr-maxframes=7 --arnr-strength=5 --sharpness=0 --undershoot-pct=100 --overshoot-pct=100 --frame-parallel=0 --tile-columns=$col_num --psnr &>> $elog # Note: $2 is the time unit, ms or us etime=`cat $elog | awk 'NR==2 {NF-=3; print $NF}'` # efps=`cat $elog | grep 'Pass 2/2' | grep 'fps)' | sed -e 's/^.*b\/s//' | awk '{print $3}'` # efps=`echo $efps | sed 's/(//'` psnr=`cat $elog | grep 'PSNR' | awk '{print $5, $6, $7, $8, $9}'` tmp=`cat $elog | grep mismatch` if [ "$?" -ne 0 ]; then eflag=e_ok else eflag=mismatch fi echo "AV1: $(basename $video), bitrate=$bitrate profile=$profile frames=$frames" taskset -c $core_id ./aomdec /dev/shm/"$bstream" $codec --i420 --noblit --summary 2>&1 &>> $dlog if [ "$?" -ne 0 ]; then dflag=fault else dflag=d_ok fi # Note: $8 is the time unit ms or us dfps=`awk '{print $9}' < $dlog` dfps=`echo $dfps | sed 's/(//'` percent=`echo "($dfps - $pdfps) / $pdfps * 100" | bc -l` percent=${percent:0:5} echo -e '\t'"Enc fps Dec fps PSNR"'\t\t\t\t\t\t\t'"Enc status Dec status Speedup(%)" echo -e '\t'$etime" "$dfps" "$psnr'\t'$eflag" "$dflag" "$percent printf "\n" # Output a html log file for email echo "
AV1: $(basename $video), bitrate=$bitrate profile=$profile frames=$frames
" >> $log_path/$html_log_file echo "Enc Time | " >> $log_path/$html_log_file echo "Dec fps | " >> $log_path/$html_log_file echo "Dec Speedup(%) | " >> $log_path/$html_log_file echo "Enc Status | " >> $log_path/$html_log_file echo "Dec Status | " >> $log_path/$html_log_file echo "PSNR | " >> $log_path/$html_log_file echo "
---|---|---|---|---|---|
$etime | " >> $log_path/$html_log_file echo "$dfps | " >> $log_path/$html_log_file echo "$percent | " >> $log_path/$html_log_file echo "$eflag | " >> $log_path/$html_log_file echo "$dflag | " >> $log_path/$html_log_file echo "$psnr | " >> $log_path/$html_log_file echo "