русс | укр

Языки программирования

ПаскальСиАссемблерJavaMatlabPhpHtmlJavaScriptCSSC#DelphiТурбо Пролог

Компьютерные сетиСистемное программное обеспечениеИнформационные технологииПрограммирование

Все о программировании


Linux Unix Алгоритмические языки Аналоговые и гибридные вычислительные устройства Архитектура микроконтроллеров Введение в разработку распределенных информационных систем Введение в численные методы Дискретная математика Информационное обслуживание пользователей Информация и моделирование в управлении производством Компьютерная графика Математическое и компьютерное моделирование Моделирование Нейрокомпьютеры Проектирование программ диагностики компьютерных систем и сетей Проектирование системных программ Системы счисления Теория статистики Теория оптимизации Уроки AutoCAD 3D Уроки базы данных Access Уроки Orcad Цифровые автоматы Шпаргалки по компьютеру Шпаргалки по программированию Экспертные системы Элементы теории информации

Итерационные циклы

Итерационным циклом называется такой, число повторений которого заранее неизвестно или его сложно рассчитать, а в процессе повторения тела цикла образуется последовательность значений y1, y2,…, yn,…, сходящаяся к некоторому пределу а, т. е.

Lim yn = a.

n ® ¥

Каждое новое значение yn в такой последовательности определяется с учетом предыдущего yn-1 и является по сравнению с ним более точным приближением к искомому результату. Итерационный цикл заканчивает свою работу в том случае, если для некоторого значения n выполняется условие

| yn - yn-1 |£ e ,

где e допустимая погрешность вычисления результата.

В такой ситуации за результат принимают последнее значение y, т.е. считают, что yn с заданной точностью представляет значение а.

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

Lim zn = 0; Lim (sn – sn-1) = 0.

n ® ¥ n ® ¥

А сумма

sn = z0 + z1 + …+zn

его первых (n + 1) слагаемых при этом стремится к некоторому пределу S, который и называется суммой ряда, т. е.

Lim sn = S; Lim S zn = S.

n ® ¥ n ® ¥

Алгоритм, реализующий подсчет суммы ряда, должен вырабатывать последовательность s1, s2, …, sn,при следующем условии окончания суммирования:

| zn |£ e.

Пример 3. Вычислить значение функции cos x, используя разложение косинуса в ряд с заданной погрешностью e:

Cos x = 1 - + - + …+(-1)n +...

При построении алгоритма данной задачи необходимо:

- определить значение очередного слагаемого z;

- осуществлять накопление суммы по итерационной формуле

s = s + z.

Для определения значения очередного слагаемого z в данном примере целесообразно использовать не прямое его вычисление по общей формуле, а рекуррентное соотношение, которое позволяет существенно сократить количество операций при вычислении его значения:

z = z * fn.

Определим сомножитель fn:

fn = =..

Для работы алгоритма (рис.7.1) весьма важно определить исходную информацию для работы цикла. Подставив в данную формулу n = 0, получим начальное значение z = 1.

Для организации цикла по накоплению суммы используется оператор цикла с предусловием, в котором условие | z | > e является условием продолжения цикла.

Вторым характерным примером использования итерационных циклов является задача решения алгебраических и нелинейных (трансцендентных) уравнений.

Нахождение корней уравнений вида

f (x)= 0

осуществляется в два этапа.

Первый этап – этап локализации корня – определяется отрезок [a,b], в пределах которого находится один и только один корень уравнения. Часто локализация корня осуществляется построением «грубого» графика функции f (x).

Второй этап – этап уточнения корня – ведется поиск корня с заданной степенью точности с помощью некоторого итерационного алгоритма.

Наиболее простым методом уточнения корня является метод итераций, заключающийся в следующем. Исходное уравнение f (x)= 0, где f (x) непрерывная функция на отрезке [a, b], заменяют эквивалентным уравнением вида

x = j (x)

и, зная начальное приближение корня x0 Î [a, b], каждое следующее приближение находят по формуле

xn = j (xn-1).

Вычисления повторяют до тех пор, пока не выполнится условие |f(xn)|£ e, где e - заданная погрешность вычислений. Отметим, что иногда используют другой способ контроля сходимости, состоящей в сравнении xnи xn-1.Процесс сходится, если на всем отрезке [a, b] |j¢(x)|< 1, где j¢(x) есть производная функции j (x).

Рисунок 7.10 – Схема алгоритма к примеру 3

Все вышесказанное реализовано в программе (лист. 7), соответствующей схеме данного алгоритма (рис. 7.10).

Листинг 7 – К примеру 3

using System;

namespace ConsoleApplication1

{

class Program

{

static void Main(string[] args)

{

double x, eps,s,t,y,f;

Console.Write("Enter x ");

x = Convert.ToDouble(Console.ReadLine());

Console.Write("Enter eps ");

eps = Convert.ToDouble(Console.ReadLine());

s=0;

t=1;

int n=1;

while (Math.Abs(t) > eps)

{ //Начало цикла

s= s + t;

f= -x*x / (2*n*(2*n-1));

t= t*f;

n++;

} //Конец цикла

y= Math.Cos (x);

Console.WriteLine("х=" + x + " у=" + y+ " s="+s);

}

}

}

Пример 4. Определить корень уравнения x – tg(x)= 0 с погрешностью e = 10-3 при начальном значении корня x0 = 4,5.

Преобразуем исходное уравнение следующим образом:

x = tg x,

тогда f(x)= x – tg x; j(x) = tg x.

Для определения x0 удобно использовать следующие графические построения. Построить графики функций y1= x; y2= j(x)= tg x. Точки пересечения этих графиков и будут корнями исходного уравнения f(x)= 0. На графике выделить приближенные отрезки [a, b] локализации каждого корня. В качестве x0можно взять любую точку отрезка.

Программа уточнения корня по методу итераций представлена в листинге 8, схема алгоритма на рисунке 7.11.

Рисунок 7.11 – Схема алгоритма к примеру 4

В данной программе на печать в качестве результата выводится последнее значение x, которое удовлетворяет заданному значению Eps.

Листинг 8 – К примеру 4

using System;

namespace ConsoleApplication1

{

class Program

{

static void Main(string[] args)

{

double x, xn, eps;

Console.Write("Enter xn ");

xn = Convert.ToDouble(Console.ReadLine());

Console.Write("Enter eps ");

eps = Convert.ToDouble(Console.ReadLine());

x=xn;

while (Math.Abs (x-Math.Sin(x)/Math.Cos(x))>eps)

x=Math.Sin(x)/Math.Cos(x);

Console.WriteLine("x=" + x);

}

}

}

Для практического контроля сходимости итерационного процесса xn=j(xn-1) можно осуществлять печать промежуточных значений x, последнее из которых и будет корнем уравнения при заданной погрешности.

Просмотров: 1210


Вернуться в оглавление



Карта сайта Карта сайта укр


Уроки php mysql Программирование

Онлайн система счисления Калькулятор онлайн обычный Инженерный калькулятор онлайн Замена русских букв на английские для вебмастеров Замена русских букв на английские

Аппаратное и программное обеспечение Графика и компьютерная сфера Интегрированная геоинформационная система Интернет Компьютер Комплектующие компьютера Лекции Методы и средства измерений неэлектрических величин Обслуживание компьютерных и периферийных устройств Операционные системы Параллельное программирование Проектирование электронных средств Периферийные устройства Полезные ресурсы для программистов Программы для программистов Статьи для программистов Cтруктура и организация данных


 


Не нашли то, что искали? Google вам в помощь!

 
 

© life-prog.ru При использовании материалов прямая ссылка на сайт обязательна.