Programming of Finite Element Methods in MATLAB

Long Chen
DOI: https://doi.org/10.48550/arXiv.1804.05156
2018-04-14
Abstract:We discuss how to implement the linear finite element method for solving the Poisson equation. We begin with the data structure to represent the triangulation and boundary conditions, introduce the sparse matrix, and then discuss the assembling process. We pay special attention to an efficient programming style using sparse matrices in MATLAB.
Numerical Analysis
What problem does this paper attempt to address?
The problem that this paper attempts to solve is: How to implement the linear finite element method in MATLAB to solve the Poisson equation. Specifically, the author discusses the following aspects: 1. **Data Structures**: Design of data structures representing triangulations and boundary conditions. 2. **Sparse Matrices**: Introduction to the use of sparse matrices and their efficient programming styles in MATLAB. 3. **Assembly Process**: A detailed description of how to assemble the stiffness matrix and optimize the computational efficiency. ### Specific Problems - **Data Structures**: - Use the `node` and `elem` matrices to represent triangulations in d - dimensional space. The `node` stores the node coordinates, and the `elem` stores the vertex indices of each element. - Introduce the boundary condition flag matrix `bdFlag` to record different types of boundaries (such as Dirichlet boundaries, Neumann boundaries, etc.). - **Sparse Matrices**: - Discuss the storage formats of sparse matrices (such as coordinate format and compressed sparse column format), and emphasize their importance in saving memory and improving computational efficiency. - Provide specific methods for creating and operating sparse matrices, including how to construct a sparse matrix through the `sparse` function and how to use the `find` function to extract non - zero elements. - **Assembly Process**: - Introduce the standard assembly process, that is, assembling local stiffness matrices into a global stiffness matrix. - Propose several optimization strategies, such as avoiding updating sparse matrices in large loops and using vectorization techniques to further accelerate the computation. ### Mathematical Formulas Some of the key formulas involved in the paper are as follows: - The weak form of the Poisson equation is: \[ a(u, v):=\int_{\Omega}\nabla u\cdot\nabla v\,dx = \int_{\Omega}fv\,dx+\int_{\Gamma_N}g_Nv\,dS \] where \(u\in H^1_{g,D}(\Omega)\), \(v\in H^1_{0,D}(\Omega)\). - The definition of the stiffness matrix is: \[ A=(a_{ij})_{N\times N},\quad a_{ij}=a(\phi_j,\phi_i) \] where \(\phi_i\) is a basis function. - The calculation formula of the local stiffness matrix is: \[ a^{\tau}_{i_{\tau}j_{\tau}}=\int_{\tau}\nabla\lambda_{j_{\tau}}\cdot\nabla\lambda_{i_{\tau}}\,dx \] Through these methods and techniques, the author aims to provide an efficient and easy - to - implement framework for the finite element method to solve the Poisson equation in MATLAB.