speedup.sh 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. #!/bin/bash
  2. # StarPU --- Runtime system for heterogeneous multicore architectures.
  3. #
  4. # Copyright (C) 2008-2021 Université de Bordeaux, CNRS (LaBRI UMR 5800), Inria
  5. #
  6. # StarPU is free software; you can redistribute it and/or modify
  7. # it under the terms of the GNU Lesser General Public License as published by
  8. # the Free Software Foundation; either version 2.1 of the License, or (at
  9. # your option) any later version.
  10. #
  11. # StarPU is distributed in the hope that it will be useful, but
  12. # WITHOUT ANY WARRANTY; without even the implied warranty of
  13. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  14. #
  15. # See the GNU Lesser General Public License in COPYING.LGPL for more details.
  16. #
  17. DIR=$PWD
  18. ROOTDIR=$DIR/../..
  19. TIMINGDIR=$DIR/timings/
  20. mkdir -p $TIMINGDIR
  21. cd $ROOTDIR
  22. make clean 1> /dev/null 2> /dev/null
  23. make STARPU_ATLAS=1 CPUS=16 1> /dev/null 2> /dev/null
  24. echo "speedup ..."
  25. for theta in 32 64 128 256 512 1024
  26. do
  27. size=$(($theta * 32))
  28. echo "# ncpus time reftime" > $TIMINGDIR/speedup.$size
  29. for cpus in 1 2 4 6 8 10 12 14 16
  30. do
  31. export STARPU_NCPUS=$cpus
  32. echo "ncpus $cpus size $size"
  33. filename=$TIMINGDIR/timing.$cpus.$size
  34. $STARPU_LAUNCH $ROOTDIR/examples/heat -v2 -pin -nthick 34 -ntheta $(($theta+2)) -nblocks 16 2>/dev/null| tee $filename
  35. echo "$cpus `cat $TIMINGDIR/timing.$cpus.$size` `cat $TIMINGDIR/timing.1.$size`" >> $TIMINGDIR/speedup.$size
  36. done
  37. done