123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- #!/bin/bash
- #
- # StarPU
- # Copyright (C) Université Bordeaux 1, CNRS 2008-2010 (see AUTHORS file)
- #
- # This program is free software; you can redistribute it and/or modify
- # it under the terms of the GNU Lesser General Public License as published by
- # the Free Software Foundation; either version 2.1 of the License, or (at
- # your option) any later version.
- #
- # This program is distributed in the hope that it will be useful, but
- # WITHOUT ANY WARRANTY; without even the implied warranty of
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- #
- # See the GNU Lesser General Public License in COPYING.LGPL for more details.
- #
- function compute_mean_and_stddev ()
- {
- filenamein=$1
- arch=$2
- filenameout=$3
- R --no-save > /dev/null << EOF
- table <- read.table("$filenamein")
- sizelist <- unique(table[,2])
- mins <- c()
- maxs <- c()
- means <- c()
- medians <- c()
- sds <- c()
- firstquarts <- c()
- thirdquarts <- c()
- for (size in sizelist)
- {
- sublist <- table[table[,2]==size,3]
- meanval <- mean(sublist)
- medianval <- median(sublist)
- sdval <- sd(sublist)
- firstquart <- quantile(sublist, 0.25)
- thirdquart <- quantile(sublist, 0.75)
- #minval <- min(sublist)
- minval <- quantile(sublist, 0.01)
- #maxval <- max(sublist)
- maxval <- quantile(sublist, 0.99)
- means <- c(means, meanval)
- medians <- c(medians, medianval)
- sds <- c(sds, sdval)
- firstquarts <- c(firstquarts, firstquart)
- thirdquarts <- c(thirdquarts, thirdquart)
- mins <- c(mins, minval)
- maxs <- c(maxs, maxval)
- }
- newtable <- data.frame(unique(sizelist), mins, firstquarts, medians, thirdquarts, maxs, means, sds);
- write.table(newtable, file="$filenameout");
- EOF
- }
- PERFMODELDISPLAY=./perfmodel_display
- function gnuplot_symbol()
- {
- symbol=$1
- echo "Display symbol $symbol"
- # TODO check return value $? of perfmodel_display to ensure we have valid data
- cuda_a=`$PERFMODELDISPLAY -s $symbol -a cuda -p a`
- cuda_b=`$PERFMODELDISPLAY -s $symbol -a cuda -p b`
- cuda_c=`$PERFMODELDISPLAY -s $symbol -a cuda -p c`
- cuda_alpha=`$PERFMODELDISPLAY -s $symbol -a cuda -p alpha`
- cuda_beta=`$PERFMODELDISPLAY -s $symbol -a cuda -p beta`
- cuda_debug=`$PERFMODELDISPLAY -s $symbol -p path-file-debug -a cuda`
- echo "CUDA : y = $cuda_a * size ^ $cuda_b + $cuda_c"
- echo "CUDA : y = $cuda_alpha * size ^ $cuda_beta"
- echo "CUDA : debug file $cuda_debug"
- cpu_a=`$PERFMODELDISPLAY -s $symbol -a cpu -p a`
- cpu_b=`$PERFMODELDISPLAY -s $symbol -a cpu -p b`
- cpu_c=`$PERFMODELDISPLAY -s $symbol -a cpu -p c`
- cpu_alpha=`$PERFMODELDISPLAY -s $symbol -a cpu -p alpha`
- cpu_beta=`$PERFMODELDISPLAY -s $symbol -a cpu -p beta`
- cpu_debug=`$PERFMODELDISPLAY -s $symbol -p path-file-debug -a cpu`
- echo "CPU : y = $cpu_a * size ^ $cpu_b + $cpu_c"
- echo "CPU : y = $cpu_alpha * size ^ $cpu_beta"
- echo "CPU : debug file $cpu_debug"
- # get the list of the different sizes of the tasks
- cuda_size_list=`cut -f2 $cuda_debug| sort -n |uniq|xargs`
- cpu_size_list=`cut -f2 $cpu_debug| sort -n |uniq|xargs`
- cpu_debug_data="model_$symbol.cpu.data"
- cuda_debug_data="model_$symbol.cuda.data"
- # In case we want stddev instead of a cloud of points ...
- compute_mean_and_stddev "$cpu_debug" "cpu" "$cpu_debug_data"
- compute_mean_and_stddev "$cuda_debug" "cuda" "$cuda_debug_data"
- # use ..
- # "$cpu_debug_data" usi 2:3:4 with errorbars title "cpu measured"
- gnuplot > /dev/null << EOF
- set term postscript eps enhanced color
- set output "model_$symbol.eps"
- set xlabel "Size (bytes)"
- set ylabel "Execution time (us)"
- set size 0.60
- set multiplot
- set style line 1 lt 1 lw 3 linecolor -1
- set style line 2 lt 2 lw 3 linecolor -1
- set logscale x
- set logscale y
- #set grid y
- #set grid x
- set format x "10^{%L}"
- set format y "10^{%L}"
- set key top left
- set key title "Non-linear regression\n(y = {/Symbol a} x@^{{/Symbol b}} + {/Symbol g})"
- set bars 4.0
- plot $cpu_a * ( x ** $cpu_b ) + $cpu_c ls 1 title "CPU" ,\
- $cuda_a * ( x ** $cuda_b ) + $cuda_c ls 2 title "GPU" ,\
- "$cpu_debug_data" usi 2:4:3:7:6 with candlesticks ls 1 notitle whiskerbars ,\
- "$cpu_debug_data" usi 2:5:5:5:5 with candlesticks ls 1 notitle ,\
- "$cuda_debug_data" usi 2:4:3:7:6 with candlesticks ls 2 notitle whiskerbars ,\
- "$cuda_debug_data" usi 2:5:5:5:5 with candlesticks ls 2 notitle
- set noborder
- set origin 0.42,0.10
- set nologscale xy
- set size .15,.25
- set tics scale 0
- set xrange [-0.1:0.1]
- set noxtics
- set noytics
- set format y2 "%g %%"
- set y2tics (1,25,50,75,99)
- set y2tics nomirror
- set title "Percentiles"
- set xlabel ""
- set ylabel ""
- set key
- plot "$cuda_debug_data" usi (0):(25):(1):(99):(75) with candlesticks ls 1 notitle whiskerbars ,\
- "$cuda_debug_data" usi (0):(50):(50):(50):(50) with candlesticks ls 1 notitle
- unset multiplot
- EOF
- }
- for symbol in $@
- do
- gnuplot_symbol $symbol
- done
|