StabilizationUtils: remove pointless bool return values

use return values instead of out-params
This commit is contained in:
Arne Morten Kvarving 2023-10-16 11:05:01 +02:00
parent e4e61a9b74
commit 32d7f01872
3 changed files with 39 additions and 47 deletions

View File

@ -43,51 +43,48 @@ double getTauPt (double dt, double mu, const Vector& U,
{
double Gnorm2 = G.norm2();
Gnorm2 *= Gnorm2;
return 1.0/ sqrt(Ct/pow(dt,2) + U.dot(G*U) + Cl*mu*mu*Gnorm2);
return 1.0 / sqrt(Ct/pow(dt,2) + U.dot(G*U) + Cl*mu*mu*Gnorm2);
}
bool getTauNSPt (double dt, double mu, const Vector& U,
const Matrix& G, double &tauM, double& tauC,
const double Ct, const double Cl)
std::pair<double,double>
getTauNSPt (double dt, double mu, const Vector& U,
const Matrix& G, const double Ct, const double Cl)
{
tauM = getTauPt(dt,mu,U,G,Ct,Cl);
tauC = 1.0/(tauM*G.trace());
return true;
double tauM = getTauPt(dt,mu,U,G,Ct,Cl);
double tauC = 1.0 / (tauM*G.trace());
return {tauM, tauC};
}
bool getTauNSALEPt (double dt, double mu, const Vector& U,
const Matrix& G, double & tauM, double& tauC,
const double Ct, const double Cl)
std::pair<double,double>
getTauNSALEPt (double dt, double mu, const Vector& U,
const Matrix& G,
const double Ct, const double Cl)
{
tauM = getTauPt(dt,mu,U,G,Ct,Cl);
double tauM = getTauPt(dt,mu,U,G,Ct,Cl);
double tauC = tauM*(U.dot(U));
tauC = tauM*(U.dot(U));
return true;
return {tauM, tauC};
}
bool getTauPtJac (const Vector& U, const Matrix& G,
const double tauM, Vector& tauMjac)
Vector getTauPtJac (const Vector& U, const Matrix& G,
const double tauM)
{
tauMjac = -pow(tauM,3)*G*U;
return true;
return -pow(tauM,3)*G*U;
}
bool getTauNSPtJac (const Vector& U, const Matrix& G,
const double tauM, const double& tauC,
Vector& tauMjac, Vector& tauCjac)
std::pair<Vector,Vector>
getTauNSPtJac (const Vector& U, const Matrix& G,
const double tauM, const double& tauC)
{
if (!getTauPtJac(U, G, tauM, tauMjac))
return false;
Vector tauMjac = getTauPtJac(U, G, tauM);
Vector tauCjac = (-tauC/tauM) * tauMjac;
tauCjac = (-tauC/tauM) * tauMjac;
return true;
return {tauMjac, tauCjac};
}
}

View File

@ -40,45 +40,40 @@ namespace StabilizationUtils {
//! \param[in] mu Diffusion/viscosity parameter
//! \param[in] U Velocity vector
//! \param[in] G The G matrix
//! \param[out] tauM Stabilization parameter for momentum
//! \param[out] tauC Stabilization parameter for continuity
//! \param[in] Ct VMS parameter
//! \param[in] Cl VMS parameter
//! \details Stabilization parameters in integration point
bool getTauNSPt(double dt, double mu, const Vector& U, const Matrix& G,
double& tauM, double& tauC,
const double Ct = 2.0, const double Cl = 36.0);
//! \return Stabilization parameters in integration point
std::pair<double,double>
getTauNSPt(double dt, double mu, const Vector& U, const Matrix& G,
const double Ct = 2.0, const double Cl = 36.0);
//! \brief Computes stabilization parameters for Navier-Stokes equations.
//! \param[in] dt The timestep size
//! \param[in] mu Diffusion/viscosity parameter
//! \param[in] U Velocity vector
//! \param[in] G The G matrix
//! \param[out] tauM Stabilization parameter for momentum
//! \param[out] tauC Stabilization parameter for continuity
//! \param[in] Ct VMS parameter
//! \param[in] Cl VMS parameter
//! \details Stabilization parameters in integration point
bool getTauNSALEPt(double dt, double mu, const Vector& U, const Matrix& G,
double& tauM, double& tauC,
const double Ct = 2.0, const double Cl = 36.0);
//! \return Stabilization parameters in integration point
std::pair<double,double>
getTauNSALEPt(double dt, double mu, const Vector& U, const Matrix& G,
const double Ct = 2.0, const double Cl = 36.0);
//! \brief Computes variation of stability parameters with respect to velocity.
//! \param[in] U Velocity vector
//! \param[in] G The G matrix
//! \param[in] tauM Stabilization parameter for momentum
//! \param[out] tauMjac Variation of tauM with respect to U
bool getTauPtJac(const Vector& U, const Matrix& G, const double tauM, Vector& tauMjac);
Vector getTauPtJac(const Vector& U, const Matrix& G,
const double tauM);
//! \brief Computes variation of stability parameters with respect to velocity.
//! \param[in] U Velocity vector
//! \param[in] G The G matrix
//! \param[in] tauM Stabilization parameter for momentum
//! \param[in] tauC Stabilization parameter for continuity
//! \param[out] tauMjac Variation of tauM with respect to U
//! \param[out] tauCjac Variation of tauC with respect to U
bool getTauNSPtJac(const Vector& U, const Matrix& G, const double tauM,
const double& tauC, Vector& tauMjac, Vector& tauCjac);
std::pair<Vector,Vector>
getTauNSPtJac(const Vector& U, const Matrix& G,
const double tauM, const double& tauC);
}
#endif

View File

@ -67,7 +67,7 @@ TEST(TestStabilizationUtils, GetTauNSPt)
utl::getGmat(J, &du[0], G);
double tauM, tauC;
ASSERT_TRUE(StabilizationUtils::getTauNSPt(0.1, 0.3, U, G, tauM, tauC));
std::tie(tauM,tauC) = StabilizationUtils::getTauNSPt(0.1, 0.3, U, G);
ASSERT_FLOAT_EQ(tauM, 0.016634906);
ASSERT_FLOAT_EQ(tauC, 1.87858);
}
@ -85,7 +85,7 @@ TEST(TestStabilizationUtils, GetTauNSALEPt)
utl::getGmat(J, &du[0], G);
double tauM, tauC;
ASSERT_TRUE(StabilizationUtils::getTauNSALEPt(0.1, 0.3, U, G, tauM, tauC));
std::tie(tauM,tauC) = StabilizationUtils::getTauNSALEPt(0.1, 0.3, U, G);
ASSERT_FLOAT_EQ(tauM, 0.016634906);
ASSERT_FLOAT_EQ(tauC, 0.049904719);
}