INTRODUCTION. Slides modified from Angel book 6e

Similar documents
Computer Graphics. Bing-Yu Chen National Taiwan University

Introduction to Computer Graphics. Overview. What is Computer Graphics?

National Chiao Tung Univ, Taiwan By: I-Chen Lin, Assistant Professor

MMGD0206 Computer Graphics. Chapter 1 Development of Computer Graphics : History

Image Formation. Ed Angel Professor of Computer Science, Electrical and Computer Engineering, and Media Arts University of New Mexico

Introduction to Computer Graphics with WebGL

Lecture 1. Computer Graphics and Systems. Tuesday, January 15, 13

Models and Architectures. Ed Angel Professor of Computer Science, Electrical and Computer Engineering, and Media Arts University of New Mexico

Introduction to Computer Graphics with WebGL

Models and Architectures

Survey in Computer Graphics Computer Graphics and Visualization

3D graphics, raster and colors CS312 Fall 2010

Image Formation. Introduction to Computer Graphics. Machiraju/Zhang/Möller/Klaffenböck

Image Formation. Introduction to Computer Graphics Torsten Möller. Machiraju/Zhang/Möller

Overview CS Plans for this semester. References. CS 4600 Fall Prerequisites

CSE4030 Introduction to Computer Graphics

Game Programming. Bing-Yu Chen National Taiwan University

Graphics Systems and Models

Computer Graphics. Bing-Yu Chen National Taiwan University The University of Tokyo

Introduction to Computer Graphics with WebGL

Computer Graphics and Visualization. Graphics Systems and Models

Introduction to Computer Graphics with WebGL

Lecturer Athanasios Nikolaidis

CS452/552; EE465/505. Overview of Computer Graphics

Computer Graphics - Chapter 1 Graphics Systems and Models

OUTLINE. Learn the basic design of a graphics system Introduce pipeline architecture Examine software components for a graphics system

CS452/552; EE465/505. Image Formation

VTU QUESTION PAPER SOLUTION UNIT -1 INTRODUCTION

Computer Graphics Lecture 2

CS452/552; EE465/505. Color Display Issues

The Display pipeline. The fast forward version. The Display Pipeline The order may vary somewhat. The Graphics Pipeline. To draw images.

Illumination and Shading

Reading. 2. Color. Emission spectra. The radiant energy spectrum. Watt, Chapter 15.

Digital Image Processing COSC 6380/4393. Lecture 19 Mar 26 th, 2019 Pranav Mantini

CIS 441/541: Introduction to Computer Graphics Lecture 14: OpenGL Basics

CS451Real-time Rendering Pipeline

CS450/550. Pipeline Architecture. Adapted From: Angel and Shreiner: Interactive Computer Graphics6E Addison-Wesley 2012

Overview. Computer Graphics CS324. OpenGL. Books. Learning Resources. CS131 Notes. 30 Lectures 3hr Exam

Models and Architectures. Angel and Shreiner: Interactive Computer Graphics 7E Addison-Wesley 2015

CS130 : Computer Graphics Lecture 2: Graphics Pipeline. Tamar Shinar Computer Science & Engineering UC Riverside

CHAPTER 1 Graphics Systems and Models 3

Introduction to OpenGL Week 1

Objectives. Image Formation Revisited. Physical Approaches. The Programmer s Interface. Practical Approach. Introduction to OpenGL Week 1

Color and Shading. Color. Shapiro and Stockman, Chapter 6. Color and Machine Vision. Color and Perception

CSE 167: Lecture #6: Color. Jürgen P. Schulze, Ph.D. University of California, San Diego Fall Quarter 2011

Graphics Hardware and Display Devices

Lecture 12 Color model and color image processing

Overview: Ray Tracing & The Perspective Projection Pipeline

Rendering. Converting a 3D scene to a 2D image. Camera. Light. Rendering. View Plane

Computer Graphics. Instructor: Oren Kapah. Office Hours: T.B.A.

Rasterization Overview

CSE 167: Lecture #7: Color and Shading. Jürgen P. Schulze, Ph.D. University of California, San Diego Fall Quarter 2011

CHAPTER 3 COLOR MEASUREMENT USING CHROMATICITY DIAGRAM - SOFTWARE

CSE528 Computer Graphics: Theory, Algorithms, and Applications

(0, 1, 1) (0, 1, 1) (0, 1, 0) What is light? What is color? Terminology

Computer Graphics. Chapter 1 (Related to Introduction to Computer Graphics Using Java 2D and 3D)

Lecture 1 Image Formation.

CS 464 Review. Review of Computer Graphics for Final Exam

Graphics for VEs. Ruth Aylett

Computer Graphics and Visualization. What is computer graphics?

The Viewing Pipeline Coordinate Systems

CS635 Spring Department of Computer Science Purdue University

Visualisatie BMT. Rendering. Arjan Kok

Principles of Computer Graphics. Lecture 3 1

CSE 167: Introduction to Computer Graphics Lecture #6: Colors. Jürgen P. Schulze, Ph.D. University of California, San Diego Fall Quarter 2013

Digital Image Processing. Introduction

Today. Rendering pipeline. Rendering pipeline. Object vs. Image order. Rendering engine Rendering engine (jtrt) Computergrafik. Rendering pipeline

Course Title: Computer Graphics Course no: CSC209

CS 354R: Computer Game Technology

Today s Agenda. Basic design of a graphics system. Introduction to OpenGL

CIS 581 Interactive Computer Graphics

Orthogonal Projection Matrices. Angel and Shreiner: Interactive Computer Graphics 7E Addison-Wesley 2015

Introduction to Computer Graphics

CSE328 Fundamentals of Computer Graphics: Concepts, Theory, Algorithms, and Applications

Computer Graphics Introduction. Taku Komura

Interactive Computer Graphics A TOP-DOWN APPROACH WITH SHADER-BASED OPENGL

Ulf Assarsson Department of Computer Engineering Chalmers University of Technology

Development of Computer Graphics

Computer Graphics CS 543 Lecture 1 (Part I) Prof Emmanuel Agu. Computer Science Dept. Worcester Polytechnic Institute (WPI)

SRM INSTITUTE OF SCIENCE AND TECHNOLOGY

Physical Color. Color Theory - Center for Graphics and Geometric Computing, Technion 2

CS770/870 Spring 2017 Color and Shading

Computer Graphics: Programming, Problem Solving, and Visual Communication

Virtual Reality for Human Computer Interaction

Ulf Assarsson Department of Computer Engineering Chalmers University of Technology

Scalar Field Visualization I

GLOBAL EDITION. Interactive Computer Graphics. A Top-Down Approach with WebGL SEVENTH EDITION. Edward Angel Dave Shreiner

Graphics Programming

Pipeline Operations. CS 4620 Lecture Steve Marschner. Cornell CS4620 Spring 2018 Lecture 11

History of computer graphics

The Elements of Colour

An Introduction to Computer Graphics

Animation & Rendering

Introduction to color science

