| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 | #!/bin/bash# StarPU --- Runtime system for heterogeneous multicore architectures.# # Copyright (C) 2009, 2010  Université de Bordeaux 1# Copyright (C) 2010  Centre National de la Recherche Scientifique# # StarPU 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.# # StarPU 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=$1arch=$2filenameout=$3R --no-save > /dev/null << EOFtable <- 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_displayfunction gnuplot_symbol(){symbol=$1echo "Display symbol $symbol"# TODO check return value $? of perfmodel_display to ensure we have valid datacuda_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 taskscuda_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 << EOFset term postscript eps enhanced colorset output "model_$symbol.eps"set xlabel "Size (bytes)"set ylabel "Execution time (us)"set size 0.60set multiplotset style line 1 lt 1 lw 3 linecolor -1 set style line 2 lt 2 lw 3 linecolor -1set logscale xset logscale y#set grid y#set grid xset 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.0plot $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  notitleset noborderset origin 0.42,0.10set nologscale xyset size .15,.25set tics scale 0 set xrange [-0.1:0.1]set noxticsset noyticsset format y2 "%g %%"set y2tics (1,25,50,75,99)set y2tics nomirrorset title "Percentiles"set xlabel ""set ylabel ""set keyplot  "$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 notitleunset multiplotEOF}for symbol in $@do	gnuplot_symbol $symboldone
 |