Difference between revisions of "CISC440 S2019"

From class_wiki
Jump to: navigation, search
(Schedule)
(Schedule)
Line 193: Line 193:
 
<br>
 
<br>
  
<iframe src="https://calendar.google.com/calendar/embed?src=ad9g5vvvp9qfcv9dvirdlprcmg%40group.calendar.google.com&ctz=America%2FNew_York" style="border: 0" width="800" height="600" frameborder="0" scrolling="no"></iframe>
 
  
 
{| class="wikitable" style="text-align: center" border="1" cellpadding="5"  
 
{| class="wikitable" style="text-align: center" border="1" cellpadding="5"  
Line 234: Line 233:
 
|style="background:rgb(102, 204, 255)"|5
 
|style="background:rgb(102, 204, 255)"|5
 
|Feb. 26
 
|Feb. 26
''Register/add deadline Feb. 19''<br>
+
''Register/add deadline Feb. 25''<br>
 
|OpenGL/GLFW
 
|OpenGL/GLFW
 
|Program initialization, window creation, geometric primitives <!--, GLUT -->
 
|Program initialization, window creation, geometric primitives <!--, GLUT -->
Line 255: Line 254:
 
|-
 
|-
 
|8
 
|8
|Mar. 5
+
|Mar. 7
 
|Shading  
 
|Shading  
 
|Quick GLSL texturing demo; Radiometry: irradiance, radiosity, radiance, BRDFs
 
|Quick GLSL texturing demo; Radiometry: irradiance, radiosity, radiance, BRDFs
Line 264: Line 263:
 
|-
 
|-
 
|style="background:rgb(102, 204, 255)"|9
 
|style="background:rgb(102, 204, 255)"|9
|Mar. 7
+
|Mar. 12
 
|Shading
 
|Shading
 
|Diffuse, specular reflection, Gouraud/Phong shading details; OpenGL, GLSL shading methods
 
|Diffuse, specular reflection, Gouraud/Phong shading details; OpenGL, GLSL shading methods
Line 271: Line 270:
 
|-
 
|-
 
|10
 
|10
|Mar. 12
+
|Mar. 14
 
|Textures
 
|Textures
 
|Texture-mapping pipeline, start bump mapping
 
|Texture-mapping pipeline, start bump mapping
Line 278: Line 277:
 
|-
 
|-
 
|style="background:rgb(102, 204, 255)"|11
 
|style="background:rgb(102, 204, 255)"|11
|Mar. 14
+
|Mar. 19
 
|Textures
 
|Textures
 
|Finish bump mapping, HW #2, displacement mapping, environment maps
 
|Finish bump mapping, HW #2, displacement mapping, environment maps
Line 285: Line 284:
 
|-
 
|-
 
|12
 
|12
|Mar. 19
+
|Mar. 21
 
|Textures
 
|Textures
 
|Shadow maps, lightmaps, magnification/minification
 
|Shadow maps, lightmaps, magnification/minification
Line 293: Line 292:
 
|-
 
|-
 
|style="background:rgb(102, 204, 255)"|13
 
|style="background:rgb(102, 204, 255)"|13
|Mar. 21
+
|Mar. 26
 
|Midterm review
 
|Midterm review
 
|
 
|
Line 301: Line 300:
 
|-
 
|-
 
|14
 
|14
|Mar. 26
+
|Mar. 28
 
|MIDTERM EXAM
 
|MIDTERM EXAM
 
|
 
|
Line 308: Line 307:
 
|-
 
|-
 
|style="background:rgb(102, 204, 255)"|
 
|style="background:rgb(102, 204, 255)"|
|Mar. 27
+
|Apr. 2
 
|style="background:rgb(255, 102, 0)"|NO CLASS<br>''Spring break''
 
|style="background:rgb(255, 102, 0)"|NO CLASS<br>''Spring break''
 
|
 
|
Line 315: Line 314:
 
|-
 
|-
 
|
 
|
|Mar. 29
+
|Apr. 4
 
|style="background:rgb(255, 102, 0)"|NO CLASS<br>''Spring break''
 
|style="background:rgb(255, 102, 0)"|NO CLASS<br>''Spring break''
 
|
 
|
Line 322: Line 321:
 
|-
 
|-
 
|style="background:rgb(102, 204, 255)"|15
 
|style="background:rgb(102, 204, 255)"|15
|Apr. 3
+
|Apr. 9
 
|Hidden surface elimination  
 
|Hidden surface elimination  
 
|Line and triangle clipping, backface culling, Z-buffering
 
|Line and triangle clipping, backface culling, Z-buffering
Line 329: Line 328:
 
|-
 
|-
 
|16
 
|16
|Apr. 5
+
|Apr. 11
 
|Motion/simulation
 
|Motion/simulation
 
|Particle systems, flocking
 
|Particle systems, flocking
Line 336: Line 335:
 
|-
 
|-
 
|style="background:rgb(102, 204, 255)"|17
 
|style="background:rgb(102, 204, 255)"|17
|Apr. 10<br>''Withdraw deadline Apr. 9''
+
|Apr. 16<br>''Withdraw deadline Apr. 15''
 
|Finish hidden surface elimination + physics/simulation
 
|Finish hidden surface elimination + physics/simulation
 
|Painter's algorithm, BSP trees; introduction to Bullet physics library
 
|Painter's algorithm, BSP trees; introduction to Bullet physics library
Line 343: Line 342:
 
|-
 
|-
 
|
 
|
|Apr. 12
+
|Apr. 18
 
|style="background:rgb(255, 102, 0)"|NO CLASS<br>''Instructor ill''
 
|style="background:rgb(255, 102, 0)"|NO CLASS<br>''Instructor ill''
 
|
 
|
Line 350: Line 349:
 
|-
 
|-
 
|style="background:rgb(102, 204, 255)"|18
 
|style="background:rgb(102, 204, 255)"|18
|Apr. 17
+
|Apr. 23
 
|*Really* finish HSE; line drawing
 
|*Really* finish HSE; line drawing
 
|DDA line-drawing
 
|DDA line-drawing
Line 357: Line 356:
 
|-
 
|-
 
|19
 
|19
|Apr. 19
+
|Apr. 25
 
|Finish line drawing, ray tracing
 
|Finish line drawing, ray tracing
 
|Midpoint algorithm, ray casting   
 
|Midpoint algorithm, ray casting   
Line 364: Line 363:
 
|-
 
|-
 
|style="background:rgb(102, 204, 255)"|20
 
|style="background:rgb(102, 204, 255)"|20
|Apr. 24
+
|Apr. 30
 
|Ray tracing
 
|Ray tracing
 
|Intersection testing, shadow rays (including soft shadows, ambient occlusion)
 
|Intersection testing, shadow rays (including soft shadows, ambient occlusion)
Line 371: Line 370:
 
|-
 
|-
 
|21
 
|21
|Apr. 26
+
|May 2
 
|Ray tracing
 
|Ray tracing
 
|Reflections, refractions, distributed ray tracing for anti-aliasing
 
|Reflections, refractions, distributed ray tracing for anti-aliasing
Line 378: Line 377:
 
|-
 
|-
 
|style="background:rgb(102, 204, 255)"|22
 
|style="background:rgb(102, 204, 255)"|22
|May 1
+
|May 7
 
|Ray tracing and beyond
 
|Ray tracing and beyond
 
|Distributed ray tracing for glossy reflections, spatial data structures; introduction to bidirectional ray tracing
 
|Distributed ray tracing for glossy reflections, spatial data structures; introduction to bidirectional ray tracing
Line 386: Line 385:
 
|-
 
|-
 
|23
 
|23
|May 3
+
|May 9
 
|Global illumination
 
|Global illumination
 
|Finish bidirectional ray tracing, start photon mapping  
 
|Finish bidirectional ray tracing, start photon mapping  
Line 393: Line 392:
 
|-
 
|-
 
|style="background:rgb(102, 204, 255)"|24
 
|style="background:rgb(102, 204, 255)"|24
|May 8
+
|May 14
 
|Finish photon mapping, noise
 
|Finish photon mapping, noise
 
|Value/Perlin noise
 
|Value/Perlin noise
Line 400: Line 399:
 
|-
 
|-
 
|25
 
|25
|May 10
+
|May 16
|Finish noise; SIGGRAPH videos
+
|Final review
 
|
 
|
 
|
 
|
 
|<!--[https://docs.google.com/presentation/d/1RWvmTrSD1076eN6luo24XgJSuhroHKgkBT4tPovJxI0/edit?usp=sharing slides]-->
 
|<!--[https://docs.google.com/presentation/d/1RWvmTrSD1076eN6luo24XgJSuhroHKgkBT4tPovJxI0/edit?usp=sharing slides]-->
|-
+
<!--|-
 
|style="background:rgb(102, 204, 255)"|26
 
|style="background:rgb(102, 204, 255)"|26
 
|May 15
 
|May 15
 
|Final review
 
|Final review
 
|
 
|
|
+
|-->
 
|<!--[https://docs.google.com/presentation/d/1bP49PWF7cBZGSLnixD9W56_qKbPzEC9XejYH8gsHsVg/edit?usp=sharing slides]<br>[http://nameless.cis.udel.edu/class_data/cg/f2008_final_arial.pdf 2008 final]-->''HW #4 due''<br>[https://docs.google.com/presentation/d/113m0MIqb3mzzp4JmUMTFBRQcta2p7rIPzf5Oy8FaBy0/edit?usp=sharing slides]<br>[http://nameless.cis.udel.edu/class_data/cg/f2008_final_arial.pdf 2008 final]
 
|<!--[https://docs.google.com/presentation/d/1bP49PWF7cBZGSLnixD9W56_qKbPzEC9XejYH8gsHsVg/edit?usp=sharing slides]<br>[http://nameless.cis.udel.edu/class_data/cg/f2008_final_arial.pdf 2008 final]-->''HW #4 due''<br>[https://docs.google.com/presentation/d/113m0MIqb3mzzp4JmUMTFBRQcta2p7rIPzf5Oy8FaBy0/edit?usp=sharing slides]<br>[http://nameless.cis.udel.edu/class_data/cg/f2008_final_arial.pdf 2008 final]
 
|-
 
|-
 
|
 
|
|May 22, 1-3 pm
+
|May 22-30
 
|FINAL EXAM  
 
|FINAL EXAM  
 
|
 
|

Revision as of 17:53, 11 February 2019

Course information

Title CISC440/640 Computer Graphics
Shortened URL https://goo.gl/V6WTfi
Description A first course in computer graphics covering fundamental concepts and techniques related to rasterization, textures, 2-D and 3-D transformations (including perspective projection), shading, hidden surface elimination, and anti-aliasing, as well as selected topics in modeling, animation, ray tracing, and global illumination. OpenGL will be used for programming; you should have some familiarity with C/C++ or be ready to learn it.
When Tuesdays and Thursdays, 2-3:15 pm
Where ISE 207
Instructor Christopher Rasmussen, 446 Smith Hall, cer@cis.udel.edu
Office hours Wednesdays, 2:30 pm -- 4 pm
TA Chunbo Song, songcb@udel.edu

TA office hours: Mondays, 3-5 pm, 201 Smith Hall

Grading
  • 60% 4 assignments worth 15% each. Each homework will be due about 2 weeks after being assigned (one is a little shorter, one a little longer)
  • 20% Midterm exam
  • 20% Final exam. "Bonus topic" lecture material will not be tested
  • 2% Extra credit for completing course evaluation

Graduate students will be given extra tasks to complete or features to implement on each homework, and extra questions to answer on each exam.

Programming assignments will be graded on the basis of correctness, efficiency, and originality. This is not an introductory programming class, so coding style is not critical. However, if you want partial credit for something that doesn't quite work, it needs to be well-commented and easy to follow.

For the overall course grade, a preliminary absolute mark will be assigned to each student based on the percentage of the total possible points they earn according to the standard formula: A = 90-100, B = 80-90, C = 70-80, etc., with +'s and -'s given for the upper and lower third of each range, respectively. Based on the distribution of preliminary grades for all students (i.e., "the curve"), the instructor may increase these grades monotonically to calculate final grades. This means that your final grade can't be lower than your preliminary grade, and your final grade won't be higher than that of anyone who had a higher preliminary grade.

I will try to keep you informed about your standing throughout the semester. If you have any questions about grading or expectations at any time, please feel free to ask me.

Piazza
Academic policies Programming projects are due by midnight of the deadline day (with a grace period of a few hours afterward...after sunrise is definitely late). A late homework is a 0 without a valid prior excuse. To give you a little flexibility, you have 6 "late days" to use on homeworks to extend the deadline by one day each without penalty. No more than three late days may be used per assignment. Late days will automatically be subtracted, but as a courtesy please notify the instructor (and CC the TA) in an e-mail of your intention to use late days before the deadline. See submission instructions below.

The two exams will be closed book (i.e., no reference materials allowed). Unless otherwise instructed, you are responsible for all material covered up to the day of the exam, both from the assigned readings (everything in the Readings column of the Schedule below) and in lectures (excluding guest lectures).

Students can discuss problems with one another in general terms, but must work independently on programming assignments. This also applies to online and printed resources: you may consult them as references (as long as you cite them), but the words and source code you turn in must be yours alone. The University's policies on academic dishonesty are set forth in the student code of conduct here.

Readings

Textbook (required) Fundamentals of Computer Graphics (4th ed.) [Marschner in calendar below]

Steve Marschner and Peter Shirley

CRC Press, 2016

Textbook web site: Author (most useful thing there is link to course with relevant slides), Publisher

This book is NOT at the campus bookstore. Other ordering options:

  • Amazon: About $79 for used hardcover, $26 to rent physical book for semester, E-book purchase $42
  • CRC Press (the publisher): E-book purchase is $52, rental is $29 for 180 days

Instructions

OpenGL Key thing to note: We are using OpenGL 3.3 for programming! A lot of examples on the web are for older 2.x, so beware


Homeworks Assignment submissions should consist of a directory containing all code (your .cpp files, header files, makefile if applicable, etc.), any output data generated (e.g., images, movies, etc.), and an explanation of your approach, what worked and didn't work, etc. contained in a separate text or HTML file. Do not submit executables, .o files, or libraries, please! The directory you submit for each assignment should be packaged by tar'ing and gzip'ing it or just zip'ing it. The resulting file should be submitted through Canvas.

You may develop your OpenGL, C/C++ code in any fashion that is convenient--that is, with any compiler and operating system that you want--but you must avoid OS- and hardware-specific functions.

Schedule

Note: The blue squares in the "#" column below indicate Tuesdays.
UDCapture link


# Date Topic Notes Readings Assignments/slides
1 Feb. 12 Introduction Graphics background, course information Marschner, 1-1.4 slides
2 Feb. 14 2-D, 3-D Geometry Vector & matrix review, homogeneous coordinates, 2-D & 3-D transformations, quaternions Marschner, 2.4, 5.2-5.2.2, 6-6.3 (skip 6.1.6, 6.2.1-6.2.2), 16.2.2 slides
3 Feb. 19 3-D Geometry More 3-D transformations, camera manipulation & the view volume Marschner, 6.5-7.2 slides
4 Feb. 21 3-D Geometry Perspective projection, geometry pipeline, transformations with GLM Marschner, 7.3, 7.5; OpenGL tutorials #1 (including installation instructions), #3 slides

HW #1

5 Feb. 26

Register/add deadline Feb. 25

OpenGL/GLFW Program initialization, window creation, geometric primitives Marschner, 17-17.7, 17.9-17.11 slides
6 Feb. 28 OpenGL/GLFW Basic animation, user interface callbacks OpenGL tutorial #6 slides
interactive_tutorial03.cpp
7 Mar. 5 GPU programming Introduction to GLSL, vertex shaders vs. fragment shaders Marschner, 17.8; Orange book Chaps. 2-5 slides
HW #1 due
8 Mar. 7 Shading Quick GLSL texturing demo; Radiometry: irradiance, radiosity, radiance, BRDFs Marschner, 10-10.2.1, 20-20.2 slides

texture_example.zip
HW #2

9 Mar. 12 Shading Diffuse, specular reflection, Gouraud/Phong shading details; OpenGL, GLSL shading methods Marschner, 10-10.2.2; OpenGL tutorial #8 slides
10 Mar. 14 Textures Texture-mapping pipeline, start bump mapping Marschner, 11.2, 11.4 (homogeneous division material--not barycentric coords), 11.5 slides
11 Mar. 19 Textures Finish bump mapping, HW #2, displacement mapping, environment maps Marschner, 11.1.3-11.1.4, 11.6-11.7 slides
12 Mar. 21 Textures Shadow maps, lightmaps, magnification/minification slides
HW #2 due
13 Mar. 26 Midterm review slides
2014 midterm (ignore Q7, Q9, Q10, and Q11)

2004 midterm (look at questions 1.1, 1.2, 2.1, and 3.2 only)

14 Mar. 28 MIDTERM EXAM
Apr. 2 NO CLASS
Spring break
Apr. 4 NO CLASS
Spring break
15 Apr. 9 Hidden surface elimination Line and triangle clipping, backface culling, Z-buffering Marschner, 8.1.3-8.2.3, 8.4; 8.1-8.2 slides
16 Apr. 11 Motion/simulation Particle systems, flocking Marschner, 16.7 slides
17 Apr. 16
Withdraw deadline Apr. 15
Finish hidden surface elimination + physics/simulation Painter's algorithm, BSP trees; introduction to Bullet physics library OpenGL tutorial #5 and clicking, Bullet tutorials slides
Apr. 18 NO CLASS
Instructor ill
HW #3
18 Apr. 23 *Really* finish HSE; line drawing DDA line-drawing Marschner, 8.1-8.1.1, 8.3 slides
19 Apr. 25 Finish line drawing, ray tracing Midpoint algorithm, ray casting Marschner, 4 slides
20 Apr. 30 Ray tracing Intersection testing, shadow rays (including soft shadows, ambient occlusion) Marschner, 4 slides
21 May 2 Ray tracing Reflections, refractions, distributed ray tracing for anti-aliasing slides
HW #3 due
HW #4
22 May 7 Ray tracing and beyond Distributed ray tracing for glossy reflections, spatial data structures; introduction to bidirectional ray tracing Marschner, 4, 12.3, 13.1, 13.4; "Bidirectional Ray Tracing" paper by

P. Heckbert

slides
23 May 9 Global illumination Finish bidirectional ray tracing, start photon mapping Photon mapping introduction, online demo, tutorial slides
24 May 14 Finish photon mapping, noise Value/Perlin noise Marschner, 11.5.2-11.5.3, Orange book 15 slides
25 May 16 Final review HW #4 due
slides
2008 final
May 22-30 FINAL EXAM