Skip to content

Departamento de Matematica

Sections
Personal tools
Views
  • State: visible

TP2 - ConvDif - TEX

TP2: Convección difusión

Click here to get the file

Size 3.8 kB - File type text/x-tex

File contents

\documentclass[12pt]{article}
\usepackage{graphicx,amsmath,amsfonts,amssymb,epsfig,euscript,enumerate}
\usepackage[T1]{fontenc}
\usepackage[utf8x]{inputenc}

\newtheorem{ejer}{Ejercicio}
\newcommand{\bej}{\begin{ejer}\rm}
\newcommand{\fej}{\end{ejer}}

\newcommand{\gO}{\Omega}
\newcommand{\R}{\mathbb{R}}
\newcommand{\C}{\mathbb{C}}
\def\dt{\Delta t}
\def\dx{\Delta x}

\topmargin-2cm \vsize 29.5cm \hsize 21cm
\setlength{\textwidth}{16.75cm}\setlength{\textheight}{23.5cm}
\setlength{\oddsidemargin}{0.0cm}
\setlength{\evensidemargin}{0.0cm}

\begin{document}
\centerline{{\small Universidad de Buenos Aires - Facultad de Ciencias Exactas y Naturales - Depto. de Matemática}}

 \vskip 0.2cm
 \hrulefill
 \vskip 0.2cm

 \centerline{{\bf\Huge {\sc Análisis Numérico}}}
 \vskip 0.2cm
 \centerline{\ttfamily Segundo Cuatrimestre 2019}
 \hrulefill

 \bigskip
 \centerline{\bf TP  N$^\circ$ 2 - Tema 2: Convección-difusión.}
 \bigskip


\section{El problema:}

Considerar el problema de convección-difusión:
\begin{equation}\label{eq}
\def\arraystretch{1.5}
\begin{array}{cl}
u_t(x,t) = \alpha\Delta_x u(x,t) - {\bf v}(x)\cdot \nabla_x u(x,t) &
\quad x\in\Omega,\;t\in[0,T] \\
u(x,0) = g(x) &
\end{array}
\end{equation}

La incógnita $u$ puede interpretarse como la concentración de una cierta sustancia quimíca en un medio. El término $\alpha\Delta_x u$ describe la difusidad: un punto de alta densidad, tenderá a difundir concentración hacia su entorno. $\alpha$ es un coeficiente positivo que modela la difusividad de la sustancia en el medio. El término de transporte ${\bf v} \cdot \nabla u$ modela el movimiento del medio, que traslada la sustancia. ${\bf v}:\R^2\to\R^2$ es el campo de velocidades. La condición de Neumann implica que no hay flujo hacia el exterior, es decir: que la cantidad total de sustancia se mantiene constante. Consideraremos $\Omega=B(0,1)$


\section{Formulación Discreta}
Dada una triangulacion $\mathcal{T}_h$ de $\Omega$, considerar el espacio $V_h$ de funciones continuas y lineales en cada triángulo. Llamemos $\{\phi_i\}_i$ a la base nodal de $V_h$. La discretización de la formulación débil del problema conduce a la necesidad de calcular la matriz de masa $M$, de rigidez $R$ y la matriz correspondiente al término convectivo $C$, dadas por:
$$M_{i,j} = \int_\Omega \phi_i\phi_j\qquad R_{i,j} =\int_\Omega\nabla\phi_i\nabla\phi_j\qquad C_{i,j} = \int_\Omega ({\bf v}\cdot \nabla\phi_j)\phi_i$$

Con esta notación el problema discreto es:
$$ (M+dt(\alpha R+C)) U^{n+1} = M U^n$$
donde $dt$ es el paso temporal y $U^n$ es el vector de coeficientesde $u_h$ a tiempo $n$.

Es conveniente hacer un programa auxiliar que, dados los datos de la triangulación, calcule las matrices $M$, $R$ y $C$.


\section{Datos }
Estudiaremos, para ${\bf v}$:
\begin{itemize}
\item  ${\bf v} = v(x,y) = (-y,x)/\|(x,y)\|$.
\end{itemize}
Con esta configuración, el problema puede pensarse como la disolución de azúcar en una taza, al revolver. 
Para el dato inicial pueden probarse distintas opciones. Por ejemplo, $g = \chi_{B((0,\frac{1}{2}),\frac{1}{4})}$

\subsection{Comandos útiles:}
Pueden resultar útiles las siguientes funciones: 
\begin{itemize}
\item \verb+Delaunay+, de la biblioteca \verb+scipy.spatial+ para la construcción de la triangulación. Alternativamente, puede usarse \verb+Triangulation+ de \verb+matplotlib.tri+, que también servirá para dibujar. 
\item \verb+csr_matrix+ de la biblioteca \verb+scipy.sparse+ para el ensamblado de matrices 
\item \verb+spsolve+ o \verb+cg+ de \verb+scipy.sparse.linalg+ para la resolución de sistemas.
\item \verb+tripcolor+, de \verb+matplotlib.pyplot+ en conjunción con \verb+Triangulation+ de \verb+matplotlib.tri+ para graficar. \verb+tripcolor+ hace un grafico 2D sobre una malla triangular, en donde la magnitud de la función graficada se traduce en color. 
\end{itemize}
\end{document}
Created by secre
Last modified 2019-11-21 11:49 AM
 
 

Powered by Plone