> On 19 Aug 2019, at 15:45, akash srivastava <akashsp...@gmail.com> wrote:
> 
> I was advised to check with the dev mailing list if anyone has a problem
> with the suggested fix.
> It seems no one does have a problem with the fixes suggested so I'll go
> forward and create a PR that returns an empty array for an array of all
> NaNs.

I suggested doing the same as what happens when you pass in an empty array, 
effectively changing the array of NaNs to an array of nothing.

Reading the code it appears that this case would throw an 
ArrayIndexOutOfBoundsException. A simple test case shows that this is true, 
e.g. this passes:

@Test(expected=ArrayIndexOutOfBoundsException.class)
public void testEmpty() {
    new NaturalRanking().rank(new double[0]);
}

So the fix for rank() on an array of NaNs has no equivalent with a normal array 
as an empty normal array is an edge case currently not handled.

IMO returning an empty array is not going to be useful. If someone is using 
this class to rank data then immediately after ranking I would assume they will 
use the rank to do something, e.g. pick the top one. An empty array will fail 
for most use cases I can think of since they will require dereferencing the 
rank array. Only if the array is used without dereferencing it, e.g. print to 
file, or if the size of the rank array is checked before using the contents 
will an empty array be OK.

So the question becomes which is better:

- Returning an empty array and requiring users to check its length or else 
receive ArrayIndexOutOfBoundsException when using the array contents
- Throwing an exception so that the exact cause of their bug can be recorded in 
the stack trace

I would suggest that an array of NaNs or an empty array should throw the same 
and it should be some sort of IllegalArgumentException. Currently this class 
only throws NotANumberException for errors. Perhaps for these two cases an 
math4.exception.InsufficientDataException should be thrown. This basically 
states that you cannot rank nothing and any result that is returned will 
contain a ranking.

Opinions?

> 
> On Thu, Aug 15, 2019 at 11:25 AM akash srivastava <akashsp...@gmail.com>
> wrote:
> 
>> Here is the link for the related bug:
>> https://issues.apache.org/jira/browse/MATH-1495
>> 
>> I have suggested two possible fixes when NaturalRanking#rank() is called
>> on an array of all NaNs:
>> 1) throwing an IllegalArgumentException
>> 2) Returning an empty array
>> 
>> I want to create a pull request regarding it, which fix do you suggest I
>> should go for?
>> 


---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscr...@commons.apache.org
For additional commands, e-mail: dev-h...@commons.apache.org

Reply via email to