列主元高斯消去法的实现

合集下载

Gauss列主元素消去法实验

Gauss列主元素消去法实验

Lab06.Gauss 列主元素消去法实验【实验目的和要求】1.使学生深入理解并掌握Gauss 消去法和Gauss 列主元素消去法步骤; 2.通过对Gauss 消去法和Gauss 列主元素消去法的程序设计,以提高学生程序设计的能力;3.对具体问题,分别用Gauss 消去法和Gauss 列主元素消去法求解。

通过对结果的分析比较,使学生感受Gauss 列主元素消去法优点。

【实验内容】1.根据Matlab 语言特点,描述Gauss 消去法和Gauss 列主元素消去法步骤。

2.编写用不选主元的直接三角分解法解线性方程组Ax=b 的M 文件。

要求输出Ax=b 中矩阵A 及向量b ,A=LU 分解的L 与U ,det A 及解向量x 。

3.编写用Gauss 列主元素消去法解线性方程组Ax=b 的M 文件。

要求输出Ax=b 中矩阵A 及向量b 、PA=LU 分解的L 与U 、det A 及解向量x ,交换顺序。

4.给定方程组(1) ⎥⎥⎥⎦⎤⎢⎢⎢⎣⎡=⎥⎥⎥⎦⎤⎢⎢⎢⎣⎡⎥⎥⎥⎦⎤⎢⎢⎢⎣⎡--11134.981.4987.023.116.427.199.103.601.3321x x x(2) ⎥⎥⎥⎥⎦⎤⎢⎢⎢⎢⎣⎡=⎥⎥⎥⎥⎦⎤⎢⎢⎢⎢⎣⎡⎥⎥⎥⎥⎦⎤⎢⎢⎢⎢⎣⎡----15900001.582012151********.23107104321x x x x 先用编写的程序计算,再将(1)中的系数3.01改为3.00,0.987改为0.990;将(2)中的系数2.099999改为2.1,5.900001改为9.5,再用Gauss 列主元素消去法解,并将两次计算的结果进行比较。

【实验仪器与软件】1.CPU 主频在1GHz 以上,内存在128Mb 以上的PC ;2.Matlab 6.0及以上版本。

