22 #ifndef _aspect_utilities_h 23 #define _aspect_utilities_h 29 #include <deal.II/base/point.h> 30 #include <deal.II/base/conditional_ostream.h> 31 #include <deal.II/base/table_indices.h> 32 #include <deal.II/base/function_lib.h> 33 #include <deal.II/dofs/dof_handler.h> 34 #include <deal.II/fe/component_mask.h> 43 template <
int dim>
class SimulatorAccess;
45 namespace GeometryModel
47 template <
int dim>
class Interface;
70 using namespace ::Utilities;
90 const std::string &id_text);
196 Options(
const std::vector<std::string> &list_of_required_keys,
197 const std::string &property_name)
199 list_of_allowed_keys(list_of_required_keys),
200 list_of_required_keys(list_of_required_keys),
201 property_name(property_name),
202 allow_multiple_values_per_key(false),
203 allow_missing_keys(false),
204 store_values_per_key(false),
205 check_values_per_key(false),
316 const std::vector<std::string> &list_of_keys,
317 const bool expects_background_field,
318 const std::string &property_name,
319 const bool allow_multiple_values_per_key =
false,
320 const std::unique_ptr<std::vector<unsigned int>> &n_values_per_key =
nullptr,
321 const bool allow_missing_keys =
false);
336 template <
typename T>
339 const unsigned int n_rows,
340 const unsigned int n_columns,
341 const std::string &property_name);
356 std::vector<std::string>
367 const ComponentMask &component_mask);
391 const parallel::distributed::Triangulation<dim> &triangulation,
392 const Point<dim> &point,
393 const MPI_Comm mpi_communicator);
396 namespace Coordinates
405 std::array<double,dim>
419 std::array<double,dim>
439 const ::Point<dim> &position);
450 const double semi_major_axis_a,
451 const double eccentricity);
460 const double semi_major_axis_a,
461 const double eccentricity);
481 const ::Point<2> &point);
491 const ::Point<2> &point);
502 const ::Point<2> &point);
512 std::array<Tensor<1,dim>,dim-1>
521 const double rotation_angle);
531 const Tensor<1,3> &point_two);
604 bool fexists(
const std::string &filename);
619 bool fexists(
const std::string &filename,
620 const MPI_Comm comm);
650 const MPI_Comm comm);
666 const std::string &file_content,
667 const MPI_Comm comm);
683 mkdirp(std::string pathname,
const mode_t mode = 0755);
720 void set_points(
const std::vector<double> &x,
721 const std::vector<double> &y,
722 const bool cubic_spline =
true,
723 const bool monotone_spline =
false);
727 double operator() (
double x)
const;
741 std::vector<double> m_a, m_b, m_c,
m_y;
755 const unsigned int q,
756 std::vector<double> &composition_values_at_q_point);
792 std::vector<unsigned int>
825 const std::vector<double> &values,
854 template <
typename T>
856 const std::vector<double> &weights,
857 const std::vector<double> &values,
858 const std::vector<T> &derivatives,
894 const SymmetricTensor<2,dim> &dviscosities_dstrain_rate,
895 const double SPD_safety_factor);
947 double operator() (
const double x,
const double y)
const;
953 bool operator== (
const operation op)
const;
1005 std::array<double,dim> &get_coordinates();
1011 const std::array<double,dim> &get_coordinates()
const;
1017 std::array<double,dim-1> get_surface_coordinates()
const;
1023 double get_depth_coordinate()
const;
1057 template <
int dim,
typename VectorType>
1060 const DoFHandler<dim> &dof_handler,
1061 const unsigned int component_index,
1062 const Quadrature<dim> &quadrature,
1064 const typename DoFHandler<dim>::active_cell_iterator &,
1065 const std::vector<Point<dim>> &,
1066 std::vector<double> &)> &
function,
1067 VectorType &vec_result);
1093 const std::string &function_name,
1094 const std::vector<SolverControl> &solver_controls,
1095 const std::exception &exc,
1096 const MPI_Comm mpi_communicator,
1097 const std::string &output_filename =
"");
1120 const std::function<Tensor<1,dim> (
const Point<dim> &)> &function_object);
1129 double value (
const Point<dim> &p,
1130 const unsigned int component = 0)
const override;
1141 void vector_value (
const Point<dim> &p,
1142 Vector<double> &values)
const override;
1149 const std::function<Tensor<1,dim> (
const Point<dim> &)> function_object;
1158 template <
typename T>
1160 std::vector<std::size_t>
1170 template <
typename T>
1174 const std::vector<T> &vector,
1175 const std::vector<std::size_t> &permutation_vector);
1189 std::vector<Tensor<2,3>>
1191 const std::vector<Tensor<2,3>> &rotation_matrices,
1192 const unsigned int n_output_matrices,
1193 std::mt19937 &random_number_generator);
1225 template <
typename T>
1229 const unsigned int N,
1230 const std::string &id_text)
1232 if (values.size() == 1)
1234 return std::vector<T> (N, values[0]);
1236 else if (values.size() == N)
1244 ExcMessage(
"Length of " + id_text +
" list must be " +
1251 return std::vector<T> ();
1257 const unsigned int q,
1258 std::vector<double> &composition_values_at_q_point)
1260 Assert(q<composition_values.size(), ExcInternalError());
1261 Assert(composition_values_at_q_point.size() > 0,
1262 ExcInternalError());
1264 for (
unsigned int k=0; k < composition_values_at_q_point.size(); ++k)
1266 Assert(composition_values[k].size() == composition_values_at_q_point.size(),
1267 ExcInternalError());
1268 composition_values_at_q_point[k] = composition_values[k][q];
1272 template <
typename T>
1274 std::vector<std::size_t>
1277 std::vector<std::size_t> p(vector.size());
1278 std::iota(p.begin(), p.end(), 0);
1279 std::sort(p.begin(), p.end(),
1280 [&](std::size_t i, std::size_t j)
1282 return vector[i] < vector[j];
1287 template <
typename T>
1291 const std::vector<T> &vector,
1292 const std::vector<std::size_t> &permutation_vector)
1294 std::vector<T> sorted_vec(vector.size());
1295 std::transform(permutation_vector.begin(), permutation_vector.end(), sorted_vec.begin(),
1313 template <
int dim,
class Iterator>
1315 SymmetricTensor<2,dim>
1316 to_symmetric_tensor(
const Iterator begin,
1319 AssertDimension(std::distance(begin, end), (SymmetricTensor<2,dim>::n_independent_components));
1322 SymmetricTensor<2,dim> output;
1324 Iterator next = begin;
1325 for (
unsigned int i=0; i < SymmetricTensor<2,dim>::n_independent_components; ++i, ++next)
1326 output[SymmetricTensor<2,dim>::unrolled_to_component_indices(i)] = *next;
1335 template <
int dim,
class Iterator>
1338 unroll_symmetric_tensor_into_array(
const SymmetricTensor<2,dim> &tensor,
1339 const Iterator begin,
1342 AssertDimension(std::distance(begin, end), (SymmetricTensor<2,dim>::n_independent_components));
1345 Iterator next = begin;
1346 for (
unsigned int i=0; i < SymmetricTensor<2,dim>::n_independent_components; ++i, ++next)
1347 *next = tensor[SymmetricTensor<2,dim>::unrolled_to_component_indices(i)];
1353 SymmetricTensor<4,3>
1354 rotate_full_stiffness_tensor(
const Tensor<2,3> &rotation_tensor,
const SymmetricTensor<4,3> &input_tensor);
1360 SymmetricTensor<2,6>
1361 rotate_voigt_stiffness_matrix(
const Tensor<2,3> &rotation_tensor,
const SymmetricTensor<2,6> &input_tensor);
1367 SymmetricTensor<2,6>
1368 to_voigt_stiffness_matrix(
const SymmetricTensor<4,3> &input_tensor);
1374 SymmetricTensor<4,3>
1375 to_full_stiffness_tensor(
const SymmetricTensor<2,6> &input_tensor);
1382 to_voigt_stiffness_vector(
const SymmetricTensor<2,6> &input_tensor);
1388 SymmetricTensor<2,6>
1389 to_voigt_stiffness_matrix(
const Tensor<1,21> &input_tensor);
1396 to_voigt_stiffness_vector(
const SymmetricTensor<4,3> &input);
1404 const Tensor<dim,dim> &levi_civita();
1408 const Tensor<3,3> &levi_civita<3>();
T derivative_of_weighted_p_norm_average(const double averaged_parameter, const std::vector< double > &weights, const std::vector< double > &values, const std::vector< T > &derivatives, const double p)
std::string read_and_distribute_file_content(const std::string &filename, const MPI_Comm comm)
Point< dim > convert_array_to_point(const std::array< double, dim > &array)
std::vector< double > m_y
Tensor< 1, dim > spherical_to_cartesian_vector(const Tensor< 1, dim > &spherical_vector, const ::Point< dim > &position)
Tensor< 2, 3 > compute_rotation_matrix_for_slice(const Tensor< 1, 3 > &point_one, const Tensor< 1, 3 > &point_two)
std::vector< std::string > list_of_required_keys
double weighted_p_norm_average(const std::vector< double > &weights, const std::vector< double > &values, const double p)
double distance_to_line(const std::array<::Point< 2 >, 2 > &point_list, const ::Point< 2 > &point)
std::vector< std::string > expand_dimensional_variable_names(const std::vector< std::string > &var_declarations)
std::array< double, dim > coordinates
void collect_and_write_file_content(const std::string &filename, const std::string &file_content, const MPI_Comm comm)
double compute_spd_factor(const double eta, const SymmetricTensor< 2, dim > &strain_rate, const SymmetricTensor< 2, dim > &dviscosities_dstrain_rate, const double SPD_safety_factor)
Table< 2, T > parse_input_table(const std::string &input_string, const unsigned int n_rows, const unsigned int n_columns, const std::string &property_name)
std::pair< double, double > real_spherical_harmonic(unsigned int l, unsigned int m, double theta, double phi)
std::vector< double > m_x
std::string expand_ASPECT_SOURCE_DIR(const std::string &location)
Tensor< 2, 3 > zxz_euler_angles_to_rotation_matrix(const double phi1, const double theta, const double phi2)
std::array< Tensor< 1, dim >, dim-1 > orthogonal_vectors(const Tensor< 1, dim > &v)
std::vector< Tensor< 2, 3 > > rotation_matrices_random_draw_volume_weighting(const std::vector< double > &volume_fractions, const std::vector< Tensor< 2, 3 >> &rotation_matrices, const unsigned int n_output_matrices, std::mt19937 &random_number_generator)
std::string to_string(const Newton::Parameters::Stabilization preconditioner_stabilization)
std::array< double, dim > WGS84_coordinates(const ::Point< dim > &position)
::Point< 3 > ellipsoidal_to_cartesian_coordinates(const std::array< double, 3 > &phi_theta_d, const double semi_major_axis_a, const double eccentricity)
void project_cellwise(const Mapping< dim > &mapping, const DoFHandler< dim > &dof_handler, const unsigned int component_index, const Quadrature< dim > &quadrature, const std::function< void(const typename DoFHandler< dim >::active_cell_iterator &, const std::vector< Point< dim >> &, std::vector< double > &)> &function, VectorType &vec_result)
bool point_is_in_triangulation(const Mapping< dim > &mapping, const parallel::distributed::Triangulation< dim > &triangulation, const Point< dim > &point, const MPI_Comm mpi_communicator)
void throw_linear_solver_failure_exception(const std::string &solver_name, const std::string &function_name, const std::vector< SolverControl > &solver_controls, const std::exception &exc, const MPI_Comm mpi_communicator, const std::string &output_filename="")
bool polygon_contains_point(const std::vector< Point< 2 >> &point_list, const ::Point< 2 > &point)
bool check_values_per_key
int mkdirp(std::string pathname, const mode_t mode=0755)
Utilities::Coordinates::CoordinateSystem coordinate_system
void create_directory(const std::string &pathname, const MPI_Comm comm, const bool silent)
::Point< dim > spherical_to_cartesian_coordinates(const std::array< double, dim > &scoord)
std::string do_grouping() const override
std::vector< T > possibly_extend_from_1_to_N(const std::vector< T > &values, const unsigned int N, const std::string &id_text)
std::array< double, 3 > cartesian_to_ellipsoidal_coordinates(const ::Point< 3 > &position, const double semi_major_axis_a, const double eccentricity)
std::string property_name
Options(const std::vector< std::string > &list_of_required_keys, const std::string &property_name)
std::array< double, dim > convert_point_to_array(const Point< dim > &point)
std::vector< bool > string_to_bool(const std::vector< std::string > &s)
std::vector< Point< dim > > get_unit_support_points(const SimulatorAccess< dim > &simulator_access)
std::vector< T > apply_permutation(const std::vector< T > &vector, const std::vector< std::size_t > &permutation_vector)
IndexSet extract_locally_active_dofs_with_component(const DoFHandler< dim > &dof_handler, const ComponentMask &component_mask)
std::vector< unsigned int > n_values_per_key
std::vector< unsigned int > string_to_unsigned_int(const std::vector< std::string > &s)
DEAL_II_DEPRECATED std::vector< double > parse_map_to_double_array(const std::string &key_value_map, const std::vector< std::string > &list_of_keys, const bool expects_background_field, const std::string &property_name, const bool allow_multiple_values_per_key=false, const std::unique_ptr< std::vector< unsigned int >> &n_values_per_key=nullptr, const bool allow_missing_keys=false)
double wrap_angle(const double angle)
bool fexists(const std::string &filename, const MPI_Comm comm)
std::vector< Operator > create_model_operator_list(const std::vector< std::string > &operator_names)
bool store_values_per_key
double signed_distance_to_polygon(const std::vector< Point< 2 >> &point_list, const ::Point< 2 > &point)
std::string parenthesize_if_nonempty(const std::string &s)
std::array< double, 3 > zxz_euler_angles_from_rotation_matrix(const Tensor< 2, 3 > &rotation_matrix)
void extract_composition_values_at_q_point(const std::vector< std::vector< double >> &composition_values, const unsigned int q, std::vector< double > &composition_values_at_q_point)
const std::string get_model_operator_options()
char do_thousands_sep() const override
std::vector< std::string > list_of_allowed_keys
bool filename_is_url(const std::string &filename)
bool allow_multiple_values_per_key
SymmetricTensor< 2, dim > nth_basis_for_symmetric_tensors(const unsigned int k)
std::vector< std::size_t > compute_sorting_permutation(const std::vector< T > &vector)
CoordinateSystem string_to_coordinate_system(const std::string &)
std::array< double, dim > cartesian_to_spherical_coordinates(const ::Point< dim > &position)
bool has_unique_entries(const std::vector< std::string > &strings)
Tensor< 2, 3 > rotation_matrix_from_axis(const Tensor< 1, 3 > &rotation_axis, const double rotation_angle)