From be05fd52972fcacdc1f1e432bb46c25ecc4a64f7 Mon Sep 17 00:00:00 2001 From: Ross Thompson Date: Sun, 12 Mar 2023 23:15:44 -0500 Subject: [PATCH] Created script to batch processes all the embench branch outcomes into C model branch prediction rate. --- bin/CModelBranchAccuracy.sh | 49 +++++++++++++++++++------------------ bin/sim_bp | 1 + 2 files changed, 26 insertions(+), 24 deletions(-) mode change 100644 => 100755 bin/CModelBranchAccuracy.sh create mode 120000 bin/sim_bp diff --git a/bin/CModelBranchAccuracy.sh b/bin/CModelBranchAccuracy.sh old mode 100644 new mode 100755 index 259a1552f..1b94f7c9a --- a/bin/CModelBranchAccuracy.sh +++ b/bin/CModelBranchAccuracy.sh @@ -27,30 +27,31 @@ ################################################################################################ -irectory="$1" -Predictor="$2" -Size="$3" +Directory="$1" +Files="$1/*.log" - -File="$1" -BeginLineNumbers=`cat $File | grep -n "BEGIN" | awk -NF ':' '{print $1}'` -Name=`cat $File | grep -n "BEGIN" | awk -NF '/' '{print $6_$4}'` -EndLineNumbers=`cat $File | grep -n "END" | awk -NF ':' '{print $1}'` -echo $Name -echo $BeginLineNumbers -echo $EndLineNumbers - -NameArray=($Name) -BeginLineNumberArray=($BeginLineNumbers) -EndLineNumberArray=($EndLineNumbers) - -mkdir -p branch -Length=${#EndLineNumberArray[@]} -for i in $(seq 0 1 $((Length-1))) +for Pred in "bimodal" "gshare" do - CurrName=${NameArray[$i]} - CurrStart=$((${BeginLineNumberArray[$i]}+1)) - CurrEnd=$((${EndLineNumberArray[$i]}-1)) - echo $CurrName, $CurrStart, $CurrEnd - sed -n "${CurrStart},${CurrEnd}p" $File > branch/${CurrName}_branch.log + for Size in $(seq 6 2 16) + do + if [ $Pred = "gshare" ]; then + SizeString="$Size $Size 18 1" + elif [ $Pred = "bimodal" ]; then + SizeString="$Size 18 1" + fi + + Product=1.0 + Count=0 + for File in $Files + do + #echo "sim_bp $Pred $Size $Size 18 1 $File | tail -1 | awk '{print $4}'" + #echo "sim_bp $Pred $SizeString $File | tail -1 | awk '{print $4}'" + BMDR=`sim_bp $Pred $SizeString $File | tail -1 | awk '{print $4}'` + Product=`echo "$Product * $BMDR" | bc` + Count=$((Count+1)) + done + + GeoMean=`perl -E "say $Product**(1/$Count)"` + echo "$Pred$Size $GeoMean" + done done diff --git a/bin/sim_bp b/bin/sim_bp new file mode 120000 index 000000000..a85da9901 --- /dev/null +++ b/bin/sim_bp @@ -0,0 +1 @@ +../addins/branch-predictor-simulator/src/sim_bp \ No newline at end of file