[Numpy-discussion] min() of array containing NaN
Mon Aug 11 20:34:52 CDT 2008
I agree with using Masked arrays...
Actually this could be viewed as a bug because it ignores the entries
to the left of the NaN.
>>> x = numpy.array([0,1,2,numpy.nan, 4, 5, 6])
>>> x = numpy.array([numpy.nan,0,1,2, 4, 5, 6])
>>> x = numpy.array([0,1,2, 4, 5, 6, numpy.nan])
As has been recently said on this list (as per Stefan's post) NaN's
and infinity have a higher computational cost. I am not sure the
relative cost of using say isnan first as a check or having a NaN flag
stored as part of the ndarray class.
As per Travis's post, technically it should return NaN. But I don't
agree with Charles that it should automatically call nanmin because
nanmin treats NaNs as zero, positive infinity as a really large
positive number and negative infinity as a very small or negative
number. This may not be want the user wants. An alternative is to
change the signature to include a flag to include or exclude NaN and
infinity which would also remove the need for nanmin and friends.
On Mon, Aug 11, 2008 at 6:41 PM, Pierre GM <firstname.lastname@example.org> wrote:
> *cough* MaskedArrays anyone ? *cough*
> The ideal would be for min/max to output a NaN when there's a NaN somewhere.
> That way, you'd know that there's a potential pb in your data, and that you
> should use the nanfunctions or masked arrays.
> is there a page on the wiki for that matter ? It seems to show up regularly...
> On Monday 11 August 2008 18:49:06 Stéfan van der Walt wrote:
>> 2008/8/11 Charles Doutriaux <email@example.com>:
>> > Seems to me like min should automagically call nanmin if it spots any
>> > nan no ?
>> Nanmin is quite a bit slower:
>> In : x = np.random.random((5000))
>> In : timeit np.min(x)
>> 10000 loops, best of 3: 24.8 µs per loop
>> In : timeit np.nanmin(x)
>> 10000 loops, best of 3: 136 µs per loop
>> So, I'm not sure if that will happen. One option is to use `nanmin`
>> by default, and to provide `min` for people who need the speed. The
>> fact that results with nan's are almost always unexpected is certainly
>> a valid concern.
>> Numpy-discussion mailing list
> Numpy-discussion mailing list
More information about the Numpy-discussion