govert/RobustGeometry.NET

GrowExpansion() typo?

Opened this issue · 6 comments

By

for (eindex = 0; eindex < e.Length; eindex++)

did you mean

for (eindex = 0; eindex < elen; eindex++) ?

I know it's not used further. Doesn't affect anything else. I was just reading through the code to understand it better.

You mean in here?

public static int GrowExpansion(int elen, double[] e, double b, double[] h)
{
    double Q;
    int eindex;

    Q = b;
    for (eindex = 0; eindex < e.Length; eindex++)
    {
        TwoSum(Q, e[eindex], out Q, out h[eindex]);
    }
    h[eindex] = Q;
    return eindex + 1;
}

I believe not. e is an array, e.Length is the array length. for (eindex = 0; eindex < e.Length; eindex++) basically means for each element in the array.

update: I took a look at it. Turns out this is only used in the tests, and in the caller, elen is exactly e.Length:
var n = GrowExpansion_Checked(e.Length, e, b, h);

So the two versions are logically equivalent. However, my personal preference is to just use e.Length, saving the effort of looking at the caller to find out what elen is.

I suspect it is a bug.
See this assert in how it is called:

This is long ago for me, but as I remember it, e will be a kind of buffer, and elen is tracking how many elements we're actually using.

Also note the GrowLength is not used other than some tests.

// NOTE: This algorithm is not actually used further, but good for checking the S. paper.

It would be good to confirm with some test or scenario that breaks with the current code.
Also to review for similar mistakes.

However, for me this is not an active project.

I do note that .Length does not appear elsewhere in that file.

as i understand if input elen and e.Length happen to be equal then it wouldn't matter. But if, say, e was the output of a zero elim expansion then elen wouldn't be the same as e.Length

i don't think any other methods use .Length

i think elen is the equivalent of e.Count in a List<>. a lot of zero elim expansion operations seem to return an array that's bigger than the number of components in that expansion because the arrays are initialized before we know how many components are zero (and therefore eliminated)