16 #ifndef dealii_solver_minres_h 17 #define dealii_solver_minres_h 71 template <
class VectorType = Vector<
double>>
104 template <
typename MatrixType,
typename PreconditionerType>
106 solve(
const MatrixType &
A,
109 const PreconditionerType &preconditioner);
154 template <
class VectorType>
164 template <
class VectorType>
168 ,
res2(numbers::signaling_nan<double>())
173 template <
class VectorType>
181 template <
class VectorType>
191 template <
class VectorType>
192 template <
typename MatrixType,
typename PreconditionerType>
197 const PreconditionerType &preconditioner)
214 vecptr u[3] = {Vu0.get(), Vu1.get(), Vu2.get()};
215 vecptr m[3] = {Vm0.get(), Vm1.get(), Vm2.get()};
220 u[0]->reinit(b,
true);
221 u[1]->reinit(b,
true);
222 u[2]->reinit(b,
true);
223 m[0]->reinit(b,
true);
224 m[1]->reinit(b,
true);
225 m[2]->reinit(b,
true);
229 double delta[3] = {0, 0, 0};
230 double f[2] = {0, 0};
231 double e[2] = {0, 0};
253 preconditioner.vmult(v, *u[1]);
255 delta[1] = v * (*u[1]);
259 r0 = std::sqrt(delta[1]);
273 v *= 1. / std::sqrt(delta[1]);
278 u[2]->add(-std::sqrt(delta[1] / delta[0]), *u[0]);
280 const double gamma = *u[2] * v;
281 u[2]->add(-gamma / std::sqrt(delta[1]), *u[1]);
287 preconditioner.vmult(v, *u[2]);
289 delta[2] = v * (*u[2]);
296 e[1] = std::sqrt(delta[2]);
300 d_ = s * e[0] - c *
gamma;
301 e[0] = c * e[0] + s *
gamma;
302 f[1] = s * std::sqrt(delta[2]);
303 e[1] = -c * std::sqrt(delta[2]);
306 const double d = std::sqrt(d_ * d_ + delta[2]);
313 s = std::sqrt(delta[2]) /
d;
318 m[0]->add(-e[0], *m[1]);
320 m[0]->add(-f[0], *m[2]);
void solve(const MatrixType &A, VectorType &x, const VectorType &b, const PreconditionerType &preconditioner)
SolverMinRes(SolverControl &cn, VectorMemory< VectorType > &mem, const AdditionalData &data=AdditionalData())
SymmetricTensor< 2, dim, Number > e(const Tensor< 2, dim, Number > &F)
boost::signals2::signal< SolverControl::State(const unsigned int iteration, const double check_value, const VectorType ¤t_iterate), StateCombiner > iteration_status
#define AssertThrow(cond, exc)
Stop iteration, goal reached.
#define Assert(cond, exc)
#define DeclException0(Exception0)
#define DEAL_II_NAMESPACE_CLOSE
virtual ~SolverMinRes() override=default
Expression fabs(const Expression &x)
SymmetricTensor< 2, dim, Number > d(const Tensor< 2, dim, Number > &F, const Tensor< 2, dim, Number > &dF_dt)
SymmetricTensor< 2, dim, Number > b(const Tensor< 2, dim, Number > &F)
void swap(MemorySpaceData< Number, MemorySpace > &, MemorySpaceData< Number, MemorySpace > &)
#define DEAL_II_NAMESPACE_OPEN
virtual double criterion()
long double gamma(const unsigned int n)
static ::ExceptionBase & ExcPreconditionerNotDefinite()
VectorMemory< VectorType > & memory
virtual void print_vectors(const unsigned int step, const VectorType &x, const VectorType &r, const VectorType &d) const