mirror of
https://gitlab.com/libeigen/eigen.git
synced 2024-12-15 07:10:37 +08:00
Fix infinite loop in sparselu
This commit is contained in:
parent
0508af4287
commit
cd606bbc94
@ -70,7 +70,7 @@ Index SparseLUImpl<Scalar,Index>::expand(VectorType& vec, Index& length, Index
|
|||||||
if(num_expansions == 0 || keep_prev)
|
if(num_expansions == 0 || keep_prev)
|
||||||
new_len = length ; // First time allocate requested
|
new_len = length ; // First time allocate requested
|
||||||
else
|
else
|
||||||
new_len = Index(alpha * length);
|
new_len = (std::max)(length+1,Index(alpha * length));
|
||||||
|
|
||||||
VectorType old_vec; // Temporary vector to hold the previous values
|
VectorType old_vec; // Temporary vector to hold the previous values
|
||||||
if (nbElts > 0 )
|
if (nbElts > 0 )
|
||||||
@ -107,7 +107,7 @@ Index SparseLUImpl<Scalar,Index>::expand(VectorType& vec, Index& length, Index
|
|||||||
do
|
do
|
||||||
{
|
{
|
||||||
alpha = (alpha + 1)/2;
|
alpha = (alpha + 1)/2;
|
||||||
new_len = Index(alpha * length);
|
new_len = (std::max)(length+1,Index(alpha * length));
|
||||||
#ifdef EIGEN_EXCEPTIONS
|
#ifdef EIGEN_EXCEPTIONS
|
||||||
try
|
try
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user