The Python module implements a semismooth Newton method for solving finite-element discretizations of the strongly convex, linear elliptic PDE-constrained optimization problem
where solves the linear elliptic PDE:
The feasible set is given by .
The control space is discretized using piecewise constant functions and the
state space is discretized using piecewise continuous functions. FEniCS
is used to preform the discretization. Sparse linear systems are solved using
npsolve
of scipy.
The parameter alpha
must be positive and beta
be nonnegative. The domain D
is (0,1)^d
with d
being one or two. The diffusion coefficient kappa
maps
from the domain to the positive reals. The lower and upper bounds lb
and ub
, the desired state yd
,
the diffusion coefficient kappa
, and the
source term g
must be instances of either
Constant
,
Function
, or
Expression
.
The semismooth Newton method is applied a normal map, a reformulation of the first-order optimality conditions as a nonsmooth operator equation (see eq. (3.3) in Ref. [3]).
The module implements a globalization via a restricted residual monotonicity test (see MonotonicityTest), while NewtonStep chooses the step size equal to one. The implementation of the restricted residual monotoncitity test is based on eq. (3.32) in Ref. [1].
The code can be downloaded using git clone
.
- example1, example2, example3, and example4 implement Examples 1--4 in Ref. [4].
- poisson1d and possion2d use an L1-heuristic to determine
beta
(compare with p. 199 in Ref. [2] and Lemma 3.1 in Ref. [4]). - example73 implements Example 7.3 in Ref. [5] and it is used for code verification.
- random_poisson2d demonstrates how to use the module to solve sample average approximations of a simple risk-neutral problem.
- cdc provides an example where globalization using MonotonicityTest requires fewer iterations than NewtonStep.
Some tests use the following packages:
The code was tested using python version 3.8.11, scipy version 1.7.0, numpy version 1.21.1, fenics version 2019.1.0, moola version 0.1.6, and matplotlib version 3.4.2 (see also environment.yml).
- [1] P. Deuflhard, Newton Methods for Nonlinear Problems, Springer Ser. Comput. Math. 35, Springer, Berlin, 2011
- [2] N. Parikh and S. Boyd, Proximal Algorithms, Found. Trends Mach. Learning, 1 (2014), pp. 127--239
- [3] K. Pieper, Finite element discretization and efficient numerical solution of elliptic and parabolic sparse control problems, Dissertation, Technische Universität München, München, 2015
- [4] G. Stadler, Elliptic optimal control problems with L1-control cost and applications for the placement of control devices, Comput. Optim. Appl., 44 (2009), pp. 159--181
- [5] G. Wachsmuth and D. Wachsmuth, Convergence and regularization results for optimal control problems with sparsity functional, ESAIM Control. Optim. Calc. Var., 17 (2011), pp. 858--886
The code has been implemented by Johannes Milz.