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

ResumingData.cpp

Blame
  • PolynomialReconstruction.cpp 58.09 KiB
    #include <scheme/PolynomialReconstruction.hpp>
    
    #include <algebra/Givens.hpp>
    #include <algebra/ShrinkMatrixView.hpp>
    #include <algebra/ShrinkVectorView.hpp>
    #include <algebra/SmallMatrix.hpp>
    #include <analysis/GaussLegendreQuadratureDescriptor.hpp>
    #include <analysis/GaussQuadratureDescriptor.hpp>
    #include <analysis/QuadratureFormula.hpp>
    #include <analysis/QuadratureManager.hpp>
    #include <geometry/CubeTransformation.hpp>
    #include <geometry/LineTransformation.hpp>
    #include <geometry/PrismTransformation.hpp>
    #include <geometry/PyramidTransformation.hpp>
    #include <geometry/SquareTransformation.hpp>
    #include <geometry/TetrahedronTransformation.hpp>
    #include <geometry/TriangleTransformation.hpp>
    #include <mesh/MeshData.hpp>
    #include <mesh/MeshDataManager.hpp>
    #include <mesh/MeshFlatFaceBoundary.hpp>
    #include <mesh/NamedBoundaryDescriptor.hpp>
    #include <mesh/StencilManager.hpp>
    #include <scheme/DiscreteFunctionDPkVariant.hpp>
    #include <scheme/DiscreteFunctionUtils.hpp>
    #include <scheme/DiscreteFunctionVariant.hpp>
    
    template <size_t Dimension>
    PUGS_INLINE auto
    symmetrize_vector(const TinyVector<Dimension>& normal, const TinyVector<Dimension>& u)
    {
      return u - 2 * dot(u, normal) * normal;
    }
    
    template <size_t Dimension>
    PUGS_INLINE auto
    symmetrize_coordinates(const TinyVector<Dimension>& origin,
                           const TinyVector<Dimension>& normal,
                           const TinyVector<Dimension>& u)
    {
      return u - 2 * dot(u - origin, normal) * normal;
    }
    
    class PolynomialReconstruction::MutableDiscreteFunctionDPkVariant
    {
     public:
      using Variant = std::variant<DiscreteFunctionDPk<1, double>,
                                   DiscreteFunctionDPk<1, TinyVector<1>>,
                                   DiscreteFunctionDPk<1, TinyVector<2>>,
                                   DiscreteFunctionDPk<1, TinyVector<3>>,
                                   DiscreteFunctionDPk<1, TinyMatrix<1>>,
                                   DiscreteFunctionDPk<1, TinyMatrix<2>>,
                                   DiscreteFunctionDPk<1, TinyMatrix<3>>,
    
                                   DiscreteFunctionDPk<2, double>,
                                   DiscreteFunctionDPk<2, TinyVector<1>>,
                                   DiscreteFunctionDPk<2, TinyVector<2>>,
                                   DiscreteFunctionDPk<2, TinyVector<3>>,
                                   DiscreteFunctionDPk<2, TinyMatrix<1>>,
                                   DiscreteFunctionDPk<2, TinyMatrix<2>>,
                                   DiscreteFunctionDPk<2, TinyMatrix<3>>,
    
                                   DiscreteFunctionDPk<3, double>,
                                   DiscreteFunctionDPk<3, TinyVector<1>>,
                                   DiscreteFunctionDPk<3, TinyVector<2>>,
                                   DiscreteFunctionDPk<3, TinyVector<3>>,
                                   DiscreteFunctionDPk<3, TinyMatrix<1>>,
                                   DiscreteFunctionDPk<3, TinyMatrix<2>>,
                                   DiscreteFunctionDPk<3, TinyMatrix<3>>,
    
                                   DiscreteFunctionDPkVector<1, double>,