伴随矩阵中退化本征值的数值精度差问题。
创始人
2024-11-21 11:30:41
0

一种可以解决伴随矩阵中退化本征值数值精度问题的方法是利用位移策略,使退化本征值与其他本征值分开计算。具体实现方法是通过使用QR分解和Wilkinson位移,将伴随矩阵的计算转化为非退化本征值计算。以下是Python代码示例:

import numpy as np 

def compeig(A):
    n = A.shape[0]
    Q = np.eye(n)
    for k in range(n-1):
        x = A[k:,k]
        e1 = np.zeros_like(x)
        e1[0] = 1
        u = np.sign(x[0])*np.linalg.norm(x)*e1 + x
        u = u/np.linalg.norm(u)
        A[k:,k:] = A[k:,k:] - 2*np.outer(u,np.dot(u.T,A[k:,k:]))
        Q[k:,:] = Q[k:,:] - 2*np.outer(u,np.dot(u.T,Q[k:,:]))
    eigvals = []
    while n > 1:
        if abs(A[n-1,n-2]) < 1e-10:
            eigvals.append(A[n-1,n-1])
            A = A[:n-1,:n-1]
            Q = Q[:n-1,:]
            n -= 1
        else:
            mu = A[n-1,n-1]
            A = A - mu*np.eye(n)
            q, r = np.linalg.qr(A)
            Q = Q.dot(q)
            A = r.dot(q) + mu*np.eye(n)
            eigvals.append(mu)
    eigvals.append(A[0,0])
    eigvals.reverse()
    Q = Q.T
    return eigvals, Q

# Example usage:
A = np.array([[0,1,0,0],
              [0,0,1,0],
              [0,0,0,1],
              [1,0,0,1]])

eig

相关内容

热门资讯

2026版辅助挂!黑科技软件大... 2026版辅助挂!黑科技软件大全(辅助)竟然真的是有辅助攻略(真实有挂)1、黑科技软件大全模拟器是什...
2026版技巧!大众互娱脚本(... 2026版技巧!大众互娱脚本(辅助)切实存在有辅助神器(有挂解惑)1、大众互娱脚本免费脚本咨询教程、...
近日!边锋嘉兴辅助(辅助)切实... 近日!边锋嘉兴辅助(辅助)切实是真的有辅助脚本(有挂规律)所有人都在同一条线上,像星星一样排成一排,...
一直以来!上饶窝龙辅助(辅助)... 一直以来!上饶窝龙辅助(辅助)切实真的是有辅助技巧(有挂分享)1、许多玩家不知道上饶窝龙辅助辅助怎么...
明白辅助挂!开心斗一番破解版(... 明白辅助挂!开心斗一番破解版(辅助)总是真的是有辅助插件(有挂教学)1、在开心斗一番破解版插件功能辅...
无独有偶!花花生活圈怎么开挂(... 无独有偶!花花生活圈怎么开挂(辅助)果然存在有辅助神器(竟然有挂)该软件可以轻松地帮助玩家将花花生活...
2026版软件!山西扣点免费辅... 2026版软件!山西扣点免费辅助(辅助)本来存在有辅助脚本(详细教程)暗藏猫腻,小编详细说明山西扣点...
黑科技攻略!悟空大厅辅助(辅助... 黑科技攻略!悟空大厅辅助(辅助)切实真的是有辅助攻略(真的有挂);1、不需要AI权限,帮助你快速的进...
2026版总结!微信小程序辅助... 2026版总结!微信小程序辅助新天道辅助(辅助)一直是有辅助技巧(有挂功能)1、点击下载安装,微信小...
第三方辅助挂!三哥玩辅助器软件... 第三方辅助挂!三哥玩辅助器软件(辅助)果然是真的有辅助软件(有挂教学)1)三哥玩辅助器软件辅助插件:...