Due: Fri, Sept 15 th, 5:00 p.m. Parallel and Sequential Data Structures and Algorithms (Fall 17)
|
|
- Archibald Parker
- 5 years ago
- Views:
Transcription
1 Lab 2 - SkylineLab Due: Fri, Sept 15 th, 5:00 p.m. Parallel and Sequential Data Structures and Algorithms (Fall 17) 1 Introduction This assignment is designed to give you more practice with divide-and-conquer algorithms as well as provide an introduction to using the sequence function scan. You will analyze and solve the skyline problem, which is a geometric problem in 2 dimensions. This lab is conceptually difficult, so be sure to get started early! 2 Files After downloading the assignment tarball from Autolab, extract the files by running: tar -xvf skylinelab-handout.tgz from a terminal window. Some of the files worth looking at are listed below. The files denoted by * will be submitted for grading. 1. * MkSkyline.sml 2. * MkPerfSkyline.sml 3. Sandbox.sml 4. Tests.sml Additionally, you should create a file called: written.pdf which contains the answers to the written parts of the assignment. provided a L A TEX template (written.tex). For your convenience, we ve 3 Submission To submit your assignment to Autolab, generate a handin archive handin.tgz with the command make package then open the Autolab webpage and submit your handin.tgz file via the Submit File link. If your code compiles correctly, then in the Compilation column, Autolab will display a score of 0. Code which does not compile will show a negative score in this column. Please double check your submission on the Autolab webpage to make sure there were no errors. Once you ve completed all problems, you should submit your written.pdf to Gradescope. Note that your code will not be graded until after the due date. It is your responsibility to test your code thoroughly before submitting.
2 (Fall 2017) SkylineLab 4 The Skyline Problem Feast your eyes upon downtown Pittsburgh. From our perspective, most of the buildings are roughly rectangular (the exceptions being those like PPG Place), so let s assume from now on that all buildings are rectangles. We ll also assume that the ground is perfectly flat so that all the rectangles rest on the same line. The skyline of these rectangles is basically their silhouette. 4.1 Buildings Under the assumptions given, each building can be represented by a triple (`, h, r) which describes a rectangle with corners (`, 0), (`, h), (r, h), and (r, 0). We will assume ` < r so that ` and r are the left and right sides of the building, and h is the height of the building. 2
3 4.2 Definition The skyline of a set of buildings B is { (x, H(x)) : x X } x = min X H(x) H(prev(x)) where X is the set of all x-coordinates in B, H(x) is the max height at x, and prev(x) is the nearest x to the left of x, given by X = {l, r} (l,h,r) B H(x) = max { h : (l, h, r) B l x < r } prev(x) = max { x X x < x } In other words, the x-coordinates in the skyline are exactly those which appear in B, and the y-coordinate for any particular x is the height h of the tallest building (l, h, r) for which l x < r. We do not include redundant points: points whose height is unchanged from the nearest point to the left. 4.3 Example In the diagrams below, skyline points are marked with diagram with.. Redundant points are marked in the first Skyline: Buildings: l h r x y
4 4.4 Implementation We define type skyline = (int * int) Seq.t. We maintain the convention that all skylines are sorted by x-coordinate, and do not contain redundant points. Throughout, we assume that all x-coordinates are unique and non-negative, and that all heights are strictly positive. Given a sequence of buildings B in no particular order, your goal is to write a divide-and-conquer algorithm for the skyline problem of the following form: fun skyline B = case Seq.splitMid B of Seq.EMPTY Seq.empty () Seq.ONE x singleton x Seq.PAIR (L, R) combine (Primitives.par (fn () skyline L, fn () skyline R)) The runtime behavior of this code is identical to the following, which uses reduce to automate the divide-and-conquer process. fun skyline B = Seq.reduce combine (Seq.empty ()) singleton b : b B All you have to do is write the functions singleton and combine. Task 4.1 (70 pts). In MkSkyline.sml, implement the following functions. val singleton : int * int * int skyline (singleton (l, h, r)) should evaluate to the skyline of a single building (l, h, r). Your implementation must take constant time. val combine : skyline * skyline skyline (combine (S 1, S 2 )) should evaluate to the skyline of all buildings from both S 1 and S 2. Your implementation must have O( S 1 + S 2 ) work and O(log S 1 + log S 2 ) span. Some notes: As usual, assume Seq = ArraySequence for cost analysis. In combine, you will probably find the functions merge, scan (or scanincl), and filter (or filteridx) particularly useful. Note that for constant-time functions f, (scan f b S) has O( S ) work and O(log S ) span. The cost bounds of scanincl are identical to scan. Don t forget about removing redundant points! 4
5 5 Testing There are two ways to test your code. 1. In Sandbox.sml, write whatever testing code you d like. You can then access the sandbox at the REPL: - CM.make "sandbox.cm";... - open Sandbox; 2. In Tests.sml, add test cases according to the instructions given. Then run the autograder: - CM.make "autograder.cm";... - Autograder.run (); As usual, it is very important that you thoroughly test your code before you submit. deadline, we will grade your code with a private set of test cases. After the 5
6 6 Analysis 6.1 Cost Consider the functions skyline, combine, and singleton as given in section 4.4. Assume combine and singleton are implemented correctly and meet the required cost bounds. Task 6.1 (5 pts). Give an upper bound for combine (S 1, S 2 ) in terms of S 1 and S 2. Task 6.2 (5 pts). Write the work and span recurrences of (skyline B) in terms of n = B. State the tight Big-O bound for each recurrence (don t show your work of solving them; we just want the bound). Task 6.3 (15 pts). Suppose that (combine (S 1, S 2 )) now has O( S 1 log S 1 + S 2 log S 2 ) work. Write the new work recurrence of (skyline B) in terms of n = B. Solve it using the substitution method and give a tight Big-O bound (show your work this time). 6.2 Finding a Lower Bound Our skyline algorithm runs in O(n log n) time. 1 But is this algorithm the fastest possible, asymptotically? It turns out that the answer is yes! It is well known that any comparison-based sorting algorithm requires at least Ω(n log n) work in the worst case. 2 This lower bound applies to the skyline problem as well; for a proof, we just have to construct a reduction from the sorting problem. Task 6.4 (15 pts). Assume you have a black-box algorithm skyline with the same specification as the one given in section 4.4. In written.pdf, write pseudocode for a function val sort : int Seq.t int Seq.t which sorts its input. Your solution must be O(n + W skyline (n)). For the sake of simplicity, you may assume the input contains only non-negative numbers and no duplicates. Our solution is 4 lines long. Task 6.5 (5 pts). Argue in just a few short sentences why this reduction proves that skyline must run in time Ω(n log n) in the worst case. 1 Oops, this pretty much gives away the answer for part of an earlier task... oh well! 2 If you haven t seen this proof before, a quick Google search should yield a wealth of useful information. 6
7 7 Performance You will now adapt your Skyline code to be (hopefully) faster, and test it. First, you will need access to the mlton-spoonhower compiler. Begin by SSHing into linux.andrew.cmu.edu, and then add the following to your PATH. Don t forget to source the edited file so that the changes to PATH are visible. /afs/cs/academic/class/15210-s17/mlton-spoonhower/build/bin/ (If you do not know how to do this, first check which shell you are using via echo $SHELL, and then Google search! If you re still having trouble, ask another student or a TA for help.) Task 7.1 (10 pts). In MkPerfSkyline.sml, implement skyline with the goal of better performance. As a starting point, try copying in your existing implementations of singleton and combine, and write skyline by adapting the code shown in Section 4.4. We will not be grading the code in MkPerfSkyline.sml for style and readability. Note that in this file, skyline also takes an argument g, which is intended to be a granularity parameter. g will be controllable from the command line. Feel free to use it however you would like in your implementation. After completing your new implementation, compile your code via mlton-spoonhower skyline.fj.mlb and then run a self-speedup experiment with the following command. You should replace <ps> with a comma-separated list of processor counts. Replace <r> with the number of times each trial should be repeated (the results will be averaged; more runs will reduce the effect of random noise in your experiment). Replace <n> with the desired input size, which should be at least 1,000,000. Finally, replace <g> with the desired granularity, which is then passed as an argument to your implementation../plotting/plot.pl -proc <ps> -runs <r> -size <n> -granularity <g> For example:./plotting/plot.pl -proc 1,2,4,8 -runs 5 -size granularity 1000 This command produces a speedup plot in a file plots.pdf. Please include an image of this plot in your submitted written.pdf. Finally, write a paragraph or two detailing what changes you made to your implementation, and what the effects were. Note that we won t penalize you for not achieving good performance. If you find that one of your changes made things worse, then tell us about it! 7
15 210: Parallel and Sequential Data Structures and Algorithms
Full Name: Andrew ID: Section: 15 210: Parallel and Sequential Data Structures and Algorithms Practice Exam I February 2017 There are 11 pages in this examination, comprising 6 questions worth a total
More informationRecitation 1. Scan. 1.1 Announcements. SkylineLab has been released, and is due Friday afternoon. It s worth 125 points.
Recitation 1 Scan 1.1 Announcements SkylineLab has been released, and is due Friday afternoon. It s worth 125 points. BignumLab will be released on Friday. 1 2 RECITATION 1. SCAN 1.2 What is scan? In the
More informationECEn 424 The Performance Lab: Code Optimization
ECEn 424 The Performance Lab: Code Optimization 1 Introduction This assignment deals with optimizing memory intensive code. Image processing offers many examples of functions that can benefit from optimization.
More informationRecitation 1. Scan. 1.1 Announcements. SkylineLab has been released, and is due Friday afternoon. It s worth 125 points.
Recitation 1 Scan 1.1 Announcements SkylineLab has been released, and is due Friday afternoon. It s worth 125 points. BignumLab will be released on Friday. 1 2 RECITATION 1. SCAN 1.2 What is scan? In the
More informationRecitation 13. Priority Queues and Hashing Announcements. PASLLab is due this Friday, May 5. The final exam is on Friday, May 13.
Recitation 13 Priority Queues and Hashing 13.1 Announcements PASLLab is due this Friday, May 5. The final exam is on Friday, May 13. A review session for the final is upcoming. Stay tuned! A practice final
More informationCS 213, Fall 2001 Lab Assignment L4: Code Optimization Assigned: October 11 Due: October 25, 11:59PM
CS 213, Fall 2001 Lab Assignment L4: Code Optimization Assigned: October 11 Due: October 25, 11:59PM Sanjit Seshia (sanjit+213@cs.cmu.edu) is the lead person for this assignment. 1 Introduction This assignment
More informationRecitation 16. Hashing and PASL Announcements. PASLLab is due on Friday at midnight. Note that you cannot use late days on this lab.
Recitation 16 Hashing and PASL 16.1 Announcements PASLLab is due on Friday at midnight. Note that you cannot use late days on this lab. 91 92 RECITATION 16. HASHING AND PASL 16.2 Removing Duplicates Removing
More informationA4: HTML Validator/Basic DOM Operation
A4: HTML Validator/Basic DOM Operation Overview You are tasked with creating a basic HTML parser to perform a *very* limited subset of what a web browser does behind the scenes to setup the DOM for displaying
More informationICS(II),Fall 2017 Performance Lab: Code Optimization Assigned: Nov 20 Due: Dec 3, 11:59PM
ICS(II),Fall 2017 Performance Lab: Code Optimization Assigned: Nov 20 Due: Dec 3, 11:59PM Shen Wenjie (17210240186@fudan.edu.cn) is the TA for this assignment. 1 Logistics This is an individual project.
More informationCSE 332 Autumn 2013: Midterm Exam (closed book, closed notes, no calculators)
Name: Email address: Quiz Section: CSE 332 Autumn 2013: Midterm Exam (closed book, closed notes, no calculators) Instructions: Read the directions for each question carefully before answering. We will
More informationECE454, Fall 2014 Homework2: Memory Performance Assigned: Sept 25th, Due: Oct 9th, 11:59PM
ECE454, Fall 2014 Homework2: Memory Performance Assigned: Sept 25th, Due: Oct 9th, 11:59PM David Lion (david.lion@mail.utoronto.ca) is the TA for this assignment. 1 Introduction After great success with
More information15 150: Principles of Functional Programming Sorting Integer Lists
15 150: Principles of Functional Programming Sorting Integer Lists Michael Erdmann Spring 2018 1 Background Let s define what we mean for a list of integers to be sorted, by reference to datatypes and
More informationCS 429H, Spring 2011 Code Optimization Assigned: Fri Apr 15, Due: Friday May 6, 11:59PM
CS 429H, Spring 2011 Code Optimization Assigned: Fri Apr 15, Due: Friday May 6, 11:59PM Christian Miller (ckm@cs.utexas.edu) is the lead person for this assignment. 1 Introduction This assignment deals
More informationCS 135, Fall 2010 Project 4: Code Optimization Assigned: November 30th, 2010 Due: December 12,, 2010, 12noon
CS 135, Fall 2010 Project 4: Code Optimization Assigned: November 30th, 2010 Due: December 12,, 2010, 12noon 1 Introduction This assignment deals with optimizing memory intensive code. Image processing
More informationCS 161 Problem Set 4
CS 161 Problem Set 4 Spring 2017 Due: May 8, 2017, 3pm Please answer each of the following problems. Refer to the course webpage for the collaboration policy, as well as for helpful advice for how to write
More informationCS 4349 Lecture October 18th, 2017
CS 4349 Lecture October 18th, 2017 Main topics for #lecture include #minimum_spanning_trees. Prelude Homework 6 due today. Homework 7 due Wednesday, October 25th. Homework 7 has one normal homework problem.
More information15 210: Parallel and Sequential Data Structures and Algorithms
Full Name: Andrew ID: Section: 15 210: Parallel and Sequential Data Structures and Algorithms Practice Exam II April 2016 There are 17 pages in this examination, comprising 6 questions worth a total of
More information15 210: Parallel and Sequential Data Structures and Algorithms
Full Name: Andrew ID: Section: 15 210: Parallel and Sequential Data Structures and Algorithms Exam II 7 April 2017 Verify There are 17 pages in this examination, comprising 7 questions worth a total of
More informationNotes slides from before lecture. CSE 21, Winter 2017, Section A00. Lecture 4 Notes. Class URL:
Notes slides from before lecture CSE 21, Winter 2017, Section A00 Lecture 4 Notes Class URL: http://vlsicad.ucsd.edu/courses/cse21-w17/ Notes slides from before lecture Notes January 23 (1) HW2 due tomorrow
More informationLab Assignment 4: Code Optimization
CS-2011, Machine Organization and Assembly Language, D-term 2013 1. Introduction Lab Assignment 4: Code Optimization Assigned: April 16, 2013, Due: April 28, 2013, at 11:59 PM Professor Hugh C. Lauer This
More informationCSE 332 Spring 2013: Midterm Exam (closed book, closed notes, no calculators)
Name: Email address: Quiz Section: CSE 332 Spring 2013: Midterm Exam (closed book, closed notes, no calculators) Instructions: Read the directions for each question carefully before answering. We will
More informationCS 105, Fall 2003 Lab Assignment L5: Code Optimization See Calendar for Dates
L CS 105, Fall 2003 Lab Assignment L5: Code Optimization See Calendar for Dates Mike and Geoff are the leads for this assignment. 1 Introduction This assignment deals with optimizing memory intensive code.
More informationCSE373: Data Structure & Algorithms Lecture 21: More Comparison Sorting. Aaron Bauer Winter 2014
CSE373: Data Structure & Algorithms Lecture 21: More Comparison Sorting Aaron Bauer Winter 2014 The main problem, stated carefully For now, assume we have n comparable elements in an array and we want
More informationCSE 373 Winter 2009: Midterm #1 (closed book, closed notes, NO calculators allowed)
Name: Email address: CSE 373 Winter 2009: Midterm #1 (closed book, closed notes, NO calculators allowed) Instructions: Read the directions for each question carefully before answering. We may give partial
More informationCIS 121 Data Structures and Algorithms with Java Spring Code Snippets and Recurrences Monday, January 29/Tuesday, January 30
CIS 11 Data Structures and Algorithms with Java Spring 018 Code Snippets and Recurrences Monday, January 9/Tuesday, January 30 Learning Goals Practice solving recurrences and proving asymptotic bounds
More informationCS 429H, Spring 2014 Lab Assignment 9: Code Optimization Assigned: April 25 Due: May 2, 11:59PM
CS 429H, Spring 2014 Lab Assignment 9: Code Optimization Assigned: April 25 Due: May 2, 11:59PM 1 Introduction This assignment deals with optimizing memory intensive code. Image processing offers many
More information0.1 Welcome. 0.2 Insertion sort. Jessica Su (some portions copied from CLRS)
0.1 Welcome http://cs161.stanford.edu My contact info: Jessica Su, jtysu at stanford dot edu, office hours Monday 3-5 pm in Huang basement TA office hours: Monday, Tuesday, Wednesday 7-9 pm in Huang basement
More informationCSE 373 Spring 2010: Midterm #1 (closed book, closed notes, NO calculators allowed)
Name: Email address: CSE 373 Spring 2010: Midterm #1 (closed book, closed notes, NO calculators allowed) Instructions: Read the directions for each question carefully before answering. We may give partial
More informationCMSC 311, Fall 2009 Lab Assignment L4: Code Optimization Assigned: Wednesday, October 14 Due: Wednesday, October 28, 11:59PM
CMSC 311, Fall 2009 Lab Assignment L4: Code Optimization Assigned: Wednesday, October 14 Due: Wednesday, October 28, 11:59PM Sandro Fouche (sandro@cs.umd.edu) is the lead person for this assignment. 1
More informationCISC 360, Fall 2008 Lab Assignment L4: Code Optimization Assigned: Nov 7 Due: Dec 2, 11:59PM
CISC 360, Fall 2008 Lab Assignment L4: Code Optimization Assigned: Nov 7 Due: Dec 2, 11:59PM Yang Guan (yguan@cis.udel.edu) is the lead person for this assignment. 1 Introduction This assignment deals
More informationProject 1 Balanced binary
CMSC262 DS/Alg Applied Blaheta Project 1 Balanced binary Due: 7 September 2017 You saw basic binary search trees in 162, and may remember that their weakness is that in the worst case they behave like
More informationUniversity of Illinois at Urbana-Champaign Department of Computer Science. Final Examination
University of Illinois at Urbana-Champaign Department of Computer Science Final Examination CS 225 Data Structures and Software Principles Spring 2010 7-10p, Wednesday, May 12 Name: NetID: Lab Section
More information: Principles of Imperative Computation. Fall Assignment 5: Interfaces, Backtracking Search, Hash Tables
15-122 Assignment 3 Page 1 of 12 15-122 : Principles of Imperative Computation Fall 2012 Assignment 5: Interfaces, Backtracking Search, Hash Tables (Programming Part) Due: Monday, October 29, 2012 by 23:59
More informationCSE 332 Spring 2014: Midterm Exam (closed book, closed notes, no calculators)
Name: Email address: Quiz Section: CSE 332 Spring 2014: Midterm Exam (closed book, closed notes, no calculators) Instructions: Read the directions for each question carefully before answering. We will
More informationLecture 6: Sequential Sorting
15-150 Lecture 6: Sequential Sorting Lecture by Dan Licata February 2, 2012 Today s lecture is about sorting. Along the way, we ll learn about divide and conquer algorithms, the tree method, and complete
More informationLab 9: More Sorting Algorithms 12:00 PM, Mar 21, 2018
CS18 Integrated Introduction to Computer Science Fisler, Nelson Lab 9: More Sorting Algorithms 12:00 PM, Mar 21, 2018 Contents 1 Heapsort 2 2 Quicksort 2 3 Bubble Sort 3 4 Merge Sort 3 5 Mirror Mirror
More information15-213/18-213/15-513, Fall 2017 C Programming Lab: Assessing Your C Programming Skills
15-213/18-213/15-513, Fall 2017 C Programming Lab: Assessing Your C Programming Skills 1 Logistics Assigned: Tues., Aug. 29, 2017 Due: Thurs., Sept. 7, 11:59 pm Last possible hand in: Tues., Sept. 7, 11:59
More informationAlgorithms Lab 3. (a) What is the minimum number of elements in the heap, as a function of h?
Algorithms Lab 3 Review Topics covered this week: heaps and heapsort quicksort In lab exercises (collaboration level: 0) The in-lab problems are meant to be be solved during the lab and to generate discussion
More informationDue: 9 February 2017 at 1159pm (2359, Pacific Standard Time)
CSE 11 Winter 2017 Program Assignment #2 (100 points) START EARLY! Due: 9 February 2017 at 1159pm (2359, Pacific Standard Time) PROGRAM #2: DoubleArray11 READ THE ENTIRE ASSIGNMENT BEFORE STARTING In lecture,
More informationCS240 Fall Mike Lam, Professor. Algorithm Analysis
CS240 Fall 2014 Mike Lam, Professor Algorithm Analysis HW1 Grades are Posted Grades were generally good Check my comments! Come talk to me if you have any questions PA1 is Due 9/17 @ noon Web-CAT submission
More informationPrinciples of Algorithm Design
Principles of Algorithm Design When you are trying to design an algorithm or a data structure, it s often hard to see how to accomplish the task. The following techniques can often be useful: 1. Experiment
More informationMergeSort, Recurrences, Asymptotic Analysis Scribe: Michael P. Kim Date: September 28, 2016 Edited by Ofir Geri
CS161, Lecture 2 MergeSort, Recurrences, Asymptotic Analysis Scribe: Michael P. Kim Date: September 28, 2016 Edited by Ofir Geri 1 Introduction Today, we will introduce a fundamental algorithm design paradigm,
More information1 Introduction. 2 InsertionSort. 2.1 Correctness of InsertionSort
CS 161, Lecture 2 MergeSort, Recurrences 101, and Asymptotic Analysis Scribes: Michael Kim (2015), Ofir Geri (2016), M. Wootters (2017) Date: September 27, 2017 Adapted From Virginia Williams lecture notes
More informationMultiple-choice (35 pt.)
CS 161 Practice Midterm I Summer 2018 Released: 7/21/18 Multiple-choice (35 pt.) 1. (2 pt.) Which of the following asymptotic bounds describe the function f(n) = n 3? The bounds do not necessarily need
More informationSecond Examination Solution
University of Illinois at Urbana-Champaign Department of Computer Science Second Examination Solution CS 225 Data Structures and Software Principles Fall 2007 7p-9p, Thursday, November 8 Name: NetID: Lab
More information15-122: Principles of Imperative Computation, Spring 2013
15-122 Homework 5 Page 1 of 13 15-122: Principles of Imperative Computation, Spring 2013 Homework 5 Programming: Peglab Due: Tuesday, March 26, 2013 by 23:59 For the programming portion of this week s
More informationMergeSort, Recurrences, Asymptotic Analysis Scribe: Michael P. Kim Date: April 1, 2015
CS161, Lecture 2 MergeSort, Recurrences, Asymptotic Analysis Scribe: Michael P. Kim Date: April 1, 2015 1 Introduction Today, we will introduce a fundamental algorithm design paradigm, Divide-And-Conquer,
More informationHow much space does this routine use in the worst case for a given n? public static void use_space(int n) { int b; int [] A;
How much space does this routine use in the worst case for a given n? public static void use_space(int n) { int b; int [] A; } if (n
More informationCOSC 311: ALGORITHMS HW1: SORTING
COSC 311: ALGORITHMS HW1: SORTIG Solutions 1) Theoretical predictions. Solution: On randomly ordered data, we expect the following ordering: Heapsort = Mergesort = Quicksort (deterministic or randomized)
More informationCMPE 655 Fall 2016 Assignment 2: Parallel Implementation of a Ray Tracer
CMPE 655 Fall 2016 Assignment 2: Parallel Implementation of a Ray Tracer Rochester Institute of Technology, Department of Computer Engineering Instructor: Dr. Shaaban (meseec@rit.edu) TAs: Akshay Yembarwar
More information15-110: Principles of Computing, Spring 2018
15-110: Principles of Computing, Spring 2018 Problem Set 5 (PS5) Due: Friday, February 23 by 2:30PM via Gradescope Hand-in HANDIN INSTRUCTIONS Download a copy of this PDF file. You have two ways to fill
More informationCS302 Topic: Algorithm Analysis #2. Thursday, Sept. 21, 2006
CS302 Topic: Algorithm Analysis #2 Thursday, Sept. 21, 2006 Analysis of Algorithms The theoretical study of computer program performance and resource usage What s also important (besides performance/resource
More informationData Structures and Algorithms Key to Homework 1
Data Structures and Algorithms Key to Homework 1 January 31, 2005 15 Define an ADT for a set of integers (remember that a set may not contain duplicates) Your ADT should consist of the functions that can
More informationToday s Outline. CSE 326: Data Structures Asymptotic Analysis. Analyzing Algorithms. Analyzing Algorithms: Why Bother? Hannah Takes a Break
Today s Outline CSE 326: Data Structures How s the project going? Finish up stacks, queues, lists, and bears, oh my! Math review and runtime analysis Pretty pictures Asymptotic analysis Hannah Tang and
More informationCMPSCI 187: Programming With Data Structures. Lecture 5: Analysis of Algorithms Overview 16 September 2011
CMPSCI 187: Programming With Data Structures Lecture 5: Analysis of Algorithms Overview 16 September 2011 Analysis of Algorithms Overview What is Analysis of Algorithms? L&C s Dishwashing Example Being
More informationLecture 1: Overview
15-150 Lecture 1: Overview Lecture by Stefan Muller May 21, 2018 Welcome to 15-150! Today s lecture was an overview that showed the highlights of everything you re learning this semester, which also meant
More informationHomework /681: Artificial Intelligence (Fall 2017) Out: October 18, 2017 Due: October 29, 2017 at 11:59PM
Homework 2 15-381/681: Artificial Intelligence (Fall 2017) Out: October 18, 2017 Due: October 29, 2017 at 11:59PM Homework Policies Homework is due on Autolab by the posted deadline. Assignments submitted
More informationCS/ENGRD 2110 Object-Oriented Programming and Data Structures Spring 2012 Thorsten Joachims. Lecture 10: Asymptotic Complexity and
CS/ENGRD 2110 Object-Oriented Programming and Data Structures Spring 2012 Thorsten Joachims Lecture 10: Asymptotic Complexity and What Makes a Good Algorithm? Suppose you have two possible algorithms or
More informationProgramming Standards: You must conform to good programming/documentation standards. Some specifics:
CS3114 (Spring 2011) PROGRAMMING ASSIGNMENT #3 Due Thursday, April 7 @ 11:00 PM for 100 points Early bonus date: Wednesday, April 6 @ 11:00 PM for a 10 point bonus Initial Schedule due Thursday, March
More informationThe Limits of Sorting Divide-and-Conquer Comparison Sorts II
The Limits of Sorting Divide-and-Conquer Comparison Sorts II CS 311 Data Structures and Algorithms Lecture Slides Monday, October 12, 2009 Glenn G. Chappell Department of Computer Science University of
More informationCS264: Homework #1. Due by midnight on Thursday, January 19, 2017
CS264: Homework #1 Due by midnight on Thursday, January 19, 2017 Instructions: (1) Form a group of 1-3 students. You should turn in only one write-up for your entire group. See the course site for submission
More informationCS 361 Algorithms & Data Structures Lecture 1. Prof. Tom Hayes University of New Mexico
CS 361 Algorithms & Data Structures Lecture 1 Prof. Tom Hayes University of New Mexico 8-21-2012 1 Who we are Prof. Tom Hayes, hayes@cs.unm.edu Office: FEC 149 Hours: TuW 2:00-2:50 and by appt Phone: 277-9328
More informationCS302 Topic: Algorithm Analysis. Thursday, Sept. 22, 2005
CS302 Topic: Algorithm Analysis Thursday, Sept. 22, 2005 Announcements Lab 3 (Stock Charts with graphical objects) is due this Friday, Sept. 23!! Lab 4 now available (Stock Reports); due Friday, Oct. 7
More informationComputer Systems for AI-programmers baicsai3, Spring 2010 Lab Assignment: Code Optimization Assigned: Week 9, Due: Week 10 Wednesday March 10, 24:00
Computer Systems for AI-programmers baicsai3, Spring 2010 Lab Assignment: Code Optimization Assigned: Week 9, Due: Week 10 Wednesday March 10, 24:00 Arnoud Visser (A.Visser@uva.nl) is the lead person for
More informationHomework 8: Matrices Due: 11:59 PM, Oct 30, 2018
CS17 Integrated Introduction to Computer Science Klein Homework 8: Matrices Due: 11:59 PM, Oct 30, 2018 Contents 1 Reverse (Practice) 4 2 Main Diagonal (Practice) 5 3 Horizontal Flip 6 4 Vertical Flip
More informationInterlude: Problem Solving
Lecture 4 Interlude: Problem Solving Supplemental reading in CLRS: None This lecture was originally given as a pep talk before the take-home exam. In note form, this chapter will be light reading, a break
More informationArea and Perimeter EXPERIMENT. How are the area and perimeter of a rectangle related? You probably know the formulas by heart:
Area and Perimeter How are the area and perimeter of a rectangle related? You probably know the formulas by heart: Area Length Width Perimeter (Length Width) But if you look at data for many different
More informationCSE 332 Winter 2015: Midterm Exam (closed book, closed notes, no calculators)
_ UWNetID: Lecture Section: A CSE 332 Winter 2015: Midterm Exam (closed book, closed notes, no calculators) Instructions: Read the directions for each question carefully before answering. We will give
More informationCS261: Problem Set #2
CS261: Problem Set #2 Due by 11:59 PM on Tuesday, February 9, 2016 Instructions: (1) Form a group of 1-3 students. You should turn in only one write-up for your entire group. (2) Submission instructions:
More information15-110: Principles of Computing, Spring Problem Set 2 (PS2) Due: Friday, February 2 by 2:30PM on Gradescope
15-110: Principles of Computing, Spring 2018 Problem Set 2 (PS2) Due: Friday, February 2 by 2:30PM on Gradescope HANDIN INSTRUCTIONS Download a copy of this PDF file. You have two ways to fill in your
More informationPart I: Written Problems
CSci 4223 Homework 1 DUE: Friday, February 1, 11:59 pm Instructions. Your task is to answer three written problems, and to write eleven SML functions related to calendar dates, as well as test cases for
More informationParallel and Sequential Data Structures and Algorithms Lecture (Spring 2012) Lecture 25 Suffix Arrays
Lecture 25 Suffix Arrays Parallel and Sequential Data Structures and Algorithms, 15-210 (Spring 2012) Lectured by Kanat Tangwongsan April 17, 2012 Material in this lecture: The main theme of this lecture
More informationLecturers: Sanjam Garg and Prasad Raghavendra March 20, Midterm 2 Solutions
U.C. Berkeley CS70 : Algorithms Midterm 2 Solutions Lecturers: Sanjam Garg and Prasad aghavra March 20, 207 Midterm 2 Solutions. (0 points) True/False Clearly put your answers in the answer box in front
More informationCS 506, Sect 002 Homework 5 Dr. David Nassimi Foundations of CS Due: Week 11, Mon. Apr. 7 Spring 2014
CS 506, Sect 002 Homework 5 Dr. David Nassimi Foundations of CS Due: Week 11, Mon. Apr. 7 Spring 2014 Study: Chapter 4 Analysis of Algorithms, Recursive Algorithms, and Recurrence Equations 1. Prove the
More informationCSE373: Data Structures & Algorithms Lecture 22: Parallel Reductions, Maps, and Algorithm Analysis. Kevin Quinn Fall 2015
CSE373: Data Structures & Algorithms Lecture 22: Parallel Reductions, Maps, and Algorithm Analysis Kevin Quinn Fall 2015 Outline Done: How to write a parallel algorithm with fork and join Why using divide-and-conquer
More informationCS 105 Lab 5: Code Optimization See Calendar for Dates
CS 105 Lab 5: Code Optimization See Calendar for Dates 1 Introduction This assignment deals with optimizing memory intensive code. Image processing offers many examples of functions that can benefit from
More informationDesign and Analysis of Algorithms Prof. Madhavan Mukund Chennai Mathematical Institute
Design and Analysis of Algorithms Prof. Madhavan Mukund Chennai Mathematical Institute Module 07 Lecture - 38 Divide and Conquer: Closest Pair of Points We now look at another divide and conquer algorithm,
More informationCS2223: Algorithms D- Term, Homework I. Teams: To be done individually. Due date: 03/27/2015 (1:50 PM) Submission: Electronic submission only
CS2223: Algorithms D- Term, 2015 Homework I Teams: To be done individually Due date: 03/27/2015 (1:50 PM) Submission: Electronic submission only 1 General Instructions Python Code vs. Pseudocode: Each
More informationScan and its Uses. 1 Scan. 1.1 Contraction CSE341T/CSE549T 09/17/2014. Lecture 8
CSE341T/CSE549T 09/17/2014 Lecture 8 Scan and its Uses 1 Scan Today, we start by learning a very useful primitive. First, lets start by thinking about what other primitives we have learned so far? The
More informationCSE 373 NOVEMBER 8 TH COMPARISON SORTS
CSE 373 NOVEMBER 8 TH COMPARISON SORTS ASSORTED MINUTIAE Bug in Project 3 files--reuploaded at midnight on Monday Project 2 scores Canvas groups is garbage updated tonight Extra credit P1 done and feedback
More informationMerge Sort. Yufei Tao. Department of Computer Science and Engineering Chinese University of Hong Kong
Department of Computer Science and Engineering Chinese University of Hong Kong In this lecture, we will design the merge sort which sorts n elements in O(n log n) time. The algorithm illustrates a technique
More informationCS 210, Spring 2018 Programming Assignment 3: Code Optimization Due: Friday, April 20, 2018, 1pm No late submissions
CS 210, Spring 2018 Programming Assignment 3: Code Optimization Due: Friday, April 20, 2018, 1pm No late submissions 1 Introduction This assignment deals with optimizing memory intensive code. Image processing
More informationSpring 2012 Homework 09
15-150 Spring 2012 Homework 09 Out: 10 April, 2012 Due: 25 April, 2012, 09:00am 1 Introduction In this homework you will write a game and a game player using the techniques you have been learning in class.
More informationUniversity of Toronto Department of Electrical and Computer Engineering. Midterm Examination. ECE 345 Algorithms and Data Structures Fall 2012
1 University of Toronto Department of Electrical and Computer Engineering Midterm Examination ECE 345 Algorithms and Data Structures Fall 2012 Print your name and ID number neatly in the space provided
More informationLecture 10 October 7, 2014
6.890: Algorithmic Lower Bounds: Fun With Hardness Proofs Fall 2014 Lecture 10 October 7, 2014 Prof. Erik Demaine Scribes: Fermi Ma, Asa Oines, Mikhail Rudoy, Erik Waingarten Overview This lecture begins
More informationHomework 6: Higher-Order Procedures Due: 11:59 PM, Oct 16, 2018
Integrated Introduction to Computer Science Klein Homework 6: Higher-Order Procedures Due: 11:59 PM, Oct 16, 2018 Contents 1 Fun with map (Practice) 2 2 Unfold (Practice) 3 3 Map2 3 4 Fold 4 5 All You
More informationHomework # 7 DUE: 11:59pm November 15, 2002 NO EXTENSIONS WILL BE GIVEN
Homework #6 CS 450 - Operating Systems October 21, 2002 Homework # 7 DUE: 11:59pm November 15, 2002 NO EXTENSIONS WILL BE GIVEN 1. Overview In this assignment you will implement that FILES module of OSP.
More informationICS(II), Fall 2017 Cache Lab: Understanding Cache Memories Assigned: Thursday, October 26, 2017 Due: Sunday, November 19, 2017, 11:59PM
ICS(II), Fall 2017 Cache Lab: Understanding Cache Memories Assigned: Thursday, October 26, 2017 Due: Sunday, November 19, 2017, 11:59PM 1 Logistics This is an individual project. All handins are electronic.
More informationData Structure and Algorithm Homework #3 Due: 2:20pm, Tuesday, April 9, 2013 TA === Homework submission instructions ===
Data Structure and Algorithm Homework #3 Due: 2:20pm, Tuesday, April 9, 2013 TA email: dsa1@csientuedutw === Homework submission instructions === For Problem 1, submit your source code, a Makefile to compile
More informationIntroduction to the Analysis of Algorithms. Algorithm
Introduction to the Analysis of Algorithms Based on the notes from David Fernandez-Baca Bryn Mawr College CS206 Intro to Data Structures Algorithm An algorithm is a strategy (well-defined computational
More informationCS/COE 1501 cs.pitt.edu/~bill/1501/ Introduction
CS/COE 1501 cs.pitt.edu/~bill/1501/ Introduction Meta-notes These notes are intended for use by students in CS1501 at the University of Pittsburgh. They are provided free of charge and may not be sold
More informationFiberMesh. Due: 4/12/10, 11:59 PM
CS224: Interactive Computer Graphics FiberMesh Due: 4/12/10, 11:59 PM Least Squares Solver 5 Mesh triangulation 10 Optimization Problem 1: Curve Dragging 25 Optimization Problem 2: Surface Optimization
More informationCS 2505 Fall 2013 Data Lab: Manipulating Bits Assigned: November 20 Due: Friday December 13, 11:59PM Ends: Friday December 13, 11:59PM
CS 2505 Fall 2013 Data Lab: Manipulating Bits Assigned: November 20 Due: Friday December 13, 11:59PM Ends: Friday December 13, 11:59PM 1 Introduction The purpose of this assignment is to become more familiar
More informationWhy study algorithms? CS 561, Lecture 1. Today s Outline. Why study algorithms? (II)
Why study algorithms? CS 561, Lecture 1 Jared Saia University of New Mexico Seven years of College down the toilet - John Belushi in Animal House Q: Can I get a programming job without knowing something
More informationCS 61B Summer 2005 (Porter) Midterm 2 July 21, SOLUTIONS. Do not open until told to begin
CS 61B Summer 2005 (Porter) Midterm 2 July 21, 2005 - SOLUTIONS Do not open until told to begin This exam is CLOSED BOOK, but you may use 1 letter-sized page of notes that you have created. Problem 0:
More informationCS201: Lab #2 Code Optimization
CS201: Lab #2 Code Optimization This assignment deals with optimizing memory intensive code. Image processing offers many examples of functions that can benefit from optimization. In this lab, we will
More informationUniversity of Illinois at Urbana-Champaign Department of Computer Science. Final Examination
University of Illinois at Urbana-Champaign Department of Computer Science Final Examination CS 225 Data Structures and Software Principles Fall 2009 7-10p, Tuesday, December 15 Name: NetID: Lab Section
More informationCS 373: Combinatorial Algorithms, Fall Name: Net ID: Alias: U 3 / 4 1
CS 373: Combinatorial Algorithms, Fall 2000 Homework 1 (due November 16, 2000 at midnight) Starting with Homework 1, homeworks may be done in teams of up to three people. Each team turns in just one solution,
More informationCS4311 Design and Analysis of Algorithms. Lecture 1: Getting Started
CS4311 Design and Analysis of Algorithms Lecture 1: Getting Started 1 Study a few simple algorithms for sorting Insertion Sort Selection Sort Merge Sort About this lecture Show why these algorithms are
More informationCS134 Spring 2005 Final Exam Mon. June. 20, 2005 Signature: Question # Out Of Marks Marker Total
CS134 Spring 2005 Final Exam Mon. June. 20, 2005 Please check your tutorial (TUT) section from the list below: TUT 101: F 11:30, MC 4042 TUT 102: M 10:30, MC 4042 TUT 103: M 11:30, MC 4058 TUT 104: F 10:30,
More information