Computer Science 501
Data Structures and Algorithm Analysis
Fall 2015, The College of Saint Rose
This lab approaches analysis of algorithms from both the theoretical and empirical perspectives. The theoretical questions in the lecture assignment and problem set portions of the lab, will give you a chance to practice with the analysis tools we have considered in class. In the empirical study, you will use the timing code you developed last week to generate tabular and graphical format data, and see if you can match your results to the theoretical expectations.
You may work individually or in a group of 2 or 3 on this lab, but it is essential that each individual understands how to do the lecture assignment and problem set questions, as exam questions will be very similar. As you know, exams are not group efforts.
Getting Set Up
Create a document where you will record your answers to the lecture assignment and lab questions. If you use plain text, call it "lab4.txt". If it's a Word document, you can call it whatever you'd like, but when you submit, be sure you convert it to a PDF document "lab4.pdf" before you submit it.
Lecture Assignment Questions
We will usually discuss these questions at the start of class on the lab due date, so no credit can be earned for late submissions of lecture assignment questions.
Problem Set Problems
See the PDF version of this document for a more readable version of this part of the assignment, as the HTML rendering of these kinds of equations is sometimes a bit lacking.
for ( i = 1; i <= n; i++ ) for ( j = 1; j <= n; j++ ) { for ( k = 1; k <= Math.pow(2,j); k++ ) { System.out.println("hello"); } System.out.println("hello"); }
Note: you may test your formula by implementing this code and then running it for different values of n.
Empirical Analysis Study
Last week, you developed one or more Java classes capable of measuring the time taken for a variety of experiments. Please refer back to that lab description for the list of experiments.
Your first task is to run your program(s) repeatedly (likely thousands of times) to generate a set of timing data.
-Xint
to your Java command
line will disable the JIT compiler.
Your second task is to gather your results into both tabular and graphical formats. You might use familiar tools such as a spreadsheet program for this, but I encourage you to look into gnuplot, which is a free data plotting program available for most platforms. It is installed on mogul, and an example of how to use it is available there in /home/shared/gnuplotexample.
Your final task is to present your results for each experiment. Before addressing the individual experiments, write an introductory paragraph describing the overall approach, including as many details about your test environment as you can (include Java version and any options used when running, operating system version, CPU configuration (number of cores, chips), architecture, and speed, and memory size at a minimum, but also things like cache sizes if you can find them).
Then for each experiment, include the following:
Submitting
Before 11:59 PM, Sunday, October 4, 2015, submit your lab for grading. There are two things you need to do to complete the submission: (i) Copy your file with the answers to the lecture assignment and lab questions into your project directory. Be sure to use the correct file name. If you prepared your answers in Word, export to a PDF file and submit that. (ii) Email a copy of your lab (a .7z or .zip file containing your project directory) to terescoj AT strose.edu. Please use a meaningful subject line such as "Joe Student Lab4 Submission".
Grading
This assignment is worth 85 points, which are distributed as follows:
> Feature | Value | Score |
LA Question 1 (5.6) | 3 | |
LA Question 2 (5.14) | 3 | |
LA Question 3 (size metrics) | 3 | |
Question 1: compare growth rates | 4 | |
Question 2: limit proofs | 4 | |
Question 3: Big O informal | 2 | |
Question 4: prove Big O class | 6 | |
Question 5: prove Big Omega class | 6 | |
Question 6: prove Big Theta class | 5 | |
Question 7: analyze code segment | 5 | |
Empirical analysis study introduction | 4 | |
Empirical analysis study choice of problem sizes, reps | 4 | |
Empirical analysis study timing data | 12 | |
Empirical analysis study tables and graphs | 12 | |
Empirical analysis study comparison with theory | 12 | |
Total | 85 | |