104 lines
3.2 KiB
Nix
104 lines
3.2 KiB
Nix
{
|
|
super
|
|
, self
|
|
, bsc
|
|
, garlic
|
|
, callPackage
|
|
}:
|
|
|
|
let
|
|
rPlot = garlic.pp.rPlot;
|
|
exp = garlic.exp;
|
|
pp = garlic.pp;
|
|
ds = garlic.ds;
|
|
fig = garlic.fig;
|
|
|
|
stdPlot = rScript: expList: rPlot {
|
|
script = rScript;
|
|
dataset = pp.mergeDatasets (map (e: ds.std.timetable e.result) expList);
|
|
};
|
|
|
|
customPlot = rScript: dataset: rPlot {
|
|
script = rScript;
|
|
dataset = dataset;
|
|
};
|
|
|
|
linkTree = name: tree: self.linkFarm name (
|
|
self.lib.mapAttrsToList (
|
|
name: value: { name=name; path=value; }
|
|
) tree);
|
|
in
|
|
{
|
|
nbody = with exp.nbody; {
|
|
baseline = stdPlot ./nbody/baseline.R [ baseline ];
|
|
small = stdPlot ./nbody/baseline.R [ small ];
|
|
jemalloc = stdPlot ./nbody/jemalloc.R [ baseline jemalloc ];
|
|
ctf = stdPlot ./nbody/baseline.R [ ctf ];
|
|
scaling = stdPlot ./nbody/baseline.R [ scaling ];
|
|
};
|
|
|
|
hpcg = with exp.hpcg; {
|
|
# /nix/store/8dr191vch1nw7vfz8nj36d5nhwnbdnf3-plot
|
|
ossGranularity = stdPlot ./hpcg/oss.granularity.R [ ossGranularity ];
|
|
|
|
# ossScalability = stdPlot ./hpcg/oss.scalability.R [ ossScalability ];
|
|
|
|
# /nix/store/a3x76fbnfbacn2xhz3q65fklfp0qbb6p-plot
|
|
ossWeakscalingPerAxisPerBlock = stdPlot ./hpcg/oss.slices.weakscaling.R [ ossSlicesWeakscaling ];
|
|
|
|
# /nix/store/pxf41v2c37h5fh5x8hm6dv297hkdka04-plot
|
|
ossStrongscalingPerBlock = stdPlot ./hpcg/oss.slices.strongscaling.R [ ossSlicesStrongscaling ];
|
|
};
|
|
|
|
saiph = with exp.saiph; {
|
|
granularity = stdPlot ./saiph/granularity.R [ granularity ];
|
|
ss = stdPlot ./saiph/ss.R [ ss ];
|
|
};
|
|
|
|
heat = with exp.heat; {
|
|
granularity = stdPlot ./heat/granularity.R [ granularity ];
|
|
cache = customPlot ./heat/cache.R (ds.perf.stat cache.result);
|
|
ctf = customPlot ./heat/mode.R (ds.ctf.mode ctf.result);
|
|
};
|
|
|
|
creams = with exp.creams; {
|
|
ss = stdPlot ./creams/ss.R [ ss ];
|
|
granularity = stdPlot ./creams/granularity.R [ granularity ];
|
|
|
|
# Extended version (we could use another R script for those plots
|
|
big.ss = stdPlot ./creams/ss.R [ big.ss ];
|
|
big.granularity = stdPlot ./creams/granularity.R [ big.granularity ];
|
|
};
|
|
|
|
fwi = with exp.fwi; {
|
|
granularity = stdPlot ./fwi/granularity.R [ granularity ];
|
|
reuse = stdPlot ./fwi/granularity.R [ reuse ];
|
|
ss = stdPlot ./fwi/ss.R [ ss ];
|
|
io = stdPlot ./fwi/io.R [ io ];
|
|
};
|
|
|
|
osu = with exp.osu; {
|
|
latency = customPlot ./osu/latency.R (ds.osu.latency latency.result);
|
|
latencyShm = customPlot ./osu/latency.R (ds.osu.latency latencyShm.result);
|
|
latencyMt = customPlot ./osu/latency.R (ds.osu.latency latencyMt.result);
|
|
latencyMtShm = customPlot ./osu/latency.R (ds.osu.latency latencyMtShm.result);
|
|
|
|
bw = customPlot ./osu/bw.R (ds.osu.bw bw.result);
|
|
bwShm = customPlot ./osu/bw.R (ds.osu.bw bwShm.result);
|
|
impi = customPlot ./osu/impi.R (ds.osu.bw impi.result);
|
|
mtu = customPlot ./osu/mtu.R (ds.osu.bw mtu.result);
|
|
eager = customPlot ./osu/eager.R (ds.osu.bw eager.result);
|
|
};
|
|
|
|
# The figures used in the article contained in a directory per figure
|
|
article = with fig; linkTree "article-fig" {
|
|
"osu/latency" = osu.latency;
|
|
"osu/bw" = osu.bw;
|
|
"osu/mtu" = osu.mtu;
|
|
};
|
|
|
|
examples = with exp.examples; {
|
|
granularity = stdPlot ./examples/granularity.R [ granularity ];
|
|
};
|
|
}
|