17 #ifndef _FUELCELL__ADAPTIVEREFINEMENT_H_
18 #define _FUELCELL__ADAPTIVEREFINEMENT_H_
21 #include <base/parameter_handler.h>
22 #include <base/convergence_table.h>
23 #include <base/smartpointer.h>
24 #include <grid/tria.h>
40 namespace ApplicationCore
118 void solve(
const std::string param_file,
119 ParameterHandler& param,
120 bool solution_component_changes_between_data_files =
false );
125 void run_Newton(
bool solution_component_changes_between_data_files =
false);
131 bool solution_component_changes_between_data_files =
false );
137 std::vector<std::vector<double> >& dresp_dl,
138 bool solution_component_changes_between_data_files =
false );
146 const std::string dvar,
148 std::vector<double>& resp,
149 std::vector<std::vector<double> >& dresp,
150 const bool gradient =
true );
bool output_initial_mesh
Flag to specify if the initial grid should be saved to a file.
Definition: adaptive_refinement.h:199
unsigned int n_ref
Number of initial refinements for the original mesh.
Definition: adaptive_refinement.h:262
bool L1_L2_error_and_convergence_rate
Use true if you have the exact or analytical solution to compare your numerical results with...
Definition: adaptive_refinement.h:245
void run_Newton(bool solution_component_changes_between_data_files=false)
Run Newton application.
std::string filename_initial_mesh
Filename where to output the initial grid.
Definition: adaptive_refinement.h:189
bool nonlinear_solver_for_linear_problem
Use true along with zero initial guess defined in your application to solve a linear problem by means...
Definition: adaptive_refinement.h:255
const FuelCell::ApplicationCore::FEVector & get_coarse_solution() const
This function returns coarse_solution.
Definition: adaptive_refinement.h:170
bool output_intermediate_sol
Boolean flag that is set to true if intermediate solutions, i.e.
Definition: adaptive_refinement.h:213
FuelCell::ApplicationCore::FEVector coarse_solution
Global FE solution at the support points of the initial mesh.
Definition: adaptive_refinement.h:292
void declare_parameters(ParameterHandler ¶m) const
Declare all parameters that are needed for:
FuelCell::ApplicationCore::FEVector solution
Global FE solution at the support points of the most refined mesh.
Definition: adaptive_refinement.h:287
This class is initialized with an application that describes the linearization of the problem that we...
Definition: adaptive_refinement.h:54
FuelCell::ApplicationCore::OptimizationBlockMatrixApplication< dim > * app_linear
Pointer to linear application.
Definition: adaptive_refinement.h:277
FuelCell::ApplicationCore::ApplicationWrapper * app
Poiner to nonlinear application.
Definition: adaptive_refinement.h:282
AdaptiveRefinement(FuelCell::ApplicationCore::ApplicationBase &application)
Constructor.
Definition: adaptive_refinement.h:62
void print_convergence_table()
const FuelCell::ApplicationCore::FEVector & get_solution() const
This function returns solution.
Definition: adaptive_refinement.h:161
void initialize(ParameterHandler ¶m)
Set up how many equations are needed and read in parameters for the parameter handler in order to ini...
std::vector< ConvergenceTable > convergence_tables
If the exact or analytical solution is available, then those convergence tables collect all necessary...
Definition: adaptive_refinement.h:300
Base class for applications.
Definition: application_base.h:114
This class implements either iterative or time-stepping wrapper of applications.
Definition: application_wrapper.h:40
bool output_final_sol
Boolean flag used to specify if the final solution should be output to a file.
Definition: adaptive_refinement.h:224
void solve(const std::string param_file, ParameterHandler ¶m, bool solution_component_changes_between_data_files=false)
Solve the nonlinear problem.
bool gradients
Compute the gradients?
Definition: adaptive_refinement.h:267
bool output_intermediate_resp
Bool flag used to specify if all responses/functionals should be evaluated at intermediate refinement...
Definition: adaptive_refinement.h:238
const Triangulation< dim > & get_coarse_triangulation() const
This function returns coarse_triangulation.
Definition: adaptive_refinement.h:179
Triangulation< dim > coarse_triangulation
Initial mesh.
Definition: adaptive_refinement.h:272
void test_derivatives(const std::string input_file, const std::string dvar, const double value, std::vector< double > &resp, std::vector< std::vector< double > > &dresp, const bool gradient=true)
Member function used to test the derivatives.
BlockVector< double > FEVector
The vector class used by applications.
Definition: application_data.h:39
Application handling matrices and assembling the linear system to solve the sensitivity equations...
Definition: optimization_block_matrix_application.h:62
void print_parameters() const
Print parameters: