Czy można ustawić liczbę NaN lub nieskończoność?
Tak, w rzeczywistości istnieje kilka sposobów. Kilka działa bez żadnego importu, inne wymagają import
, jednak dla tej odpowiedzi ograniczę biblioteki w przeglądzie do biblioteki standardowej i NumPy (która nie jest biblioteką standardową, ale bardzo popularną biblioteką innej firmy).
W poniższej tabeli podsumowano sposoby tworzenia nieskończonej liczby lub dodatniej lub ujemnej nieskończoności float
:
╒══════════╤══════════════╤════════════════════╤════════════════════╕
│ result │ NaN │ Infinity │ -Infinity │
│ module │ │ │ │
╞══════════╪══════════════╪════════════════════╪════════════════════╡
│ built-in │ float("nan") │ float("inf") │ -float("inf") │
│ │ │ float("infinity") │ -float("infinity") │
│ │ │ float("+inf") │ float("-inf") │
│ │ │ float("+infinity") │ float("-infinity") │
├──────────┼──────────────┼────────────────────┼────────────────────┤
│ math │ math.nan │ math.inf │ -math.inf │
├──────────┼──────────────┼────────────────────┼────────────────────┤
│ cmath │ cmath.nan │ cmath.inf │ -cmath.inf │
├──────────┼──────────────┼────────────────────┼────────────────────┤
│ numpy │ numpy.nan │ numpy.PINF │ numpy.NINF │
│ │ numpy.NaN │ numpy.inf │ -numpy.inf │
│ │ numpy.NAN │ numpy.infty │ -numpy.infty │
│ │ │ numpy.Inf │ -numpy.Inf │
│ │ │ numpy.Infinity │ -numpy.Infinity │
╘══════════╧══════════════╧════════════════════╧════════════════════╛
Kilka uwag do stołu:
float
Konstruktor jest rzeczywiście wielkość liter, więc można również użyć float("NaN")
albo float("InFiNiTy")
.
cmath
I numpy
stałe powrotu zwykły Python float
obiektów.
- To
numpy.NINF
właściwie jedyna stała, o której wiem, że nie wymaga -
.
Możliwe jest tworzenie złożonych NaN i Infinity za pomocą complex
i cmath
:
╒══════════╤════════════════╤═════════════════╤═════════════════════╤══════════════════════╕
│ result │ NaN+0j │ 0+NaNj │ Inf+0j │ 0+Infj │
│ module │ │ │ │ │
╞══════════╪════════════════╪═════════════════╪═════════════════════╪══════════════════════╡
│ built-in │ complex("nan") │ complex("nanj") │ complex("inf") │ complex("infj") │
│ │ │ │ complex("infinity") │ complex("infinityj") │
├──────────┼────────────────┼─────────────────┼─────────────────────┼──────────────────────┤
│ cmath │ cmath.nan ¹ │ cmath.nanj │ cmath.inf ¹ │ cmath.infj │
╘══════════╧════════════════╧═════════════════╧═════════════════════╧══════════════════════╛
Opcje z ¹ zwracają zwykły float
, a nie a complex
.
czy jest jakaś funkcja sprawdzająca, czy liczba jest nieskończonością?
Tak, istnieje - w rzeczywistości istnieje kilka funkcji NaN, Infinity i ani Nan, ani Inf. Jednak te predefiniowane funkcje nie są wbudowane, zawsze wymagają import
:
╒══════════╤═════════════╤════════════════╤════════════════════╕
│ for │ NaN │ Infinity or │ not NaN and │
│ │ │ -Infinity │ not Infinity and │
│ module │ │ │ not -Infinity │
╞══════════╪═════════════╪════════════════╪════════════════════╡
│ math │ math.isnan │ math.isinf │ math.isfinite │
├──────────┼─────────────┼────────────────┼────────────────────┤
│ cmath │ cmath.isnan │ cmath.isinf │ cmath.isfinite │
├──────────┼─────────────┼────────────────┼────────────────────┤
│ numpy │ numpy.isnan │ numpy.isinf │ numpy.isfinite │
╘══════════╧═════════════╧════════════════╧════════════════════╛
Ponownie kilka uwag:
- Funkcje
cmath
i numpy
działają również dla złożonych obiektów, sprawdzą, czy częścią rzeczywistą lub urojoną jest NaN lub Infinity.
- Funkcje
numpy
działają również dla numpy
tablic i wszystkiego, co można przekonwertować na jedną (np. Listy, krotki itp.)
- Istnieją również funkcje, które jawnie sprawdzają dodatnią i ujemną nieskończoność w NumPy:
numpy.isposinf
i numpy.isneginf
.
- Panda oferuje dwie dodatkowe funkcje do sprawdzania
NaN
: pandas.isna
i pandas.isnull
(ale nie tylko NaN, to także pasuje None
i NaT
)
Mimo że nie ma żadnych wbudowanych funkcji, łatwo byłoby je utworzyć samodzielnie (pominąłem tutaj sprawdzanie typu i dokumentację):
def isnan(value):
return value != value # NaN is not equal to anything, not even itself
infinity = float("infinity")
def isinf(value):
return abs(value) == infinity
def isfinite(value):
return not (isnan(value) or isinf(value))
Podsumowując oczekiwane wyniki dla tych funkcji (zakładając, że dane wejściowe są zmiennoprzecinkowe):
╒════════════════╤═══════╤════════════╤═════════════╤══════════════════╕
│ input │ NaN │ Infinity │ -Infinity │ something else │
│ function │ │ │ │ │
╞════════════════╪═══════╪════════════╪═════════════╪══════════════════╡
│ isnan │ True │ False │ False │ False │
├────────────────┼───────┼────────────┼─────────────┼──────────────────┤
│ isinf │ False │ True │ True │ False │
├────────────────┼───────┼────────────┼─────────────┼──────────────────┤
│ isfinite │ False │ False │ False │ True │
╘════════════════╧═══════╧════════════╧═════════════╧══════════════════╛
Czy w Pythonie można ustawić element tablicy na NaN?
Na liście nie ma problemu, zawsze możesz tam dołączyć NaN (lub Infinity):
>>> [math.nan, math.inf, -math.inf, 1] # python list
[nan, inf, -inf, 1]
Jednak jeśli chcesz dołączyć go do array
(na przykład array.array
lub numpy.array
), typ tablicy musi być float
lub, complex
ponieważ w przeciwnym razie spróbuje sprowadzić ją do typu tablic!
>>> import numpy as np
>>> float_numpy_array = np.array([0., 0., 0.], dtype=float)
>>> float_numpy_array[0] = float("nan")
>>> float_numpy_array
array([nan, 0., 0.])
>>> import array
>>> float_array = array.array('d', [0, 0, 0])
>>> float_array[0] = float("nan")
>>> float_array
array('d', [nan, 0.0, 0.0])
>>> integer_numpy_array = np.array([0, 0, 0], dtype=int)
>>> integer_numpy_array[0] = float("nan")
ValueError: cannot convert float NaN to integer