解线性方程组——(Jacobi)雅克比迭代法 | 北太天元

一、Jacobi迭代法

n = 3 n=3 n=3 , 阶数为 3 时
A = ( a 11 a 12 a 13 a 21 a 22 a 23 a 31 a 32 a 33 ) , b = ( b 1 b 2 b 3 ) , A=\begin{pmatrix} a_{11} & a_{12} &a_{13}\\ a_{21} & a_{22} &a_{23}\\ a_{31} & a_{32} &a_{33}\\ \end{pmatrix} ,\quad b=\begin{pmatrix} b_1\\b_2\\ b_3 \end{pmatrix}, A= a11a21a31a12a22a32a13a23a33 ,b= b1b2b3 ,

Jacobi公式为
x 1 ( k + 1 ) = b 1 − a 12 x 2 ( k ) − a 13 x 3 ( k ) a 11 x 2 ( k + 1 ) = b 2 − a 21 x 1 ( k ) − a 23 x 3 ( k ) a 22 x 3 ( k + 1 ) = b 3 − a 31 x 1 ( k ) − a 32 x 2 ( k ) a 33 \begin{gathered} x_1^{(k+1)} =\frac{b_{1}-a_{12}x_{2}^{(k)}-a_{13}x_{3}^{(k)}}{a_{11}} \\ x_2^{(k+1)} =\frac{b_{2}-a_{21}x_{1}^{(k)}-a_{23}x_{3}^{(k)}}{a_{22}} \\ x_3^{(k+1)} =\frac{b_{3}-a_{31}x_{1}^{(k)}-a_{32}x_{2}^{(k)}}{a_{33}} \end{gathered} x1(k+1)=a11b1a12x2(k)a13x3(k)x2(k+1)=a22b2a21x1(k)a23x3(k)x3(k+1)=a33b3a31x1(k)a32x2(k)
由公式可以看出 ,每一次迭代的各个分量都是独立计算的,这也是为什么Jacobi迭代可以用于并行计算。

或等价的,将 A A A 分解为 A = D − L − U A=D-L-U A=DLU,其中
D = d i a g ( a 11 , a 22 , a 33 ) , D=diag(a_{11},a_{22},a_{33}), D=diag(a11,a22,a33), L = − [ 0 0 0 a 21 0 0 a 31 a 32 0 ] , U = − [ 0 a 12 a 13 0 0 a 23 0 0 0 ] . L=-\begin{bmatrix} 0 & 0 &0\\ a_{21} & 0&0\\ a_{31} & a_{32} &0\\ \end{bmatrix},\quad U=-\begin{bmatrix} 0 & a_{12} &a_{13}\\ 0 & 0&a_{23}\\ 0 & 0 &0\\ \end{bmatrix}. L= 0a21a3100a32000 ,U= 000a1200a13a230 . ( D − L − U ) x = b D x = b + ( L + U ) x x = D − 1 ( b + ( L + U ) x ) \begin{gathered} (D-L-U)x = b\\ Dx = b+(L+U)x\\ x=D^{-1}(b+(L+U)x)\\ \end{gathered} (DLU)x=bDx=b+(L+U)xx=D1(b+(L+U)x)
得Jacobi公式 x ( k + 1 ) = D − 1 ( b + ( L + U ) x ( k ) ) x^{(k+1)}=D^{-1}(b+(L+U)x^{(k)}) x(k+1)=D1(b+(L+U)x(k))
写成矩阵的形式
[ x 1 ( k + 1 ) x 2 ( k + 1 ) x 3 ( k + 1 ) ] = [ 1 a 11 1 a 22 1 a 33 ] ( [ b 1 b 2 b 3 ] − [ a 12 a 13 a 21 a 23 a 31 a 32 ] [ x 1 ( k ) x 2 ( k ) x 3 ( k ) ] ) \begin{bmatrix} x_1^{(k+1)}\\x_2^{(k+1)}\\ x_3^{(k+1)} \end{bmatrix} = \begin{bmatrix} \frac{1}{a_{11}} & &\\ & \frac{1}{a_{22}} &\\ & &\frac{1}{a_{33}}\\ \end{bmatrix}\left( \begin{bmatrix} b_1\\b_2\\ b_3 \end{bmatrix}-\begin{bmatrix} & a_{12} &a_{13}\\ a_{21} & &a_{23}\\ a_{31} & a_{32} &\\ \end{bmatrix}\begin{bmatrix} x_1^{(k)}\\x_2^{(k)}\\ x_3^{(k)} \end{bmatrix}\right) x1(k+1)x2(k+1)x3(k+1) = a111a221a331 b1b2b3 a21a31a12a32a13a23 x1(k)x2(k)x3(k)
下面是其一般形式下的算法

