From ee36af178e09ac4160aff2589cbd48f60b0dd6b6 Mon Sep 17 00:00:00 2001 From: Tom Gustafsson Date: Sat, 15 Jun 2024 14:26:54 +0300 Subject: [PATCH] modernize ex05 --- docs/examples/ex05.py | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/docs/examples/ex05.py b/docs/examples/ex05.py index e25c04150..6bea02093 100644 --- a/docs/examples/ex05.py +++ b/docs/examples/ex05.py @@ -15,17 +15,19 @@ to a saddle point system. """ - from skfem import * from skfem.helpers import dot, grad from skfem.models.poisson import laplace +import numpy as np +import scipy.sparse + m = MeshTri().refined(5).with_boundaries({"plate": lambda x: x[1] == 0.0}) e = ElementTriP1() -ib = Basis(m, e) -fb = FacetBasis(m, e) +basis = Basis(m, e) +fbasis = FacetBasis(m, e) @BilinearForm @@ -42,19 +44,18 @@ def facetlinf(v, w): return -dot(grad(v), n) * (x[0] == 1.0) -A = asm(laplace, ib) -B = asm(facetbilinf, fb) +A = laplace.assemble(basis) +B = facetbilinf.assemble(fbasis) +b = facetlinf.assemble(fbasis) -b = asm(facetlinf, fb) +I = basis.complement_dofs(basis.get_dofs("plate")) -I = ib.complement_dofs(ib.get_dofs("plate")) -import scipy.sparse b = scipy.sparse.csr_matrix(b) -K = scipy.sparse.bmat([[A+B, b.T], [b, None]], 'csr') -import numpy as np -f = np.concatenate((ib.zeros(), -1.0*np.ones(1))) +# create a block system with an extra Lagrange multiplier +K = scipy.sparse.bmat([[A + B, b.T], [b, None]], 'csr') +f = np.concatenate((basis.zeros(), -1.0 * np.ones(1))) I = np.append(I, K.shape[0] - 1)