Add complex number support to isfinite
#531
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR
isfinite
by documenting special cases. Namely, if both the real and imaginary component are finite numbers, the result should beTrue
; otherwise, if a component is either+-infinity
orNaN
, the result should beFalse
. This follows Python, Julia, and NumPy.Notes
inf + NaN j
), a value cannot be both finite and NaN (e.g.,4.0 + NaN j
). In other words, when evaluating whether a value is infinite, we only consider components in isolation, irrespective of whether the other component is NaN; however, for the finite test, both components are considered, such that aNaN
for either component results inFalse
, irrespective of whether the other component is finite. While perhaps not surprising, one should note that we do not have uniform rules for considering whether a complex number is infinite, finite, and/or NaN.Reference