-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathSIMElasticityWrap.h
85 lines (65 loc) · 2.87 KB
/
SIMElasticityWrap.h
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
// $Id$
//==============================================================================
//!
//! \file SIMElasticityWrap.h
//!
//! \date April 21 2016
//!
//! \author Knut Morten Okstad
//!
//! \brief Wrapper equipping the elasticity solver with an ISolver interface.
//!
//==============================================================================
#ifndef _SIM_ELASTICITY_WRAP_H_
#define _SIM_ELASTICITY_WRAP_H_
#include "SIMElasticity.h"
#include "SIMenums.h"
#include "SIMsolution.h"
class DataExporter;
/*!
\brief Driver wrapping an elasticity solver with an ISolver interface.
\details The purpose of this class is to extend the SIMElasticity class with
the required methods such that it fits the ISolver interface and thus can be
used as class template argument to a SIMSolver instance for coupled solvers.
*/
template<class Dim>
class SIMElasticityWrap : public SIMElasticity<Dim>, public SIMsolution
{
protected:
//! \brief The default constructor is protected as this is an interface class.
explicit SIMElasticityWrap(const std::vector<unsigned char>& = {});
public:
//! \brief Empty destructor.
virtual ~SIMElasticityWrap() {}
//! \brief Registers solution fields for data output.
//! \param exporter Result export handler
void registerFields(DataExporter& exporter);
//! \brief Opens a new VTF-file and writes the model geometry to it.
//! \param[in] fileName File name used to construct the VTF-file name from
//! \param geoBlk Running geometry block counter
bool saveModel(char* fileName, int& geoBlk, int&);
//! \brief Saves the converged results of a given time step to VTF file.
//! \param[in] tp Time stepping parameters
//! \param nBlock Running result block counter
virtual bool saveStep(const TimeStep& tp, int& nBlock);
//! \brief Serializes current internal state for restarting purposes.
bool serialize(SerializeMap& data) const override;
//! \brief Restores the internal state from serialized data.
bool deSerialize(const SerializeMap& data) override;
//! \brief Restores the basis from serialized data.
bool deSerializeBasis(const SerializeMap& data);
//! \brief Initializes the linear equation solver and solution vectors.
//! \param[in] tp Time stepping parameters
//! \param[in] withRF If \e true, reaction forces will be calculated
virtual bool init(const TimeStep& tp, bool withRF = false);
//! \brief Advances the time step one step forward.
bool advanceStep(TimeStep& tp) override;
//! \brief Computes the solution for the current time step.
virtual bool solveStep(TimeStep& tp) = 0;
// Due to the multiple inheritance, the compiler needs to be told which
// version of this method to use (even though they have different signature)
using SIMsolution::getSolution;
//! \brief Overrides the parent class method to do nothing.
bool postProcessNorms(Vectors&, Matrix*) override { return true; }
};
#endif