Commit b8e46128 authored by Stephan Rave's avatar Stephan Rave
Browse files

[StationaryModel] add deaffinize method

parent 64f07ff6
......@@ -6,7 +6,8 @@ import numpy as np
from pymor.algorithms.timestepping import TimeStepper
from pymor.models.interface import Model
from pymor.operators.constructions import IdentityOperator, VectorOperator, ZeroOperator
from pymor.parameters.base import Parameters
from pymor.operators.constructions import IdentityOperator, VectorOperator, ZeroOperator, ConstantOperator
from pymor.vectorarrays.interface import VectorArray
from pymor.vectorarrays.numpy import NumpyVectorSpace
......@@ -146,6 +147,33 @@ class StationaryModel(Model):
return gradients
def deaffinize(self, arg):
if not isinstance(arg, VectorArray):
mu = self.parameters.parse(arg)
arg = self.solve(mu)
assert arg in self.solution_space and len(arg) == 1
affine_shift = arg
if self.operator.linear:
new_operator = self.operator
new_rhs = self.rhs - self.operator @ VectorOperator(affine_shift)
new_operator = \
self.operator @ (IdentityOperator(self.solution_space)
+ ConstantOperator(affine_shift, self.solution_space))
new_rhs = self.rhs
if self.output_functional is not None:
new_output_functional = \
self.output_functional @ (IdentityOperator(self.solution_space)
+ ConstantOperator(affine_shift, self.solution_space))
new_output_functional = None
return self.with_(operator=new_operator, rhs=new_rhs, output_functional=new_output_functional,
class InstationaryModel(Model):
"""Generic class for models of instationary problems.
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment