|
What's a checklist? The assignment checklists are meant to supplement the assignment, and clear up any confusing points. They will also provide brief hints on getting started. They also include links to sample data files, reference solutions, and information on what to include in the programming report. Be sure to read the checklist before each assignment.
Is there anything else I should do before getting started? Please read the Assignments Page, including the collaboration policy, lateness policy, and submission system instructions if you have not done so already. The programming assignments will require a good deal of time. The final source code may not be that long, but creating and debugging the code is a serious time commitment. It would be a mistake to wait until after Tuesday precept to start your assignments. You may be able to ask more meaningful questions in precept if you already have worked on the program enough to know what the real difficult issues are.
The whiteboard submission system describes my file as a C++ program instead of a Java program. Am I doing anything wrong? Unlikely. We use the Unix command file -b Point.java, and it occasionally gets it wrong because the language syntaxes are so similar.
Can I redraw the same line segment several times? Yes. If this simplifies your code, we'll allow it without penalty.
Can the same point appear more than once in the input file? No. You may assume the data has been pre-processed so that this does not happen.
How do I access the mathematical constant π? Use Math.PI.
Why use Math.atan2 instead of Math.atan? The latter treats the angle between the origin and (x, y) as equal to the angle between the origin and (-x, -y). For the collinearity test, it should work. But you cannot use it for compareTo since you could end up with inconsistent situations like a < b and b < c, but a > c.
Does (Math.atan2(y, x) == Math.atan2(c*y, c*x)) if x, y, and c are integers with c not equal to zero? Yes, I believe so. In any case, it's fine on this assignment to assume that they will since our main focus here is not floating point precision. In real applications, you would use the integer pseudo-angle trick described below.
Do I have to implement my own sorting algorithm? No, there is no need to re-invent the wheel. Feel free to use Java's system sort. See the java documentation here. You also can use any code from the Sedgewick book with an appropriate reference.
How do I read in the data and plot graphics? Use the same helper programs from COS 126: StdIn for reading from standard input and StdDraw for drawing. See Section 2.4 from the 126 text for a refresher.
How do I measure the running time of my program in seconds from Unix, Linux or OS X? Use the command:
and look at the output for user time. Note that you should use the full path name; otherwise your shell might use its own built-in time command. Be careful when using /usr/bin/time with piping - it may only time the first process and not the whole chain./usr/bin/time java Hello < input.txt > output.txt
How do I measure the running time of my program in seconds from Windows? The easiest solution is to use a stopwatch. A more complicated approach involves adding in some Java code (don't forget to remove it before submitting) as in Timing.java. If you use this, be sure that you are running on a lightly loaded system since it uses the system time to measure running time. Srivas Prasad '03 suggests changing the command prompt to display the time using "prompt $t", creating a batch file with "cls" and "java Hello < input.txt > output.txt". The clear screen command clears the screen and displays the starting time in the prompt; upon termination the prompt shows the ending time. If you have a better solution, let us know.
How do I profile my program? Execute with the command
java -Xprof Hello < input.txt > output.txt
|
Input. Here are some sample input files. Thanks to Jesse Levinson for rs1423.txt. To estimate the running time as a function of N, you can use the program Generator.java. It takes a command line argument N and outputs a random instance of N points.
Submission. Your two programs must be named Brute.java and Fast.java. Both programs must use a common point data type named Point.java. Be sure to submit every file that your program needs (except StdIn.java, StdDraw.java and Draw.java). Don't forget to hit the "Run Script" button on the submission system to test that it compiles cleanly.
Program report. You also need to submit a brief written report on what you did for this assignment that answers these questions, including both an empirical and theoretical analysis of the two algorithms. This report should be submitted in hard copy with the written exercises. See the assignments page for more details.
|
These are purely suggestions for how you might make progress. You do not have to follow these steps.
This should open up a graphical window where you will see the points plotted.javac PointPlotter.java java PointPlotter < input56.txt
that returns the angle that b makes with a. The Java function Math.atan2(double y, double x) is exactly what you need: it returns the polar angle that corresponds to the point (x, y) in Cartesian coordinates. Then, use this helper function to create a functionpublic static double angle(Point a, Point b)
that returns true if a, b, and c are collinear and false otherwise.public static boolean areCollinear(Point a, Point b, Point c)
To do this, make Point.java implement the Comparable interface. Introduce a static variable (here, static means that it is a common variable, shared by the whole class) p to Point.java that represents the origin. Then, add a function
that sets the origin, and a methodpublic static void setOrigin(Point theOrigin)
such that invoking q1.compareTo(q2) returns a negative integer, zero, or a positive integer depending on whether the angle that q1 makes with p is less than, equal to, or greater than the angle that q2 makes with p. The method compareTo now has access to the origin p, and the client can change p by calling setOrigin.public int compareTo(Object q2)
|
This problem belongs to a group of problems that are known as 3SUM-hard. It is conjectured that such problems have no subquadratic algorithms. Thus, the sorting algorithm presented above is about the best we can hope for (unless the conjecture is wrong). Under a restricted decision tree model of computation, Erickson proved that the conjecture is true.