二、算法

💖 Jacobi迭代法

主要思路

输入: A , b , x ( 0 ) A,b,x^{(0)} A,b,x(0),输出 x x x
x ( 0 ) = initial vector  x ( k + 1 ) = D − 1 ( b + ( L + U ) x ( k ) ) \begin{aligned} x^{(0)} &= \text{ initial vector } \\ x^{(k+1)} &= D^{-1}(b+(L+U)x^{(k)}) \end{aligned} x(0)x(k+1)= initial vector =D1(b+(L+U)x(k))

添加一些限制

  • 容许误差 e_tol
  • 最大迭代步 N N N

当 残差 < e_tol 或 迭代步数 ≥ N \geq N N 时,停止迭代,输出结果

实现步骤

  • 步骤 1: k = 0 k=0 k=0 x = x ( 0 ) x=x^{(0)} x=x(0)
  • 步骤 2: 计算残差 r = ∥ b − A x ∥ r=\|b-Ax\| r=bAx
    • 如果残差 r r r > e_tol 且 k < N k<N k<N,转步骤 3;
    • 否则,转步骤 5;
  • 步骤 3: 更新解向量
    x = D − 1 ( b + ( L + U ) x ( 0 ) ) x=D^{-1}(b+(L+U)x^{(0)}) x=D1(b+(L+U)x(0))
  • 步骤 4: x 0 = x x0=x x0=x k = k + 1 k=k+1 k=k+1,转步骤 2;
  • 步骤 5: 输出 x x x

在这里插入图片描述

三、北太天元源程序

Jacobi迭代

function [x,k,r] = myJacobi(A,b,x0,e_tol,N)
% Jacobi迭代法解线性方程组
% Input: A, b(列向量), x0(初始值)
%        e_tol: error tolerant  
%        N: 限制迭代次数小于 N 次
% Output: x , k(迭代次数),r:残差
%   Version:            1.0
%   last modified:      01/27/2024n = length(b); k = 0; x=zeros(n,N); % 记录每一次迭代的结果,方便后续作误差分析x(:,1)=x0; L = -tril(A,-1); U = -triu(A,1); D = diag(diag(A));r = norm(b - A*x,2);while r > e_tol && k < Nx(:,k+2) = inv(D)*(b+(L+U)*x(:,k+1));r = norm(b - A*x(:,k+2),2); % 残差k = k+1;endx = x(:,2:k+1); % x取迭代时的结果if k>Nfprintf('迭代超出最大迭代次数');elsefprintf('迭代次数=%i\n',k);end
end

保存为 myJacobi.m文件

四、数值算例

例1

A x = b Ax=b Ax=b,求 x x x
A = ( 10 − 1 2 0 − 1 11 − 1 3 2 − 1 10 − 1 0 3 − 1 8 ) b = ( 6 25 − 11 15 ) A = \begin{pmatrix} 10 & -1 & 2 & 0 \\ -1 & 11 & -1 & 3 \\ 2 & -1 & 10 & -1 \\ 0 & 3 & -1 & 8 \\ \end{pmatrix}\quad b = \begin{pmatrix} 6 \\ 25 \\ -11 \\ 15 \\ \end{pmatrix} A= 1012011113211010318 b= 6251115

用Gauss列主元消去法,得

x = 1.0000000000000002.000000000000000-1.0000000000000001.000000000000000

下面我们用Jacobi迭代法进行求解

设 N = 100 , e_tol = 1e-8, x0=[0; 0; 0; 0]

clc;clear all,format long;
N = 100; e_tol = 1e-8;
A=[10 -1 2 0; -1 11 -1 3; 2 -1 10 -1; 0 3 -1 8];
b=[6; 25; -11; 15];
x0=[0; 0; 0; 0];
t1 =tic;[x11,k1] = myJacobi(A,b,x0,e_tol,N)
toc(t1);
t2 = tic;[x12] = gsem_column(A,b)
toc(t2);
% 作图查看误差变化x_exact=[1;2;-1;1]; %真解n = length(b);error=zeros(n,k1);% 每个分量的误差error = abs(x_exact - x11) res =zeros(1,k1); % 残差for i=1:1:k1res(i) = norm(b-A*x11(:,i),2);end % 数值解figure(1);plot(1:k1,x11(1,:),'-*r',1:k1,x11(2,:),'-og', 1:k1,x11(3,:),'-+b',1:k1,x11(4,:),'-dk');legend('x_1','x_2','x_3','x_4');title('每个数值解的变化')% 残差变化figure(2);plot(1:k1,res,'-*r');legend('残差');title('残差变化')% 误差figure(3);plot(1:k1,error(1,:),'-*r',1:k1,error(2,:),'-og', 1:k1,error(3,:),'-+b',1:k1,error(4,:),'-dk');legend('x_1','x_2','x_3','x_4');title('误差变化')

