Quadrature schemes#
Objectives
This code snippet shows the location of the quadrature points for different degrees, cell types and quadrature rules both in 2D and 3D.
Download sources
2D Quadrature rule#
import matplotlib.pyplot as plt
import numpy as np
import basix
from basix import CellType, QuadratureType
all_cell_types = [CellType.triangle, CellType.quadrilateral]
degrees = range(5)
quad_rules = {
QuadratureType.Default: (degrees, all_cell_types),
QuadratureType.gauss_jacobi: (degrees, all_cell_types),
QuadratureType.gll: (degrees, [CellType.quadrilateral]),
QuadratureType.xiao_gimbutas: (degrees[1:], [CellType.triangle]),
}
Show code cell source
def plot_quad_points_2D(rule, cell_type, deg, color, ax):
points, weights = basix.make_quadrature(cell_type, deg, rule=rule)
vertices = basix.geometry(cell_type)
facets = basix.cell.sub_entity_connectivity(cell_type)[1]
for f in facets:
vert = vertices[f[0], :]
ax.plot(vert[:, 0], vert[:, 1], "k")
ax.scatter(points[:, 0], points[:, 1], 500 * weights, color=color)
ax.set_aspect("equal")
def plot_quadrature_rule_2D(rule, color="C0"):
degs, cell_types = quad_rules[rule]
for deg in degs:
plt.figure()
for i, cell_type in enumerate(cell_types):
no_subplot = len(cell_types) < 2
if no_subplot:
ax = plt.gca()
else:
ax = plt.subplot(1, 2, i + 1)
ax.margins(0.05)
plot_quad_points_2D(rule, cell_type, deg, color, ax)
if no_subplot:
plt.title(f"{rule.name} rule, degree $d={deg}$")
else:
plt.suptitle(f"{rule.name} rule, degree $d={deg}$", y=0.8)
plt.show()
Default quadrature rule#
plot_quadrature_rule_2D(QuadratureType.Default, color="C3")
data:image/s3,"s3://crabby-images/fbeeb/fbeeba4bf326dafb584b43fe2b301beed59afb0c" alt="../../_images/4b63f344d1f6b06fc4ce87619c245c0d794367226b80566930bf96a2eb332972.png"
data:image/s3,"s3://crabby-images/d00c5/d00c50c9d4312f8319bd9bf8985b89b5e5057ba5" alt="../../_images/563e968d92d4b857daa11989b42244cc769c56feea7a45a311fc277f6c1a371e.png"
data:image/s3,"s3://crabby-images/077e7/077e706cd1378f462a59a918ff1e93ba52e6e3fa" alt="../../_images/7710490499c070a7cb4e25c190919eeb218a31b88194636894a1a27d72fa9ea4.png"
data:image/s3,"s3://crabby-images/cd45e/cd45effb30a06e66b85a0358d54282cbb0b38996" alt="../../_images/96b41093cc6bc6b159dfa59ba5ba172f9275a77628628d71b20b5cec07578e4b.png"
data:image/s3,"s3://crabby-images/a418b/a418ba3c9cdb4182d58fab0c86e0d8c37e0afd51" alt="../../_images/b8cbff56d2c159f32e10a0e109d3bbabc75ec62ec53ddc3eca8aeb24d1f5c947.png"
Gauss-Jacobi quadrature rule#
plot_quadrature_rule_2D(QuadratureType.gauss_jacobi, color="C2")
data:image/s3,"s3://crabby-images/cca15/cca15d81fd004a816e77c408a84772f343a89107" alt="../../_images/4250e0f77d65e0eeadc0d3e849f562854de56abfa9afd12b0efa67f10e930252.png"
data:image/s3,"s3://crabby-images/45ca8/45ca861cb18da92a8f248f4778c6b8866046423a" alt="../../_images/abcd94f9b1b3fbc9fc970452059fcddab4a4f57fc761bb42b5a08f09a64d6f79.png"
data:image/s3,"s3://crabby-images/a843a/a843a0ef87c5ff481fc50f92f01de54979a32411" alt="../../_images/dbcfc58d7698e1a176015dd0a6dd3d18cb09b2c4d7e7696cf99116259a9d25e4.png"
data:image/s3,"s3://crabby-images/49638/496384a3b3e5904a3a45ed2fa7e9d2d97c72e6f7" alt="../../_images/f8253b434ec948ee1423d488e177edc3eceb6bf0999a9d968f7692785f2c0290.png"
data:image/s3,"s3://crabby-images/f2c08/f2c088dd3d37456809498f7f81ec96a78e0e4e79" alt="../../_images/d27f08eeb142598b14fae775b085b930354cad141275bd45f555279c7d3cad7e.png"
Gauss-Legendre-Lobatto quadrature rule#
plot_quadrature_rule_2D(QuadratureType.gll, color="C1")
data:image/s3,"s3://crabby-images/6846a/6846a96b1413c8f30988c90c06d08b3b1692a9a1" alt="../../_images/ad3005dad51bdb1408faf3ddd40fc2da4fec68b289b7e71c7623d0318cac258d.png"
data:image/s3,"s3://crabby-images/2ddaa/2ddaaecfac0a30da7e46c9c42d0ee9ef5b61d4ca" alt="../../_images/d279e0fde72f27d093ea7d23df3398d18a38c0c370fc717b0aec1bc5dbe3a24c.png"
data:image/s3,"s3://crabby-images/f87a6/f87a62e8c5ed282ef88b3d5d0df5a494762d0232" alt="../../_images/81c2bc3d70b0c71243e22fc862de234252ef325d53fe76c049419720fc3d8a49.png"
data:image/s3,"s3://crabby-images/3895e/3895e874ff0b3b8fdd692421599cf6570effbecf" alt="../../_images/2aa069b86e56058931ef364e5543c5b35aa6a96ffbca6a369288f9d1adc0aa44.png"
data:image/s3,"s3://crabby-images/53927/539279c6e1471f0390dff727459e3e237e333f82" alt="../../_images/3583acb8b180a4da2e90705ff7ac3c3f444abe3344412c797053a56fda48b1fb.png"
Xiao-Gimbutas quadrature rule#
plot_quadrature_rule_2D(QuadratureType.xiao_gimbutas, color="C0")
data:image/s3,"s3://crabby-images/e566c/e566c591983fa5627e9f26849f696b70ba7aeb0f" alt="../../_images/0f706c4d570fb9a4f0e4f9e529fce1e32551071687bf9b42f845e82bb1e5a7c2.png"
data:image/s3,"s3://crabby-images/e145e/e145e2317c0c5147d37fa63df1058cd16c683ffe" alt="../../_images/54fc46b6479cd8b810935dd1a41de2d04785ad4be36a2fb32460b610529e1aca.png"
data:image/s3,"s3://crabby-images/76431/764318fd0f0b9582ccb6ac6502fe85ff8a5d05a6" alt="../../_images/158a378440b90c6b9a5110233aa266dd56af9310a8955c8285a97bfd2b9c70ed.png"
data:image/s3,"s3://crabby-images/3d54f/3d54f7268b837be13bc1e31d83fcd1f99b56f24e" alt="../../_images/e93655a28ce78d64b3c8eaa4d222d259f6eb69a871bf5a401329fb411224863e.png"
3D rules#
cell_type = CellType.hexahedron
dim = 3
deg = 2
from dolfinx import cpp, mesh
import pyvista as pv
from matplotlib.colors import to_hex
pv.set_jupyter_backend("static")
all_cell_types = [CellType.tetrahedron, CellType.hexahedron]
degrees = range(5)
quad_rules = {
QuadratureType.Default: (degrees, all_cell_types),
QuadratureType.gauss_jacobi: (degrees, all_cell_types),
QuadratureType.gll: (degrees, [CellType.hexahedron]),
QuadratureType.xiao_gimbutas: (degrees[1:], [CellType.tetrahedron]),
}
Show code cell source
def plot_quad_points_3D(rule, cell_type, deg, color, plotter):
points, weights = basix.make_quadrature(cell_type, deg, rule=rule)
vertices = basix.geometry(cell_type)
facets = basix.cell.sub_entity_connectivity(cell_type)
num_nodes_per_cell = len(facets[dim - 1][0][0])
subentity_cell_type = {
CellType.tetrahedron: mesh.CellType.triangle,
CellType.hexahedron: mesh.CellType.quadrilateral,
}
map_vtk = np.argsort(
cpp.io.perm_vtk(subentity_cell_type[cell_type], num_nodes_per_cell)
)
faces = [[f[0][m] for m in map_vtk] for f in facets[dim - 1]]
cell = pv.PolyData.from_regular_faces(vertices, faces)
# Add the mesh to the plotter
plotter.add_mesh(cell, color="gray", opacity=0.4, show_edges=True)
point_cloud = pv.PolyData(points)
point_cloud["weights"] = np.abs(weights) ** 0.33 * 0.25
glyphs = point_cloud.glyph(scale="weights", geom=pv.Sphere(), orient=False)
plotter.add_mesh(glyphs, color=to_hex(color))
plotter.camera.azimuth = 10.0
plotter.camera.elevation = -30.0
def plot_quadrature_rule_3D(rule, color="C0"):
degs, cell_types = quad_rules[rule]
for deg in degs:
for i, cell_type in enumerate(cell_types):
no_subplot = len(cell_types) < 2
# Create a PyVista plotter
if no_subplot:
plotter = pv.Plotter()
plotter.window_size = (400, 400)
plotter.add_title(rf"{rule.name} rule, degree d={deg}", font_size=10)
else:
if i == 0:
plotter = pv.Plotter(shape=(1, 2))
plotter.window_size = (800, 400)
plotter.subplot(0, i)
plotter.add_title(rf"{rule.name} rule, degree d={deg}", font_size=10)
plot_quad_points_3D(rule, cell_type, deg, color, plotter)
plotter.show()
Default quadrature rule#
plot_quadrature_rule_3D(QuadratureType.Default, "C3")
data:image/s3,"s3://crabby-images/5fb19/5fb19f20e02bc38f1833746e1e15b988229d8923" alt="../../_images/6a23341c925457400f116558bf40f1484def05dc76476f29907e2ccbb19fd381.png"
data:image/s3,"s3://crabby-images/7fb6e/7fb6efc108eb81ae2164e806c4d6ddb201b378db" alt="../../_images/1d939a9ea7a5443494485ad541d52be902a25c777ca3c2e57fb701877b6f505f.png"
data:image/s3,"s3://crabby-images/6ee9d/6ee9dbe883470274d46dde4efdf2826681df806e" alt="../../_images/daa2f884c2d26b797521d3d4914360d4c7bb6cbbcc9e1ac33bd5dc8603efeb2d.png"
data:image/s3,"s3://crabby-images/b4c6c/b4c6c675bc13795617afc43162218e4f12f6a13e" alt="../../_images/8a0cecd2fd502073ee2d9029cc2f6bbf0b2c8c1c25a36d64c600b6cdd653d5d2.png"
data:image/s3,"s3://crabby-images/374af/374affc721c6588c34806f8d2a8feb37930fa79b" alt="../../_images/57f4bb3a5fd3d6a90174754f48b7018ff8aaa0e156675b0f496655a70cbabe1c.png"
Gauss-Jacobi quadrature rule#
plot_quadrature_rule_3D(QuadratureType.gauss_jacobi, "C2")
data:image/s3,"s3://crabby-images/5cae9/5cae9c08ec849bd220cb0129b272f588565d40ea" alt="../../_images/3a77c786b706069d17dd08a60bea38ed1e788c86109cf5aead781ac68bc2d1fc.png"
data:image/s3,"s3://crabby-images/3560b/3560bdd04f55c0e5c60731008d06948814bf123a" alt="../../_images/0b8afc4476eab3a0d7dc90484597f3db946ff0a9e66affff1cfa0132d111bcb8.png"
data:image/s3,"s3://crabby-images/360eb/360eb1ee7bc3afe496c196c556a125cfac4b56ba" alt="../../_images/d938027c88665b8879c05ce4b28eda3922eb28029633a98c07948949b3ea6ee6.png"
data:image/s3,"s3://crabby-images/1601e/1601e9a69d3e67b45326228959fe3344a2fff67a" alt="../../_images/56620153c30de41fe92fc837d13fe031ae3b4e9505dd4605410511be5f742ce5.png"
data:image/s3,"s3://crabby-images/6ac88/6ac8852d0c8018c8b343a3f72cd8bb4c590e59c6" alt="../../_images/64ef4d00999bc9f3912e9e798d7ecc415500f89fd851f8721106cbcfe0e6b5cf.png"
Gauss-Legendre-Lobatto quadrature rule#
plot_quadrature_rule_3D(QuadratureType.gll, "C1")
data:image/s3,"s3://crabby-images/34fba/34fbadf0fe2f925ece2f212ffa9cfce4d7eddfb3" alt="../../_images/1642be917148615ee681c13f682c1fc202d64679c4c7dfa16bbad9576c771463.png"
data:image/s3,"s3://crabby-images/f85d2/f85d20c791668e6f1ee8d40d038eb2f413068980" alt="../../_images/97f0ae4f1ebf604687246cc95dfd206339068641a9a9919d4fffda1605bfecfa.png"
data:image/s3,"s3://crabby-images/3637a/3637acccddf70786a5884d02cb541df50c0cd19d" alt="../../_images/eb79a25d431da0810af06a329de663bb1026f8875144e1384c3ad819b465d44d.png"
data:image/s3,"s3://crabby-images/485e6/485e6378e015be81663b0b1b16951d4ca521abfc" alt="../../_images/ed18f0389088361af16d3b7634fd7684ad84d49e373f7552bda8f4896bc0bbce.png"
data:image/s3,"s3://crabby-images/d7a03/d7a03dca3be15ca8fb1ca88a5582e14a674a7c62" alt="../../_images/061746172f2dc05cfccbac43971929436e91220b63289786ce5bae3a27d6c98d.png"
Xiao-Gimbutas quadrature rule#
plot_quadrature_rule_3D(QuadratureType.xiao_gimbutas, "C0")
data:image/s3,"s3://crabby-images/71c1f/71c1f9d62dd9b0fe397dcff9d921788e225dfe1f" alt="../../_images/b7090f38ffed3d979d628c4de1b96f0327a7ef0005d239771c2591e2a40932bd.png"
data:image/s3,"s3://crabby-images/9d6dc/9d6dc6882338b1d411a2440fc5d5a91448e14e34" alt="../../_images/97e749a8cfb82f17410f7cbb4a83c83ef2f003c8b60308982b6d8fb9803b35fd.png"
data:image/s3,"s3://crabby-images/c689c/c689c0b1d8a7e7ce41f5c22e164fbec5160c7892" alt="../../_images/6b7f3dd7ff69a0c0e8813faaca880edfa24d1c607b1a1517384c7a6e2f54682b.png"
data:image/s3,"s3://crabby-images/1b71f/1b71f348a26984a79465456b437f4da0cfeb530f" alt="../../_images/c835289d713d5eb02cfdcafa20a486e30b043be951783fc6e54519ef37370bb9.png"