Hank Childs, University of Oregon

Slides:



Advertisements
Similar presentations
7.1 Vis_04 Data Visualization Lecture 7 3D Scalar Visualization Part 2 : Volume Rendering- Introduction.
Advertisements

15.1 Si23_03 SI23 Introduction to Computer Graphics Lecture 15 – Visible Surfaces and Shadows.
8.1si31_2001 SI31 Advanced Computer Graphics AGR Lecture 8 Polygon Rendering.
Hank Childs, University of Oregon Nov. 25th, 2014 CIS 441/541: Introduction to Computer Graphics Lecture 15: animation, transparency.
Direct Volume Rendering. What is volume rendering? Accumulate information along 1 dimension line through volume.
Week 7 - Monday.  What did we talk about last time?  Specular shading  Aliasing and antialiasing.
Computer Graphics Visible Surface Determination. Goal of Visible Surface Determination To draw only the surfaces (triangles) that are visible, given a.
Hank Childs, University of Oregon November 15 th, 2013 Volume Rendering, Part 2.
Fractal Image Compression
1Notes. 2Atop  The simplest (useful) and most common form of compositing: put one image “atop” another  Image 1 (RGB) on top of image 2 (RGB)  For.
1 King ABDUL AZIZ University Faculty Of Computing and Information Technology CS 454 Computer graphicsIntroduction Dr. Eng. Farag Elnagahy
Introduction to 3D Graphics John E. Laird. Basic Issues u Given a internal model of a 3D world, with textures and light sources how do you project it.
02/14/02(c) University of Wisconsin 2002, CS 559 Last Time Filtering Image size reduction –Take the pixel you need in the output –Map it to the input –Place.
1 Computer Graphics Week13 –Shading Models. Shading Models Flat Shading Model: In this technique, each surface is assumed to have one normal vector (usually.
Technology and Historical Overview. Introduction to 3d Computer Graphics  3D computer graphics is the science, study, and method of projecting a mathematical.
09/09/03CS679 - Fall Copyright Univ. of Wisconsin Last Time Event management Lag Group assignment has happened, like it or not.
Filtering and Color To filter a color image, simply filter each of R,G and B separately Re-scaling and truncating are more difficult to implement: –Adjusting.
Advanced Computer Graphics Depth & Stencil Buffers / Rendering to Textures CO2409 Computer Graphics Week 19.
Emerging Technologies for Games Alpha Sorting and “Soft” Particles CO3303 Week 15.
Computer Graphics Bitmaps & Sprites CO2409 Computer Graphics Week 3.
Hank Childs, University of Oregon October 3, 2014 CIS 441/541: Intro to Computer Graphics Lecture 2: The Scanline Algorithm.
CS-378: Game Technology Lecture #4: Texture and Other Maps Prof. Okan Arikan University of Texas, Austin V Lecture #4: Texture and Other Maps.
Advanced Computer Graphics Advanced Shaders CO2409 Computer Graphics Week 16.
Hank Childs, University of Oregon Oct. 10, 2014 CIS 441/541: Introduction to Computer Graphics Lecture 4: Interpolating Colors and the Z-buffer.
Game Programming 06 The Rendering Engine
Hank Childs, University of Oregon Lecture #6 CIS 410/510: Advection (Part 1)
Digital Image Compositing. Compositing for volume rendering c1 c2 c3 The initial pixel color = Black opaque Back-to-Front compositing: use ‘under’ operator.
Hank Childs, University of Oregon Lecture #3 Fields, Meshes, and Interpolation (Part 2)
Parallel Ray Tracer Computer Systems Lab Presentation Stuart Maier.
CS559: Computer Graphics Lecture 4: Compositing and Resampling Li Zhang Spring 2008.
Computer Graphics Blending CO2409 Computer Graphics Week 14.
Hank Childs, University of Oregon Lecture #10 CIS 410/510: Isosurfacing.
Lynwood Dunn ( ) Visual effects pioneer Acme-Dunn optical printer.
Hank Childs, University of Oregon Unstructured Grids.
Hank Childs, University of Oregon Volume Rendering, Part 3.
Hank Childs, University of Oregon Volume Rendering Primer / Intro to VisIt.
Hank Childs, University of Oregon Volume Rendering, pt 1.
Graphics Graphics Korea University cgvr.korea.ac.kr Image Processing 고려대학교 컴퓨터 그래픽스 연구실.
Visual Appearance Chapter 4 Tomas Akenine-Möller Department of Computer Engineering Chalmers University of Technology.
UniS CS297 Graphics with Java and OpenGL Blending.
CS 418 : EXAM 2 REVIEW TA: Ryan Freedman Sushma Kini Chi Zhou.
Compositing and Rendering
Model Optimization Wed Nov 16th 2016 Garrett Morrison.
Hank Childs, University of Oregon
Hank Childs, University of Oregon
Discrete Techniques.
Week 7 - Monday CS361.
Week 2 - Friday CS361.
Advanced Computer Graphics
CIS 410/510: Isosurfacing (pt 2)
Volume Visualization Chap. 10 November 20 , 2008 Jie Zhang Copyright ©
Visual Appearance Chapter 4
Hank Childs, University of Oregon
Deferred Lighting.
3D Graphics Rendering PPT By Ricardo Veguilla.
The Graphics Rendering Pipeline
Jim X. Chen George Mason University
Images Presentation Name Course Name Unit # – Lesson #.# – Lesson Name
Volume Visualization Chap. 10 December 3 , 2009 Jie Zhang Copyright ©
Real-Time Volume Graphics [06] Local Volume Illumination
Volume Rendering (2).
Hank Childs, University of Oregon
Hank Childs, University of Oregon
© University of Wisconsin, CS559 Spring 2004
Volume Rendering.
Images Presentation Name Course Name Unit # – Lesson #.# – Lesson Name
An Algorithm of Eye-Based Ray Tracing on MATLAB
CS-378: Game Technology Lecture #4: Texture and Other Maps
GR2 Advanced Computer Graphics AGR
Hank Childs, University of Oregon
Presentation transcript:

Hank Childs, University of Oregon Volume Rendering, Part 2 Hank Childs, University of Oregon

Announcements VisIt lecture: will be posted (sorry) Grading: will happen soon Projects: ~30 hours Aim for something worthy of your resume Pre-defined project: posted tonight Volume rendering lectures: today & Weds Weds: yes, there’s class

Review

Plotting Techniques X-rays Film/image Emitter

Volume rendering Important visualization technique for 3D data Use combination of color and transparency to see entire 3D data set at one time. There are multiple ways to do volume rendering. I will describe one way today (raycasting). That will help explain the technique. I will describe alternate ways on Friday.

Volume rendering overview Camera Pixels on the screen 3D data

Volume rendering overview Camera Pixels on the screen Ray casting game plan: For every pixel on the screen, Find ray for that pixel Intersect volume with ray Calculate color from intersection Assign color to pixel 3D data

Outline Find Ray For That Pixel Intersect Volume With Ray Calculate Color From Intersection Assign Color To Pixel

Outline Find Ray For That Pixel Intersect Volume With Ray Calculate Color From Intersection Assign Color To Pixel

How do we specify a camera? The “viewing pyramid” or “view frustum”. Frustum: In geometry, a frustum (plural: frusta or frustums) is the portion of a solid (normally a cone or pyramid) that lies between two parallel planes cutting it.

This answers the “find ray for this pixel” question From Pixels to Rays From: Zhang, CSUSM, Introduction to Ray Tracing This answers the “find ray for this pixel” question

Outline Find Ray For That Pixel Intersect Volume With Ray Calculate Color From Intersection Assign Color To Pixel

Intersect Volume With Ray } Camera Pixels on the screen 3D data What is the result of the ray-volume intersection?

Ray-Volume Intersection How would you calculate this intersection?

Face Intersections Can we calculate the intersections at the faces? Can we calculate the data at the faces? Is this a good idea? Why or why not? X (it is not a good idea if we interpolate between the face values) How do we fix this? X

Ray-Volume Intersection: sampling x Camera Pixels on the screen Sampling is the most common method for “ray-casting” volume rendering 3D data Do we know how to do this sampling?

Approximately how many samples will we calculate? How to sample quickly Multiple strategies. For now, similar as before: Find first cell intersected Intersection is at a face Find where ray exits that cell Are there samples within the cell? Then sample them? Go to next cell (which shares a face) and repeat Keep going until you exit the volume, one cell at a time, and see what samples it covers Approximately how many samples will we calculate?

Outline Find Ray For That Pixel Intersect Volume With Ray Calculate Color From Intersection Assign Color To Pixel

Refresher: Color Maps

Transfer function Assigns a color and an opacity to each scalar value. Technique Abstraction for assigning color Pseudocoloring Color Map Volume Rendering Transfer Function

Transfer Function

“Alpha Channel” Represents opacity Stored alongside RGB 1.0 or 255: fully opaque 0: fully transparent Stored alongside RGB Referred to as RGBA Floating point (1.0) vs byte (255): Precision vs uniformity with RGB & performance

Applying a transfer function Sample Scalar Value 5.8 1 4.7 2 3 3.5 4 1.1 R G B A 255 1.0 0.75 0.5 Quiz: calculate the results from transfer function for each sample

Transparency Quiz: If you have a red square that is 50% opaque in front of a black background, what color would you see? Represent your answer in terms of (R, G, B) Answer: (128, 0, 0)

Transparency If you have an opaque red square in front of a blue square, what color would you see? Red If you have a 50% transparent red square in front of a blue square, what color would you see? Purple If you have a 100% transparent red square in front of a blue square, what color would you see? Blue

Formula For Transparency Front = (Fr,Fg,Fb,Fa) a = alpha, transparency factor Sometimes percent Typically 0-255, with 255 = 100%, 0 = 0% Back = (Br,Bg,Bb,Ba) Equation = (Or = Fa*Fr+(1-Fa)*Ba*Br, Og = Fa*Fg+(1-Fa)*Ba*Bg, Ob = Fa*Fb+(1-Fa)*Ba*Bb, Oa = Fa+(1-Fa)*Ba) Alpha component is important! Any observations?

Wikipedia page is great reference: Representing Colors Two ways of representing colors Pre-multiplication Straight RGBA (non-premultiplied) Slides use straight RGBA. Will describe pre-multiplication afterwards Wikipedia page is great reference: http://en.wikipedia.org/wiki/Alpha_compositing

Transparency If you have an 25% transparent red square (255,0,0) in front of a blue square (0,0,255), what color would you see (in RGB)? (192,0,64) If you have an 25% transparent blue square (0,0,255) in front of a red square (255,0,0), what color would you see (in RGB)? (64,0,192)

Calculating Color Sample Scalar Value 5.8 1 4.7 2 3 3.5 4 1.1 R G B A 255 1.0 0.75 0.5 Note: we will talk more about alpha Equation = (Fa*Fr+(1-Fa)*Ba*Br, Fa*Fg+(1-Fa)*Ba*Bg, Fa*Fb+(1-Fa)*Ba*Bb, Fa+(1-Fa)*Ba) Apply this equation over and over until you run out of samples (then use background color)

Game Plan Initialize pixel color / alpha with TransferFunction(first sample) Iterate over remaining samples Front-to-back order pixel color / alpha updated each time using composite function

Outline Find Ray For That Pixel Intersect Volume With Ray Calculate Color From Intersection Assign Color To Pixel

Assign Color To Pixel Allocate a buffer for storing RGB values Buffer should have one RGB for every pixel on the screen. As you calculate color for a ray, assign that color to its corresponding buffer entry When you have all of the colors, put that image up on the screen, as if you had rendered it using graphics cards.

Volume rendering overview Camera Pixels on the screen Ray casting game plan: For every pixel on the screen, Find ray for that pixel Intersect volume with ray Calculate color from intersection Assign color to pixel 3D data Which of these 4 steps were easy? Which were hard?

Ray-Volume Intersection: sampling x x Camera Pixels on the screen What happens when we change the sampling rate? 3D data Imagine if we had half or twice as many transparent squares… Should the picture change if we change the sampling rate?

What is the opacity of these three samples together? Opacity Adjustment Consider ray with this profile 100% transfer function Opacity from 50% x x x Distance along ray What is the opacity of these three samples together?

Opacity Adjustment Consider ray with this profile New interpretation: opacity is for a range, not a point. If you double the sampling, then the range is reduced. Typically think of opacity for a given sampling rate and then adjust as sampling rate changes. 100% transfer function Opacity from 50% x x x x x Distance along ray What is the opacity of these five samples together?

Opacity Correction http://http.developer.nvidia.com/GPUGems/gpugems_ch39.html