码迷,mamicode.com
首页 > 其他好文 > 详细

numpy库

时间:2018-11-17 14:37:12      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:垂直   矩阵   1.4   +=   user   code   org   msi   one   

 

 

创建数组

>>> np.ones([3,4])          # 值为浮点1的矩阵
array([[ 1.,  1.,  1.,  1.],
       [ 1.,  1.,  1.,  1.],
       [ 1.,  1.,  1.,  1.]])
>>> np.zeros([3,4])         # 值为浮点0的矩阵
array([[ 0.,  0.,  0.,  0.],
       [ 0.,  0.,  0.,  0.],
       [ 0.,  0.,  0.,  0.]])
>>> np.array([[1,2,3],[4,5,6]])    # 深拷贝
array([[1, 2, 3],
       [4, 5, 6]])
>>> np.asarray([[1,2,3],[4,5,6]])  # 浅拷贝
array([[1, 2, 3], 
       [4, 5, 6]])    

 

 

数组属性

>>> d=np.random.rand(2,3,4)   
>>> d
array([[[ 0.75432633,  0.57838693,  0.9298954 ,  0.01667251],
        [ 0.81329288,  0.18277114,  0.40584013,  0.30055277],
        [ 0.12805651,  0.38665696,  0.29655644,  0.61897223]],

       [[ 0.1072343 ,  0.34588952,  0.96080471,  0.56854714],
        [ 0.76898631,  0.4881976 ,  0.85973732,  0.1127037 ],
        [ 0.27826845,  0.81381869,  0.03623546,  0.11600406]]])
>>> d.size   # 元素个数
24
>>> d.shape  # 数组形状
(2, 3, 4)
>>> d.dtype  # 元素类型
dtype(float64)
>>> d.ndim   # 数组维度
3
>>> d.itemsize # 元素字节长度
8

 

随机数(均匀分布)

>>> np.random.uniform(0,100)  # 创建指定范围的随机浮点数
79.95384787852716
>>> np.random.randint(0,100)  # 创建指定范围的随机整数
13
>>> np.random.rand(3,3)       # 创建指定[0, 1]之间的浮点数矩阵
array([[ 0.3672736 ,  0.64473369,  0.51615523],
       [ 0.12016337,  0.80318054,  0.02896355],
       [ 0.22252509,  0.41416445,  0.9141706 ]])

 

正态分布

np.random.normal(1, 0.5, (3,4))   # 指定均值、标准差、维度
array([[ 0.86131114,  0.97396862,  1.41560527,  0.9125575 ],
       [ 0.50615441,  1.30600456,  0.28319673,  0.73952316],
       [ 1.683847  ,  1.88634808,  0.81664031,  1.04438156]])

 

slice(切片)

 >>> a
array([[ 0.91108116,  0.38937371,  0.44120738,  0.9711543 ,  0.50400801,
         0.8159346 ],
       [ 0.23592619,  0.9446476 ,  0.83056827,  0.80585383,  0.98337604,
         0.34744683]])
>>> a[:,3:-1]
array([[ 0.9711543 ,  0.50400801],
       [ 0.80585383,  0.98337604]])

 

 

reshape (reshape前后元素个数要一致)

>>> a=np.random.rand(2,6)
>>> b=a.reshape(3,4)
>>> a
array([[ 0.91108116,  0.38937371,  0.44120738,  0.9711543 ,  0.50400801,
         0.8159346 ],
       [ 0.23592619,  0.9446476 ,  0.83056827,  0.80585383,  0.98337604,
         0.34744683]])
>>> b
array([[ 0.91108116,  0.38937371,  0.44120738,  0.9711543 ],
       [ 0.50400801,  0.8159346 ,  0.23592619,  0.9446476 ],
       [ 0.83056827,  0.80585383,  0.98337604,  0.34744683]])

 

 

条件计算

>>> a
array([[80, 88],
       [82, 81],
       [84, 75],
       [86, 83],
       [75, 81]])
>>> a>80
array([[False,  True],
       [ True,  True],
       [ True, False],
       [ True,  True],
       [False,  True]], dtype=bool)
>>> np.where(a<=80, 0, 1)  # <=80的元素替换为0,否则替换为1
array([[0, 1],
       [1, 1],
       [1, 0],
       [1, 1],
       [0, 1]])

 

最大(小)值

>>> a
array([[80, 88],
       [82, 81],
       [84, 75],
       [86, 83],
       [75, 81]])
>>> np.amax(a, axis=0)   # 按列求最大值
array([86, 88])
>>> np.amax(a, axis=1)   # 按行求最大值
array([88, 82, 84, 86, 81])
>>> np.amin(a, axis=0)   # 按列求最小值
array([75, 75])
>>> np.amin(a, axis=1)   # 按行求最小值
array([80, 81, 75, 83, 75])
>>> np.mean(a, axis=1)   # 平均值
array([ 84. ,  81.5,  79.5,  84.5,  78. ])
>>> np.mean(a, axis=0)   
array([ 81.4,  81.6])
>>> np.std(a, axis=0)    # 标准差
array([ 3.77359245,  4.1761226 ])  
>>> np.std(a, axis=1)
array([ 4. ,  0.5,  4.5,  1.5,  3. ])

 

数组与数值的运算

a
array([[84, 92],
       [86, 85],
       [88, 79],
       [90, 87],
       [79, 85]])
>>> a[:,0]+=4
>>> a
array([[88, 92],
       [90, 85],
       [92, 79],
       [94, 87],
       [83, 85]])
>>> a[2:4,1] -= 10
>>> a
array([[88, 92],
       [90, 85],
       [92, 69],
       [94, 77],
       [83, 85]])

 

 

数组拼接

>>> v1
[[0, 1, 2, 3, 4, 5], [6, 7, 8, 9, 10, 11]]
>>> v2
[[12, 13, 14, 15, 16, 17], [18, 19, 20, 21, 22, 23]]
>>> np.vstack((v1, v2))    # 垂直拼接
array([[ 0,  1,  2,  3,  4,  5],
       [ 6,  7,  8,  9, 10, 11],
       [12, 13, 14, 15, 16, 17],
       [18, 19, 20, 21, 22, 23]])
>>> np.hstack((v1, v2))   # 水平拼接
array([[ 0,  1,  2,  3,  4,  5, 12, 13, 14, 15, 16, 17],
       [ 6,  7,  8,  9, 10, 11, 18, 19, 20, 21, 22, 23]])
>>> 

 

 

矩阵乘法

>>> a = np.array([[80, 88], [82, 81], [84, 75], [86, 83], [75, 81]])
>>> b = np.array([[0.4], [0.6]])
>>> np.dot(a, b)
array([[ 84.8],
       [ 81.4],
       [ 78.6],
       [ 84.2],
       [ 78.6]])

 

 

 

 

参考文档:

https://www.jianshu.com/p/a260a8c43e44

https://docs.scipy.org/doc/numpy/user/quickstart.html

 

numpy库

标签:垂直   矩阵   1.4   +=   user   code   org   msi   one   

原文地址:https://www.cnblogs.com/chenny7/p/9973609.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!