Graphics

Utrecht University - Information and Computing Sciences

academic year 2024/25 – 4th period

title image title image title image

Navigation

Course Overview

Exam & Grading

Extensions & Exceptions

Teaching Team

Schedule

Literature & Links

Voertaal / Instruction Language

Nederlands is de voertaal in de colleges en communicatie van deze cursus. Er wordt verwacht dat studenten Nederlands spreken.
Docenten die nog Nederlands aan het leren zijn, kunnen Engels praten. Cursusmateriaal en tentamens zijn Engelstalig.

Dutch is the instructional language in the delivery and communications of this course. Students are expected to speak Dutch.
Teachers who are still learning Dutch, may speak English instead. Course materials and exams will be in English.

Prerequisites back to navigation

Math: 2D Geometry and Algebra, equivalent to 'vwo Wiskunde B' in Dutch secondary education. This course includes a quick recap of these topics but prior knowledge is expected.

Programming: Ideally in C#, for example from the courses INFOB1GP or INFOIMP. This course requires that you can already program fluently. This course does not teach any programming. During this course there is not enough time to learn the necessary programming.

Course Overview back to navigation

bunny logo image

Course: "Graphics" is an introductory course about computer graphics. Computer graphics deals with the algorithmic processing of visual (images) and spatial (geometry) data. The course will focus on the very basics of modeling and rendering, i.e., the mathematical description of three-dimensional scenes and how to create (realistic) images of such models.

Rendering Algorithms: We have several options to convert the mathematical representation of a virtual world into a digital image. Modern games typically rely on the z-buffer algorithm. An alternative approach is ray tracing. In this course we will explore both methods. Ray tracing allows us to produce 'correct' images; rasterization lets us approximate this in real-time.

Math: An important aspect of computer graphics is the use of mathematics. This course provides a short coverage of the mathematical basics needed for rendering. We will introduce fundamental concepts of linear algebra and other areas of higher mathematics that are important far beyond the field of graphics.

The information on this website is static; announcements and discussions will be on Microsoft Teams. Please join the Team using the code that you can find on Blackboard.

This course takes place offline only, in person. Please join us on campus!
We expect that most of our communication will be offline during the lectures and tutorial sessions. Please use Teams as a way to interact with each other and with us, but we may not be able to respond quickly to Teams questions.

This course will be taught in English.

Teaching Team back to navigation

Lecturers:     (email both of us if you have a personal question that cannot be asked in Teams)

Student Assistants:

  •   Jens Steenmetz
  •   Sybren Lange
  •   Robin Schenkels
  •   Quân Tran
  •   Mathieu Chappin
  •   Hugo Krul
  •   Tijmen Vis
  •   Benjamin Blankers

Teaching Assistants:

  •   Victor Stenvers
  •   Ethan Waterink


Extensions and Exceptionsback to navigation

If you need to skip or postpone a deadline or an exam for any reason (e.g., health, family), the Education and Examination Regulations (EER) (degree-specific appendices) describe the following procedure:

Send an email to your study advisor, cc: the course coordinator (p.vangorp@uu.nl), as early as possible. This email should contain the following information:

  • Your name and student number
  • The affected course
  • The date and time of the affected exam or assignment deadline
  • Brief reason (no sensitive details needed in this initial email)
  • Your specific request, e.g., N days extension, or skip and do the retake
  • Ask the study advisor to send their recommendation to the course coordinator directly. (Your study advisor may not be aware of this step in the procedure!)
If necessary, the study advisor may discuss sensitive details with you in confidence. The course coordinator will confirm the outcome.


Topics back to navigation

Mathematics (50%)

Linear algebra

  • Points & vectors
  • Matrices & linear maps
  • Affine transformations
  • Linear systems & determinants

Projective geometry

  • Homogeneous coordinates
  • Projection matrices

Geometric modeling

  • Primitives (triangles, spheres, etc.)
  • Curves and surfaces
  • Differential properties / normals
 
Graphics (50%)

Raytracing

  • Ray-primitive intersections
  • Visibility queries
  • Data structures: acceleration structures
  • Shading: diffuse, glossy
  • Recursive ray tracing (shadows, reflections, refraction)

Rasterization

  • Camera models / perspective projection
  • Visibility algorithms
  • Data structures: scene graph
  • Rasterization pipeline
  • Shading: diffuse, glossy

This list is intended to give a rough orientation; topics are subject to change.


Course Schedule back to navigation

Period 4 Schedule

Week
Date
Time & Location
Lecture
Tutorial
Practical
17 Tue Apr 22 9:00 - 10:45
Ruppert BLAUW
Introduction
Math: Vectors

11:00 - 12:45
BBG 201, 209, 214, 219

Math: Vectors
Thu Apr 24 13:15 - 15:00
Ruppert BLAUW
Math: 2D Geometry

15:15 - 17:00
BBG 201, 209, 214, 219

