⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 timeslabsolver.h

📁 利用C
💻 H
字号:
// Copyright (C) 2005 Anders Logg.// Licensed under the GNU LGPL Version 2.1.//// First added:  2005-01-05// Last changed: 2005-11-11#ifndef __TIME_SLAB_SOLVER_H#define __TIME_SLAB_SOLVER_H#include "ODE.h"namespace dolfin{  class Method;  class TimeSlab;    /// This is the base class for solvers of the system of equations  /// defined on time slabs.  class TimeSlabSolver  {  public:        /// Constructor    TimeSlabSolver(TimeSlab& timeslab);    /// Destructor    virtual ~TimeSlabSolver();    /// Solve system    bool solve();  protected:    /// Solve system    bool solve(uint attempt);    /// Retry solution of system, perhaps with a new strategy (optional)    virtual bool retry();    /// Start iterations (optional)    virtual void start();    /// End iterations (optional)    virtual void end();    /// Make an iteration, return increment    virtual real iteration(real tol, uint itera, real d0, real d1) = 0;    /// Size of system    virtual uint size() const = 0;    // The ODE    ODE& ode;    // The method    const Method& method;        // Tolerance for iterations (max-norm)    real tol;    // Maximum number of iterations    uint maxiter;    // True if we should monitor the convergence    bool monitor;    // Number of time slabs systems solved    uint num_timeslabs;    // Number of global iterations made    uint num_global_iterations;    // Number of local iterations made (GMRES)    uint num_local_iterations;    // Current maxnorm of solution    real xnorm;  private:    /// Choose tolerance    void chooseTolerance();  };}#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -