注意:做算术运算时,输入数组必须具有相同的形状,或者符合数组的广播规则,才可以执行运算。
下面看一组示例:import numpy as np a = np.arange(9, dtype = np.float_).reshape(3,3) #数组a print(a) #数组b b = np.array([10,10,10]) print(b) #数组加法运算 print(np.add(a,b)) #数组减法运算 print(np.subtract(a,b)) #数组乘法运算 print(np.multiply(a,b)) #数组除法运算 print(np.divide(a,b))输出结果:
a数组: [[ 0. 1. 2.] [ 3. 4. 5.] [ 6. 7. 8.]] b数组: [10 10 10] 加: [[ 10. 11. 12.] [ 13. 14. 15.] [ 16. 17. 18.]] 减: [[-10. -9. -8.] [ -7. -6. -5.] [ -4. -3. -2.]] 乘: [[ 0. 10. 20.] [ 30. 40. 50.] [ 60. 70. 80.]] 除: [[ 0. 0.1 0.2] [ 0.3 0.4 0.5] [ 0.6 0.7 0.8]]下面介绍了 NumPy 中其他重要的算术运算函数。
import numpy as np #注意此处有0 a = np.array([0.25, 1.33, 1, 0, 100]) #数组a默认为浮点类型数据 print(a) #对数组a使用求倒数操作 print (np.reciprocal(a)) #b数组的数据类型为整形int b = np.array([100], dtype = int) print(b) #对数组b使用求倒数操作 print( np.reciprocal(b) )输出结果:
a数组: [ 0.25 1.33 1. 0. 100. ] 对a数组求倒数有inf提示: __main__:1: RuntimeWarning: divide by zero encountered in reciprocal [ 4. 0.7518797 1. inf 0.01 ] b数组: [100] 对b数组求倒数: [0]
import numpy as np a = np.array([10,100,1000]) #a数组 print ('我们的数组是;') #调用 power 函数 print (np.power(a,2)) b数组 b = np.array([1,2,3]) print (b) 调用 power 函数 print (np.power(a,b))输出结果:
a数组是: [ 10 100 1000] 调用 power 函数: [ 100 10000 1000000] b数组: [1 2 3] 调用 power 函数: [ 10 10000 1000000000]
import numpy as np a = np.array([11,22,33]) b = np.array([3,5,7]) #a与b相应位置的元素做除法 print( np.mod(a,b)) #remainder方法一样 print(np.remainder(a,b))输出结果:
mod: [1 0 2] remainder: [1 0 2]
import numpy as np a = np.array([-5.6j, 0.2j, 11. , 1+1j]) print(a) #real() print np.real(a) #imag() print np.imag(a) #conj() print np.conj(a) #angle() print np.angle(a) #angle() 带参数deg print np.angle(a, deg = True)输出结果:
a数组: [ 0.-5.6j 0.+0.2j 11.+0.j 1.+1.j ] real(): [ 0. 0. 11. 1.] imag(): [-5.6 0.2 0. 1. ] conj(): [ 0.+5.6j 0.-0.2j 11.-0.j 1.-1.j ] angle() : [-1.57079633 1.57079633 0. 0.78539816] angle(a,deg=True) [-90. 90. 0. 45.]
本文链接:http://task.lmcjl.com/news/13667.html