实验讲评:实验成绩:评阅教师:200 年 月 日Lab06.Gauss 列主元素消去法实验第一题:1、算法描述:Ⅰ、Gauss 消去法由书上定理5可知 设Ax=b ,其中A ∈R^(n(1)如果()0(1,2,....,1)k kka k n ≠=-,则可通过高斯消去法将Ax=b 约化为等价的 角形线性方程组,且计算公式为:① 消元计算(k=1,2,….,n-1)()()(1)()()(1)()()/,1,...,,,,1,...,,,1,...,.k k ik ik kk k k k ij ij ik kj k k k iiik k m a a i k n a a m a i j k n b b m b i k n ++==+=-=+=-=+② 回带公式()()()()()1/,()/,1,...,2,1.n n n n nn ni i i i iii j ii j i x b a x ba x a i n =+==-=-∑(2)如果A 为非奇异矩阵,则可通过高斯消去法将方程组Ax=b 约化方程组为上三角矩阵以上消元和回代过程总的乘除法次数为332333nn nn +-≈,加减法次数为32353263nnn n+-≈以上过程就叫高斯消去法。

列主元高斯消去法发展过程

列主元高斯消去法发展过程

列主元高斯消去法发展过程1.引言1.1 概述列主元高斯消去法是一种重要的线性方程组求解方法,它在科学计算、工程领域以及数学研究中都有广泛的应用。

本文将对列主元高斯消去法的发展过程进行深入探讨。

列主元高斯消去法最早可以追溯到高斯消去法的提出。

高斯消去法是由十九世纪德国数学家卡尔·弗里德里希·高斯首先提出的一种解线性方程组的方法。

但是高斯消去法的一个缺点是,它需要选取主元,并且主元的选取会影响计算结果的精确性和稳定性。

为了克服这个问题,人们开始思考如何选择更稳定的主元。

随着计算机技术的发展,人们可以使用计算机进行大规模的数值计算。

在这个背景下,对算法的精确性和稳定性要求越来越高。

于是,人们开始尝试改进高斯消去法,以提高算法的效率和计算结果的精确性。

经过多年的研究和实践,人们发现通过选择列主元进行消去,可以在很大程度上提高算法的稳定性。

列主元高斯消去法的基本思想是,在每一步消去过程中,选择列主元使其绝对值最大,从而减小误差的传播。

通过这种策略,列主元高斯消去法能够更好地处理数值计算中的舍入误差,提高计算结果的准确性和稳定性。

随着计算机科学的快速发展,列主元高斯消去法的应用领域也不断扩大。

它在科学计算中被广泛应用于解线性方程组、求解矩阵的特征值和特征向量、拟合曲线等问题。

在工程领域,列主元高斯消去法可以用于求解结构力学、电路分析、图像处理等相关问题。

总而言之,列主元高斯消去法是一种重要的数值计算方法,通过选择列主元进行消去,能够提高计算结果的精确性和稳定性。

它在科学计算和工程领域有广泛的应用,是现代数值计算的重要组成部分。

本文将进一步探讨列主元高斯消去法的定义、原理、应用领域以及其发展过程的总结和未来发展方向。

文章结构文章的结构是指整篇文章的框架和分节安排,它对于读者理解和掌握文章的内容起着至关重要的作用。

对于本文《列主元高斯消去法发展过程》而言,其结构可以按照以下方式进行组织和安排。

(7) 列主元高斯消去法的实现

(7) 列主元高斯消去法的实现

列主元高斯消去法是一种用于解线性方程组的经典算法,其实现过程包括主元选取、互换行、消元和回代等步骤。

本文将从理论基础、算法描述、实现步骤和代码示例等方面介绍列主元高斯消去法的实现方法,希望可以帮助读者更好地理解和掌握这一算法。

一、理论基础列主元高斯消去法是求解线性方程组的一种经典方法,其基本思想是通过逐步消去未知数,最终得到方程组的解。

在实际应用中,通常将线性方程组表示为增广矩阵的形式,然后通过主元选取、互换行、消元和回代等操作,逐步将增广矩阵转化为阶梯形矩阵或行阶梯形矩阵,最终获得方程组的解。

列主元高斯消去法的关键在于主元的选取,通过选取适当的主元可以避免出现数值不稳定的情况,从而提高求解的准确性和稳定性。

二、算法描述列主元高斯消去法的基本算法描述如下:1. 将线性方程组表示为增广矩阵的形式2. 从第一行开始,选择当前列中绝对值最大的元素作为主元,并将其所在行与当前行交换3. 通过第一个主元,将当前列下方的元素消为零,得到一个新的增广矩阵4. 重复以上步骤,直到得到一个阶梯形矩阵或行阶梯形矩阵5. 利用回代的方法,求解得到线性方程组的解三、实现步骤基于上述算法描述,可以将列主元高斯消去法的实现步骤总结如下:1. 主元选取:对于当前列,在所有未处理的元素中选择绝对值最大的元素作为主元,并将其所在行与当前行交换2. 互换行:如果选取的主元为零,则需要考虑互换行的操作,以避免出现除零错误3. 消元:利用当前列的主元将下方的元素消为零4. 回代:通过阶梯形矩阵或行阶梯形矩阵进行回代,求解得到线性方程组的解在实现列主元高斯消去法时,需要注意处理数值计算中可能出现的特殊情况,如零主元和除零错误等,并进行合理的异常处理。

四、代码示例下面是列主元高斯消去法的简单实现代码示例,该示例使用Python 语言编写:```pythonimport numpy as npdef gauss_elimination(A, b):n = len(b)for i in range(n):pivot = ifor j in range(i+1, n):if abs(A[j, i]) > abs(A[pivot, i]):pivot = jA[[i, pivot]] = A[[pivot, i]]b[[i, pivot]] = b[[pivot, i]]for j in range(i+1, n):factor = A[j, i] / A[i, i]b[j] -= factor * b[i]A[j] -= factor * A[i]x = np.zeros(n)for i in range(n-1, -1, -1):x[i] = (b[i] - np.dot(A[i, i+1:], x[i+1:])) / A[i, i]return x```以上代码示例实现了列主元高斯消去法的求解过程,通过调用该函数可以求解给定的线性方程组。

实验三高斯列主元消去法

实验三高斯列主元消去法

实验三 高斯列主元消去法一、实验目的:1、掌握高斯消去法的基本思路和迭代步骤。

2、 培养编程与上机调试能力。

二、高斯列主元消去法的基本思路与计算步骤:设有方程组Ax b =,设A 是可逆矩阵。

高斯消去法的基本思想就是僵局真的初等行变换作用于方程组的增广矩阵[]B A b = ,将其中的A 变换成一个上三角矩阵,然后求解这个三角形方程组。

列主元高斯消去法计算步骤:将方程组用增广矩阵[]()(1)ij n n B A b a ⨯+== 表示。

步骤1:消元过程,对1,2,,1k n =-(1) 选主元,找{},1,,k i k k n ∈+ 使得,max k i k ikk i n a a ≤≤= (2) 如果,0k i k a =,则矩阵A 奇异,程序结束;否则执行(3)。

(3) 如果k i k ≠,则交换第k 行与第k i 行对应元素位置,k kj i j a a ↔,,,1j k n =+ 。

(4) 消元,对,,i k n = ,计算/,ikik kk l a a =对1,,1j k n =++ ,计算 .ij ij ik kj a a l a =- 步骤 2:回代过程:(1) 若0,nn a =则矩阵奇异,程序结束;否则执行(2)。

(2) ,1/;n n n nn x a a +=对1,,2,1i n =- ,计算,11/n i i n ij j ii j i x a a x a +=+⎛⎫=- ⎪⎝⎭∑三:程序流程图四:程序清单:function X=uptrbk(A,b)% A是一个n阶矩阵。

% b是一个n维向量。

% X是线性方程组AX=b的解。

[N N]=size(A);X=zeros(1,N+1);Aug=[A b];for p=1:N-1[Y,j]=max(abs(Aug(p:N,p)));%返回向量的最大值存入y,最大值的序号存入j。

C=Aug(p,:);Aug(p,:)=Aug(j+p-1,:);Aug(j+p-1,:)=C;if Aug(p,p)==0'A是奇异阵,方程无惟一解'breakendfor k=p+1:Nm=Aug(k,p)/Aug(p,p);Aug(k,p:N+1)=Aug(k,p:N+1)-m*Aug(p,p:N+1);endend% 这里用到程序函数backsub来进行回代。

实验三 高斯消去法和三角分解法1

实验三 高斯消去法和三角分解法1

实验报告实验三 高斯消去法与矩阵的三角分解一、实验目的1、掌握列主元素消去法,并且能够用MATLAB 编写相关程序,实现高斯消去法的求解。

2、能够用矩阵理论理解与研究高斯消去法,通过对矩阵的初等变换实现高斯消去法。

3、学会矩阵的三角分解,并且能够用MATLAB 编写相关程序,实现矩阵的三角分解,解方程组。

二、上机内容⎥⎥⎥⎥⎥⎥⎥⎥⎥⎦⎤⎢⎢⎢⎢⎢⎢⎢⎢⎢⎣⎡=⎥⎥⎥⎥⎥⎥⎥⎥⎥⎦⎤⎢⎢⎢⎢⎢⎢⎢⎢⎢⎣⎡⎥⎥⎥⎥⎥⎥⎥⎥⎥⎦⎤⎢⎢⎢⎢⎢⎢⎢⎢⎢⎣⎡2822171310871234567112345611123451111234111112311111121111111764321x x x x x x1、用列主元素高斯消去法求解方程组。

2、用列主元消去法求解方程组(实现PA=LU) 要求输出: (1)计算解X;(2)L,U;(3)正整型数组IP(i),(i=1,···,n) (记录主行信息)。

三、实验原理1、列主元素消去法用高斯消去法求解方程组时,为了减小误差,在消去的过程中要避免用绝对值较小的主元素。

因此在高斯消去法的每一步应该在系数矩阵货消去后的低阶矩阵中选取绝对值较大的元素作为主元素,保持|m ik |<=1,以减小计算过程中的舍入误差对计算解的影响。

此方法为完全主元素消去法。

完全主元素消去法在选主元素时花费一定的计算机时间,因此实际计算中常用列主元消去法。

列主元消去法在每次选主元时,仅依次按列选取绝对值最大的元素作为主元素,且仅交换两行,再进行消元计算。

装订 线第k步计算如下:对于k=1,2,…,n-1(1)按列选主元:即确定t使(2)如果t≠k,则交换[A,b]第t行与第k行元素。

(3)消元计算(4)回代求解计算流程图回代求解 b=b/a (当a nn ≠0)b ←(b -∑a x )/adet=a nn *det输出计算解及行列式及detk=1,2,…,n-1输入n ,A,b,εdet=1按列主元|a i(k),k |=max|a ik |C 0=a i(k),k换行 a ik a i(k)j(j=k,…n ) b k b j(k), 消元计算 (i=k+1,…,n ) a ik=a ik -a kk *m ik a ij=a ij -a kj *m ik (j=k+1,…,n )|C 0|<εi k =kdet=a kk det否否是是k<=n-1输出det(A)=0停机停机2. 矩阵的三角分解法 (1)定理设 n n R A ⨯∈ 。

列主元素Gauss消去法Jacobi迭代法原理及计算方法

列主元素Gauss消去法Jacobi迭代法原理及计算方法

一、 列主元素Gauss 消去法、Jacobi 迭代法原理及计算方法1. 列主元素Gauss 消去法:1.1 Gauss 消去法基本原理设有方程组Ax b =,设A 是可逆矩阵。

高斯消去法的基本思想就是将矩阵的初等行变换作用于方程组的增广矩阵[]B A b = ,将其中的A 变换成一个上三角矩阵,然后求解这个三角形方程组。

1.2 列主元Gauss 消去法计算步骤将方程组用增广矩阵[]()(1)ijn n B A b a ⨯+== 表示。

1). 消元过程对1,2,,1k n =-(1) 选主元,找{},1,,k i k k n ∈+ 使得 ,max k i k ik k i na a ≤≤= (2) 如果,0k i k a =,则矩阵A 奇异,程序结束;否则执行(3)。

