高斯消去法 | LU分解 | PA=LU分解(MatLab)

一、问题描述

利用高斯消去法,LU 分解及PA=LU 分解求解非线性方程组。

二、实验目的

掌握高斯消去法、LU 分解、PA=LU 分解的算法原理;编写代码实现利用高斯消去法、LU 分解、PA=LU 分解来求解线性方程组。

三、实验内容及要求

1. 利用顺序高斯消去法求解如下方程组。

请添加图片描述

(注意将顺序高斯消去法封装为一个函数,函数名Gauss,该函数对应的文件同样命名为Gauss)。

function x = Gauss(A, b)n = length(b);for k = 1:n-1for i = k+1:nfactor = A(i,k) / A(k,k);A(i,k+1:n) = A(i,k+1:n) - factor * A(k,k+1:n);b(i) = b(i) - factor * b(k);endendx = zeros(n, 1);x(n) = b(n) / A(n,n);for i = n-1:-1:1x(i) = (b(i) - A(i,i+1:n) * x(i+1:n)) / A(i,i);end
end% 使用例子
A = [2 -2 -1; 4 1 -2; -2 1 -1];
b = [-2; 1; -3];
x = Gauss(A, b);
disp(x);

2. 对1 中的线性方程组,利用LU 分解进行求解,并输出L 和U。

(注意将本部分代码封装为一个函数,函数名LU,该函数对应的文件同样命名为LU)。

function [L, U] = LU(A)[n,~] = size(A);L = eye(n);U = A;for k = 1:n-1for i = k+1:nfactor = U(i,k) / U(k,k);L(i,k) = factor;U(i,k:n) = U(i,k:n) - factor * U(k,k:n);endend
end% 使用例子
A = [2 -2 -1; 4 1 -2; -2 1 -1];
[L, U] = LU(A);
disp(L);
disp(U);

3. 对1 中的线性方程组,利用PA=LU 分解进行求解,并输出P、L 和U。

(注意将本部分代码封装为一个函数,函数名PLU,该函数对应的文件同样命名为PLU)。

function [P, L, U] = PLU(A)[n,~] = size(A);P = eye(n);L = zeros(n);U = A;for k = 1:n-1[~, maxindex] = max(abs(U(k:n,k)));maxindex = maxindex + k - 1;U([k,maxindex],:) = U([maxindex,k],:);L([k,maxindex],1:k-1) = L([maxindex,k],1:k-1);P([k,maxindex],:) = P([maxindex,k],:);for i = k+1:nfactor = U(i,k) / U(k,k);L(i,k) = factor;U(i,k:n) = U(i,k:n) - factor * U(k,k:n);endendL = L + eye(n);
end% 使用例子
A = [2 -2 -1; 4 1 -2; -2 1 -1];
[P, L, U] = PLU(A);
disp(P);
disp(L);
disp(U);

四、算法原理

1. 给出高斯消去法、LU 分解、PA=LU 分解的算法原理

  • 高斯消去法
    高斯消去法是一种用于解线性方程组的算法,它的目标是将给定的系数矩阵转化为上三角矩阵(或更进一步转化为对角矩阵),这样可以直接使用回代法求解未知数。

    步骤

    1. 选取主元(通常是当前列下的最大绝对值元素)。
    2. 使用主元所在的行减去其他行,从而消去该列下主元以下的所有元素。
    3. 对下一个列重复以上步骤,直到整个矩阵成为上三角形态。
    4. 使用回代法求解未知数。
  • LU 分解
    LU分解是将系数矩阵A分解为一个下三角矩阵L和一个上三角矩阵U的过程。这样原方程组Ax=b变为LUx=b,先解Ly=b得到y,再解Ux=y得到x。

    步骤

    1. 从第一行开始,将A的当前行元素存储在U的相应位置,将除对角线元素外的当前列元素存储在L的相应位置。
    2. 使用L的当前列元素与U的当前行元素更新A的剩余部分。
    3. 对于下一个列重复上述步骤。
  • PA=LU 分解
    有时直接的LU分解不可能或者数值上不稳定,这时可以通过行交换获得稳定性。PA=LU分解将A分解为一个置换矩阵P、一个下三角矩阵L和一个上三角矩阵U。

    步骤

    1. 选择一个主元并进行必要的行交换。
    2. 按照LU分解的方法更新L和U的元素。
    3. 对下一个列重复以上步骤。

