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

ScalarHybridScheme.cpp

Blame
  • ScalarHybridScheme.cpp 70.50 KiB
    #include <scheme/ScalarHybridScheme.hpp>
    
    #include <scheme/DiscreteFunctionP0.hpp>
    #include <scheme/DiscreteFunctionUtils.hpp>
    
    class ScalarHybridSchemeHandler::IScalarHybridScheme
    {
     public:
      virtual std::tuple<std::shared_ptr<const IDiscreteFunction>, std::shared_ptr<const IDiscreteFunction>> getSolution()
        const = 0;
    
      // virtual std::shared_ptr<const IDiscreteFunction> getSolution() const = 0;
    
      IScalarHybridScheme()          = default;
      virtual ~IScalarHybridScheme() = default;
    };
    
    template <size_t Dimension>
    class ScalarHybridSchemeHandler::ScalarHybridScheme : public ScalarHybridSchemeHandler::IScalarHybridScheme
    {
     private:
      using ConnectivityType = Connectivity<Dimension>;
      using MeshType         = Mesh<ConnectivityType>;
      using MeshDataType     = MeshData<Dimension>;
    
      std::shared_ptr<const DiscreteFunctionP0<Dimension, double>> m_cell_temperature;
      std::shared_ptr<const DiscreteFunctionP0<Dimension, double>> m_node_temperature;
      //  std::shared_ptr<const DiscreteFunctionP0<Dimension, double>> m_solution;
    
      class DirichletBoundaryCondition
      {
       private:
        const Array<const double> m_node_value_list;
        const Array<const double> m_face_value_list;
        const Array<const FaceId> m_face_list;
        const Array<const NodeId> m_node_list;
    
       public:
        const Array<const NodeId>&
        nodeList() const
        {
          return m_node_list;
        }
    
        const Array<const FaceId>&
        faceList() const
        {
          return m_face_list;
        }
    
        const Array<const double>&
        nodeValueList() const
        {
          return m_node_value_list;
        }
    
        const Array<const double>&
        faceValueList() const
        {
          return m_face_value_list;
        }
    
        DirichletBoundaryCondition(const Array<const FaceId>& face_list,
                                   const Array<const NodeId>& node_list,
                                   const Array<const double>& node_value_list,
                                   const Array<const double>& face_value_list)
          : m_node_value_list{node_value_list},
            m_face_value_list{face_value_list},
            m_face_list{face_list},
            m_node_list{node_list}