迭代次数=26

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

例2

[ 3 − 1 0 0 0 1 2 − 1 3 − 1 0 1 2 0 0 − 1 3 − 1 0 0 0 0 − 1 3 − 1 0 0 1 2 0 − 1 3 − 1 1 2 0 0 0 − 1 3 ] [ x 1 x 2 x 3 x 4 x 4 x 5 x 6 ] = [ 5 2 3 2 1 1 3 2 5 2 ] . \begin{bmatrix}3&-1&0&0&0&\frac{1}{2}\\-1&3&-1&0&\frac{1}{2}&0\\0&-1&3&-1&0&0\\0&0&-1&3&-1&0\\0&\dfrac{1}{2}&0&-1&3&-1\\\frac{1}{2}&0&0&0&-1&3\end{bmatrix}\begin{bmatrix}x_1\\x_2\\x_3\\x_4\\x_4\\x_5\\x_6\end{bmatrix}=\begin{bmatrix}\frac{5}{2}\\ \frac{3}{2}\\1\\1\\\frac{3}{2}\\\frac{5}{2}\end{bmatrix}. 3100021131021001310000131002101312100013 x1x2x3x4x4x5x6 = 2523112325 .
使用Gauss消去法与Jacobi迭代法分别对其进行求解,并观察有何差异。
试着得到在更高阶数下的结果。

x x x的真解为 [ 1 , 1 , 1 , 1 , 1 , 1 ] T [1,1,1,1,1,1]^T [1,1,1,1,1,1]T

稀疏矩阵的构造:

function [A,b,x_sp] = setup_Sparse1(n)% 定义一个 n 阶的稀疏矩阵, 真解全为1% Input: n% Output: A,b%%   Version:            1.0%   last modified:      09/28/2023A = zeros(n,n);b = ones(n,1) * 1.5;b([1,n],1) = 2.5; b([n/2,n/2 + 1],1) = 1;x_sp = ones(n,1); % 真解for i = 1:1:nA(i,n+1-i) = 1/2;A(i,i) = 3;endfor i =1:1:n-1A(i,i+1)= -1;A(i+1,i)= -1;end
end

保存为 setup_Sparse1.m 文件

实现代码

%% 测试 消去法 与 迭代法 在处理稀疏矩阵问题上的差距
clc;clear all,format long;
N = 100; e_tol = 1e-8;
n = 6; %  n 为 6 50 100 500 1000
[A,b,x]=setup_Sparse1(n);
x0 = zeros(n,1); t1 =tic;
[x11,k1,r1] = myJacobi(A,b,x0,e_tol,N);
toc(t1);t2 = tic;
[x12] = gsem_column(A,b);
toc(t2);
r2 = norm(b-A*x12);

结果如下:
n=6时

  • Jacobi迭代次数为33次,耗时 0.254356 秒。 r = 8.383869485405770 e − 09 r= 8.383869485405770e-09 r=8.383869485405770e09
  • Gauss列主元耗时 0.246983 秒。 r = 0 r=0 r=0

n=50时

  • Jacobi迭代次数为84次,耗时 0.252936 秒。 r = 8.506205291756777 e − 09 r= 8.506205291756777e-09 r=8.506205291756777e09
  • Gauss列主元耗时 0.499854 秒。 r = 5.197930934883577 e − 15 r=5.197930934883577e-15 r=5.197930934883577e15

n=100时

  • Jacobi迭代次数为84次,耗时 1.017717 秒。 r = 9.969971572640032 e − 09 r= 9.969971572640032e-09 r=9.969971572640032e09
  • Gauss列主元耗时 1.121281 秒。 r = 7.077617359078848 e − 15 r=7.077617359078848e-15 r=7.077617359078848e15

n=500时

  • Jacobi迭代次数为84次,耗时 20.812204 秒。 r = 9.964771950043455 e − 09 r= 9.964771950043455e-09 r=9.964771950043455e09
  • Gauss列主元耗时 21.329216 秒。 r = 8.862333997095065 e − 15 r=8.862333997095065e-15 r=8.862333997095065e15

