很容易理解的是,NumPy 包含大量的各种数学运算功能。 NumPy 提供标准的三角函数,算术运算的函数,复数处理函数等。
NumPy 拥有标准的三角函数,它为弧度制单位的给定角度返回三角函数比值。
示例
import numpy as np a = np.array([0,30,45,60,90]) print '不同角度的正弦值:' # 通过乘 pi/180 转化为弧度 print np.sin(a*np.pi/180) print '\n' print '数组中角度的余弦值:' print np.cos(a*np.pi/180) print '\n' print '数组中角度的正切值:' print np.tan(a*np.pi/180)
输出如下:
不同角度的正弦值: [ 0. 0.5 0.70710678 0.8660254 1. ] 数组中角度的余弦值: [ 1.00000000e+00 8.66025404e-01 7.07106781e-01 5.00000000e-01 6.12323400e-17] 数组中角度的正切值: [ 0.00000000e+00 5.77350269e-01 1.00000000e+00 1.73205081e+00 1.63312394e+16]
arcsin
,arccos
,和arctan
函数返回给定角度的sin
,cos
和tan
的反三角函数。 这些函数的结果可以通过numpy.degrees()
函数通过将弧度制转换为角度制来验证。
示例
import numpy as np a = np.array([0,30,45,60,90]) print '含有正弦值的数组:' sin = np.sin(a*np.pi/180) print sin print '\n' print '计算角度的反正弦,返回值以弧度为单位:' inv = np.arcsin(sin) print inv print '\n' print '通过转化为角度制来检查结果:' print np.degrees(inv) print '\n' print 'arccos 和 arctan 函数行为类似:' cos = np.cos(a*np.pi/180) print cos print '\n' print '反余弦:' inv = np.arccos(cos) print inv print '\n' print '角度制单位:' print np.degrees(inv) print '\n' print 'tan 函数:' tan = np.tan(a*np.pi/180) print tan print '\n' print '反正切:' inv = np.arctan(tan) print inv print '\n' print '角度制单位:' print np.degrees(inv)
输出如下:
含有正弦值的数组: [ 0. 0.5 0.70710678 0.8660254 1. ] 计算角度的反正弦,返回值以弧度制为单位: [ 0. 0.52359878 0.78539816 1.04719755 1.57079633] 通过转化为角度制来检查结果: [ 0. 30. 45. 60. 90.] arccos 和 arctan 函数行为类似: [ 1.00000000e+00 8.66025404e-01 7.07106781e-01 5.00000000e-01 6.12323400e-17] 反余弦: [ 0. 0.52359878 0.78539816 1.04719755 1.57079633] 角度制单位: [ 0. 30. 45. 60. 90.] tan 函数: [ 0.00000000e+00 5.77350269e-01 1.00000000e+00 1.73205081e+00 1.63312394e+16] 反正切: [ 0. 0.52359878 0.78539816 1.04719755 1.57079633] 角度制单位: [ 0. 30. 45. 60. 90.]
numpy.around()
这个函数返回四舍五入到所需精度的值。 该函数接受以下参数。
numpy.around(a,decimals)
其中:
序号 | 参数及描述 |
---|---|
1. | a 输入数组 |
2. | decimals 要舍入的小数位数。 默认值为0。 如果为负,整数将四舍五入到小数点左侧的位置 |
示例
import numpy as np a = np.array([1.0,5.55, 123, 0.567, 25.532]) print '原数组:' print a print '\n' print '舍入后:' print np.around(a) print np.around(a, decimals = 1) print np.around(a, decimals = -1)
输出如下:
原数组: [ 1. 5.55 123. 0.567 25.532] 舍入后: [ 1. 6. 123. 1. 26. ] [ 1. 5.6 123. 0.6 25.5] [ 0. 10. 120. 0. 30. ]
numpy.floor()
此函数返回不大于输入参数的最大整数。 即标量x
的下限是最大的整数i
,使得i <= x
。 注意在Python中,向下取整总是从 0 舍入。
示例
import numpy as np a = np.array([-1.7, 1.5, -0.2, 0.6, 10]) print '提供的数组:' print a print '\n' print '修改后的数组:' print np.floor(a)
输出如下:
提供的数组: [ -1.7 1.5 -0.2 0.6 10. ] 修改后的数组: [ -2. 1. -1. 0. 10.]
numpy.ceil()
ceil()
函数返回输入值的上限,即,标量x
的上限是最小的整数i
,使得i> = x
。
示例
import numpy as np a = np.array([-1.7, 1.5, -0.2, 0.6, 10]) print '提供的数组:' print a print '\n' print '修改后的数组:' print np.ceil(a)
输出如下:
提供的数组: [ -1.7 1.5 -0.2 0.6 10. ] 修改后的数组: [ -1. 2. -0. 1. 10.]