(12 intermediate revisions by 2 users not shown)
Line 26: Line 26:
  
 
*[https://docs.google.com/spreadsheets/d/1emeCZo3fX5lgA-hOB-lgllLghS-0LDdW1rxdNXFWx_o/edit?usp=sharing '''VIEW RESULTS''']
 
*[https://docs.google.com/spreadsheets/d/1emeCZo3fX5lgA-hOB-lgllLghS-0LDdW1rxdNXFWx_o/edit?usp=sharing '''VIEW RESULTS''']
*[https://moodle.uniba.sk/course/view.php?id=2164 Final Term] by Comenius University Moodle Electronic test 17.5 8:00 )
+
*[https://docs.google.com/document/d/1SMJ4-SlsqxaXfO6dWtE5kEa57Vc5khEw9YPKakWdo_Q/edit?usp=sharing '''EXERCISE FEEDBACK DOCUMENT''']
 +
*[https://moodle.uniba.sk/course/view.php?id=2164 Final Term] by Comenius University Moodle Electronic test 16.5 8:00 )
 
* Before the test exam you can try to solve many tests from the graphics page, is you can pass the example test then you have big chance to pass the test exam.  
 
* Before the test exam you can try to solve many tests from the graphics page, is you can pass the example test then you have big chance to pass the test exam.  
  
Line 144: Line 145:
 
= Seminars on Advanced Computer Graphics  =
 
= Seminars on Advanced Computer Graphics  =
  
On wednesdays at 9:50 [https://teams.microsoft.com/l/channel/19%3a940702169208456d80b2bd374bfdc14b%40thread.tacv2/Cvi%25C4%258Denia?groupId=ef1d5f0e-c528-46c9-8b30-3e704e8af8ee&tenantId=ce31478d-6e7a-4ce7-8670-a5b9d51884f9 On Teams]
+
On Wednesdays at 8:10 at [https://teams.microsoft.com/l/meetup-join/19%3a940702169208456d80b2bd374bfdc14b%40thread.tacv2/1644847529062?context=%7b%22Tid%22%3a%22ce31478d-6e7a-4ce7-8670-a5b9d51884f9%22%2c%22Oid%22%3a%2284c6d7a6-7722-4fe4-8e1b-0989d01277e3%22%7d Microsoft Teams] (possibly in-person later in the semester).
  
'''Guide:''' Adam Riečický
+
See [https://liveuniba.sharepoint.com/:f:/s/2-AIN-12715-Pokroilpotaovgrafika/Eme5y4JAIIVJjh5fKSgryQgBPF8LIrh4mt0nWBG5vpQXPw?e=OkGBlo recordings] from previous year.
  
'''Contact:''' adam.riecicky@fmph.uniba.sk
+
See feedback [https://docs.google.com/document/d/1SMJ4-SlsqxaXfO6dWtE5kEa57Vc5khEw9YPKakWdo_Q/edit?usp=sharing document] with comments on submitted solutions of exercises.
 +
 
 +
'''Guide:''' Lukáš Gajdošech
 +
 
 +
'''Contact:''' lukas.gajdosech@fmph.uniba.sk
  
 
== Info ==
 
== Info ==
 
Each week a short guided presentation will be given.
 
Each week a short guided presentation will be given.
  
An assignment for every week will be finishing a template C# project. The deadline for every project is ''' right before the next successive seminar - Wednesday at 9:50'''. The extended deadline is a week after with 0.5x penalization. Solutions to bonus assignment can be submitted anytime during the 2 weeks without the penalization.
+
An assignment for every week will be finishing a template C# project. The deadline for every assingment is ''' midnight before the next successive seminar'''. The extended deadline is a week after with 0.5x penalization. Solutions to bonus assignment can be submitted anytime during the 2 weeks without the penalization.
  
 
=== Grading ===
 
=== Grading ===
Line 174: Line 179:
 
* Submission email must have the '''subject in the form of 'ACG ExNN'''' where NN is the exercise id, eg. ACG Ex05.
 
* Submission email must have the '''subject in the form of 'ACG ExNN'''' where NN is the exercise id, eg. ACG Ex05.
 
* Solution source codes have to be '''archived and named properly 'ExNN_YourName''''
 
* Solution source codes have to be '''archived and named properly 'ExNN_YourName''''
* Do not archive send executable files.  
+
* Do not archive and send executable files.  
* Send by email to [mailto:adam.riecicky@fmph.uniba.sk  adam.riecicky@fmph.uniba.sk].
+
* Send by email to [mailto:lukas.gajdosech@fmph.uniba.sk  lukas.gajdosech@fmph.uniba.sk].
  
 
== Exercises ==
 
== Exercises ==
  
<!---
+
=== Exercise00 "Introduction" ===
=== Introduction ===
+
 
* Motivation?
 
* Motivation?
 
** [http://goo.gl/5YLSxN 1st Octane], [http://goo.gl/J0E8qM 2nd Octane], [http://goo.gl/xVMEIk 3rd Octane]
 
** [http://goo.gl/5YLSxN 1st Octane], [http://goo.gl/J0E8qM 2nd Octane], [http://goo.gl/xVMEIk 3rd Octane]
Line 191: Line 195:
 
* Intro to c#?
 
* Intro to c#?
 
** [http://www.amazon.com/Microsoft-Visual-2010-Step/dp/0735626707 Visual c# 2010], [http://www.amazon.com/4-0-Nutshell-The-Definitive-Reference/dp/0596800959 c# 4.0 in a Nutshell]
 
** [http://www.amazon.com/Microsoft-Visual-2010-Step/dp/0735626707 Visual c# 2010], [http://www.amazon.com/4-0-Nutshell-The-Definitive-Reference/dp/0596800959 c# 4.0 in a Nutshell]
** [http://www.dofactory.com/ShortCutKeys/ShortCutKeys.aspx Visual Shortcuts], [http://www.shortcutworld.com/en/win/SharpDevelop_4.0.html SharpDevelop Short cuts]
+
** [https://www.dofactory.com/visual-studio-shortcuts Visual Studio Shortcuts], [http://www.shortcutworld.com/en/win/SharpDevelop_4.0.html SharpDevelop Short cuts]
--->
+
  
=== Exercise00 "Vectors and Matrices" ===
+
 
'''Deadline (no extended deadline): ''' 3.3.2021 at 23:59
+
=== Exercise01 "Vectors and Matrices" ===
 +
'''Deadline (no extended deadline): ''' 1.3.2022 at 23:59
  
 
'''Asignment:'''
 
'''Asignment:'''
 
Create a simple application for vector(4x1) and matrix operations(4x4).
 
Create a simple application for vector(4x1) and matrix operations(4x4).
 
Use struct properties, functions and/or operators. Create a calculator, check your equations and results.
 
Use struct properties, functions and/or operators. Create a calculator, check your equations and results.
Add implementation to theese files in folder ''./Mathematics/'' : ''Vector4.cs'', ''MathEx.cs'', and "Matrix44.cs''
+
Add implementation to theese files in folder ''./Mathematics/'' : ''Vector4.cs'', ''MathEx.cs'', and ''Matrix44.cs''.
  
 
'''You can ignore vector operations "/" (vector projection) and "^" (modulation product).'''
 
'''You can ignore vector operations "/" (vector projection) and "^" (modulation product).'''
  
For a help, see [https://chortle.ccsu.edu/vectorlessons/vectorindex.html this reminder on linear algebra]  
+
For a help, see [https://chortle.ccsu.edu/vectorlessons/vectorindex.html this reminder on linear algebra] and/or useful [http://learnwebgl.brown37.net/transformations2/transformations_matrices.html tutorial on transformation matrices].
 
*[[media:CG1.Ex01.Sample.zip|Sample]] | [[media:CG1.Ex01.Template.zip‎|Template]]
 
*[[media:CG1.Ex01.Sample.zip|Sample]] | [[media:CG1.Ex01.Template.zip‎|Template]]
  
  
=== Exercise01 "Ray Casting" ===
+
=== Exercise02 "Ray Casting" ===
'''Deadline (no extended deadline):''' 10.3.2021 at 23:59
+
'''Deadline (no extended deadline):''' 8.3.2022 at 23:59
  
 
[https://docs.google.com/presentation/d/1qfbRX35LpC72wCmBLcaftWsIUqFF7Ej6fBn4NGFoKMc/edit?usp=sharing Seminar slides]
 
[https://docs.google.com/presentation/d/1qfbRX35LpC72wCmBLcaftWsIUqFF7Ej6fBn4NGFoKMc/edit?usp=sharing Seminar slides]
Line 222: Line 226:
  
  
=== Exercise02 "Primitives" ===
+
=== Exercise03 "Primitives" ===
'''Deadline:''' 10.3.2021 at 9:50
+
'''Deadline:''' 15.3.2022 at 23:59
'''Extended deadline:''' 17.3.2021 at 9:50
+
'''Extended deadline:''' 22.3.2022 at 23:59
  
 
[https://docs.google.com/presentation/d/1QqosOvNF8QMCX_AvhbjhgO2Kbc1ehBI6aomLubBKpdQ/edit?usp=sharing Seminar Slides]
 
[https://docs.google.com/presentation/d/1QqosOvNF8QMCX_AvhbjhgO2Kbc1ehBI6aomLubBKpdQ/edit?usp=sharing Seminar Slides]
Line 240: Line 244:
  
  
=== Exercise03 "Shaders, Shading and Shadows" ===
+
=== Exercise04 "Shaders, Shading and Shadows" ===
'''Deadline:''' 17.3.2021 at 9:50
+
'''Deadline:''' 22.3.2022 at 23:59
'''Extended deadline:''' 24.3.2021 at 9:50
+
'''Extended deadline:''' 29.3.2022 at 23:59
  
 
[https://docs.google.com/presentation/d/1q_n3gjcUHZ8Nr7ma6EJXmE9RJxMHj1bmysQnKQwzb3U/edit?usp=sharing Seminar Slides]
 
[https://docs.google.com/presentation/d/1q_n3gjcUHZ8Nr7ma6EJXmE9RJxMHj1bmysQnKQwzb3U/edit?usp=sharing Seminar Slides]
  
 
'''Asignment:'''
 
'''Asignment:'''
Improve your tracer by implementing Phong and checker shaders, directional light, and hard shadows. Compute normals of each primitive at the point of intersection. As usual, you should use a similar functionality as in the sample application.
+
Improve your tracer by implementing Phong and checker shaders, directional light, and hard shadows. Compute normals of each primitive at the point of intersection. As usual, you should get a similar functionality as in the sample application.
 
* [[media:CG2.Ex03.Sample.zip | Sample]] | [[media:CG2.Ex03.Template.zip | Template]]  
 
* [[media:CG2.Ex03.Sample.zip | Sample]] | [[media:CG2.Ex03.Template.zip | Template]]  
  
  
=== Exercise04 "Light Types" ===
+
=== Exercise05 "Light Types" ===
'''Deadline:''' 24.3.2021 at 9:50
+
'''Deadline:''' 29.3.2021 at 23:59
'''Extended deadline:''' 31.3.2021 at 9:50
+
'''Extended deadline:''' 5.4.2022 at 23:59
  
 
[https://docs.google.com/presentation/d/1BefIrufgieVVjSyr5R65CKWFwuxBaj2CGhXIx_58CNA/edit?usp=sharing Seminar Slides]
 
[https://docs.google.com/presentation/d/1BefIrufgieVVjSyr5R65CKWFwuxBaj2CGhXIx_58CNA/edit?usp=sharing Seminar Slides]
Line 265: Line 269:
  
  
=== Exercise05 "Shaders" ===
+
=== Exercise06 "Shaders" ===
'''Deadline:''' 31.3.2021 at 9:50
+
'''Deadline:''' 5.4.2022 at 23:59
'''Extended deadline:''' 7.4.2021 at 9:50
+
'''Extended deadline:''' 12.4.2022 at 23:59
  
 
[https://docs.google.com/presentation/d/1nJxdeN_NfT_45Fn7z_d-Vh3sS-NZcYWbRslSPudYKxw/edit?usp=sharing Seminar Slides]
 
[https://docs.google.com/presentation/d/1nJxdeN_NfT_45Fn7z_d-Vh3sS-NZcYWbRslSPudYKxw/edit?usp=sharing Seminar Slides]
Line 281: Line 285:
  
  
=== Exercise06 "Reflections" ===
+
=== Exercise07 "Reflections" ===
'''Deadline:''' 7.4.2021 at 9:50
+
'''Deadline:''' 12.4.2022 at 23:59
'''Extended deadline:''' 14.4.2021 at 9:50
+
'''Extended deadline:''' 19.4.2022 at 23:59
  
 
[https://docs.google.com/presentation/d/1GNhGJqi-ELtQMMUU2RvHqTa_0U2oJQLHEyAh-dvIzoQ/edit?usp=sharing Seminar Slides]
 
[https://docs.google.com/presentation/d/1GNhGJqi-ELtQMMUU2RvHqTa_0U2oJQLHEyAh-dvIzoQ/edit?usp=sharing Seminar Slides]
Line 292: Line 296:
  
  
=== Exercise07 "Transparency" ===
+
=== Exercise08 "Transparency" ===
'''Deadline:''' 14.4.2021 at 9:50
+
'''Deadline:''' 19.4.2022 at 23:59
'''Extended deadline:''' 21.4.2021 at 9:50
+
'''Extended deadline:''' 26.4.2022 at 23:59
  
 
[https://docs.google.com/presentation/d/1XxI2xLD8UFpLSICbP5f09biCb8DAaxrM0nmxto2-bL4/edit?usp=sharing Seminar Slides]
 
[https://docs.google.com/presentation/d/1XxI2xLD8UFpLSICbP5f09biCb8DAaxrM0nmxto2-bL4/edit?usp=sharing Seminar Slides]
Line 306: Line 310:
  
  
=== Exercise08 "Postprocessing" ===
+
=== Exercise09 "Postprocessing" ===
'''Deadline:''' 5.5.2021 at 9:50
+
'''Deadline:''' 3.5.2022 at 23:59
'''Extended deadline:''' 12.5.2021 at 9:50
+
'''Extended deadline:''' 10.5.2022 at 23:59
  
 
[https://docs.google.com/presentation/d/1CxRs7VM0ZEMMq-m4BCklmpTWJyFDQDb_XPunFWeFtMU/edit?usp=sharing Seminar slides]
 
[https://docs.google.com/presentation/d/1CxRs7VM0ZEMMq-m4BCklmpTWJyFDQDb_XPunFWeFtMU/edit?usp=sharing Seminar slides]
Line 315: Line 319:
 
* [[media:CG2.Ex08.Sample.zip | Sample]] | [[media:CG2.Ex08.Template.zip | Template]]
 
* [[media:CG2.Ex08.Sample.zip | Sample]] | [[media:CG2.Ex08.Template.zip | Template]]
  
 +
<!--
 
'''[2 bonus %]:'''  
 
'''[2 bonus %]:'''  
 
Implement DOF. You can use the definition from blur to create a fake DOF. A user can define a point of sharpness and the intensity of the effect.
 
Implement DOF. You can use the definition from blur to create a fake DOF. A user can define a point of sharpness and the intensity of the effect.
 +
-->
  
 
<!--
 
<!--
Line 329: Line 335:
 
* Submit your results as a regular submission by mail
 
* Submit your results as a regular submission by mail
  
 
+
=== Exercise09 "Textures" ===
 
+
<!--=== Exercise09 "Textures" ===
+
 
[[media:CG2.Ex09.pdf‎ | Seminar slides]]
 
[[media:CG2.Ex09.pdf‎ | Seminar slides]]
  
Line 347: Line 351:
 
Implement repeat and mirror texture sampling and bilinear texture filtering.
 
Implement repeat and mirror texture sampling and bilinear texture filtering.
  
'''Deadline : 7.5. - 16:30'''
+
=== ExerciseChicken "The One About Chickens" ===
 
+
=== AMA "Ask Me Anything" ===
+
Send your questions in advance to homework email
+
 
+
[https://docs.google.com/presentation/d/1RtsxHpjtC_Rfh3tKd7u4cQYNqi71lvOP7XUnzlI-rS4/edit#slide=id.p29 Slides]
+
 
+
=== Final Term "Final Term" ===
+
* Final test in moodle
+
* Oral exam afterwards for successful students
+
 
+
=== [20.05.2015] "Final Term" ===
+
 
+
=== ExerciseChicken [01.04.2015] "The One About Chickens" ===
+
 
* [[media:CG2.ExChicken.pdf‎ | Chicken slides]]
 
* [[media:CG2.ExChicken.pdf‎ | Chicken slides]]
 
* Improve your chickener by adding a few more shaders: Chicken, Cooked-Chicken, Chicken-Nyan. As usual, you should use a similar functionality as in the sample application.
 
* Improve your chickener by adding a few more shaders: Chicken, Cooked-Chicken, Chicken-Nyan. As usual, you should use a similar functionality as in the sample application.
  
=== Exercise05 [02.04.2014] "More About Shaders" ===
+
=== Exercise05 "More About Shaders" ===
 
* Improve your tracer by adding a few procedural shaders: noise, turbulence / clouds / marble, stripes, gradient, wood. For inspiration and additional material start here - [http://wiki.blender.org/index.php/Doc:2.6/Manual/Textures/Types/Procedural]. As usual you should use a similar functionality as in the sample application.
 
* Improve your tracer by adding a few procedural shaders: noise, turbulence / clouds / marble, stripes, gradient, wood. For inspiration and additional material start here - [http://wiki.blender.org/index.php/Doc:2.6/Manual/Textures/Types/Procedural]. As usual you should use a similar functionality as in the sample application.
 
* ''''[2 bonus %]:'''  
 
* ''''[2 bonus %]:'''  
Line 370: Line 361:
 
* [http://www.sccg.sk/~hudak/CG2/Ex05.Sample.zip Sample] | [http://www.sccg.sk/~hudak/CG2/Ex05.Template.zip Template]
 
* [http://www.sccg.sk/~hudak/CG2/Ex05.Sample.zip Sample] | [http://www.sccg.sk/~hudak/CG2/Ex05.Template.zip Template]
  
=== Exercise07 [16.04.2014] "The One About Acceleration" ===
+
=== Exercise07 "The One About Acceleration" ===
 
* Implement accelerating structure for ray tracing. The structure is KD Trees + surface area heuristic (SAH) [http://www.sccg.sk/~durikovic/classes/CG2/Handouts/CG03-kdtrees.pdf] (4.4.2). The dimension is 2. Go. As usual you should use a similar functionality as in the sample application [http://www.sccg.sk/~durikovic/classes/CG2/Handouts/CG03RT-II.pdf].
 
* Implement accelerating structure for ray tracing. The structure is KD Trees + surface area heuristic (SAH) [http://www.sccg.sk/~durikovic/classes/CG2/Handouts/CG03-kdtrees.pdf] (4.4.2). The dimension is 2. Go. As usual you should use a similar functionality as in the sample application [http://www.sccg.sk/~durikovic/classes/CG2/Handouts/CG03RT-II.pdf].
 
* Physically based rendering could help [http://www.amazon.com/Physically-Based-Rendering-Second-Edition/dp/0123750792]
 
* Physically based rendering could help [http://www.amazon.com/Physically-Based-Rendering-Second-Edition/dp/0123750792]
Line 382: Line 373:
 
** '''Special bonus deadline:''' 17.5. - 23:59
 
** '''Special bonus deadline:''' 17.5. - 23:59
  
=== [21.05.2014] "Final Term" ===
+
=== AMA "Ask Me Anything" ===
 +
Send your questions in advance to homework email
 +
 
 +
[https://docs.google.com/presentation/d/1RtsxHpjtC_Rfh3tKd7u4cQYNqi71lvOP7XUnzlI-rS4/edit#slide=id.p29 Slides]
 +
 
 +
=== Final Term "Final Term" ===
 +
* Final test in moodle
 +
* Oral exam afterwards for successful students
 
-->
 
-->

Latest revision as of 20:38, 15 May 2022

Cg2 2014.png

Advanced Computer Graphics

What you Need to Pass

  • Attend lessons. One missed +0 points. 2 missed 0 points, 3 missed 0 points, 4 and more is Fx.
  • Project and exercise (mandatory, 10+50 points).
  • Solve all homework problems (mandatory each one >=30%, 10 points)
  • Pass final term (mandatory, 20 points) You will need to solve several problems discussed during lessons.
  • Pass oral/written exam: (mandatory, +20 points)
  • Summary
    • Attendance = 0 or -100 (Fx)
    • Exercise = +50..0
    • Bonus = +10..0 (optional)
    • Homework = +10..4 or +4..0 (Fx)
    • Final term = +20..0
    • Oral/written exam = +20..0
  • Grades
   A = 92-100
   B = 84-91
   C = 76-83
   D = 68-75
   E = 60-67
   Fx = 0-59
  • VIEW RESULTS
  • EXERCISE FEEDBACK DOCUMENT
  • Final Term by Comenius University Moodle Electronic test 16.5 8:00 )
  • Before the test exam you can try to solve many tests from the graphics page, is you can pass the example test then you have big chance to pass the test exam.
  • Schedule
    • Mon (15:40) - Online MS Teams (lecture)
    • Wed (8:10) - (excercises)

Materials to read


Lecture00 "Introduction to Computer Graphics"

  • Computer Graphics Applications

Lecture01 "Graphics Pipeline"

  • What is The Graphics Pipeline
  • Vertex Shader
  • Primitive Assembly
  • Tessellation Shaders
  • Geometry Shader
  • Geometry Postprocessing and Rasterization
  • Fragment Shader
  • Frame Buffer Operations
  • http://www.lighthouse3d.com/tutorials/glsl-core-tutorial/pipeline33/
  • Lecture notes: lesson00.pdf [1]
  • Štátnicová téma: Zobrazovací kanál. Grafická pipeline moderného hardvéru, framebuffer, buffer objekty, používané súradnicové priestory, druhy shader programov, druhy optimalizačných techník (view frustum, occlusion, backface culling), príklad shader programov.

Lecture02 "Ray Tracing 1."

Lecture03 "Ray Tracing 2."

Lecture04 "Ray Tracing 3."

  • Ray Tracing Acceleration
  • Data structure: grids, BVH, Kd-tree, Directional Partitioning
  • Dynamic Scenes
  • Beam and Cone Tracing
  • Packet Tracing
  • Lecture notes: lesson02.pdf
  • Poznámky v Slovenčine k téme Dátové Štruktúry a Kd-tree.
  • Štátnicová téma: Kanál metódy sledovania lúča a porovnanie s Radiosity metódou. (definícia lúča, definícia tieňového lúča, popis metódy sledovania lúča, generovanie lúča, pochod po lúči (ray traversal), prienik lúča s trojuholníkom, stromová štruktúra lúčov (ray tree) a jej použitie na výpočet lokálnej farby, problém presnosti priesečníkov). Metóda sledovania lúča na GPU, urýchľovacie techniky.

Lecture05 "Shading."

  • OPENGL Light sources
  • Shading Phong model
  • First time meeting with Rendering Equation
  • Book chapter Shading: shading.pdf

Lecture06 "Light Trasport."

  • Physics behind ray tracing
  • Physical light quantities
  • Visual perception of light
  • Light sources
  • Light transport simulation: Rendering Equation
  • Lecture notes: lesson05.pdf
  • Štátnicová téma: Fyzikálny osvetlovací model a výpočet farieb renderovacou rovnicou. (definícia radiancie, definícia BRDF a jej vlastnosti, fyzikálne BRDF Cook-Tarrance, definícia priestorového uhlu, napíšte renderovaciu rovnicu a vysvetlite jej členy).

Lecture07 "Radiosity."

  • Diffuse reflectance function
  • Radiative equilibrium between emission and absorption, escape
  • System of linear equations
  • Iterative solution Neuman series
  • Lecture notes: lesson05.pdf
  • Book chapter Shading: shading.pdf

Lecture08 "BRDF."

  • Bidirectional Reflectance Distribution Function (BRDF)
  • Reflection models
  • Projection onto spherical basis functions
  • Shading Phong model, Blin-Phong model
  • Lecture notes: lesson07.pdf
  • Homework:
    • 1. Prove that the mirror BRDF from slides less07 fulfills the BRDF properties: reciprocity, energy conservation, definit space, value space of BRDF
    • 2. Derive the equation for refracted direction Omega_r from shading document in section 6.3.3.
  • Physical BRDF
  • Ward Reflection Model
  • Cook-Torrance model
  • Lecture notes: lesson07Phys.pdf

Lecture09, Lecture10 "Shadows."

  • Lecture notes: lesson08.pdf
  • Štátnicová téma: Tiene, typy tieňov (mäkké, tvrdé, statické, dynamické), typy a popis algoritmov (projekčné, tieňové objemy, tieňové mapy (shadow mapping)), spôsoby implementácie jednotlivých algoritmov, artefakty a ich odstraňovanie, príklad shader programov pre tieňové mapy. Artefakty spôsobené diskretizáciou. Tiene vo Phongovom modeli.

Lecture11, Lecture12 "Texturing 1, 2."

  • Texture parameterization
  • Procedural methods
  • Procedural textures
  • Fractal landscapes
  • Lecture notes: lesson09.pdf
  • Book chapter (Surface reality techniques): lessonBoook09.pdf
  • Štátnicová téma: Lokálne osvetľovacie modely. (tieňovanie, Phongov a Blinn-Phongov osvetlovací model, zložky (ambientna, difúzna, zrkadlová), textúrovanie a druhy textúr, mapovanie a filtrácia textúr, popísať princípy environment, bump, normal mapovania, textúrovací a tangenciálny priestor, príklad shader programov na GPU.

Lecture13 "Image Based Rendering 1."

  • Plenopticfunction
  • Panoramas
  • Concentric Mosaics
  • Light Field Rendering
  • The Lumigraph
  • Lecture notes: lesson10.pdf
  • Homework: Blinn-Phong enumeration.

Lecture14 "Image Based Rendering 2."

  • Layered Depth Images
  • View-dependent Texture Mapping
  • Surface Light Fields
  • View Morphing
  • Lecture notes: lesson10.pdf

Lecture15 "Ask me anything."

  • Test problem introduction

Seminars on Advanced Computer Graphics

On Wednesdays at 8:10 at Microsoft Teams (possibly in-person later in the semester).

See recordings from previous year.

See feedback document with comments on submitted solutions of exercises.

Guide: Lukáš Gajdošech

Contact: lukas.gajdosech@fmph.uniba.sk

Info

Each week a short guided presentation will be given.

An assignment for every week will be finishing a template C# project. The deadline for every assingment is midnight before the next successive seminar. The extended deadline is a week after with 0.5x penalization. Solutions to bonus assignment can be submitted anytime during the 2 weeks without the penalization.

Grading

  • Total points from exercises make half of your final grade!
  • Minimum of 50% from exercises required to finish the class successfully
  • Late submission is for 0, no discussion

Project Evaluation Criteria

  • 10 pt => Correct submission, everything works as supposed.
  • 6 pt => Partially correct submission, most of the things work as supposed.
  • 3 pt => Partially correct submission, at least one core functionality correct.
  • 0 pt => Incorrect submission or unsubmitted.
  • Penalization 0.5x when submitting in extended deadline (not for bonus).

Project Submittion

  • Your code should be well formatted and commented. Titles of functions, classes, variables should be representative of their purpose.
  • Submission email must have the subject in the form of 'ACG ExNN' where NN is the exercise id, eg. ACG Ex05.
  • Solution source codes have to be archived and named properly 'ExNN_YourName'
  • Do not archive and send executable files.
  • Send by email to lukas.gajdosech@fmph.uniba.sk.

Exercises

Exercise00 "Introduction"


Exercise01 "Vectors and Matrices"

Deadline (no extended deadline): 1.3.2022 at 23:59

Asignment: Create a simple application for vector(4x1) and matrix operations(4x4). Use struct properties, functions and/or operators. Create a calculator, check your equations and results. Add implementation to theese files in folder ./Mathematics/ : Vector4.cs, MathEx.cs, and Matrix44.cs.

You can ignore vector operations "/" (vector projection) and "^" (modulation product).

For a help, see this reminder on linear algebra and/or useful tutorial on transformation matrices.


Exercise02 "Ray Casting"

Deadline (no extended deadline): 8.3.2022 at 23:59

Seminar slides

Asignment: Implement basic ray casting and the intersection of ray and plane. Define the camera class and implement a simple ray-tracing procedure.

Bonus [2 bonus %]: Create a camera that will rotate around defined point P (target) among a sphere with r = 1. You can use ideas from the Blender camera system and/or two-angle camera in OpenGL. The camera should use some sort of interactivity (2 angles) and targeted point P should be movable. Bonus camera can be created in a separate solution or you can change the structure in the template to implement two different cameras.


Exercise03 "Primitives"

Deadline: 15.3.2022 at 23:59 Extended deadline: 22.3.2022 at 23:59

Seminar Slides

Asignment: Improve your tracer by adding new primitive object types: box, sphere, and ring.

Resources: Planes, triangles, and distances, Intersection algorithms

Bonus [3 bonus % (1 for each)]: Create also a triangle, cylinder, and cone primitives and add them to the tracer. Also, create a new scene where you present the primitive(s).


Exercise04 "Shaders, Shading and Shadows"

Deadline: 22.3.2022 at 23:59 Extended deadline: 29.3.2022 at 23:59

Seminar Slides

Asignment: Improve your tracer by implementing Phong and checker shaders, directional light, and hard shadows. Compute normals of each primitive at the point of intersection. As usual, you should get a similar functionality as in the sample application.


Exercise05 "Light Types"

Deadline: 29.3.2021 at 23:59 Extended deadline: 5.4.2022 at 23:59

Seminar Slides

Asignment: Improve your tracer by adding a point, spot and an area light types. In the case of point and spotlight, define the light as a point with hard shadows and linear/quadratic light attenuation [2]. Area light could be defined by Lights x Lights point lights. Area light should also be able to produce "soft" shadows.

[2 bonus %]: Write an equation for illumination computed by sample code from seminar slides


Exercise06 "Shaders"

Deadline: 5.4.2022 at 23:59 Extended deadline: 12.4.2022 at 23:59

Seminar Slides

Asignment: Improve your tracer by adding a few more shaders: Toon, Gradient, Cook-Torrance, and Oren-Nayar.

[2 bonus %]: Implement Ward Shader [ Example ].

  • Generate tangent space for each point on the sphere
  • Remember to keep the same orientation of tangent space at each point


Exercise07 "Reflections"

Deadline: 12.4.2022 at 23:59 Extended deadline: 19.4.2022 at 23:59

Seminar Slides

Asignment: Improve your tracer by adding reflections for rendering mirror-like materials.


Exercise08 "Transparency"

Deadline: 19.4.2022 at 23:59 Extended deadline: 26.4.2022 at 23:59

Seminar Slides

Asignment: Improve your tracer by adding reflections and refractions for rendering glass materials.

[2 bonus %]: Implement fresnel effect.


Exercise09 "Postprocessing"

Deadline: 3.5.2022 at 23:59 Extended deadline: 10.5.2022 at 23:59

Seminar slides

Finalize your raytracer by adding supersampling antialiasing [3]. Implement blur. Users can scale the intensity of blur [4].