Data Structures for Computer Graphics
Code | Completion | Credits | Range | Language |
---|---|---|---|---|
B4M39DPG | Z,ZK | 6 | 2P+2S | Czech |
- Relations:
- It is not possible to register for the course B4M39DPG if the student is concurrently registered for or has already completed the course BE4M39DPG (mutually exclusive courses).
- The requirement for course B4M39DPG can be fulfilled by substitution with the course BE4M39DPG.
- It is not possible to register for the course B4M39DPG if the student is concurrently registered for or has previously completed the course BE4M39DPG (mutually exclusive courses).
- Course guarantor:
- Vlastimil Havran
- Lecturer:
- Vlastimil Havran
- Tutor:
- Vlastimil Havran
- Supervisor:
- Department of Computer Graphics and Interaction
- Synopsis:
-
This course provides you with the fundamentals of data structures commonly used in computer graphics. In contrast to standard binary search trees used in one dimension, the presented theory focuses on multidimensional data used to describe 3D scenes. In addition to the theory, the course emphasizes individual and team projects, where the importance and advantages of multidimensional data are demonstrated on practical examples. The students will gain practical experience through their own individual projects.
- Requirements:
-
Space and runtime complexity of algorithms, binary trees and heaps, tree balancing, search algorithms, priority queues, fundamentals of von Neumann architecture, and good knowledge of C++. The knowledge of C++ will be checked during the first exercise.
- Syllabus of lectures:
-
1. Lectures overview, review of sorting and searching, review of computer graphics algorithms, questions to the course, rules of the game. Introduction to hierarchical and regular data structures used in CG.
2. Incidence operations used in computer graphics
3. Point based representations and data structures
4. Object based and image based representations in 2D and 3D
5. Proximity search and its applications I.
6. Proximity search and its application II.
7. High-dimensional search algorithms.
8. Ray shooting and its applications I.
9. Ray shooting and its applications II.
10. Visibility algorithms based on z-buffer I.
11. Visibility algorithms based on z-buffer II.
12. Static collision detection.
13. Advanced collision detection.
14. Reserved.
- Syllabus of tutorials:
-
1. Introduction to the exercises, description of homework projects
2. Selection of term projects + consultations
3. Examples of incidence operations
4. Consultation to homework projects
5. Project presentations (4 participants)
6. Project presentations (4 participants)
7. Project presentations (4 participants)
8. Consultations to homework projects
9. Written test for 60 minutes (plus perhaps some presentations)
10. Project presentation (4 participants)
11. Project presentations (4 participants)
12. Consultation to the term projects.
13. Demonstration and evaluation of the projects (10x)
14. Demonstration and evaluation of the projects (10x)
- Study Objective:
-
Students will acquire credits on the basis of term project and it consists of achieved results, the source code documentation, project presentation and the project functionality. There will be a written test in the term. The extent of the exam is given by contents of lectures.
- Study materials:
-
1. Samet, H: The Design and Analysis of Spatial Data Structures, Addison Wesley 1994.
2. Samet, H: Applications of Spatial Data Structures, Addison Wesley, 1990.
3. Laurini, R. and Thompson D.: Fundamentals of Spatial Information Systems, Academic Press 1992.
4. Samet, H: Foundations of Multidimensional and Metric Data Structures, Morgan Kaufmann Publishers, 2006.
5. E. Langetepe and G. Zachmann: Geometric Data Structures for Computer Graphics, 2006.
6. C. Ericson: Real Time Collision Detection, Morgan Kauffman Publishers, 2005.
7. G. van den Bergen: Collision Detection in Interactive 3D Environments, Elsevier, 2004.
8. D. P. Mehta and S. Sahni: Handbook of Data Structures and Applications, Chapman and Hall/CRC, 2004
- Note:
- Further information:
- https://cw.fel.cvut.cz/wiki/courses/B4M39DPG
- Time-table for winter semester 2024/2025:
-
06:00–08:0008:00–10:0010:00–12:0012:00–14:0014:00–16:0016:00–18:0018:00–20:0020:00–22:0022:00–24:00
Mon Tue Wed Thu Fri - Time-table for summer semester 2024/2025:
- Time-table is not available yet
- The course is a part of the following study plans:
-
- Open Informatics - Computer Graphics (compulsory course of the specialization)