creams: merge similar experiments together
Large experiments have the enableExtended parameter disabled by default, which enables more tests.
This commit is contained in:
		
							parent
							
								
									ec056d97e5
								
							
						
					
					
						commit
						87f751185c
					
				| @ -1,114 +0,0 @@ | |||||||
| { |  | ||||||
|   stdenv |  | ||||||
| , stdexp |  | ||||||
| , bsc |  | ||||||
| , targetMachine |  | ||||||
| , stages |  | ||||||
| }: |  | ||||||
| 
 |  | ||||||
| with stdenv.lib; |  | ||||||
| 
 |  | ||||||
| let |  | ||||||
|   # Initial variable configuration |  | ||||||
|   varConf = { |  | ||||||
|     input = [ |  | ||||||
|       { nodes=1 ; nprocz=2 ; granul=256; time= "02:00:00"; } |  | ||||||
|       { nodes=1 ; nprocz=2 ; granul=128; time= "02:00:00"; } |  | ||||||
|       { nodes=1 ; nprocz=2 ; granul=64;  time= "02:00:00"; } |  | ||||||
|       { nodes=1 ; nprocz=2 ; granul=32;  time= "02:00:00"; } |  | ||||||
|       { nodes=1 ; nprocz=2 ; granul=16;  time= "02:00:00"; } |  | ||||||
|       { nodes=1 ; nprocz=2 ; granul= 9;  time= "02:00:00"; } |  | ||||||
|       { nodes=1 ; nprocz=2 ; granul= 5;  time= "02:00:00"; } |  | ||||||
|       { nodes=1 ; nprocz=2 ; granul= 4;  time= "02:00:00"; } |  | ||||||
|     ]; |  | ||||||
| 
 |  | ||||||
|     gitBranch = [ |  | ||||||
|       "garlic/mpi+send+omp+task" |  | ||||||
|       "garlic/mpi+send+oss+task" |  | ||||||
|       "garlic/mpi+isend+omp+task" |  | ||||||
|       "garlic/mpi+isend+oss+task" |  | ||||||
|       "garlic/tampi+isend+oss+task" |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Generate the complete configuration for each unit |  | ||||||
|   genConf = with bsc; c: targetMachine.config // rec { |  | ||||||
|     expName = "creams-gran-node1"; |  | ||||||
|     inherit (targetMachine.config) hw; |  | ||||||
|     # Options for creams |  | ||||||
|     cc = icc; |  | ||||||
|     mpi = impi; |  | ||||||
|     inherit (c.input) granul time nodes; |  | ||||||
|     inherit (c) gitBranch; |  | ||||||
|     unitName = "${expName}-${toString nodes}-${gitBranch}"; |  | ||||||
| 
 |  | ||||||
|     # Repeat the execution of each unit 10 times |  | ||||||
|     loops = 10; |  | ||||||
| 
 |  | ||||||
|     # Resources |  | ||||||
|     qos = "debug"; |  | ||||||
|     ntasksPerNode = hw.socketsPerNode; |  | ||||||
|     cpusPerTask = hw.cpusPerSocket; |  | ||||||
|     jobName = unitName; |  | ||||||
|      |  | ||||||
|     nprocz = ntasksPerNode * nodes; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Compute the array of configurations |  | ||||||
|   configs = stdexp.buildConfigs { |  | ||||||
|     inherit varConf genConf; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Custom srun stage to copy the creams input dataset |  | ||||||
|   customSrun = {nextStage, conf, ...}: |  | ||||||
|     let |  | ||||||
|       input = bsc.garlic.apps.creamsInput.override { |  | ||||||
|         inherit (conf) gitBranch granul nprocz; |  | ||||||
|       }; |  | ||||||
|     in |  | ||||||
|       stages.srun { |  | ||||||
|         # These are part of the stdndard srun stage: |  | ||||||
|         inherit (conf) nixPrefix; |  | ||||||
|         inherit nextStage; |  | ||||||
|         cpuBind = "cores,verbose"; |  | ||||||
| 
 |  | ||||||
|         # Now we add some commands to execute before calling srun. These will |  | ||||||
|         # only run in one rank (the first in the list of allocated nodes) |  | ||||||
|         preSrun = '' |  | ||||||
|           cp -r ${input}/SodTubeBenchmark/* . |  | ||||||
|           chmod +w -R . |  | ||||||
|           rm -f nanos6.toml |  | ||||||
|         ''; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   exec = {nextStage, conf, ...}: with conf; stages.exec { |  | ||||||
|     inherit nextStage; |  | ||||||
|     env = '' |  | ||||||
|       export NANOS6_CONFIG_OVERRIDE="version.dependencies=regions" |  | ||||||
|     ''; |  | ||||||
| 
 |  | ||||||
|     # Remove restarts as is not needed and is huge |  | ||||||
|     post = '' |  | ||||||
|       rm -rf restarts || true |  | ||||||
|     ''; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Creams program |  | ||||||
|   creams = {nextStage, conf, ...}: with conf; |  | ||||||
|     let |  | ||||||
|       customPkgs = stdexp.replaceMpi conf.mpi; |  | ||||||
|     in |  | ||||||
|       customPkgs.apps.creams.override { |  | ||||||
|         inherit cc mpi gitBranch; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   pipeline = stdexp.stdPipelineOverride { |  | ||||||
|     overrides = { |  | ||||||
|       # Replace the stdandard srun stage with our own |  | ||||||
|       srun = customSrun; |  | ||||||
|     }; |  | ||||||
|   } ++ [ exec creams ]; |  | ||||||
| 
 |  | ||||||
| in |  | ||||||
|   |  | ||||||
|   stdexp.genExperiment { inherit configs pipeline; } |  | ||||||
| @ -1,114 +0,0 @@ | |||||||
| { |  | ||||||
|   stdenv |  | ||||||
| , stdexp |  | ||||||
| , bsc |  | ||||||
| , targetMachine |  | ||||||
| , stages |  | ||||||
| }: |  | ||||||
| 
 |  | ||||||
| with stdenv.lib; |  | ||||||
| 
 |  | ||||||
| let |  | ||||||
|   # Initial variable configuration |  | ||||||
|   varConf = { |  | ||||||
|     input = [ |  | ||||||
|       { nodes=16 ; nprocz=32 ; granul=64;  time= "02:00:00"; } |  | ||||||
|       { nodes=16 ; nprocz=32 ; granul=32;  time= "02:00:00"; } |  | ||||||
|       { nodes=16 ; nprocz=32 ; granul=16;  time= "02:00:00"; } |  | ||||||
|       { nodes=16 ; nprocz=32 ; granul= 9;  time= "02:00:00"; } |  | ||||||
|       { nodes=16 ; nprocz=32 ; granul= 5;  time= "02:00:00"; } |  | ||||||
|       { nodes=16 ; nprocz=32 ; granul= 4;  time= "02:00:00"; } |  | ||||||
|       { nodes=16 ; nprocz=32 ; granul= 2;  time= "02:00:00"; } |  | ||||||
|       { nodes=16 ; nprocz=32 ; granul= 1;  time= "02:00:00"; } |  | ||||||
|     ]; |  | ||||||
| 
 |  | ||||||
|     gitBranch = [ |  | ||||||
|       "garlic/mpi+send+omp+task" |  | ||||||
|       "garlic/mpi+send+oss+task" |  | ||||||
|       "garlic/mpi+isend+omp+task" |  | ||||||
|       "garlic/mpi+isend+oss+task" |  | ||||||
|       "garlic/tampi+isend+oss+task" |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Generate the complete configuration for each unit |  | ||||||
|   genConf = with bsc; c: targetMachine.config // rec { |  | ||||||
|     expName = "creams-gran-node16"; |  | ||||||
|     inherit (targetMachine.config) hw; |  | ||||||
|     # Options for creams |  | ||||||
|     cc = icc; |  | ||||||
|     mpi = impi; |  | ||||||
|     inherit (c.input) granul time nodes; |  | ||||||
|     inherit (c) gitBranch; |  | ||||||
|     unitName = "${expName}-${toString nodes}-${gitBranch}"; |  | ||||||
| 
 |  | ||||||
|     # Repeat the execution of each unit 10 times |  | ||||||
|     loops = 10; |  | ||||||
| 
 |  | ||||||
|     # Resources |  | ||||||
|     qos = "debug"; |  | ||||||
|     ntasksPerNode = hw.socketsPerNode; |  | ||||||
|     cpusPerTask = hw.cpusPerSocket; |  | ||||||
|     jobName = unitName; |  | ||||||
|      |  | ||||||
|     nprocz = ntasksPerNode * nodes; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Compute the array of configurations |  | ||||||
|   configs = stdexp.buildConfigs { |  | ||||||
|     inherit varConf genConf; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Custom srun stage to copy the creams input dataset |  | ||||||
|   customSrun = {nextStage, conf, ...}: |  | ||||||
|     let |  | ||||||
|       input = bsc.garlic.apps.creamsInput.override { |  | ||||||
|         inherit (conf) gitBranch granul nprocz; |  | ||||||
|       }; |  | ||||||
|     in |  | ||||||
|       stages.srun { |  | ||||||
|         # These are part of the stdndard srun stage: |  | ||||||
|         inherit (conf) nixPrefix; |  | ||||||
|         inherit nextStage; |  | ||||||
|         cpuBind = "cores,verbose"; |  | ||||||
| 
 |  | ||||||
|         # Now we add some commands to execute before calling srun. These will |  | ||||||
|         # only run in one rank (the first in the list of allocated nodes) |  | ||||||
|         preSrun = '' |  | ||||||
|           cp -r ${input}/SodTubeBenchmark/* . |  | ||||||
|           chmod +w -R . |  | ||||||
|           rm -f nanos6.toml |  | ||||||
|         ''; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   exec = {nextStage, conf, ...}: with conf; stages.exec { |  | ||||||
|     inherit nextStage; |  | ||||||
|     env = '' |  | ||||||
|       export NANOS6_CONFIG_OVERRIDE="version.dependencies=regions" |  | ||||||
|     ''; |  | ||||||
| 
 |  | ||||||
|     # Remove restarts as is not needed and is huge |  | ||||||
|     post = '' |  | ||||||
|       rm -rf restarts || true |  | ||||||
|     ''; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Creams program |  | ||||||
|   creams = {nextStage, conf, ...}: with conf; |  | ||||||
|     let |  | ||||||
|       customPkgs = stdexp.replaceMpi conf.mpi; |  | ||||||
|     in |  | ||||||
|       customPkgs.apps.creams.override { |  | ||||||
|         inherit cc mpi gitBranch; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   pipeline = stdexp.stdPipelineOverride { |  | ||||||
|     overrides = { |  | ||||||
|       # Replace the stdandard srun stage with our own |  | ||||||
|       srun = customSrun; |  | ||||||
|     }; |  | ||||||
|   } ++ [ exec creams ]; |  | ||||||
| 
 |  | ||||||
| in |  | ||||||
|   |  | ||||||
|   stdexp.genExperiment { inherit configs pipeline; } |  | ||||||
| @ -1,114 +0,0 @@ | |||||||
| { |  | ||||||
|   stdenv |  | ||||||
| , stdexp |  | ||||||
| , bsc |  | ||||||
| , targetMachine |  | ||||||
| , stages |  | ||||||
| }: |  | ||||||
| 
 |  | ||||||
| with stdenv.lib; |  | ||||||
| 
 |  | ||||||
| let |  | ||||||
|   # Initial variable configuration |  | ||||||
|   varConf = { |  | ||||||
|     input = [ |  | ||||||
|       { nodes=2 ; nprocz=4 ; granul=256; time= "02:00:00"; } |  | ||||||
|       { nodes=2 ; nprocz=4 ; granul=128; time= "02:00:00"; } |  | ||||||
|       { nodes=2 ; nprocz=4 ; granul=64;  time= "02:00:00"; } |  | ||||||
|       { nodes=2 ; nprocz=4 ; granul=32;  time= "02:00:00"; } |  | ||||||
|       { nodes=2 ; nprocz=4 ; granul=16;  time= "02:00:00"; } |  | ||||||
|       { nodes=2 ; nprocz=4 ; granul= 9;  time= "02:00:00"; } |  | ||||||
|       { nodes=2 ; nprocz=4 ; granul= 5;  time= "02:00:00"; } |  | ||||||
|       { nodes=2 ; nprocz=4 ; granul= 4;  time= "02:00:00"; } |  | ||||||
|     ]; |  | ||||||
| 
 |  | ||||||
|     gitBranch = [ |  | ||||||
|       "garlic/mpi+send+omp+task" |  | ||||||
|       "garlic/mpi+send+oss+task" |  | ||||||
|       "garlic/mpi+isend+omp+task" |  | ||||||
|       "garlic/mpi+isend+oss+task" |  | ||||||
|       "garlic/tampi+isend+oss+task" |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Generate the complete configuration for each unit |  | ||||||
|   genConf = with bsc; c: targetMachine.config // rec { |  | ||||||
|     expName = "creams-gran-node2"; |  | ||||||
|     inherit (targetMachine.config) hw; |  | ||||||
|     # Options for creams |  | ||||||
|     cc = icc; |  | ||||||
|     mpi = impi; |  | ||||||
|     inherit (c.input) granul time nodes; |  | ||||||
|     inherit (c) gitBranch; |  | ||||||
|     unitName = "${expName}-${toString nodes}-${gitBranch}"; |  | ||||||
| 
 |  | ||||||
|     # Repeat the execution of each unit 10 times |  | ||||||
|     loops = 10; |  | ||||||
| 
 |  | ||||||
|     # Resources |  | ||||||
|     qos = "debug"; |  | ||||||
|     ntasksPerNode = hw.socketsPerNode; |  | ||||||
|     cpusPerTask = hw.cpusPerSocket; |  | ||||||
|     jobName = unitName; |  | ||||||
|      |  | ||||||
|     nprocz = ntasksPerNode * nodes; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Compute the array of configurations |  | ||||||
|   configs = stdexp.buildConfigs { |  | ||||||
|     inherit varConf genConf; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Custom srun stage to copy the creams input dataset |  | ||||||
|   customSrun = {nextStage, conf, ...}: |  | ||||||
|     let |  | ||||||
|       input = bsc.garlic.apps.creamsInput.override { |  | ||||||
|         inherit (conf) gitBranch granul nprocz; |  | ||||||
|       }; |  | ||||||
|     in |  | ||||||
|       stages.srun { |  | ||||||
|         # These are part of the stdndard srun stage: |  | ||||||
|         inherit (conf) nixPrefix; |  | ||||||
|         inherit nextStage; |  | ||||||
|         cpuBind = "cores,verbose"; |  | ||||||
| 
 |  | ||||||
|         # Now we add some commands to execute before calling srun. These will |  | ||||||
|         # only run in one rank (the first in the list of allocated nodes) |  | ||||||
|         preSrun = '' |  | ||||||
|           cp -r ${input}/SodTubeBenchmark/* . |  | ||||||
|           chmod +w -R . |  | ||||||
|           rm -f nanos6.toml |  | ||||||
|         ''; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   exec = {nextStage, conf, ...}: with conf; stages.exec { |  | ||||||
|     inherit nextStage; |  | ||||||
|     env = '' |  | ||||||
|       export NANOS6_CONFIG_OVERRIDE="version.dependencies=regions" |  | ||||||
|     ''; |  | ||||||
| 
 |  | ||||||
|     # Remove restarts as is not needed and is huge |  | ||||||
|     post = '' |  | ||||||
|       rm -rf restarts || true |  | ||||||
|     ''; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Creams program |  | ||||||
|   creams = {nextStage, conf, ...}: with conf; |  | ||||||
|     let |  | ||||||
|       customPkgs = stdexp.replaceMpi conf.mpi; |  | ||||||
|     in |  | ||||||
|       customPkgs.apps.creams.override { |  | ||||||
|         inherit cc mpi gitBranch; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   pipeline = stdexp.stdPipelineOverride { |  | ||||||
|     overrides = { |  | ||||||
|       # Replace the stdandard srun stage with our own |  | ||||||
|       srun = customSrun; |  | ||||||
|     }; |  | ||||||
|   } ++ [ exec creams ]; |  | ||||||
| 
 |  | ||||||
| in |  | ||||||
|   |  | ||||||
|   stdexp.genExperiment { inherit configs pipeline; } |  | ||||||
| @ -1,114 +0,0 @@ | |||||||
| { |  | ||||||
|   stdenv |  | ||||||
| , stdexp |  | ||||||
| , bsc |  | ||||||
| , targetMachine |  | ||||||
| , stages |  | ||||||
| }: |  | ||||||
| 
 |  | ||||||
| with stdenv.lib; |  | ||||||
| 
 |  | ||||||
| let |  | ||||||
|   # Initial variable configuration |  | ||||||
|   varConf = { |  | ||||||
|     input = [ |  | ||||||
|       { nodes=4 ; nprocz=8 ; granul=64;  time= "02:00:00"; } |  | ||||||
|       { nodes=4 ; nprocz=8 ; granul=32;  time= "02:00:00"; } |  | ||||||
|       { nodes=4 ; nprocz=8 ; granul=16;  time= "02:00:00"; } |  | ||||||
|       { nodes=4 ; nprocz=8 ; granul= 9;  time= "02:00:00"; } |  | ||||||
|       { nodes=4 ; nprocz=8 ; granul= 5;  time= "02:00:00"; } |  | ||||||
|       { nodes=4 ; nprocz=4 ; granul= 4;  time= "02:00:00"; } |  | ||||||
|       { nodes=4 ; nprocz=8 ; granul= 2;  time= "02:00:00"; } |  | ||||||
|       { nodes=4 ; nprocz=8 ; granul= 1;  time= "02:00:00"; } |  | ||||||
|     ]; |  | ||||||
| 
 |  | ||||||
|     gitBranch = [ |  | ||||||
|       "garlic/mpi+send+omp+task" |  | ||||||
|       "garlic/mpi+send+oss+task" |  | ||||||
|       "garlic/mpi+isend+omp+task" |  | ||||||
|       "garlic/mpi+isend+oss+task" |  | ||||||
|       "garlic/tampi+isend+oss+task" |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Generate the complete configuration for each unit |  | ||||||
|   genConf = with bsc; c: targetMachine.config // rec { |  | ||||||
|     expName = "creams-gran-node4"; |  | ||||||
|     inherit (targetMachine.config) hw; |  | ||||||
|     # Options for creams |  | ||||||
|     cc = icc; |  | ||||||
|     mpi = impi; |  | ||||||
|     inherit (c.input) granul time nodes; |  | ||||||
|     inherit (c) gitBranch; |  | ||||||
|     unitName = "${expName}-${toString nodes}-${gitBranch}"; |  | ||||||
| 
 |  | ||||||
|     # Repeat the execution of each unit 10 times |  | ||||||
|     loops = 10; |  | ||||||
| 
 |  | ||||||
|     # Resources |  | ||||||
|     qos = "debug"; |  | ||||||
|     ntasksPerNode = hw.socketsPerNode; |  | ||||||
|     cpusPerTask = hw.cpusPerSocket; |  | ||||||
|     jobName = unitName; |  | ||||||
|      |  | ||||||
|     nprocz = ntasksPerNode * nodes; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Compute the array of configurations |  | ||||||
|   configs = stdexp.buildConfigs { |  | ||||||
|     inherit varConf genConf; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Custom srun stage to copy the creams input dataset |  | ||||||
|   customSrun = {nextStage, conf, ...}: |  | ||||||
|     let |  | ||||||
|       input = bsc.garlic.apps.creamsInput.override { |  | ||||||
|         inherit (conf) gitBranch granul nprocz; |  | ||||||
|       }; |  | ||||||
|     in |  | ||||||
|       stages.srun { |  | ||||||
|         # These are part of the stdndard srun stage: |  | ||||||
|         inherit (conf) nixPrefix; |  | ||||||
|         inherit nextStage; |  | ||||||
|         cpuBind = "cores,verbose"; |  | ||||||
| 
 |  | ||||||
|         # Now we add some commands to execute before calling srun. These will |  | ||||||
|         # only run in one rank (the first in the list of allocated nodes) |  | ||||||
|         preSrun = '' |  | ||||||
|           cp -r ${input}/SodTubeBenchmark/* . |  | ||||||
|           chmod +w -R . |  | ||||||
|           rm -f nanos6.toml |  | ||||||
|         ''; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   exec = {nextStage, conf, ...}: with conf; stages.exec { |  | ||||||
|     inherit nextStage; |  | ||||||
|     env = '' |  | ||||||
|       export NANOS6_CONFIG_OVERRIDE="version.dependencies=regions" |  | ||||||
|     ''; |  | ||||||
| 
 |  | ||||||
|     # Remove restarts as is not needed and is huge |  | ||||||
|     post = '' |  | ||||||
|       rm -rf restarts || true |  | ||||||
|     ''; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Creams program |  | ||||||
|   creams = {nextStage, conf, ...}: with conf; |  | ||||||
|     let |  | ||||||
|       customPkgs = stdexp.replaceMpi conf.mpi; |  | ||||||
|     in |  | ||||||
|       customPkgs.apps.creams.override { |  | ||||||
|         inherit cc mpi gitBranch; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   pipeline = stdexp.stdPipelineOverride { |  | ||||||
|     overrides = { |  | ||||||
|       # Replace the stdandard srun stage with our own |  | ||||||
|       srun = customSrun; |  | ||||||
|     }; |  | ||||||
|   } ++ [ exec creams ]; |  | ||||||
| 
 |  | ||||||
| in |  | ||||||
|   |  | ||||||
|   stdexp.genExperiment { inherit configs pipeline; } |  | ||||||
| @ -1,114 +0,0 @@ | |||||||
| { |  | ||||||
|   stdenv |  | ||||||
| , stdexp |  | ||||||
| , bsc |  | ||||||
| , targetMachine |  | ||||||
| , stages |  | ||||||
| }: |  | ||||||
| 
 |  | ||||||
| with stdenv.lib; |  | ||||||
| 
 |  | ||||||
| let |  | ||||||
|   # Initial variable configuration |  | ||||||
|   varConf = { |  | ||||||
|     input = [ |  | ||||||
|       { nodes=8 ; nprocz=16 ; granul=64;  time= "02:00:00"; } |  | ||||||
|       { nodes=8 ; nprocz=16 ; granul=32;  time= "02:00:00"; } |  | ||||||
|       { nodes=8 ; nprocz=16 ; granul=16;  time= "02:00:00"; } |  | ||||||
|       { nodes=8 ; nprocz=16 ; granul= 9;  time= "02:00:00"; } |  | ||||||
|       { nodes=8 ; nprocz=16 ; granul= 5;  time= "02:00:00"; } |  | ||||||
|       { nodes=8 ; nprocz=16 ; granul= 4;  time= "02:00:00"; } |  | ||||||
|       { nodes=8 ; nprocz=16 ; granul= 2;  time= "02:00:00"; } |  | ||||||
|       { nodes=8 ; nprocz=16 ; granul= 1;  time= "02:00:00"; } |  | ||||||
|     ]; |  | ||||||
| 
 |  | ||||||
|     gitBranch = [ |  | ||||||
|       "garlic/mpi+send+omp+task" |  | ||||||
|       "garlic/mpi+send+oss+task" |  | ||||||
|       "garlic/mpi+isend+omp+task" |  | ||||||
|       "garlic/mpi+isend+oss+task" |  | ||||||
|       "garlic/tampi+isend+oss+task" |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Generate the complete configuration for each unit |  | ||||||
|   genConf = with bsc; c: targetMachine.config // rec { |  | ||||||
|     expName = "creams-gran-node8"; |  | ||||||
|     inherit (targetMachine.config) hw; |  | ||||||
|     # Options for creams |  | ||||||
|     cc = icc; |  | ||||||
|     mpi = impi; |  | ||||||
|     inherit (c.input) granul time nodes; |  | ||||||
|     inherit (c) gitBranch; |  | ||||||
|     unitName = "${expName}-${toString nodes}-${gitBranch}"; |  | ||||||
| 
 |  | ||||||
|     # Repeat the execution of each unit 10 times |  | ||||||
|     loops = 10; |  | ||||||
| 
 |  | ||||||
|     # Resources |  | ||||||
|     qos = "debug"; |  | ||||||
|     ntasksPerNode = hw.socketsPerNode; |  | ||||||
|     cpusPerTask = hw.cpusPerSocket; |  | ||||||
|     jobName = unitName; |  | ||||||
|      |  | ||||||
|     nprocz = ntasksPerNode * nodes; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Compute the array of configurations |  | ||||||
|   configs = stdexp.buildConfigs { |  | ||||||
|     inherit varConf genConf; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Custom srun stage to copy the creams input dataset |  | ||||||
|   customSrun = {nextStage, conf, ...}: |  | ||||||
|     let |  | ||||||
|       input = bsc.garlic.apps.creamsInput.override { |  | ||||||
|         inherit (conf) gitBranch granul nprocz; |  | ||||||
|       }; |  | ||||||
|     in |  | ||||||
|       stages.srun { |  | ||||||
|         # These are part of the stdndard srun stage: |  | ||||||
|         inherit (conf) nixPrefix; |  | ||||||
|         inherit nextStage; |  | ||||||
|         cpuBind = "cores,verbose"; |  | ||||||
| 
 |  | ||||||
|         # Now we add some commands to execute before calling srun. These will |  | ||||||
|         # only run in one rank (the first in the list of allocated nodes) |  | ||||||
|         preSrun = '' |  | ||||||
|           cp -r ${input}/SodTubeBenchmark/* . |  | ||||||
|           chmod +w -R . |  | ||||||
|           rm -f nanos6.toml |  | ||||||
|         ''; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   exec = {nextStage, conf, ...}: with conf; stages.exec { |  | ||||||
|     inherit nextStage; |  | ||||||
|     env = '' |  | ||||||
|       export NANOS6_CONFIG_OVERRIDE="version.dependencies=regions" |  | ||||||
|     ''; |  | ||||||
| 
 |  | ||||||
|     # Remove restarts as is not needed and is huge |  | ||||||
|     post = '' |  | ||||||
|       rm -rf restarts || true |  | ||||||
|     ''; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Creams program |  | ||||||
|   creams = {nextStage, conf, ...}: with conf; |  | ||||||
|     let |  | ||||||
|       customPkgs = stdexp.replaceMpi conf.mpi; |  | ||||||
|     in |  | ||||||
|       customPkgs.apps.creams.override { |  | ||||||
|         inherit cc mpi gitBranch; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   pipeline = stdexp.stdPipelineOverride { |  | ||||||
|     overrides = { |  | ||||||
|       # Replace the stdandard srun stage with our own |  | ||||||
|       srun = customSrun; |  | ||||||
|     }; |  | ||||||
|   } ++ [ exec creams ]; |  | ||||||
| 
 |  | ||||||
| in |  | ||||||
|   |  | ||||||
|   stdexp.genExperiment { inherit configs pipeline; } |  | ||||||
							
								
								
									
										125
									
								
								garlic/exp/creams/granularity.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										125
									
								
								garlic/exp/creams/granularity.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,125 @@ | |||||||
|  | { | ||||||
|  |   stdenv | ||||||
|  | , stdexp | ||||||
|  | , bsc | ||||||
|  | , targetMachine | ||||||
|  | , stages | ||||||
|  | , garlicTools | ||||||
|  | , enableExtended ? false | ||||||
|  | }: | ||||||
|  | 
 | ||||||
|  | with stdenv.lib; | ||||||
|  | with garlicTools; | ||||||
|  | 
 | ||||||
|  | let | ||||||
|  |   # Initial variable configuration | ||||||
|  |   varConf = { | ||||||
|  |     granul = range2 4 128; | ||||||
|  | 
 | ||||||
|  |     gitBranch = [ | ||||||
|  |       "garlic/tampi+isend+oss+task" | ||||||
|  |       "garlic/mpi+isend+omp+task" | ||||||
|  |       "garlic/mpi+send+seq" | ||||||
|  |     ] ++ optionals (enableExtended) [ | ||||||
|  |       #"garlic/mpi+send+omp+fork" # Don't use fork for granularity | ||||||
|  |       "garlic/mpi+send+omp+task" | ||||||
|  |       "garlic/mpi+send+oss+task" | ||||||
|  |       "garlic/mpi+isend+oss+task" | ||||||
|  |     ]; | ||||||
|  | 
 | ||||||
|  |     # Max. number of iterations | ||||||
|  |     iterations = [ 10 20 ]; | ||||||
|  | 
 | ||||||
|  |     nodes = [ 1 ] ++ optionals (enableExtended) (range2 2 16); | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   # We use these auxiliary functions to assign different configurations | ||||||
|  |   # depending on the git branch. | ||||||
|  |   getGranul = branch: oldGranul: | ||||||
|  |     if (branch == "garlic/mpi+send+seq") | ||||||
|  |     then 999999 else oldGranul; | ||||||
|  | 
 | ||||||
|  |   getCpusPerTask = branch: hw: | ||||||
|  |     if (branch == "garlic/mpi+send+seq") | ||||||
|  |     then 1 else hw.cpusPerSocket; | ||||||
|  | 
 | ||||||
|  |   getNtasksPerNode = branch: hw: | ||||||
|  |     if (branch == "garlic/mpi+send+seq") | ||||||
|  |     then hw.cpusPerNode else hw.socketsPerNode; | ||||||
|  | 
 | ||||||
|  |   # Generate the complete configuration for each unit | ||||||
|  |   genConf = c: targetMachine.config // rec { | ||||||
|  | 
 | ||||||
|  |     expName = "creams-gran"; | ||||||
|  |     unitName = "${expName}"+ | ||||||
|  |       "-nodes${toString nodes}"+ | ||||||
|  |       "-granul${toString granul}"+ | ||||||
|  |       "-${gitBranch}"; | ||||||
|  | 
 | ||||||
|  |     inherit (targetMachine.config) hw; | ||||||
|  | 
 | ||||||
|  |     # Options for creams | ||||||
|  |     inherit (c) gitBranch nodes iterations; | ||||||
|  |     granul = getGranul gitBranch c.granul; | ||||||
|  |     nprocz = ntasksPerNode * nodes; | ||||||
|  | 
 | ||||||
|  |     # Repeat the execution of each unit 10 times | ||||||
|  |     loops = 10; | ||||||
|  | 
 | ||||||
|  |     # Resources | ||||||
|  |     qos = "debug"; | ||||||
|  |     time = "02:00:00"; | ||||||
|  |     ntasksPerNode = getNtasksPerNode gitBranch hw; | ||||||
|  |     cpusPerTask = getCpusPerTask gitBranch hw; | ||||||
|  |     jobName = unitName; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   # Compute the array of configurations | ||||||
|  |   configs = stdexp.buildConfigs { | ||||||
|  |     inherit varConf genConf; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   # Custom srun stage to copy the creams input dataset | ||||||
|  |   customSrun = {nextStage, conf, ...}: | ||||||
|  |   let | ||||||
|  |     input = bsc.garlic.apps.creamsInput.override { | ||||||
|  |       inherit (conf) gitBranch granul nprocz; | ||||||
|  |     }; | ||||||
|  |   in | ||||||
|  |     stdexp.stdStages.srun { | ||||||
|  |       inherit nextStage conf; | ||||||
|  |       # Now we add some commands to execute before calling srun. These will | ||||||
|  |       # only run in one rank (the first in the list of allocated nodes) | ||||||
|  |       preSrun = '' | ||||||
|  |         cp -r ${input}/SodTubeBenchmark/* . | ||||||
|  |         chmod +w -R . | ||||||
|  |         sed -i '/maximum number of iterations/s/50/${toString conf.iterations}/' input.dat | ||||||
|  |         rm -f nanos6.toml | ||||||
|  |       ''; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |   exec = {nextStage, conf, ...}: stages.exec { | ||||||
|  |     inherit nextStage; | ||||||
|  |     env = '' | ||||||
|  |       export NANOS6_CONFIG_OVERRIDE="version.dependencies=regions" | ||||||
|  |     ''; | ||||||
|  | 
 | ||||||
|  |     # Remove restarts as is not needed and is huge | ||||||
|  |     post = '' | ||||||
|  |       rm -rf restarts || true | ||||||
|  |     ''; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   # Creams program | ||||||
|  |   creams = {nextStage, conf, ...}: bsc.apps.creams.override { | ||||||
|  |     inherit (conf) gitBranch; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   pipeline = stdexp.stdPipelineOverride { | ||||||
|  |     # Replace the stdandard srun stage with our own | ||||||
|  |     overrides = { srun = customSrun; }; | ||||||
|  |   } ++ [ exec creams ]; | ||||||
|  | 
 | ||||||
|  | in | ||||||
|  |   | ||||||
|  |   stdexp.genExperiment { inherit configs pipeline; } | ||||||
| @ -1,112 +0,0 @@ | |||||||
| { |  | ||||||
|   stdenv |  | ||||||
| , stdexp |  | ||||||
| , bsc |  | ||||||
| , targetMachine |  | ||||||
| , stages |  | ||||||
| }: |  | ||||||
| 
 |  | ||||||
| with stdenv.lib; |  | ||||||
| 
 |  | ||||||
| let |  | ||||||
|   # Initial variable configuration |  | ||||||
|   varConf = { |  | ||||||
|     input = [ |  | ||||||
|       { nodes=1 ; nprocz=2 ; granul=16; time= "02:00:00"; } |  | ||||||
|       { nodes=2 ; nprocz=4 ; granul=16; time= "02:00:00"; } |  | ||||||
|       { nodes=4 ; nprocz=8 ; granul=9 ; time= "02:00:00"; } |  | ||||||
|       { nodes=8 ; nprocz=16; granul=9 ; time= "02:00:00"; } |  | ||||||
|       { nodes=16; nprocz=32; granul=9 ; time= "02:00:00"; }     |  | ||||||
|     ]; |  | ||||||
| 
 |  | ||||||
|     gitBranch = [ |  | ||||||
|       "garlic/mpi+send+omp+fork" |  | ||||||
|       "garlic/mpi+send+omp+task" |  | ||||||
|       "garlic/mpi+send+oss+task" |  | ||||||
|       "garlic/mpi+isend+omp+task" |  | ||||||
|       "garlic/mpi+isend+oss+task" |  | ||||||
|       "garlic/tampi+isend+oss+task" |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Generate the complete configuration for each unit |  | ||||||
|   genConf = with bsc; c: targetMachine.config // rec { |  | ||||||
|     expName = "creams-ss-hybrid"; |  | ||||||
|     inherit (targetMachine.config) hw; |  | ||||||
|     # Options for creams |  | ||||||
|     cc = icc; |  | ||||||
|     mpi = impi; |  | ||||||
|     inherit (c.input) granul time nodes; |  | ||||||
|     inherit (c) gitBranch; |  | ||||||
|     unitName = "${expName}-${toString nodes}-${gitBranch}"; |  | ||||||
| 
 |  | ||||||
|     # Repeat the execution of each unit 10 times |  | ||||||
|     loops = 10; |  | ||||||
| 
 |  | ||||||
|     # Resources |  | ||||||
|     qos = "debug"; |  | ||||||
|     ntasksPerNode = hw.socketsPerNode; |  | ||||||
|     cpusPerTask = hw.cpusPerSocket; |  | ||||||
|     jobName = unitName; |  | ||||||
|      |  | ||||||
|     nprocz = ntasksPerNode * nodes; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Compute the array of configurations |  | ||||||
|   configs = stdexp.buildConfigs { |  | ||||||
|     inherit varConf genConf; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Custom srun stage to copy the creams input dataset |  | ||||||
|   customSrun = {nextStage, conf, ...}: |  | ||||||
|     let |  | ||||||
|       input = bsc.garlic.apps.creamsInput.override { |  | ||||||
|         inherit (conf) gitBranch granul nprocz; |  | ||||||
|       }; |  | ||||||
|     in |  | ||||||
|       stages.srun { |  | ||||||
|         # These are part of the stdndard srun stage: |  | ||||||
|         inherit (conf) nixPrefix; |  | ||||||
|         inherit nextStage; |  | ||||||
|         cpuBind = "cores,verbose"; |  | ||||||
| 
 |  | ||||||
|         # Now we add some commands to execute before calling srun. These will |  | ||||||
|         # only run in one rank (the first in the list of allocated nodes) |  | ||||||
|         preSrun = '' |  | ||||||
|           cp -r ${input}/SodTubeBenchmark/* . |  | ||||||
|           chmod +w -R . |  | ||||||
|           rm -f nanos6.toml |  | ||||||
|         ''; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   exec = {nextStage, conf, ...}: with conf; stages.exec { |  | ||||||
|     inherit nextStage; |  | ||||||
|     env = '' |  | ||||||
|       export NANOS6_CONFIG_OVERRIDE="version.dependencies=regions" |  | ||||||
|     ''; |  | ||||||
| 
 |  | ||||||
|     # Remove restarts as is not needed and is huge |  | ||||||
|     post = '' |  | ||||||
|       rm -rf restarts || true |  | ||||||
|     ''; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Creams program |  | ||||||
|   creams = {nextStage, conf, ...}: with conf; |  | ||||||
|     let |  | ||||||
|       customPkgs = stdexp.replaceMpi conf.mpi; |  | ||||||
|     in |  | ||||||
|       customPkgs.apps.creams.override { |  | ||||||
|         inherit cc mpi gitBranch; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   pipeline = stdexp.stdPipelineOverride { |  | ||||||
|     overrides = { |  | ||||||
|       # Replace the stdandard srun stage with our own |  | ||||||
|       srun = customSrun; |  | ||||||
|     }; |  | ||||||
|   } ++ [ exec creams ]; |  | ||||||
| 
 |  | ||||||
| in |  | ||||||
|   |  | ||||||
|   stdexp.genExperiment { inherit configs pipeline; } |  | ||||||
| @ -1,107 +0,0 @@ | |||||||
| { |  | ||||||
|   stdenv |  | ||||||
| , stdexp |  | ||||||
| , bsc |  | ||||||
| , targetMachine |  | ||||||
| , stages |  | ||||||
| }: |  | ||||||
| 
 |  | ||||||
| with stdenv.lib; |  | ||||||
| 
 |  | ||||||
| let |  | ||||||
|   # Initial variable configuration |  | ||||||
|   varConf = { |  | ||||||
|     input = [ |  | ||||||
|       { nodes=1 ; nprocz=2 ; granul=999999; time= "02:00:00"; } |  | ||||||
|       { nodes=2 ; nprocz=4 ; granul=999999; time= "02:00:00"; } |  | ||||||
|       { nodes=4 ; nprocz=8 ; granul=999999; time= "02:00:00"; } |  | ||||||
|       { nodes=8 ; nprocz=16; granul=999999; time= "02:00:00"; } |  | ||||||
|       { nodes=16; nprocz=32; granul=999999; time= "02:00:00"; }     |  | ||||||
|     ]; |  | ||||||
| 
 |  | ||||||
|     gitBranch = [ |  | ||||||
|       "garlic/mpi+send+seq" |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Generate the complete configuration for each unit |  | ||||||
|   genConf = with bsc; c: targetMachine.config // rec { |  | ||||||
|     expName = "creams-ss-pure"; |  | ||||||
|     inherit (targetMachine.config) hw; |  | ||||||
|     # Options for creams |  | ||||||
|     cc = icc; |  | ||||||
|     mpi = impi; |  | ||||||
|     inherit (c.input) granul time nodes; |  | ||||||
|     inherit (c) gitBranch; |  | ||||||
|     unitName = "${expName}-${toString nodes}-${gitBranch}"; |  | ||||||
| 
 |  | ||||||
|     # Repeat the execution of each unit 10 times |  | ||||||
|     loops = 10; |  | ||||||
| 
 |  | ||||||
|     # Resources |  | ||||||
|     qos = "debug"; |  | ||||||
|     ntasksPerNode = hw.cpusPerNode; |  | ||||||
|     cpusPerTask = 1; |  | ||||||
|     jobName = unitName; |  | ||||||
|      |  | ||||||
|     nprocz = ntasksPerNode * nodes; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Compute the array of configurations |  | ||||||
|   configs = stdexp.buildConfigs { |  | ||||||
|     inherit varConf genConf; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Custom srun stage to copy the creams input dataset |  | ||||||
|   customSrun = {nextStage, conf, ...}: |  | ||||||
|     let |  | ||||||
|       input = bsc.garlic.apps.creamsInput.override { |  | ||||||
|         inherit (conf) gitBranch granul nprocz; |  | ||||||
|       }; |  | ||||||
|     in |  | ||||||
|       stages.srun { |  | ||||||
|         # These are part of the stdndard srun stage: |  | ||||||
|         inherit (conf) nixPrefix; |  | ||||||
|         inherit nextStage; |  | ||||||
|         cpuBind = "cores,verbose"; |  | ||||||
| 
 |  | ||||||
|         # Now we add some commands to execute before calling srun. These will |  | ||||||
|         # only run in one rank (the first in the list of allocated nodes) |  | ||||||
|         preSrun = '' |  | ||||||
|           cp -r ${input}/SodTubeBenchmark/* . |  | ||||||
|           chmod +w -R . |  | ||||||
|           rm -f nanos6.toml |  | ||||||
|         ''; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   exec = {nextStage, conf, ...}: with conf; stages.exec { |  | ||||||
|     inherit nextStage; |  | ||||||
|     env = '' |  | ||||||
|       export NANOS6_CONFIG_OVERRIDE="version.dependencies=regions" |  | ||||||
|     ''; |  | ||||||
| 
 |  | ||||||
|     # Remove restarts as is not needed and is huge |  | ||||||
|     post = '' |  | ||||||
|       rm -rf restarts || true |  | ||||||
|     ''; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   # Creams program |  | ||||||
|   creams = {nextStage, conf, ...}: with conf; |  | ||||||
|     let |  | ||||||
|       customPkgs = stdexp.replaceMpi conf.mpi; |  | ||||||
|     in |  | ||||||
|       customPkgs.apps.creams.override { |  | ||||||
|         inherit cc mpi gitBranch; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|   pipeline = stdexp.stdPipelineOverride { |  | ||||||
|     overrides = { |  | ||||||
|       # Replace the stdandard srun stage with our own |  | ||||||
|       srun = customSrun; |  | ||||||
|     }; |  | ||||||
|   } ++ [ exec creams ]; |  | ||||||
| 
 |  | ||||||
| in |  | ||||||
|   |  | ||||||
|   stdexp.genExperiment { inherit configs pipeline; } |  | ||||||
							
								
								
									
										125
									
								
								garlic/exp/creams/ss.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										125
									
								
								garlic/exp/creams/ss.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,125 @@ | |||||||
|  | { | ||||||
|  |   stdenv | ||||||
|  | , stdexp | ||||||
|  | , bsc | ||||||
|  | , targetMachine | ||||||
|  | , stages | ||||||
|  | , garlicTools | ||||||
|  | , enableExtended ? false | ||||||
|  | }: | ||||||
|  | 
 | ||||||
|  | with stdenv.lib; | ||||||
|  | with garlicTools; | ||||||
|  | 
 | ||||||
|  | let | ||||||
|  |   # Initial variable configuration | ||||||
|  |   varConf = { | ||||||
|  | 
 | ||||||
|  |     nodes = range2 1 16; | ||||||
|  |     granul = [ 16 ] ++ optionals (enableExtended) [ 8 32 ]; | ||||||
|  | 
 | ||||||
|  |     # Max. number of iterations | ||||||
|  |     iterations = [ 20 ] ++ optionals (enableExtended) [ 10 ]; | ||||||
|  | 
 | ||||||
|  |     gitBranch = [ | ||||||
|  |       "garlic/tampi+isend+oss+task" | ||||||
|  |       "garlic/mpi+send+omp+task" | ||||||
|  |       "garlic/mpi+send+seq" | ||||||
|  |     ] ++ optionals (enableExtended) [ | ||||||
|  |       "garlic/mpi+send+omp+fork" | ||||||
|  |       "garlic/mpi+send+oss+task" | ||||||
|  |       "garlic/mpi+isend+omp+task" | ||||||
|  |       "garlic/mpi+isend+oss+task" | ||||||
|  |     ]; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   # We use these auxiliary functions to assign different configurations | ||||||
|  |   # depending on the git branch. | ||||||
|  |   getGranul = branch: oldGranul: | ||||||
|  |     if (branch == "garlic/mpi+send+seq") | ||||||
|  |     then 999999 else oldGranul; | ||||||
|  | 
 | ||||||
|  |   getCpusPerTask = branch: hw: | ||||||
|  |     if (branch == "garlic/mpi+send+seq") | ||||||
|  |     then 1 else hw.cpusPerSocket; | ||||||
|  | 
 | ||||||
|  |   getNtasksPerNode = branch: hw: | ||||||
|  |     if (branch == "garlic/mpi+send+seq") | ||||||
|  |     then hw.cpusPerNode else hw.socketsPerNode; | ||||||
|  | 
 | ||||||
|  |   # Generate the complete configuration for each unit | ||||||
|  |   genConf = c: targetMachine.config // rec { | ||||||
|  | 
 | ||||||
|  |     expName = "creams-ss"; | ||||||
|  |     unitName = "${expName}"+ | ||||||
|  |       "-nodes${toString nodes}"+ | ||||||
|  |       "-granul${toString granul}"+ | ||||||
|  |       "-${gitBranch}"; | ||||||
|  | 
 | ||||||
|  |     inherit (targetMachine.config) hw; | ||||||
|  | 
 | ||||||
|  |     # Options for creams | ||||||
|  |     inherit (c) iterations gitBranch nodes; | ||||||
|  |     granul = getGranul gitBranch c.granul; | ||||||
|  |     nprocz = ntasksPerNode * nodes; | ||||||
|  | 
 | ||||||
|  |     # Repeat the execution of each unit 10 times | ||||||
|  |     loops = 10; | ||||||
|  | 
 | ||||||
|  |     # Resources | ||||||
|  |     qos = "debug"; | ||||||
|  |     time = "02:00:00"; | ||||||
|  |     ntasksPerNode = getNtasksPerNode gitBranch hw; | ||||||
|  |     cpusPerTask = getCpusPerTask gitBranch hw; | ||||||
|  |     jobName = unitName; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   # Compute the array of configurations | ||||||
|  |   configs = stdexp.buildConfigs { | ||||||
|  |     inherit varConf genConf; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   # Custom srun stage to copy the creams input dataset | ||||||
|  |   customSrun = {nextStage, conf, ...}: | ||||||
|  |   let | ||||||
|  |     input = bsc.garlic.apps.creamsInput.override { | ||||||
|  |       inherit (conf) gitBranch granul nprocz; | ||||||
|  |     }; | ||||||
|  |   in | ||||||
|  |     stdexp.stdStages.srun { | ||||||
|  |       inherit nextStage conf; | ||||||
|  |       # Now we add some commands to execute before calling srun. These will | ||||||
|  |       # only run in one rank (the first in the list of allocated nodes) | ||||||
|  |       preSrun = '' | ||||||
|  |         cp -r ${input}/SodTubeBenchmark/* . | ||||||
|  |         chmod +w -R . | ||||||
|  |         sed -i '/maximum number of iterations/s/50/${toString conf.iterations}/' input.dat | ||||||
|  |         rm -f nanos6.toml | ||||||
|  |       ''; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |   exec = {nextStage, conf, ...}: stages.exec { | ||||||
|  |     inherit nextStage; | ||||||
|  |     env = '' | ||||||
|  |       export NANOS6_CONFIG_OVERRIDE="version.dependencies=regions" | ||||||
|  |     ''; | ||||||
|  | 
 | ||||||
|  |     # Remove restarts as is not needed and is huge | ||||||
|  |     post = '' | ||||||
|  |       rm -rf restarts || true | ||||||
|  |     ''; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   # Creams program | ||||||
|  |   creams = {nextStage, conf, ...}: bsc.apps.creams.override { | ||||||
|  |     inherit (conf) gitBranch; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   pipeline = stdexp.stdPipelineOverride { | ||||||
|  |     # Replace the stdandard srun stage with our own | ||||||
|  |     overrides = { srun = customSrun; }; | ||||||
|  |   } ++ [ exec creams ]; | ||||||
|  | 
 | ||||||
|  | in | ||||||
|  |   | ||||||
|  |   stdexp.genExperiment { inherit configs pipeline; } | ||||||
| @ -36,18 +36,14 @@ | |||||||
|     granularity = callPackage ./saiph/granularity.nix { }; |     granularity = callPackage ./saiph/granularity.nix { }; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   creams = { |   creams = rec { | ||||||
|     ss = { |     ss = callPackage ./creams/ss.nix { }; | ||||||
|       pure = callPackage ./creams/ss+pure.nix { }; |     granularity = callPackage ./creams/granularity.nix { }; | ||||||
|       hybrid = callPackage ./creams/ss+hybrid.nix { }; | 
 | ||||||
|     }; |     # These experiments are the extended versions of the previous | ||||||
|     gran = { |     # ones. We split them so we can keep a reasonable execution time | ||||||
|       node1 = callPackage ./creams/gran+node1.nix { }; |     big.granularity = granularity.override { enableExtended = true; }; | ||||||
|       node2 = callPackage ./creams/gran+node2.nix { }; |     big.ss = granularity.override { enableExtended = true; }; | ||||||
|       node4 = callPackage ./creams/gran+node4.nix { }; |  | ||||||
|       node8 = callPackage ./creams/gran+node8.nix { }; |  | ||||||
|       node16 = callPackage ./creams/gran+node16.nix { }; |  | ||||||
|     }; |  | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   hpcg = rec { |   hpcg = rec { | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user