Reference documentation for deal.II version 9.1.0-pre
grid_reordering.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2000 - 2018 by the deal.II authors
4 //
5 // This file is part of the deal.II library.
6 //
7 // The deal.II library is free software; you can use it, redistribute
8 // it, and/or modify it under the terms of the GNU Lesser General
9 // Public License as published by the Free Software Foundation; either
10 // version 2.1 of the License, or (at your option) any later version.
11 // The full text of the license can be found in the file LICENSE.md at
12 // the top level directory of deal.II.
13 //
14 // ---------------------------------------------------------------------
15 
16 #ifndef dealii_grid_reordering_h
17 #define dealii_grid_reordering_h
18 
19 
20 #include <deal.II/base/config.h>
21 
22 #include <deal.II/grid/tria.h>
23 
24 #include <vector>
25 
26 DEAL_II_NAMESPACE_OPEN
27 
33  "The edges of the mesh are not consistently orientable.");
34 
35 
632 template <int dim, int spacedim = dim>
634 {
635 public:
650  static void
651  reorder_cells(std::vector<CellData<dim>> &original_cells,
652  const bool use_new_style_ordering = false);
653 
669  static void
671  const std::vector<Point<spacedim>> &all_vertices,
672  std::vector<CellData<dim>> & original_cells);
673 };
674 
675 
676 // declaration of explicit specializations
677 template <>
678 void
680  const std::vector<Point<2>> &all_vertices,
681  std::vector<CellData<2>> & cells);
682 
683 template <>
684 void
686  const std::vector<Point<3>> &all_vertices,
687  std::vector<CellData<2>> & cells);
688 
689 template <>
690 void
692  const std::vector<Point<3>> &all_vertices,
693  std::vector<CellData<3>> & cells);
694 
695 DEAL_II_NAMESPACE_CLOSE
696 
697 #endif
static void reorder_cells(std::vector< CellData< dim >> &original_cells, const bool use_new_style_ordering=false)
#define DeclExceptionMsg(Exception, defaulttext)
Definition: exceptions.h:397
static void invert_all_cells_of_negative_grid(const std::vector< Point< spacedim >> &all_vertices, std::vector< CellData< dim >> &original_cells)
static::ExceptionBase & ExcMeshNotOrientable()