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

AcousticSolver.cpp

Blame
  • test_Polynomial.cpp 5.36 KiB
    #include <catch2/catch_test_macros.hpp>
    
    #include <Kokkos_Core.hpp>
    
    #include <utils/PugsAssert.hpp>
    #include <utils/Types.hpp>
    
    #include <algebra/TinyMatrix.hpp>
    #include <analysis/Polynomial.hpp>
    
    // Instantiate to ensure full coverage is performed
    template class Polynomial<0>;
    template class Polynomial<1>;
    template class Polynomial<2>;
    template class Polynomial<3>;
    template class Polynomial<4>;
    template class Polynomial<5>;
    
    // clazy:excludeall=non-pod-global-static
    
    TEST_CASE("Polynomial", "[analysis]")
    {
      SECTION("construction")
      {
        REQUIRE_NOTHROW(Polynomial<2>{TinyVector<3>{2, 3, 4}});
      }
      SECTION("degree")
      {
        Polynomial<2> P(TinyVector<3>{2, 3, 4});
        REQUIRE(P.degree() == 2);
      }
      SECTION("equality")
      {
        Polynomial<2> P(TinyVector<3>{2, 3, 4});
        Polynomial<2> Q(TinyVector<3>{2, 3, 4});
        Polynomial<2> S(TinyVector<3>{2, 3, 5});
    
        REQUIRE(P == Q);
        REQUIRE(P != S);
      }
      SECTION("addition")
      {
        Polynomial<2> P(TinyVector<3>{2, 3, 4});
        Polynomial<2> Q(TinyVector<3>{-1, -3, 2});
        Polynomial<2> S(TinyVector<3>{1, 0, 6});
        Polynomial<3> T(TinyVector<4>{0, 3, 1, -2});
        Polynomial<3> U(TinyVector<4>{2, 6, 5, -2});
        REQUIRE(S == (P + Q));
        REQUIRE((T + P) == U);
      }
      SECTION("opposed")
      {
        Polynomial<2> P(TinyVector<3>{2, 3, 4});
        Polynomial<2> Q = -P;
        REQUIRE(Q == Polynomial<2>(TinyVector<3>{-2, -3, -4}));
      }
      SECTION("difference")
      {
        Polynomial<2> P(TinyVector<3>{2, 3, 4});
        Polynomial<2> Q(TinyVector<3>{3, 4, 5});
        Polynomial<2> D(TinyVector<3>{-1, -1, -1});
        REQUIRE(D == (P - Q));
        Polynomial<3> R(TinyVector<4>{2, 3, 4, 1});
        REQUIRE(D == (P - Q));
        REQUIRE((P - R) == Polynomial<3>(TinyVector<4>{0, 0, 0, -1}));
        R -= P;
        REQUIRE(R == Polynomial<3>(TinyVector<4>{0, 0, 0, 1}));
      }
      SECTION("product_by_scalar")
      {