Skip to content
Snippets Groups Projects
Commit e26ac777 authored by Kilian Weishaupt's avatar Kilian Weishaupt
Browse files

[staggered][elementSolutiuon] Add convenience function

* directly creates elementSolution from CC privars
parent 088859f0
No related branches found
No related tags found
1 merge request!1143Fix/caching staggered
...@@ -32,10 +32,10 @@ namespace Dumux { ...@@ -32,10 +32,10 @@ namespace Dumux {
/*! /*!
* \ingroup StaggeredDiscretization * \ingroup StaggeredDiscretization
* \brief Helper function to creater a PrimaryVariables object from CellCenterPrimaryVariables * \brief Helper function to create a PrimaryVariables object from CellCenterPrimaryVariables
* \tparam PrimaryVariables The type of the desired primary variables object * \tparam PrimaryVariables The type of the desired primary variables object
* \tparam CellCenterPrimaryVariables The type of the cell center (input) primary variables object * \tparam CellCenterPrimaryVariables The type of the cell center (input) primary variables object
* \param CellCenterPrimaryVariables The cell center (input) primary variables object * \param cellCenterPrimaryVariables The cell center (input) primary variables object
*/ */
template<class PrimaryVariables, class CellCenterPrimaryVariables> template<class PrimaryVariables, class CellCenterPrimaryVariables>
PrimaryVariables makePriVarsFromCellCenterPriVars(const CellCenterPrimaryVariables& cellCenterPriVars) PrimaryVariables makePriVarsFromCellCenterPriVars(const CellCenterPrimaryVariables& cellCenterPriVars)
...@@ -56,7 +56,7 @@ using StaggeredElementSolution = Dune::BlockVector<PrimaryVariables>; ...@@ -56,7 +56,7 @@ using StaggeredElementSolution = Dune::BlockVector<PrimaryVariables>;
/*! /*!
* \ingroup StaggeredDiscretization * \ingroup StaggeredDiscretization
* \brief Make an element solution for staggered schemes * \brief Make an element solution for staggered schemes
* \note This is e.g. used to contruct an element solution at Dirichlet boundaries * \note This is e.g. used to construct an element solution at Dirichlet boundaries
*/ */
template<class FVElementGeometry, class PrimaryVariables> template<class FVElementGeometry, class PrimaryVariables>
auto elementSolution(PrimaryVariables&& priVars) auto elementSolution(PrimaryVariables&& priVars)
...@@ -66,6 +66,19 @@ auto elementSolution(PrimaryVariables&& priVars) ...@@ -66,6 +66,19 @@ auto elementSolution(PrimaryVariables&& priVars)
return StaggeredElementSolution<PrimaryVariables>({std::move(priVars)}); return StaggeredElementSolution<PrimaryVariables>({std::move(priVars)});
} }
/*!
* \ingroup StaggeredDiscretization
* \brief Helper function to create an elementSolution from cell center primary variables
* \tparam PrimaryVariables The type of the desired primary variables object
* \tparam CellCenterPrimaryVariables The type of the cell center (input) primary variables object
* \param cellCenterPrimaryVariables The cell center (input) primary variables object
*/
template<class PrimaryVariables, class CellCenterPrimaryVariables>
StaggeredElementSolution<PrimaryVariables> makeElementSolutionFromCellCenterPrivars(const CellCenterPrimaryVariables& cellCenterPriVars)
{
return StaggeredElementSolution<PrimaryVariables>({makePriVarsFromCellCenterPriVars<PrimaryVariables>(cellCenterPriVars)});
}
} // end namespace Dumux } // end namespace Dumux
#endif #endif
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment