From a90c044c3e2096fb8e638683a54d71eca226b2b7 Mon Sep 17 00:00:00 2001 From: Sandra Date: Thu, 25 Feb 2021 18:00:13 +0100 Subject: [PATCH] saiph: add manual global blocking Ensure cuts in a single dimension --- garlic/exp/saiph/scaling.nix | 31 +++++++++++++++++++------------ 1 file changed, 19 insertions(+), 12 deletions(-) diff --git a/garlic/exp/saiph/scaling.nix b/garlic/exp/saiph/scaling.nix index 3ea0c3b..f69df8f 100644 --- a/garlic/exp/saiph/scaling.nix +++ b/garlic/exp/saiph/scaling.nix @@ -11,28 +11,33 @@ with stdenv.lib; let # Initial variable configuration varConf = with bsc; { - nb = [ 1 2 4 8 16 32 64 ]; - nodes = [ 1 2 4 ]; - gitCommit = [ - "3ecae7c209ec3e33d1108ae4783d7e733d54f2ca" - ]; + nbl = [ 1 2 4 8 16 32 64 ]; + nodes = [ 1 2 4 8 ]; + #gitCommit = [ "3ecae7c209ec3e33d1108ae4783d7e733d54f2ca" "3b52a616d44f4b86880663e2d951ad89c1dcab4f" ]; }; # Generate the complete configuration for each unit genConf = with bsc; c: targetMachine.config // rec { expName = "saiph"; - unitName = "${expName}-N${toString nodes}" + - "-nbx${toString nbx}-nby${toString nby}"; + unitName = "${expName}-N${toString nodes}" + "-nblx${toString nblx}-nbly${toString nbly}" + "-par-init-One-dimensionalDistribution"; +# unitName = if (gitCommit == "3b52a616d44f4b86880663e2d951ad89c1dcab4f") +# then "${expName}-N${toString nodes}" + "-nblx${toString nblx}-nbly${toString nbly}" + "-par-init" +# else "${expName}-N${toString nodes}" + "-nblx${toString nblx}-nbly${toString nbly}" + "-seq-init"; inherit (targetMachine.config) hw; # saiph options - nbx = 1; - nby = c.nb; - nbz = c.nb; + manualDist = 1; + nbgx = 1; + nbgy = 1; + nbgz = nodes; + nblx = 1; + nbly = c.nbl; + nblz = c.nbl; mpi = impi; gitBranch = "garlic/tampi+isend+oss+task+simd"; - inherit (c) gitCommit; + #gitCommit = c.gitCommit; # if exp involves more than 1 commit + #inherit (c) gitCommit; # if exp fixes the commit # Repeat the execution of each unit 50 times loops = 10; @@ -49,6 +54,8 @@ let configs = stdexp.buildConfigs { inherit varConf genConf; }; + #configs = filter (el: if el.nbly == 1 && el.nblz == 1 && el.nodes == 1 && el.gitCommit == "3b52a616d44f4b86880663e2d951ad89c1dcab4f" then false else true) configsAll; + exec = {nextStage, conf, ...}: with conf; stages.exec { inherit nextStage; @@ -63,7 +70,7 @@ let customPkgs = stdexp.replaceMpi conf.mpi; in customPkgs.apps.saiph.override { - inherit (conf) nbx nby nbz mpi gitBranch gitCommit; + inherit (conf) manualDist nbgx nbgy nbgz nblx nbly nblz mpi gitBranch; }; pipeline = stdexp.stdPipeline ++ [ exec program ];