2. 分别给出高斯消去法、LU 分解消去和回代过程的耗费的计算量。

  • 高斯消去法
    消去过程的计算量大约为(2/3)n3,而回代过程为n2。所以总的计算量大约是O(n^3)。

  • LU 分解
    LU分解的计算量和高斯消去法类似,主要来自于消去过程,大约为(2/3)n3。回代过程是O(n2),所以总的计算量仍然是O(n^3)。

  • PA=LU 分解
    PA=LU分解的计算量和LU分解相似,因为增加的主要是行交换操作,这不会显著增加计算量。所以总的计算量仍然是O(n^3)。

五、测试数据及结果

  1. 给出算法输出的方程组的解。
    请添加图片描述

  2. 给出算法输出的方程组的解及L 和U。
    请添加图片描述

  3. 给出算法输出的方程组的解及P、L 和U。
    请添加图片描述

六、总结与思考

  1. 知识点的理解

    通过本次MATLAB实验,我深化了对线性代数中几个关键算法的理解:高斯消去法、LU分解和PA=LU分解。这些算法是解线性方程组的基石,并且在各种应用领域中都有广泛的使用。

  2. 代码实现的技巧

    • 使用MATLAB进行矩阵操作相对简单。例如,我们可以轻松地进行矩阵乘法、提取子矩阵和矩阵分解。
    • 通过封装代码为函数,可以使整体代码结构更清晰、模块化,并增强代码的可读性和重用性。
    • 适当的注释和文档对于理解和后期修改代码非常重要。

思考

  1. 算法的应用

    虽然这三种算法在解决线性方程组方面很有用,但它们在处理大型矩阵或具有特定结构的矩阵时可能并不是最优的。例如,对于稀疏矩阵或对称正定矩阵,可能存在更高效的算法。考虑不同的问题背景和矩阵特点来选择合适的算法是很重要的。

  2. 数值稳定性

    实验中,我们简单地实现了上述算法,但在实际应用中,数值稳定性是一个需要考虑的重要问题。特别是在高斯消去法中,如果不适当地选择主元,可能会导致数值不稳定。这就是为什么PA=LU分解(带有行交换)在某些情况下更受欢迎。

  3. 优化与进一步学习

    MATLAB提供了一系列的内置函数和工具箱,例如lu函数,可以直接进行LU分解。通过比较我们自己的实现和MATLAB的内置函数,我们可以进一步了解性能和数值稳定性的问题,并从中学习。

综上,本次MATLAB实验不仅加深了我计算方法的理解,而且让我认识到在实际应用中考虑算法的数值稳定性和选择最适合的算法的重要性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/453593.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言标准库所有字符串操作库函数汇总

以下是C语言标准库中字符串操作相关的API列表&#xff0c;这些函数通常在 <string.h> 头文件中定义&#xff1a; 1. strlen - 计算字符串长度&#xff0c;不包括结尾的空字符\0&#xff1a; size_t strlen(const char *str); 2. strcpy - 复制字符串&#xff1a; c…

【Linux】信号-上

欢迎来到Cefler的博客&#x1f601; &#x1f54c;博客主页&#xff1a;折纸花满衣 &#x1f3e0;个人专栏&#xff1a;题目解析 &#x1f30e;推荐文章&#xff1a;【LeetCode】winter vacation training 目录 &#x1f449;&#x1f3fb;信号的概念与产生jobs命令普通信号和实…

154基于matlab的二维元胞自动机模拟森林火灾(生命游戏 )和模拟收费站交通流

