Programming Assignment 4: K-d Trees /* ***************************************************************************** * Describe the Node data type you used to implement the * 2d-tree data structure. **************************************************************************** */ /* ***************************************************************************** * Describe your method for range search in a k-d tree. **************************************************************************** */ /* ***************************************************************************** * Describe your method for nearest neighbor search in a k-d tree. **************************************************************************** */ /* ***************************************************************************** * How many nearest-neighbor calculations can your PointST implementation * perform per second for input1M.txt (1 million points), where the query * points are random points in the unit square? * * Fill in the table below, rounding each value to use one digit after * the decimal point. Use at least 1 second of CPU time. Do not use -Xint. * (Do not count the time to read the points or to build the 2d-tree.) * (See the checklist for information on how to do this) * * Repeat the same question but with your KdTreeST implementation. * **************************************************************************** */ # calls to / CPU time = # calls to nearest() client nearest() (seconds) per second ------------------------------------------------------ PointST: KdTreeST: Note: more calls per second indicates better performance. /* ***************************************************************************** * Suppose you wanted to add a method numberInRange(RectHV rect) to your * KdTreeST, which should return the number of points that are inside rect * (or on the boundary), i.e. the number of points in the iterable returned by * calling range(rect). * * Describe a pruning rule that would make this more efficient than the * range() method. Also, briefly describe how you would implement it. * * Hint: consider a range search. What can you do when the query rectangle * completely contains the rectangle corresponding to a node? **************************************************************************** */ /* ***************************************************************************** * List any other comments here. Feel free to provide any feedback * on how helpful the class meeting was and on how much you learned * from doing the assignment, and whether you enjoyed doing it. **************************************************************************** */