Skip to content
Snippets Groups Projects
Select Git revision
  • 63712a3882514fae70007e6eb8f7ced773d7c241
  • develop default protected
  • feature/advection
  • feature/composite-scheme-other-fluxes
  • origin/stage/bouguettaia
  • save_clemence
  • feature/local-dt-fsi
  • feature/variational-hydro
  • feature/gmsh-reader
  • feature/reconstruction
  • feature/kinetic-schemes
  • feature/composite-scheme-sources
  • feature/serraille
  • feature/composite-scheme
  • hyperplastic
  • feature/polynomials
  • feature/gks
  • feature/implicit-solver-o2
  • feature/coupling_module
  • feature/implicit-solver
  • feature/merge-local-dt-fsi
  • v0.5.0 protected
  • v0.4.1 protected
  • v0.4.0 protected
  • v0.3.0 protected
  • v0.2.0 protected
  • v0.1.0 protected
  • Kidder
  • v0.0.4 protected
  • v0.0.3 protected
  • v0.0.2 protected
  • v0 protected
  • v0.0.1 protected
33 results

NoSplitting.hpp

Blame
  • Connectivity3D.hpp 14.99 KiB
    #ifndef CONNECTIVITY_3D_HPP
    #define CONNECTIVITY_3D_HPP
    
    #include <Kokkos_Core.hpp>
    #include <PastisAssert.hpp>
    #include <TinyVector.hpp>
    
    #include <ConnectivityUtils.hpp>
    #include <vector>
    #include <map>
    #include <unordered_map>
    #include <algorithm>
    
    #include <RefId.hpp>
    #include <RefNodeList.hpp>
    #include <RefFaceList.hpp>
    
    #include <tuple>
    
    class Connectivity3D
    {
    public:
      static constexpr size_t dimension = 3;
    
      ConnectivityMatrix m_cell_to_node_matrix;
    
      ConnectivityMatrix m_cell_to_face_matrix;
      ConnectivityMatrixShort m_cell_to_face_is_reversed_matrix;
    
      ConnectivityMatrix m_face_to_cell_matrix;
      ConnectivityMatrixShort m_face_to_cell_local_face_matrix;
      ConnectivityMatrix m_face_to_node_matrix;
    
      ConnectivityMatrix m_node_to_cell_matrix;
      ConnectivityMatrixShort m_node_to_cell_local_node_matrix;
    
    private:
      std::vector<RefFaceList> m_ref_face_list;
      std::vector<RefNodeList> m_ref_node_list;
    
      Kokkos::View<double*> m_inv_cell_nb_nodes;
    
      Kokkos::View<const unsigned short*> m_node_nb_faces;
      Kokkos::View<const unsigned int**> m_node_faces;
    
      size_t m_max_nb_node_per_cell;
      size_t m_max_nb_face_per_cell;
      size_t m_max_nb_node_per_face;
    
      class Face
      {
       public:
        friend struct Hash;
        struct Hash {
          size_t operator()(const Face& f) const
          {
            size_t hash = 0;
            for (size_t i=0; i<f.m_node_id_list.size(); ++i) {
              hash ^= std::hash<unsigned int>()(f.m_node_id_list[i]) >> i;
            }
            return hash;
          }
        };
       private:
        bool m_reversed;
        std::vector<unsigned int> m_node_id_list;
    
       public:
        friend std::ostream& operator<<(std::ostream& os, const Face& f)
        {