Parallel Computing on Windows
There are many ways to use MPI. In this post I show how to install and use the DeinoMPI implementation which looks very cool and is free.
The screen captures in this post were taken using the nice SnapIt tool.
Part 1: Installing DeinoMPI
After downloading and starting the msi file:
data:image/s3,"s3://crabby-images/e3531/e353114c29d821eeee9c98b7103fe4939a7b34c1" alt=""
data:image/s3,"s3://crabby-images/584b1/584b1fe0c01ebddbfcea789b18d5db2b186e4fd5" alt=""
data:image/s3,"s3://crabby-images/1e730/1e730008a51ddc6b7f93ff120cec37dfdd170611" alt=""
data:image/s3,"s3://crabby-images/adf39/adf398ac5dadae02bbce06f1c9e4f2011067c782" alt=""
data:image/s3,"s3://crabby-images/bbb99/bbb99d5e5e9be636ac16f52f2102f6107ab5faf6" alt=""
data:image/s3,"s3://crabby-images/ac667/ac667ec0f00ccbd62b908e3d12251921c932e0b4" alt=""
Part 2: Configuring DeinoMPI
2.1 Start the deinoMPI daemon:
data:image/s3,"s3://crabby-images/e45fd/e45fdb04726451f46a6f247bb79a2b72fb9835b6" alt=""
2.2 Credentials
data:image/s3,"s3://crabby-images/0c227/0c2278411af73d1839caba8286926220bb9d2b61" alt=""
Part 3: Testing
In this part I show how to compile a MPI program with the free Bloodshed DevC++ IDE.
I use the famous cpi.c code
data:image/s3,"s3://crabby-images/f3e3e/f3e3e7ae7f26b6e6e1f93dc2313006f6b8051647" alt=""
This installation is "Local Only" (perhaps in one of my future posts I will show how to use this tool with more than one node):
data:image/s3,"s3://crabby-images/fca68/fca680b2860ee8cbc9df2f6ddb22c1eaf10b34fc" alt=""
The Windows Firewall is noticing the new player:
data:image/s3,"s3://crabby-images/c8bb1/c8bb19d927782790d0f65c33cd9c42207e228ba8" alt=""
Here is the execution and output window:
data:image/s3,"s3://crabby-images/86c32/86c32c126004d459d644ee1e36d7cb6bcfebd525" alt=""
It is nice to see the Task Manager showing the 10 parallel running processes:
data:image/s3,"s3://crabby-images/ac399/ac399a2f57f5e575f72ef8c3328eb5c92b9e4d1f" alt=""
Part 4: A little-bit Mathematics
The integration in cpi.c is done for f(x)=1/(1+x**2) between 0 to 1.
It is nice to replace this function by f(x)=sqrt(1-x**2) also between 0 to 1 (the unit circle).
Strangely enough, integration of either of these functions between 0 to 1 is equal to Pi/4.
The Sage Symbolic Mathematics tool is a good way to show the difference between the two functions:
The screen captures in this post were taken using the nice SnapIt tool.
Part 1: Installing DeinoMPI
After downloading and starting the msi file:
data:image/s3,"s3://crabby-images/e3531/e353114c29d821eeee9c98b7103fe4939a7b34c1" alt=""
data:image/s3,"s3://crabby-images/584b1/584b1fe0c01ebddbfcea789b18d5db2b186e4fd5" alt=""
data:image/s3,"s3://crabby-images/1e730/1e730008a51ddc6b7f93ff120cec37dfdd170611" alt=""
data:image/s3,"s3://crabby-images/adf39/adf398ac5dadae02bbce06f1c9e4f2011067c782" alt=""
data:image/s3,"s3://crabby-images/bbb99/bbb99d5e5e9be636ac16f52f2102f6107ab5faf6" alt=""
data:image/s3,"s3://crabby-images/ac667/ac667ec0f00ccbd62b908e3d12251921c932e0b4" alt=""
Part 2: Configuring DeinoMPI
2.1 Start the deinoMPI daemon:
data:image/s3,"s3://crabby-images/e45fd/e45fdb04726451f46a6f247bb79a2b72fb9835b6" alt=""
2.2 Credentials
data:image/s3,"s3://crabby-images/0c227/0c2278411af73d1839caba8286926220bb9d2b61" alt=""
Part 3: Testing
In this part I show how to compile a MPI program with the free Bloodshed DevC++ IDE.
I use the famous cpi.c code
data:image/s3,"s3://crabby-images/f3e3e/f3e3e7ae7f26b6e6e1f93dc2313006f6b8051647" alt=""
This installation is "Local Only" (perhaps in one of my future posts I will show how to use this tool with more than one node):
data:image/s3,"s3://crabby-images/fca68/fca680b2860ee8cbc9df2f6ddb22c1eaf10b34fc" alt=""
The Windows Firewall is noticing the new player:
data:image/s3,"s3://crabby-images/c8bb1/c8bb19d927782790d0f65c33cd9c42207e228ba8" alt=""
Here is the execution and output window:
data:image/s3,"s3://crabby-images/86c32/86c32c126004d459d644ee1e36d7cb6bcfebd525" alt=""
It is nice to see the Task Manager showing the 10 parallel running processes:
data:image/s3,"s3://crabby-images/ac399/ac399a2f57f5e575f72ef8c3328eb5c92b9e4d1f" alt=""
Part 4: A little-bit Mathematics
The integration in cpi.c is done for f(x)=1/(1+x**2) between 0 to 1.
It is nice to replace this function by f(x)=sqrt(1-x**2) also between 0 to 1 (the unit circle).
Strangely enough, integration of either of these functions between 0 to 1 is equal to Pi/4.
The Sage Symbolic Mathematics tool is a good way to show the difference between the two functions:
data:image/s3,"s3://crabby-images/dd2e5/dd2e55d329b1335e7209fd976c71d2d321209d80" alt=""
Comments