Метод половинного деления

Пусть уравнение (2.1) имеет на отрезке [ a,b ] один корень, а функция f(x) на данном отрезке непрерывна и f(a)·f(b)<0. Разделим отрезок [ a,b ] пополам точкой x1=(а+b)/2. Если f(x1)≠0, то для продолжения вычислений выберем ту часть промежутка, где знаки функции различны. Концы полученного отрезка обозначим [ a1,b1 ] и снова разделим отрезок [ a1,b1 ] пополам точкой x2=(a1+ b1)/2 и т. д. В результате на каком-то этапе получим или точный корень уравнения(2.1) или бесконечную последовательность вложенных друг в друга отрезков [ a1,b1 ], [ a2,b2 ],… [ an,bn ],…таких, что

f(an)·f(bn)<0, (n=1,2,…) (2.2)

bn - an=2 -n·(b-a). (2.3)

Так как левые концы a1, a2,…,an образуют монотонную неубывающую ограниченную последовательность, а правые концы b1 b2,…,bn образуют монотонную невозрастающую ограниченную последовательность, а расстояние между ними в силу (2.2) стремится к нулю, то у последовательностей существует общий предел. Число ξ, которое является общим пределом последовательностей { an } и { bn }, точный корень уравнения (2.1). Оценим погрешность решения на n -м шаге. Считаем до тех пор, пока длина промежутка не станет меньше заданной точности ε.

В качестве ответа возьмем середину отрезка [ an,bn ].

.

Рис.2.2. К объяснению метода половинного деления

Метод половинного деления практически удобно применять для грубого нахождения корня данного уравнения, так как при увеличении точности значительно возрастает объём вычислений.

Пример 2.3. Найти, используя пакет Matchcad, методом половинного деления корень уравнения x4-x3-2x2+3x-3=0 на промежутке [1,2]

Функция koren(a,b,ε) возвращает длину отрезка, который будет меньше заданной точности ε, и значение корня на этом промежутке, если на концах отрезка [ a,b ] функция имеет противоположные знаки, или сообщение об отсутствии корня, в противном случае.

Метод легко реализуется на компьютере. Далее приводится листинг программы, написанной на языке, встроенном в систему Mathcad.

Рис. 2.3. Листинг программы в Mathcad, реализующей метод половинного деления для примера 2.3


Понравилась статья? Добавь ее в закладку (CTRL+D) и не забудь поделиться с друзьями:  



double arrow
Сейчас читают про: