CSCI 3366 (Introduction to Parallel and Distributed Processing), Spring 2005:
Homework 2

Assigned:
February 24, 2005.

Due:
March 10, 2005, at 11:59pm.

Credit:
30 points.

Overview

In class we briefly discussed approximating the value of $ \pi$ by ``throwing darts'' at a square of side 2 enclosing a circle of radius 1, counting how many darts fall within the circle, and then dividing that by the total number of darts to get the ratio between the area of the circle ($ \pi$) and the area of the square (4). For this assignment, your mission is to write, for each of the programming environments we've talked about (MPI, OpenMP, and Java), a parallel program that performs this calculation.

Details

Sequential starter programs

To get you started, I have written sequential programs in C and Java that perform the desired calculation and print appropriate results:

Start by downloading these two programs, compiling them, and running them a few times to get a sense of what inputs you need to get a good approximation of $ \pi$. Feel free to also tinker with the parts of the code that generate the sequence of random numbers; you may find some method you think will work better. (For the C program, review the man pages for random and drand48. For the Java program, review the API (``Java docs'') for the Random class.)

Parallel programs

The three programs you write (one each using MPI, OpenMP, and Java) should accept the same command-line input and produce the same output as my sequential programs, except that:

You can also make any changes you like to how the programs work internally.

It's up to you how you choose to parallelize the sequential code, but notice that in many respects the calculation here strongly resembles the one in the numerical integration example, so the approaches we used for that example might work well here too. The only thing that's tricky is deciding what to do about the random numbers (should all the processes/threads generate the same sequence of random numbers? should they generate different ones? if so, how?). For this assignment, I want you to make your best guess about what would be reasonable, implement that, and see how it works. In class next Thursday we will discuss your results and possible improvements.

You can make my grading job a bit easier by using the following names for your programs:

Hints and tips

As with the previous homework, feel free to borrow code from any of the sample programs linked from the course sample programs page. This page also contains links to my writeups about compiling and running programs on the lab machines. The course ``useful links'' page has pointers to documentation on MPI, OpenMP, and Java.

What to turn in and how

Submit your program source code (three files, one per language) by sending mail to bmassing@cs.trinity.edu, with each file as an attachment. Please use a subject line that mentions the course number and the assignment (e.g., ``csci 3366 homework 2''). You can develop your programs on any system that provides the needed functionality, but I will test it on one of the department's Fedora Core 2 Linux machines, so you should probably make sure they work in that environment before turning them in.



Berna Massingill
2005-03-09