The variance of a set of  numbers
 numbers
 is defined to be the sum
 is defined to be the sum
 
 is the average of
 is the average of 
 .1
.1
For this assignment, you are to write a multi-threaded program to compute the variance of a set of numbers. The textbook discusses using multiple threads to speed up the calculation of the sum of a set of numbers; it is not difficult to extrapolate from this discussion to an approach for using multiple threads to speed up calculating the variance of a set of numbers, if you break down the calculation into two steps:
Your program should take two command-line arguments:
 ).  
	This argument is required.
).  
	This argument is required.
 ).  
	This argument is optional.
).  
	This argument is optional.
 ),
	it should read its input numbers from standard input,
	continuing to read until end-of-file is encountered.
	It should accept any number of input numbers.
	Floating-point inputs are okay.
),
	it should read its input numbers from standard input,
	continuing to read until end-of-file is encountered.
	It should accept any number of input numbers.
	Floating-point inputs are okay.
 and
 and
	 ), it should generate
), it should generate  input numbers using any reasonable
	technique for generating random numbers.
 input numbers using any reasonable
	technique for generating random numbers.
In either case, once it has read or generated its input numbers, the program should compute their variance and print the following output:
You can write your program either (i) in C++ with the POSIX threads library functions or (ii) in Java using Java's built-in support for multi-threading. Whichever language you use, be sure your program compiles and executes correctly on the department's Linux machines.
So that you do not have to write the tedious and non-parallel parts of this program, I am providing a sequential program that performs the required calculations.
Once you have confirmed that your program is operating correctly
(for small numbers of inputs), try running it for a large number
of generated inputs and varying values of  (number of threads).
Record at least half a dozen observations (different combinations
of
 (number of threads).
Record at least half a dozen observations (different combinations
of  and
 and  ) to see how running time varies with these two
variables.  Also record which machine you performed these experiments
on.  You may find it interesting to see whether multi-threading can
help even if you have more threads than processors.
FYI, machines known to have multiple processors include
SnowWhite.CS.Trinity.Edu (4 processors)
and the Dwarf
) to see how running time varies with these two
variables.  Also record which machine you performed these experiments
on.  You may find it interesting to see whether multi-threading can
help even if you have more threads than processors.
FYI, machines known to have multiple processors include
SnowWhite.CS.Trinity.Edu (4 processors)
and the Dwarf .CS.Trinity.Edu machines (2 processors each).
.CS.Trinity.Edu machines (2 processors each).
You may find it useful to look at some of
sample programs, 
in particular the various programs to compute
the sum of  numbers.
 numbers.
Note that when you compile (and link) a program that uses the POSIX threads library, you need the flag -pthread. The sample programs page has an example of a Makefile that takes care of this.
 (the number of threads) might not evenly divide
 (the number of threads) might not evenly divide  .  Your code
should be prepared to cope with this.  At the very least, it should
print an error message and stop.
.  Your code
should be prepared to cope with this.  At the very least, it should
print an error message and stop.
Submit your completed program (variance.cpp or Variance.java), plus the text file containing your timing measurements, as described in the Guidelines for Programming Assignments, using a subject header of ``cs3366 hw 4''.
 .  For this assignment, use the incorrect definition,
since this was pointed out after some students had submitted
solutions.
.  For this assignment, use the incorrect definition,
since this was pointed out after some students had submitted
solutions.