Численные методы решения нелинейных уравнений
Разновидность комбинаторных задач, их характеристика и специфика. Этапы приближенного решения нелинейных уравнений, графическое и аналитическое отделение корней. Описание и отличительные черты методов решения нелинейных уравнений, их применение.
Рубрика | Математика |
Вид | курсовая работа |
Язык | русский |
Дата добавления | 14.03.2015 |
Размер файла | 759,7 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Размещено на http://www.allbest.ru/
Министерство образования Российской Федерации
Федеральное государственное бюджетное образовательное учреждение
высшего профессионального образования
«Орловский государственный университет»
Физико-математический факультет
Кафедра информатики
Курсовая работа
"Численные методы решения нелинейных уравнений"
Кравченко Анна Викторовна
Орел - 2011
Содержание
Введение
Численные методы решения нелинейных уравнений
Постановка задачи
Этапы приближенного решения нелинейных уравнений
Определение корней
Уточнение корней
Основные методы решения нелинейных уравнений
Метод половинного деления
Метод касательных (Ньютона)
Метод секущих (хорд)
Метод простой итерации
Заключение
Список используемой литературы
Введение
Очень часто в различных областях экономики приходится встречаться с математическими задачами, для которых не удается найти решение классическими методами или решения выражены громоздкими формулами, которые не приемлемы для практического использования. Поэтому большое значение приобрели численные методы. В большинстве случаев численные методы являются приближенными, так как с их помощью обычно решаются задачи, аппроксимирующие исходные. В ряде случаев численный метод строится на базе бесконечного процесса, который в пределе сводится к искомому решению. Однако реально предельный переход не удается осуществить, и процесс, прерванный на некотором шаге, дает приближенное решение. Кроме того, источниками погрешности являются несоответствие математической модели изучаемому реальному явлению и погрешность исходных данных.
Решение систем нелинейных алгебраических уравнений - одна из сложных и до конца не решенных задач. Даже о расположении и существовании корней систем нелинейных уравнений почти ничего нельзя сказать. Большинство методов решения систем нелинейных уравнений сходятся к решению, если начальное приближение достаточно близко к нему, и могут вообще не давать решения при произвольном выборе начального приближения. Условия и скорость сходимости каждого итерационного процесса существенно зависят от свойств уравнений, то есть от свойств матрицы системы, и от выбора начальных приближений.
В своей курсовой работе я поставила три основные цели и задачи:
1. Изучение разновидности комбинаторных задач.
2. Изучение основных комбинаторных операций.
3. Изучение комбинаторики как раздел элементарной алгебры.
Для достижения поставленных целей и решения задач в курсовой работе я использовала различные источники информации. В основном это были книги Бахвалов Н. С. Численные методы и Вержбицкий В. М. Численные методы. Линейная алгебра и нелинейные уравнения. В них четко и точно изложен нужный для моей курсовой работы материал.
Курсовая работа построена таким образом, что сначала идут сведения о численных методах в целом, а уже после более подробно рассмотрены решения нелинейных уравнений.
Численные методы
Проблема численного решения линейных уравнений интересует математиков уже несколько столетий. Первые математические результаты появились в XVIII веке. В 1750 году Г. Крамер (1704-1752) опубликовал свои труды по детерминантам квадратных матриц и предложил алгоритм нахождения обратной матрицы, известный как правило Крамера. Гаусс в 1809 году опубликовал работу, посвященную движению небесных тел, в которой был изложен метод для решения линейных систем, известный как метод исключения.
В 40-х годах XX века с появлением компьютеров сильно возрос интерес к численным методам. Тогда же началось активное исследование существующих методов для их реализации на ЭВМ и предпринимались активные попытки увеличить их точность.
Вплоть до 80-х годов решение вычислительных задач было ограничено ресурсами ЭВМ, поэтому особое значение придавалось экономичности алгоритмов. комбинаторный нелинейный уравнение графический
В настоящее время ограничения по оперативной памяти и быстродействию ЭВМ потеряли актуальность в связи с появлением относительно дешевых мини- и суперкомпьютеров.
Постановка задачи
Пусть имеется уравнение вида
f (x) = 0. (1)
где f (x) - заданная алгебраическая или трансцендентная функция. (Функция называется алгебраической, если для получения её значения нужно выполнить арифметические операции и возведение в степень с рациональным показателем. Примеры трансцендентных функций - показательная, логарифмическая, тригонометрические, обратные тригонометрические.)
Решить уравнение - значит найти все его корни, то есть те значения x, которые обращают уравнение в тождество, или доказать, что корней нет.
Если алгебраическое или трансцендентное уравнение достаточно сложно, то довольно редко удается точно найти его корни. Кроме того, в некоторых случаях уравнение может содержать коэффициенты, известные лишь приблизительно, поэтому сама задача о точном нахождении корней теряет смысл. В таких случаях применяют численные (приближенные) методы решения.
Поставим задачу найти такое приближенное значение корня xпр, которое мало отличается от точного значения корня x*, так что выполняется неравенство ¦x* - xпр ¦< e , где e (эпсилон) - малая положительная величина - допустимая ошибка, которую мы можем заранее задать по своему усмотрению. Если корень найден с точностью e, то принято писать x*=xпр±e.
Будем предполагать, что уравнение (1) имеет лишь изолированные корни, т.е. для каждого корня существует окрестность, не содержащая других корней этого уравнения.
Этапы приближенного решения нелинейных уравнений
Приближенное решение уравнения состоит из двух этапов:
1. Отделение корней, то есть нахождение интервалов из области определения функции f (x), в каждом из которых содержится только один корень уравнения (1).
2. Уточнение корней до заданной точности.
Отделение корней
Отделение корней можно проводить графически и аналитически.
Для того чтобы графически отделить корни уравнения (1), необходимо построить график функции y=f(x). Абсциссы точек его пересечения с осью Ox являются действительными корнями уравнения (рис. 1).
Рис. 1. Графическое отделение корней (1-ый способ).
На практике же бывает удобнее заменить уравнение (1) равносильным ему уравнением
ц(x)=ш(x), (2)
где ц(x) и ш(x) - более простые функции, чем f(x). Абсциссы точек пересечения графиков функций y= ц(x) и y= ш(x) дают корни уравнения (2), а значит и исходного уравнения (1) (рис.2).
Рис 2. Графическое отделение корней (2-ой способ).
Пример 1. Отделить графически корень уравнения 1-x2+x3=0.
Решение. Для решения задачи построим график функции y=1-x2+x3 (рис. 3).
Рис. 3. График функции y=1-x2+x3.
Из рисунка видно, что один из корней уравнения принадлежит отрезку [-1,2;-0,8], второй - отрезку [0,8;1,2]. Так как рассматриваемое уравнение имеет третью степень, то должен существовать еще один корень на интервале (3,2;+?).
Аналитическое отделение корней основано на следующих теоремах.
Теорема 1. Если непрерывная функция y=f(x) принимает на концах отрезка [a;b]значения разных знаков, т.е. f(a)•f(b)<0, то на этом отрезке содержится по крайней мере один корень уравнения (1) (рис. 4).
Рис. 4. Существование корня на отрезке.
Теорема 2. Если непрерывная на отрезке[a;b] функция y=f(x) принимает на концах отрезка значения разных знаков, а производная f '(x) сохраняет знак внутри отрезка [a;b] , то внутри отрезка существует единственный корень уравнения f (x) = 0 (рис. 5).
Рис. 5. Существование единственного корня на отрезке.
Пример 2. Подтвердить аналитически правильность нахождения отрезка изоляции корня уравнения (x-1)2-ex=0.
Решение. Для отрезка [0;1] имеем: f(0)=(0-1)2-e0=0,5;
f(1)=(1-1)2-e1=-e=-1.359 .Значит, f(0)•f(1)<0. Следовательно, корень отделён правильно.
Уточнение корней
Уточнение корней до заданной точности заключается в сужении интервала изоляции корня и выполняется одним из специальных методов. Наиболее распространенными являются метод деления отрезка пополам, метод касательных (Ньютона), метод секущих (хорд), метод простой итерации.
Основные методы решения нелинейных уравнений
Уравнение типа F(x)=0 или x=f(x) называется нелинейным. Решить уравнение это значит найти такое x, при котором уравнение превращается в тождество. В общем случае уравнение может иметь 0; 1; 2;...? корней. Рассмотренные ниже численные методы решения нелинейных уравнений позволяют находить один корень на заданном интервале [a,b]. При этом на интервале должен существовать только один корень. Рассмотрим несколько методов решения нелинейных уравнений.
Метод половинного деления
Метод деления отрезка пополам имеет другие названия: метод половинного деления, метод дихотомии, метод проб, метод бисекций.
Пусть корень уравнения f (x) = 0 отделен на отрезке[a;b] , т.е. f(a)•f(b)<0.
Алгоритм приближенного вычисления корня методом половинного деления.
Исходные данные: f (x) - функция; е - требуемая точность; a, b - границы заданного интервала (границы поиска корня).
Результат: xпр - приближенный корень уравнения f (x) = 0.
Метод решения:
Шаг 1. Выбрать середину отрезка[a;b] в качестве приближенного корня.
Шаг 2. Если f(c)=0, то c - искомый корень уравнения, на этом прекращаем вычисления. В противном случае перейти к шагу 3.
Шаг 3. Точный корень уравнения x* отличается от c не более чем на половину длины отрезка, т.е. не более чем на (полученная точность). Проверяем условие . Если условие не выполняется, т.е. полученная точность нас не устраивает (она больше, чем требуемая), то перейти к шагу 4; в противном случае прекратить вычисления, поскольку мы достигли требуемой точности, и приближенным корнем уравнения f(x) = 0 считать середину c отрезка [a;b] .
Шаг 4. Определить интервал дальнейшего поиска корня. Из двух образовавшихся при делении отрезков переходим к той из его половин [a;c] и [c;b] , на концах которого функция принимает значения разных знаков.
Случай 1 (рис. 1). Корень на отрезке [a;c]. f(a)•f(c)?0, граница b сдвигается влево - заменить b на с: b:= c.
Рис. 1. Графическая иллюстрация метода половинного деления.
Случай 2 (рис. 1). Корень на отрезке [c;b] . f(a)•f(c)>0, граница a сдвигается вправо - заменить a на с: a:= c.
Перейти к шагу 1.
Алгоритм деления отрезка пополам довольно медленный, но зато абсолютно застрахован от неудач. Основное достоинство метода состоит в том, что его скорость сходимости не зависит от вида функции f (x). Данный метод не имеет дополнительных условий сходимости, кроме f(a)•f(b)<0.
Метод касательных
Пусть на отрезке [a; b] отделен корень с уравнения f (x) = 0 и f -функция непрерывна на отрезке [a; b], а на интервале (a; b) существуют отличные от нуля производные f ' и f ”.
Так как f '(x) ? 0 , то запишем уравнение f (x) = 0 в виде:
x = x - ( f (x) / f '(x)) (1)
Решая его методом итераций можем записать :
xn+1 = x n- ( f (x n) / f '(x n)) (2)
Если на отрезке [a;b] f '(x) * f “(x) > 0, то нулевое приближение выбираем x0=a. Рассмотрим геометрический смысл метода. Рассмотрим график функции y=f(x). Пусть для определенности f `(x) > 0 и f “(x) > 0 (рис. 1). Проведем касательную к графику функции в точке B (b, f (b)). Ее уравнение будет иметь вид:
y = f (b) + f '(b) * (x - b)
Полагая в уравнении y = 0 и учитывая, что f '(x) ? 0, решаем его относительно x. Получим :
x = b - (f (b) /f `(b))
Нашли абсциссу x1 точки c1 пересечения касательной с осью Оx:
x1 = b - (f (b) - f ' (b))
Проведем касательную к графику функции в точке b1 (x1; f (x1)).Найдем абсциссу x2 точки с2 пересечения касательной с осью Ox :
x2 = x1 - (f (x1) / ( f '(x1))
Вообще :
xk+1 = x k - ( f (x k) / f '(x k)) (3)
Таким образом, формула (3) дает последовательные приближения (xk) корня, получаемые из уравнения касательной , проведенной к графику функции в точке b k (x k; f (x k0) метод уточнения корня c [a;b] уравнения f (x) = 0 с помощью формулы (3) называется методом касательной или методом Ньютона.
Геометрический смысл метода касательных состоит в замене дуги y = f (x) касательной, одной к одной из крайних точек . Начальное приближение x 0=a или x0 = b брать таким, чтобы вся последовательность приближения х k принадлежала интервалу (a;b). В случае существования производных f ', f ”, сохраняющих свои знаки в интервале, за х0 берется тот конец отрезка [a;b], для которого выполняется условие f '(х0) * f (х0) > 0. Для оценки приближения используется общая формула :
|c-x k-1 | ? | f (x k+1)/m| , где m = min f '(x) на отрезке [a;b] .
На практике проще пользоваться другим правилом :
Если на отрезке [a;b] выполняется условие 0 < m < | f (x)| и ?????заданная точность решения, то неравенство | x k+1-x k| ? ??? влечет выполнение неравенства |c-x k-1| ? ????
В этом случае процесс последовательного приближения продолжают до тех пор, пока не выполнится неравенство:
|c-x k-1| ? ????
Пример 1. Определим корни уравнения х3 + 0,1х2 + 0,4х - 1,2 = 0 аналитически. Находим: f (x) = х3 + 0,1х2 + 0,4х - 1,2
f ` (x) = 3х2 + 0,1х + 0,4
f (-1) = -2,5 < 0 f (0) = -1,2 < 0 f (+1) = 0,3 > 0
x |
- ? |
-1 |
0 |
+1 |
+ ? |
|
sign f (x) |
- |
- |
- |
+ |
+ |
Следовательно, уравнение имеет действительный корень, лежащий в промежутке [0; +1].
Приведем уравнение к виду x = ? (x), так, чтобы |? ` (x)|<1 при 0 ??x ? +1.
Так как max | f '(x) | = f '(+1) = 3 + 0,1 + 0,4 = 3,5 то можно взять R = 2.
Тогда ? (x) = x - ( f (x) / R) = x - 0,5 х3 - 0,05 х2 - 0,2 х + 0,6 = - 0,5 х3 - 0,05 х2 + 0,8 х + 0,6.
Вычисления расположим в таблице.
n |
хn |
х2n |
х3n |
? (хn). |
f (x) |
|
1 |
1 |
1 |
1 |
0,85 |
-0,17363 |
|
2 |
0,85 |
0,7225 |
0,614125 |
0,9368125 |
0,08465 |
|
3 |
0,9368125 |
0,87761766 |
0,822163194 |
0,89448752 |
-0,04651 |
|
4 |
0,89448752 |
0,800107923 |
0,715686552 |
0,917741344 |
0,024288 |
|
5 |
0,917741344 |
0,842249174 |
0,772966889 |
0,905597172 |
-0,01306 |
|
6 |
0,905597172 |
0,820106238 |
0,74268589 |
0,912129481 |
0,006923 |
|
7 |
0,912129481 |
0,83198019 |
0,758873659 |
0,908667746 |
-0,0037 |
|
8 |
0,908667746 |
0,825677072 |
0,750266124 |
0,910517281 |
0,001968 |
|
9 |
0,910517281 |
0,829041719 |
0,754856812 |
0,909533333 |
-0,00105 |
|
10 |
0,909533333 |
0,827250884 |
0,752412253 |
0,910057995 |
0,000559 |
|
11 |
0,910057995 |
0,828205555 |
0,753715087 |
0,909778575 |
-0,0003 |
|
12 |
0,909778575 |
0,827697055 |
0,753021048 |
0,909927483 |
0,000159 |
|
13 |
0,909927483 |
0,827968025 |
0,753390861 |
0,909848155 |
-8,5E-05 |
|
14 |
0,909848155 |
0,827823665 |
0,753193834 |
0,909890424 |
4,5E-05 |
|
15 |
0,909890424 |
0,827900583 |
0,753298812 |
0,909867904 |
-2,4E-05 |
|
16 |
0,909867904 |
0,827859602 |
0,753242881 |
0,909879902 |
1,28E-05 |
|
17 |
0,909879902 |
0,827881437 |
0,753272681 |
0,90987351 |
-6,8E-06 |
|
18 |
0,90987351 |
0,827869803 |
0,753256804 |
0,909876916 |
3,63E-06 |
|
19 |
0,909876916 |
0,827876002 |
0,753265263 |
0,909875101 |
-1,9E-06 |
|
20 |
0,909875101 |
0,827872699 |
0,753260756 |
0,909876068 |
1,03E-06 |
График функции y = х3 + 0,1х2 + 0,4х - 1,2
Блок-схема программы
Размещено на http://www.allbest.ru/
Размещено на http://www.allbest.ru/
Программа на языке Paskal
program metod_kasatel;
var xn,xn1,a,b,c,mx,y0,x0:real;
function f1(x1:Real): Real;
begin
f1 := x1*x1*x1*(-0.5)-0.05*x1*x1+0.8*x1+0.6;
end;
function f2(x4:Real): Real; {Производная от основной функции}
begin
f2 := x4*x4*x4+0.5*x4*x4+0.1*x4*x4+0.4*x4-1.2;
end;
begin
a:=0;b:=1;c:=0.00000001;
Writeln(' От A=',a,' до B=',b);
Writeln(' Погрешность с=',c);
Readln;
xn:=b;
xn1:= f1(xn);
y0:=f2(b);
while ABS(y0)>c do {Проверка по точности вычисления корня}
begin xn:=xn1;
xn1:=f1(xn);
y0:= f2(xn1);
{Печать промежуточного результата}
Writeln('xn=',xn,' xn+1=',xn1,' f(xn+1)=',y0);
Readln;
end;
Writeln('Конечные значения'); {Печать полученного результата}
Writeln(' xn+1=',xn1,' f(xn+1)=',y0);
end.
Результат выполнения программы
От A= 0.0000000000E+00 до B= 1.0000000000E+00
Погрешность с= 1.0000000000E-08
От A= 0.0000000000E+00 до B= 1.0000000000E+00
Погрешность с= 1.0000000000E-08
xn= 8.5000000000E-01 xn+1= 9.3681250000E-01 f(xn+1)= 8.4649960270E-02
xn= 9.3681250000E-01 xn+1= 8.9448751986E-01 f(xn+1)=-4.6507647892E-02
xn= 8.9448751986E-01 xn+1= 9.1774134381E-01 f(xn+1)= 2.4288343840E-02
xn= 9.1774134381E-01 xn+1= 9.0559717189E-01 f(xn+1)=-1.3064617920E-02
xn= 9.0559717189E-01 xn+1= 9.1212948085E-01 f(xn+1)= 6.9234699658E-03
xn= 9.1212948085E-01 xn+1= 9.0866774587E-01 f(xn+1)=-3.6990702320E-03
xn= 9.0866774587E-01 xn+1= 9.1051728099E-01 f(xn+1)= 1.9678960780E-03
xn= 9.1051728099E-01 xn+1= 9.0953333295E-01 f(xn+1)=-1.0493249720E-03
xn= 9.0953333295E-01 xn+1= 9.1005799543E-01 f(xn+1)= 5.5884091853E-04
xn= 9.1005799543E-01 xn+1= 9.0977857497E-01 f(xn+1)=-2.9781681224E-04
xn= 9.0977857497E-01 xn+1= 9.0992748338E-01 f(xn+1)= 1.5865717614E-04
xn= 9.0992748338E-01 xn+1= 9.0984815480E-01 f(xn+1)=-8.4537703515E-05
xn= 9.0984815480E-01 xn+1= 9.0989042365E-01 f(xn+1)= 4.5040009354E-05
xn= 9.0989042365E-01 xn+1= 9.0986790364E-01 f(xn+1)=-2.3997676180E-05
xn= 9.0986790364E-01 xn+1= 9.0987990248E-01 f(xn+1)= 1.2785800209E-05
xn= 9.0987990248E-01 xn+1= 9.0987350958E-01 f(xn+1)=-6.8122881203E-06
xn= 9.0987350958E-01 xn+1= 9.0987691573E-01 f(xn+1)= 3.6295678001E-06
xn= 9.0987691573E-01 xn+1= 9.0987510095E-01 f(xn+1)=-1.9338276616E-06
xn= 9.0987510095E-01 xn+1= 9.0987606786E-01 f(xn+1)= 1.0303429008E-06
xn= 9.0987606786E-01 xn+1= 9.0987555269E-01 f(xn+1)=-5.4896190704E-07
xn= 9.0987555269E-01 xn+1= 9.0987582717E-01 f(xn+1)= 2.9248803912E-07
xn= 9.0987582717E-01 xn+1= 9.0987568093E-01 f(xn+1)=-1.5583464119E-07
xn= 9.0987568093E-01 xn+1= 9.0987575885E-01 f(xn+1)= 8.3031409304E-08
xn= 9.0987575885E-01 xn+1= 9.0987571733E-01 f(xn+1)=-4.4236003305E-08
xn= 9.0987571733E-01 xn+1= 9.0987573945E-01 f(xn+1)= 2.3572283681E-08
xn= 9.0987573945E-01 xn+1= 9.0987572766E-01 f(xn+1)=-1.2558302842E-08
Конечные значения
xn+1= 9.0987573394E-01 f(xn+1)= 6.6920620156E-09
Метод хорд
Пусть на отрезке [a;b] функция непрерывна, принимает на концах отрезка значение разных знаков, а производная f '(x) сохраняет знак. В зависимости от знака второй производной возможны следующие случаи расположения кривых (рис. 1).
Рис. 1. Возможные случаи расположения кривых.
Алгоритм приближенного вычисления корня методом хорд.
Исходные данные: f (x) - функция; е - требуемая точность; x0 - начальное приближение.
Результат: xпр - приближенный корень уравнения f (x) = 0.
Метод решения:
Рис. 2. Геометрическая интерпретация метода хорд для случая f '(x) f ''(x)>0.
Рассмотрим случай, когда f '(x) и f ''(x) имеют одинаковые знаки (рис. 2).
График функции проходит через точки A0(a,f(a)) и B0(b,f(b)). Искомый корень уравнения (точка x*) нам неизвестен, вместо него возьмет точку х1 пересечения хорды А0В0 с осью абсцисс. Это и будет приближенное значение корня.
В аналитической геометрии выводится формула, задающая уравнение прямой, проходящей через две точки с координатами (х1; у1) и (х2; у2): .
Тогда уравнение хорды А0В0 запишется в виде: .
Найдем значение х = х1, для которого у = 0: . Теперь корень находится на отрезке [x1;b]. Применим метод хорд к этому отрезку. Проведем хорду, соединяющую точки A1(x1,f(x1)) и B0(b,f(b)), и найдем х2 - точку пересечения хорды А1В0 с осью Ох: x2=x1 .
Продолжая этот процесс, находим
x3=x2.
Получаем рекуррентную формулу вычисления приближений к корню
xn+1=xn.
В этом случае конец b отрезка [a;b] остается неподвижным, а конец a перемещается.
Таким образом, получаем расчетные формулы метода хорд:
xn+1=xn; x0=a. (4)
Вычисления очередных приближений к точному корню уравнения продолжается до тех пор, пока не достигнем заданной точности, т.е. должно выполняться условие: |xn+1-xn|<, где - заданная точность.
Теперь рассмотрим случай, когда первая и вторая производные имеют разные знаки, т.е. f '(x) f ''(x)<0. (рис. 3).
Рис. 3. Геометрическая интерпретация метода хорд для случая f '(x) f ''(x)<0.
Соединим точки A0(a,f(a)) и B0(b,f(b)) хордой А0В0. Точку пересечения хорды с осью Ох будем считать первым приближение корня. В этом случае неподвижным концом отрезка будет являться конец а.
Уравнение хорды А0В0:. Отсюда найдем x1, полагая y = 0: x1=b. Теперь корень уравнения x[a;x1]. Применяя метод хорд к этому отрезку, получим x2=x1. Продолжая и т.д., получим xn+1=xn.
Расчетные формулы метода:
xn+1=xn, x0=0 . (5)
Условие окончания вычислений: |xn+1-xn|<. Тогда хпр = xn+1 с точностью Итак, если f '(x) f ''(x)>0 приближенное значение корня находят по формуле (4), если f '(x) f ''(x)<0, то по формуле (5).
Практический выбор той или иной формулы осуществляется, пользуясь следующим правилом: неподвижным концом отрезка является тот, для которого знак функции совпадает со знаком второй производной.
Пример. Проиллюстрировать действие этого правила на уравнении
(x-1)ln(x)-1=0, если отрезок изоляции корня [2;3].
Решение. Здесь f(x)=(x-1)ln(x)-1.
f '(x)=ln(x)+;
f ''(x)=.
Вторая производная в этом примере положительна на отрезке изоляции корня [2;3]: f ''(x)>0, f(3)>0, т.е. f(b) f''(x)>0. Таким образом, при решении данного уравнения методом хорд для уточнения корня выбираем формулы (4).
program horda;
var e,c,a,b,y,ya,yb,yn,x,x1,x2,xn,f1,f2:real;
begin e:=0.0001;
writeln('vvedi nachalo otrezka');
readln(a);
writeln('vvedi konec otrezka');
readln(b);
x:=a;
y:=((x-1)*ln(x))-1;
ya:=y; x:=b;
y:=((x-1)*ln(x))-1;
yb:=y; c:=(a+b)/2; x:=c;
y:=((x-1)*ln(x))-1;
f1:=ln(x) + (x-1)/x ;
f2:= 1/x + 1/(x*x);
if (ya*yb < 0) and (f1*f2 > 0)
then begin x1:=a; while abs(x2 - x) > e do
begin x:=x1; y:=((x-1)*ln(x))-1; yn:=y;
x2:=x1 - (yn*(b-x1))/(yb - yn);
x1:=x2; end;
writeln('koren uravneniya xn = ', x2)
end elsebegin x1:=b;
while abs(x2 - x) > e do
begin x:=x1; y:=((x-1)*ln(x))-1; yn:=y;
x2:=x1 - (yn*(x1- a))/(yn - ya);
x1:=x2; end;
writeln('koren uravneniya xn = ', x2);
end;
end.
Метод простых итераций
Рассмотрим уравнение f(x)=0 (1) с отделенным корнем X[a, b]. Для решения уравнения (1) методом простой итерации приведем его к равносильному виду: x=ц(x). (2)
Это всегда можно сделать, причем многими способами. Например:
x=g(x) · f(x) + x ? ц(x), где g(x) - произвольная непрерывная функция, не имеющая корней на отрезке [a,b].
Пусть x(0) - полученное каким-либо способом приближение к корню x (в простейшем случае x(0)=(a+b)/2). Метод простой итерации заключается в последовательном вычислении членов итерационной последовательности:
x(k+1)=ц(x(k)), k=0, 1, 2, ... (3)
начиная с приближения x(0).
УТВЕРЖДЕНИЕ: 1 Если последовательность {x(k)} метода простой итерации сходится и функция ц непрерывна, то предел последовательности является корнем уравнения x=ц(x)
ДОКАЗАТЕЛЬСТВО: Пусть . (4)
Перейдем к пределу в равенстве x(k+1)=ц(x(k)) Получим с одной стороны по (4), что а с другой стороны в силу непрерывности функции ц и (4) .
В результате получаем x*=ц(x*). Следовательно, x* - корень уравнения (2), т.е. X=x*.
Чтобы пользоваться этим утверждением нужна сходимость последовательности {x(k)}. Достаточное условие сходимости дает:
ТЕОРЕМА 1: (о сходимости) Пусть уравнение x=ц(x) имеет единственный корень на отрезке [a,b] и выполнены условия:
1) ц(x) C1[a,b];
2) ц(x) [a,b] " x [a,b];
3) существует константа q > 0: | ц '(x) | ? q < 1 x [a,b]. Tогда итерационная последовательность {x(k)}, заданная формулой x(k+1) = ц(x(k)), k=0, 1, ... сходится при любом начальном приближении x(0) [a,b].
ДОКАЗАТЕЛЬСТВО: Рассмотрим два соседних члена последовательности {x(k)}: x(k) = ц(x(k-1)) и x(k+1) = ц(x(k)) Tак как по условию 2) x(k) и x(k+1) лежат внутри отрезка [a,b], то используя теорему Лагранжа о средних значениях получаем:
x (k+1) - x (k) = ц(x (k)) - ц(x (k-1)) = ц '(c k )(x (k) - x (k-1)), где c k (x (k-1), x (k)).
Отсюда получаем:
| x (k+1) - x (k) | = | ц '(c k ) | · | x (k) - x (k-1) | ? q | x (k) - x (k-1)| ?
? q ( q | x (k-1) - x (k-2) | ) = q 2 | x (k-1) - x (k-2) | ? ... ? q k | x (1) - x (0) |. (5)
Рассмотрим ряд
S? = x (0) + ( x (1) - x (0) ) + ... + ( x (k+1) - x (k) ) + ... . (6)
Если мы докажем, что этот ряд сходится, то значит сходится и последовательность его частичных сумм
Sk = x (0) + ( x (1) - x (0) ) + ... + ( x (k) - x (k-1) ).
Но нетрудно вычислить, что
Sk = x (k)). (7)
Следовательно, мы тем самым докажем и сходимость итерационной последовательности {x(k)}.
Для доказательства сходимости pяда (6) сравним его почленно (без первого слагаемого x(0)) с рядом
q 0 | x (1) - x (0) | + q 1 |x (1) - x (0)| + ... + |x (1) - x (0)| + ..., (8)
который сходится как бесконечно убывающая геометрическая прогрессия (так как по условию q < 1). В силу неравенства (5) абсолютные величины ряда (6) не превосходят соответствующих членов сходящегося ряда (8) (то есть ряд (8) мажорирует ряд (6). Следовательно ряд (6) также сходится. Tем самым сходится последовательность {x(0)}.
Получим формулу, дающую способ оценки погрешности |X - x (k+1)|
метода простой итерации.
Имеем
X - x(k+1) = X - Sk+1 = S? - Sk+1 = (x(k+2) - (k+1) ) + (x(k+3) - x(k+2) ) + ... .
Следовательно
|X - x(k+1)| ? |x(k+2) - (k+1) | + |x(k+3) - x(k+2) | + ... ? qk+1 |x(1) - x(0) | + qk+2 |x(1) - x(0) | + ... = qk+1|x(1) - x(0) | / (1-q).
В результате получаем формулу
|X - x(k+1)| ? qk+1|x(1) - x(0) | / (1-q). (9)
Взяв за x(0) значение x(k), за x(1) - значение x(k+1) (так как при выполнении условий теоремы такой выбор возможен) и учитывая, что при имеет место неравенство qk+1 ? q выводим:
|X - x(k+1)| ? qk+1|x(k+1) - x(k) | / (1-q) ? q|x(k+1) - x(k) | / (1-q).
Итак, окончательно получаем:
|X - x(k+1)| ? q|x(k+1) - x(k) | / (1-q). (10)
Используем эту формулу для вывода критерия окончания итерационной последовательности. Пусть уравнение x=ц(x) решается методом простой итерации, причем ответ должен быть найден с точностью е, то есть
|X - x(k+1)| ? е.
С учетом (10) получаем, что точность е будет достигнута, если выполнено неравенство
|x(k+1)-x(k)| ? (1-q)/q. (11)
Таким образом, для нахождения корней уравнения x=ц(x) методом простой итерации с точностью нужно продолжать итерации до тех пор, пока модуль разности между последними соседними приближениями остается больше числа е(1-q)/q.
ЗАМЕЧАНИЕ 1: В качестве константы q обычно берут оценку сверху для величины
.
Геометрическая интерпретация
Рассмотрим график функции . Это означает, что решение уравнения и - это точка пересечения с прямой :
Рисунок 1.
И следующая итерация - это координата x пересечения горизонтальной прямой точки с прямой .
Рисунок 2.
Из рисунка наглядно видно требование сходимости . Чем ближе производная к 0, тем быстрее сходится алгоритм. В зависимости от знака производной вблизи решения приближения могут строится по разному. Если , то каждое следующее приближение строится с другой стороны от корня:
Рисунок 3.
Заключение
Проблема повышения качества вычислений, как несоответствие между желаемым и действительным, существует и будет существовать в дальнейшем. Ее решению будет содействовать развитие информационных технологий, которое заключается как в совершенствовании методов организации информационных процессов, так и их реализации с помощью конкретных инструментов - сред и языков программирования.
Итогом работы можно считать созданную функциональную модель нахождения корней уравнения методами простой итерации, Ньютона, хорд и половинного деления. Данная модель применима к детерминированным задачам, т.е. погрешностью экспериментального вычисления которых можно пренебречь. Созданная функциональная модель и ее программная реализация могут служить органической частью решения более сложных задач.
Проведя исследования по теме курсовой работы "Численные методы. Решение нелинейных уравнений", я добилась поставленных во введении целей. Были подробно рассмотрены методы уточнения корней. К каждому определению и теореме были приведены несколько примеров. Все теоремы доказаны.
Использование различных источников дало возможность полностью раскрыть тему.
Список литературы
1. Бахвалов Н. С. Численные методы М.: БИНОМ. Лаб. знаний, 2003. 632с.
2. Бахвалов Н. С. Численные методы в задачах и упражнениях / Н. С. Бахвалов, А. В. Лапин, Е. В. Чижонков. М.: Высш. шк., 2000. 192 с.
3. Вержбицкий В. М. Численные методы. Линейная алгебра и нелинейные уравнения. М.: Высш.шк., 2000. 268 с.
4. Вержбицкий В. М. Численные методы. Математический анализ и обыкновенные дифференциальные уравнения. М.: Высш.шк., 2001. 383с.
5. Волков Е. А. Численные методы. СПб.: Лань, 2004. 248 с.
6. Мудров А. Е. Численные методы для ПЭВМ на языках Бейсик, Фортран и Паскаль. Томск: МП "РАСКО", 1991. 272 с.
7. Шуп Т. Е. Прикладные численные методы в физике и технике. М.: Высш. шк., 1990. 255 с.
Размещено на Allbest.ru
Подобные документы
Изучение численных методов приближенного решения нелинейных систем уравнений. Составление на базе вычислительных схем алгоритмов; программ на алгоритмическом языке Фортран - IV. Приобретение практических навыков отладки и решения задач с помощью ЭВМ.
методичка [150,8 K], добавлен 27.11.2009Методы решения нелинейных уравнений: касательных и хорд, результаты их вычислений. Алгоритм и блок схема метода секущих. Исследование характерных примеров для практического сравнения эффективности рассмотренных методов разрешения нелинейных уравнений.
дипломная работа [793,2 K], добавлен 09.04.2015Анализ методов решения систем нелинейных уравнений. Простая итерация, преобразование Эйткена, метод Ньютона и его модификации, квазиньютоновские и другие итерационные методы решения. Реализация итерационных методов с помощью математического пакета Maple.
курсовая работа [820,5 K], добавлен 22.08.2010Сущность и графическое представление методов решения нелинейных уравнений вида F(x)=0. Особенности метода хорд, бисекции, простой итерации, касательных и секущих. Проверка результатов с помощью встроенных функций и оценка точности полученных значений.
контрольная работа [316,1 K], добавлен 09.11.2010Численные методы решения систем линейных уравнений: Гаусса, простой итерации, Зейделя. Методы аппроксимации и интерполяции функций: неопределенных коэффициентов, наименьших квадратов. Решения нелинейных уравнений и вычисление определенных интегралов.
курсовая работа [322,7 K], добавлен 27.04.2011Сравнение методов простой итерации и Ньютона для решения систем нелинейных уравнений по числу итераций, времени сходимости в зависимости от выбора начального приближения к решению и допустимой ошибки. Описание программного обеспечения и тестовых задач.
курсовая работа [3,1 M], добавлен 26.02.2011Решение нелинейных уравнений методом касательных (Ньютона), особенности и этапы данного процесса. Механизм интерполирования функции и численное интегрирование. Приближенное решение обыкновенных дифференциальных уравнений первого порядка методом Эйлера.
курсовая работа [508,1 K], добавлен 16.12.2015Изучение способов решения нелинейных уравнений: метод деления отрезка пополам, комбинированный метод хорд и касательных. Примеры решения систем линейных алгебраических уравнений. Особенности математической обработки результатов опыта, полином Лагранжа.
курсовая работа [181,1 K], добавлен 13.04.2010Особенности решения линейных и нелинейных уравнений. Характеристика и практическое применение и различных методов при решении уравнений. Сущность многочлена Лагранжа и обратного интерполирования. Сравнение численного дифференцирования и интегрирования.
курсовая работа [799,6 K], добавлен 20.01.2010Разработка программного обеспечения для решения нелинейных систем алгебраических уравнений методом дифференцирования по параметру и исследование влияние метода интегрирования на точность получаемого решения. Построение графиков переходных процессов.
курсовая работа [619,3 K], добавлен 26.04.2011