MPI.NET Tutorial
In this post I will show step by step how to install and execute MPI (Message Passing Interface) parallel programs in the .NET environment.
A much more detailed tutorial is available here.
1) Installation:
My computer is running Windows Vista and Visual Studio 2008 is already installed.
Download and install the HPC Pack 2008 (next 5 figures):
data:image/s3,"s3://crabby-images/b6d67/b6d672eb412bcce9af4c5f897ce7fd95bf13c7f7" alt=""
data:image/s3,"s3://crabby-images/c212c/c212cb551e0fc00388db04581095ab455555e4f5" alt=""
data:image/s3,"s3://crabby-images/9d0a6/9d0a6138cd6ccbc728b20056129114120189728f" alt=""
data:image/s3,"s3://crabby-images/55aac/55aacc221790325ea7a0fa4f895a5a729b20e997" alt=""
data:image/s3,"s3://crabby-images/ab593/ab593fe96b46d6157f5e16feb7b0cc54cae7683f" alt=""
Then install the MPI.NET SDK.msi (see next 4 figures):
data:image/s3,"s3://crabby-images/58bb4/58bb44e033644aef97d65e010109cc2d8c29c603" alt=""
data:image/s3,"s3://crabby-images/5fe76/5fe762937d893929df41c09334abac38aaad8366" alt=""
data:image/s3,"s3://crabby-images/c2359/c2359c452f530eaee99c2fb87b61e539ec170dbc" alt=""
data:image/s3,"s3://crabby-images/cebef/cebef225f8182ee8e6fdeb91ae0138976e5cbed0" alt=""
2) Test the installation from the command line (next 3 figures):
A "Ping-Pong" program
Serial run:
data:image/s3,"s3://crabby-images/837a9/837a99cf40950672fff5cca580a89e74df5dd921" alt=""
As should be, the firewall detects the communication traffic and the user should allow it:
data:image/s3,"s3://crabby-images/48518/4851808f553ba766d8efee900bec469f83159bcf" alt=""
Parallel run:
data:image/s3,"s3://crabby-images/44bad/44bad5c61e58a2e5d0311af4f8579740a79fa52a" alt=""
3) MPI "Hello" demo using Visual Studio 2008 and C# (next 5 figures):
Start a new console C# project:
data:image/s3,"s3://crabby-images/2f185/2f1853be798085486cf06380215150ed30ba7787" alt=""
Add Reference to the MPI component:
Build the executable:
data:image/s3,"s3://crabby-images/15398/153987c8b0e8becc251aec364edf38be7bfc0599" alt=""
Execute the parallel program with 8 threads:
Verifying the execution of the 8 threads by looking at the Task Manager:
data:image/s3,"s3://crabby-images/ddfb8/ddfb8e4e73d56e6ad7aac0894fa0f48204e7aa6c" alt=""
That's all for now.
Your comments are welcome.
Guy Tel-Zur
Email: tel-zur@computer.org
A much more detailed tutorial is available here.
1) Installation:
My computer is running Windows Vista and Visual Studio 2008 is already installed.
Download and install the HPC Pack 2008 (next 5 figures):
data:image/s3,"s3://crabby-images/b6d67/b6d672eb412bcce9af4c5f897ce7fd95bf13c7f7" alt=""
data:image/s3,"s3://crabby-images/c212c/c212cb551e0fc00388db04581095ab455555e4f5" alt=""
data:image/s3,"s3://crabby-images/9d0a6/9d0a6138cd6ccbc728b20056129114120189728f" alt=""
data:image/s3,"s3://crabby-images/55aac/55aacc221790325ea7a0fa4f895a5a729b20e997" alt=""
data:image/s3,"s3://crabby-images/ab593/ab593fe96b46d6157f5e16feb7b0cc54cae7683f" alt=""
Then install the MPI.NET SDK.msi (see next 4 figures):
data:image/s3,"s3://crabby-images/58bb4/58bb44e033644aef97d65e010109cc2d8c29c603" alt=""
data:image/s3,"s3://crabby-images/5fe76/5fe762937d893929df41c09334abac38aaad8366" alt=""
data:image/s3,"s3://crabby-images/c2359/c2359c452f530eaee99c2fb87b61e539ec170dbc" alt=""
data:image/s3,"s3://crabby-images/cebef/cebef225f8182ee8e6fdeb91ae0138976e5cbed0" alt=""
2) Test the installation from the command line (next 3 figures):
A "Ping-Pong" program
Serial run:
data:image/s3,"s3://crabby-images/837a9/837a99cf40950672fff5cca580a89e74df5dd921" alt=""
As should be, the firewall detects the communication traffic and the user should allow it:
data:image/s3,"s3://crabby-images/48518/4851808f553ba766d8efee900bec469f83159bcf" alt=""
Parallel run:
data:image/s3,"s3://crabby-images/44bad/44bad5c61e58a2e5d0311af4f8579740a79fa52a" alt=""
3) MPI "Hello" demo using Visual Studio 2008 and C# (next 5 figures):
Start a new console C# project:
data:image/s3,"s3://crabby-images/2f185/2f1853be798085486cf06380215150ed30ba7787" alt=""
Add Reference to the MPI component:
data:image/s3,"s3://crabby-images/a55c1/a55c17e7ddc746070f99801a804dbc9d555cdedf" alt=""
data:image/s3,"s3://crabby-images/15398/153987c8b0e8becc251aec364edf38be7bfc0599" alt=""
Execute the parallel program with 8 threads:
data:image/s3,"s3://crabby-images/fe54f/fe54fb79bea2cb86de7712d1fcf5b678ae676590" alt=""
data:image/s3,"s3://crabby-images/ddfb8/ddfb8e4e73d56e6ad7aac0894fa0f48204e7aa6c" alt=""
That's all for now.
Your comments are welcome.
Guy Tel-Zur
Email: tel-zur@computer.org
Comments