In [1]:
import numpy as np
In [2]:
l_2d = [[0, 1, 2], [3, 4, 5]]
print(l_2d)
In [3]:
print(type(l_2d))
In [4]:
arr = np.array([[0, 1, 2], [3, 4, 5]])
print(arr)
In [5]:
print(type(arr))
In [6]:
arr = np.arange(6)
print(arr)
In [7]:
arr = np.arange(6).reshape((2, 3))
print(arr)
In [8]:
mat = np.matrix([[0, 1, 2], [3, 4, 5]])
print(mat)
In [9]:
print(type(mat))
In [10]:
mat = np.matrix(arr)
print(mat)
In [11]:
print(type(mat))
In [12]:
mat_1d = np.matrix([0, 1, 2])
print(mat_1d)
In [13]:
print(type(mat_1d))
In [14]:
print(mat_1d.shape)
In [15]:
# mat_3d = np.matrix([[[0, 1, 2]]])
# ValueError: matrix must be 2-dimensional
In [16]:
print(l_2d)
In [17]:
print(l_2d[0][1])
In [18]:
l_2d[0][1] = 100
print(l_2d)
In [19]:
print(arr)
In [20]:
print(arr[0, 1])
In [21]:
arr[0, 1] = 100
print(arr)
In [22]:
l_2d = [[0, 1, 2], [3, 4, 5]]
print(l_2d)
In [23]:
print([list(x) for x in list(zip(*l_2d))])
In [24]:
arr = np.arange(6).reshape((2, 3))
print(arr)
In [25]:
print(arr.T)
In [26]:
l_2d_1 = [[0, 1, 2], [3, 4, 5]]
l_2d_2 = [[0, 2, 4], [6, 8, 10]]
In [27]:
print(l_2d_1 + l_2d_2)
In [28]:
# print(l_2d_1 - l_2d_2)
# TypeError: unsupported operand type(s) for -: 'list' and 'list'
In [29]:
arr1 = np.arange(6).reshape((2, 3))
print(arr1)
In [30]:
arr2 = np.arange(0, 12, 2).reshape((2, 3))
print(arr2)
In [31]:
print(arr1 + arr2)
In [32]:
print(arr1 - arr2)
In [33]:
mat1 = np.matrix(arr1)
mat2 = np.matrix(arr2)
In [34]:
print(mat1 + mat2)
In [35]:
print(mat1 - mat2)
In [36]:
print(l_2d_1 * 2)
In [37]:
# print(l_2d_1 * l_2d_2)
# TypeError: can't multiply sequence by non-int of type 'list'
In [38]:
print(arr1 * 2)
In [39]:
print(mat1 * 2)
In [40]:
print(np.multiply(arr1, arr2))
In [41]:
print(np.multiply(mat1, mat2))
In [42]:
print(arr1 * arr2)
In [43]:
arr1 = np.arange(4).reshape((2, 2))
print(arr1)
In [44]:
arr2 = np.arange(6).reshape((2, 3))
print(arr2)
In [45]:
print(np.dot(arr1, arr2))
In [46]:
print(arr1.dot(arr2))
In [47]:
print(np.matmul(arr1, arr2))
In [48]:
print(arr1 @ arr2)
In [49]:
mat1 = np.matrix(arr1)
mat2 = np.matrix(arr2)
In [50]:
print(np.dot(mat1, mat2))
In [51]:
print(mat1.dot(mat2))
In [52]:
print(np.matmul(mat1, mat2))
In [53]:
print(mat1 @ mat2)
In [54]:
print(mat1 * mat2)
In [55]:
arr = np.arange(1, 5).reshape(2, 2)
print(arr)
In [56]:
print(arr**2)
In [57]:
mat = np.matrix(arr)
print(mat)
In [58]:
print(mat**2)
In [59]:
print(mat**2 == mat * mat)
In [60]:
print(mat**3 == mat * mat * mat)
In [61]:
# print(arr**-1)
# ValueError: Integers to negative integer powers are not allowed.
In [62]:
arr_f = np.array(arr, dtype=float)
print(arr_f**-1)
In [63]:
print(mat**-1)
In [64]:
print(mat**-2)
In [65]:
print(mat**-2 == mat**-1 * mat**-1)
In [66]:
print(mat**-3 == mat**-1 * mat**-1 * mat**-1)