Rendu volumique Nicolas Holzschuch iMAGIS/GRAVIR IMAG

Slides:



Advertisements
Présentations similaires
Chaîne de Synthèse Réel Modélisation Rendu Image Fichier Scène
Advertisements

Hierarchical Z-Buffer Visibility
Modélisation par Surfaces Implicites à Squelettes Complexes
______________________________________________________________________________________________________________________________________________________________________.
Fanny CHEVALIER Guillaume CAURANT
for Painting and Rendering Textures on Unparameterized Models
LOD et Progressive Meshes (maillages progressifs) Hugue Hoppes 1996
RENDU DE TERRAIN Problématique : Rendre une très large zone de terrains en la simplifiant au maximum pour réduire le nombre de polygones à afficher. A.Bailly.
Simplification Out-of-Core des modèles polygonales complexes
Unstructured Lumigraph Rendering
The Reyes Image Rendering Architecture
Accélération du Rendu Volumique basée sur la Quantification des Voxels
Marques Patrice & Maurer Romain DESS IMM 2002 / 2003 ACCELERATION DE LA RADIOSITE.
Technique des Surfels Surfels: Surface Elements as Rendering Primitives SIGGRAPH 2000 H.Pfiste, J.van Baar, M.Zwicker, M.Gross.
Matthias Zwicker Hanspeter Pfister Jeroen van Baar Markus Gross
Efficient Simplification of Point-Sampled Surfaces
Ray Tracing Acceleration Techniques A Survey of Ray Tracing Acceleration Techniques James Arvo et David Kirk Ray Tracing on Programmable Graphics Hardware.
1/30 Rendu par tracé de chemins ESSI2 George Drettakis http: //www-sop.imag.fr/reves/George.Drettakis/cours/ESSI2/index.html.
Synthèse d’images.
à partir notamment du cours Siggraph 97 et d’autres ….
IMAGIS-GRAVIR / IMAG Rendu de forêts en temps-réel iMAGIS / GRAVIR Franck Sénégas DEA IVR Tuteur: Fabrice Neyret.
Xavier Décoret* Frédo Durand° François Sillion*
Modélisation 3D Réalisation d'une image de synthèse
Rapport signal sur bruit
Génération interactive dimages projectives : Application à la Radiothérapie Pierre BLUNIER Du 01/12/2002 au 28/03/2003 Centre Léon Bérard.
Lancer de rayons interactif
Le diaphragme (photographie)
IFT3730: Infographie 3D Transformations Géométriques
Résolution des Équations Différentielles
Evaluation de la qualité des documents anciens
Cours Corporate finance Eléments de théorie du portefeuille Le Medaf
Méthode des k plus proches voisins
Modélisation géométrique à l’aide d’un maillage
IFT3730: Infographie 3D Illumination locale
Nicolas Holzschuch Cours d’Option Majeure 2
Nicolas Holzschuch iMAGIS-GRAVIR/IMAG
Visualisation de surfaces décrites analytiquement
OBJETS ÉLÉMENTAIRES DANS L’ESPACE À TROIS DIMENSIONS
IFT3730 : Infographie 3D Systèmes et modèles graphiques Pierre Poulin, Derek Nowrouzezahrai Hiver 2013 DIRO, Université de Montréal.
IFT2740 : Outils de l'infographie 3D Systèmes et modèles graphiques
IFT3355: Infographie Visualisation
Méthodes de rendu utilisant les images
Design dun système de vision embarqué. Application:
Réalisation d'une image de synthèse
GAMMA CAMERA (images).
IFT3355: Infographie Courbes et surfaces
L’adaptativité pour un solveur de l’équation de Vlasov
Rendu réaliste en synthèse d’images.
Géométrie épipolaire (deux vues)
1 Modèles de particules Reeves, W. T., "Particle Systems - A technique for Modeling a Class of Fuzzy Objects," SIGGRAPH 83, Reeves, W. T., and.
Caractérisation texturale des surfaces boisées dans une image Ikonos de la région de Montréal Pierre Bugnet Langis.
Modélisation géométrique
Création en images de Synthèse Modèles de rendu d’une scène 3D
Etude et test des algorithmes d'estimation de mouvement en MPEG
Un état de l’art sur les logiciels de détection de collision
Projet Lancer de Rayons
Credits : Joëlle Thollot, Hector Briceño, Edmond Boyer
Les différents modèles
GRAPHISME PAR ORDINATEUR SIF Contenu du cours 8 Rendu de surfaces –Modèles de rendu de surfaces –Illumination de la scène –Sources lumineuses –Composante.
Synthèse d’images et Rendu Réaliste Compression Progressive de Modèles 3D DOMENGET Bruno DUMAS Benjamin EISTI.
Romain Dupont encadré par J.Aubourg et P. Fuchs
Architecture et Fonctionnement d’un GPU Géométrie Rendu.
Introduction aux Surfaces implicites
FAUVET Nicolas 1 Gestion de données scientifiques 3d massives pour l’interaction en Réalité Virtuelle Doctorant: Nicolas Fauvet Encadrant: Jean-Marc Vézien.
Plan du cours Cours 1,2 : le pipeline graphique
Visualisation des flots optiques en 3D
OBJETS ÉLÉMENTAIRES DANS L’ESPACE À TROIS DIMENSIONS
IFT3355: Infographie Plan © Victor Ostromoukhov Dép. I.R.O. Université de Montréal.
Introduction aux technologies du jeux-vidéo Steve Gury
Couche limite atmosphérique Micrométéorologie. Équations de Reynolds 7 équations et 16 inconnues...
Transcription de la présentation:

Rendu volumique Nicolas Holzschuch iMAGIS/GRAVIR IMAG

Rendu volumique Pourquoi faire ? –Parce qu'on a des données volumiques… Simulations numériques Scanners, données médicales –Visualiser et comprendre Qu'est-ce qu'on visualise ? –Ce qu'il faut pour comprendre Comment faire ?

Exemples

Plan Le traitement des données Les techniques standard, vue générale –Surfaces, pixels, volumes Les techniques standard, détails –Surfaces, pixels, volumes Utilisation du hardware Et le réalisme ?

Données de départ Données volumiques –Champ volumique f(x,y,z), voire f(x,y,z,t) –Densité, température, concentration,… Échantillonnage –Régulier ou irrégulier –Éventuellement insuffisant Objets échantillonnés ? Hautes fréquences ? Limite de Nyquist

Techniques générales Beaucoup d'information –Trop ? Éliminer certaines informations : –Cacher, masquer, –Rendre transparent, –Couper… Perception des surfaces : –Ombrage

Traitement des données Affichage : RGB + opacité Fonctions de transfert : –Permettent de souligner les détails, au choix © Craig Upson, 1988

Interpolation des échantillons Interpolation linéaire entre les échantillons –Linéaire par axe, tri-linéaire au total : –Calcul des coefficients : –Par rapport à la distance à l'œil : S est cubique

Techniques générales © Drebin, 1988

Techniques de visualisation Par surfaces Par pixels Par volume

Techniques de visualisation Par surfaces : –Extraire les surfaces iso-potentielles Marching-cube, octree… –Visualisation standard : Z-buffer, ombrage, transparence… –Pré-traitement (un peu) long Par pixels Par volume

Techniques de visualisation Par surfaces Par pixels : –Lancer de rayon –Partie du volume de données intersectée par le rayon –Intégration/maximum/autres... Par volume

© Craig Upson, 1988

Techniques de visualisation Par surfaces Par pixel Par volume : –Projection des cellules du volume Interpolation dans la projection –Intégration directe : Valeur à un pixel = intégrale pour chaque échantillon Projection orthographique : –Noyau indépendant de la position Afficher la projection du noyau

Et maintenant, les détails

Extractions de surfaces Marching cubes (Lorensen, 1987) –Extraction de l'iso-surface et des normales –Échantillons ponctuels, organisés en cubes © Lorensen, 1987

Marching cubes Sélection des cubes qui intersectent l'iso-surface : –Au moins un sommet dedans, au moins un sommet dehors Classification des cubes : –8 sommets, 2 états (dedans, dehors) = 256 possibilités –Symétrie des 2 états : 128 possibilités –Symétries par rotation : 14 possibilités –Pour chaque possibilité, une seule triangulation possible –De 1 à 4 triangles par cube

© Lorensen, 1987

Marching cubes Indexation des cubes : –8 bits par cube –Table donnant les arêtes intersectées Interpolation linéaire sur les arêtes pour calculer les points d'intersection © Lorensen, 1987

Calcul des normales Les normales sont calculées indépendamment –Lisser la surface obtenue –Une normale par triangle Calcul : –Gradient de la fonction : normal à l'iso-surface –Calcul du gradient aux sommets du cube –Normalisation : normale aux sommets du cube –Interpolation linéaire : normales aux sommets des triangles –Interpolation linéaire : normales sur les triangles Besoin de 4 tranches en mémoire

Gradient aux sommets du cube Estimation par différences centrales :

Marching-cubes : accélérations Cohérence du modèle : –On ré-utilise les calculs des cubes précédents Subdivision hiérarchique –Octrees Élimination de certaines ambiguïtés –Plus de cubes, moins d'erreurs

Marching-cubes : problèmes Beaucoup de polygones : –Même ordre de grandeur que le nombre de voxels –Stockage, affichage… Parfois plus cher de stocker les polygones que de stocker le volume ! Gros problèmes liés à la précision –Sous-échantillonnage –Artefacts

Rendu à base de pixels Lancer de rayons simplifié –Sans rebonds –Modèle simplifié de la lumière –Interpolation dans chaque cellule traversée –Calcul de l'opacité et de l'intensité –Arrêt quand opacité = 1

Rendu à base de pixels

f : atténuation avec la distance O : opacité. Dépend de S (le champ) K d : dépend de S. n : normale ; définie par le gradient de S bg : couleur du fond

Intégration Calcul de l'intégrale cellule par cellule Valeurs aux coins de la projection du pixel sur la cellule (par interpolation) Dans une cellule : –Intégration pas à pas (I et O) –Arrêt quand O=1 Si cellule se projette entièrement dans un pixel : –Valeurs moyennes pour la cellule, –Multiplié par le rapport aire projetée/aire du pixel

Optimisations

Parallélisation Traitement dans l'ordre. Les cellules de même numéro ne se recouvrent pas, donc elles peuvent être traitées simultanément.

Cas particulier : MIP

Par le volume : coherent projection Projection des cellules : –Même projection pour toutes les cellules –Rendu par polygones (de 1 à 7 pg par cellule) –Calcul des valeurs aux sommets des polygones –Interpolation entre les sommets Faite par la librairie graphique Projection, puis interpolation Approximatif, mais rapide

© Wilhelms, 1991

Par le volume : splatting Extraire la contribution de chaque cellule –Chaque cellule contribue à différents pixels

footprint d'une cellule Empreinte de la cellule sur chaque pixel –(x,y) déplacement par rapport à la projection du centre Noyau approximé, pré-échantillonné

Noyaux Gaussiens approximés par des polygones –Utilise le hardware –Qualité de l'approximation variable © Laur, 1991

Splatting hiérarchique © Laur, 1991

Décomposition hiérarchique © Laur, 1991 Un noyau pour chaque cellule Décomposition adaptable selon la précision/la rapidité souhaitée

Utilisation du hardware Textures 3D : –Construire une texture 3D à partir des données –Utiliser la texture 3D pour l'affichage Plans parallèles semi-transparents texturés –De l'arrière vers l'avant C'est la carte qui fait tout –Conversion de coordonnées, extraction de textures... On peut rajouter de l'ombrage

Construction d'une texture 3D La texture contient une intégration des données entre deux plans –Dépend de l'intervalle entre deux plans –Cet intervalle doit être connu à l'avance Pour chaque cellule de données : –Calculer opacité et couleur E = couleur ponctuelle (cf. fonction de transfert) O 1 = opacité ponctuelle (cf. fonction de transfert) –Stocker (C,O) dans texture 3D (R,G,B,A)

Affichage « Bloc » de textures Tranches qui coupent le bloc Coordonnées des tranches ? © Wilson, 1994

Affichage La texture tourne, les tranches restent fixe –Le bloc des tranches doit pouvoir contenir toutes les rotations du cube de texture –Conversion entre coord. (x,y,z) (fixes) et coordonnées de textures (s,t,r) (variables) –La carte fait l'interpolation

Cas particulier simple Cube (n x x, n y y, n z z ) –n x nbre échantillons – x intervalle d'éch. –s varie de 0 à 1sur le cube © Wilson, 1994

Cas particulier simple... Pb : les textures doivent avoir une taille 2 n –N x =2 k > n x –L x =N x x –s varie maintenant de 0 à n x / N x

Cas particulier simple D : matrice de changement d'échelle d S : matrice de changement d'échelle (d/L x, d/L y, d/L z ) T : translation de (n x /2N x, n y /2N y, n z /2N z ) Texture de taille (N x, N y, N z )

Cas général Point de vue modifié par une rotation R –On inverse la rotation, et on est ramené au cas précédent : –D commute avec R © Wilson, 1994

Cas général Évaluer aux coins du cube : (±1/2d, ±1/2d, ±1/2d) Égale évaluer TSR -1 sur (± 1/2,±1/2,±1/2) Transformation faite par la texture matrix (OpenGL) Rotation, puis échelle, puis translation

Considérations matérielles Nombre optimal de plans : –Au moins 1 plan par échantillon –Donc d/ z 110 plans pour 64 3 –Qualité proportionnelle au nombre de plans –Temps de rendu aussi Interpolation tri-linéaire –Remplace plus-proche-voisin (par défaut) –Plus lent (50 %), mais meilleure qualité, plus lisse

Considérations matérielles Précision des calculs : –8 bits par canal ou 12 bits ? –2 fois plus rapide, 50 % de coût mémoire en moins –Problèmes d'arrondi : Erreurs d'arrondi au maximum de 1/2*1/256 Devient problématique si on a plusieurs centaines de tranches Plus visible avec des données homogènes Mémoire : –2 Mo de texture 3D : 64 3, 4 canaux, 12 bits

Ombrage des surfaces Identification des cellules proches d'une frontière de matériau Calcul du gradient –Discrétisé, g valeurs possible Table des couleurs : – m matériaux, g valeurs de gradient –(m+1)g entrées Ordre des opérations : –Interpoler les données ou les couleurs ?

© Van Gelder, 1996 software hardware Une fois À chaque image Légende :

© Van Gelder, 1996

Bibliographie Marching cubes : –Lorensen, W. E. et Cline, H. E., Marching cubes: a high resolution 3D surface construction algorithm, Computer Graphics, 21(4) (Siggraph '87), p Rendu à base de pixels : –Upson, C. et Keeler, M., V-Buffer : Visible Volume Rendering, Computer Graphics, 22(4) (Siggraph '88), p –Drebin, R.A., Carpenter, L. et Hanrahan, P., Volume Rendering, Computer Graphics, 22(4) (Siggraph '88), p Coherent Projection : –Wilhelms, J. et Van Gelder, A., A Coherent Projection Approach for Direct Volume Rendering, Computer Graphics, 25(4) (Siggraph '91), p Splatting : –Westover, L., Footprint Evaluation for Volume Rendering, Computer Graphics, 24(4) (Siggraph '90), p –Laur, D. et Hanrahan, P., Hierarchical Splatting: A Progressive Refinement Algorithm for Volume Rendering, Computer Graphics, 25(4) (Siggraph '91), p Textures 3D : –Wilson, O., Van Gelder, A. et Wilhelms, J., Direct Volume Rendering via 3D Textures, Tech. Report de l'Université de Californie- Santa Cruz (UCSC-CRL-94-19) –Van Gelder, A. et Kwansik, K., Direct Volume Rendering with Shading via 3D Textures, ACM Symposium on Volume Visualisation '96, p