热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

高编课后作业------第十一周-Numpyexercise

GeneratematricesA,withrandomGaussianentries,B,aToeplitzmatrix,whereAR
Generate matrices A , with random Gaussian entries, B , a Toeplitz matrix, where A   R n × m and B   R m × m ,

for n = 200, m = 500.  为了显示方便,用规模小一点的矩阵,n=10,m=25

  

from scipy.linalg import toeplitz
import numpy as np
#选用服从 N(0,1)的正态分布 , 生成之后 reshape
A = np.random.normal(0,1,100000)
A = A.reshape(200,500)
B = toeplitz(list(range(1,501)))
A2 = A+A
AAt = A@A.T
AtA = A.T@A
AmB = A@B

def compute(A,B,lam):
    temp = B-lam*np.eye(500)
    return A@temp

print(compute(A,B,3))

在上面基础上,加上:

b = np.array(list(range(1,501)))
x = np.linalg.solve(B,b)

    norm(矩阵,哪种范数) , Frobenius范数就是'fro', 无穷范数就是np.inf 。然后就是svd分解函数,full_matrices=True就是全部分解

na = np.linalg.norm(A,'fro')
nb = np.linalg.norm(B,np.inf)

u, s, vh = np.linalg.svd(B,full_matrices=True)
maxvalue = max(s)
minvalue = min(s)


就是用幂法求主特征值和主特征向量,数值计算刚刚学过就用上了,精度设置为1e-4,返回值为

lam:主特征值

u:规格化之后的主特征向量

cnt: 迭代次数

cost:使用的时间

n = 100
Z = np.random.normal(5,1,n*n).reshape(n,n)
def powerit(Z,n):
    from time import clock
    start = clock()
    u = np.random.normal(5,1,n)
    last = 1000
    lam = 0
    cnt = 0
    while abs(last-lam) > 0.0001:
        cnt = cnt+1
        v = Z@u
        big = -1
        last = lam
        for vv in v:
            if abs(vv)>big:
                lam = vv
                big = abs(vv)
        u = v/lam
    end = clock()
    return lam, u, cnt, end-start

n=100时,只用6次就收敛了。。。


改成n=1000,甚至精度改成了1e-10,也只用了8次.....这个收敛速度是真的快.....


写到这里才发现生成正态分布矩阵的参数中有一个size参数 可以直接生成2维矩阵........

0-1分布是一种特殊的二项分布,而numpy.random里只有二项分布,所以就用n=1的二项分布生成。。。

for n in (10,50,100):
    for p in (0.2,0.5,0.8):
        print("n = %d, p = %.3f" % (n,p))
        C = np.random.binomial(1,p,(n,n))
        u, s, vh = np.linalg.svd(C,full_matrices=True)
        maxvalue = max(s)
        print(maxvalue)
结果是:

可以看到随着n和p的增加,最大奇异值maxvalue也会增加。

而且好像是成倍增加的!!!

大概是 maxvalue = t * n * p的形式


def closest(A,z):
    B = A - z
    idx = np.argmin(np.abs(B))
    return A[idx]
    

提示说用argmin,就是获取最小值的下标,而离z最近的元素,就是先把A每项都减去z,然后取绝对值,哪一项绝对值最小哪一项就离z最近,然后通过argmin获取下标,返回原矩阵A中的idx下标的值就可以了。



推荐阅读
  • 本文由编程笔记#小编为大家整理,主要介绍了logistic回归(线性和非线性)相关的知识,包括线性logistic回归的代码和数据集的分布情况。希望对你有一定的参考价值。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • Python瓦片图下载、合并、绘图、标记的代码示例
    本文提供了Python瓦片图下载、合并、绘图、标记的代码示例,包括下载代码、多线程下载、图像处理等功能。通过参考geoserver,使用PIL、cv2、numpy、gdal、osr等库实现了瓦片图的下载、合并、绘图和标记功能。代码示例详细介绍了各个功能的实现方法,供读者参考使用。 ... [详细]
  • Day2列表、字典、集合操作详解
    本文详细介绍了列表、字典、集合的操作方法,包括定义列表、访问列表元素、字符串操作、字典操作、集合操作、文件操作、字符编码与转码等内容。内容详实,适合初学者参考。 ... [详细]
  • IjustinheritedsomewebpageswhichusesMooTools.IneverusedMooTools.NowIneedtoaddsomef ... [详细]
  • 基于dlib的人脸68特征点提取(眨眼张嘴检测)python版本
    文章目录引言开发环境和库流程设计张嘴和闭眼的检测引言(1)利用Dlib官方训练好的模型“shape_predictor_68_face_landmarks.dat”进行68个点标定 ... [详细]
  • Givenasinglylinkedlist,returnarandomnode'svaluefromthelinkedlist.Eachnodemusthavethe s ... [详细]
  • 欢乐的票圈重构之旅——RecyclerView的头尾布局增加
    项目重构的Git地址:https:github.comrazerdpFriendCircletreemain-dev项目同步更新的文集:http:www.jianshu.comno ... [详细]
  • EPPlus绘制刻度线的方法及示例代码
    本文介绍了使用EPPlus绘制刻度线的方法,并提供了示例代码。通过ExcelPackage类和List对象,可以实现在Excel中绘制刻度线的功能。具体的方法和示例代码在文章中进行了详细的介绍和演示。 ... [详细]
  • Python使用Pillow包生成验证码图片的方法
    本文介绍了使用Python中的Pillow包生成验证码图片的方法。通过随机生成数字和符号,并添加干扰象素,生成一幅验证码图片。需要配置好Python环境,并安装Pillow库。代码实现包括导入Pillow包和随机模块,定义随机生成字母、数字和字体颜色的函数。 ... [详细]
  • OpenMap教程4 – 图层概述
    本文介绍了OpenMap教程4中关于地图图层的内容,包括将ShapeLayer添加到MapBean中的方法,OpenMap支持的图层类型以及使用BufferedLayer创建图像的MapBean。此外,还介绍了Layer背景标志的作用和OMGraphicHandlerLayer的基础层类。 ... [详细]
  • #define_CRT_SECURE_NO_WARNINGS#includelist.h#includevoidSListInit(PNode*pHead ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
author-avatar
吉樺雄_910
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有