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

FunctionTable.hpp

Blame
  • Stephane Del Pino's avatar
    Stéphane Del Pino authored
    This is a concept proof. It requires many improvements:
    - code is crappy
    - only works for one kind of function (R^3->R^3 with a result defined
    as a list of 3 R)
    - no check is performed
    - execution context (necessary for multi-threading  is not properly
    defined)
    
    Also, one should define an handier way to define such mechanism
    6a15ee1c
    History
    FunctionTable.hpp 1.93 KiB
    #ifndef FUNCTION_TABLE_HPP
    #define FUNCTION_TABLE_HPP
    
    #include <language/ASTNode.hpp>
    #include <language/ASTNodeDataType.hpp>
    #include <language/DataVariant.hpp>
    #include <utils/PugsAssert.hpp>
    
    #include <pegtl/position.hpp>
    
    class FunctionDescriptor
    {
      std::unique_ptr<ASTNode> m_domain_mapping_node;
      std::unique_ptr<ASTNode> m_definition_node;
    
     public:
      auto&
      domainMappingNode() const
      {
        Assert(m_domain_mapping_node, "undefined domain mapping node");
        return *m_domain_mapping_node;
      }
    
      auto&
      definitionNode() const
      {
        Assert(m_definition_node, "undefined expression node");
        return *m_definition_node;
      }
    
      FunctionDescriptor& operator=(FunctionDescriptor&&) = default;
    
      FunctionDescriptor(std::unique_ptr<ASTNode>&& domain_mapping_node, std::unique_ptr<ASTNode>&& definition_node)
        : m_domain_mapping_node(std::move(domain_mapping_node)), m_definition_node(std::move(definition_node))
      {}
    
      FunctionDescriptor(FunctionDescriptor&&) = default;
      FunctionDescriptor()                     = default;
      ~FunctionDescriptor()                    = default;
    };
    
    class FunctionTable
    {
     private:
      std::vector<FunctionDescriptor> m_function_descriptor_list;
    
     public:
      PUGS_INLINE
      size_t
      size() const
      {
        return m_function_descriptor_list.size();
      }
    
      PUGS_INLINE
      FunctionDescriptor& operator[](size_t function_id)
      {
        Assert(function_id < m_function_descriptor_list.size());
        return m_function_descriptor_list[function_id];
      }
    
      PUGS_INLINE
      const FunctionDescriptor& operator[](size_t function_id) const
      {
        Assert(function_id < m_function_descriptor_list.size());
        return m_function_descriptor_list[function_id];
      }
    
      size_t
      add(FunctionDescriptor&& function_descriptor)
      {
        m_function_descriptor_list.emplace_back(std::move(function_descriptor));
        return m_function_descriptor_list.size() - 1;
      }
    
      FunctionTable()  = default;
      ~FunctionTable() = default;
    };
    
    #endif   // FUNCTION_TABLE_HPP