matlab中高精度计算函数vpa与非厄米矩阵本征值的求解

bash 复制代码
clear;clc;close all
tic
%并行设置%
delete(gcp('nocreate'));%关闭之前的并行
c=parcluster('local');
c.NumWorkers=50;%手动设置线程数(否则默认最大线程为12)
parpool(c, c.NumWorkers);
%并行设置%

w=1;
u=2.5;

N=30;


valsto=zeros(2*N+2,100);
v10=linspace(-3,3,100).';


parfor jj=1:length(v10)


    v1=v10(jj);

    [~,val]=eig(vpa(H(u,v1,w,N),30));%设置30位高精度计算
    %[~,val]=eig(H(u,v1,w,N));
    tval=diag(val);
    [~,index]=sort(real(tval));
    val=tval(index);
    valsto(:,jj)=val;

end

figure
hold on
plot(linspace(-3,3,100),abs(valsto(:,:)),'k.')

%%%%%%%%%%=========%%%%%%%%%%%%%%
%%%%%%%%%%=========%%%%%%%%%%%%%%



clearvars -except N
syms u v w real


val2=eig(H(u,v,w,N));
val2=subs(val2,{u,w},{2.5,1});

valsto2=zeros(2*N+2,100);
v10=linspace(-3,3,100).';


parfor jj=1:length(v10)


    v1=v10(jj);
    tval=val2;
    tval=double(subs(tval,v,v1));
    [~,index]=sort(real(tval));
    tval=tval(index);
    valsto2(:,jj)=tval;

end

plot(linspace(-3,3,100),abs(valsto2(:,:)),'bo')
hold off
saveas(gcf,"VAPtest0.fig")
toc

function [H0]=H(u,v,w,N)

T1=[];
T2=[];
for hh=1:N
    T1=[T1;v+u;w+u];
    T2=[T2;v-u;w-u];
end
T1=[T1;v+u];
T2=[T2;v-u];
H0=diag(T1,1)+diag(T2,-1);


end

上面代码没用高精度计算函数vpa之前数值计算的特征值能谱有部分和符号计算(篮圈)是对不上的,如下:

使用了vpa高精度函数后,数值计算和符号计算的结果完全一致:

相关推荐
-一杯为品-4 小时前
【机器人学|运动学与动力学】#1 齐次变换矩阵
线性代数·矩阵
Dev7z8 小时前
基于MATLAB的零件表面缺陷检测系统设计与实现
开发语言·人工智能·matlab
foundbug9998 小时前
基于MATLAB Simulink的双向DC-DC变换器仿真程序实现
开发语言·matlab
可编程芯片开发8 小时前
基于静止坐标系和正交坐标系的非对称六相电机simulink建模与仿真
matlab·simulink·静止坐标系·正交坐标系·非对称六相电机
胖咕噜的稞达鸭10 小时前
算法入门:专题前缀和:一二维前缀和 寻找数组的中心下标 除自身以外数组的乘积 和为k的子数组 和可被k整除的子数组 连续数组 矩阵区域和
线性代数·算法·矩阵
民乐团扒谱机11 小时前
【微实验】谱聚类之大规模数据应用——Nyström 方法
人工智能·算法·机器学习·matlab·数据挖掘·聚类·谱聚类
wuk99812 小时前
基于Jousselme距离的改进D-S证据理论MATLAB实现
matlab
拾贰_C12 小时前
【数学 | 大学数学 | 考研数学 | 计算机】线性代数 | 矩阵论
线性代数·矩阵
chen_jared13 小时前
opencv和matlab中相机内参标定模型
opencv·matlab·相机内参标定
hoiii1871 天前
MATLAB实现Canny边缘检测算法
算法·计算机视觉·matlab