数值分析算法 MATLAB 实践 线性方程组 分解法

简介: 数值分析算法 MATLAB 实践 线性方程组 分解法

数值分析算法 MATLAB 实践 线性方程组 分解法

Lu分解法

% LUmethod分解矩阵
function [L,U]=LUmethod(A)
[rows,~]=size(A);
temp_mat=A;
L=zeros(rows);
for i=1:rows
    coefficient=temp_mat(:,i);
    coefficient=coefficient./coefficient(i);
    coefficient(1:i)=0;
    L(:,i)=coefficient;
    temp_mat=-coefficient*temp_mat(i,:)+temp_mat;
end
U=temp_mat;
L(eye(rows)==1)=1;
end
% LUmethod分解矩阵 求解线性方程组
function x=LUsolve(L,U,b)
[rows,~]=size(L);
aug_mat=[L,b];
for i=1:rows
    aug_mat(i,:)=aug_mat(i,:)./aug_mat(i,i);
    coefficient=-aug_mat(:,i);
    coefficient(1:i)=0;
    aug_mat=coefficient*aug_mat(i,:)+aug_mat;
end
aug_mat=[U,aug_mat(:,rows+1:end)];
for i=rows:-1:1
    aug_mat(i,:)=aug_mat(i,:)./aug_mat(i,i);
    coefficient=-aug_mat(:,i);
    coefficient(i:end)=0;
    aug_mat=coefficient*aug_mat(i,:)+aug_mat;
end
x=aug_mat(:,rows+1:end);
x=x';
end
function solution=LuFunmethon(M, Presion) 
 % LU分解 M为用户输入的增广矩阵
 % Precision为用户所输入的精度要求
    if nargin==2
      try
         digits(Precision);
      cath
         disp('你输入的精度有误');digits(10);
      end
    else
      digits(10);
    end     

    A=vpa(M)
    row=size(A,1);
    col=size(A,2);
    if ndims(A)~=2|(col-row)~=1
        disp('矩阵的大小有误');
        return
    end
    if det(M(:,1:row))==0
        disp('该方程的系数矩阵行列式为零');
        return
    end
%% 调用系统的LU命令
       [L,U,P]=lu(double(A));
      %% 回代求解过程
    for i=row:-1:1
        temp=U(i,col);
        for k=i+1:row
            temp=vpa(temp-t_solution(k)*U(i,k));
        end
            t_solution(i)=vpa(temp/U(i,i));
    end
    for i=1:row
        temp=t_solution(i);
        for k=1: i-1
            temp=vpa(temp-t_solution(k)*U(i,k));
        end
             solution(i)=temp;
    end
end

Cholesky分解

%% 0.平方根法解线性方程组,输出L矩阵和根
%% 1.对称正定矩阵的Cholesky分解
%对称正定矩阵A存在唯一的对角元素均为正数的下三角矩阵L,使得A=L*L'
%这种分解叫做Cholesky分解
A=[3,3,5;3,5,9;5,9,17];
b=[0;-2;-4];
%L=chol(A,'lower')基于矩阵A的对角线和下三角形生成下三角矩阵L,满足方程L*L'=A
L=chol(A,'lower')
%% 2.由Ly=b得到y
y=L\b;
%% 3.由L_转置*x=y得到方程组的解x
x=L'\y%输出线性方程组的根

function x = Cholesky_method(A,b)
%Cholesky平方根法解方程组
%A为方程组的系数矩阵 b为方程组的右端项;
    n = length(A);
    L = zeros(n);
    for k = 1:n
        delta = A(k,k);
        for j = 1:k-1
            delta = delta-L(k,j)^2;
        end

        L(k,k) = sqrt(delta);
        for i = k+1:n
            L(i,k) = A(i,k);
            for j = 1:n-1
                L(i,k) = L(i,k)-L(i,j)*L(k,j);
            end
            L(i,k) = L(i,k)/L(k,k);
        end

    end
    L 
    x =zeros(n,1);
    y =zeros(n,1);
    y(1) = b(1)/L(1,1);
    for i = 2:n
        ly = 0;
        for j = 1:i-1
            ly = ly+L(i,j)*y(i);
        end
        y(i) = (b(i)-ly)/L(i,i);
    end
    x(n) = y(n)/L(n,n);
    for i = n-1:-1:1
        lx = 0;
        for j = i+1:n
            lx = lx+L(j,i)*x(j);
        end
        x(i) = (y(i)-lx)/L(i,i);
    end
end

%Cholesky平方根法解方程组
%A为方程组的系数矩阵 b为方程组的右端项;
A6= [1 2 -1;2 5 1; -1 1 14];
b6 = [3;4;3];
x6 = Cholesky_method(A6,b6);
disp(['方程组的解:x6= ']);
disp(x6)

Cholesky分解--改进平方根法

function x=chol_ldlt_method(A,b)
%function x=chol_ldlt_method(A,b)
%Cholesky改进平方根法解方程组
%A为方程组的系数矩阵 b为方程组的右端项;
    n = length(A);
    L = eye(n);
    D = zeros(n);
    d = zeros(1,n);
    T = zeros(n);
    for k =1:n
        d(k) = A(k,k);
        for j = 1:k-1
            d(k)=d(k)-L(k,j)*T(k,j);
        end
        for i=k+1:n
            T(i,k) = A(i,k);
            for j = 1:k-1
                T(i,k) =T(i,k) -T(i,j)*L(k,j);
            end
            L(i,k) = T(i,k)/d(k);
        end
    end
    D = diag(d);
    L
    D
    x =zeros(n,1);
    y =zeros(n,1);
    d1 = zeros(n,1);
    d1 = diag(D);
    y(1) = b(1);
    for i =2:n
        ly = 0;
        for k=1:i-1
            ly = ly+L(i,k)*y(k);
        end
        y(i) = b(i)-ly;
    end
    x(n) = y(n)/d1(n);
    for i = n-1:-1:1
        lx = 0;
        for k=i+1:n
            lx = lx+L(k,i)*x(k);
        end
        x(i) = y(i)/d1(i)-lx;
end
%function x=chol_ldlt_method(A,b)
%Cholesky改进平方根法解方程组
%A为方程组的系数矩阵 b为方程组的右端项;
A7= [1 2 -1;2 5 1; -1 1 14];
b7 = [3;4;3];
x7=chol_ldlt_method(A7,b7);
disp(['方程组的解:x7= ']);
disp(x7)

奇异值分解法

