Ось правильний простір імен для функцій:
Обидві функції повертають сплющені 1D масиви, що вказують на нові структури пам'яті.
import numpy
a = numpy.array([[1,2],[3,4]])
r = numpy.ravel(a)
f = numpy.ndarray.flatten(a)
print(id(a))
print(id(r))
print(id(f))
print(r)
print(f)
print("\nbase r:", r.base)
print("\nbase f:", f.base)
---returns---
140541099429760
140541099471056
140541099473216
[1 2 3 4]
[1 2 3 4]
base r: [[1 2]
[3 4]]
base f: None
У верхньому прикладі:
- місця пам'яті результатів різні,
- результати виглядають однаково
- flatten поверне копію
- ravel поверне погляд.
Як ми перевіряємо, чи є щось копія? Використовуючи .base
атрибут ndarray
. Якщо це вид, основою буде оригінальний масив; якщо це копія, база буде None
.