基于matlab的二维元胞自动机模拟森林火灾&#xff08;生命游戏 &#xff09;和模拟收费站交通流。全国大学生美国建模竞赛&#xff0c;程序已调通&#xff0c;可直接运行。 154 元细胞自动机 森林起火 收费站交通 (xiaohongshu.com)

Python flask 模板详解

文章目录 1 概述1.1 模板简介1.2 templates 文件1.3 简单应用 2 模板语法2.1 for 循环2.2 if 判断 3 模板的继承3.1 格式要求3.2 实现示例3.3 复用父模板的内容&#xff1a;super 1 概述 1.1 模板简介 定义&#xff1a;定义好的 html 文件&#xff0c;用于快速开发 web 页面J…

【linux】git和gdb调试工具

在linux下提交代码同步到gitee 1.创建一个新的仓库&#xff08;演示步骤&#xff09; 2.init 这两个步骤用于识别提交代码的身份&#xff0c;一个你的名字&#xff0c;一个你的邮箱 开启本地仓库 克隆本地仓库成功 我们将这个仓库拷到了111目录底下. 我们发现少了一个.gitig…

Centos 7.5 安装 NVM 详细步骤

NVM&#xff08;Node Version Manager&#xff09;是一个用于管理Node.js版本的工具&#xff0c;它可以让你轻松地在多个版本之间切换。NVM 通过下载和管理 Node.js 的多个版本&#xff0c;为用户提供了一种灵活的方式来使用不同版本的 Node.js。如果你需要更多关于NVM的信息&a…

【云原生之kubernetes系列】--污点与容忍

污点与容忍 污点&#xff08;taints)&#xff1a;用于node节点排斥Pod调度&#xff0c;与亲和效果相反&#xff0c;即taint的node排斥Pod的创建容忍&#xff08;toleration)&#xff1a;用于Pod容忍Node节点的污点信息&#xff0c;即node节点有污点&#xff0c;也将新的pod创建…

超时引发的牛角尖二(hystrix中的超时)

至今我都清楚记得自己负责的系统请求云上关联系统时所报的异常信息。为了解决这个异常&#xff0c;我坚持让这个关联系统的负责人查看&#xff0c;并且毫不顾忌他的嘲讽和鄙视&#xff0c;甚至无视他烦躁的情绪。不过我还是高估了自己的脸皮&#xff0c;最终在其恶狠狠地抛下“…

Blender_查看版本

Blender_查看版本 烦人的烦恼&#xff0c;没找见哪儿可以查看版本&#xff1f; 算是个隐蔽的角落&#xff01;

[设计模式Java实现附plantuml源码~结构型]处理多维度变化——桥接模式

前言&#xff1a; 为什么之前写过Golang 版的设计模式&#xff0c;还在重新写Java 版&#xff1f; 答&#xff1a;因为对于我而言&#xff0c;当然也希望对正在学习的大伙有帮助。Java作为一门纯面向对象的语言&#xff0c;更适合用于学习设计模式。 为什么类图要附上uml 因为很…

10_机械臂运动学_机械臂C++逆解——2023

就是算&#xff01; 遨博机械臂改进DH参数表&#xff1a; 机械臂正运动学连杆变换通式&#xff1a; 其中si代表sin(θi),ci代表cos(θi) sij代表sin(θi-θj),cij代表cos(θi-θj) sijk代表sin(θi-θjθk),cijk代表cos(θi-θj-θk)&#xff0c;用两角和差公式直接展开即可. 每…

[Linux 进程控制(二)] 写时拷贝 - 进程终止

文章目录 1、写时拷贝2、进程终止2.1 进程退出场景2.1.1 退出码2.1.2 错误码错误码 vs 退出码2.1.3 代码异常终止引入 2.2 进程常见退出方法2.2.1 exit函数2.2.2 _exit函数 本片我们主要来讲进程控制&#xff0c;讲之前我们先把写时拷贝理清&#xff0c;然后再开始讲进程控制。…