21 #ifndef _aspect_particle_property_interface_h 22 #define _aspect_particle_property_interface_h 31 #include <deal.II/particles/particle.h> 32 #include <deal.II/particles/particle_handler.h> 33 #include <deal.II/particles/property_pool.h> 34 #include <deal.II/fe/fe_update_flags.h> 44 using namespace ::Particles;
65 std::vector<small_vector<Tensor<1,dim>,50>>
gradients;
137 fieldname_exists(
const std::string &name)
const;
143 get_field_index_by_name(
const std::string &name)
const;
149 get_field_name_by_index(
const unsigned int field_index)
const;
156 get_position_by_field_name(
const std::string &name)
const;
163 get_components_by_field_name(
const std::string &name)
const;
171 get_position_by_field_index(
const unsigned int field_index)
const;
178 get_components_by_field_index(
const unsigned int field_index)
const;
186 get_position_by_plugin_index(
const unsigned int plugin_index)
const;
193 get_components_by_plugin_index(
const unsigned int plugin_index)
const;
200 get_fields_by_plugin_index(
const unsigned int plugin_index)
const;
206 std::vector<std::string>
207 get_property_names()
const;
225 n_components()
const;
361 initialize_one_particle_property (
const Point<dim> &position,
362 std::vector<double> &particle_properties)
const;
387 typename ParticleHandler<dim>::particle_iterator_range &particles)
const;
422 update_particle_property (
const unsigned int data_position,
424 const std::vector<Tensor<1,dim>> &
gradients,
425 typename ParticleHandler<dim>::particle_iterator &particle)
const;
442 need_update ()
const;
466 get_update_flags (
const unsigned int component)
const;
482 get_needed_update_flags ()
const;
500 late_initialization_mode ()
const;
511 advection_field_for_boundary_initialization(
const unsigned int property_component)
const;
527 std::vector<std::pair<std::string, unsigned int>>
528 get_property_information()
const = 0;
535 set_data_position (
const unsigned int data_position);
542 get_data_position ()
const;
572 initialize_one_particle_property (
const Point<dim> &position,
573 std::vector<double> &particle_properties)
const override;
582 std::vector<std::pair<std::string, unsigned int>>
583 get_property_information()
const override;
590 parse_parameters (ParameterHandler &prm)
override;
624 initialize_one_particle (
typename ParticleHandler<dim>::particle_iterator &particle)
const;
633 initialize_late_particle (
const Point<dim> &particle_location,
634 const ParticleHandler<dim> &particle_handler,
636 const typename parallel::distributed::Triangulation<dim>::active_cell_iterator &cell =
typename parallel::distributed::Triangulation<dim>::active_cell_iterator())
const;
652 typename ParticleHandler<dim>::particle_iterator_range &particles)
const;
666 need_update ()
const;
681 std::vector<UpdateFlags>
682 get_update_flags ()
const;
689 plugin_name_exists(
const std::string &name)
const;
701 check_plugin_order(
const std::string &first,
const std::string &second)
const;
706 unsigned int get_plugin_index_by_name(
const std::string &name)
const;
722 template <
typename ParticlePropertyType,
723 typename =
typename std::enable_if_t<std::is_base_of<Interface<dim>,ParticlePropertyType>::value>>
726 has_matching_property ()
const;
744 template <
typename ParticlePropertyType,
745 typename =
typename std::enable_if_t<std::is_base_of<Interface<dim>,ParticlePropertyType>::value>>
747 const ParticlePropertyType &
748 get_matching_property ()
const;
758 get_n_property_components ()
const;
769 get_particle_size ()
const;
778 get_data_info()
const;
800 register_particle_property (
const std::string &name,
801 const std::string &description,
802 void (*declare_parameters_function) (ParameterHandler &),
817 parse_parameters (ParameterHandler &prm)
override;
824 void set_particle_manager_index(
unsigned int particle_manager_index);
856 template <
typename ParticlePropertyType,
typename>
861 return this->
template has_matching_active_plugin<ParticlePropertyType>();
866 template <
typename ParticlePropertyType,
typename>
868 const ParticlePropertyType &
871 return this->
template get_matching_active_plugin<ParticlePropertyType>();
881 #define ASPECT_REGISTER_PARTICLE_PROPERTY(classname,name,description) \ 882 template class classname<2>; \ 883 template class classname<3>; \ 884 namespace ASPECT_REGISTER_PARTICLE_PROPERTY_ ## classname \ 886 aspect::internal::Plugins::RegisterHelper<aspect::Particle::Property::Interface<2>,classname<2>> \ 887 dummy_ ## classname ## _2d (&aspect::Particle::Property::Manager<2>::register_particle_property, \ 888 name, description); \ 889 aspect::internal::Plugins::RegisterHelper<aspect::Particle::Property::Interface<3>,classname<3>> \ 890 dummy_ ## classname ## _3d (&aspect::Particle::Property::Manager<3>::register_particle_property, \ 891 name, description); \ std::vector< unsigned int > position_per_field
DoFHandler< dim >::active_cell_iterator current_cell
DEAL_II_DEPRECATED const ParticlePropertyType & get_matching_property() const
ParticlePropertyInformation property_information
std::vector< small_vector< Tensor< 1, dim >, 50 > > gradients
std::vector< unsigned int > components_per_plugin
void write_plugin_graph(std::ostream &output_stream)
InitializationModeForLateParticles
std::vector< std::string > field_names
std::vector< unsigned int > components_per_field
unsigned int n_integrator_properties
unsigned int number_of_components
unsigned int number_of_plugins
std::vector< small_vector< double, 50 > > solution
std::vector< unsigned int > fields_per_plugin
unsigned int particle_manager_index
DEAL_II_DEPRECATED bool has_matching_property() const
unsigned int number_of_fields
std::vector< unsigned int > position_per_plugin
unsigned int data_position
void declare_parameters(ParameterHandler &prm)