(3) 如果k i k ≠,则交换第k 行与第k i 行对应元素位置,k kj i j a a ↔,,,1j k n =+ 。

(4) 消元,对,,i k n = ,计算/,ik ik kk l a a =对1,,1j k n =++ ,计算.ij ij ik kj a a l a =-2). 回代过程(1) 若0,nn a =则矩阵奇异,程序结束;否则执行(2)。

(2) ,1/;n n n nn x a a +=对1,,2,1i n =- ,计算,11/n i i n ij j ii j i x a a x a +=+⎛⎫=- ⎪⎝⎭∑2. Jacobi 迭代法2.1 Jacobi 迭代法基本原理Jacobi 迭代法的基本思想是对n 元线性方程组b Ax =,.,n n R b R A ∈∈将其变形为等价方程组f Bx x +=,其中.,,n n n n R x R f R B ∈∈∈⨯B 成为迭代矩阵。

从某一取定的初始向量)0(x 出发,按照一个适当的迭代公式 ,逐次计算出向量f Bx x k k +=+)()1( ( 1,0=k ),使得向量序列}{)(k x 收敛于方程组的精确解.(1)输入1,,,,)0(=k n xb A ε,. (2) )(1,1)0()1(∑≠=-=n j i i j ij i iii x a b a x )1,0(n i = (3)判断 ε≤--≤≤)0()1(10max i i n i x x ,若是,输出1)1(2)1(1,,n x x x ,若否,置1+=k k ,)1()0(i i x x =,)2,1(n i =。

数值分析列主元高斯消去法

数值分析列主元高斯消去法

实验四:列组元消去法一、目的1)熟悉列主元高斯消元法解线性方程组的算法2)掌握列主元高斯消去法的编程二、实验原理列主元素消去法是为控制舍入误差而提出来的一种算法,在Gauss消去法的消元过程中,若出现a=0,则消元无法进行,即使其不为0,但很小,把它作为除数,就会导致其他元素量级的巨大增长和舍入误差的扩散,最后使计算结果不可靠.使用列主元素消去法计算,基本上能控制舍入误差的影响,并且选主元素比较方便.三、运行结果四、代码using System;using System.Collections.Generic;using System.Linq;using System.Text;namespace高斯{class Program{static double[] Gause(double[,] a, int n){int i, j, k;int rank, columm;double temp, l, s, mx;double[] x = new double[n];for (i = 0; i <= n - 2; i++){mx = Math.Abs(a[i, i]);rank = i;columm = i;for (j = i + 1; j <= n - 1; j++) //选主元if (Math.Abs(a[j, i]) > mx){mx = Math.Abs(a[j, i]);rank = j;columm = i;}for (k = 0; k <= n; k++) //主元行变换{temp = a[i, k];a[i, k] = a[rank, k];a[rank, k] = temp;} //消元for (j = i + 1; j <= n - 1; j++){l = a[j, i] / a[i, i];for (k = i; k <= n; k++)a[j, k] = a[j, k] - l * a[i, k];}}x[n - 1] = a[n - 1, n] / a[n - 1, n - 1]; //回代方程求解x for (i = n - 2; i >= 0; i--){s = 0;for (j = i + 1; j <= n - 1; j++)s = s + a[i, j] * x[j];x[i] = (a[i, n] - s) / a[i, i];}return x;}static void Main(string[] args){double[,] a = new double[4, 5] { { 10, -7, 0, 1, 8 }, { -3, 2.099999, 6, 2, 5.900001 }, { 5, -1, 5, -1, 5 }, { 2, 1, 0, 2, 1 } };int n = 4;double[] x = new double[n];x = Gause(a, n);Console.WriteLine("高斯消去法方程:");for (int i = 0; i < n; i++){for (int j = 0; j < n; j++)Console.Write(a[i, j].ToString() + " ");Console.WriteLine();}Console.WriteLine("线性方程组的解:");for (int i = 0; i <= n - 1; i++)Console.Write("x" + (i + 1).ToString() + "=" +x[i].ToString() + " ");Console.WriteLine();Console.ReadLine();}}}四、分析通过本次实验的学习,学会根据算法编写基本的相关程序,虽然此次程序模板由老师给予,但认真阅读理解程序有助于今后的学习,再利用计算机中的C语言对高斯列主元消去法可以快速得到线性方程组的解,由简单的线性方程组可以推广到一般n阶线性方程组,这对如何利用高斯列主元消去法解决实际问题有了一定的经验。

列主元高斯消去法和列主元三角分解法解线性方程

列主元高斯消去法和列主元三角分解法解线性方程

计算方法实验报告1课题名称用列主元高斯消去法和列主元三角分解法解线性方程目的和意义高斯消去法是一个古老的求解线性方程组的方法,但由它改进得到的选主元的高斯消去法则是目前计算机上常用的解低阶稠密矩阵方程组的有效方法;用高斯消去法解线性方程组的基本思想时用矩阵行的初等变换将系数矩阵A 约化为具有简单形式的矩阵上三角矩阵、单位矩阵等,而三角形方程组则可以直接回带求解 用高斯消去法解线性方程组b Ax =其中A ∈Rn ×n 的计算量为:乘除法运算步骤为32(1)(1)(21)(1)(1)262233n n n n n n n n n n nMD n ----+=+++=+-,加减运算步骤为(1)(21)(1)(1)(1)(25)6226n n n n n n n n n n AS -----+=++=;相比之下,传统的克莱姆法则则较为繁琐,如求解20阶线性方程组,克莱姆法则大约要19510⨯次乘法,而用高斯消去法只需要3060次乘除法;在高斯消去法运算的过程中,如果出现absAi,i 等于零或过小的情况,则会导致矩阵元素数量级严重增长和舍入误差的扩散,使得最后的计算结果不可靠,所以目前计算机上常用的解低阶稠密矩阵方程的快速有效的方法时列主元高斯消去法,从而使计算结果更加精确; 2、列主元三角分解法高斯消去法的消去过程,实质上是将A 分解为两个三角矩阵的乘积A=LU,并求解Ly=b 的过程;回带过程就是求解上三角方程组Ux=y;所以在实际的运算中,矩阵L 和U 可以直接计算出,而不需要任何中间步骤,从而在计算过程中将高斯消去法的步骤进行了进一步的简略,大大提高了运算速度,这就是三角分解法采用选主元的方式与列主元高斯消去法一样,也是为了避免除数过小,从而保证了计算的精确度计算公式1、 列主元高斯消去法设有线性方程组Ax=b,其中设A 为非奇异矩阵;方程组的增广矩阵为第1步k=1:首先在A 的第一列中选取绝对值最大的元素1l a ,作为第一步的主元素:111211212222112[,]n n n l n nn n a a a a b a a a b a a a b ⎡⎤⎢⎥⎢⎥⎢⎥=⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎣⎦a b然后交换A,b 的第1行与第l 行元素,再进行消元计算;设列主元素消去法已经完成第1步到第k -1步的按列选主元,交换两行,消元计算得到与原方程组等价的方程组 Akx=bk第k 步计算如下:对于k=1,2,…,n -11按列选主元:即确定t 使 2如果t ≠k,则交换A,b 第t 行与第k 行元素; 3消元计算消元乘数mik 满足:4回代求解2、 列主元三角分解法 对方程组的增广矩阵 经过k -1步分解后,可变成如下形式:111max 0l i i n a a ≤≤=≠(1)(1)(1)(1)(1)1112111(2)(2)(2)(2)22222()(()1)()()()()()1,1()(,)()[,][,] k k k k nk k nk n k k k k k kk kn k k k k n k k k n nn a a a a b a a a b a a b a b b a a a +++⎡⎤⎢⎥⎢⎥⎢⎥⎢⎥→=⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎣⎦A b A b ()()max 0k k tk ik k i na a ≤≤=≠,(1,,)ik ik ik kka a m i k n a ←=-=+, (,1,,), (1,,)ij ij ik kji i ik k a a m a i j k n b b m b i k n ←+=+⎧⎨←+=+⎩⎪⎪⎩⎪⎪⎨⎧--=-←←∑+=)1,,2,1(,)(1n n i a x a b x a b x ii n i j j ij i i nnn n [,]A A b =11121,11111222,122221,11,1,1,211,11,2121,112,112,1k k k k k k k j n k k j n k k k i i i k n n kk kj kn k ik ij in i nknjk k k j k n n nnk k n a a a b A a u u u u u u y l l l l l l ll l l l u u u u u y u u u u y a a b a a b l a -------------⎡→⎣⎤⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎦第k 步分解,为了避免用绝对值很小的数kku 作除数,引进量1111 (,1,,;1,2,,) ()/ (1,2,,;1,2,,)k kj kj km mj m k ik ik im mk kkm u a l u j k k n k n l a l u u i k k n k n -=-=⎧=-=+=⎪⎪⎨⎪=-=++=⎪⎩∑∑11(,1,,)k i ik im mk m s a l u i k k n -==-=+∑,于是有kk u =ks ;如果 ,则将矩阵的第t 行与第k 行元素互换,将i,j 位置的新元素仍记为jjl 或jja ,然后再做第k 步分解,这时列主元高斯消去法程序流程图max t ik i n s s ≤≤= ()/ 1,2,,)1 (1,2,,),kk k k t iki k ik u s s s l s s i k k n l i k k n ===++≤=++即交换前的,(且列主元高斯消去法Matlab主程序function x=gauss1A,b,c %列主元法高斯消去法解线性方程Ax=bif lengthA~=lengthb %判断输入的方程组是否有误disp'输入方程有误'return;enddisp'原方程为AX=b:' %显示方程组Abdisp'------------------------'n=lengthA;for k=1:n-1 %找列主元p,q=maxabsAk:n,k; %找出第k列中的最大值,其下标为p,qq=q+k-1; %q在Ak:n,k中的行号转换为在A中的行号if absp<cdisp'列元素太小,detA≈0';break;elseif q>ktemp1=Ak,:; %列主元所在行不是当前行,将当前行与列主Ak,:=Aq,:; 元所在行交换包括bAq,:=temp1;temp2=bk,:;bk,:=bq,:;bq,:=temp2;end%消元for i=k+1:nmi,k=Ai,k/Ak,k; %Ak,k将Ai,k消为0所乘系数Ai,k:n=Ai,k:n-mi,kAk,k:n; %第i行消元处理bi=bi-mi,kbk; %b消元处理endenddisp'消元后所得到的上三角阵是'A %显示消元后的系数矩阵bn=bn/An,n; %回代求解for i=n-1:-1:1bi=bi-sumAi,i+1:nbi+1:n/Ai,i;endclear x;disp'AX=b的解x是' x=b;调用函数解题列主元三角分解法程序流程图列主元三角分解法Matlab主程序①自己编的程序:function x=PLUA,b,eps %定义函数列主元三角分解法函数if lengthA~=lengthb %判断输入的方程组是否有误disp'输入方程有误'return;enddisp'原方程为AX=b:' %显示方程组Abdisp'------------------------'n=lengthA;A=A b; %将A与b合并,得到增广矩阵for r=1:nif r==1for i=1:nc d=maxabsA:,1; %选取最大列向量,并做行交换if c<=eps %最大值小于e,主元太小,程序结束break;elseendd=d+1-1;p=A1,:;A1,:=Ad,:;Ad,:=p;A1,i=A1,i;endA1,2:n=A1,2:n;A2:n,1=A2:n,1/A1,1; %求u1,ielseur,r=Ar,r-Ar,1:r-1A1:r-1,r; %按照方程求取ur,iif absur,r<=eps %如果ur,r小于e,则交换行p=Ar,:;Ar,:=Ar+1,:;Ar+1,:=p;elseendfor i=r:nAr,i=Ar,i-Ar,1:r-1A1:r-1,i; %根据公式求解,并把结果存在矩阵A中endfor i=r+1:nAi,r=Ai,r-Ai,1:r-1A1:r-1,r/Ar,r; %根据公式求解,并把结果存在矩阵A中endendendy1=A1,n+1;for i=2:nh=0;for k=1:i-1h=h+Ai,kyk;endyi=Ai,n+1-h; %根据公式求解yiendxn=yn/An,n;for i=n-1:-1:1h=0;for k=i+1:nh=h+Ai,kxk;endxi=yi-h/Ai,i; %根据公式求解xiendAdisp'AX=b的解x是'x=x'; %输出方程的解②可直接得到P,L,U并解出方程解的的程序查阅资料得子函数PLU1,其作用是将矩阵A分解成L乘以U的形式;PLU2为调用PLU1解题的程序,是自己编的Ⅰ.function l,u,p=PLU1A %定义子函数,其功能为列主元三角分解系数矩阵A m,n=sizeA; %判断系数矩阵是否为方阵if m~=nerror'矩阵不是方阵'returnendif detA==0 %判断系数矩阵能否被三角分解error'矩阵不能被三角分解'endu=A;p=eyem;l=eyem; %将系数矩阵三角分解,分别求出P,L,Ufor i=1:mfor j=i:mtj=uj,i;for k=1:i-1tj=tj-uj,kuk,i;endenda=i;b=absti;for j=i+1:mif b<abstjb=abstj;a=j;endendif a~=ifor j=1:mc=ui,j;ui,j=ua,j;ua,j=c;endfor j=1:mc=pi,j;pi,j=pa,j;pa,j=c;endc=ta;ta=ti;ti=c;endui,i=ti;for j=i+1:muj,i=tj/ti;endfor j=i+1:mfor k=1:i-1ui,j=ui,j-ui,kuk,j;endendendl=trilu,-1+eyem;u=triuu,0Ⅱ.function x=PLU2A,b %定义列主元三角分解法的函数l,u,p=PLU1A %调用PLU分解系数矩阵A m=lengthA; %由于A左乘p,故b也要左乘p v=b;for q=1:mbq=sumpq,1:mv1:m,1;endb1=b1 %求解方程Ly=b for i=2:1:mbi=bi-sumli,1:i-1b1:i-1;endbm=bm/um,m; %求解方程Ux=y for i=m-1:-1:1bi=bi-sumui,i+1:mbi+1:m/ui,i;endclear x;disp'AX=b的解x是' x=b;调用函数解题①②编程疑难这是第一次用matlab编程,对matlab的语句还不是非常熟悉,因此在编程过程中,出现了许多错误提示;并且此次编程的两种方法对矩阵的运算也比较复杂;问题主要集中在循环控制中,循环次数多了一次或者缺少了一次,导致数据错误,一些基本的编程语句在语法上也会由于生疏而产生许多问题,但是语句的错误由于系统会提示,比较容易进行修改,数据计算过程中的一些逻辑错误,比如循环变量的控制,这些系统不会提示错误,需要我们细心去发现错误,不断修正,调试;。

解线性方程组的方法

解线性方程组的方法

解线性方程组的方法线性方程组是数学中常见的一类方程组,它由一组线性方程组成,常用形式为:a₁₁x₁ + a₁₂x₂ + … + a₁ₙxₙ = b₁a₂₁x₁ + a₂₂x₂ + … + a₂ₙxₙ = b₂⋮aₙ₁x₁ + aₙ₂x₂ + … + aₙₙxₙ = bₙ其中,a₁₁, a₁₂, …, a₁ₙ, a₂₁, a₂₂, …, aₙₙ为已知系数,b₁,b₂, …, bₙ为已知常数,x₁, x₂, …, xₙ为未知数。

解线性方程组的方法有多种,下面将详细介绍其中的几种常用方法。

1. 列主元高斯消元法列主元高斯消元法是一种经典的解线性方程组的方法。

它的基本思想是通过消元将线性方程组转化为三角形式,然后逐步回代求解未知数。

具体步骤如下:(1)将系数矩阵按列选择主元,即选取每一列中绝对值最大的元素作为主元;(2)对系数矩阵进行初等行变换,使主元所在列下方的元素全部变为零;(3)重复上述步骤,直到将系数矩阵化为上三角矩阵;(4)从最后一行开始,逐步回代求解未知数。

2. Cramer法则Cramer法则是一种基于行列式的解线性方程组的方法。

它利用克拉默法则,通过求解线性方程组的系数矩阵的行列式和各个未知数对应的代数余子式的乘积,进而得到方程组的解。

具体步骤如下:(1)计算线性方程组的系数矩阵的行列式,若行列式为零,则方程组无解,否则进行下一步;(2)分别将每个未知数对应的列替换为常数向量,并计算替换后的系数矩阵的行列式;(3)将第二步计算得到的行列式除以第一步计算得到的行列式,得到各个未知数的解。

需要注意的是,Cramer法则只适用于系数矩阵为非奇异矩阵的情况。

3. 矩阵求逆法矩阵求逆法是一种利用矩阵求逆运算解线性方程组的方法。

它将线性方程组转化为矩阵形式,通过求解系数矩阵的逆矩阵,然后与常数向量相乘得到未知数向量。

具体步骤如下:(1)将线性方程组的系数矩阵记为A,常数向量记为b,未知数向量记为x;(2)判断A是否可逆,若A可逆,则进行下一步,否则方程组无解;(3)求解系数矩阵的逆矩阵A⁻¹;(4)计算未知数向量x = A⁻¹b。

列主元高斯消去法python代码

列主元高斯消去法python代码

列主元高斯消去法python代码主元高斯消去法(Gaussian elimination with partial pivoting)是一种用于解线性方程组的常用算法。

该算法通过将方程组表示为增广矩阵,然后使用行变换的方式将矩阵转化为上三角形矩阵,最后通过回代的方式求解方程组。

以下是一个使用Python实现的主元高斯消去法的示例代码:```pythonimport numpy as npdef gaussian_elimination(A, b):n = len(A)# 构造增广矩阵augmented_matrix = np.column_stack((A, b))# 遍历每一行for i in range(n):# 部分主元消去pivot_row = ipivot = augmented_matrix[i, i]for row in range(i + 1, n):if abs(augmented_matrix[row, i]) > abs(pivot):pivot_row = rowpivot = augmented_matrix[row, i]# 交换当前行与主元行augmented_matrix[[i, pivot_row]] =augmented_matrix[[pivot_row, i]]# 消元for row in range(i + 1, n):factor = augmented_matrix[row, i] / augmented_matrix[i, i] augmented_matrix[row, i:] -= factor * augmented_matrix[i, i:]# 回代x = np.zeros(n)for i in range(n - 1, -1, -1):x[i] = (augmented_matrix[i, -1] - np.dot(augmented_matrix[i, i+1:n], x[i+1:])) / augmented_matrix[i, i]return x# 示例输入A = np.array([[2, -1, 1],[1, 3, -2],[-3, 1, 3]])b = np.array([3, 4, -6])# 使用主元高斯消去法求解线性方程组x = gaussian_elimination(A, b)print("Solution:")print(x)```在该示例代码中,我们首先构造了一个`gaussian_elimination`函数,接受矩阵`A`和向量`b`作为参数,返回线性方程组的解`x`。

Gauss消去法和列主元消去法

Gauss消去法和列主元消去法
while s<=n
max=abs(C(s,s));big=0;
if det(C(s:n,s:n))==0
disp('此方程无解');
answer=0;
break;
end
for i=s:n
if max<abs(C(i,s))
max=abs(C(i,s));
k=i;
big=1;
else continue
for i=n:(-1):1
X(i,1)=C(i,n+1);
for j=(i+1):n
X(i,1)=X(i,1)-E(i,j)*X(j,1);
end
X(i,1)=X(i,1)/E(i,i);
ห้องสมุดไป่ตู้end
disp('此方程的解为:')
X
end
5、实验结果
请输入未知数系数矩阵A:
A=[2,-1,3;4,2,5;1,2,0]
3、实验原理
高斯列主元消去法
4、实验内容
clc;clear;format short
disp('请输入未知数系数矩阵A:');
A=input('A=');
disp('请输入常数项列向量B:');
B=input('B=');
C=[A,B];
[m,n]=size(A);
s=1;answer=1;P=zeros(1,n);L=zeros(n);I=eye(n);
y=a(i,k:n+1);a(i,k:n+1)=a(k,k:n+1);a(k,k:n+1)=y;
break;

列主元高斯消元法

列主元高斯消元法

列主元高斯消元法《列主元高斯消元法》被认为是一种十分有效的非负定线性方程组求解方法,在研究过程中曾被用于解决多项式的根的问题,例如求解二次方程及其高次多项式的根。

在数学分析理论及应用中,高斯消元法曾大量的被使用,因此需要对其进行深入的研究。

高斯消元法,又称列主元消元法,其核心思想是通过行变换,将线性方程组变化为上三角矩阵,从而求解问题。

推广到一般情况,假设给定一个下三角矩阵A,它的行列式为D,其定义为D=det(A)。

现在,对矩阵A做行变换,可得到新的矩阵A,其满足det(A=det(A)。

如果变换的主要元素来自第一列的元素,则称之为列主元变换。

一般来说,列主元变换可以将矩阵变为上三角形,高斯消元法就是以此为基础,通过连续重复列主元变换,使得矩阵变为上三角形,从而解决非负定线性方程组求解问题。

首先,对非负定方程组进行矩阵化,可以得到一个系数矩阵A和一个常数项向量b,把它们组合进一个矩阵X,则可以表示成AX=b。

即用AE=b来表示,其中E可以代表某一个线性空间的基,比如n维空间的基Ai=(1,0,….,0),i=1,2…,n。

接下来,再以矩阵X进行转变,以第一列的元素A1、A2、A3、…、An作为主元,对A、b作列主元变换,从而使得A矩阵变为上三角矩阵。

由于变换的主元是第一列的元素,所以整个消元过程将按此进行,使得矩阵A变为三角形,如:A11 A12 A13 A14 An10 A22 A23 A24 An20 0 A33 A34 An30 0 0 A44 An4最后,只需将A阵最后一行转变为单位向量,所有的行变换就完成了,即得到上三角形:A11 A12 A13 A14 An10 A22 A23 A24 An20 0 A33 A34 An30 0 0 1 An4解这种上三角矩阵就会变得十分容易,例如,若A=(A11,A22,A33,… An-1,An),要求解每个矩阵对应的未知数向量x,只需进行下面的步骤:1. 令xn=An/An2.知xn,令xn-1=(A(n-1)-(A(n-1),A)xn)/ A(n-1)3.续令xn-2=(A(n-2)-(A(n-2),A)xn)/A(n-2)4. 一直重复上述步骤,直到x1=(A1-(A1,A)x2)/A1由此,就可以得到所求的向量X,最后,将方程组AX=b转换为可求解的上三角矩阵,即可用列主元高斯消元法得出求解的结果。

解线性方程组的列主元素高斯消去法和LU分解法

解线性方程组的列主元素高斯消去法和LU分解法

实验报告一、实验名称解线性方程组的列主元素高斯消去法和LU 分解法 二、实验目的及要求通过数值实验,用熟悉的算法语言编写程序,从中体会解线性方程组选主元素的必要性和Lu 分解法的优点,以及方程组系数矩阵和右端向量的微小变化对解向量的影响。

三、实验内容解下列两个线性方程组(1)1233.01 6.03 1.9911.274.16-1.2310.987-4.819.341x x x ⎛⎫⎛⎫⎛⎫ ⎪⎪ ⎪= ⎪⎪ ⎪ ⎪⎪ ⎪⎝⎭⎝⎭⎝⎭(2)12341070183 2.09999962 5.9000015151521021x x x x -⎛⎫⎛⎫⎛⎫ ⎪ ⎪ ⎪- ⎪ ⎪ ⎪= ⎪ ⎪ ⎪-- ⎪ ⎪ ⎪⎝⎭⎝⎭⎝⎭ 四、算法描述1、列主元高斯消去法:记(1)ij ij a a = (,1,2,i j n =) (1)i i b b = (1,2,i n =)(1)消元过程对于R=1,2,……,n-1执行: 1)选行号k i ,使()()a max k k k i k ikk i na ≤≤=2)交换()k kj a 与()a k k i k (j=k,k+1,……n)以及()k kb 与()k ik b 所含的数值。

3)对于i=k+1,k+2,……,n 计算()()/k k ik ik kk m a a =(1)()()k k k ij ij ik kja a m a +=- j=k+1,k+2,……n 。

(1)(k)()k k i i ik kb b m b +=-(2)回代过程()n /n n n nn x b a =()()()()1()/,1,2,,1.nk k k k k kj j kk j k x ba x a k n n =+=-∑=--在此算法中的()a k k i k (k=1,2,……,n-1)称为第k 个列主元素,它的数值总要被交换到第k 个主对角线元素的位置上。

高斯消去实验报告分析

高斯消去实验报告分析

一、实验背景高斯消去法(Gaussian Elimination)是线性代数中解决线性方程组的重要方法之一。

它通过初等行变换将系数矩阵化为行阶梯形矩阵,从而求解线性方程组。

本实验旨在通过编写程序实现顺序高斯消去法和列主元高斯消去法,并对比分析两种方法的计算效率和精度。

二、实验目的1. 理解高斯消去法的原理和步骤。

2. 编写程序实现顺序高斯消去法和列主元高斯消去法。

3. 比较两种方法的计算效率和精度。

4. 分析高斯消去法的适用范围和局限性。

三、实验内容1. 顺序高斯消去法- 实现顺序高斯消去法,将系数矩阵化为行阶梯形矩阵。

- 求解线性方程组,得到未知数的解。

2. 列主元高斯消去法- 实现列主元高斯消去法,将系数矩阵化为行阶梯形矩阵。

- 求解线性方程组,得到未知数的解。

3. 比较两种方法- 对比两种方法的计算效率和精度。

- 分析两种方法的优缺点。

四、实验步骤1. 编写程序- 使用C/C++、Python等编程语言编写顺序高斯消去法和列主元高斯消去法程序。

- 程序应包含以下功能:- 输入线性方程组的系数矩阵和常数项。

- 实现顺序高斯消去法和列主元高斯消去法。

- 输出求解结果。

2. 测试程序- 使用一组已知线性方程组测试程序的正确性。

- 验证求解结果与精确解是否一致。

3. 比较分析- 使用不同的线性方程组测试两种方法的计算效率和精度。

- 比较两种方法的运行时间、解的精度和误差。

五、实验结果与分析1. 顺序高斯消去法- 计算效率:顺序高斯消去法的时间复杂度为O(n^3),其中n为方程组中未知数的个数。

- 精度:顺序高斯消去法可能会受到舍入误差的影响,导致求解结果与精确解存在一定的误差。

2. 列主元高斯消去法- 计算效率:列主元高斯消去法的时间复杂度同样为O(n^3),但通过选择主元,可以减少舍入误差,提高求解精度。

- 精度:列主元高斯消去法具有更高的精度,求解结果与精确解更接近。

3. 比较分析- 顺序高斯消去法和列主元高斯消去法在计算效率上基本相同,但列主元高斯消去法具有更高的精度。

计算方法实验报告_列主元高斯消去法

计算方法实验报告_列主元高斯消去法
double row_first; //行首元素 //主对角元素单位化 for(int i=0;i<n;i++) {
row_first=A[i][i]; for(int j=0;j<n+1;j++)
计算方法实验报告
{ A[i][j]=A[i][j]/row_first;
} }
for(int k=n-1;k>0;k--) {
for(int i=0;i<N;i++) {
for(int j=0;j<N;j++) {
A_B[i][j]=A[i][j]; } A_B[i][N]=B[i][0]; } return A_B; }
3
//输出矩阵 A 的 row x col 个元素 void Show_Matrix(double **A,int row,int col) {
for(int i=0;i<N;i++)
{
int row=Choose_Colum_Main_Element(N,A_B,i);
if(Main_Element<=e) goto A_0;
Exchange(A_B,N+1,row,i);
Elimination(N,A_B,i);
cout<<"选取列主元后第"<<i+1<<"次消元:"<<endl;
double factor; for(int i=start+1;i<n;i++) {
factor=A[i][start]/A[start][start]; for(int j=start;j<n+1;j++) {

解线性方程组的列主元素高斯消去法和lu分解法

解线性方程组的列主元素高斯消去法和lu分解法

数值试验报告分析一、实验名称:解线性方程组的列主元素高斯消去法和LU 分解法二、实验目的及要求:通过数值实验,从中体会解线性方程组选主元的必要性和LU 分解法的优点,以及方程组系数矩阵和右端向量的微小变化对解向量的影响。

三、算法描述:本次试验采用的是高斯列主元消去法和LU 分解法求解线性方程组的解。

其中,高斯消去法的基本思想是避免接近于零的数作分母;能进行到底的条件:当A 可逆时,列主元Gauss(高斯)消去法一定能进行到底。

优点:具有很好的数值稳定性;具有与顺序Gauss 消去法相同的计算量。

列主元Gauss(高斯)消去法的精度显著高于顺序Gauss(高斯)消去法。

注意:省去换列的步骤,每次仅选一列中最大的元。

矩阵的三角分解法是A=LU,L 是下三角阵,U 是上三角阵,Doolittle 分解:L 是单位下三角阵,U 是上三角阵;Crout 分解:L 是下三角阵,U 是单位上三角阵。

矩阵三角分解的条件 是矩阵A 有唯一的Doolittle 分解的充要条件是A 的前n-1顺序主子式非零;矩阵A 有唯一的Crout 分解的充要条件是A 的前n-1顺序主子式非零。

三角分解的实现是通过(1)Doolittle 分解的实现; (2)Doolittle 分解的缺点:条件苛刻,且不具有数值稳定性。

(3)用Doolittle 分解求解方程组: AX=b LUX=b LY=bA=LU UX=Y ;四、实验内容:解下列两个线性方程组(1) ⎪⎪⎪⎭⎫ ⎝⎛=⎪⎪⎪⎭⎫ ⎝⎛⎪⎪⎪⎭⎫ ⎝⎛--11134.981.4987.023.116.427.199.103.601.3321x x x (2) ⎪⎪⎪⎪⎪⎭⎫ ⎝⎛=⎪⎪⎪⎪⎪⎭⎫ ⎝⎛⎪⎪⎪⎪⎪⎭⎫ ⎝⎛----15900001.582012151526099999.23107104321x x x x a 、用你熟悉的算法语言编写程序用列主元高斯消去法和LU 分解求解上述两个方程组,输出Ax=b 中矩阵A 及向量b, A=LU 分解的L 及U ,detA 及解向量x.b 、将方程组(1)中系数3.01改为3.00,0.987改为0.990,用列主元高斯消去法求解变换后的方程组,输出列主元行交换次序,解向量x及detA,并与(1)中结果比较。

高斯消元法和列主元消元法

高斯消元法和列主元消元法

用第二列的3、4行除以 k22得
- 25 - 5 = 11 = k 32 90 18 11
k
42
=
3 1 9 1
2 1 = 0 1
16 45
第三行减去第二行乘以 k 3 2 , 第四行减去第二行乘以k 4 2 。
由以上可得:
骣 1 5 ç11 ç ç 32 ç 0 19 ç ç 11 11 ç ç ç ç 1870 ç0 0 ç ç 198 ç ç ç ç 0 0 - 1727 ç ç 桫 495 - 4 25 11 1133 198 8195 495 13 ÷ ÷ ÷ 147 ÷ ÷ ÷ 11 ÷ ÷ ÷ ÷ 3003 ÷ ÷ ÷ ÷ 198 ÷ ÷ ÷ 6468 ÷ ÷ ÷ ÷ 495 ÷
- 4 25 11 1133 198 3421705518 183278700
÷ ÷ ÷ ÷ 147 ÷ ÷ ÷ 11 ÷ ÷ ÷ ÷ 3003 ÷ ÷ ÷ ÷ 198 ÷ ÷ 3421705518 ÷ ÷ ÷ ÷ 183278700 ÷
13
回代过程可得:
X 4 = 1; X 3 = 1; X 2 = 1; X 1 = 1;
1 k 41 = 11
第二行减去第一行乘以 k 21 , 第三行减去第一行乘以 第四行减去第一行乘以
k k
31


41
由此上可得:
骣 1 ç11 ç ç 90 ç0 ç ç 11 ç ç ç ç ç 0 - 25 ç ç 11 ç ç ç 32 ç0 ç ç 桫 11 5 - 4 13 ÷ ÷ ÷ 32 25 147 ÷ ÷ ÷ 11 11 11 ÷ ÷ ÷ ÷ 95 56 126 ÷ ÷ ÷ ÷ 11 11 11 ÷ ÷ ÷ - 27 191 196 ÷ ÷ ÷ ÷ 11 11 11

列选主元高斯消去法

列选主元高斯消去法

列选主元高斯消去法
列选主元高斯消去法是一种常用的线性方程组求解方法,在求解大规模线性方程组时具有较高的数值稳定性和计算效率。

该方法的基本思想是,通过选取主元来消除非主元系数的影响,以减小计算误差。

具体步骤如下:
1. 首先将线性方程组的系数矩阵进行列选主元,即对每一列选取绝对值最大的元素所在的行,然后将该行与第一行交换位置。

2. 对于第一列,将选取的主元所在行除以主元的值,使主元变为1。

3. 利用第一行的主元,通过消去操作将其他行的第一列元素变为零。

具体操作是,对于每一行,将该行与第一行乘以适当的倍数后相减,使得第一列元素为零。

4. 重复以上步骤,对第二列以及其后的列重复进行列选主元和消去操作,直到系数矩阵变成上三角矩阵。

5. 根据上三角矩阵进行回代求解,从最后一行开始,依次代入已求解的变量值,计算出未知数的值。

需要注意的是,在进行列选主元时,要注意避免主元为零或接近零的情况,以免造成计算错误或数值不稳定性。

列选主元高斯消去法可以有效地提高线性方程组的求解精度和计算效率,特别适用于存在较大数值差异或特殊矩阵结构的情况。

然而,在某些情况下,该方法可能会导致数值不稳定性或计算量较大,因此在实际应用中需综合考虑问题的特点和求解需求,选择合适的方法。

python高斯列主元素消元法

python高斯列主元素消元法

python高斯列主元素消元法高斯列主元素消元法是一种用于解线性方程组的常见方法。

它通过一系列的消元和回代操作,将线性方程组转化为上三角或下三角矩阵,从而求得方程组的解。

本文将详细介绍高斯列主元素消元法的原理和步骤,并通过实例来加深理解。

高斯列主元素消元法的原理很简单,它通过不断进行消元操作,将线性方程组转化为上三角或下三角矩阵。

消元操作的具体步骤如下:1. 首先,将线性方程组写成增广矩阵的形式,即将系数矩阵和常数向量合并到一起。

例如,对于一个3个未知数的线性方程组,可以写成如下形式:```a11*x1 + a12*x2 + a13*x3 = b1a21*x1 + a22*x2 + a23*x3 = b2a31*x1 + a32*x2 + a33*x3 = b3```其中,a11、a12、a13、b1等为已知系数,x1、x2、x3为未知数。

2. 接下来,选择第一列中绝对值最大的元素所在的行,并将该行与第一行进行交换。

这样可以确保第一列的第一个元素绝对值最大。

如果第一列的第一个元素为0,则继续选择第一列中绝对值最大的非零元素所在的行,并将该行与第一行进行交换。

3. 对于第一列的其他行,通过消元操作将其第一列的元素变为0。

具体操作如下:首先,计算第一行与其他行的倍数,使得第一行的第一个元素与其他行的第一个元素相等。

然后,将第一行的倍数与其他行相减,得到新的矩阵。

这样,第一列的其他行的第一个元素即变为0。

4. 重复以上步骤,依次处理第二列、第三列等,直到处理完所有的列。

最终得到一个上三角或下三角矩阵。

5. 最后,通过回代操作求解方程组的解。

具体操作如下:从最后一行开始,依次计算每个未知数的值。

首先,将最后一行的常数项除以最后一行的系数,得到最后一个未知数的值。

然后,将该值代入倒数第二行的方程中,求解倒数第二个未知数的值。

依次类推,直到求解出第一个未知数的值。

下面通过一个实例来进一步理解高斯列主元素消元法的应用。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

《数值分析课程设计》
报告
专业:
学号:
学生姓名:
指导教师:
一、题目
列主元guess消去法求方程的解
二、理论
列主元高斯消去法是在高斯消去法的基础上而得到的一种比较快速合理的解线性方程组的方法。

它的基本思想是每次在所在列对角线及以下元素中选择绝对值最大的元素作为主元进行消元计算。

使用列主元消去法相对于高斯消去法更能减少舍入误差的影响。

三、方法、算法与程序设计
求解Ax=b
第一步:写出增广矩阵[A| b];
第二步:判断增广矩阵的秩r[A|b]与A的秩r[A]的关系:
若r[A|b]= r[A],线性方程组有唯一解;
若r[A|b]>r[A],线性方程组没有解;
若r[A|b]<r[A],线性方程组有无穷多解;
第三步:若|A|≠0,方程组有唯一解
法一:求出A-1,x=A-1b
法二:利用初等行变换将[A| b]中A化为对角阵
计算矩阵行列式:直接调用Det[]函数计算
计算矩阵条件数:第一步:求出矩阵的逆矩阵
第二步:分别计算矩阵极其逆的无穷范数,一范数和二
范数
第三步:求解矩阵的条件数
Cond(A)∞=||A-1||∞*||A||∞
Cond(A)1=||A-1||1*||A||1
Cond(A)2=||A-1||2*||A||2=(λmax(A的转置*A)/
λmin(A的转置*A))1/2
计算机求解
第一步:消元
对k=1,2,3,……n,进行:
步骤1:选主元(第k列中第k个至第n个元素中绝对值较大者)
步骤2:将主元所在行与第k行交换
步骤3:消元
第二步:回代求解
流程图如下:k=1,2,……,n
i=k+1,k+2,……,n
l
ik =a
ik
/a
kk
得到a
ik
j=k+1,k+2,……,n+1 a ij-a ik*a kj得到a ij
三、算例、应用实例
用列主元消去法解线性方程组Ax=b
⑴ 3.10x1+ 6.03x2+1.99x3=1
1.27x1+ 4.16x2-1.23x3= 1 ;
0.983x1-4.81x2+ 9.34x3=1
⑵ 3.00x1+ 6.03x2+ 1.99x3=1
1.27x1+ 4.16x2-1.23 x3 = 1.
0.990x1 -4.81x2+9.34 x3=1
分别输出A ,b ,detA,解向量x,⑴中A的条件数。

分析比较⑴、⑵的计算结果。

输出结果为:

A =
3.100000000000000 6.030000000000000 1.990000000000000
1.270000000000000 4.160000000000000 -1.230000000000000
0.983000000000000 -4.810000000000000 9.340000000000000
b =
1
1
1
X=
-16.234490957625489
6.763269451277317
5.298697074088838
ans =
(矩阵的行列式的值)
2.9967
ans =
(A的条件数)
314.3810

A =
3.000000000000000 6.030000000000000 1.990000000000000
1.270000000000000 4.160000000000000 -1.230000000000000
0.990000000000000 -4.810000000000000 9.340000000000000
b =
1
1
1
X=
1.0e+002 *
1.195273381259593
-0.471426044312964
-0.368402561091259
ans =
-0.4070
虽然两题中A的数只差两个数,但是结果完全不同
五、参考文献
数值计算方法与算法(第二版)科学出版社
数值分析(第五版)清华大学出版社
六、附录
%高斯列主元消元法求解线性方程组Ax=b
%A为输入矩阵系数,b为方程组右端系数
%方程组的解保存在x变量中
format long;%设置为长格式显示,显示15位小数
A=[???]
det(A);
cond(A);
b=[???]'
[m,n]=size(A);
%先检查系数正确性
if m~=n
error('矩阵A的行数和列数必须相同');
return;
end
if m~=size(b)
error('b的大小必须和A的行数或A的列数相同');
return;
end
%再检查方程是否存在唯一解
if rank(A)~=rank([A,b])
error('A矩阵的秩和增广矩阵的秩不相同,方程不存在唯一解');
return;
end
c=n+1;
A(:,c)=b; %(增广)
for k=1:n-1
[r,m]=max(abs(A(k:n,k))); %选主元
m=m+k-1; %修正操作行的值
if(A(m,k)~=0)
if(m~=k)
A([k m],:)=A([m k],:); %换行
end
A(k+1:n,k:c)=A(k+1:n,k:c)-(A(k+1:n,k)/A(k,k))*A(k, k:c); %消去end
end
x=zeros(length(b),1); %回代求解
x(n)=A(n,c)/A(n,n);
for k=n-1:-1:1
x(k)=(A(k,c)-A(k,k+1:n)*x(k+1:n))/A(k,k);
end
disp('X=');
disp(x);
format short;%设置为默认格式显示,显示5位。

相关文档
最新文档