I am using Taylor-Hood element solving fluid problem with mesh motion (CG2 (velocity)-CG2(motion)-CG1(pressure)). To enhance stability, I want to do mass lumping. I am wondering if this is feasible in dolfin (Python).
I actually read this post a few hours ago, but noticed the last comment at the bottom on the page you gave saying “Be advised, however, that with parabolic and/or higher order continuous Lagrange interpolation lumping by using action (i.e. summing the elements of the consistent mass matrix rows) can lead lead to null or negative diagonal terms”.
So for your use case, are you using high order elements?
I am not using higher order elements myself. According to Hughes’ “The Finite Element Method” textbook “no general theory of obtaining higher-order accurate mass matrices exists yet”. There is a wide range of special lumping techniques out there in the literature you may want to explore. In case you will not achieve a diagonalized mass matrix, the consistent mass is probably a good starting point.
excellent! This is exactly what i’m looking for. Thanks a lot!
Additionally, I notice that for quadrilateral mesh, the singular matrix by “first” mass lumping way is no longer observed. Thus, i’m interested in comparing your implementation for quadrilateral mesh. Could you please provide some reference about how to set up the array “x” and “w” for quadrilateral mesh? Thank you!
Hello,
if you want to apply the same procedure for quadrilaterals, x correspond to the vertex positions in the reference element space and w are the corresponding weights for each points. Here I used 1D Gauss-Lobatto quadrature points and weights for 3 points: