- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第三章 线性方程组的解算
第三章 线性方程组的解算
测绘观测数据处理主要采用最小二乘法进行解算,平差计算中的法方程式为线性方程组。本章主要介绍线性方程组解算及相应的程序设计。
§3-1 高斯(GAUSS)消去法
3.1.1 非对称方程组求解
设有非对称方程Ax = b,其中,A是 m×m阶非奇异实矩阵,b是给定的m×1阶向量。为了说明简便,下面表3-1以4阶方程组为例介绍消去法的具体做法。(设矩阵A的主元素不等于零)
表3-1 消去法解非对称线性方程
a11 a12 a13 a14
a21 a22 a23 a24
a31 a32 a33 a34
a41 a42 a43 a44 b1
b2
b3
b4 消
去
第
一
列 a11 a12 a13 a14
0 a′22 a′23 a′24
0 a′32 a′33 a′34
0 a′42 a′43 a′44 b1
b′2
b′3
b′4 a′ij = aij-ai1 a1j / a11
b′i = bi -ai1 b1 / a11
i , j = 2,3,4 消
去
第
二
列 a11 a12 a13 a14
0 a′22 a′23 a′24
0 0 a33 a34
0 0 a43 a44 b1
b′2
b3
b4 aij=a′ij-a′i2a′2j / a′22
bi=b′i-a′i2 b′2 / a′22
i , j = 3,4 ……………………… … …………………… 根据上表的消去过程,归纳如下:
消去第k个未知数是从k+1行开始,使第k列所有元素为零。(k = 1,2,…, m-1)
从第k+1列开始,各元素为
(3-1)
(3-2)
用赋值语句写为
(3-3)
(3-4)
k = 1,2,…, m-1;i = k+1, … ,m; j = k+1, … ,m。
将上述消去过程用VB语言写成程序如下:
Sub GS1(m as Integer)
Dim c as Double
For k=1 To m-1
For i=k+1 To m
c=a(I,k)/a(k,k)
For j=k+1 to m
a(I,J)=a(I,J)-c *a(k,J)
Next j
b(i)=b(i)-b(k)*c
Next i
Next k
End Sub
3.1.2 列主元消去法
为了避免主元素等于零而使消去过程失败,有时由于主元素的有效数字严重损失而使舍入误差的相对误差增大,舍入误差扩散使得最终答解极不准确。为克服这些困难,选主元消去法是有效的。选主元消去法有列主元消去法、行主元消去法、全选主元消去法几种。列主元消去法是从第k列(k = 1,2, …, m)的各元素寻出最大元作为主元,其具体做法如下:
从第1列开始,寻找本列绝对值最大的元素,记下该元素所在的行数(i0),并把该行(i0)与第1行(k行)的所有元素互换(即把第i0行移至第k行,使主元素是本列中最大元)。
按式(3-1)和(3-2)进行消元。
将上述消去过程用VB语言写成程序如下:
Sub GS2(m As Integer)
Dim t As Double
Dim i0 As Integer
Dim c As Double
For k= 1 To m - 1
c = 0#
i0 = k
For i = k To m
If Abs(A(i, k)) Abs(c) Then
c = a(i, k)
i0 = i
End If
Next i
If i0 =k Then GoTo 30
For i =k To m
t = A(k, j)
a(k, j) = a(i0, j)
a(i0,j) = t
Next j
t = b(k)
b(k) = b(i0)
b(i0) = t
30:
For i = k + 1 To m
c = a(i, k) / a(k, k)
For j= k + 1 To m
a(i, j) = a(i, j) - c * a(k, j)
Next j
b(i) =
文档评论(0)