File: Bandwidth.java

package info (click to toggle)
mpj 0.44%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 7,600 kB
  • ctags: 6,809
  • sloc: java: 49,853; ansic: 2,508; xml: 596; sh: 311; perl: 156; makefile: 26
file content (140 lines) | stat: -rwxr-xr-x 3,826 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
package mpjdev.perftest;

import mpjdev.*;
import mpjbuf.*;
import java.io.*; 

public class Bandwidth {

  public Bandwidth() {
  }

  public Bandwidth(String[] args) throws Exception {

    MPJDev.init(args);
    int SEND_OVERHEAD = MPJDev.getSendOverhead() ; 
    int RECV_OVERHEAD = MPJDev.getRecvOverhead() ;
    Buffer buffer = null;
    Buffer rbuffer = null ; 
    byte[] byteArray = new byte[16*1024*1024] ;
    int WARM_UP = 10000 ;
    int REPEAT = 20000 ;
    int j = 1, i = 0;
    int LOG2N_MAX = 1000000, log2nbyte = 0, padding = 0;
    PrintStream out = null ;
    FileOutputStream fos = null ;
    long[] delays = new long[REPEAT];
    long[] latency = new long[REPEAT];
    long start= 0L, stop=0L, init = 0L;

    int me = MPJDev.WORLD.id() ; 

    if(me == 1) { 
      fos = new FileOutputStream("bw_delays.out");
      out = new PrintStream (fos);
    } 
    else { 
      fos = new FileOutputStream("bw.out");
      out = new PrintStream (fos);
    }

    /* Logrithmic Loop */
    for (log2nbyte = 0; log2nbyte <= LOG2N_MAX && j < 64*1024 ;
		    ++log2nbyte) {
	    
      j = (1 << log2nbyte);
	
      if ( ( (j / 8) > 1) && j % 8 != 0) {
        padding = j % 8;
      }
      else if ( ( (j / 8) == 0)) {
        padding = j;
      }
      else {
        padding = 0;
      }

      buffer = new Buffer(
                   BufferFactory.create(8+j+padding+SEND_OVERHEAD), 
		   SEND_OVERHEAD, 8+j+padding+SEND_OVERHEAD );
      buffer.putSectionHeader(Type.BYTE);
      buffer.write(byteArray, 0, j);
      buffer.commit();
      
      rbuffer = new Buffer( BufferFactory.create(8+j+padding+RECV_OVERHEAD),
			    RECV_OVERHEAD, 8+j+padding+RECV_OVERHEAD );

      /* Warm Up Loop */
      for (i = 0; i < WARM_UP; i++) {
        if (MPJDev.WORLD.id() == 0) {
          MPJDev.WORLD.recv(rbuffer, 1, j, true);
          MPJDev.WORLD.send(buffer, 1, j, true);
        }
        else if (MPJDev.WORLD.id() == 1) {
          MPJDev.WORLD.send(buffer, 0, j, true);
          MPJDev.WORLD.recv(rbuffer, 0, j, true);
        }
      }

     /* Latency Calculation Loop */
        for (i = 0; i < REPEAT; i++) {
          if (MPJDev.WORLD.id() == 0) {
            myDelay( (int) (Math.random() * 1000)) ;
            init = System.nanoTime() ;
            MPJDev.WORLD.send(buffer, 1, j, true);
            MPJDev.WORLD.recv(rbuffer, 1, j, true);
            latency[i] = ((System.nanoTime() - init)/1000) ;
          }
          else if (MPJDev.WORLD.id() == 1) {
            MPJDev.WORLD.recv(rbuffer, 0, j, true);
            start = System.nanoTime() ;
            myDelay( (int)(Math.random() * 1000));
            delays[i] = (System.nanoTime() - start)/1000 ;
            MPJDev.WORLD.send(buffer, 0, j, true);
          }
        }

	BufferFactory.destroy( buffer.getStaticBuffer());
	BufferFactory.destroy( rbuffer.getStaticBuffer());

        if(me == 0) {
          for(int k=WARM_UP; k<REPEAT ; k++) {
            out.println(latency[k]+"   ");
          }
        }

        else {
          for (i = WARM_UP ; i < REPEAT ; i++) {
            out.println(delays[i]+"   ");
          }
        }

        MPJDev.WORLD.barrier() ;
      } //end logrithmic loop

      MPJDev.finish();
  }

  static double tripsPerMS = 1000000 ;
  static int dummy ;

  static void myDelay(int us) {

    int trips = (int) (tripsPerMS * us) ;
    long start = System.nanoTime() ;

    for(int i = 0 ; i < trips ; i++) {
      dummy ++ ;
    }

    long actualDelay = System.nanoTime() - start ;

    if(actualDelay > 0 ) {
      long newTripsPerMS = (trips * 1000 ) / actualDelay ;

      if(newTripsPerMS > 0) {
        tripsPerMS = newTripsPerMS ;
      }
    } 
  } 
}