Personal tools
You are here: Home Courses Computational Geometry Fall 2017/2018 Computational Geometry - Fall 2017/2018
« November 2017 »
Log in

Forgot your password?

Computational Geometry - Fall 2017/2018


Monday, 16:00-19:00, Melamed 006

Instructor: Dan Halperin , danha@post
Office hours: by appointment
TA: Michal Kleinbort, balasmic AT
Office hours: by appointment
Grader: Shahar Shamai,
Maibox no. 312, Schriebr, 1st floor


The course covers fundamental algorithms for solving geometric problems such as computing convex hulls, intersection of line segments, Voronoi diagrams, polygon triangulation, and linear programming in low dimensional space. We will also discuss several applications of geometric algorithms to solving problems in robotics, GIS (geographic information systems), computer graphics, and more.


Data Structures, Algorithms and knowledge of C++ or willingness to learn the language



I will often use slides that accompany the main textbook of the course.The slides are by Marc van Kreveld and they can be found

at the following site: Geometric Algorithms



The main textbook of the course is:

Computational Geometry: Algorithms and Applications (CGAA), 2nd or 3rd edition by M. de Berg, M. van Kreveld, M. Overmars, and O. Schwarzkopf.

A bibliographic list for the course


Assignments, Examination and Grade:

The standard assignments will account for 10% of the final grade, in case they improve the final grade. 

The grade in the final exam, to be held on Wednesday, February 22nd, 2017, will account for the remaining 90% of the grade in the course. 

Exam(ple), pdf file

Although the assignment grades will be used only for improving the final grade, submission of the assignments is mandatory and a prerequisite for taking the exam.


About halfway through the course, we will present a programming project.

We encourage you to submit the programming project as well. This is not mandatory. 

If however you do submit it, then your grade breakdown will be 10% the standard assignments, 
15% the programming project, and 75% the final exam. Here as well, 
the assignments grades and project grade will be counted toward the final grade only if they improve it.  

There is an option to do the project in pairs, in which case its weight will be only 10% for each student of the pair instead of 15%.

The assignments will appear here.

Assignment no. 1 file , Part I due: November 13th, 2017. Part II due: November 20th, 2017.
Submission guidelines

Assignment no. 2 file , due: December 4th, 2017. Part II due: November 20th, 2017. 

Course Summary:

Below you'll find a very brief summary of what was covered in class during the semester.
This should not be taken as a complete description of the course's contents. "Slides X" refers to the relevant set of slides from Geometric Algorithms.

For an outline of the course, see for example, the course summary in the 2010 computational geometry course.

What is Computational Geometry? 
Course outline, motivation and techniques. A slow convex hull algorithm. Orientation (Side-of-line) test. Graham's O(n log n) algorithm (Chapter 1 in CGAA). Lower bound.    (Slides 1.) 
Gift-wrapping algorithm for computing the convex hull. 
Output sensitive algorithm to compute the intersections of line segments: Bentley Ottmann's plane sweep; handling degeneracies (CGAA, Chapter 2). (Slides 2a.)
Recitation: Problems about convex polygons.
The doubly-connected edge list (DCEL). Map overlay and applications (CGAA, Chapter 2). 
The Douglas-Peucker algorithm for line simplification. 
Polygon triangulation and art gallery problems - Part I: combinatorial bounds and properties (O'Rourke's book CG in C, Chapters 1 and 2, and in CGAA, Chapter 3). Part II: Triangulating a monotone polygon (CGAA, Chapter 3) and decomposing a polygon into monotone polygons via trapezoidal decomposition (O'Rourke's book, Chapter 2). 
Recitation: Problems about sweep line.


We will use piazza platform for our forum discussions.
Use this link to sign up for this class:

Document Actions