我是MPJ的新手,这是一个用Java开发基于MPI的程序的API。我写了一个简单的代码如下:
import mpi.MPI;
import mpi.Status;
public class Send {
public static void main(String[] args) throws Exception
{
MPI.Init(args);
int rank = MPI.COMM_WORLD.Rank();
int size = MPI.COMM_WORLD.Size();
int peer;
int buffer[] = new int[10];
int len = 1;
int dataToBeSent = 99;
int tag = 100;
if(rank == 0)
{
buffer[0] = dataToBeSent;
peer = 1;
MPI.COMM_WORLD.Send(buffer, 0, len, MPI.INT, peer, tag);
System.out.println("process <"+rank+"> sent a msg to process <"+peer+">");
}
else if(rank == 1)
{
peer = 0 ;
Status status = MPI.COMM_WORLD.Recv(buffer, 0, buffer.length, MPI.INT, peer, tag);
System.out.println("process <"+rank+"> recv'ed a msg\n"+ "\tdata <"+buffer[0]+"> \n"+"\tsource <"+status.source+"> \n"+"\ttag<"+status.tag+"> \n"+"\tcount <"+status.count +">");
}
MPI.Finalize();
}
}
编译时,我收到以下错误:
Exception in thread "main" java.lang.UnsupportedClassVersionError: mpi/MPI : Unsupported major.minor version 51.0
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:620)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:124)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:260)
at java.net.URLClassLoader.access$000(URLClassLoader.java:56)
at java.net.URLClassLoader$1.run(URLClassLoader.java:195)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:276)
at java.lang.ClassLoader.loadClass(ClassLoader.java:251)
at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:319)
at Send.main(Send.java:7)
Java Result: 1
要解决此问题,我发现我的JDK和JRE版本必须相同。执行以下命令后,我发现它们是相同的,没有区别:
C:\Users\Dev>javac -version
javac 1.6.0
C:\Users\Dev>java -version
java version "1.6.0"
Java(TM) SE Runtime Environment (build 1.6.0-b105)
Java HotSpot(TM) Client VM (build 1.6.0-b105, mixed mode, sharing)
在Ubuntu Java 8中,我得到以下异常:
Exception in thread "main" mpi.MPIException: Usage: java MPI <myrank> <conf_file> <device_name> conf_file can be, ../conf/xdev.conf <Local>OR http://holly.dsg.port.ac.uk:15000/xdev.conf <Remote>
at mpi.MPI.Init(MPI.java:233)
at mpi.MPI.Init(MPI.java:233) at mpi.MPI.Init(MPI.java:233)
at Send.main(Send.java:7)
Java Result: 1
如何解决此问题并使用Java在我的系统上运行MPI?
答案 0 :(得分:0)
这是一个古老的问题,但是我想我可以总结一下这里发生的情况,因为我自己使用了这个库。
您获得的编译错误“不支持的major.minor版本51.0”表明您用于运行程序的Java版本太旧。程序的某些部分很可能是使用Java的较新版本编译的。可能是您下载的MPJ库?
当您尝试使用Java 8运行程序时,实际上是您自己解决了这个问题!但是,正如您在问题的后半部分正确确定的那样,程序参数仍然有问题。 MPJ-express主程序需要一些特定的参数才能知道要启动多少个进程。如果没有这些参数,则会出现错误Exception in thread "main" mpi.MPIException: Usage: java MPI <myrank> <conf_file> <device_name>
基本上,MPJ-Express库带有许多小脚本,这些小脚本将为您安排MPI特定的参数。根据您要使用的模式(多核/群集),脚本和过程将有所不同。所有详细信息均在以下页面上的指南中进行了说明:http://mpj-express.org/guides.html。如果您使用的是这种方式,则还可以从Eclipse IDE中启动程序。