Skip to content

Commit

Permalink
pc (facet_split): not use vec.permute()
Browse files Browse the repository at this point in the history
  • Loading branch information
ksagiyam committed Jan 31, 2024
1 parent d8bf62c commit f164243
Showing 1 changed file with 16 additions and 9 deletions.
25 changes: 16 additions & 9 deletions firedrake/preconditioners/facet_split.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,8 @@ def initialize(self, pc):
_, P = pc.getOperators()
appctx = self.get_appctx(pc)
fcp = appctx.get("form_compiler_parameters")
self.work_vec_x = P.createVecLeft()
self.work_vec_y = P.createVecRight()

prefix = pc.getOptionsPrefix()
options_prefix = prefix + self._prefix
Expand Down Expand Up @@ -102,7 +104,8 @@ def _permute_nullspace(nsp):
return nsp
vecs = [vec.duplicate() for vec in nsp.getVecs()]
for vec in vecs:
vec.permute(self.iperm)
self.work_vec_x.getArray(readonly=False)[:] = vec.getArray(readonly=True)[:]
self._vec_permute(self.work_vec_x, vec, self.iperm)
return PETSc.NullSpace().create(constant=nsp.hasConstant(), vectors=vecs, comm=nsp.getComm())

mixed_opmat.setNullSpace(_permute_nullspace(P.getNullSpace()))
Expand Down Expand Up @@ -152,23 +155,27 @@ def update(self, pc):

def apply(self, pc, x, y):
if self.perm:
x.permute(self.iperm)
self._vec_permute(x, self.work_vec_x, self.iperm)
dm = self._dm
with dmhooks.add_hooks(dm, self, appctx=self._ctx_ref):
self.pc.apply(x, y)
self.pc.apply(self.work_vec_x, self.work_vec_y)
if self.perm:
x.permute(self.perm)
y.permute(self.perm)
self._vec_permute(self.work_vec_y, y, self.perm)

def applyTranspose(self, pc, x, y):
if self.perm:
x.permute(self.iperm)
self._vec_permute(x, self.work_vec_y, self.iperm)
dm = self._dm
with dmhooks.add_hooks(dm, self, appctx=self._ctx_ref):
self.pc.applyTranspose(x, y)
self.pc.applyTranspose(self.work_vec_y, self.work_vec_x)
if self.perm:
x.permute(self.perm)
y.permute(self.perm)
self._vec_permute(self.work_vec_x, y, self.perm)

def _vec_permute(self, vec_in, vec_out, perm):
array_in = vec_in.getArray(readonly=True)
array_out = vec_out.getArray(readonly=False)
with perm as perm_indices:
array_out[:] = array_in[perm_indices]

def view(self, pc, viewer=None):
super(FacetSplitPC, self).view(pc, viewer)
Expand Down

0 comments on commit f164243

Please sign in to comment.