numpy总结

numpy的功能:

    提供数组的矢量化操作,所谓矢量化就是不用循环就能将运算符应用到数组中的每个元素中。
    提供数学函数应用到每个数组中元素
    提供线性代数,随机数生成,傅里叶变换等数学模块

numpy数组操作

    numpy.array([],dttype=)生成ndarry数组,dttype指定存储数据类型
    numpy.zeros((3,4))生成指定元素0的3行4列矩阵。
    numpy.reshape((2,2))转换数组阵维数为2行2列
    numpy.arange(4)生成0到3的一行矩阵。
    numpy.dot(a,b)矩阵a,b乘法
    numpy.sum(a,axis=1)axis=1表示在矩阵a的行求和,axis=0表示在列求和
    ndarray.T,ndarray表示数组类型,T表示转置矩阵。
    ndarray.flateen()返回数组元素形成的列表,flat()返回迭代对象。
    numpy.vstack((A,B,C))上下合并矩阵数组A,B,C。
    numpy.hstack((A,B,C))左右合并矩阵数组A,B,C。
    ndarray[:,numpy.newaxis]增加列的维度。对于单行横矩阵,变成单行列矩阵。
    numpy.concatenate((A,B,B,A),axis=0)也是合并矩阵,axis=0表示垂直合并,- axis=1表示水平合并
    numpy.dstack(())深度组合,将互不相干的
    numpy.split(A,2,axis=1)对矩阵数组分割分成两块,axis=1是行分割,axis=0是列分割。等量分割,必须除的断
    numpy.array_split(A,2,axis=1)不等量分割,第一个矩阵占元素较多。
    numpy.vsplit(A,3)纵向分割,hsplit(A,3)横向分割 对于多维,只分割最外维的
    numpy.dsplit()深度分割,突破维数的一列一列的分割
    numpy属性 size元素个数 itemsize元素空间大小 nbytes总空间 T转置 ndim维数 real复数数组的实部,imag复数数组的虚部 flat返回迭代器遍历数组
    numpy.tolist()将数组转换为列表
    numpy.eye(宽高)单位矩阵即对角线为1的二维数组
    numpy.loadtxt(‘data.csv’,delimiter=’,’,)载入csv文件
    numpy.mean()对数组取平均值
    numpy.average()时间加权平均值,最近的数权重大些
    numpy.max()取到数组最大值
    numpy.min()取到数组最小值
    numpy.median()取到数组中位数
    numpy.msort()排序数组
    numpy.var()统计数组的方差
    numpy.diff()返回数组相邻值的差值组成的数组
    numpy.log()得到数组每个元素的对数数组
    numpy.std()数组的标准差
    ndarray.copy()复制
    numpy.dtype()自定义数据类型,接收元组的列表作为参数。()元组第一个是数据名称,第二个是数据类型,第三个指定数据类型长度,创立该类型的数据只要将对应数据元组列表传给array()指定dtype=自定义数据类型
    利用:或…对多维数组进行切片
    numpy.ravel()输出一个多维数组被抹平成一维数组的视图
    numpy.resize()直接修改数组,而reshape()返回修改后的新数组
    numpy.transpose()转置
    numpy.where(x,date==i)取出符合条件表达式的索引
    numpy.take(x,indices)根据索引数组取出值数组
    numpy.maximum(多个数组)每个数组的最大值组成一个数组
    numpy.convolve()卷积,两个函数相乘,移动窗口均值可以用1/窗口长度组成的数组和原数组作为参数
    numpy.linespace()返回一个元素值在指定范围均匀分布的数组
    ndarray.clip(min,max)返回一个修剪过的数组,比min小的修正为min,比max大的修正为max
    ndarray.compress(条件)返回数组元素经过条件筛选组成的数组
    ndarray.prod计算所有元素的乘积
    numpy.cov()计算两个数组之间的协方差矩阵
    ndarray.trace计算矩阵的迹,即对角线元素之和
    numpy.corrcoef()计算两个数组之间的相关系数
    numpy.ployfit(x=,y=,阶次)对给的数据进行多项式拟合
    numpy.polyval(ployfit拟合的函数,x)进行计算预测
    numpy.polyder(多项式函数)对函数进行求导
    numpy.argmax(函数对象)找出最大值点的x值
    numpy.hanning()加权余弦窗函数进行数据平滑
    numpy.mat(‘1;4;4’)创建矩阵,矩阵的行与行用分号隔开,也可以传入已有矩阵,但是不会创建副本
    .-I属性是逆矩阵
    numpy.matrix(data,copy=False)也是创建矩阵
    numpy.bmat(“矩阵名A 矩阵名B;矩阵名A 矩阵名B;”)通过分块矩阵创建大矩阵
    numpy.remainder(),mod(),%返回两个数组中相除后的余数组成的数组
    numpy.Fmod()余数的正负由被除数决定,与除数无关

通用函数

    numpy.frompyfunc()创建通用函数 生成输入两个参数输出一个参数的ufunc对象,
    np.add.reduce()对数组元素求和
    np.add.accmulate()返回中间结果,返回一步一步求和组成的数组,等价于cumsum()函数
    np.add.reduceat()在某个范围进行求和
    np.add.outer()等于两个输入数组的秩的和

专用函数

    np.bitwise_xor()函数对应异或 bitwise_and对应与 ==对应equal()函数
    np.linalg.inv(A)计算矩阵A的逆矩阵
    np.linalg.solve(A,b)用矩阵对向量b进行线性变换,即求解线性方程组得出系数向量
    np.dot(A,x)点积函数,通过矩阵A与系数向量x点积来验证求解线性方程组是否正确。

线性代数专用函数

    np.linalg.eigvals()计算矩阵的特征值
    np.linalg.eig()返回特征值和对应的特征向量的元组
    np.linalg.svd()分解矩阵为三个矩阵的乘积
    np.linalg.pinv()求解广义逆矩阵
    np.linalg.det(A)计算矩阵的行列式
    np.linalg.fftshift()FFT输出中的直流分量移动到频谱的中央ifftshift()是逆操作

随机数专用函数

    np.random.binomial(最大值,概率,产生数的个数)产生符合二项分布的随机数
    np.random.hypergemotric(普通球数量,倒霉球数量,一次取出个数,个数)超几何分布
    np.random.beta、chisquare、exponential、f、连续分布
    np.random.normal(数量)正态分布随机数
    np.random.lognormal()对数正态分布

数组专用函数

    np.sort()排序 lesort()根据键值对字典进行排序,argsort()返回输入数组排序后的下标
    ndarray.sort()对数组进行原地排序。msort()沿第一个轴进行排序,sort_complex()对复数按照先实部后虚部的顺序进行排序。
    np.searchsorted(数组a,要插入的数组值)计算出不影响数组a的插入位置索引,再通过np.insert(a,索引,插入数组)就不影响原先数组的顺序
    np.extract((a%2==0),a)从a中抽取能被2整除的元素
    np.nonzero(a)抽取非0元素
    np.outer(a数组,b数组)a数组的元素*b数组行,生成二维数组

金融专用函数

    np.fv()计算终值
    np.pv()金融资产当前的价值
    np.npv按折现率计算的净现金流之和
    np.pmt根据本金和利率计算每期需支付的金额
    np.irr 内部收益率净现值为0时的有效利率,不考虑通胀因素
    np.mirr计算修正后内部收益率

窗函数

    np.bartlett()巴特利特窗,三角形平滑窗
    np.blackman()布莱克曼窗,三项余弦函数
    np.hmming()汉明窗,加权余弦函数

数学函数

    np.i0()零阶贝塞尔函数
    np.sinc()1阶贝塞尔函数

测试专用函数

    np.assert_almost_equal(num1,num2,精度(小数点后几位+1))断言进行相等,否则抛出异常
    np.assert_approx_equal(num1,num2,有效数字(小数点后几位))一样的效果
    np.assert_array_almost_equal()断言数组近似相等,前提大小一致,否则抛出异常
    np.assert_array_equal()比较数组的元素是否都相等,允许空值
    np.assert_array_less()比较一个数组每个元素是否大于另一个数组的对应索引的每个元素,抛出异常

numpy中要注意的几个地方:

    切片不会复制原数组,而是生成原数组的视图,对视图的更改会反映到原数组上。一般的函数都是直接在原数组上进行操作,这样不用复制数组,节省大量时间。
posted @ 2019-06-17 22:03  love_water  阅读(501)  评论(0编辑  收藏  举报