Метод деления отрезка пополам. 


Мы поможем в написании ваших работ!



ЗНАЕТЕ ЛИ ВЫ?

Метод деления отрезка пополам.

Поиск

Допустим, что мы нашли отрезок , в котором расположено искомое значение корня , т.е. .

Пусть для определенности , (рис. 1.1). В качестве начального приближения корня принимается середина этого отрезка, т.е. . Далее исследуем значение функции на концах отрезков и . Тот из них, на концах которого принимает значения разных знаков, содержит искомый корень. Поэтому его принимаем в качестве нового отрезка. Вторую половину отрезка отбрасываем. В качестве первой итерации корня принимаем середину нового отрезка и т. д.

Рис. 1.1 Метод деления отрезка пополам.

Таким образом, после каждой итерации отрезок, на котором расположен корень, уменьшается вдвое, т.е. после итераций он сокращается в раз. Если длина полученного отрезка становится меньше допустимой погрешности, т.е. , счет прекращается. Значение корня принимается равным .

Пример 1.1. Найти решение уравнения c точностью методом деления отрезка пополам.

 
Рис. 1.2. Графический метод изоляции корня уравнения

Решение. Уравнение представим в виде . Корнем данного уравнения является -координата точки пересечения графиков функций и (рис.1.2). Искомый корень находится между точками и . Функция на концах отрезка принимает значения разных знаков и .

Начальное приближение: , , .

; ; .

1-е приближение: , , .

Погрешность .

; ; .

Корень находится в интервале .

2-е приближение: , , .

Погрешность .

; ; .

Корень находится в интервале .

7-е приближение: , , .

Погрешность .

Приближенным решением данного уравнения является .

На рис. 1.3 приведена программа решения данного уравнения методом деления отрезка пополам. В качестве исходных данных вводятся границы интервала, содержащего корень и точность вычисления.

 

CLS DEF FNF(X)=X^3+X-1 1 INPUT A, B, E IF FNF(A)*FNF(B)>0 THEN 1 2 X =(A+B)/2 IF FNF(A)*FNF(X)<0 THEN B=X ELSE A=X IF (B-A)>E THEN 2 PRINT X,FNF(X) END
Рис. 1.3. Пример программы нахождения корней уравнения методом деления отрезка пополам на языке QUICK BASIC.

Пример 1.2. Найти решение уравнения c точностью методом деления отрезка пополам с помощью программы Excel.

Найдем интервал, содержащий единственный корень уравнения. Для этого необходимо построить таблицу или график функции .

1) Введем в ячейки A2, A3, A4, … значения переменной .

2) Введем в ячейку B2 формулу =–A2^3+A2–1.

3) Скопируем формулу и вставим в остальные ячейки столбца B.

4) Найдем соседние ячейки, в которых значения функции имеют разные знаки (рис. 1.4 а). Соответствующие значения переменной дают границы интервала, содержащего корень.

5) Для построения графика вызываем мастер диаграмм. Выбираем тип диаграммы «точечная» - точечная диаграмма со значениями, соединенными сглаживающими линиями.

6) Границы интервала, содержащего корень, соответствуют значениям шкалы, между которыми линия графика пересекает горизонтальную ось (рис. 1.4 б)

a) б)
 
  A B
  x F(x)
  -3 -31
  -2 -11
  -1 -3
    -1
     
     
     

 

Рис. 1.4. Изоляция корня уравнения в Excel с помощью: а) таблицы; б) графика. Искомый корень находится в интервале [0; 1].

 

  A B C D E F G
  a b x b-a F(a) F(b) F(x)
  0,0000 1,0000 0,5000 1,0000 -1,0000 1,0000 -0,3750
  0,5000 1,0000 0,7500 0,5000 -0,3750 1,0000 0,1719
  0,5000 0,7500 0,6250 0,2500 -0,3750 0,1719 -0,1309
  0,6250 0,7500 0,6875 0,1250 -0,1309 0,1719 0,0125
  0,6250 0,6875 0,6563 0,0625 -0,1309 0,0125 -0,0611
  0,6563 0,6875 0,6719 0,0313 -0,0611 0,0125 -0,0248
  0,6719 0,6875 0,6797 0,0156 -0,0248 0,0125 -0,0063
  0,6797 0,6875 0,6836 0,0078 -0,0063 0,0125 0,0030
Рис. 1.5. Решение уравнения методом деления отрезка пополам с помощью программы Excel.

 

Продолжаем решение на новом листе (рис. 1.5).

1) Ввести в ячейки A1 – G1 заголовки столбцов.

2) В ячейку A2 – значение левой границы интервала

3) В ячейку B2 – значение правой границы интервала

4) В ячейку C2 – формулу середины отрезка =(A2+B2)/2

5) В ячейку D2 – формулу погрешности =B2–A2

6) В ячейку E2 – формулу функции =A2^3+A2-1.

7) Скопировать формулу из E2 в ячейки F2 и G2. Строка 2 теперь содержит результаты начального приближения

8) В ячейку A3 – формулу =ЕСЛИ(E2*G2<0;A2;C2)

9) В ячейку B3 – формулу =ЕСЛИ(E2*G2<0;C2;B2)

10) Выделить ячейки C2:G2 и скопировать формулы в соседние ячейки C3:G3 при помощи маркера заполнения (небольшой черный квадрат в правом нижнем углу выделенного блока). Строка 3 теперь содержит результаты первого приближения

11) Выделить ячейки A3:G3 и скопировать формулы в соседние ячейки расположенных ниже строк A4:G4, A5:G5, и т.д. при помощи маркера заполнения. Каждая новая строка содержит результаты очередного приближения.

12) В столбце С найти значение корня, соответствующее заданной точности.

Приближенное решение данного уравнения содержится в ячейке С9 (погрешность в ячейке D9).

 



Поделиться:


Последнее изменение этой страницы: 2016-12-17; просмотров: 1363; Нарушение авторского права страницы; Мы поможем в написании вашей работы!

infopedia.su Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. Обратная связь - 3.12.152.100 (0.009 с.)