/* * Solver.hpp, part of LatAnalyze 3 * * Copyright (C) 2013 - 2020 Antonin Portelli * * LatAnalyze 3 is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * LatAnalyze 3 is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with LatAnalyze 3. If not, see . */ #ifndef Latan_Solver_hpp_ #define Latan_Solver_hpp_ #include BEGIN_LATAN_NAMESPACE /****************************************************************************** * Solver * ******************************************************************************/ class Solver { public: static const unsigned int defaultMaxIteration = 10000u; static constexpr double defaultPrec = 1.0e-7; public: enum class Verbosity { Silent = 0, Normal = 1, Debug = 2 }; public: // constructors Solver(const double precision = defaultPrec, const unsigned int maxIteration = defaultMaxIteration); explicit Solver(const Index dim, const double precision = defaultPrec, const unsigned int maxIteration = defaultMaxIteration); // destructor virtual ~Solver(void) = default; // access Index getDim(void) const; virtual double getPrecision(void) const; virtual unsigned int getMaxIteration(void) const; Verbosity getVerbosity(void) const; virtual void setInit(const DVec &x0); virtual void setPrecision(const double precision); virtual void setMaxIteration(const unsigned int maxIteration); void setVerbosity(const Verbosity verbosity); virtual void resize(const Index dim); protected: // access DVec & getState(void); private: unsigned int maxIteration_; double precision_; DVec x_; Verbosity verbosity_{Verbosity::Silent}; }; END_LATAN_NAMESPACE #endif // Latan_Solver_hpp_