Math: 2D Geometry
18 Tue Apr 29
9:00 - 10:45
Ruppert BLAUW
Math: 3D Geometry
11:00 - 12:45
BBG 201, 209, 214, 219

Math: 3D Geometry
Thu May 1
13:15 - 15:00
Ruppert BLAUW
Graphics: Ray Tracing

Assignment P1:

Ray Tracing

15:15 - 17:00
BBG 201, 209, 214, 219

Practical #1 Support
19
Tue May 6
9:00 - 10:45
Ruppert BLAUW
Graphics: Shadows and Shading
11:00 - 12:45
BBG 201, 209, 214, 219

Exam Preparation
Thu May 8 13:30 - 15:30
Educ GAMMA
MIDTERM EXAM
20
Tue May 13
9:00 - 10:45
Ruppert BLAUW
Graphics: Reflection and Refraction
11:00 - 12:45
BBG 201, 209, 214, 219

Practical #1 Support
Thu May 15
13:15 - 15:00
Ruppert BLAUW
Graphics: Texturing
15:15 - 17:00
BBG 201, 209, 214, 219

Practical #1 Support
21 Tue May 20
9:00 - 10:45
Ruppert BLAUW
Graphics: Advanced Ray Tracing
11:00 - 12:45
BBG 201, 209, 214, 219

Practical #1 Support
Thu May 22
13:15 - 15:00
Ruppert BLAUW
Math: Matrices
15:15 - 17:00
BBG 201, 209, 214, 219

Math: Matrices P1 Deadline:
Mon May 26, 17:00
22 Tue May 27 9:00 - 10:45
Ruppert BLAUW
Math: Transformations

Assignment P2:

Rasterization
11:00 - 12:45
BBG 201, 209, 214, 219

Math: Transformations
Thu May 29
ASCENSION
23 Tue Jun 3
9:00 - 10:45
Ruppert BLAUW
Graphics: Rasterization

11:00 - 12:45
BBG 201, 209, 214, 219

Exam Preparation
Thu Jun 5 13:30 - 15:30
Educ BETA & GAMMA
FINAL EXAM
24 Tue Jun 10 9:00 - 10:45
Ruppert BLAUW
Graphics: OpenGL

11:00 - 12:45
BBG 201, 209, 214, 219

Practical #2 Support
Thu Jun 12 13:15 - 15:00
Ruppert BLAUW
Graphics: More Modern OpenGL
15:15 - 17:00
BBG 201, 209, 214, 219

Practical #2 Support
25 Tue Jun 17 9:00 - 10:45
Ruppert BLAUW
Graphics: Shaders

11:00 - 12:45
BBG 201, 209, 214, 219

Practical #2 Support
Thu Jun 19 13:15 - 15:00
Ruppert BLAUW
Practical #2 Support

15:15 - 17:00
BBG 201, 209, 214, 219

Practical #2 Support
26

(exam week for other courses)
P2 Deadline:
Fri Jun 27, 17:00



...
28
Thu Jul 10
13:30 - 15:30
Educ BETA
RETAKE EXAM
Practical Retake Deadline:
Fri Jul 11, 17:00

 


Math Tutorials & Examsback to navigation



MATH TUTORIALS

There will be math assignments during a number of weeks. The exercises cover the topics discussed in the math lectures. We highly recommend that you work on all the assignments as we put a special effort to make sure they prepare you well for the exam.

IMPORTANT RULES
  • You are supposed to work alone on the exercises, for the reason that they prepare you for the exam, which is also individual.
  • As much as possible, you are expected to prepare the solution for the exercises before the tutorial session. So, for example, before the tutorial session on April 22 you should have finished as many exercises on Vectors as you can with your prior math knowledge.
  • Presence at the Math tutorial sessions (certain Tuesdays and Thursdays, immediately after the lecture) is mandatory, as solutions for a selection of exercises will be discussed and you will get a chance to ask questions.
  • Please use the Teams channel "Math Tutorials" to ask questions about the exercises but only do this in two cases:
    • if for some good reason you were not able to attend the corresponding Math tutorial session, or
    • if you don't understand the question of the exercise.
    Make sure your question is concise and suitably specific. We cannot help you if you just state ‘I do not understand this exercise’.

MATH TUTORIAL SOLUTIONS

We will not provide solution sheets for the Math tutorial exercises. There are several other ways to check your answers: ask in the next tutorial session, ask on Teams, confirm with another calculation, ask Wolfram Alpha, or compare with classmates. Each of those ways is an opportunity to learn more math/tools/skills.

MATH EXAMS

The exams will take place on campus, digitally, on university computers, using the Remindo system. Bring a pen/pencil so you can sketch geometry questions or do calculations on paper. You're allowed to bring a simple calculator that cannot draw graphs, solve equations, or do matrix/vector math. Remindo also has a simple calculator built in.

Graphics Practicals back to navigation


PRACTICAL ASSIGNMENTS

There will be two practical assignments, covering the two main rendering algorithms: ray tracing (P1) and rasterization (P2). A suggested programming template for P1 will be available on the first day of the course. We recommend that you start familiarizing yourself with it right away.

Important Rules

Because of the large group of students taking this course, we need strict rules to keep everything manageable.

  • Presence at the Practicals Support sessions (certain Tuesdays and Thursdays, immediately after the lecture) is strongly recommended. During these sessions, you should bring your laptop so you can work on the practicals and get help from your classmates and from us.
  • Working in teams: The programming assignments are designed for groups of three students. You may however also work on the assignments in a group of two or alone. Details:
    • Working in a group of two or alone: There is no penalty for working in a group of two or alone on the assignments, but you will be expected to complete the same amount of work as a three-person team. It is however not allowed to work in a team of four or more students.
    • Building groups: You can choose your teammates yourself among your fellow students. If you cannot find teammates on your own, ask on the Teams channel "Finding Teammates" or during the tutorial sessions. We will help you to team up with other students.
    • If a teammate drops the course: This is a risk of working in groups. You may continue working with the materials that you produced together. However, you cannot continue working on these materials with a new teammate.
    • Project team responsibility: It is up to you how you split the work among your team members. However, this freedom comes at the price that you have to be prepared for situations such as team members dropping the course or not delivering what they promised to you. It is your responsibility to make sure that you are aware of your team's progress, so you can react to such issues in an appropriate way.
  • Plagiarism:
    • We use an automated plagiarism detection system. Suspected plagiarism must always be reported to the exam board and may have severe consequences.

    • Do not store or share your projects publicly, e.g., in a public GitHub repository. If your code is found and used by another team, you may be complicit in their plagiarism and also face consequences. Sharing ideas is fine, of course.

    • We recognize the value of AI assistive technologies for programming such as ChatGPT or Copilot to understand and improve code. However, such tools tend to produce code that they have copied ("learned") from online sources. If that's more than a few lines of code, that will likely be detected as plagiarism and will be treated as such.


Soft- / Hardware and Infrastructure:

  • Required equipment: For the practicals, you need a Windows PC with Visual Studio. The free Community Edition of Visual Studio 2022 is a good platform for C# development. We will be using the open-source OpenTK library to access OpenGL from C#.
  • Alternative platforms: For this course, support will be mostly limited to Microsoft Windows and C#. You may of course use alternative platforms and programming languages, but an appropriate level of autonomy is expected in that case.


(1) Ray Tracing

In the first assignment you will create a basic ray tracer, featuring shadows, reflections and refraction.

Assignment details will be announced during the course.

 
(2) Real-time Rasterizer

In the second assignment you will create a basic 3D engine using hardware rasterization via OpenGL.

Assignment details will be announced during the course.


Assignment P1

This assignment is all about ray tracing. You can find all the details in the formal assignment description.

Please find the following Files on Teams:

  • C# / OpenTK template
  • Assignment description including optional honours assignment (pdf)
Deadline(s):
  • Monday, May 26, 17:00 (hard deadline, late submissions will not be graded)
  • Hand-in on Blackboard

 

Assignment P2

For this final assignment, you will be creating a small OpenGL-based rasterizer engine. Details are in the formal assignment description.

Please find the following Files on Teams:

  • C# / OpenTK template with post-processing example
  • Assignment description (pdf)
Deadline(s):
  • Friday, June 27, 17:00 (hard deadline, late submissions will not be graded)
  • Hand-in on Blackboard

Exam & Grading back to navigation

GRADING

Programming assignments: There will be two programming assignments throughout the course. The final grade P for your programming assignments is the average of the two grades for the assignments: P = (P1+P2)/2. P must be at least 5.0 (before rounding) to pass the course.

Exams: There will be a midterm exam T1 and a final exam T2. The final grading T for your exams is calculated as follows: T = 0.3*T1 + 0.7*T2. T must be at least 5.0 (before rounding) to pass the course.

Final grade: If both T (= the grade for the exams) and P (= the programming grade) are at least 5.0, the final grade for the course is (T + P) / 2. Your final grade must be at least 6 (after rounding) to pass the course.

RETAKES AND REQUIREMENTS

You are entitled to participate in one retake if:

  • you participated in all graded assignments and exams and your final grade was at least 4.0 but less than 6 (after rounding); or
  • you missed 1 graded assignment or exam and you obtained an exception by following the extension procedure.

This can either be a retake assignment or a retake exam. Criteria for passing stay the same as indicated above.

Retake final exam (T2): This exam will cover all lectures and tutorials.

Retake practical (P1 or P2): This retake assignment can replace either P1 or P2 and must be made individually, not as a group.

Literature & Links back to navigation

Textbook:

Additional free online resources that might be helpful:

About this course: