Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
updates to smpi_bench and added smpi_calibration
[simgrid.git] / contrib / network_model / smpi_calibration.c
1 /**--------- <copy/paste C code snippet in surf/network.c> -------------
2   * produced by:
3   * ./regression2.py ./pingpong-in.dat 0.15 30 2 2.4e-5 1.25e8
4   * outliers: 66
5   * gnuplot: 
6     plot "./pingpong-in.dat" using 1:2 with lines title "data", \
7         (x >= 65472) ? 0.00850436*x+558.894 : \
8         (x >= 15424) ? 0.0114635*x+167.446 : \
9         (x >= 9376) ? 0.0136219*x+124.464 : \
10         (x >= 5776) ? 0.00735707*x+105.022 : \
11         (x >= 3484) ? 0.0103235*x+90.2886 : \
12         (x >= 1426) ? 0.0131384*x+77.3159 : \
13         (x >= 732) ? 0.0233927*x+93.6146 : \
14         (x >= 257) ? 0.0236608*x+93.7637 : \
15         (x >= 127) ? 0.0246645*x+94.0447 : \
16         (x >= 64) ? 0.037963*x+93.0877 : \
17         (x >= 0) ? 2.22507e-308*x+98.0633 : \
18         1.0 with lines title "piecewise function"
19   *-------------------------------------------------------------------*/
20
21 static double smpi_bandwidth_factor(double size)
22 {
23
24     if (size >= 65472) return 0.940694;
25     if (size >= 15424) return 0.697866;
26     if (size >= 9376) return 0.58729;
27     if (size >= 5776) return 1.08739;
28     if (size >= 3484) return 0.77493;
29     if (size >= 1426) return 0.608902;
30     if (size >= 732) return 0.341987;
31     if (size >= 257) return 0.338112;
32     if (size >= 127) return 0.324353;
33     if (size >= 64) return 0.210731;
34     if (size >= 0) return 3.59539e+305;
35     return 1.0;
36 }
37
38 static double smpi_latency_factor(double size)
39 {
40
41     if (size >= 65472) return 11.6436;
42     if (size >= 15424) return 3.48845;
43     if (size >= 9376) return 2.59299;
44     if (size >= 5776) return 2.18796;
45     if (size >= 3484) return 1.88101;
46     if (size >= 1426) return 1.61075;
47     if (size >= 732) return 1.9503;
48     if (size >= 257) return 1.95341;
49     if (size >= 127) return 1.95926;
50     if (size >= 64) return 1.93933;
51     if (size >= 0) return 2.04299;
52     return 1.0;
53 }
54
55 /**--------- <copy/paste C code snippet in surf/network.c> -----------*/