⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 buffertest7.java

📁 MPI for java for Distributed Programming
💻 JAVA
字号:
package mpjdev.buffertest;

import mpjdev.*;
import mpjbuf.*;

/**
 * This checks the gathering/scattering of the Java objects.
 */
public class BufferTest7 {
  public static void main(String args[]) throws Exception {
  }

  public BufferTest7() {
  }

  public BufferTest7(String[] args) throws Exception {
	  
    String[] nargs = new String[args.length+1];	  
    System.arraycopy(args,0,nargs,0,args.length);
    nargs[args.length] = this.toString();	  
    MPJDev.init(args);

    int indexes[] = {
        2, 4, 6, 8, 12, 14, 16, 18, 22, 24, 26, 28, 32, 34, 36, 38, 42, 44, 46,
        48, 52, 54, 56, 58,
        62, 64, 66, 68, 72, 74, 76, 78, 82, 84, 86, 88, 92, 94, 96, 98};

    int id = MPJDev.WORLD.id();
    int size = MPJDev.WORLD.size();

    if(size > 2) {
      if(id == 1)
        System.out.println("BufferTest7: Must run with 2 tasks!");      
      MPJDev.finish();
      return;
    }

    int SEND_OVERHEAD = MPJDev.getSendOverhead() ;
    int RECV_OVERHEAD = MPJDev.getRecvOverhead() ; 

    java.util.Vector vector1 = null;
    java.util.Vector vector = new java.util.Vector();

    for (int k = 0; k < 10; k++) {
      vector.add("" + k);
    }
    if (MPJDev.WORLD.id() == 0) {

      Object[] source = new Object[100];

      for (int k = 0; k < source.length; k++) {
        source[k] = vector;
      }

      Buffer writeBuffer = new Buffer( 
                 BufferFactory.create(8 + SEND_OVERHEAD),
		 SEND_OVERHEAD, 8+ SEND_OVERHEAD );

      writeBuffer.putSectionHeader(Type.OBJECT);
      writeBuffer.gather(source, 40, 0, indexes);
      writeBuffer.commit();
      MPJDev.WORLD.send(writeBuffer, 1, 992, true);
      //System.out.println("Send Completed");
      writeBuffer.clear();

      BufferFactory.destroy(writeBuffer.getStaticBuffer() );
    
    }
    else if (MPJDev.WORLD.id() == 1) {

      Buffer readBuffer = new Buffer(
                 BufferFactory.create(8 + RECV_OVERHEAD),
		 RECV_OVERHEAD, 8+ RECV_OVERHEAD );
      
      Object[] source = new Object[100];

      for (int k = 0; k < source.length; k++) {
        source[k] = null;
      }

      MPJDev.WORLD.recv(readBuffer, 0, 992, true);
      readBuffer.commit();
      readBuffer.getSectionHeader();
      int els = readBuffer.getSectionSize();
      
      //System.out.println(" els " + els);

      try {
        readBuffer.scatter(source, 40, 0, indexes);
        //System.out.println("Receive Completed ");
      }
      catch (Exception e) {
        e.printStackTrace();
      }

      BufferFactory.destroy(readBuffer.getStaticBuffer() );
      
      System.out.println("BufferTest7 TEST Completed (?)");
/*
      for (int j = 0; j < source.length; j++) {
        System.out.println("source[" + j + "] :: " + source[j]);
      }
*/      

    } 
    
    //This should be the last call, in order to finish the communication
 //try {   MPJDev.WORLD.barrier(); }catch(Exception e){}
    MPJDev.finish();
  }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -