If you have any problems (I mean bugs you encountered, not your own problems), please contact me via the email: [email protected]
mVEM is a MATLAB software package containing efficient and easy-following codes for various virtual element methods (VEMs) published in the literature.
-
We present some basic functions to show the polygonal meshes, including marking of the nodes, elements and (boundary) edges.
-
For the convenience of computation, some auxiliary mesh data are introduced. The idea stems from the treatment of triangulation in iFEM, which is generalized to polygonal meshes with certain modifications.
-
We also provide a boundary setting function to identify the Neumann and Dirichlet boundaries (See setboundary.m).
-
The mesh generation algorithms are also described in detail.
-
We present an efficient implementation of the mesh refinement for polygonal meshes. To the best of our knowledge, this is the first publicly available implementation of the polygonal mesh refinement algorithms. We remove the small edges by requiring the one-hanging-node rule.
-
nonConvexMesh: generates a typical nonconvex polygonal mesh
-
gunelveMesh: generates the Gunelve mesh used in the Cook's membrane problem
-
dualMesh: Generate polygonal mesh by establishing the dual mesh of a given Delaunay triangulation.
We describe the details of designing the codes of conforming VEMs for Poisson equation with k up to 3, including the computation of elliptic projection and L2 projection, the matrix form of the approximated variational problems as well as the treatment of boundary conditions. We also show how the errors under L2,H1 and energy norms can be computed using the numerical d.o.f.s.
The VEM of lowest order for linear elasticity problems is introduced for both the displacement-type (or Navier-type) and tensor-type bilinear forms.
Three VEMs involved in the literature are described in detail, i.e., the C1, C0 and Morley-type elements.
This problem combines the techniques in Poisson equation and plate bending problems.
- Standard nonconforming VEM in the lowest order case
- The nonconforming VEM with a continuous treatment on the boundary of the domain
For linear elasticity problems, we mainly consider the (locking-free) virtual elements in the lowest order case.
- conforming and nonconforming VEMs for the Navier/displacement form
- conforming and nonconforming VEMs for the tensor form
- nonconforming VEMs for a continuous treatment of the domain boundary
- locking-free VEMs: Kouhia-Stenberg VEM (Vnc \times Vc), reduced integration technique based VEMs
- a standard benchmark: Cook's membrane problem
-
Mixed vem for Darcy problem in the lowest order H(div)-conforming virtual element
-
Mixed vem for Darcy problem in the lowest order lifting H(div)-conforming virtual element
-
Divergence-free mixed vem for Stokes problem in the lowest order
-
Divergence-free mixed vem for Stokes problem in the lowest order with enhancement technique used
-
Mesh refinement of polygonal meshes
-
Adaptive VEM for Poisson equation in the lowest order
- We provide the implementation of the the virtual element method for a simplified friction problem, which is a typical elliptic variational inequality of the second kind. The discrete problem is solved by using the Uzawa iteration algorithm, hence the implentation is reduced to that of Poisson equation in each iteration.
We present a simple and efficient implementation of the linear virtual element method for the three dimensional Poisson equation. The design ideas can be directly generalized to higher-order cases.
-
IPVEM for biharmonic equation
-
IPVEM for fourth-order singular perturbation problems
- Poisson equation
-
The vectorized implementatioin for conforming VEMs of Poisson equation has been accomplished in a unified way.
-
The current realization may be less straighforward compared to the FEMs.
-
Only the calculation of projection matrices is vectorized, and the assembly procedure is still implemented by looping over the elements
The author would like to thank Sen Lin and Fang Feng, my schoolmates in Shanghai Jiao Tong University for many helpful discussions.
The author thanks Postdoc Dohyun for pointing out the bugs in PolyMeshRefine.m and provide another version PolyMeshRefine1.m. Detailed credits can be found in the M-lint of several m files.
If you feel it is helpful for your research, please acknowledge your use by citing the arxiv paper in Doc.
PS:
程序对区域、边界条件等的处理都较为一般,可容易地移植到其他问题。
编程过程完全遵循有限元的思路。
相比网上有的程序,过程更加清晰,充分使用了 MATLAB 的向量运算。
在计算各种投影的边界项时,部分程序中使用有限元载荷向量的装配技巧避免了繁琐的人为处理。
TO DO:
- Vectorized implementation
- Time-dependent problems and nonlinear problems
- Various applications: Cahn–Hilliard problem, Stokes–Darcy problem, Navier-Stokes, etc.
- Mesh generation in 3-D