File: RingTest.java

package info (click to toggle)
mpj 0.44%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, buster, forky, sid, trixie
  • size: 7,592 kB
  • sloc: java: 49,853; ansic: 2,508; xml: 596; sh: 311; perl: 156; makefile: 27
file content (106 lines) | stat: -rwxr-xr-x 3,375 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
package misc; 

import mpjdev.*;
import mpjbuf.*;



public class RingTest {
  public RingTest() {
  }
  public RingTest(String[] args) throws Exception {

    int num, rank, size, tag, next, from;
    Buffer wBuffer = null;
    Buffer rBuffer = null;
    int[] sendArray = new int[1];
    int[] recvArray = new int[1];
    MPJDev.init(args);
    size = MPJDev.WORLD.size();
    rank = MPJDev.WORLD.id();
    tag = 100;
    next = (rank + 1) % size;
    from = (rank + size - 1) % size;

    if (rank == 0) {
      num = 100000;
      System.out.println("Process " + rank + " sending " + num + " to " + next +
                         " with tag " + tag * (rank + 100));
      wBuffer = new Buffer(8 + 8);
      sendArray = new int[1];
      sendArray[0] = num;
      wBuffer.putSectionHeader(Buffer.INT);
      wBuffer.write(sendArray, 0, 1);
      wBuffer.commit();
      MPJDev.WORLD.send(wBuffer, next, tag * (rank + 100));
      wBuffer.clear();
      System.out.println("Process " + rank + " sent " + num + " to " + next +
                         " with tag " + tag * (rank + 100));
    }

    do {
      System.out.println("Process " + rank + " receiving from " + from +
                         " with tag " + tag * (from + 100));
      rBuffer = new Buffer(8 + 8);
      MPJDev.WORLD.recv(rBuffer, from, tag * (from + 100));
      rBuffer.commit();
      rBuffer.getSectionHeader(Buffer.INT);
      rBuffer.read(recvArray, 0, 1);
      rBuffer.clear();
      num = recvArray[0];
      System.out.println("Process " + rank + " received " + num + " from " +
                         from + " with tag " + tag * (from + 100));

      if (rank == 0) {
        --num;
        System.out.println("Process 0 decremented num from" + (num + 1) +
                           " to " + num);
      }

      System.out.println("Process " + rank + " sending " + num + " to " + next +
                         " with tag " + tag * (rank + 100));
      wBuffer = new Buffer(8 + 8);
      wBuffer.putSectionHeader(Buffer.INT);
      sendArray = new int[1];
      sendArray[0] = num;
      wBuffer.write(sendArray, 0, 1);
      wBuffer.commit();
      MPJDev.WORLD.send(wBuffer, next, tag * (rank + 100));
      wBuffer.clear();
      System.out.println("Process " + rank + " sent " + num + " to " + next +
                         " with tag " + tag * (rank + 100));
    }
    while (num > 0);

    System.out.println("Process " + rank + " exiting ...");

    if (rank == 0) {
      System.out.println("Process " + rank + " receiving from " + from +
                         " with tag " + tag * (from + 100));
      rBuffer = new Buffer(8 + 8);
      MPJDev.WORLD.recv(rBuffer, from, tag * (from + 100));
      rBuffer.commit();
      rBuffer.getSectionHeader(Buffer.INT);
      rBuffer.read(recvArray, 0, 1);
      rBuffer.clear();
      num = recvArray[0];
      System.out.println("Process " + rank + " received " + num + " from " +
                         from + " with tag " + tag * (from + 100));
    }

    //System.out.println("Sleeping");
    //try { Thread.currentThread().sleep(10000); }catch(Exception e){}
    //System.out.println("Slept");
    //MPJDev.WORLD.nbarrier();
    MPJDev.finish();
  }

  public static void main(String args[]) {
    try {
      RingTest ringTest = new RingTest(args);
    }
    catch (Exception e) {
      e.printStackTrace();
    }
  }
}