22 #ifndef _aspect_boundary_traction_interface_h 23 #define _aspect_boundary_traction_interface_h 28 #include <deal.II/base/point.h> 29 #include <deal.II/base/parameter_handler.h> 39 namespace BoundaryTraction
47 class Interface :
public Plugins::InterfaceBase
67 const Point<dim> &position,
68 const Tensor<1,dim> &normal_vector)
const = 0;
72 class Manager :
public Plugins::ManagerBase<Interface<dim>>,
public SimulatorAccess<dim>
82 const Point<dim> &position,
83 const Tensor<1,dim> &normal_vector)
const;
101 const std::map<types::boundary_id, std::pair<std::string,std::vector<std::string>>> &
102 get_active_boundary_traction_names ()
const;
117 const std::map<types::boundary_id,std::vector<std::unique_ptr<BoundaryTraction::Interface<dim>>>> &
118 get_active_boundary_traction_conditions ()
const;
124 const std::set<types::boundary_id> &
125 get_prescribed_boundary_traction_indicators ()
const;
133 const std::vector<types::boundary_id> &
134 get_active_plugin_boundary_indicators()
const;
147 get_component_mask(
const types::boundary_id boundary_id)
const;
184 <<
"Could not find entry <" 186 <<
"> among the names of registered boundary traction objects.");
206 register_boundary_traction (
const std::string &name,
207 const std::string &description,
208 void (*declare_parameters_function) (ParameterHandler &),
209 std::unique_ptr<Interface<dim>> (*factory_function) ());
274 std::unique_ptr<Interface<dim>>
319 #define ASPECT_REGISTER_BOUNDARY_TRACTION_MODEL(classname,name,description) \ 320 template class classname<2>; \ 321 template class classname<3>; \ 322 namespace ASPECT_REGISTER_BOUNDARY_TRACTION_MODEL_ ## classname \ 324 aspect::internal::Plugins::RegisterHelper<aspect::BoundaryTraction::Interface<2>,classname<2>> \ 325 dummy_ ## classname ## _2d (&aspect::BoundaryTraction::Manager<2>::register_boundary_traction, \ 326 name, description); \ 327 aspect::internal::Plugins::RegisterHelper<aspect::BoundaryTraction::Interface<3>,classname<3>> \ 328 dummy_ ## classname ## _3d (&aspect::BoundaryTraction::Manager<3>::register_boundary_traction, \ 329 name, description); \ virtual void parse_parameters(ParameterHandler &prm)
std::vector< ComponentMask > component_masks
std::unique_ptr< Interface< dim > > create_boundary_traction(const std::string &name)
void write_plugin_graph(std::ostream &output_stream)
std::map< types::boundary_id, std::pair< std::string, std::vector< std::string > > > boundary_traction_indicators
std::map< types::boundary_id, std::vector< std::unique_ptr< BoundaryTraction::Interface< dim > > > > boundary_traction_objects
std::vector< types::boundary_id > boundary_indicators
std::set< types::boundary_id > prescribed_traction_boundary_indicators
static void declare_parameters(ParameterHandler &prm)
virtual Tensor< 1, dim > boundary_traction(const types::boundary_id boundary_indicator, const Point< dim > &position, const Tensor< 1, dim > &normal_vector) const =0
DeclException1(ProbabilityFunctionNegative, Point< dim >,<< "Your probability density function in the particle generator " "returned a negative probability density for the following position: "<< arg1<< ". Please check your function expression.")