| CMSC 201Programming Project Two
 
Oil Spill Simulation
 Out: Monday 3/5/07Due: Before Midnight, Sunday 3/25/07
 
The design document for this project,
 design2.txt , is due: Before Midnight, Sunday 3/11/07
 | 
Objective
The objective of this assignment is to give you practice with project and 
function design.  It will also give you an opportunity to work with random
numbers, two-dimensional arrays, passing arrays to functions, and using
separate compilation.
Description of the Oil Spill and Simulation
Your program will simulate an oil spill involving 8,000 gallons of crude oil
and the movement of that oil over time under certain conditions. You will run 
the simulation over a 225 square mile area, a 15 mile X 15 mile square.
You must keep track of the number of gallons of oil that are present on the 
surface of each square mile.  The number of gallons in a particular square-mile
location will vary over time due to environmental factors, i.e. the tides,
wind, etc.  For this simulation we will be concerned only with the effects of
the wind on the oil spill.
If the wind is from the west, then the oil in a particular location will be
pushed primarily to the east, affecting the neighboring areas to the north,
north-east, east, south-east and south. Some portion of the oil will stay 
within the original square-mile area.  Obviously the area to the east will
get the largest influx of oil.  Over time, the spill will shift significantly
to the east.
The integer time interval value is the number of time intervals that should 
pass between displaying the values for each square-mile area.  The total time
is the amount of time for the entire simulation.
The wind direction is to be chosen randomly, by getting a random number 
between 1 and 4, where 1 is West, 2 is North, 3 is East and 4 is South.  You
should use a call to time() to seed the random number generator.  We will 
assume a constant wind velocity so that you do not need to consider any
fluctuations in your calculations.
More details
- To begin, you will need to read in the data from the data file, 
oilspill.dat, which includes the viewing time interval and the total time of 
the simulation, followed by 225 integer values separated by whitespace that
represent the original number of gallons per square mile area.  You will use 
unix redirection to read in the contents of this file.  There will be little 
difference in the way you write your program to do the input.  You will use 
calls to the function scanf() as you normally would to read in integers, 
however, since the user won't be entering the data (it will be the contents of 
a file instead), there is no need to prompt the user for the values.  To
use unix redirection you will run your program like this 
 a.out < oilspill.dat
The file oilspill.dat shown below is just one of many files that we may use to 
test your program.  We have files with different time intervals, total times, 
and different original concentrations of oil that may be used to test your 
program.  So oilspill.dat is just a sample data file provided for your use. 
You may assume that none of the integers found in any of the files used for 
testing your program will be larger than 3 digits.  We guarantee that there 
are exactly 227 non-negative integers in each of the test files.
 Here is the contents of oilspill.dat:
 
 5
   15
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0 500 500 500 500   0   0   0   0   0
   0   0   0   0   0   0 500 500 500 500   0   0   0   0   0
   0   0   0   0   0   0 500 500 500 500   0   0   0   0   0
   0   0   0   0   0   0 500 500 500 500   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
You will be reading the 225 initial oil values found in the file into a 
two-dimensional array.  This array will then hold the original number of 
gallons found in each square-mile area at the time of the spill.
 
 
- For each unit of time, the amount of oil in each square-mile area must be
recalculated.  We will chose the wind direction W for the explanation of the
calculations.  The original amount of oil in the square will be reduced by 50%,
because that much will be pushed by the wind into some of it's neighboring
squares (mostly easterly).  At the same time, however, more oil will be pushed 
into the area from some of its more westerly neighbors.
For a west wind, the square and its surrounding squares will be affected as 
follows:
 Percentage of original                Example using # of gallons
Time 0:           Time 1:              Time 0:            Time 1:
    |    |           | 5% | 10%           0|   0|   0        0|  10|  20
----+----+----   ----+----+----        ----+----+----     ----+----+----
    |100%|           | 50%| 20%           0| 200|   0        0| 100|  40
----+----+----   ----+----+----        ----+----+----     ----+----+----
    |    |	     | 5% | 10%           0|   0|   0        0|  10|  20
Winds from other directions will cause similar effects on their neighboring 
squares using the same percentages.
- If you view the results of the simulation after each unit of time, the
movement of the oil is less noticeable than if you wait for several time units
before viewing.  Since the user needs to see and interpret the results of the 
simulation, we have chosen a time interval of 5 (5 time units will pass before 
you show him the next results) and a total time of 15 (how long a period of 
time to run the simulation).  
 
- Hints
- Be aware that the diagrams of oil movement shown above are the
simplest case, where there was no oil originally in any of the neighboring
squares.  Each square mile that contains oil will lose oil in the fashion 
indicated, but each square mile may also have an influx of oil from its 
neighboring squares.
- Since every square may be altered by its neighbors, and you must use the
original values of each square for the calculations, you cannot just move 
through the array making changes as you go.  This would give erroneous results.
A second two-dimensional array needs to be made that will hold the new amounts
of oil that are being calculated for each square, while the original array is
still intact to provide the values needed for the calculations.
 
