4.Python科学计算与数据处理.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
使用缺省参数的好处是,如果某个参数大部分情况下都取某个固定的值,那么就可以为这个参数定义一个默认值,这样在以后使用这个函数时带来很大的便利,因为我们大部分时间都不用给它传参数;如果偶尔情况有变,还可以给它传递更适合的值——真是一举两得呀! * * 先创建一个dtype对象persontype,通过其字典参数描述结构类型的各个字段。字典有两个关键字:names,formats。每个关键字对应的值都是一个列表。names定义结构中的每个字段名,而 formats则定义每个字段的类型: ? S32 : 32个字节的字符串类型,由于结构中的每个元素的大小必须固定,因此需要指定字符串的长度? i : 32bit的整数类型,相当于32? f : 32bit的单精度浮点数类型,相当于np.float32 然后我们调用array函数创建数组,通过关键字参数dtype=persontype, 指定所创建的数组的元素类型为结构persontype。运行上面程序之后,我们可以在IPython中执行如下的语句查看数组a的元素类型 * 数据存储区域保存着数组中所有元素的二进制数据,dtype对象则知道如何将元素的二进制数据转换为可用的值。数组的维数、大小等信息都保存在ndarray数组对象的数据结构中。图中显示的是如下数组的内存结构: a = np.array([[0,1,2],[3,4,5],[6,7,8]], dtype=np.float32) strides中保存的是当每个轴的下标增加1时,数据存储区中的指针所增加的字节数。 * * n, bins, patches = plt.hist(arr, bins=50, normed=1, facecolor=green, alpha=0.75) arr: 需要计算直方图的一维数组 bins: 直方图的柱数,可选项,默认为10 normed: 是否将得到的直方图向量归一化。默认为0 facecolor: 直方图颜色 alpha: 透明度 返回值 :n: 直方图向量,是否归一化由参数设定 bins: 返回各个bin的区间范围 patches: 返回每个bin里面包含的数据,是一个list * numpy.linalg模块 在numpy.linalg模块中的svd函数可以对矩阵进行奇异值分解。该函数返回3个矩阵——U、Sigma和V,其中U和V是正交矩阵,Sigma包含输入矩阵的奇异值。 * import numpy as np A = np.mat(4 11 14;8 7 -2) print A\n, A U, Sigma, V = np.linalg.svd(A, full_matrices=False) print U print U print Sigma print Sigma print V print V print Product\n, U * np.diag(Sigma) * V numpy.linalg模块 广义逆矩阵 摩尔·彭罗斯广义逆矩阵(Moore-Penrose pseudoinverse)可以使用numpy.linalg模块中的pinv函数进行求解。计算广义逆矩阵需要用到奇异值分解。inv函数只接受方阵作为输入矩阵,而pinv函数则没有这个限制。 * import numpy as np A = np.mat(4 11 14;8 7 -2) print A\n, A pseudoinv = np.linalg.pinv(A) print Pseudo inverse\n, pseudoinv print Check, A * pseudoinv numpy.linalg模块 行列式 numpy.linalg模块中的det函数可以计算矩阵的行列式。 * import numpy as np A = np.mat(3 4;5 6) print A\n, A print Determinant, np.linalg.det(A) numpy.linalg模块 矩阵的秩 * import numpy as np I = np.eye(3)#先创建一个单位阵 I array([[ 1., 0., 0.], [ 0., 1., 0.], [ 0., 0., 1.]]) np.linalg.matrix_rank(I)#秩 3 I[1, 1] = 0#将该元素置为0 I array([[ 1., 0., 0.], [ 0., 0., 0.], [ 0., 0., 1.]]) np.linalg.matrix_rank(I)#此时秩变成2 2 N

文档评论(0)

qbjzmxj5904 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档