Robustness improvement
This commit is contained in:
parent
64b1dbc341
commit
3ae0021235
1 changed files with 5 additions and 15 deletions
|
@ -317,24 +317,14 @@ vector eigenValues(const symmTensor& t)
|
|||
|
||||
// If there is a zero root
|
||||
if (mag(c) < SMALL)
|
||||
// if (mag(c) < 1.0e-100)
|
||||
{
|
||||
scalar disc = sqr(a) - 4*b;
|
||||
const scalar disc = Foam::max(sqr(a) - 4*b, 0.0);
|
||||
|
||||
if (disc >= -SMALL)
|
||||
{
|
||||
scalar q = -0.5*sqrt(max(scalar(0), disc));
|
||||
scalar q = -0.5*sqrt(max(scalar(0), disc));
|
||||
|
||||
i = 0;
|
||||
ii = -0.5*a + q;
|
||||
iii = -0.5*a - q;
|
||||
}
|
||||
else
|
||||
{
|
||||
FatalErrorIn("eigenValues(const tensor&)")
|
||||
<< "zero and complex eigenvalues in tensor: " << t
|
||||
<< abort(FatalError);
|
||||
}
|
||||
i = 0;
|
||||
ii = -0.5*a + q;
|
||||
iii = -0.5*a - q;
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
Reference in a new issue