A Sample Run 
linux1[102] a.out < oilspill.dat
Time interval : 5
Total time : 15
Wind direction : From the West
Time: 0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0 500 500 500 500   0   0   0   0   0
   0   0   0   0   0   0 500 500 500 500   0   0   0   0   0
   0   0   0   0   0   0 500 500 500 500   0   0   0   0   0
   0   0   0   0   0   0 500 500 500 500   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
Time: 5
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   3   6   8   7   4   1   0
   0   0   0   0   0   0   1  10  28  43  47  39  20   5   0
   0   0   0   0   0   0   9  49 108 149 153 114  56  15   1
   0   0   0   0   0   0  28 116 229 303 299 213 100  26   3
   0   0   0   0   0   0  36 154 305 402 396 282 130  34   3
   0   0   0   0   0   0  36 154 305 402 396 282 130  34   3
   0   0   0   0   0   0  28 116 229 303 299 213 100  26   3
   0   0   0   0   0   0   9  49 108 149 153 114  56  15   1
   0   0   0   0   0   0   1  10  28  43  47  39  20   5   0
   0   0   0   0   0   0   0   0   3   6   8   7   4   1   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
Time: 10
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   2   5   6   5   3
   0   0   0   0   0   0   0   0   1   7  15  23  26  21  13
   0   0   0   0   0   0   0   1  10  28  51  69  71  57  35
   0   0   0   0   0   0   0   6  28  67 114 145 144 113  68
   0   0   0   0   0   0   1  13  49 114 186 231 226 173 102
   0   0   0   0   0   0   2  17  65 146 235 289 280 213 124
   0   0   0   0   0   0   2  17  65 146 235 289 280 213 124
   0   0   0   0   0   0   1  13  49 114 186 231 226 173 102
   0   0   0   0   0   0   0   6  28  67 114 145 144 113  68
   0   0   0   0   0   0   0   1  10  28  51  69  71  57  35
   0   0   0   0   0   0   0   0   1   7  15  23  26  21  13
   0   0   0   0   0   0   0   0   0   0   2   5   6   5   3
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
Time: 15
   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0   0   0   0   0   0   0   0   0   0   0   0   1   2
   0   0   0   0   0   0   0   0   0   0   1   3   8  11  12
   0   0   0   0   0   0   0   0   0   1   6  15  26  34  36
   0   0   0   0   0   0   0   0   0   5  18  38  59  74  75
   0   0   0   0   0   0   0   0   2  13  37  72 107 129 128
   0   0   0   0   0   0   0   0   5  22  57 106 155 185 180
   0   0   0   0   0   0   0   0   7  28  71 129 187 220 213
   0   0   0   0   0   0   0   0   7  28  71 129 187 220 213
   0   0   0   0   0   0   0   0   5  22  57 106 155 185 180
   0   0   0   0   0   0   0   0   2  13  37  72 107 129 128
   0   0   0   0   0   0   0   0   0   5  18  38  59  74  75
   0   0   0   0   0   0   0   0   0   1   6  15  26  34  36
   0   0   0   0   0   0   0   0   0   0   1   3   8  11  12
   0   0   0   0   0   0   0   0   0   0   0   0   0   1   2
linux1[103] 
The data files
The sample data file for this project is called oilspill.dat and it is found 
in my pub directory.  You should copy this file into your own directory.  The 
executable and this data file need to be in the same directory.  Here's how:
Change directory until you are in the directory where you will write your code
and have the executable, then type the following command at the unix prompt.
cp /afs/umbc.edu/users/b/o/bogar/pub/oilspill.dat .
The space and the dot at the end of this command are an important part of the 
command itself.  It means that the file indicated as the source is to be copied
into your current working directory and have the same name as the original, in 
this case, oilspill.dat
util.c & util.h
You should start to build and keep a util.c and util.h file that contain 
utility functions and their prototypes, respectively.  Functions that you keep
in this file should be modules that can be used by many projects.  You should 
continue to add functions to these files as the semester progresses.  The 
functions GetPositiveValue() and ConvertDegreesToRadians() would be good 
functions from project 1 to put in the util.c file.  GetValidInt(), 
SetRandomSeed() and GetRandomNumber() from the lecture notes would also be
good to add to the files.  There are some functions that deal with 2-D integer 
arrays that you'll be writing for this project that could be reused and, as 
such, should be in util.c.
  
What to Turn In
 
You must use separate compilation for this project and should have a file, 
called proj2.c, that contains the function main().
You should have an oilspill.c and oilspill.h, that contain the functions 
related to an oilspill used by proj2.c and the prototypes for those functions, 
respectively.  
You should also have a util.c and a util.h, that contain utility functions 
that could be reused by many other projects and the prototypes for those 
functions, respectively.  
Submit as follows:
submit cs201 Proj2 proj2.c oilspill.c oilspill.h util.c util.h
The order in which the files are listed doesn't matter.  However, you
must make sure that all files necessary to compile your
project are listed.