I've opened a .fits image:
scaled_flat1 = pyfits.open('scaled_flat1.fit')
scaled_flat1a = scaled_flat1[0].data
and when I print its shape:
print scaled_flat1a.shape
I get the following:
(1, 1, 510, 765)
I want it to read:
(510, 765)
How do I get rid of the two ones before it?
You can use numpy. squeeze() to remove all dimensions of size 1 from the NumPy array ndarray . squeeze() is also provided as a method of ndarray .
numpy arrays can have 0, 1, 2 or more dimensions. C. shape returns a tuple of the dimensions; it may be of 0 length, () , 1 value, (81,) , or 2 (81,1) .
all() in Python. The numpy. all() function tests whether all array elements along the mentioned axis evaluate to True.
There is the method called squeeze
which does just what you want:
Remove single-dimensional entries from the shape of an array.
Parameters
a : array_like Input data. axis : None or int or tuple of ints, optional .. versionadded:: 1.7.0 Selects a subset of the single-dimensional entries in the shape. If an axis is selected with shape entry greater than one, an error is raised.
Returns
squeezed : ndarray The input array, but with with all or a subset of the dimensions of length 1 removed. This is always `a` itself or a view into `a`.
for example:
import numpy as np
extra_dims = np.random.randint(0, 10, (1, 1, 5, 7))
minimal_dims = extra_dims.squeeze()
print minimal_dims.shape
# (5, 7)
I'm assuming scaled_flat1a
is a numpy array? In that case, it should be as simple as a reshape
command.
import numpy as np
a = np.array([[[[1, 2, 3],
[4, 6, 7]]]])
print(a.shape)
# (1, 1, 2, 3)
a = a.reshape(a.shape[2:]) # You can also use np.reshape()
print(a.shape)
# (2, 3)
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With