version 3.8
gridmanager_oned.hh
Go to the documentation of this file.
1// -*- mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2// vi: set et ts=4 sw=4 sts=4:
3//
4// SPDX-FileCopyrightInfo: Copyright © DuMux Project contributors, see AUTHORS.md in root folder
5// SPDX-License-Identifier: GPL-3.0-or-later
6//
12#ifndef DUMUX_IO_GRID_MANAGER_ONED_HH
13#define DUMUX_IO_GRID_MANAGER_ONED_HH
14
15#include <dune/grid/onedgrid.hh>
16#include <dune/grid/io/file/dgfparser/dgfoned.hh>
17
18#ifndef DUMUX_IO_GRID_MANAGER_BASE_HH
20#endif
21
22namespace Dumux {
23
38template<>
39class GridManager<Dune::OneDGrid>
40: public GridManagerBase<Dune::OneDGrid>
41{
42public:
43 using Grid = Dune::OneDGrid;
45
49 void init(const std::string& modelParamGroup = "")
50 {
51
52 // try to create it from a DGF or msh file in GridParameterGroup.File
53 if (hasParamInGroup(modelParamGroup, "Grid.File"))
54 {
55 ParentType::makeGridFromDgfFile(getParamFromGroup<std::string>(modelParamGroup, "Grid.File"));
56 postProcessing_(modelParamGroup);
57 return;
58 }
59
60 // Look for the necessary keys to construct from the input file
61 else if (hasParamInGroup(modelParamGroup, "Grid.RightBoundary"))
62 {
63 // The required parameters
64 using CoordinateType = typename Grid::ctype;
65 const auto leftBoundary = getParamFromGroup<CoordinateType>(modelParamGroup, "Grid.LeftBoundary", 0.0);
66 const auto rightBoundary = getParamFromGroup<CoordinateType>(modelParamGroup, "Grid.RightBoundary");
67 const int cells = getParamFromGroup<int>(modelParamGroup, "Grid.Cells", 1);
68
69 ParentType::gridPtr() = std::make_shared<Grid>(cells, leftBoundary, rightBoundary);
70 postProcessing_(modelParamGroup);
71 return;
72 }
73
74 // Look for the necessary keys to construct from the input file with just a coordinates vector
75 else if (hasParamInGroup(modelParamGroup, "Grid.Coordinates"))
76 {
77 const auto coordinates = getParamFromGroup<std::vector<typename Grid::ctype>>(modelParamGroup, "Grid.Coordinates");
78 ParentType::gridPtr() = std::make_shared<Grid>(coordinates);
79 postProcessing_(modelParamGroup);
80 }
81
82 // Didn't find a way to construct the grid
83 else
84 {
85 const auto prefix = modelParamGroup.empty() ? modelParamGroup : modelParamGroup + ".";
86 DUNE_THROW(ParameterException, "Please supply one of the parameters "
87 << prefix + "Grid.RightBoundary"
88 << ", or " << prefix + "Grid.Coordinates"
89 << ", or a grid file in " << prefix + "Grid.File");
90 }
91 }
92
96 void loadBalance() {}
97
98private:
102 void postProcessing_(const std::string& modelParamGroup)
103 {
104 // Set refinement type
105 const auto refType = getParamFromGroup<std::string>(modelParamGroup, "Grid.RefinementType", "Local");
106 if (refType == "Local")
107 ParentType::grid().setRefinementType(Dune::OneDGrid::RefinementType::LOCAL);
108 else if (refType == "Copy")
109 ParentType::grid().setRefinementType(Dune::OneDGrid::RefinementType::COPY);
110 else
111 DUNE_THROW(Dune::IOError, "OneGrid only supports 'Local' or 'Copy' as refinement type. Not '"<< refType<<"'!");
112
113 // Check if should refine the grid
114 ParentType::maybeRefineGrid(modelParamGroup);
115 loadBalance();
116 }
117};
118
119} // end namespace Dumux
120
121#endif
void init(const std::string &modelParamGroup="")
Make the grid. This is implemented by specializations of this method.
Definition: gridmanager_oned.hh:49
void loadBalance()
Call loadBalance() function of the grid. OneDGrid is not parallel an thus cannot communicate.
Definition: gridmanager_oned.hh:96
Dune::OneDGrid Grid
Definition: gridmanager_oned.hh:43
The grid manager base interface (public) and methods common to most grid manager specializations (pro...
Definition: gridmanager_base.hh:55
void loadBalance()
Call loadBalance() function of the grid.
Definition: gridmanager_base.hh:97
The grid manager (this is the class used by the user) for all supported grid managers that constructs...
Definition: gridmanager_base.hh:323
Exception thrown if a run-time parameter is not specified correctly.
Definition: exceptions.hh:48
Provides a grid manager for all supported grid managers with input file interfaces....
bool hasParamInGroup(const std::string &paramGroup, const std::string &param)
Check whether a key exists in the parameter tree with a model group prefix.
Definition: parameters.hh:165
Definition: adapt.hh:17
Definition: common/pdesolver.hh:24