Автор работы: Пользователь скрыл имя, 21 Января 2011 в 01:59, курсовая работа
Программа разработана для решения систем нелинейных алгебраических уравнений методом Зейделя и простой итерации.
Метод Зейделя является частным случаем, метода простой итерации. Точность данных методов e= 0,001. Программа разработана на языке Borland Pascal 7.0
1. Графическое отделение корней 4
1.1 Графическое решение 5
2. Обзор методов решения систем нелинейных уравнений 6
2.1 Решение систем нелинейных уравнений 6
2.1.1 Метод простых итераций 6
2.1.2 Решение систем нелинейных уравнений методом Ньютона 7
2.1.3 Определение матрицы Якоби 9
3. Разработка и отладка программы 10
4. Блок-схема рабочей программы 11
5. Листинг программы 14
6. Решение контрольного примера 16
7. Список литературы 17
Пояснительная записка
к курсовой
работе
по дисциплине
Вычислительная математика и программирование
Методы
численного решения систем нелинейных
уравнений
Выполнил:
студент
группы
Руководитель:
Содержание
Аннотация
Программа разработана для решения систем нелинейных алгебраических уравнений методом Зейделя и простой итерации.
Метод Зейделя является частным случаем, метода простой итерации. Точность данных методов e= 0,001. Программа разработана на языке Borland Pascal 7.0
Решение уравнения
fn(xn)=0 из
системы уравнений F(xn)=0
состоит из двух этапов:
1) Отделение корней,
то есть отыскание достаточно малых областей,
в каждой из которых заключен ровно один
корень системы уравнений.
2) Вычисление каждого
отделенного корня с заданной точностью.
Отделение корней
можно произвести графически. [2]
Дана система нелинейных уравнений
Необходимо построить графики этих функций, далее преобразуем систему для решения
Проверяем условие сходимости
Находим:
Определяем область
сходимости G. [5]
Граница области сходимости определится при решении системы, полученной в ходе предыдущих действий. На графике уравнений строим область сходимости G.
Выбираем начальную
точку
, принадлежащую области сходимости G.
Используя выбранную начальную точку,
решаем заданную систему нелинейных уравнений.
Кривые, определяемые уравнением (*) изображены на рис. (1а). Эти кривые пересекаются в двух точках ξ1 и ξ2. Возьмем в качестве начального значения (графическое решение) . [3]
2.1 Решение систем нелинейных уравнений
Дана система нелинейных уравнений
или
Необходимо решить эту систему, т.е. найти вектор , удовлетворяющий системе (1) с точностью .
Вектор определяет точку в n-мерном Евклидовом пространстве, т.е. этому пространству и удовлетворяет всем уравнениям системы (1).
В отличие от систем линейных уравнений для систем нелинейных уравнений неизвестны прямые методы решения. При решении систем нелинейных уравнений используются итерационные методы. Эффективность всех итерационных методов зависит от выбора начального приближения (начальной точки), т.е. вектора .
Область, в которой начальное приближение сходится к искомому решению, называется областью сходимости G. Если начальное приближение лежит за пределами G, то решение системы получить не удается.
Выбор начальной точки во многом определяется интуицией и опытом специалиста. [5]
2.1.1 Метод простых итераций
Для применения этого метода исходная система (1) должна быть преобразована к виду
или
Далее, выбрав начальное приближение и используя систему (2), строим итерационный процесс поиска по схеме:
т.е. на каждом k-ом шаге поиска вектор переменных находим, используя значения переменных, полученных на шаге (k-1).
Итерационный процесс поиска прекращается, как только выполнится условие
При этом условие (3) должно выполняться одновременно по всем переменным.
Метод простых итераций используется для решения таких систем нелинейных уравнений, в которых выполняется условие сходимости итерационного процесса поиска, а именно:
т.е. сумма абсолютных величин частных производных всех преобразованных уравнений системы (2) по j-ой переменной меньше единицы. [5]
2.1.2 Решение систем нелинейных уравнений методом Ньютона
Дана система нелинейных уравнений
или
Необходимо решить эту систему, т.е. найти вектор , удовлетворяющий систему (5) с точностью .
Метод Ньютона наиболее распространенный метод решения систем нелинейных уравнений. Он обеспечивает более быструю сходимость по сравнению с методом итераций.
В основе метода Ньютона лежит идея линеаризации всех нелинейных уравнений системы (5). Сообщим всей системе (5) малые приращения hj и разложим каждое уравнение системы (5) в ряд Тейлора:
где
hj- приращение по каждой xj;
Ri - остаточные нелинейные члены второго и более высоких порядков каждого ряда Тейлора.
Если приращения hj таковы, что переменные xj принимают значения близкие к корню, то будем считать, что левые части уравнений системы (6) обращаются в нули. Тогда отбросив Ri сведем задачу решения системы нелинейных уравнений (5) к решению системы линейных уравнений, в которой неизвестными являются приращения hj,
Система (7) – система линейных уравнений с неизвестными hj, . Запишем (7) в матричной форме
где
Матрица А, составленая из частных производных ; называется матрицей Якоби или Якобианом.
Метод Ньютона состоит из двух этапов:
На первом этапе реализации метода Ньютона необходимо построить систему (8).
На втором этапе, начиная с начальной точки , необходимо решать систему (8) на каждом шаге итерационного процесса поиска методом Гаусса. Найденные значения приращений hj используются как поправки к решению, полученному на предыдущем шаге поиска, т.е.
или
Итерационный процесс прекращается, как только выполнится условие
по всем приращениям одновременно. [5]
2.1.3 Определение матрицы Якоби
В методе Ньютона на каждом шаге итерационного процесса поиска необходимо формировать матрицу Якоби, при этом каждый элемент матрицы можно определить:
В результате частная производная по первой координате х1 определится как
а частная производная по координате хj определится как
где .
Метод Ньютона имеет преимущества по сравнению с другими методами. Но для метода Ньютона так, же существует проблема сходимости, с увеличением числа неизвестных область сходимости уменьшается, а в случае больших систем, сходимость обеспечивается, если начальная точка близка к искомому решению. [5]
Для метода простой итерации
Для метода Зейделя
При разработке программы
использовались методы
простой итерации и Зейделя. На вход
подаются начальные значения корней
x1 и x2, просчитанные при
помощи графического решения рис. (1а).
Так же необходимо привести систему
уравнений (1) к системе вида (13) вручную,
для использование ее в программе.
Блок-схема
метода простой итерации
Блок-схема метода Зейделя
uses crt;
var
d,e,x1,x2,y1,y2:real;
c,k,p:integer;
ch:char;
function f1(x1,x2:real):real;
begin
f1:=x1*sin(x1)-x2;
end;
function f2(x1,x2:real):real;
Информация о работе Методы численного решения систем нелинейных уравнений