Design 20 points; code 40 points.
By now your game should be playable, with all the major functionality implemented. This homework is something of a tangent; the goal is to write a second, more efficient priority queue and compare its performance with your first version. The needed code breaks down into two categories:
First, you are to write a second priority queue class that uses a heap (as discussed in class) to store elements rather than a sorted linked list.
Second, you are to add code to your game that will allow you to compare the performance of the two implementations as the number of game entities in the queue varies. To do this, you need to do several things: create a ``dummy'' game entity class so you can put arbitrarily many entities in the priority queue, change your main class to accept two command-line arguments that specify which implementation to use and how many of these dummy entities to add, and change your player class to print out some information that will allow you to see how performance varies based on the choice of priority queue implementation and the number of dummy entities.
Once you do all of this, you can run your game with different values of the two command-line arguments and see how performance changes. The final part of this assignment is to do this and plot the results.
The design for this assignment will likely be simpler for this assignment than for previous assignments, since the number of new classes is smaller, and there will not be many changes to the descriptions of other classes.
The class you need to add and/or modify are described in the next section (``Classes for this assignment''). This section describes the overall procedure.
NOTE: I do not recommend that you make other changes to your code in this assignment, unless it's to fix critical bugs. The changes you make for this assignment do not need to be included in the final version of the game you will turn in for Homework 8, and if you avoid making other changes, you can use Homework 6 as your starting point for Homework 8 and not worry about backing out Homework 7 changes.
The ``General requirements'' section of the Project description has more suggestions about how to send me the needed files.
Please use a subject line such as ``csci 1321 code 7''.
For this assignment the coding job consists of three main pieces -- writing a second PriorityQueue class, writing a class for dummy entities, and making changes to other classes to let you conduct the performance experiments described earlier.
Like the priority queue class you wrote for Homework 5, the one for this assignment should implement the framework's PriorityQueue interface. You could call it HeapBasedQueue, or something else that distinguishes it from the previous class. It will store elements using a heap (as discussed in class) rather than a linked list. NOTE that you should not implement the heap using a tree-like representation. Instead, use an array (as discussed in class) or one of the Java library classes that can represent a resizable array (Vector or ArrayList). If you use a plain array your code is likely to be simpler, but you will have to include code to make it bigger if it fills up (by creating a bigger array and copying elements). A good strategy for that is to start out with some reasonable-seeming size, and double it if it fills up.
You also need a ``dummy'' game entity class you can use to put lots of entries in the priority queue. It will need all the methods of the GameEntity interface, but the only ones that have to do anything are update (store the time passed in) and getUpdateTime (return the time previously passed to update plus something nonzero). To fully test your priority queue, the time between updates should not be the same for all dummy entities. A simple way to make this happen is for each entity to have a timeBetweenUpdates variable, passed in via a constructor; its getUpdateTime method then returns the time of the last update plus timeBetweenUpdates.
Finally, you have to make some smaller changes to other classes to allow you to conduct performance experiments:
Probably the right place to add this code is in the constructor for the class. There are various options for passing in the two command-line arguments. One is to make them parameters to the class's constructor, write a method makeInstance that takes two parameters and uses them to create the class's one instance, and call makeInstance from your game's main class. Or you may think of a better approach!
Once you have written and tested the above code, I want you to collect and plot timing information that shows how, for each version of the priority queue, performance (time for 100 calls to player's update method) changes as the number of dummy entities increases. You will have to experiment a little to see what number of entities is needed to get meaningful results. Start with a small number (say 10), and then increase it by factors of 2 or 10 until you see performance differences. Then collect timing results for at least six different numbers of dummy entities. (You might start with the value at which you first notice an increase, and then double that repeatedly, or multiply by 10. What you should see is that for entities the time for the linked-list version is roughly proportional to , while for the heap version time is roughly proportional to .) I also suggest letting the game run long enough to print several values (at least three or four) for the ``time for 100 updates'' measurement, and then averaging them.
Plot your performance data in whatever way is easiest for you -- using whatever tool you prefer for making plots, or with pencil and paper if that's easier. I usually use gnuplot (that's what I've used in class), but it does take a bit of learning to use. Details on request.