Resize: Compensation for bad planning?
Top
Questions to David Rotermund
Try to avoid using this function! Do better planning.
Resize does its work on the linear memory segment.
- If it is resized to a bigger array, the beginning of the original memory segment is copied into the new end segment.
- If it is resized to a smaller array, the memory segment is shrunken by cutting of the end.
numpy.resize
numpy.resize(a, new_shape)
Return a new array with the specified shape.
If the new array is larger than the original array, then the new array is filled with repeated copies of a. Note that this behavior is different from a.resize(new_shape) which fills with zeros instead of repeated copies of a.
import numpy as np
a = np.arange(1, 10).reshape((3, 3))
print(a)
print()
b = np.resize(a, (2, 3))
print(b)
print()
b = np.resize(a, (3, 1))
print(b)
print()
b = np.resize(a, (5, 5))
print(b)
Output:
[[1 2 3]
[4 5 6]
[7 8 9]]
[[1 2 3]
[4 5 6]]
[[1]
[2]
[3]]
[[1 2 3 4 5]
[6 7 8 9 1]
[2 3 4 5 6]
[7 8 9 1 2]
[3 4 5 6 7]]
This is not numpy.ndarray.resize
ndarray.resize(new_shape, refcheck=True)
Change shape and size of array in-place.
I added a copy because it does not work on views (ValueError: cannot resize this array: it does not own its data) , which reshape creates.
import numpy as np
a = np.arange(1, 10).reshape((3, 3)).copy()
print(a)
print()
a.resize((5, 5))
print(a)
Output:
[[1 2 3]
[4 5 6]
[7 8 9]]
[[1 2 3 4 5]
[6 7 8 9 0]
[0 0 0 0 0]
[0 0 0 0 0]
[0 0 0 0 0]]
More bad function
Try to avoid using these functions!
numpy.delete
numpy.delete(arr, obj, axis=None)
Return a new array with sub-arrays along an axis deleted. For a one dimensional array, this returns those entries not returned by arr[obj].
numpy.insert
numpy.insert(arr, obj, values, axis=None)
Insert values along the given axis before the given indices.
numpy.append
numpy.append(arr, values, axis=None)
Append values to the end of an array.
The source code is Open Source and can be found on GitHub.