ProblemInstat.h 7.77 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
// ============================================================================
// ==                                                                        ==
// == AMDiS - Adaptive multidimensional simulations                          ==
// ==                                                                        ==
// ============================================================================
// ==                                                                        ==
// ==  crystal growth group                                                  ==
// ==                                                                        ==
// ==  Stiftung caesar                                                       ==
// ==  Ludwig-Erhard-Allee 2                                                 ==
// ==  53175 Bonn                                                            ==
// ==  germany                                                               ==
// ==                                                                        ==
// ============================================================================
// ==                                                                        ==
// ==  http://www.caesar.de/cg/AMDiS                                         ==
// ==                                                                        ==
// ============================================================================

/** \file ProblemInstat.h */

#ifndef AMDIS_PROBLEM_INSTAT_H_
#define AMDIS_PROBLEM_INSTAT_H_

#include "ProblemScal.h"
#include "ProblemVec.h"
#include "ProblemTimeInterface.h"
#include "AdaptInstationary.h"

namespace AMDiS {

  // ===========================================================================
  // ===== class ProblemInstat =================================================
  // ===========================================================================

  /**
   * \ingroup Problem
   *
   * \brief
   * Base class for ProblemInstatScal and ProblemInstatVec.
   */
  class ProblemInstat : public ProblemTimeInterface,
			public ProblemStatBase
  {
  public:
    /** \brief
     * Constructor.
     */
49
    ProblemInstat(std::string name_,
50 51 52
		  ProblemStatBase *initialProb)
      : name(name_),
	initialProblem(initialProb ? initialProb : this)
53
    {}
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69

    /** \brief
     * Destructor.
     */
    virtual ~ProblemInstat();


    /** \brief
     * Initialisation of the problem.
     */
    virtual void initialize(Flag initFlag,
			    ProblemInstat *adoptProblem = NULL,
			    Flag adoptFlag = INIT_NOTHING);

    /** \brief
     */
70 71 72 73 74 75 76
    virtual void solve(AdaptInfo* adaptInfo) {}

    /** \brief
     */
    virtual void solve(AdaptInfo *adaptInfo, bool fixedMatrix) {
      solve(adaptInfo);
    }
77 78 79

    /** \brief
     */
80
    virtual void estimate(AdaptInfo *adaptInfo) {}
81 82 83

    /** \brief
     */
84
    virtual void buildBeforeRefine(AdaptInfo *adaptInfo, Flag) {}
85 86 87

    /** \brief
     */
88
    virtual void buildBeforeCoarsen(AdaptInfo *adaptInfo, Flag) {}
89 90 91

    /** \brief
     */
92
    virtual void buildAfterCoarsen(AdaptInfo *adaptInfo, Flag, bool, bool) {}
93 94 95

    /** \brief
     */
Thomas Witkowski's avatar
Thomas Witkowski committed
96 97
    virtual Flag markElements(AdaptInfo *adaptInfo) { 
      return 0; 
98
    }
99 100 101

    /** \brief
     */
Thomas Witkowski's avatar
Thomas Witkowski committed
102 103
    virtual Flag refineMesh(AdaptInfo *adaptInfo) { 
      return 0; 
104
    }
105 106 107

    /** \brief
     */
Thomas Witkowski's avatar
Thomas Witkowski committed
108 109
    virtual Flag coarsenMesh(AdaptInfo *adaptInfo) { 
      return 0; 
110
    }
111 112 113 114

    /** \brief
     * Implementation of ProblemTimeInterface::closeTimestep().
     */
115
    virtual void closeTimestep() {}
116 117 118 119

    /** \brief
     * Returns \ref name.
     */
120
    inline const std::string& getName() { 
Thomas Witkowski's avatar
Thomas Witkowski committed
121
      return name; 
122
    }
123 124 125 126 127 128

    /** \brief
     * Used by \ref problemInitial
     */
    virtual void solveInitialProblem(AdaptInfo *adaptInfo);  

Thomas Witkowski's avatar
Thomas Witkowski committed
129

130 131 132 133
  protected:
    /** \brief
     * Name of the problem.
     */
134
    std::string name;
135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175

    ProblemStatBase *initialProblem;
  };

  // ===========================================================================
  // ===== class ProblemInstatScal =============================================
  // ===========================================================================

