حساب کاربری
​
تغیر مسیر یافته از - روش گاوس سیدل
زمان تقریبی مطالعه: 5 دقیقه
لینک کوتاه

روش گاوس-سایدل

در جبر خطی عددی روش تکراری است که برای حل دستگاه معادلات خطی استفاده می‌شود

روش گاوس سایدل (به انگلیسی: Gauss–Seidel method) در جبر خطی عددی روش تکراری است که برای حل دستگاه معادلات خطی استفاده می‌شود. نام این روش از روی ریاضی‌دانان آلمانی کارل فریدریش گاوس و فیلیپ لودویگ ون سایدل نهاده شده‌است. اگرچه از این روش می‌توان در هر ماتریسی که دارای درایه قطری صفر نباشد استفاده کرد، اما فقط در صورتی همگرایی تضمین می‌شود که ماتریس مثبت معین یا قطری‌غالب باشد.

فهرست

  • ۱ توضیح
  • ۲ مثال
  • ۳ منابع
  • ۴ پیوند به بیرون

توضیح

برای یک سیستم مربعی با n معادلهٔ خطی و دارای مجهول x داریم:

A x = b

که در آن:

A = [ a 11 a 12 ⋯ a 1 n a 21 a 22 ⋯ a 2 n ⋮ ⋮ ⋱ ⋮ a n 1 a n 2 ⋯ a n n ] , x = [ x 1 x 2 ⋮ x n ] , b = [ b 1 b 2 ⋮ b n ] .

اگر A را به ماتریس پایین مثلثی و بالا مثلثی L* و U تجزیه کنیم:

A = L ∗ + U where L ∗ = [ a 11 0 ⋯ 0 a 21 a 22 ⋯ 0 ⋮ ⋮ ⋱ ⋮ a n 1 a n 2 ⋯ a n n ] , U = [ 0 a 12 ⋯ a 1 n 0 0 ⋯ a 2 n ⋮ ⋮ ⋱ ⋮ 0 0 ⋯ 0 ]

معادلات خطی سیستم به شکل زیر بازنویسی خواهند شد:

L ∗ x = b − U x

روش گاوس سایدل از روش تکراری برای حل قسمت چپ عبارت جهت به دست آوردن x بهره می‌برد، و بدین منظور از مقدار قبلی x در سمت راست عبارت استفاده می‌کند. می‌توان آن را به صورت زیر نوشت:

x ( k + 1 ) = L ∗ − 1 ( b − U x ( k ) ) .

و با استفاده از خواص ماتریس مثلثی L* می‌توان x را به صورت زیر به دست آورد:

x i ( k + 1 ) = 1 a i i ( b i − ∑ j > i a i j x j ( k ) − ∑ j < i a i j x j ( k + 1 ) ) , i = 1 , 2 , … , n .

در واقع برای محاسبه xi به همه عناصر x به جز خود xi نیاز خواهد شد.

محاسبات تا زمانی ادامه داده می‌شود تا در تکراری خاص به خطایی کمتر از مقدار مورد نظر برسیم.

مثال

برای سیستمی که به شکل A x = b

نمایش می‌دهیم داریم:

A = [ 16 3 7 − 11 ]
و b = [ 11 13 ] .

می‌خواهیم از معادله زیر

x ( k + 1 ) = L ∗ − 1 ( b − U x ( k ) )

به شکل

x ( k + 1 ) = T x ( k ) + C

استفاده کنیم، که در آن:

T = − L ∗ − 1 U
و C = L ∗ − 1 b .

باید A

به جمع دو ماتریس پایین مثلثی و بالا مثلثی L ∗
و U
تجزیه شود:

L ∗ = [ 16 0 7 − 11 ]
و U = [ 0 3 0 0 ] .

معکوس L ∗

برابر است با:

L ∗ − 1 = [ 16 0 7 − 11 ] − 1 = [ 0.0625 0.0000 0.0398 − 0.0909 ]
.

و حالا می‌توانیم مقدار زیر را پیدا کنیم:

T = − [ 0.0625 0.0000 0.0398 − 0.0909 ] × [ 0 3 0 0 ] = [ 0.000 − 0.1875 0.000 − 0.1193 ] ,
C = [ 0.0625 0.0000 0.0398 − 0.0909 ] × [ 11 13 ] = [ 0.6875 − 0.7443 ] .

و با استفاده از T

و C
مقدار x
را به صورت تکرار به دست می‌آوریم.

باید مقدار اولیه را به صورت حدس انتخاب کنیم، برای همین فرض می‌کنیم:

x ( 0 ) = [ 1.0 1.0 ] .

حال می‌توانیم محاسبه کنیم:

x ( 1 ) = [ 0.000 − 0.1875 0.000 − 0.1193 ] × [ 1.0 1.0 ] + [ 0.6875 − 0.7443 ] = [ 0.5000 − 0.8636 ] .
x ( 2 ) = [ 0.000 − 0.1875 0.000 − 0.1193 ] × [ 0.5000 − 0.8636 ] + [ 0.6875 − 0.7443 ] = [ 0.8494 − 0.6413 ] .
x ( 3 ) = [ 0.000 − 0.1875 0.000 − 0.1193 ] × [ 0.8494 − 0.6413 ] + [ 0.6875 − 0.7443 ] = [ 0.8077 − 0.6678 ] .
x ( 4 ) = [ 0.000 − 0.1875 0.000 − 0.1193 ] × [ 0.8077 − 0.6678 ] + [ 0.6875 − 0.7443 ] = [ 0.8127 − 0.6646 ] .
x ( 5 ) = [ 0.000 − 0.1875 0.000 − 0.1193 ] × [ 0.8127 − 0.6646 ] + [ 0.6875 − 0.7443 ] = [ 0.8121 − 0.6650 ] .
x ( 6 ) = [ 0.000 − 0.1875 0.000 − 0.1193 ] × [ 0.8121 − 0.6650 ] + [ 0.6875 − 0.7443 ] = [ 0.8122 − 0.6650 ] .
x ( 7 ) = [ 0.000 − 0.1875 0.000 − 0.1193 ] × [ 0.8122 − 0.6650 ] + [ 0.6875 − 0.7443 ] = [ 0.8122 − 0.6650 ] .

و همانگونه که انتظار داشتیم به مقدار دقیق همگرا شد:

x = A − 1 b = [ 0.8122 − 0.6650 ] .

منابع

  • Black, Noel and Moore, Shirley. "Gauss-Seidel Method". MathWorld.

پیوند به بیرون

  • www.math-linux.com
  • محاسبه گاوس-سایدل
  • روش گاوس-سایدل
  • کد متلب
آخرین نظرات
کلیه حقوق این تارنما متعلق به فرا دانشنامه ویکی بین است.