Xyst test code coverage report
Current view: top level - Physics - Zalesak.cpp (source / functions) Hit Total Coverage
Commit: b2278901c7a653f0d92b235cc98ed02988a87738 Lines: 215 216 99.5 %
Date: 2024-12-18 15:54:33 Functions: 4 4 100.0 %
Legend: Lines: hit not hit | Branches: + taken - not taken # not executed Branches: 128 222 57.7 %

           Branch data     Line data    Source code
       1                 :            : // *****************************************************************************
       2                 :            : /*!
       3                 :            :   \file      src/Physics/Zalesak.cpp
       4                 :            :   \copyright 2012-2015 J. Bakosi,
       5                 :            :              2016-2018 Los Alamos National Security, LLC.,
       6                 :            :              2019-2021 Triad National Security, LLC.,
       7                 :            :              2022-2024 J. Bakosi
       8                 :            :              All rights reserved. See the LICENSE file for details.
       9                 :            :   \brief     Zalesak, FCT limiting for edge-based continuous Galerkin
      10                 :            : */
      11                 :            : // *****************************************************************************
      12                 :            : 
      13                 :            : #include "Vector.hpp"
      14                 :            : #include "Around.hpp"
      15                 :            : #include "DerivedData.hpp"
      16                 :            : #include "EOS.hpp"
      17                 :            : #include "Zalesak.hpp"
      18                 :            : #include "Problems.hpp"
      19                 :            : #include "InciterConfig.hpp"
      20                 :            : 
      21                 :            : namespace inciter {
      22                 :            : 
      23                 :            : extern ctr::Config g_cfg;
      24                 :            : 
      25                 :            : } // ::inciter
      26                 :            : 
      27                 :            : namespace zalesak {
      28                 :            : 
      29                 :            : using inciter::g_cfg;
      30                 :            : 
      31                 :            : static void
      32                 :    9794900 : advedge( const tk::real supint[],
      33                 :            :          const tk::Fields& U,
      34                 :            :          const std::array< std::vector< tk::real >, 3 >& coord,
      35                 :            :          tk::real t,
      36                 :            :          tk::real dt,
      37                 :            :          const std::vector< tk::real >& tp,
      38                 :            :          const std::vector< tk::real >& dtp,
      39                 :            :          std::size_t p,
      40                 :            :          std::size_t q,
      41                 :            :          tk::real f[],
      42                 :            :          const std::function< std::vector< tk::real >
      43                 :            :                  ( tk::real, tk::real, tk::real, tk::real ) >& src )
      44                 :            : // *****************************************************************************
      45                 :            : //! Compute advection fluxes on a single edge
      46                 :            : //! \param[in] supint Edge integral
      47                 :            : //! \param[in] U Solution vector to read conserved variables from
      48                 :            : //! \param[in] coord Mesh node coordinates
      49                 :            : //! \param[in] t Physical time
      50                 :            : //! \param[in] dt Physical time step size
      51                 :            : //! \param[in] tp Phisical time step size for each mesh node (if steady state)
      52                 :            : //! \param[in] dtp Time step size for each mesh node (if steady state)
      53                 :            : //! \param[in] p Left node index of edge
      54                 :            : //! \param[in] q Right node index of edge
      55                 :            : //! \param[in,out] f Flux computed
      56                 :            : //! \param[in] src Function to call to evaluate a problem-sepcific source term
      57                 :            : // *****************************************************************************
      58                 :            : {
      59                 :   19589800 :   const auto steady = g_cfg.get< tag::steady >();
      60                 :    9794900 :   const auto ncomp = U.nprop();
      61                 :    9794900 :   const auto& x = coord[0];
      62                 :    9794900 :   const auto& y = coord[1];
      63                 :    9794900 :   const auto& z = coord[2];
      64                 :            : 
      65                 :            :   // edge vector
      66                 :    9794900 :   auto dx = x[p] - x[q];
      67                 :    9794900 :   auto dy = y[p] - y[q];
      68                 :    9794900 :   auto dz = z[p] - z[q];
      69                 :    9794900 :   auto dl = dx*dx + dy*dy + dz*dz;
      70                 :    9794900 :   dx /= dl;
      71                 :    9794900 :   dy /= dl;
      72                 :    9794900 :   dz /= dl;
      73                 :            : 
      74                 :            :   // left state
      75         [ +  - ]:    9794900 :   auto rL  = U(p,0);
      76         [ +  - ]:    9794900 :   auto ruL = U(p,1);
      77         [ +  - ]:    9794900 :   auto rvL = U(p,2);
      78         [ +  - ]:    9794900 :   auto rwL = U(p,3);
      79         [ +  - ]:    9794900 :   auto reL = U(p,4);
      80                 :    9794900 :   auto pL = eos::pressure( reL - 0.5*(ruL*ruL + rvL*rvL + rwL*rwL)/rL );
      81                 :    9794900 :   auto dnL = (ruL*dx + rvL*dy + rwL*dz)/rL;
      82                 :            : 
      83                 :            :   // right state
      84         [ +  - ]:    9794900 :   auto rR  = U(q,0);
      85         [ +  - ]:    9794900 :   auto ruR = U(q,1);
      86         [ +  - ]:    9794900 :   auto rvR = U(q,2);
      87         [ +  - ]:    9794900 :   auto rwR = U(q,3);
      88         [ +  - ]:    9794900 :   auto reR = U(q,4);
      89                 :    9794900 :   auto pR = eos::pressure( reR - 0.5*(ruR*ruR + rvR*rvR + rwR*rwR)/rR );
      90                 :    9794900 :   auto dnR = (ruR*dx + rvR*dy + rwR*dz)/rR;
      91                 :            : 
      92                 :    9794900 :   auto nx = supint[0];
      93                 :    9794900 :   auto ny = supint[1];
      94                 :    9794900 :   auto nz = supint[2];
      95                 :            : 
      96                 :            :   #if defined(__clang__)
      97                 :            :     #pragma clang diagnostic push
      98                 :            :     #pragma clang diagnostic ignored "-Wvla"
      99                 :            :     #pragma clang diagnostic ignored "-Wvla-extension"
     100                 :            :   #elif defined(STRICT_GNUC)
     101                 :            :     #pragma GCC diagnostic push
     102                 :            :     #pragma GCC diagnostic ignored "-Wvla"
     103                 :            :   #endif
     104                 :            : 
     105                 :            :   // Taylor-Galerkin first half step
     106                 :            : 
     107         [ +  + ]:    9794900 :   if (steady) dt = (dtp[p] + dtp[q])/2.0;
     108                 :            : 
     109                 :    9794900 :   tk::real ue[ncomp];
     110                 :            : 
     111                 :            :   // flow
     112                 :    9794900 :   auto dp = pL - pR;
     113                 :    9794900 :   ue[0] = 0.5*(rL + rR - dt*(rL*dnL - rR*dnR));
     114                 :    9794900 :   ue[1] = 0.5*(ruL + ruR - dt*(ruL*dnL - ruR*dnR + dp*dx));
     115                 :    9794900 :   ue[2] = 0.5*(rvL + rvR - dt*(rvL*dnL - rvR*dnR + dp*dy));
     116                 :    9794900 :   ue[3] = 0.5*(rwL + rwR - dt*(rwL*dnL - rwR*dnR + dp*dz));
     117                 :    9794900 :   ue[4] = 0.5*(reL + reR - dt*((reL+pL)*dnL - (reR+pR)*dnR));
     118                 :            :   // scalar
     119         [ +  + ]:   10192880 :   for (std::size_t c=5; c<ncomp; ++c) {
     120 [ +  - ][ +  - ]:     397980 :     ue[c] = 0.5*(U(p,c) + U(q,c) - dt*(U(p,c)*dnL - U(q,c)*dnR));
         [ +  - ][ +  - ]
     121                 :            :   }
     122                 :            : 
     123                 :            :   // source
     124         [ +  + ]:    9794900 :   if (src) {
     125         [ -  + ]:     423100 :     if (steady) t = (tp[p] + tp[q])/2.0;
     126                 :     423100 :     auto coef = dt/4.0;
     127         [ +  - ]:     423100 :     auto sL = src( x[p], y[p], z[p], t );
     128         [ +  - ]:     423100 :     auto sR = src( x[q], y[q], z[q], t );
     129                 :            :     // flow + scalar
     130         [ +  + ]:    2936580 :     for (std::size_t c=0; c<ncomp; ++c) {
     131                 :    2513480 :       ue[c] += coef*(sL[c] + sR[c]);
     132                 :            :     }
     133                 :     423100 :   }
     134                 :            : 
     135                 :            :   // Taylor-Galerkin second half step
     136                 :            : 
     137                 :    9794900 :   auto rh  = ue[0];
     138                 :    9794900 :   auto ruh = ue[1];
     139                 :    9794900 :   auto rvh = ue[2];
     140                 :    9794900 :   auto rwh = ue[3];
     141                 :    9794900 :   auto reh = ue[4];
     142                 :    9794900 :   auto ph = eos::pressure( reh - 0.5*(ruh*ruh + rvh*rvh + rwh*rwh)/rh );
     143                 :    9794900 :   auto vn = (ruh*nx + rvh*ny + rwh*nz)/rh;
     144                 :            : 
     145                 :            :   // flow
     146                 :    9794900 :   f[0] = 2.0*rh*vn;
     147                 :    9794900 :   f[1] = 2.0*(ruh*vn + ph*nx);
     148                 :    9794900 :   f[2] = 2.0*(rvh*vn + ph*ny);
     149                 :    9794900 :   f[3] = 2.0*(rwh*vn + ph*nz);
     150                 :    9794900 :   f[4] = 2.0*(reh + ph)*vn;
     151                 :            :   // scalar
     152         [ +  + ]:   10192880 :   for (std::size_t c=5; c<ncomp; ++c) {
     153                 :     397980 :     f[c] = 2.0*ue[c]*vn;
     154                 :            :   }
     155                 :            : 
     156                 :            :   // source
     157         [ +  + ]:    9794900 :   if (src) {
     158                 :     423100 :     auto coef = -5.0/3.0*supint[3];
     159                 :     423100 :     auto xe = (x[p] + x[q])/2.0;
     160                 :     423100 :     auto ye = (y[p] + y[q])/2.0;
     161                 :     423100 :     auto ze = (z[p] + z[q])/2.0;
     162         [ +  - ]:     423100 :     auto se = src( xe, ye, ze, t+dt/2.0 );
     163                 :            :     // flow + scalar
     164         [ +  + ]:    2936580 :     for (std::size_t c=0; c<ncomp; ++c) {
     165                 :    2513480 :       f[ncomp+c] = coef*se[c];
     166                 :            :     }
     167                 :     423100 :   }
     168                 :            : 
     169                 :            :   // artificial viscosity
     170                 :            : 
     171                 :    9794900 :   const auto stab2 = g_cfg.get< tag::stab2 >();
     172         [ +  + ]:    9794900 :   if (!stab2) return;
     173                 :            : 
     174                 :    5838840 :   auto stab2coef = g_cfg.get< tag::stab2coef >();
     175                 :    5838840 :   auto vnL = (ruL*nx + rvL*ny + rwL*nz)/rL;
     176                 :    5838840 :   auto vnR = (ruR*nx + rvR*ny + rwR*nz)/rR;
     177                 :    5838840 :   auto len = tk::length( nx, ny, nz );
     178                 :    5838840 :   auto cL = eos::soundspeed( std::max(rL,1.0e-8), std::max(pL,0.0) );
     179                 :    5838840 :   auto cR = eos::soundspeed( std::max(rR,1.0e-8), std::max(pR,0.0) );
     180                 :    5838840 :   auto sl = std::abs(vnL) + cL*len;
     181                 :    5838840 :   auto sr = std::abs(vnR) + cR*len;
     182                 :    5838840 :   auto fw = stab2coef * std::max( sl, sr );
     183                 :            : 
     184                 :            :   // flow
     185                 :    5838840 :   f[0] -= fw*(rL - rR);
     186                 :    5838840 :   f[1] -= fw*(ruL - ruR);
     187                 :    5838840 :   f[2] -= fw*(rvL - rvR);
     188                 :    5838840 :   f[3] -= fw*(rwL - rwR);
     189                 :    5838840 :   f[4] -= fw*(reL - reR);
     190                 :            :   // scalar
     191         [ -  + ]:    5838840 :   for (std::size_t c=5; c<ncomp; ++c) {
     192 [ -  - ][ -  - ]:          0 :     f[c] -= fw*(U(p,c) - U(q,c));
     193                 :            :   }
     194                 :            : 
     195                 :            :   #if defined(__clang__)
     196                 :            :     #pragma clang diagnostic pop
     197                 :            :   #elif defined(STRICT_GNUC)
     198                 :            :     #pragma GCC diagnostic pop
     199                 :            :   #endif
     200                 :    9794900 : }
     201                 :            : 
     202                 :            : static void
     203                 :       5365 : advdom( const std::array< std::vector< std::size_t >, 3 >& dsupedge,
     204                 :            :         const std::array< std::vector< tk::real >, 3 >& dsupint,
     205                 :            :         const std::array< std::vector< tk::real >, 3 >& coord,
     206                 :            :         tk::real t,
     207                 :            :         tk::real dt,
     208                 :            :         const std::vector< tk::real >& tp,
     209                 :            :         const std::vector< tk::real >& dtp,
     210                 :            :         const tk::Fields& U,
     211                 :            :         // cppcheck-suppress constParameter
     212                 :            :         tk::Fields& R )
     213                 :            : // *****************************************************************************
     214                 :            : //! Compute domain-edge integrals for advection
     215                 :            : //! \param[in] dsupedge Domain superedges
     216                 :            : //! \param[in] dsupint Domain superedge integrals
     217                 :            : //! \param[in] coord Mesh node coordinates
     218                 :            : //! \param[in] t Physical time
     219                 :            : //! \param[in] dt Physical time step size
     220                 :            : //! \param[in] tp Phisical time step size for each mesh node (if steady state)
     221                 :            : //! \param[in] dtp Time step size for each mesh node (if steady state)
     222                 :            : //! \param[in] U Solution vector at recent time step
     223                 :            : //! \param[in,out] R Right-hand side vector
     224                 :            : // *****************************************************************************
     225                 :            : {
     226                 :       5365 :   auto ncomp = U.nprop();
     227         [ +  - ]:       5365 :   auto src = problems::SRC();
     228                 :            : 
     229                 :            :   #if defined(__clang__)
     230                 :            :     #pragma clang diagnostic push
     231                 :            :     #pragma clang diagnostic ignored "-Wvla"
     232                 :            :     #pragma clang diagnostic ignored "-Wvla-extension"
     233                 :            :   #elif defined(STRICT_GNUC)
     234                 :            :     #pragma GCC diagnostic push
     235                 :            :     #pragma GCC diagnostic ignored "-Wvla"
     236                 :            :   #endif
     237                 :            : 
     238                 :            :   // domain edge contributions: tetrahedron superedges
     239         [ +  + ]:     988615 :   for (std::size_t e=0; e<dsupedge[0].size()/4; ++e) {
     240                 :     983250 :     const auto N = dsupedge[0].data() + e*4;
     241                 :     983250 :     tk::real f[6][ncomp*2];
     242                 :     983250 :     const auto d = dsupint[0].data();
     243         [ +  - ]:     983250 :     advedge( d+(e*6+0)*4, U, coord, t, dt, tp, dtp, N[0], N[1], f[0], src );
     244         [ +  - ]:     983250 :     advedge( d+(e*6+1)*4, U, coord, t, dt, tp, dtp, N[1], N[2], f[1], src );
     245         [ +  - ]:     983250 :     advedge( d+(e*6+2)*4, U, coord, t, dt, tp, dtp, N[2], N[0], f[2], src );
     246         [ +  - ]:     983250 :     advedge( d+(e*6+3)*4, U, coord, t, dt, tp, dtp, N[0], N[3], f[3], src );
     247         [ +  - ]:     983250 :     advedge( d+(e*6+4)*4, U, coord, t, dt, tp, dtp, N[1], N[3], f[4], src );
     248         [ +  - ]:     983250 :     advedge( d+(e*6+5)*4, U, coord, t, dt, tp, dtp, N[2], N[3], f[5], src );
     249         [ +  + ]:    5932460 :     for (std::size_t c=0; c<ncomp; ++c) {
     250 [ +  - ][ +  - ]:    4949210 :       R(N[0],c) = R(N[0],c) - f[0][c] + f[2][c] - f[3][c];
     251 [ +  - ][ +  - ]:    4949210 :       R(N[1],c) = R(N[1],c) + f[0][c] - f[1][c] - f[4][c];
     252 [ +  - ][ +  - ]:    4949210 :       R(N[2],c) = R(N[2],c) + f[1][c] - f[2][c] - f[5][c];
     253 [ +  - ][ +  - ]:    4949210 :       R(N[3],c) = R(N[3],c) + f[3][c] + f[4][c] + f[5][c];
     254         [ +  + ]:    4949210 :       if (src) {
     255                 :     208060 :         auto nc = ncomp + c;
     256         [ +  - ]:     208060 :         R(N[0],c) += f[0][nc] + f[2][nc] + f[3][nc];
     257         [ +  - ]:     208060 :         R(N[1],c) += f[0][nc] + f[1][nc] + f[4][nc];
     258         [ +  - ]:     208060 :         R(N[2],c) += f[1][nc] + f[2][nc] + f[5][nc];
     259         [ +  - ]:     208060 :         R(N[3],c) += f[3][nc] + f[4][nc] + f[5][nc];
     260                 :            :       }
     261                 :            :     }
     262                 :     983250 :   }
     263                 :            : 
     264                 :            :   // domain edge contributions: triangle superedges
     265         [ +  + ]:     544685 :   for (std::size_t e=0; e<dsupedge[1].size()/3; ++e) {
     266                 :     539320 :     const auto N = dsupedge[1].data() + e*3;
     267                 :     539320 :     tk::real f[3][ncomp*2];
     268                 :     539320 :     const auto d = dsupint[1].data();
     269         [ +  - ]:     539320 :     advedge( d+(e*3+0)*4, U, coord, t, dt, tp, dtp, N[0], N[1], f[0], src );
     270         [ +  - ]:     539320 :     advedge( d+(e*3+1)*4, U, coord, t, dt, tp, dtp, N[1], N[2], f[1], src );
     271         [ +  - ]:     539320 :     advedge( d+(e*3+2)*4, U, coord, t, dt, tp, dtp, N[2], N[0], f[2], src );
     272         [ +  + ]:    3266800 :     for (std::size_t c=0; c<ncomp; ++c) {
     273 [ +  - ][ +  - ]:    2727480 :       R(N[0],c) = R(N[0],c) - f[0][c] + f[2][c];
     274 [ +  - ][ +  - ]:    2727480 :       R(N[1],c) = R(N[1],c) + f[0][c] - f[1][c];
     275 [ +  - ][ +  - ]:    2727480 :       R(N[2],c) = R(N[2],c) + f[1][c] - f[2][c];
     276         [ +  + ]:    2727480 :       if (src) {
     277                 :     195830 :         auto nc = ncomp + c;
     278         [ +  - ]:     195830 :         R(N[0],c) += f[0][nc] + f[2][nc];
     279         [ +  - ]:     195830 :         R(N[1],c) += f[0][nc] + f[1][nc];
     280         [ +  - ]:     195830 :         R(N[2],c) += f[1][nc] + f[2][nc];
     281                 :            :       }
     282                 :            :     }
     283                 :     539320 :   }
     284                 :            : 
     285                 :            :   // domain edge contributions: edges
     286         [ +  + ]:    2282805 :   for (std::size_t e=0; e<dsupedge[2].size()/2; ++e) {
     287                 :    2277440 :     const auto N = dsupedge[2].data() + e*2;
     288                 :    2277440 :     tk::real f[ncomp*2];
     289                 :    2277440 :     const auto d = dsupint[2].data();
     290         [ +  - ]:    2277440 :     advedge( d+e*4, U, coord, t, dt, tp, dtp, N[0], N[1], f, src );
     291         [ +  + ]:   13772220 :     for (std::size_t c=0; c<ncomp; ++c) {
     292         [ +  - ]:   11494780 :       R(N[0],c) -= f[c];
     293         [ +  - ]:   11494780 :       R(N[1],c) += f[c];
     294         [ +  + ]:   11494780 :       if (src) {
     295                 :     677630 :         auto nc = ncomp + c;
     296         [ +  - ]:     677630 :         R(N[0],c) += f[nc];
     297         [ +  - ]:     677630 :         R(N[1],c) += f[nc];
     298                 :            :       }
     299                 :            :     }
     300                 :    2277440 :   }
     301                 :            : 
     302                 :            :   #if defined(__clang__)
     303                 :            :     #pragma clang diagnostic pop
     304                 :            :   #elif defined(STRICT_GNUC)
     305                 :            :     #pragma GCC diagnostic pop
     306                 :            :   #endif
     307                 :       5365 : }
     308                 :            : 
     309                 :            : static void
     310                 :       5365 : advbnd( const std::vector< std::size_t >& triinpoel,
     311                 :            :         const std::array< std::vector< tk::real >, 3 >& coord,
     312                 :            :         const std::vector< std::uint8_t >& besym,
     313                 :            :         const tk::Fields& U,
     314                 :            :         tk::Fields& R )
     315                 :            : // *****************************************************************************
     316                 :            : //! Compute boundary integrals for advection
     317                 :            : //! \param[in] triinpoel Boundary face connectivity
     318                 :            : //! \param[in] coord Mesh node coordinates
     319                 :            : //! \param[in] besym Boundary element symmetry BC flags
     320                 :            : //! \param[in] U Solution vector at recent time step
     321                 :            : //! \param[in,out] R Right-hand side vector
     322                 :            : // *****************************************************************************
     323                 :            : {
     324                 :       5365 :   auto ncomp = U.nprop();
     325                 :            : 
     326                 :       5365 :   const auto& x = coord[0];
     327                 :       5365 :   const auto& y = coord[1];
     328                 :       5365 :   const auto& z = coord[2];
     329                 :            : 
     330                 :            :   #if defined(__clang__)
     331                 :            :     #pragma clang diagnostic push
     332                 :            :     #pragma clang diagnostic ignored "-Wvla"
     333                 :            :     #pragma clang diagnostic ignored "-Wvla-extension"
     334                 :            :   #elif defined(STRICT_GNUC)
     335                 :            :     #pragma GCC diagnostic push
     336                 :            :     #pragma GCC diagnostic ignored "-Wvla"
     337                 :            :   #endif
     338                 :            : 
     339         [ +  + ]:     974720 :   for (std::size_t e=0; e<triinpoel.size()/3; ++e) {
     340                 :    1938710 :     const auto N = triinpoel.data() + e*3;
     341                 :            : 
     342         [ +  - ]:     969355 :     auto rA  = U(N[0],0);
     343         [ +  - ]:     969355 :     auto ruA = U(N[0],1);
     344         [ +  - ]:     969355 :     auto rvA = U(N[0],2);
     345         [ +  - ]:     969355 :     auto rwA = U(N[0],3);
     346         [ +  - ]:     969355 :     auto reA = U(N[0],4);
     347                 :            : 
     348         [ +  - ]:     969355 :     auto rB  = U(N[1],0);
     349         [ +  - ]:     969355 :     auto ruB = U(N[1],1);
     350         [ +  - ]:     969355 :     auto rvB = U(N[1],2);
     351         [ +  - ]:     969355 :     auto rwB = U(N[1],3);
     352         [ +  - ]:     969355 :     auto reB = U(N[1],4);
     353                 :            : 
     354         [ +  - ]:     969355 :     auto rC  = U(N[2],0);
     355         [ +  - ]:     969355 :     auto ruC = U(N[2],1);
     356         [ +  - ]:     969355 :     auto rvC = U(N[2],2);
     357         [ +  - ]:     969355 :     auto rwC = U(N[2],3);
     358         [ +  - ]:     969355 :     auto reC = U(N[2],4);
     359                 :            : 
     360                 :            :     const std::array< tk::real, 3 >
     361                 :     969355 :       ba{ x[N[1]]-x[N[0]], y[N[1]]-y[N[0]], z[N[1]]-z[N[0]] },
     362                 :     969355 :       ca{ x[N[2]]-x[N[0]], y[N[2]]-y[N[0]], z[N[2]]-z[N[0]] };
     363                 :     969355 :     auto [nx,ny,nz] = tk::cross( ba, ca );      // 2A
     364                 :     969355 :     nx /= 12.0;
     365                 :     969355 :     ny /= 12.0;
     366                 :     969355 :     nz /= 12.0;
     367                 :            : 
     368                 :     969355 :     tk::real p, vn, f[ncomp][3];
     369                 :     969355 :     const auto sym = besym.data() + e*3;
     370                 :            : 
     371                 :     969355 :     p = eos::pressure( reA - 0.5*(ruA*ruA + rvA*rvA + rwA*rwA)/rA );
     372         [ +  + ]:     969355 :     vn = sym[0] ? 0.0 : (nx*ruA + ny*rvA + nz*rwA)/rA;
     373                 :            :     // flow
     374                 :     969355 :     f[0][0] = rA*vn;
     375                 :     969355 :     f[1][0] = ruA*vn + p*nx;
     376                 :     969355 :     f[2][0] = rvA*vn + p*ny;
     377                 :     969355 :     f[3][0] = rwA*vn + p*nz;
     378                 :     969355 :     f[4][0] = (reA + p)*vn;
     379                 :            :     // scalar
     380 [ +  - ][ +  + ]:    1113235 :     for (std::size_t c=5; c<ncomp; ++c) f[c][0] = U(N[0],c)*vn;
     381                 :            : 
     382                 :     969355 :     p = eos::pressure( reB - 0.5*(ruB*ruB + rvB*rvB + rwB*rwB)/rB );
     383         [ +  + ]:     969355 :     vn = sym[1] ? 0.0 : (nx*ruB + ny*rvB + nz*rwB)/rB;
     384                 :            :     // flow
     385                 :     969355 :     f[0][1] = rB*vn;
     386                 :     969355 :     f[1][1] = ruB*vn + p*nx;
     387                 :     969355 :     f[2][1] = rvB*vn + p*ny;
     388                 :     969355 :     f[3][1] = rwB*vn + p*nz;
     389                 :     969355 :     f[4][1] = (reB + p)*vn;
     390                 :            :     // scalar
     391 [ +  - ][ +  + ]:    1113235 :     for (std::size_t c=5; c<ncomp; ++c) f[c][1] = U(N[1],c)*vn;
     392                 :            : 
     393                 :     969355 :     p = eos::pressure( reC - 0.5*(ruC*ruC + rvC*rvC + rwC*rwC)/rC );
     394         [ +  + ]:     969355 :     vn = sym[2] ? 0.0 : (nx*ruC + ny*rvC + nz*rwC)/rC;
     395                 :            :     // flow
     396                 :     969355 :     f[0][2] = rC*vn;
     397                 :     969355 :     f[1][2] = ruC*vn + p*nx;
     398                 :     969355 :     f[2][2] = rvC*vn + p*ny;
     399                 :     969355 :     f[3][2] = rwC*vn + p*nz;
     400                 :     969355 :     f[4][2] = (reC + p)*vn;
     401                 :            :     // scalar
     402 [ +  - ][ +  + ]:    1113235 :     for (std::size_t c=5; c<ncomp; ++c) f[c][2] = U(N[2],c)*vn;
     403                 :            : 
     404         [ +  + ]:    5960010 :     for (std::size_t c=0; c<ncomp; ++c) {
     405                 :    4990655 :       auto fab = (f[c][0] + f[c][1])/4.0;
     406                 :    4990655 :       auto fbc = (f[c][1] + f[c][2])/4.0;
     407                 :    4990655 :       auto fca = (f[c][2] + f[c][0])/4.0;
     408         [ +  - ]:    4990655 :       R(N[0],c) += fab + fca + f[c][0];
     409         [ +  - ]:    4990655 :       R(N[1],c) += fab + fbc + f[c][1];
     410         [ +  - ]:    4990655 :       R(N[2],c) += fbc + fca + f[c][2];
     411                 :            :     }
     412                 :     969355 :   }
     413                 :            : 
     414                 :            :   #if defined(__clang__)
     415                 :            :     #pragma clang diagnostic pop
     416                 :            :   #elif defined(STRICT_GNUC)
     417                 :            :     #pragma GCC diagnostic pop
     418                 :            :   #endif
     419                 :       5365 : }
     420                 :            : 
     421                 :            : void
     422                 :       5365 : rhs( const std::array< std::vector< std::size_t >, 3 >& dsupedge,
     423                 :            :      const std::array< std::vector< tk::real >, 3 >& dsupint,
     424                 :            :      const std::array< std::vector< tk::real >, 3 >& coord,
     425                 :            :      const std::vector< std::size_t >& triinpoel,
     426                 :            :      const std::vector< std::uint8_t >& besym,
     427                 :            :      tk::real t,
     428                 :            :      tk::real dt,
     429                 :            :      const std::vector< tk::real >& tp,
     430                 :            :      const std::vector< tk::real >& dtp,
     431                 :            :      const tk::Fields& U,
     432                 :            :      tk::Fields& R )
     433                 :            : // *****************************************************************************
     434                 :            : //  Compute right hand side
     435                 :            : //! \param[in] dsupedge Domain superedges
     436                 :            : //! \param[in] dsupint Domain superedge integrals
     437                 :            : //! \param[in] coord Mesh node coordinates
     438                 :            : //! \param[in] triinpoel Boundary face connectivity
     439                 :            : //! \param[in] besym Boundary element symmetry BC flags
     440                 :            : //! \param[in] t Physical time
     441                 :            : //! \param[in] dt Physical time size
     442                 :            : //! \param[in] tp Phisical time step size for each mesh node (if steady state)
     443                 :            : //! \param[in] dtp Time step size for each mesh node (if steady state)
     444                 :            : //! \param[in] U Unknowns/solution vector in mesh nodes
     445                 :            : //! \param[in,out] R Right-hand side vector computed
     446                 :            : // *****************************************************************************
     447                 :            : {
     448 [ -  + ][ -  - ]:       5365 :   Assert( U.nunk() == coord[0].size(), "Number of unknowns in solution "
         [ -  - ][ -  - ]
     449                 :            :           "vector at recent time step incorrect" );
     450 [ -  + ][ -  - ]:       5365 :   Assert( R.nunk() == coord[0].size(),
         [ -  - ][ -  - ]
     451                 :            :           "Number of unknowns and/or number of components in right-hand "
     452                 :            :           "side vector incorrect" );
     453                 :            : 
     454                 :       5365 :   R.fill( 0.0 );
     455                 :       5365 :   advdom( dsupedge, dsupint, coord, t, dt, tp, dtp, U, R );
     456                 :       5365 :   advbnd( triinpoel, coord, besym, U, R );
     457                 :       5365 : }
     458                 :            : 
     459                 :            : } // zalesak::

Generated by: LCOV version 1.16