Skip to content
Snippets Groups Projects
Select Git revision
  • 091cb272fe098beea21f0cc345ca5e3cb20c4ee7
  • 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

MeshFaceBoundary.hpp

Blame
  • ConnectivityToMedianDualConnectivityDataMapper.hpp 8.42 KiB
    #ifndef CONNECTIVITY_TO_MEDIAN_DUAL_CONNECTIVITY_DATA_MAPPER_HPP
    #define CONNECTIVITY_TO_MEDIAN_DUAL_CONNECTIVITY_DATA_MAPPER_HPP
    
    #include <mesh/Connectivity.hpp>
    #include <mesh/IConnectivityToDualConnectivityDataMapper.hpp>
    #include <mesh/ItemIdToItemIdMap.hpp>
    #include <mesh/ItemValue.hpp>
    #include <utils/Array.hpp>
    #include <utils/PugsAssert.hpp>
    
    template <size_t Dimension>
    class ConnectivityToMedianDualConnectivityDataMapper : public IConnectivityToDualConnectivityDataMapper
    {
     private:
      const IConnectivity* m_primal_connectivity;
      const IConnectivity* m_dual_connectivity;
    
      ConstNodeIdToNodeIdMap m_primal_boundary_node_to_dual_node_map;
      ConstFaceIdToNodeIdMap m_primal_face_to_dual_node_map;
      ConstCellIdToNodeIdMap m_primal_cell_to_dual_node_map;
      ConstNodeIdToCellIdMap m_primal_node_to_dual_cell_map;
    
     public:
      template <typename OriginDataType1, typename OriginDataType2, typename OriginDataType3, typename DestinationDataType>
      void
      toDualNode(const NodeValue<OriginDataType1>& primal_node_value,
                 const FaceValue<OriginDataType2>& primal_face_value,
                 const CellValue<OriginDataType3>& primal_cell_value,
                 const NodeValue<DestinationDataType>& dual_node_value) const
      {
        static_assert(not std::is_const_v<DestinationDataType>, "destination data type must not be constant");
        static_assert(std::is_same_v<std::remove_const_t<OriginDataType1>, DestinationDataType>, "incompatible types");
        static_assert(std::is_same_v<std::remove_const_t<OriginDataType2>, DestinationDataType>, "incompatible types");
        static_assert(std::is_same_v<std::remove_const_t<OriginDataType3>, DestinationDataType>, "incompatible types");
    
        Assert(m_primal_connectivity == primal_cell_value.connectivity_ptr().get(),
               "unexpected connectivity for primal CellValue");
        Assert(m_primal_connectivity == primal_face_value.connectivity_ptr().get(),
               "unexpected connectivity for primal FaceValue");
        Assert(m_primal_connectivity == primal_node_value.connectivity_ptr().get(),
               "unexpected connectivity for primal NodeValue");
        Assert(m_dual_connectivity == dual_node_value.connectivity_ptr().get(),
               "unexpected connectivity for dual NodeValue");
    
        parallel_for(
          m_primal_boundary_node_to_dual_node_map.size(), PUGS_LAMBDA(size_t i) {
            const auto [primal_node_id, dual_node_id] = m_primal_boundary_node_to_dual_node_map[i];
    
            dual_node_value[dual_node_id] = primal_node_value[primal_node_id];
          });
    
        parallel_for(
          m_primal_face_to_dual_node_map.size(), PUGS_LAMBDA(size_t i) {
            const auto [primal_face_id, dual_node_id] = m_primal_face_to_dual_node_map[i];
    
            dual_node_value[dual_node_id] = primal_face_value[primal_face_id];
          });
    
        parallel_for(
          m_primal_cell_to_dual_node_map.size(), PUGS_LAMBDA(size_t i) {
            const auto [primal_cell_id, dual_node_id] = m_primal_cell_to_dual_node_map[i];
    
            dual_node_value[dual_node_id] = primal_cell_value[primal_cell_id];
          });
      }
    
      template <typename OriginDataType,
                typename DestinationDataType1,
                typename DestinationDataType2,
                typename DestinationDataType3>
      void
      fromDualNode(const NodeValue<OriginDataType>& dual_node_value,
                   const NodeValue<DestinationDataType1>& primal_node_value,
                   const FaceValue<DestinationDataType2>& primal_face_value,
                   const CellValue<DestinationDataType3>& primal_cell_value) const
      {
        static_assert(not std::is_const_v<DestinationDataType1>, "destination data type must not be constant");
        static_assert(not std::is_const_v<DestinationDataType2>, "destination data type must not be constant");
        static_assert(not std::is_const_v<DestinationDataType3>, "destination data type must not be constant");
        static_assert(std::is_same_v<std::remove_const_t<OriginDataType>, DestinationDataType1>, "incompatible types");
        static_assert(std::is_same_v<std::remove_const_t<OriginDataType>, DestinationDataType2>, "incompatible types");
        static_assert(std::is_same_v<std::remove_const_t<OriginDataType>, DestinationDataType3>, "incompatible types");
    
        Assert(m_primal_connectivity == primal_cell_value.connectivity_ptr().get(),
               "unexpected connectivity for primal CellValue");
        Assert(m_primal_connectivity == primal_face_value.connectivity_ptr().get(),
               "unexpected connectivity for primal FaceValue");
        Assert(m_primal_connectivity == primal_node_value.connectivity_ptr().get(),
               "unexpected connectivity for primal NodeValue");
        Assert(m_dual_connectivity == dual_node_value.connectivity_ptr().get(),
               "unexpected connectivity for dual NodeValue");
    
        parallel_for(
          m_primal_boundary_node_to_dual_node_map.size(), PUGS_LAMBDA(size_t i) {
            const auto [primal_node_id, dual_node_id] = m_primal_boundary_node_to_dual_node_map[i];
    
            primal_node_value[primal_node_id] = dual_node_value[dual_node_id];
          });
    
        parallel_for(
          m_primal_face_to_dual_node_map.size(), PUGS_LAMBDA(size_t i) {
            const auto [primal_face_id, dual_node_id] = m_primal_face_to_dual_node_map[i];
    
            primal_face_value[primal_face_id] = dual_node_value[dual_node_id];
          });
    
        parallel_for(
          m_primal_cell_to_dual_node_map.size(), PUGS_LAMBDA(size_t i) {
            const auto [primal_cell_id, dual_node_id] = m_primal_cell_to_dual_node_map[i];
    
            primal_cell_value[primal_cell_id] = dual_node_value[dual_node_id];
          });
      }
    
      template <typename OriginDataType, typename DestinationDataType>
      void
      toDualCell(const NodeValue<OriginDataType>& primal_node_value,
                 const CellValue<DestinationDataType>& dual_cell_value) const
      {
        static_assert(not std::is_const_v<DestinationDataType>, "destination data type must not be constant");
        static_assert(std::is_same_v<std::remove_const_t<OriginDataType>, DestinationDataType>, "incompatible types");
    
        Assert(m_primal_connectivity == primal_node_value.connectivity_ptr().get(),
               "unexpected connectivity for primal NodeValue");
        Assert(m_dual_connectivity == dual_cell_value.connectivity_ptr().get(),
               "unexpected connectivity for dual CellValue");
    
        parallel_for(
          m_primal_node_to_dual_cell_map.size(), PUGS_LAMBDA(size_t i) {
            const auto [primal_node_id, dual_cell_id] = m_primal_node_to_dual_cell_map[i];
    
            dual_cell_value[dual_cell_id] = primal_node_value[primal_node_id];
          });
      }
    
      template <typename OriginDataType, typename DestinationDataType>
      void
      fromDualCell(const CellValue<DestinationDataType>& dual_cell_value,
                   const NodeValue<OriginDataType>& primal_node_value) const
      {
        static_assert(not std::is_const_v<DestinationDataType>, "destination data type must not be constant");
        static_assert(std::is_same_v<std::remove_const_t<OriginDataType>, DestinationDataType>, "incompatible types");
    
        Assert(m_primal_connectivity == primal_node_value.connectivity_ptr().get(),
               "unexpected connectivity for primal NodeValue");
        Assert(m_dual_connectivity == dual_cell_value.connectivity_ptr().get(),
               "unexpected connectivity for dual CellValue");
    
        parallel_for(
          m_primal_node_to_dual_cell_map.size(), PUGS_LAMBDA(size_t i) {
            const auto [primal_face_id, dual_cell_id] = m_primal_node_to_dual_cell_map[i];
    
            primal_node_value[primal_face_id] = dual_cell_value[dual_cell_id];
          });
      }
    
      ConnectivityToMedianDualConnectivityDataMapper(const Connectivity<Dimension>& primal_connectivity,
                                                     const Connectivity<Dimension>& dual_connectivity,
                                                     const ConstNodeIdToNodeIdMap& primal_boundary_to_dual_node_map,
                                                     const ConstFaceIdToNodeIdMap& primal_face_to_dual_node_map,
                                                     const ConstCellIdToNodeIdMap& primal_cell_to_dual_node_map,
                                                     const ConstNodeIdToCellIdMap& primal_node_to_dual_cell_map)
        : m_primal_connectivity{&primal_connectivity},
          m_dual_connectivity{&dual_connectivity},
          m_primal_boundary_node_to_dual_node_map{primal_boundary_to_dual_node_map},
          m_primal_face_to_dual_node_map{primal_face_to_dual_node_map},
          m_primal_cell_to_dual_node_map{primal_cell_to_dual_node_map},
          m_primal_node_to_dual_cell_map{primal_node_to_dual_cell_map}
      {}
    };
    
    #endif   // CONNECTIVITY_TO_MEDIAN_DUAL_CONNECTIVITY_DATA_MAPPER_HPP