$25
This programming laboratory will provide you an opportunity to brush up on your programming skills. If you haven’t yet been introduced to Matlab, you will also get a learn-by-doing introduction.
For this first lab, you will be required to implement solutions in two languages: 1) Python, Java, or C/C++ (your choice) and 2) Matlab. It is not the purpose of this course to teach you these languages, however if you have questions/troubles with your code please don’t hesitate to ask.
A crash course in Matlab programming can be found on the course webpage. If you are learning Matlab for the first time, it is highly suggested that you read the posted supplemental material before coming to the lab.
Problem 1 – Matrix Multiplication
Functions
Implement a matrix-matrix-product function called matrixmultiply that takes as arguments matrices A and B and returns the product C = A*B. Your implementation should directly implement the triply-nested for-loop algorithm presented in Lecture 1. The following notes apply:
• it is not necessary for the matrices to be square
• your function should identify and report erroneous problem instances
• you are free to add any function arguments required for your language of choice (e.g., matrix sizes)
• you can use derived types or classes to represent matrices but will have to clearly explain what you’re using and where it comes from (if you’re using a third-party library)
Note: Implement your matrix multiplication function in two languages, one of which must be Matlab.
Main Program
Write a main program Lab 1 Problem 1 that:
• reads the sizes of matrices A and B from the command line (or other user input), allocates and fills A and B as random matrices, and evaluates the product C = A*B
• evaluates the computational time of the matrix product (excluding other operations) and clearly displays the elapsed time
• verifies the matrix product against a built-in/library routine (think carefully about how can you succintly show that the result is correct)
• evaluates the computational time of the built-in/library routine and clearly displays the elapsed time
Note: Implement your main program in two languages, one of which must be Matlab.
Validation and Data Collection
Once you have completed writing your function and main program you need to:
• show that your function works for both square and rectangular matrices (you will need to decide what is convincing)
• use both your method and the built-in/library method to collect timing data for various square matrix sizes, for example n = 100,200,400,800,... and plot time versus problem size for the two methods.
Note: You should validate, collect data, and produce plots for two languages. The plots can be produced by a common tool (e.g., you could use Matlab to produce plots for both implementations).
Evaluation and Discussion
Answer the following questions:
1. What computer hardware did you use to run the algorithms produced in this lab (CPU type, number of cores, amount of memory)?
2. How did you verify that your algorithm works? How can you be sure it works for all problem instances?
3. How does your algorithm perform versus the built-in/library function? What factors/reasons contribute to any difference in performance?
4. How does the performance of your algorithm change as a function of problem size? Is the change the same or different from the built-in function? Why?
5. Derive the order-of-growth of your matrix multiplication algorithm. Justify why or why not the results you measured agree with your assessment of the order-of-growth. You can do this on just the square matrix-matrix multiplication for simplicity (i.e.
Cn×n = An×nBn×n). Is this a tight upper bound? Justify.
6. Under what conditions would order of growth not be useful for estimating the actual run-time scaling?
Note: Evaluation and discussion should occur for two languages corresponding to your validation/data collection for those languages. There is no need to repeat discussions that are common to both language implementations, just focus on any differences.
Problem 2 – Merge Sort
Functions
Implement an in-place merge sort function called mergesort that takes as arguments an
array A and returns the sorted array in A. The following notes apply:
• your function can be implemented for sorting one specific type of data (it does not need to work for general inputs)
• your function should identify and report erroneous problem instances (erroneous might depend on your previous design decision)
• you are free to add any function arguments required for your language of choice (e.g., array size)
Note: Implement your merge sort function in two languages, one of which must be Matlab.
Main Program
Write a main program Lab 1 Problem 2 that:
• reads the size of the array/list to be sorted from the command line (or other user input), allocates and fills A as a random list and sorts it using your merge sort function
• evaluates the computational time of the sorting (excluding other operations) and clearly displays the elapsed time
• verifies the sorting; you may consider writing a utility function for this
• evaluates the computational time for sorting the same list using a built-in/library routine and clearly displays the elapsed time
Note: Implement your main program in two languages, one of which must be Matlab.
Validation and Data Collection
Once you have completed writing your function and main program you need to:
• show that your function works
• use both your method and the built-in/library method to collect timing data for various array/list sizes, for example n = 1000,2000,4000,8000,... and plot time versus problem size for the two methods.
Note: You should validate, collect data, and produce plots for two languages. The plots can be produced by a common tool (e.g., you could use Matlab to produce plots for both implementations).
Evaluation and Discussion
Answer the following questions:
1. How did you verify that your algorithm works? How can you be sure it works for all problem instances?
2. How does your algorithm perform versus the built-in/library function? What factors/reasons contribute to any difference in performance? Just use the default sort function from the language you are using.
3. How does the performance of your algorithm change as a function of problem size? Is the change the same or different from the built-in function? Why?
4. Derive the order-of-growth of your merge sort implementation. Justify why or why not the results you measured agree with your assessment of the order-of-growth.
5. Relate this result to what the algorithm is doing in plain English. As an example, for bubble sort (O(n2)) we might say, “Each entry in a list of length n needs to be compared to/swapped with ∼ n other entries in the list. This means that for n list entries and ∼ n checks/swaps per list entry, we see some function of n2 checks/swaps”.
6. Prove (with math) that the base of the logarithm in Big-O analysis doesn’t matter. (Hint: What else doesn’t matter in Big-O analysis?)