  /**
   * \ingroup Problem
   *
   * \brief
   * Standard implementation of ProblemTimeInterface for a time dependent problems.
   */
  class ProblemInstatScal : public ProblemInstat
  {
  public:
    /** \brief
     * Constructs a ProblemInstatScal with prob as its stationary problem.
     */
    ProblemInstatScal(char* name_, 
		      ProblemScal *prob,
		      ProblemStatBase *initialProb = NULL);

    /** \brief
     * Destructor.
     */
    virtual ~ProblemInstatScal();

    /** \brief
     * Initialisation of the problem.
     */
    virtual void initialize(Flag initFlag,
			    ProblemInstat *adoptProblem = NULL,
			    Flag adoptFlag = INIT_NOTHING);


    /** \brief
     * Used in \ref initialize().
     */
    virtual void createUhOld();
176
 
177 178 179 180 181 182 183 184 185 186 187 188 189
    /** \brief
     * Implementation of ProblemTimeInterface::initTimestep().
     */
    virtual void initTimestep(AdaptInfo *adaptInfo);

    /** \brief
     * Implementation of ProblemTimeInterface::closeTimestep().
     */
    virtual void closeTimestep(AdaptInfo *adaptInfo);
  
    /** \brief
     * Returns \ref problemStat.
     */
190 191 192
    inline ProblemScal* getStatProblem() { 
      return problemStat; 
    };
193 194 195 196

    /** \brief
     * Returns \ref oldSolution.
     */
197 198 199
    inline DOFVector<double> *getOldSolution() { 
      return oldSolution; 
    };
200 201 202 203 204 205

    /** \brief
     * Used by \ref problemInitial
     */
    virtual void transferInitialSolution(AdaptInfo *adaptInfo);  

Thomas Witkowski's avatar
Thomas Witkowski committed
206

207
    virtual void serialize(std::ostream &out) {};
208

209
    virtual void deserialize(std::istream &in) {};
210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274
   
  protected:
    /** \brief
     * Space problem solved in each timestep.
     */
    ProblemScal* problemStat;

    /** \brief
     * Solution of the last timestep.
     */
    DOFVector<double>* oldSolution;
  };


  // ===========================================================================
  // ===== class ProblemInstatVec ==============================================
  // ===========================================================================

  /**
   * \ingroup Problem
   *
   * \brief
   * Standard implementation of ProblemTimeInterface for a time dependent 
   * vector valued problems.
   */
  class ProblemInstatVec : public ProblemInstat
  {
  public:
    /** \brief
     * Constructs a ProblemInstatVec with prob as its stationary problem.
     */
    ProblemInstatVec(char       *name_, 
		     ProblemVec *prob,
		     ProblemStatBase *initialProb = NULL);

    /** \brief
     * Destructor.
     */
    virtual ~ProblemInstatVec();

    /** \brief
     * Initialisation of the problem.
     */
    virtual void initialize(Flag initFlag,
			    ProblemInstat *adoptProblem = NULL,
			    Flag adoptFlag = INIT_NOTHING);

    /** \brief
     * Used in \ref initialize().
     */
    virtual void createUhOld();

    /** \brief
     * Implementation of ProblemTimeInterface::initTimestep().
     */
    virtual void initTimestep(AdaptInfo *adaptInfo);

    /** \brief
     * Implementation of ProblemTimeInterface::closeTimestep().
     */
    virtual void closeTimestep(AdaptInfo *adaptInfo);
  
    /** \brief
     * Returns \ref problemStat.
     */
275 276
    inline ProblemVec* getStatProblem() { 
      return problemStat; 
Thomas Witkowski's avatar
Thomas Witkowski committed
277
    }
278 279 280 281

    /** \brief
     * Returns \ref oldSolution.
     */
282 283
    inline SystemVector *getOldSolution() { 
      return oldSolution; 
Thomas Witkowski's avatar
Thomas Witkowski committed
284
    }
285 286 287 288 289 290

    /** \brief
     * Used by \ref problemInitial
     */
    virtual void transferInitialSolution(AdaptInfo *adaptInfo);  

Thomas Witkowski's avatar
Thomas Witkowski committed
291
    virtual void serialize(std::ostream &out) {}
Thomas Witkowski's avatar
Thomas Witkowski committed
292

Thomas Witkowski's avatar
Thomas Witkowski committed
293
    virtual void deserialize(std::istream &in) {}
294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309

  protected:
    /** \brief
     * Space problem solved in each timestep.
     */
    ProblemVec* problemStat;

    /** \brief
     * Solution of the last timestep.
     */
    SystemVector *oldSolution;
  };

}

#endif