1 / 38

Visualizing Time-Varying Three-Dimensional Flow Fields Using Accelerated UFLIC

— 11th International Symposium on Flow Visualization, Notre Dame, Indiana, Aug 9-12, 2004 —. Visualizing Time-Varying Three-Dimensional Flow Fields Using Accelerated UFLIC. Zhanping Liu, PhD Robert J. Moorhead II, PhD Visualization Analysis & Imaging Lab ERC / GeoResources Institute

marva
Download Presentation

Visualizing Time-Varying Three-Dimensional Flow Fields Using Accelerated UFLIC

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. — 11th International Symposium on Flow Visualization, Notre Dame, Indiana, Aug 9-12, 2004 — Visualizing Time-Varying Three-Dimensional Flow Fields Using Accelerated UFLIC Zhanping Liu, PhD Robert J. Moorhead II, PhD Visualization Analysis & Imaging Lab ERC / GeoResources Institute Mississippi State University

  2. Introduction • Flow visualization • LIC (Line Integral Convolution) • UFLIC (Unsteady Flow LIC) • AUFLIC (Accelerated UFLIC) • Overview • Flow-driven seeding strategy • Dynamic seeding controller • VAUFLIC (Volume AUFLIC) • Volume AUFLIC • VAUFLIC rendering • Results Outline • Conclusions

  3.  Major Challenges  In-depth perception of directions  Computational performance  Increasingly large-scale data size  Time-varying flows  Flows defined on complex grids  Feature extraction & tracking  Available Methods Graphics Based Methodsachieve either local, discrete, coarse, or cluttered representations using various graphical primitives Introduction —Flow Visualization arrow plots, streamlines, pathlines, timelines, streaklines, particle tracing, surface particles, stream ribbons, stream polygons, stream surfaces, stream arrows, stream tubes, stream balls, flow volumes, and topological analysis Texture / Image Based Methodsemploy texture synthesis and image processing to provide global, continuous, dense, pleasing representations Spot Noise, LIC (Line Integral Convolution), UFLIC (Unsteady Flow LIC), HATA (Hardware-Accelerated Texture Advection), IBFV (Image-Based Flow Visualization), LEA (Lagrangian-Eulerian Advection), UFAC (Unsteady Flow Advection-Convolution), and their variations

  4. Introduction — LIC A LIC image color-mapped with the velocity magnitude (blue: lowest; red: highest)

  5. Basic Idea LIC (Line Integral Convolution) was presented by Brian Cabral and Casey Leedom in ACM SIGGRAPH'93 Conference flow field (wind) LIC image (pattern) noise texture (fine sand) Introduction — LIC LIC convolves an input noise texture using a low-pass filter along pixel- centered symmetrically bi-directional streamlines to exploit spatial correlation in the flow direction LIC synthesizes an image that provides a global dense representation of the flow, analogous to the resulting pattern of wind-blown sand 

  6. ( () ) ( + d) () d Introduction — LIC • Pipeline a point in the flow field, the counterpart of a pixel in the LIC image the correlated pixels along the streamline index the input noise for the texture values d( () ) / d  = ( () ) ( + d) = () + ( () ) d  compute the target pixel value in the LIC image by convolution

  7. Introduction — LIC • Animation — successively shifting the phase of a periodic convolution kernel

  8. VolumeLIC 3D LIC + Volume Rendering Visualizing Steady Volume Flows

  9. Motivation LICisan image-space oriented, Eulerian-based texture synthesis technique — given a pixel in the output image, locate the correlated pixels and accept the contributions / properties • UFLIC Unsteady Flow LIC by Han-Wei Shen & David L. Kao in IEEE Visualization'97 & IEEE TVCG Vol.4, No.2, 1998  High spatial coherence  Strong temporal coherence Introduction — UFLIC LIC can only be used to visualize steady flow fieldssinceanimating a sequence of LIC frames of a time-varying flow fails to maintain temporal coherence ?Particle-space oriented, Lagrangian-based texture synthesis techniques — given a particle at a time step, locate downstream points (i.e., pixels in subsequent frames) where it leaves the footprint (scatters the contribution / property) over time www.erc.msstate.edu/~zhanping/Research/ FlowVis/AUFLIC/Comparison.html

  10. Components Time-Accurate Value Scattering Scheme  At each time step, a Scattering Process (SCAP) occurs for which a seed is released from each pixel as a contributor to scatter the texture value to the downstream pixels along the advected pathline in its Life Span— usually several time steps  Value scattering to “downstream pixels” correlates both intra-frame pixels and inter-frame pixels to establish high temporal-spatial coherence Introduction — UFLIC Per-Pixel Value Accumulation-Convolution As a receiver, each pixel keeps several stamped buckets to accumulate deposited values while a frame is obtained by convolving the values that each pixel has received and stored in the very bucket stamped with the frame index Successive Texture Feed-Forward Strategy Besides the output, each synthesized frame is High-Pass Filtered with Noise Jittering and taken as the input texture for the next SCAP to enhance inter-frame coherence

  11. white noise disk files input texture vector data buffer time-accurate value scattering process (SCAP) release a seed from each pixel center t = t + 1 advect the pathline to the next pixel feed texture forward if within the life span scatter the seed value accumulate to the receiver’s buckets convolve each pixel in the bucket with stamp t noise-jittered high-pass filtering frame t Introduction — UFLIC • Pipeline

  12. : the input texture for SCAP k : the input texture for SCAP k + 1 : the pathline advected by seed A (the pixel center) in SCAP k : the pathline advected by seed B (the pixel center) in SCAP k + 1 y : the point (P) through which seed A passes at exactly time step k + 1 in SCAP k P : the point (Q) through which seed A passes at a small fractional time past time step k + 1 in SCAP k Q : the pixel center from which seed B is released at time step k + 1 in SCAP k + 1 B x A & B’s common receiver-pixels A B SCAP k k seed A’s receiver- pixels in SCAP k SCAP k + 1 k + 1 stamp k k + 1 k + 2 k +3 k + 4 seed B’s receiver- pixels in SCAP k + 1 k + 2 k + 3 k + 4 k + 5 life span = 4 time steps time step • Seed B can be released either from point P at exactly time step k + 1, or from a loosely specified point Q at a small fractional time past time step k + 1 to reuse the red pathline in SCAP k + 1 To reuse pathlines, a temporally-spatially flexible seeding strategy is required

  13. Motivation  Problemlow computational performance  Reasonredundant pathline advection Solutionas-many-as-possible pathline reuse • AUFLIC — Accelerated UFLIC  Targets the bottleneckvalue scattering process (SCAP)  Exploits the correlations intra-SCAPand inter-SCAP Places seeds along available pathlines flow structures taken into account Reuses as many pathlines as possible as few pathlines advected as possible Maintains a dense scattering coverage for high temporal-spatial coherence AUFLIC — Overview Employs a flexible seeding strategy instead of the conservative one Spatial flexibility: a seed may not necessarily be released exactly from a pixel center as long as the seed is within the pixel Temporal flexibility: a seed may not necessarily be released exactly at an integer time step; instead at a fractional time shortly after the SCAP begins

  14. Comparison Items UFLIC AUFLIC pathline integrator Euler (first-order) Fourth-order Runge-Kutta (RK4) step size line-segment clamp against pixels adaptive step size error control none embedded Runge-Kutta formulae numerical accuracy first-order second-order overall efficiency slow and inaccurate fast and accurate Pathline Integration Flow-Driven Seeding Strategy Dynamic Seeding Controller Result temporal flexibility none (always at an integer time step) within a fractional time past a time step spatial flexibility none (always from a pixel center) an arbitrary position within a pixel flow-aligned no (a lattice pattern) yes (release seeds along pathlines) seeding order left-to-right, top-to-bottom roughly left-to-right, top-to-bottom flow structures ignored adapt seeding to flow structures dense scattering yes yes pathline integration a large amount substantially reduced performance low high (1 order-of-magnitude faster) quality high temporal-spatial coherence high temporal-spatial coherence Line Convolution SCAP Correlation intra-SCAP ignored copy and truncate pathlines inter-SCAP ignored reuse and extend pathlines evenly line sampling none by cubic Hermite polynomial accumulation line-segment lengths as accum-weights collected values are averaged AUFLIC — Overview • AUFLIC v.s. UFLIC

  15. Key Points Spatial flexibility arbitrary position with a pixel (not necessarily the center) Temporal flexibilitywithin a small fractional time shortly after the SCAP begins Pathline copyingintra-SCAP operation — S andS0 are released in the same SCAP Pathline reuse inter-SCAP operation — S andS0 are released in different SCAPs A relatively-continuous, flow-structure based seeding strategy to replace the intermittent (only at integer time steps), pixel-center based scheme of UFLIC High temporal-spatial coherence is maintained due to a still dense value scattering coverage AUFLIC — Flow-Driven Seeding Strategy Spatially-evenly Pathline sampling convolution is simplified to averaging Fourth-order Runge-Kutta integrator with adaptive step-size and error control  Cubic Hermite polynomial interpolation If possible,seeds (S) are released at some sample points along an available pathline (seed S0) at the same time as S0 passes through these sample points  only a small number of seeds need to actually advect pathlines  a significant number of seeds extract pathlines by pathline copying & pathline reuse

  16. advect copy & truncate A y copy & truncate save in a pathline-list truncated part for B x B truncated part for E C D stamp k k + 1 k + 2 k +3 k + 4 A Life span = 4 time steps reuse from the list E copy & truncate time step C k k + 1 k + 2 k + 3 k + 4 k + 5 receiver pixels B copy & truncate D E F SCAP k + 1 & extend F SCAP k

  17. Problem As pathlines are advected, copied & truncated, saved, and reused & extended over SCAPs, there may be an undesirable seeding pattern in a SCAP  Seeding redundancymany seeds released from the same pixel • Controller governs the seed distribution in a SCAP by determining for pixel whether a pathline is advected, reused & extended, copied & truncated, saved for the next SCAP, or deleted  An adaptive, global, organized control over the seed placement preventing redundant pathline copying or reuse while maintaining dense scattering  A balance between pathline reuse and advection in each SCAP computational fluctuation is suppressed to obtain a nearly constant frame rate AUFLIC — Dynamic Seeding Controller  un-necessary & image blurred  increased storage overhead & degraded acceleration-efficiency  Seeding vacancyno seeds released from pixels, e.g., in diverging regions  value scattering disabled & features missed  artifacts introduced

  18. Pixel State To ensure no more than one seed is released from a pixel in a SCAP openthere has not been yet a seed released from the pixel allowing for a seed release closethere has been already a seed released from the pixel blocking further seed releases • Two Arrays Current[1 …M, 1 … N]for pixels in the current SCAP checks if a pixel still allows for a seed release in the current SCAP Next[1 …M, 1 … N] for pixels in the next SCAP checks if a pixel allows for a given pathline to be saved in the current SCAP so that it is reused from the pixel in the next SCAP • Dynamic Update  InitializationNext[1 …M, 1 … N] = open When each SCAP beginsCurrent[1 …M, 1 … N] = Next[1 …M, 1 … N] During each SCAPtwo arrays are dynamically updated AUFLIC — Dynamic Seeding Controller

  19. AUFLIC achieves near-interactive flow visualization (frame generation) with up to 160k particles in time-varying flow fields (left : 397  397 data points & 101 time steps at 1.2FPS;right: 576  291 data points & 41 time steps at 1.0FPS) on SGIOnyx2(four400MHZ MIPS R12000 / 4GB RAM)

  20. Texture-Based Volume Flow Visualization Limited to steady flows  “Visualizing Vector Fields using Line Integral Convolution and Dye Advection” — Han-Wei Shen et al, IEEE Symposium on Volume Visualization 96  “Strategies for Effectively Visualizing 3D Flow with Volume LIC” — Victoria Interrante & Chester Grosch, IEEE Visualization 97  “Interactive Exploration of Volume LIC Based on 3D-Texture Mapping” — C. Rezk-Salama et al, IEEE Visualization 99  “3D IBFV: Hardware-Accelerated 3D Flow Visualization” — Alexandru Telea & Jarke J. van Wijk, IEEE Visualization 03 Dependent on special-purpose hardware  “Hardware-Accelerated Visualization of Time-Varying 2D and 3D Vector Fields by Texture Advection via Programmable Per-pixel Operations” — D. Weiskopf et al, International Workshop on Vision, Modeling&Visualization 01 — the only publication on texture-based time-varying volume visualization — dependent on per-pixel operations which are not supported by ordinary cards An open problem intensive computation, temporal-spatial coherence, rendering of 3D flow textures VAUFLIC — Volume AUFLIC

  21. Volume AUFLIC The first hardware-independent texture-based time-varying volume flow visualization method Extension of AUFLIC to time-varying volume flows 2D vectors  3D vectors  2D input (noise) textures  3D input (noise) textures  output pixels  output voxels  flow-driven seeding strategy  dynamic seeding controller work in the same way as in AUFLIC Volume AUFLIC is 5 times faster than brute-force volume UFLIC Small memory footprint for large-scale time-varying volume flow vis VAUFLIC — Volume AUFLIC Application of volume rendering to view the output volumetric textures

  22. Volume Rendering Without constructing intermediate geometric representations (e.g., triangles) to fit iso-surfaces through the volume Operating directly on voxels by using a light absorption-transmission model and a transfer function to assign colors & opacities to voxels that are then composited along view directions Available techniques ray casting  ray tracing  splatting  shear-warp  hardware-based texture mapping VAUFLIC — VAUFLIC Rendering Well suitable for investigating the distribution of a physical property (e.g., density, velocity magnitude, vorticity, temperature, pressure, precipitation) within a dense volume, representing amorphous transparent gel-like objects such as clouds and smoke that are too complicated to be either geometrically modeled or effectively rendered using extracted iso-surfaces

  23. Ray Casting Sampling& interpolation the original signal is reconstructed by (e.g., tri-linear) interpolation and then (in most cases evenly) sampled along the ray to find the contributions affecting the pixel Compositingsamples samples are assigned color & opacity values (RGBAs) by a transfer function and then composited from front to back to sum the opacity- weighted colors until the opacity accumulates to 1 Backward mapping rays are cast from the viewer through the pixels backward into the volume (object)

  24. Problems Although volume rendering is well established in medical data visualization Ad hoc in rendering dense volume flow textures degraded visual perception of 3D flow directions in dense volume  poor depth cueing  occluded interior flow structures VAUFLIC — VAUFLIC Rendering • Lack of any physical meaning of a texture value  the histogram of a VAUFLIC texture, nearly a horizontal line, offers no guidance to transfer function design since it does not convey information provided by, e.g., that of a medical data which can be used to distinguish between bones and soft tissues

  25. Magnitude-Based Color-Opacity Mapping • VAUFLIC texture values are used to compute gradients used as normals in Phong shading • The velocity magnitude is used to guide color & opacity mapping in the transfer function designto enhance or suppress certain parts of the flow texture volume magnitude volume transfer function gradients (normals) Phong shading voxel intensity (grey) color hue (r, g, b) ray casting voxel color (R, G, B) voxel opacity (A) 2D color image VAUFLIC — VAUFLIC Rendering

  26. Time-Varying Volume Flow Dataset • 41 time steps • 144  73  81 data points • Transfer Function magnitude histogram opacity curve VAUFLIC texture histogram color mapping bar opacity mapping bar VAUFLIC — Results • High Temporal-Spatial Coherence Flow directions and interior flow structures can be clearly revealed in images by tuning the magnitude-based transfer function while the flow evolution is shown by means of a smooth animation

  27. VAUFLIC — Results

  28. VAUFLIC — Results

  29. VAUFLIC — Results

  30. VAUFLIC — Results

  31. VAUFLIC — Results

  32. VAUFLIC — Results

  33. VAUFLIC — Results

  34. VAUFLIC — Results

  35. VAUFLIC — Results

  36. Conclusions • UFLIC employs a time-accurate value scattering scheme & a successive texture feed-forward strategy to achieve very high temporal-spatial coherence in visualizing 2D unsteady flows • AUFLIC adopts a flow-driven seeding strategy & a dynamic seeding controller to reuse pathlines in the computationally expensive value scattering process of UFLIC to achieve one order-of-magnitude acceleration, or near-interactive (1.0f FPS) visualization with up to 160k particles in time-varying 2D flows without temporal-spatial coherence degradation • VAUFLIC is the extension of AUFLIC to texture-based time-varying volume flow visualization, so far the first hardware-independent solution of its kind • Magnitude-based color-opacity mapping is used in transfer function design for effective volume rendering of VAUFLIC flow textures to reveal interior flow structures and the evolution

  37. Future Work • To enhance VAUFLIC by using shorter pathlines while maintaining high temporal-spatial coherence • To improve volume rendering of 3D flow textures by, e.g., using ROI masking, clipping planes, and 3D halos • Acknowledgments — DoD HPCMP program & NSF EPS-0132618 • Key References • Han-Wei Shen and David L. Kao, “New Line Integral Convolution Algorithm for Visualizing Time-Varying Flow Fields,” IEEE Transactions on Visualization and Computer Graphics, Vol. 4, No. 2, pp. 98-108, 1998 • Zhanping Liu and Robert J. Moorhead, “Accelerated Unsteady Flow Line Integral Convolution, ” IEEE Transactions on Visualization and Computer Graphics, 2004 (accepted to appear) Conclusions • URL http://www.erc.msstate.edu/~zhanping/Research/FlowVis/FlowVis.htm

  38. Thank You

More Related