36 #ifndef NEKTAR_SOLVERUTILS_UNSTEADYSYSTEM_H 
   37 #define NEKTAR_SOLVERUTILS_UNSTEADYSYSTEM_H 
virtual SOLVER_UTILS_EXPORT bool v_SteadyStateCheck(int step)
 
virtual SOLVER_UTILS_EXPORT void v_DoSolve()
Solves an unsteady problem. 
 
bool m_explicitReaction
Indicates if explicit or implicit treatment of reaction is used. 
 
virtual SOLVER_UTILS_EXPORT void v_NumFluxforVector(const Array< OneD, Array< OneD, NekDouble > > &ufield, Array< OneD, Array< OneD, Array< OneD, NekDouble > > > &qfield, Array< OneD, Array< OneD, NekDouble > > &qflux)
 
SOLVER_UTILS_EXPORT void CheckForRestartTime(NekDouble &time)
 
virtual SOLVER_UTILS_EXPORT bool v_PreIntegrate(int step)
 
A base class for describing how to solve specific equations. 
 
bool m_homoInitialFwd
Flag to determine if simulation should start in homogeneous forward transformed state. 
 
bool m_explicitDiffusion
Indicates if explicit or implicit treatment of diffusion is used. 
 
LibUtilities::TimeIntegrationSchemeOperators m_ode
The time integration scheme operators to use. 
 
std::vector< std::pair< std::string, std::string > > SummaryList
 
void WeakPenaltyforVector(const int var, const int dir, const Array< OneD, const NekDouble > &physfield, Array< OneD, NekDouble > &penaltyflux, NekDouble C11, NekDouble time=0.0)
 
virtual SOLVER_UTILS_EXPORT void v_AppendOutput1D(Array< OneD, Array< OneD, NekDouble > > &solution1D)
Print the solution at each solution point in a txt file. 
 
boost::shared_ptr< TimeIntegrationWrapper > TimeIntegrationWrapperSharedPtr
 
virtual SOLVER_UTILS_EXPORT NekDouble v_GetTimeStep(const Array< OneD, const Array< OneD, NekDouble > > &inarray)
Return the timestep to be used for the next step in the time-marching loop. 
 
SOLVER_UTILS_EXPORT NekDouble MaxTimeStepEstimator()
Get the maximum timestep estimator for cfl control. 
 
boost::shared_ptr< SessionReader > SessionReaderSharedPtr
 
SOLVER_UTILS_EXPORT void SVVVarDiffCoeff(const Array< OneD, Array< OneD, NekDouble > > vel, StdRegions::VarCoeffMap &varCoeffMap)
Evaluate the SVV diffusion coefficient according to Moura's paper where it should proportional to h t...
 
virtual SOLVER_UTILS_EXPORT void v_GenerateSummary(SummaryList &s)
Print a summary of time stepping parameters. 
 
bool m_explicitAdvection
Indicates if explicit or implicit treatment of advection is used. 
 
virtual SOLVER_UTILS_EXPORT ~UnsteadySystem()
Destructor. 
 
virtual SOLVER_UTILS_EXPORT bool v_PostIntegrate(int step)
 
std::map< StdRegions::VarCoeffType, Array< OneD, NekDouble > > VarCoeffMap
 
Base class for unsteady solvers. 
 
virtual SOLVER_UTILS_EXPORT void v_InitObject()
Init object for UnsteadySystem class. 
 
SOLVER_UTILS_EXPORT NekDouble GetTimeStep()
 
NekDouble m_cflSafetyFactor
CFL safety factor (comprise between 0 to 1). 
 
virtual SOLVER_UTILS_EXPORT void v_NumFluxforScalar(const Array< OneD, Array< OneD, NekDouble > > &ufield, Array< OneD, Array< OneD, Array< OneD, NekDouble > > > &uflux)
 
SOLVER_UTILS_EXPORT UnsteadySystem(const LibUtilities::SessionReaderSharedPtr &pSession)
Initialises UnsteadySystem class members. 
 
virtual SOLVER_UTILS_EXPORT void v_NumericalFlux(Array< OneD, Array< OneD, NekDouble > > &physfield, Array< OneD, Array< OneD, NekDouble > > &numflux)
 
#define SOLVER_UTILS_EXPORT
 
boost::shared_ptr< TimeIntegrationSolution > TimeIntegrationSolutionSharedPtr
 
LibUtilities::TimeIntegrationWrapperSharedPtr m_intScheme
Wrapper to the time integration scheme. 
 
std::vector< FilterSharedPtr > m_filters
 
int m_infosteps
Number of time steps between outputting status information. 
 
void WeakPenaltyforScalar(const int var, const Array< OneD, const NekDouble > &physfield, Array< OneD, NekDouble > &penaltyflux, NekDouble time=0.0)
 
LibUtilities::TimeIntegrationSolutionSharedPtr m_intSoln
 
virtual SOLVER_UTILS_EXPORT void v_DoInitialise()
Sets up initial conditions. 
 
std::vector< int > m_intVariables