From 02a62c18ac7ee27599835da4b3f37b3c5db40006 Mon Sep 17 00:00:00 2001 From: Sandra Date: Fri, 19 Feb 2021 11:09:49 +0100 Subject: [PATCH] saiph: add strong scaling experiment --- garlic/exp/saiph/strongScaling.nix | 71 ++++++++++++++++++++++++++++++ 1 file changed, 71 insertions(+) create mode 100644 garlic/exp/saiph/strongScaling.nix diff --git a/garlic/exp/saiph/strongScaling.nix b/garlic/exp/saiph/strongScaling.nix new file mode 100644 index 00000000..cc583171 --- /dev/null +++ b/garlic/exp/saiph/strongScaling.nix @@ -0,0 +1,71 @@ +{ + stdenv +, stdexp +, bsc +, targetMachine +, stages +}: + +with stdenv.lib; + +let + # Initial variable configuration + varConf = with bsc; { + nodes = [ 1 2 4 8 16 32 ]; + }; + + # Generate the complete configuration for each unit + genConf = with bsc; c: targetMachine.config // rec { + expName = "saiph.strongScaling"; + unitName = "${expName}.nodes-${toString nodes}-nb{y, z}=4"; + inherit (targetMachine.config) hw; + + # saiph options + nbx = 1; + nby = 4; + nbz = 4; + mpi = impi; + gitBranch = "garlic/tampi+isend+oss+task+simd"; + + # Repeat the execution of each unit 50 times + loops = 30; + + # Resources + cachelineBytes = hw.cachelineBytes; + time = "02:00:00"; + nodes = c.nodes; + qos = if (nodes>16) + then "bsc_cs" + else "debug"; + ntasksPerNode = hw.socketsPerNode; + cpusPerTask = hw.cpusPerSocket; + jobName = "${unitName}-${gitBranch}"; + }; + + # Compute the array of configurations + configs = stdexp.buildConfigs { + inherit varConf genConf; + }; + + exec = {nextStage, conf, ...}: with conf; stages.exec { + inherit nextStage; + env = '' + export NANOS6_REPORT_PREFIX="#" + export I_MPI_THREAD_SPLIT=1 + export ASAN_SYMBOLIZER_PATH=${bsc.clangOmpss2Unwrapped}/bin/llvm-symbolizer + ''; + }; + + program = {nextStage, conf, ...}: with conf; + let + customPkgs = stdexp.replaceMpi conf.mpi; + in + customPkgs.apps.saiph.override { + inherit nbx nby nbz mpi gitBranch cachelineBytes; + }; + + pipeline = stdexp.stdPipeline ++ [ exec program ]; + +in + + stdexp.genExperiment { inherit configs pipeline; }