%奇异值分解计算线性方程组
a=[6.5 -1 -1 3.6
6.2 7 -5 4
3 2.1 -6 4.8
1 5.6 3.7 2.1];
b=[12.3 21.4 -7.8 21]';
[u,s,v]=svd(a)
x=v*inv(s)*u'*b
目录
相关文章
|
5天前
|
算法 安全 数据库
基于结点电压法的配电网状态估计算法matlab仿真
**摘要** 该程序实现了基于结点电压法的配电网状态估计算法,旨在提升数据的准确性和可靠性。在MATLAB2022a中运行,显示了状态估计过程中的电压和相位估计值,以及误差随迭代变化的图表。算法通过迭代计算雅可比矩阵,结合基尔霍夫定律解决线性方程组,估算网络节点电压。状态估计过程中应用了高斯-牛顿或莱文贝格-马夸尔特法,处理量测数据并考虑约束条件,以提高估计精度。程序结果以图形形式展示电压幅值和角度估计的比较,以及估计误差的演变,体现了算法在处理配电网状态估计问题的有效性。
|
1天前
|
数据采集 存储 算法
基于BP算法的SAR成像matlab仿真
**摘要:** 基于BP算法的SAR成像研究,利用MATLAB2022a进行仿真。SAR系统借助相对运动合成大孔径,提供高分辨率图像。BP算法执行回波数据预处理、像素投影及图像重建,实现精确成像。优点是高精度和强适应性,缺点是计算量大、内存需求高。代码示例展示了回波生成、数据处理到插值显示的全过程。
|
2天前
|
算法 vr&ar
基于自适应波束成形算法的matlab性能仿真,对比SG和RLS两种方法
```markdown - MATLAB2022a中比较SG与RLS自适应波束成形算法。核心程序实现阵列信号处理,强化期望信号,抑制干扰。RLS以其高效计算权重,而SG则以简单和低计算复杂度著称。[12345] [6666666666] [777777] ```
|
3天前
|
算法 索引
基于Prony算法的系统参数辨识matlab仿真
Prony算法在MATLAB2022a中用于信号分析,识别复指数信号成分。核心程序通过模拟信号X1,添加不同SNR的噪声,应用Prony方法处理并计算误差。算法基于离散序列的复指数叠加模型,通过构建矩阵并解线性方程组估计参数,实现LTI系统动态特性的辨识。
|
1天前
|
传感器 算法
基于无线传感器网络的LC-DANSE波束形成算法matlab仿真
摘要: 此MATLAB程序对比了LC-DANSE与LCMV波束形成算法在无线传感器网络中的性能,基于SNR和MSE指标。测试在MATLAB 2022a环境下进行。核心代码涉及权重更新迭代,用于调整传感器节点权重以增强目标信号。LC-DANSE是分布式自适应算法,关注多约束条件下的噪声抑制;LCMV则是经典集中式算法,侧重单个期望信号方向。两者在不同场景下各有优势。程序结果显示SNR和MSE随迭代变化趋势,并保存结果数据。
|
9天前
|
机器学习/深度学习 自然语言处理 算法
m基于深度学习的OFDM+QPSK链路信道估计和均衡算法误码率matlab仿真,对比LS,MMSE及LMMSE传统算法
**摘要:** 升级版MATLAB仿真对比了深度学习与LS、MMSE、LMMSE的OFDM信道估计算法,新增自动样本生成、复杂度分析及抗频偏性能评估。深度学习在无线通信中,尤其在OFDM的信道估计问题上展现潜力,解决了传统方法的局限。程序涉及信道估计器设计,深度学习模型通过学习导频信息估计信道响应,适应频域变化。核心代码展示了信号处理流程,包括编码、调制、信道模拟、降噪、信道估计和解调。
31 8
|
11天前
|
算法
基于GA遗传优化的混合发电系统优化配置算法matlab仿真
**摘要:** 该研究利用遗传算法(GA)对混合发电系统进行优化配置,旨在最小化风能、太阳能及电池储能的成本并提升系统性能。MATLAB 2022a用于实现这一算法。仿真结果展示了一系列图表,包括总成本随代数变化、最佳适应度随代数变化,以及不同数据的分布情况,如负荷、风速、太阳辐射、弃电、缺电和电池状态等。此外,代码示例展示了如何运用GA求解,并绘制了发电单元的功率输出和年变化。该系统原理基于GA的自然选择和遗传原理,通过染色体编码、初始种群生成、适应度函数、选择、交叉和变异操作来寻找最优容量配置,以平衡成本、效率和可靠性。
|
12天前
|
机器学习/深度学习 算法
基于鲸鱼优化的knn分类特征选择算法matlab仿真
**基于WOA的KNN特征选择算法摘要** 该研究提出了一种融合鲸鱼优化算法(WOA)与K近邻(KNN)分类器的特征选择方法,旨在提升KNN的分类精度。在MATLAB2022a中实现,WOA负责优化特征子集,通过模拟鲸鱼捕食行为的螺旋式和包围策略搜索最佳特征。KNN则用于评估特征子集的性能。算法流程包括WOA参数初始化、特征二进制编码、适应度函数定义(以分类准确率为基准)、WOA迭代搜索及最优解输出。该方法有效地结合了启发式搜索与机器学习,优化特征选择,提高分类性能。
|
7天前
|
机器学习/深度学习 存储 算法
基于SFLA算法的神经网络优化matlab仿真
**摘要:** 使用MATLAB2022a,基于SFLA算法优化神经网络,降低训练误差。程序创建12个神经元的前馈网络,训练后计算性能。SFLA算法寻找最优权重和偏置,更新网络并展示训练与测试集的预测效果,以及误差对比。SFLA融合蛙跳与遗传算法,通过迭代和局部全局搜索改善网络性能。通过调整算法参数和与其他优化算法结合,可进一步提升模型预测精度。
|
12天前
|
机器学习/深度学习 算法 数据可视化
基于BP神经网络的64QAM解调算法matlab性能仿真
**算法预览图省略** MATLAB 2022A版中,运用BP神经网络进行64QAM解调。64QAM通过6比特映射至64复数符号,提高数据速率。BP网络作为非线性解调器,学习失真信号到比特的映射,对抗信道噪声和多径效应。网络在处理非线性失真和复杂情况时展现高适应性和鲁棒性。核心代码部分未显示。