n=1000时

  • Jacobi迭代次数为84次,耗时 34.252031 秒。 r = 9.964771950894769 e − 09 r= 9.964771950894769e-09 r=9.964771950894769e09
  • Gauss列主元耗时 89.985333 秒。 r = 1.072960336432300 e − 14 r=1.072960336432300e-14 r=1.072960336432300e14

可以看出,随着稀疏矩阵规模的不断增大,迭代法相比直接法的优势越来越明显。
直接法即能够在有限步内完成计算,随着阶数增大,(gauss消去法运算量 O ( n 3 ) O(n^3) O(n3)),所需步数,指数级增加。

而Jacobi迭代法,只需把精度控制在所需范围内即算完成任务,能够节约很多时间。

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

广东海洋大学成功部署(泰迪智能科技)大数据人工智能实验室建设

广东海洋大学简称广东海大&#xff0c;坐落于广东省湛江市&#xff0c;是国家海洋局与广东省人民政府共建的省属重点建设大学、广东省高水平大学重点学科建设高校、粤港澳高校联盟成员 &#xff0c;入选卓越农林人才教育培养计划&#xff0c;是教育部本科教学水平评估优秀院校。…

vuex中mutations和actions 异步同步实现方法

一 mutations 和 actions 优缺点及使用场景 同步性&#xff1a; Mutations是同步的&#xff0c;这意味着它们会在提交后立即执行。而Actions是异步的&#xff0c;提交后会被排队&#xff0c;在稍后执行。 用途&#xff1a; Mutations适用于简单的状态修改&#xff0c;如递增/…

【Java基础】压测工具JMeter使用简介

1. JMeter介绍 Apache JMeter是一个基于Java开发的开源性能测试工具&#xff0c;由Apache软件基金会维护 JMeter最初设计用于Web应用测试&#xff0c;但它的功能已经扩展到其他测试领域。JMeter可以用于测试静态和动态资源&#xff0c;如静态文件、Java小服务程序、CGI脚本、J…

力扣HOT100 - 543. 二叉树的直径

解题思路&#xff1a; class Solution {int ans;//记录节点数public int diameterOfBinaryTree(TreeNode root) {ans 1;depth(root);return ans - 1;//节点数减 1 就是路径长度}public int depth(TreeNode root) {if (root null) return 0;int l depth(root.left);int r de…

中红医疗:纷享销客CRM系统如何助力​数字化“狂飙”

纷享销客深耕 CRM 多年&#xff0c;可以顺畅打通 CRM 和 ERP 系统客户资源池&#xff0c;将金蝶苍穹平台的物料、产品基础主数据作为档案同步到纷享销客&#xff0c;以便商务维护好产品及库存。 纷享销客通过成熟的集成方案提高系统耦合性&#xff0c;让销售实时获得新产品及营…

123.Mit6.S081-实验1-Xv6 and Unix utilities

今天我们来进行Mit6.S081实验一的内容。 实验任务 一、启动xv6(难度&#xff1a;Easy) 获取实验室的xv6源代码并切换到util分支。 $ git clone git://g.csail.mit.edu/xv6-labs-2020 Cloning into xv6-labs-2020... ... $ cd xv6-labs-2020 $ git checkout util Branch util …

uniapp微信小程序(商城项目)

最近&#xff0c;闲来无事&#xff0c;打算学一下uniapp小程序 于是在跟着某站上学着做了一个小程序&#xff0c;主要是为了学uniapp和vue。某站黑马优购 完成的功能主要有&#xff1a;首页、搜索、分类和购物车。 有人问了为什么没有登录、和添加订单呢&#xff1f;问的很好…

linux负载均衡 和 系统负载分析笔记

1 负载均衡 1.1 计算负载 1.1.1 PELT算法简介 从Linux3.8内核以后进程的负载计算不仅考虑权重&#xff0c;⽽且跟踪每个调度实体的历史负载情况&#xff0c;该算法称为PELT(Per-entity Load Tracking) 《奔跑吧Linux内核》卷1&#xff1a;基础架构&#xff1b;P505 相关资料…

kubectl常用命令行介绍

1、kubectl用法概述 kubectl命令⾏的语法如下&#xff1a; $ kubectl [command] [type] [name] [flags] command&#xff1a;命令&#xff0c;用于操作Kubernetes集群资源对象的命令&#xff0c;例如create、delete、describe、get、apply等TYPE&#xff1a;资源对象的类型&am…

婴儿洗衣机全自动哪个好?推荐四款实惠耐用的婴儿洗衣机

婴儿的衣物对于卫生要求需要高一些&#xff0c;其抵抗力是比较弱的&#xff0c;再加上普通洗衣机无法对婴儿的衣物进行有效的消毒处理&#xff0c;轻则会对婴儿的健康造成威胁&#xff0c;重则会导致皮肤病的发生。因此&#xff0c;一台可以对衣物进行高温除菌的婴儿洗衣机非常…

运营高手都在用的9款办公软件!一定要收藏

最近&#xff0c;运营群里的00后天天都在搞新花样&#xff0c;每天都有新的idea&#xff0c;各种跟热点、做品牌联名、拍好玩的视频、做创意海报……。但奇怪的是&#xff0c;工作量增加了、业绩增长了&#xff0c;却不见有人加班。一问&#xff0c;原来因为用上了办公神器啊&a…

数据结构(C):时间复杂度和空间复杂度

目录 &#x1f680; 0.前言 &#x1f680; 1.为何会有时间复杂度和空间复杂度的概念 &#x1f680; 2.时间复杂度 2.1初步时间复杂度 2.2大O表示法 2.2.1.O&#xff08;N*N&#xff09; 2.2.2.O&#xff08;N&#xff09; 2.2.3.O&#xff08;1&#xff09; 2.3最坏情况…

揭秘分销系统:商业模式的新风向

大家好&#xff0c;我是微三云周丽&#xff0c;今天给大家分析当下市场比较火爆的商业模式&#xff01; 小编今天跟大伙们分享什么是分销系统&#xff1f; 在数字化浪潮席卷全球的今天&#xff0c;电子商务以其独特的优势&#xff0c;正在重塑商业世界的格局。其中&#xff0…

大模型产业盛典上石景山智能算力中心绽放新光芒

2024年4月16日&#xff0c;由中关村数智人工智能产业联盟主办的“2024人工智能大模型产业发展大会”圆满闭幕。在这场盛会中&#xff0c;企商在线石景山智能算力中心以其作为北京最大规模的公共智能算力中心的身份亮相&#xff0c;为首都建设全球数字标杆城市注入了新的活力。 …

KingbaseES数据库bulkload快速导入导出数据

数据库版本&#xff1a;KingbaseES V008R006C008B0014 简介 sys_bulkload 是 kingbase 快速将 CSV 文件导入数据库的命令行工具&#xff0c;它支持串行和并行的方式&#xff0c;是目前导入数据最快的工具。 文章目录如下 1. 基础语法 1.1. 语法说明 1.2. 参数选项 1.3. 配置…

C语言进阶课程学习记录- 函数与宏分析

C语言进阶课程学习记录- 函数与宏分析 实验-宏和函数实验-宏的副作用实验-宏的妙用小结 本文学习自狄泰软件学院 唐佐林老师的 C语言进阶课程&#xff0c;图片全部来源于课程PPT&#xff0c;仅用于个人学习记录 实验-宏和函数 #include <stdio.h>#define RESET(p, len) …

贪心算法练习day.1

理论基础 贪心算法是一种常见的解决优化问题的方法&#xff0c;其基本思想就是在问题的每个决策阶段&#xff0c;都选择当前看起来最优的选择&#xff0c;即贪心地做出局部的最优决策&#xff0c;以此得到全局的最优解&#xff0c;例如在十张面额不同的钞票&#xff0c;让我们…

批量修改kingbase数据库中表未生成的rowid字段

批量修改生成kingbase的rowid列 show default_with_rowid; 如果结果是off&#xff0c;说明不会生成rowid的列&#xff0c;则无法查询rowid列 想要查询需要手动将表得rowid列加上或者修改上面参数后重新迁移数据批量修改对应用户对应模式下所有表的rowid的存储过程如下&#xf…

【C++】详解初始化列表,隐式类型转化,类静态成员,友元

前言 初始化列表是对构造函数内容的补充&#xff0c;小编会详细的讲解初始化列表的概念&#xff0c;特性&#xff0c;注意点。这是本篇内容的重头戏&#xff0c;小编会先提一个问题来抛砖引玉。 隐式类型转换顾名思义&#xff0c;首先它不需要主动转换&#xff0c;类似于把浮点…

Vision Pro 手势追踪 - ARKit 教程

在 visionOS 中,ARKit 可以实现手部追踪和世界感应等增强现实功能,在 ARKit 中调用手部追踪的流程如下: ARKit 追踪数据使用流程 首先,需要向用户描述手势追踪数据的用途并取得用户授权。 Xcode Info 中填写 NSHandsTrackingUsageDescription 为了确保用户隐私,要调用…