12 #define BOOST_ALLOW_DEPRECATED_HEADERS
14 #include <deal.II/base/multithread_info.h>
20 #include "project_PHI_to_D.hpp"
21 #include "project_PHI_to_E.hpp"
36 if (nr_threads_max > 0)
37 MultithreadInfo::set_thread_limit(nr_threads_max);
39 Assert(DIMENSION__ > 1, ExcInternalError());
40 Assert(DIMENSION__ < 4, ExcInternalError());
45 if (HYPERCUBE__ == 1) {
46 dir = (DIMENSION__ == 2) ?
"Data/square/" :
"Data/cube/";
48 dir = (DIMENSION__ == 2) ?
"Data/circle/" :
"Data/sphere/";
51 std::cout <<
"Program: mms\n"
52 <<
"Dimensions: " << DIMENSION__ <<
"\n"
53 <<
"Writing to: " << dir <<
"\n";
59 for (
unsigned int p = 1; p < 4; p++) {
65 for (
unsigned int r = 9; r < 13; r++)
68 for (
unsigned int r = 8; r < 12; r++)
71 fname = dir +
"solution_PHI_p" + std::to_string(p) +
"_r" +
75 table_PHI.add_value(
"r", r);
76 table_PHI.add_value(
"p", p);
79 std::cout <<
"Time table PHI \n";
82 table_PHI.add_value(
"ndofs", problem.
get_n_dofs());
83 table_PHI.add_value(
"ncells", problem.
get_n_cells());
90 fname = dir +
"solution_E_p" + std::to_string(p) +
"_r" +
93 table_E.add_value(
"r", r);
94 table_E.add_value(
"p", p);
97 std::cout <<
"Time table E \n";
101 ProjectPHItoE projector(p - 1,
113 table_E.add_value(
"ndofs", projector.get_n_dofs());
114 table_E.add_value(
"ncells", projector.get_n_cells());
115 table_E.add_value(
"L2", projector.get_L2_norm());
116 table_E.add_value(
"H1", 0.0);
119 fname = dir +
"solution_D_p" + std::to_string(p) +
"_r" +
122 table_D.add_value(
"r", r);
123 table_D.add_value(
"p", p);
126 std::cout <<
"Time table D \n";
130 ProjectPHItoD projector(p - 1,
142 table_D.add_value(
"ndofs", projector.get_n_dofs());
143 table_D.add_value(
"ncells", projector.get_n_cells());
144 table_D.add_value(
"L2", projector.get_L2_norm() / ep_0);
145 table_D.add_value(
"H1", 0.0);
149 std::cout <<
"Table PHI\n";
150 table_PHI.
save(dir +
"table_PHI_p" + std::to_string(p));
152 std::cout <<
"Table E\n";
153 table_E.
save(dir +
"table_E_p" + std::to_string(p));
155 std::cout <<
"Table D\n";
156 table_D.
save(dir +
"table_D_p" + std::to_string(p));
167 }
catch (std::exception& exc) {
168 std::cerr << std::endl
170 <<
"----------------------------------------------------"
172 std::cerr <<
"Exception on processing: " << std::endl
173 << exc.what() << std::endl
174 <<
"Aborting!" << std::endl
175 <<
"----------------------------------------------------"
179 std::cerr << std::endl
181 <<
"----------------------------------------------------"
183 std::cerr <<
"Unknown exception!" << std::endl
184 <<
"Aborting!" << std::endl
185 <<
"----------------------------------------------------"
This is a wrap-around class. It contains the main loop of the program that implements the Method of m...
Describes exact solution, , of the Method of manufactured solutions (mms/) numerical experiment in tw...
Describes exact solution, , of the Method of manufactured solutions (mms/) numerical experiment in tw...
The convergence table used in multiple numerical experiments.
void save(std::string fname)
Saves the data in text and tex formats, and prints the data on screen.
Global settings for the Method of manufactured solutions (mms/) numerical experiment.
const bool project_exact_solution
If set to true, the program will project the exact solution.
const bool log_cg_convergence
If set to true, saves the residual at each iteration of the CG solver. The names of the files fit the...
const bool print_time_tables
If set to true, the program will print time tables on the screen.
Implements the solver of the Method of manufactured solutions (mms/) numerical experiment.
const Triangulation< dim > & get_tria() const
Returns a reference to triangulation.
const Vector< double > & get_solution() const
Returns a reference to the solution.
double get_L2_norm() const
Returns error norm.
void clear()
Releases computer memory associated with the system matrix and right-hand side.
const DoFHandler< dim > & get_dof_handler() const
Returns a reference to dof handler.
double get_H1_norm() const
Returns error norm.
unsigned int get_n_dofs() const
Returns the total amount of the degrees of freedom.
unsigned int get_n_cells() const
Returns the number of active cells in the mesh.
unsigned int get_mapping_degree() const
Returns degree of the interpolating Lagrange polynomials used for mapping from the reference cell to ...