4. Analyse de champ#

Marc BUFFAT, dpt mécanique, Université Claude Bernard Lyon 1


Mise à disposition selon les termes de la Licence Creative Commons
Licence Creative Commons.

ligne de courant

%matplotlib inline
import numpy as np
import scipy as sp
import matplotlib.pyplot as plt
from matplotlib import animation
from cinematique import part_animation

4.1. Analyse locale d’un champ#

Etude locale de la trajectoire d’une particule fluide dans un champ de vitesse \(U\) dont on se donne le gradient: \(\mathbf{grad}\,U\)

  • Localement le champ de vitesse en \(X_0+dX\) est:

\[ u = u_0 + \frac{\partial u}{\partial x} dx + \frac{\partial u}{\partial y} dy\]
\[ v = v_0 + \frac{\partial v}{\partial x} dx + \frac{\partial v}{\partial y} dy\]
\[ \vec{U} = \vec{U}_0 + \mathbf{grad}\,\vec{U} \times d\vec{X} \]
  • Les trajectoires des particules fluides \(\vec{M}(t)=\vec{M}_0(0)+d\vec{M}\) vérifient:

\[ \frac{d \vec{M}}{dt} = \vec{U}(M) = \vec{U}_0 + \mathbf{grad}\,\vec{U} \times d\vec{M}\]
  • la rotation solide d’une particule (ex: \(U_\theta = \omega r\))

\[ \vec{\Omega} = \frac{1}{2} \mathbf{rot}\,\vec{U}\]
  • Le volume d’une particule varie comme la divergence du champ de vitesse \(div\,\vec{U}\)

\[ \frac{1}{V}\frac{dV}{dt} \equiv div\,\vec{U} = trace(\mathbf{grad}\,\vec{U}) \]

4.2. Analyse locale d’un champ 2D#

On se donne la valeur locale \(U_0\) et son gradient \(\mathbf{grad} U\) du champ de la vitesse.

Locallement en supposant que ce gradient est constant on peut écrire

\[\begin{split} \vec{U}(x,y) = \vec{U}_0 + \mathbf{grad}\, \vec{U} \times \begin{bmatrix} x-x_0 \\ y-y_0 \end{bmatrix}\end{split}\]

4.2.1. Champ incompressible#

\[div \, \vec{U} = 0\]

donc $\( trace(\mathbf{grad} \vec{U}) = 0\)$

U0=np.array([1.0,0.])
gradU=np.array([[-1,1.0],[1.,1.0]])
anim=part_animation(U0,gradU,FigSize=(7,5))
Gradient de U    = | -1 1 |
                   | 1 1 |
Divergence div(U)= 0.0
Rotation W_z     = 0.0
volume initiale  0.020000000000000004
Animation avec  40
../../_images/0b83b7f8638eba2d4e6c93a1dfdef7a338193ec041dd569233ce0984a3345766.png
plt.rc('animation', html='jshtml')
anim

4.2.2. Cisaillement homogéne#

gradU=np.array([[0,1],[0,0]])
anim=part_animation(U0,gradU,FigSize=(7,5))
Gradient de U    = | 0 1 |
                   | 0 0 |
Divergence div(U)= 0
Rotation W_z     = -0.5
volume initiale  0.020000000000000004
Animation avec  40
../../_images/b40c0818f7de89ac38b7d532e1d9b10427573e9e06df2f347b39c98a9cb33dc1.png
plt.rc('animation', html='jshtml')
anim

4.2.3. Rotation homogéne#

gradU=np.array([[0,1],[-1,0]])
anim=part_animation(U0,gradU,FigSize=(7,5))
Gradient de U    = | 0 1 |
                   | -1 0 |
Divergence div(U)= 0
Rotation W_z     = -1.0
volume initiale  0.020000000000000004
Animation avec  40
../../_images/04d9683861bb05ecff5953e39eb86f9ecd1dd107d8d67f0e109d8cd0aa1084e6.png
plt.rc('animation', html='jshtml')
anim

4.2.4. Déformation à volume constant#

gradU=np.array([[1,0.5],[0.5,-1]])
anim=part_animation(U0,gradU,FigSize=(7,5))
Gradient de U    = | 1 0.5 |
                   | 0.5 -1 |
Divergence div(U)= 0.0
Rotation W_z     = 0.0
volume initiale  0.020000000000000004
Animation avec  40
../../_images/79ec1809107a2d55c0bd0bdbd95924d26babcd3acba4dd96315b5c5d9d06d966.png
plt.rc('animation', html='jshtml')
anim

4.2.5. Compression#

gradU=np.array([[-1,0.],[0.,0.5]])
anim=part_animation(U0,gradU,FigSize=(7,5))
Gradient de U    = | -1 0 |
                   | 0 0.5 |
Divergence div(U)= -0.5
Rotation W_z     = 0.0
volume initiale  0.020000000000000004
Animation avec  40
../../_images/996cee7e6dbe31291cbc75661092321f0e4d4431fc0bec641ee4b480eb9ed90e.png
plt.rc('animation', html='jshtml')
anim

###Dilatation

gradU=np.array([[1,0.],[0.,-0.5]])
anim=part_animation(U0,gradU,FigSize=(7,5))
Gradient de U    = | 1 0 |
                   | 0 -0.5 |
Divergence div(U)= 0.5
Rotation W_z     = 0.0
volume initiale  0.020000000000000004
Animation avec  40
../../_images/fb7a2e93ef6cddeb46724460360d41ecfe3453b5441c44b9fa6d2823d42ec0e7.png
plt.rc('animation', html='jshtml')
anim

4.3. Cas Général d’un écoulement compressible#

  • décomposition du champ de vitesse

\[ \vec{U}(M) = \vec{U}(O) + (\nabla \vec{U})\times\vec{OM} \]
  • en partie anti-symétrique (rotation) et symétrique (déformation)

\[ \vec{U}(M) = \vec{U}(O) + \vec{\Omega} \wedge \vec{OM} + D \]
gradU=np.array([np.random.rand(2),np.random.rand(2)])
anim=part_animation(U0,gradU,FigSize=(7,5))
Gradient de U    = | 0.134372 0.9274 |
                   | 0.522548 0.106097 |
Divergence div(U)= 0.24046878253749893
Rotation W_z     = -0.20242615901319433
volume initiale  0.020000000000000004
Animation avec  40
../../_images/cb3de11a795edea1bb4a8633aa4c633b8aa7539063d25414e9bc30745dbd9ac6.png
plt.rc('animation', html='jshtml')
anim

4.3.1. partie déformation (symétrique)#

UZ = np.array([0.,0.])
D  = 0.5*(gradU + gradU.transpose())
anim=part_animation(U0,D,FigSize=(7,5))
Gradient de U    = | 0.134372 0.724974 |
                   | 0.724974 0.106097 |
Divergence div(U)= 0.24046878253749893
Rotation W_z     = 0.0
volume initiale  0.020000000000000004
Animation avec  40
../../_images/b696169bd9e85d33981b1a049d3ee7cd6e050f17b60b538494219d22b904d551.png
plt.rc('animation', html='jshtml')
anim

4.3.2. partie rotation(antisymétrique)#

R  = 0.5*(gradU - gradU.transpose())
anim=part_animation(U0,R,FigSize=(7,5))
Gradient de U    = | 0 0.202426 |
                   | -0.202426 0 |
Divergence div(U)= 0.0
Rotation W_z     = -0.20242615901319433
volume initiale  0.020000000000000004
Animation avec  40
../../_images/aa597996c05398bb6c595d108c8d1de016fc7982d7f97cf4c3be4650c3bdf05e.png
plt.rc('animation', html='jshtml')
anim

4.4. Cas Général d’un écoulement incompressible#

gradU=np.array([np.random.rand(2),np.random.rand(2)])
gradU[1,1]=-gradU[0,0]
anim=part_animation(U0,gradU,FigSize=(7,5))
Gradient de U    = | 0.687847 0.553417 |
                   | 0.449201 -0.687847 |
Divergence div(U)= 0.0
Rotation W_z     = -0.052107898973094646
volume initiale  0.020000000000000004
Animation avec  40
../../_images/5f280314c0e5bfd8b139433f115845d4f7cece44ba034cc7d1fa776640e35585.png
plt.rc('animation', html='jshtml')
anim

4.5. FIN#