最小二乘问题的正则化方法求解(QR分解的实验报告)

实验内容及分析

import numpy as np
fs = float(0)           #范数
p = float(0)            #贝塔
print("请输入矩阵的行标:")
m = int(input())
print("请输入矩阵的列标:")
n = int(input())
I = np.array([([0 for i in range(m)])for i in range(m)])
for i in range(0,m):
    for j in range(0,m):
        if i==j:
            I[i][j]=float(1)       #定义一个单位矩阵
H = np.array([([0 for i in range(m)])for i in range(m)])
for i in range(0,m):
    for j in range(0,m):
        if i==j:
            H[i][j]=float(1)
a = np.array([([0 for i in range(n)])for i in range(m)])
print("请输入需要求的矩阵:")
for i in range(0,m):
    for j in range(0,n):
        a[i][j]=float(input())
for i in range(0,n):
    x = np.array([[float(0)] for k in range(0,m)])
    v = np.array([[float(0)] for k in range(0,m)])
    e = np.array([[float(0)] for k in range(0,m)])
    e[i][0]=float(1)
    for j in range(i,m):
        x[j] = a[j][i]
    fs = float((x.T@x)**(1/2))
    v = x-fs*e
    p = float(2/(v.T@v))
    H = (I-p*(v@v.T))@H
    a = (I-p*(v@v.T))@a
print("注:由于计算机的精度问题,存在一定误差。")
print("输出的正交矩阵(QR分解的Q):")
print(np.linalg.inv(H))
print("输出的上三角+零矩阵(QR分解的R):")
print(a)

实验中的问题及解决

1.问题:矩阵的行标列标在进行运算时可能存在不匹配的情况。

解决方法:用逐步输出的方法找到问题所在并解决。

2.问题:由于计算机的精度,计算值和理论值存在一定误差。

解决方法:通过人为的变化,例如矩阵出现可忽略不计的值时,可计为零。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值