# AN3D: Bases du rendu graphique
# Contexte
On a l'habitude de voir des models 3D virtuels
data:image/s3,"s3://crabby-images/8ea97/8ea97ecbd82694777369734e12ebb389258bab67" alt=""
**Conclusion: il est aise de concevoir et animer ses propres modeles 3D**
:::danger
FAUX !
data:image/s3,"s3://crabby-images/6e0a2/6e0a241011e3ce5e4ec495ba515dc97eb76fc81d" alt=""
:::
data:image/s3,"s3://crabby-images/3989b/3989bba81f4fd4a0203a9b91c45b0b052027825f" alt=""
Outils:
- Blender
- Maya
Formation de 3 a 5 ans dans les ecoles d'infographie.
:::warning
Le cout/temp passe sur la 3D n'a jamais ete aussi elevve
:::
- Films animations/VFX
- Cout moyen par sequence VFX ($\lt10s$): 50k\$
- Cout animation 3D $\gt$ cout dessin manuel
- Jeu videos AAA
- 100M\$
- 2 a 4 annees de dev
:::success
Les outils 3D se sont ameliores
:::warning
Mais restent complexes et tres techniques (3 ans d'etude infographistes)
:::
:::
## Creation 3D
La quantite et la qualite demande a augmente plus rapidement que les outils
data:image/s3,"s3://crabby-images/d22bc/d22bc1087dc47cc67b1e9732ccd4f5ec2687f824" alt=""
Dessins/sculpture a la main restent plus efficace pour le prototypage/design
data:image/s3,"s3://crabby-images/a7fe7/a7fe7c925268c01c734d177f87d55b21e422b889" alt=""
# Equipe: Geometric & visual computing
- Equipe informatique graphique et vision
## Applications
Domaine d'applications typiques
- Loisirs & creations artistiques
- Modelisation & visualisation en Sciences Naturelles
- Prototypage et fabrication
data:image/s3,"s3://crabby-images/35f1c/35f1c151d2ee7f465b90b4f14e797593d34e3118" alt=""
Notre "expertise"
- Methode interactive pour l'aide a la creativite
- Simulation visuelles
- Analyses de formes et algorithmique
## Aide: stages, emploi, poursuite en Informatique Graphique ?
Rem. IG: Domaine technique, R&D avancee
- Lien fort sujets recherche et entreprise
- Theses IG - sujets appliques qui interessent les industries
Si le domaine vous interesse:
- AFIG
# Plan du cours
1. Introduction et rappels d'Info Graphique
2. Warm-up systeme de particules
3. Animation descriptive
4. Animation physique
5. Animation de personnages
# Evaluation
- Un compte rendu de tp
- Collision de spheres, tissus, ou personnage articule
- $\simeq5$ pages
- Notre demarche, resultats et analyses
# Computer graphics
## Main subfields
- Modeling
- Animation
- Rendering
## Representing 3D shapes for Graphics Application
data:image/s3,"s3://crabby-images/3d1ca/3d1ca2e379e3829c3cf7ba139ab9a82089764714" alt=""
- Computer graphics: mostly focus on representing surfaces
- Scientific visualization: volume data
# Surfaces
## Two main rpz
data:image/s3,"s3://crabby-images/9a836/9a8367c9c5f7255db1739b2db50a3f3f105d5b54" alt=""
Representation d'une sphere:
data:image/s3,"s3://crabby-images/7fd29/7fd2996a5e8f60a1163618b202cc0201506c3d62" alt=""
## Difficulty of surface representation using function
data:image/s3,"s3://crabby-images/15127/15127495d52679582eee36d6bfc1c6ccbedf5829" alt=""
:::success
C'est impossible, la forme est trop complexe
:::
## Objective of surface representation
Main idea: use **piecewise approximation**
Ideal surface representation
- Approximate well any surface
- Require few samples
- Can be rendered efficiently (GPU)
- Can be manipulated for modeling
Example of models:
- Mesh-based
- Triangular meshes, polygonal meshes, subdivision surfaces
- Polynomial
- Polynomial: bezier, spline NURBS
- Implicit
- grid, skeleton based, RBF, MLS
- Points sets
:::warning
For projective/rasterization render pipeline: always render **triangular meshes** at the end
:::
| Pros | Cons |
| ----------------------------------- | ------------------------------------------------- |
| Simplest representation | Requires large number of saples: complex modeling |
| Fit to GPU Graphics render pipeline | Tangential discontinuities at edges |
## Mesh encoding
data:image/s3,"s3://crabby-images/84b25/84b25e3edbaf5c7b67044bad98fc0a0d9f40d1ed" alt=""
## Example of 3D Mesh File
data:image/s3,"s3://crabby-images/702a7/702a7cc189543d1a3d3a041454ec5f346c231aba" alt=""
## Affine transforms and 4D vectors/matrices
data:image/s3,"s3://crabby-images/82ebb/82ebb0aac1fbdf648e20d693fe3afe27db553e3a" alt=""
## Perspective matrix
Perspective space: allows perspective projection expressed as a matrix.
Common constraints (in OpenGL):
- Wrap the viewing volume (truncated cone with rectangulare basis called `frutsum`) ($z_{near},z_{far},\theta$) to a cube
- $\theta: view angle$
- $p=(x,y,z,1)\in$ `frutsum` $\Rightarrow p'=(x',y',z',1)\in[-1,1]^30$
data:image/s3,"s3://crabby-images/9c570/9c570b2531a64d4781e18ca4d364c20b8e33bdc3" alt=""
$$
M=\begin{pmatrix}
f&0&0&0\\
0&f&0&0\\
0&0&C&D\\
0&0&-1&0
\end{pmatrix}\\
f=\frac{1}{\tan(\frac{\theta}{2})}\\
L = z_{near}-z_{far}\\
C= \frac{z_{far}+z_{near}}{L}\\
D= \frac{2z_{far}z_{near}}{L}
$$
In practice
- You must define $z_{near}, z_{far}$
- $z_{far}-z_{near}$ should be as small as possible for max depth precsion
*To which view space are mapped 3D world space points at $z_{near}, z_{far}$ ?*
## Fractals
:::info
**Idea**
Recursively add self-similar details
:::
- Simple rule $\to$ complex shape
- May look like complex natural details
data:image/s3,"s3://crabby-images/1b746/1b746671e553f03b72af11c82f9895e751d72861" alt=""
data:image/s3,"s3://crabby-images/af948/af9486556336cb205d107b3ca24cca465e6e074c" alt=""
# Perlin noise
> A widely used *noise* function
Creer une fonction pseudo-aleatoire continue
- MAIS deterministe
data:image/s3,"s3://crabby-images/29065/29065a7c6bba005cf1d2e361ab0f9bed420910fb" alt=""
On prend des echantillons a des valeurs entiere
- Pour chaque on associe une tangente
- Utilise une fonction de hash
- `float hash(float n) {return fract(sin(n)*1e4);}`
data:image/s3,"s3://crabby-images/e2e68/e2e686189ad6dadff9bfa5b3d31b73e0227b9e70" alt=""
## Fractal Perlin Noise
On somme la fonction avec elle-meme en changeant ses parametres
data:image/s3,"s3://crabby-images/fb832/fb8328bee44576c7e926effa65f504d9fb9cca15" alt=""
$$
g(x)=\sum_{k=0}^N\alpha^kf(\omega^kx)
$$
- $f$: smooth Perlin noise function
- $N$: number of Octave
- $\alpha$: persistency
- $\omega$: frequency gain
data:image/s3,"s3://crabby-images/8618e/8618e52f14ae9e40c8fb495525c66f2f6d0f2667" alt=""
## Usage
- Material texture data:image/s3,"s3://crabby-images/abd23/abd239f76556793fec5a7cb27204545996927422" alt=""
- Ridge effect
- Marble effect
- Animated textures data:image/s3,"s3://crabby-images/2343e/2343e8927d6b9e9e9001ff8062f01d7c6831ba6d" alt=""
- Translation: $f(x,y+t)$
- Smooth evolution: $f(x,y,t)$
- Moutain-looking terrain data:image/s3,"s3://crabby-images/fcac5/fcac55c9715bf23b2f3c3b4bb1011a5219f8f141" alt=""
- $z=f(x,y)$
## Applications
In almost any complex shape
data:image/s3,"s3://crabby-images/418a8/418a8614d034d28525593d93759803e87eb368ce" alt=""
## Exercice
### Perlin Noise terrain
$$
S(u,v)=\begin{cases}
x(u,v)=u\\
x(u,v)=v\\
z(u,v)=hg(s(u+o), s(v+o))
\end{cases}
$$
The perlin noise
$$
g(u,v)=\sum_{k=0}^N\alpha^kf(2^ku,2^kv)
$$
$$
N=9\\
\alpha=0.4\\
h=0.3\\
s=1\\
o=0
$$
data:image/s3,"s3://crabby-images/e9b34/e9b348ed0f04f9356adc09832403a8a50ff2b10f" alt=""
- b: $N$ modifie
- a: $s$ modifie
- Les montagnes du fond sont des "nouvelles" montagnes
- on voit plus loin
- f: $o$ modifie
- e: $h$ modifie
### Animation
Reference surface function:
$$
(u,v)\in[0,1]^2, f(u,v)=(u,v,0)
$$
*How to generate the following animations ?*
> **Help**
> Dimension of the Perlin noise ?
> Which parameter $(u,v,t-\text{time})$ ?
data:image/s3,"s3://crabby-images/bf1b1/bf1b1dee108ecc91c7c0521d1b8224212b1f99eb" alt=""
- a: axe $z$ qui change
- $f(u,v)=(u,v,p(u+t))$
- Faux! $u+t$ nous fait deplacer dans les $t$ negatifs
- $f(u,v)=(u,v,p(u-t))$
- b: $f(u,v)=(u,v,p(u+t, v))$
- c: piege !
- On a le droit au bruit de Perlin 3D
- $(u,v,p(u,v,t))$
:::warning
Quand on a des textures animees a partir de bruit de Perlin, il y a une dimension supplementaire: le temps
:::
- d: similaire a la c
- e: $f(u,v)=(u,v,p(u-t)+up(u,v,t))$
- Multiplication par $u$ car le bruit est plus important a la fin
- v: on ne change pas que $z$ cette fois
- $f(u,v)=(u+p(u,v,t),v+p(u,v,t), p(u,v,t))$
# Geometry processing libraries
Development libraries
- LibIGL
- CGAL
- GeoGram
Viewer (+lib)
- Graphite
- Meshlab
Software
- Blender
## Useful CG programming library
Useful libs
- Eigen
- GLM
- Assimpl
- DevIL
Minimalistic GUI
- ImGui
- NanoGui
- AnTweakBar
Full framework
- Qt
# Particle system
:::info
**Definition**
Element at a given position + extra parameters (mass, life time, etc)
:::
On appelle un systeme de particules en oppositionL
- Rigid bodies - Solid objects with static shape
- Deformable bodies - Continuum material that can deforms
| Pros | Cons |
|:------------------------------------------------------------------ |:--------------------------------------- |
| Lightweight rpz | Simple model from physics point of view |
| Generic flexible model (spatial deformation, no connectivity, etc) | |
## Particles systems in History
One of the first animated model in CG
data:image/s3,"s3://crabby-images/10059/1005959c94afae43f855706a09ae3b4feddcdd36" alt=""
## Example of particle system
Free fall of sphere under gravity
- Geometrical rpz of each particle: sphere
- Equation of motion $p(t)=\frac{1}{2}gt^2+v_0t+p_0$
- Initial position and speed may be placed at random position
- Each particle may have a different life time
data:image/s3,"s3://crabby-images/78bb8/78bb80135c93c664776316cecee8af4e44b9b5f2" alt=""
*What are the parameters used for $p_0$ and $v_0$ in this example ?*
$$
p_0=(0,0,0)\\
v_0=(\sin(), 1,\cos())
$$
Si on a un $\sin$ du temps, on aurait des particules emises suivant un cercle
data:image/s3,"s3://crabby-images/e3e8c/e3e8c96f7aa2fa635ed3baad212af91442481b49" alt=""
data:image/s3,"s3://crabby-images/8d1d6/8d1d67e01d115dc6f09750d3b52806c568899888" alt=""
> Genre comme ca
Or, nos particules ne suivent pas ce cerlce, elles suivent un *nombre aleatoire* $\theta$:
$$
v_0=(\sin(\theta), 1,\cos(\theta))
$$
> Par exemple, $\theta\in[-\pi,\pi]$
## Bouncing spheres
data:image/s3,"s3://crabby-images/7ca1b/7ca1b90f7fca422d08b68bcd23cf5f40510ff990" alt=""
*What is the equation of motion (taking into account the bouncing) ?*
- Considere a particle emited at time $t=0$
- At what time $t_i$, the particle touch the floor ?
- What is the new speed after impact ?
- What is the complete equation of trajectory ?
$$
t_i=\\
p(t)=\frac{1}{2}gt^2+v_0t\\
p_g(t_i)=0\\
\begin{aligned}
\frac{1}{2}g_yt_i^2+v_{og}t_i=0&\Rightarrow\frac{1}{2}g_yt_i=-v_{oy}\\
&\Rightarrow=-2\frac{v_{oy}}{g_y}
\end{aligned}\\
p(t_i)\quad v(t_i)\to\begin{pmatrix}
V_x\\
-V_y\\
V_z
\end{pmatrix}\\
p_2(t)=\frac{1}{2}g(t-t_i)^2+v'(t_i)(t-t_i)+p(t_i)
$$
## General motions
:::success
Motion equation is not restricted to physics-based equations
:::
data:image/s3,"s3://crabby-images/cde4b/cde4b7722130c3c7e2074e07c1a78f0c1f15a297" alt=""
- *What are the parameters associated to each particle ?*
- *What are the corresponding equations of motions ?*
> On dirait que les bulles sortantes bougent en forme de cercle
> data:image/s3,"s3://crabby-images/98372/98372a54569d3ec5cd9b4a8f6cc072f605a38ba6" alt=""
$$
\text{rand}\to[0,1]\\
p_0=(?,0,?)
$$
*Comment faisons-nous pour recreer le cercle ?*
> On randomise $x$ et $y$ entre $-1$ et $1$
> Or ca nous fais un carre et on veut un cercle
> On tire au hasard 2 rayons $r_1$ et $r_2$
data:image/s3,"s3://crabby-images/29e00/29e002f216b4bb313acd2fb5f0f268012d834191" alt=""
$$
\sqrt{r_1^2+r_2^2}\gt R\\
\begin{cases}
R\cos(\theta)\\
R\sin(\theta)
\end{cases}
$$
Avec:
- $r_1, r_2\in[0,R]$
:::success
On a donc $p_0,v_0,R,C$
$$
p(t) = p_0+v_0(t-t_0)+\begin{pmatrix}
r\cos(\theta t-t_0+\gamma)\\
r\sin(\theta t-t_0+\gamma)\\
0
\end{pmatrix}
$$
Avec:
- $\gamma$: un offset aleatoire
:::
# Billboards, impostors, sprites
:::info
Particle can be displayed as small images/thumbnails
:::
In practice:
- Each particle is displayed as a quadrangle
- A texture is mappe on the quad
data:image/s3,"s3://crabby-images/60c71/60c71f9e6b2b5238c694d2ebdfdb4524c79ccdca" alt=""
- The texture can contains transparency
## Usage
Large use of billboard for complex models
- vegetation, fire, etc.
data:image/s3,"s3://crabby-images/a1f56/a1f56734a4b0a3274586a7b480a5f792fcb6c685" alt=""
## Example
data:image/s3,"s3://crabby-images/b4a09/b4a09321ce448dbb2bd87866e5b35178d9da4272" alt=""
## Use case in production
data:image/s3,"s3://crabby-images/b4f0d/b4f0db14571488e1676e12e85891106068e348c7" alt=""
> Le seigneur des anneaux
*Comment on ete fait ces chevaux liquides ? Comment a ete filme la scene ?*
> Il n'y a que des vrais chevaux sur la scene
> Pour l'eau, les chevaux ont ete fait a partir d'emission de particules
data:image/s3,"s3://crabby-images/21e9e/21e9e367b1cc41c52593cf923397951f875faaa5" alt=""
> Zoom sur une chute d'eau
data:image/s3,"s3://crabby-images/f8cb8/f8cb8d6372cb0f736f8a24a3c65ca593687a0d83" alt=""
> La base des tetes de chevaux
data:image/s3,"s3://crabby-images/1e1a5/1e1a5ff383fe615dce268bf9e7a26370f3c687e1" alt=""
> Couches de particules emisent a partir des tetes
data:image/s3,"s3://crabby-images/6f710/6f710abb7ccbaad7d45ec788830f0f259af309d9" alt=""
> Ensemble final
data:image/s3,"s3://crabby-images/48e86/48e8676070911a292c1735e4fca05442f74f0c13" alt=""
> La riviere
data:image/s3,"s3://crabby-images/55967/559674138e81b697faae37d0024a80897e360bd4" alt=""
> Les vrais chevaux, qui ne meurent pas
data:image/s3,"s3://crabby-images/fb8f1/fb8f1e13c724edc2ec9f63597fa89e0d28b1cab3" alt=""
> Faux chevaux et cavaliers modelises pour etre emporte par la riviere