Source code for fe_utils.utils
import numpy as np
from .quadrature import gauss_quadrature
[docs]
def errornorm(f1, f2):
"""Calculate the L^2 norm of the difference between f1 and f2."""
fs1 = f1.function_space
fs2 = f2.function_space
fe1 = fs1.element
fe2 = fs2.element
mesh = fs1.mesh
# Create a quadrature rule which is exact for (f1-f2)**2.
Q = gauss_quadrature(fe1.cell, 2 * max(fe1.degree, fe2.degree))
# Evaluate the local basis functions at the quadrature points.
phi = fe1.tabulate(Q.points)
psi = fe2.tabulate(Q.points)
norm = 0.0
for c in range(mesh.entity_counts[-1]):
# Find the appropriate global node numbers for this cell.
nodes1 = fs1.cell_nodes[c, :]
nodes2 = fs2.cell_nodes[c, :]
# Compute the change of coordinates.
J = mesh.jacobian(c)
detJ = np.abs(np.linalg.det(J))
# Compute the actual cell quadrature.
norm += (
np.dot(
(np.dot(f1.values[nodes1], phi.T) - np.dot(f2.values[nodes2], psi.T))
** 2,
Q.weights,
)
* detJ
)
return norm**0.5