ASPECT
dynamic_topography.h
Go to the documentation of this file.
1 /*
2  Copyright (C) 2011 - 2021 by the authors of the ASPECT code.
3 
4  This file is part of ASPECT.
5 
6  ASPECT is free software; you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation; either version 2, or (at your option)
9  any later version.
10 
11  ASPECT is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with ASPECT; see the file LICENSE. If not see
18  <http://www.gnu.org/licenses/>.
19 */
20 
21 
22 #ifndef _aspect_postprocess_surface_topography_h
23 #define _aspect_postprocess_surface_topography_h
24 
27 
28 
29 namespace aspect
30 {
31  namespace Postprocess
32  {
33 
39  template <int dim>
40  class DynamicTopography : public Interface<dim>, public ::aspect::SimulatorAccess<dim>
41  {
42  public:
46  std::pair<std::string,std::string>
47  execute (TableHandler &statistics) override;
48 
57  topography_vector() const;
58 
65  const Vector<float> &
66  cellwise_topography() const;
67 
71  std::list<std::string>
72  required_other_postprocessors() const override;
73 
77  void
78  parse_parameters (ParameterHandler &prm) override;
79 
83  static
84  void
85  declare_parameters (ParameterHandler &prm);
86 
87  private:
94  void output_to_file(const types::boundary_id boundary_id,
95  const std::vector<std::pair<Point<dim>, double>> &position_and_topography);
96 
102 
108  Vector<float> visualization_values;
109 
115 
121 
126 
131  };
132  }
133 }
134 
135 
136 #endif
const Vector< float > & cellwise_topography() const
::TrilinosWrappers::MPI::BlockVector BlockVector
Definition: global.h:239
LinearAlgebra::BlockVector topo_vector
std::list< std::string > required_other_postprocessors() const override
void parse_parameters(ParameterHandler &prm) override
const LinearAlgebra::BlockVector & topography_vector() const
std::pair< std::string, std::string > execute(TableHandler &statistics) override
static void declare_parameters(ParameterHandler &prm)
void output_to_file(const types::boundary_id boundary_id, const std::vector< std::pair< Point< dim >, double >> &position_and_topography)