Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Only check isnan if applicable #54

Open
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

ianfiske
Copy link

@ianfiske
Copy link
Author

As per the discussion in #53, I added a check if isnan is applicable before calling it. Note that now, the tests fail because there is also no isfinite method for Millisecond. I can fix this with the same strategy of checking if the method is applicable, but this just feels clunky to me. I'm used to the "call the method" and it does the right thing for each type. Checking before calling so many methods just starts to look clunky, but if you think that's the right approach, I can easily add it.

@nalimilan
Copy link
Member

I agree it's not ideal, but the only other solution I can see is to define isnan(::Any) and isfinite(::Any) to be false. Do you feel like proposing this in Base? That would probably allow making the code cleaner.

CI errors, but AFAICT it's no related to isfinite?

@nalimilan
Copy link
Member

Bump.

@ianfiske
Copy link
Author

ianfiske commented Nov 9, 2020

@nalimilan Thanks for the bump, I've been busy with other things and I don't think I have time to make the PR to Base right now. Feel free to run with it if you have time before I do.

@@ -695,6 +696,8 @@ end
@test quantile(skipmissing([1, missing, 2]), 0.5) === 1.5
@test quantile([1], 0.5) === 1.0

@test quantile(Millisecond.(1:10), 0.5) == Millisecond(5)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
@test quantile(Millisecond.(1:10), 0.5) == Millisecond(5)
@test quantile(Millisecond.(0:10), 0.5) == Millisecond(5)

@@ -1049,7 +1049,7 @@ end

# When a ≉ b, b-a may overflow
# When a ≈ b, (1-γ)*a + γ*b may not be increasing with γ due to rounding
if isfinite(a) && isfinite(b) &&
if applicable(isfinite, a) && isfinite(a) && isfinite(b) &&
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
if applicable(isfinite, a) && isfinite(a) && isfinite(b) &&
if applicable(isfinite, a) && isfinite(a) &&
applicable(isfinite, b) && isfinite(b)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Cannot compute quantile(x::Array{Millisecond,1})
3 participants