Real-Time Shadows. Last Time? Textures can Alias. Schedule. Questions? Quiz 1: Tuesday October 26 th, in class (1 week from today!

Visible Color. 700 (red) 580 (yellow) 520 (green)

Spring 2009 Prof. Hyesoon Kim

The Traditional Graphics Pipeline

Some Resources. What won t I learn? What will I learn? Topics

QUESTION BANK 10CS65 : COMPUTER GRAPHICS AND VISUALIZATION

Transcription:

INTRODUCTION Slides modified from Angel book 6e

Fall 2012 COSC4328/5327 Computer Graphics 2 Objectives Historical introduction to computer graphics Fundamental imaging notions Physical basis for image formation Light, Color, Perception Synthetic camera model Other models Basic design of a graphics system Introduce a graphics pipeline architecture Examine software components for interactive graphics

Fall 2012 COSC4328/5327 Computer Graphics 3 Computer Graphics Computer graphics deals with all aspects of creating images with a computer Hardware Software Applications

Fall 2012 COSC4328/5327 Computer Graphics 4 Example Where did this image come from? What hardware/software did we need to produce it?

Fall 2012 COSC4328/5327 Computer Graphics 5 Preliminary Answer Application: The object is an artist s rendition of the sun for an animation to be shown in a domed environment (planetarium) Software: Maya for modeling and rendering but Maya is built on top of OpenGL Hardware: PC with graphics card for modeling and rendering

Fall 2012 COSC4328/5327 Computer Graphics 6 Basic Graphics System Input devices Output device Image formed in frame buffer

Fall 2012 COSC4328/5327 Computer Graphics 7 CRT Can be used either as a line-drawing device (calligraphic) or to display contents of frame buffer (raster mode)

Fall 2012 COSC4328/5327 Computer Graphics 8 Computer Graphics: 1950-1960 Computer graphics goes back to the earliest days of computing Strip charts Pen plotters Simple displays using A/D converters to go from computer to calligraphic CRT Cost of refresh for CRT too high Computers slow, expensive, unreliable

Fall 2012 COSC4328/5327 Computer Graphics 9 Computer Graphics: 1960-1970 Wireframe graphics Draw only lines Sketchpad Display Processors Storage tube wireframe representation of sun object

Fall 2012 COSC4328/5327 Computer Graphics 10 Sketchpad Ivan Sutherland s PhD thesis at MIT Recognized the potential of man-machine interaction Loop Display something User moves light pen Computer generates new display Sutherland also created many of the now common algorithms for computer graphics

Fall 2012 COSC4328/5327 Computer Graphics 11 Display Processor Rather than have the host computer try to refresh display use a special purpose computer called a display processor (DPU) Graphics stored in display list (display file) on display processor Host compiles display list and sends to DPU

Fall 2012 COSC4328/5327 Computer Graphics 12 Direct View Storage Tube Created by Tektronix Did not require constant refresh Standard interface to computers Allowed for standard software Plot3D in Fortran Relatively inexpensive Opened door to use of computer graphics for CAD community

Fall 2012 COSC4328/5327 Computer Graphics 13 Computer Graphics: 1970-1980 Raster Graphics Beginning of graphics standards IFIPS GKS: European effort Becomes ISO 2D standard Core: North American effort 3D but fails to become ISO standard Workstations and PCs

Fall 2012 COSC4328/5327 Computer Graphics 14 Raster Graphics Image produced as an array (the raster) of picture elements (pixels) in the frame buffer

Fall 2012 COSC4328/5327 Computer Graphics 15 Raster Graphics Allows us to go from lines and wire frame images to filled polygons

Fall 2012 COSC4328/5327 Computer Graphics 16 Vector vs. Raster Which draws better pictures? Which draws better shaded pictures? Which draws better color pictures? Which draws better lines? Which requires more memory? Which has a constant display time?

Fall 2012 COSC4328/5327 Computer Graphics 17 PCs and Workstations Although we no longer make the distinction between workstations and PCs, historically they evolved from different roots Early workstations characterized by Networked connection: client-server model High-level of interactivity Early PCs included frame buffer as part of user memory Easy to change contents and create images

Fall 2012 COSC4328/5327 Computer Graphics 18 Computer Graphics 1970-1980 Pong 1972 The Black Hole 1979

Fall 2012 COSC4328/5327 Computer Graphics 19 Computer Graphics: 1980-1990 Tron 1982 Wrath of Kahn 1982 Last Starfighter 1984

Fall 2012 COSC4328/5327 Computer Graphics 20 Computer Graphics: 1980-1990 Realism comes to computer graphics smooth shading environment mapping bump mapping

Fall 2012 COSC4328/5327 Computer Graphics 21 Computer Graphics: 1980-1990 Special purpose hardware Silicon Graphics geometry engine VLSI implementation of graphics pipeline Industry-based standards PHIGS RenderMan Networked graphics: X Window System Human-Computer Interface (HCI)

Fall 2012 COSC4328/5327 Computer Graphics 22 Computer Graphics: 1990-2000 Babylon 5 93-98 TV Jurrasic Park 1993 Titanic 1997 (linux rendering) The Matrix 1999

Fall 2012 COSC4328/5327 Computer Graphics 23 Computer Graphics: 1990-2000 OpenGL API Completely computer-generated feature-length movies (Toy Story) are successful New hardware capabilities Texture mapping Blending Accumulation, stencil buffers

Fall 2012 COSC4328/5327 Computer Graphics 24 Computer Graphics: 2000- Photorealism Graphics cards for PCs dominate market Nvidia, ATI Game boxes and game players determine direction of market Computer graphics routine in movie industry: Maya, Lightwave Programmable pipelines

Fall 2012 COSC4328/5327 Computer Graphics 25 Image Formation In computer graphics, we form images which are generally two dimensional using a process analogous to how images are formed by physical imaging systems Cameras Microscopes Telescopes Human visual system

Fall 2012 COSC4328/5327 Computer Graphics 26 Elements of Image Formation Objects Viewer Light source(s) Attributes that govern how light interacts with the materials in the scene Note the independence of the objects, the viewer, and the light source(s)

Fall 2012 COSC4328/5327 Computer Graphics 27 Light Light is the part of the electromagnetic spectrum that causes a reaction in our visual systems Generally these are wavelengths in the range of about 350-750 nm (nanometers) Long wavelengths appear as reds and short wavelengths as blues

Fall 2012 COSC4328/5327 Computer Graphics 28 Ray Tracing and Geometric Optics One way to form an image is to follow rays of light from a point source finding which rays enter the lens of the camera. However, each ray of light may have multiple interactions with objects before being absorbed or going to infinity.

Fall 2012 COSC4328/5327 Computer Graphics 29 Luminance and Color Images Luminance Image Monochromatic Values are gray levels Analogous to working with black and white film or television Color Image Has perceptional attributes of hue, saturation, and lightness Do we have to match every frequency in visible spectrum? No!

Fall 2012 COSC4328/5327 Computer Graphics 30 Three-Color Theory Human visual system has two types of sensors Rods: monochromatic, night vision Cones Color sensitive Three types of cones: S, M, L Name after wavelength they respond to Only three values (the tristimulus values) are sent to the brain Need only match these three values Can get by with three primary colors

Fall 2012 COSC4328/5327 Computer Graphics 31 What is This?

Fall 2012 COSC4328/5327 Computer Graphics 32 Color Perception

Fall 2012 COSC4328/5327 Computer Graphics 33 Light Source What does the power spectrum from varying sources look like? Fluorescent solid Tungsten - dash

Fall 2012 COSC4328/5327 Computer Graphics 34 Color Perception How is a red Cortland apple perceived under fluorescent lighting? This is called the dominant wavelength It is the perceived hue

Fall 2012 COSC4328/5327 Computer Graphics 35 Color Terms Hue Dominant wavelength (spectral color) Brightness/Luminance Brightness increases until colors wash out Luminance is total power of the light. Purity/Saturation How close to a spectral pure color How many wavelengths make up a color Percent of luminance in dominant wavelength Chromaticity Combination of hue and purity Metamer Two colors (objects) that appear the same under one set of conditions and different under another.

Fall 2012 COSC4328/5327 Computer Graphics 36 Optical Illusions http://www.youramazingbrain.org.uk/supersenses/asto unding.htm http://www.echalk.co.uk/amusements/opticalillusions/c olourperception/colourperception.html

Fall 2012 COSC4328/5327 Computer Graphics 37 Additive and Subtractive Color Additive color Form a color by adding amounts of three primaries CRTs, projection systems, positive film Primaries are Red (R), Green (G), Blue (B) Subtractive color Form a color by filtering white light with cyan (C), Magenta (M), and Yellow (Y) filters Light-material interactions Printing Negative film

Fall 2012 COSC4328/5327 Computer Graphics 38 CIE In 1931, Commission Internationale de Eclariage created three primaries They are imaginary primaries Adding different amounts of them will produce all visible colors These three colors form a 3- space All perceived hues in diagram Plus others

Fall 2012 COSC4328/5327 Computer Graphics 39 CIE Colors on a line emanating from the origin have the same hue and saturation, but different luminance Boundary colors correspond to maximum saturation of a spectral color Except on purple line Triangle is a gamut for RGB All colors that can be matched by RGB

Fall 2012 COSC4328/5327 Computer Graphics 40 CIE Color Regions

Fall 2012 COSC4328/5327 Computer Graphics 41 Other Gamuts matched to CIE

Color Terms Spectral Color Color of the rainbow Non-spectral color A perceivable color that doesn t have a wavelength (not part of rainbow) Colors on the Purple line. What about white? Dominant wavelength Line from W through the color C will intersect the dominant wavelength White Spot (W) Equal parts of all primaries Complimentary color Line from color through W will intersect this Gamut Colors that can be represented by a group of primaries

Fall 2012 COSC4328/5327 Computer Graphics 43 CIE Some Relationships W White spot Achromatic point B Complimentary to A Equal quantities of A & B give white Non-spectral No dominant wavelength C Dominant wavelength for A Mix with White to get A Complimentary wavelength for B D Complimentary color to A Non-spectral (on purple line) D C A W B

Fall 2012 COSC4328/5327 Computer Graphics 44 CIE 3D not 2D Sometimes a color appears in the gamut but is not

Fall 2012 COSC4328/5327 Computer Graphics 45 Shadow Mask CRT

Fall 2012 COSC4328/5327 Computer Graphics 46 Liquid Crystal Display Liquid Crystal Not solid, not liquid Can transmit and change polarized light Change alignment with a current Place liquid crystals between two polarized panels Applying charge to crystals will untwist them allowing light to pass through (or stop) Can be backlit or reflective http://static.howstuffworks.com/flash/lcd-twisted.swf

Fall 2012 COSC4328/5327 Computer Graphics 47 LCD Arrange pixels in a grid with row and column oriented conductive substrates A charge on the correct row and column will light up pixel Amount of charge controls how much light passes through Generally 256 levels Alternating Red, Green, and Blue columns allows for color

Fall 2012 COSC4328/5327 Computer Graphics 48 Pinhole Camera Use trigonometry to find projection of point at (x,y,z) x p = -x/z/d y p = -y/z/d z p = d These are equations of simple perspective

Fall 2012 COSC4328/5327 Computer Graphics 49 Synthetic Camera Model projector p image plane projection of p center of projection

Fall 2012 COSC4328/5327 Computer Graphics 50 Advantages Separation of objects, viewer, light sources Two-dimensional graphics is a special case of threedimensional graphics Leads to simple software API Specify objects, lights, camera, attributes Let implementation determine image Leads to fast hardware implementation

Fall 2012 COSC4328/5327 Computer Graphics 51 Global vs Local Lighting Cannot compute color or shade of each object independently Some objects are blocked from light Light can reflect from object to object Some objects might be translucent

Fall 2012 COSC4328/5327 Computer Graphics 52 Why not ray tracing? Ray tracing seems more physically based so why don t we use it to design a graphics system? Possible and is actually simple for simple objects such as polygons and quadrics with simple point sources In principle, can produce global lighting effects such as shadows and multiple reflections but ray tracing is slow and not well-suited for interactive applications Ray tracing with GPUs is close to real time

Fall 2012 COSC4328/5327 Computer Graphics 53 Image Formation Revisited Can we mimic the synthetic camera model to design graphics hardware software? Application Programmer Interface (API) Need only specify Objects Materials Viewer Lights But how is the API implemented?

Fall 2012 COSC4328/5327 Computer Graphics 54 Physical Approaches Ray tracing: follow rays of light from center of projection until they either are absorbed by objects or go off to infinity Can handle global effects Multiple reflections Translucent objects Slow Must have whole data base available at all times Radiosity: Energy based approach Very slow

Fall 2012 COSC4328/5327 Computer Graphics 55 Practical Approach Process objects one at a time in the order they are generated by the application Can consider only local lighting Pipeline architecture application program display All steps can be implemented in hardware on the graphics card

Fall 2012 COSC4328/5327 Computer Graphics 56 Vertex Processing Much of the work in the pipeline is in converting object representations from one coordinate system to another Object coordinates Camera (eye) coordinates Screen coordinates Every change of coordinates is equivalent to a matrix transformation Vertex processor also computes vertex colors

Fall 2012 COSC4328/5327 Computer Graphics 57 Projection Projection is the process that combines the 3D viewer with the 3D objects to produce the 2D image Perspective projections: all projectors meet at the center of projection Parallel projection: projectors are parallel, center of projection is replaced by a direction of projection

Fall 2012 COSC4328/5327 Computer Graphics 58 Primitive Assembly Vertices must be collected into geometric objects before clipping and rasterization can take place Line segments Polygons Curves and surfaces

Fall 2012 COSC4328/5327 Computer Graphics 59 Clipping Just as a real camera cannot see the whole world, the virtual camera can only see part of the world or object space Objects that are not within this volume are said to be clipped out of the scene

Fall 2012 COSC4328/5327 Computer Graphics 60 Rasterization If an object is not clipped out, the appropriate pixels in the frame buffer must be assigned colors Rasterizer produces a set of fragments for each object Fragments are potential pixels Have a location in frame bufffer Color and depth attributes Vertex attributes are interpolated over objects by the rasterizer

Fall 2012 COSC4328/5327 Computer Graphics 61 Fragment Processing Fragments are processed to determine the color of the corresponding pixel in the frame buffer Colors can be determined by texture mapping or interpolation of vertex colors Fragments may be blocked by other fragments closer to the camera Hidden-surface removal

Fall 2012 COSC4328/5327 Computer Graphics 62 The Programmer s Interface Programmer sees the graphics system through a software interface: the Application Programmer Interface (API)

Fall 2012 COSC4328/5327 Computer Graphics 63 API Contents Functions that specify what we need to form an image Objects Viewer Light Source(s) Materials Other information Input from devices such as mouse and keyboard Capabilities of system

Fall 2012 COSC4328/5327 Computer Graphics 64 Object Specification Most APIs support a limited set of primitives including Points (0D object) Line segments (1D objects) Polygons (2D objects) Some curves and surfaces Quadrics Parametric polynomials All are defined through locations in space or vertices

Fall 2012 COSC4328/5327 Computer Graphics 65 Example (GL 2.X) type of object glbegin(gl_polygon) glvertex3f(0.0, 0.0, 0.0); glvertex3f(0.0, 1.0, 0.0); glvertex3f(0.0, 0.0, 1.0); glend( ); location of vertex end of object definition

Fall 2012 COSC4328/5327 Computer Graphics 66 Example (GL > 3.X - GPU based) Put geometric data in an array vec3 points[3]; points[0] = vec3(0.0, 0.0, 0.0); points[1] = vec3(0.0, 1.0, 0.0); points[2] = vec3(0.0, 0.0, 1.0); Send array to GPU Tell GPU to render as triangle

Fall 2012 COSC4328/5327 Computer Graphics 67 Camera Specification Six degrees of freedom Position of center of lens Orientation Lens Film size Orientation of film plane

Fall 2012 COSC4328/5327 Computer Graphics 68 Lights and Materials Types of lights Point sources vs distributed sources Spot lights Near and far sources Color properties Material properties Absorption: color properties Scattering Diffuse Specular