GeoSELECT.ru



Компьютеры / Реферат: Решение дифференциального уравнения с последующей аппроксимацией (Компьютеры)

Космонавтика
Уфология
Авиация
Административное право
Арбитражный процесс
Архитектура
Астрология
Астрономия
Аудит
Банковское дело
Безопасность жизнедеятельности
Биология
Биржевое дело
Ботаника
Бухгалтерский учет
Валютные отношения
Ветеринария
Военная кафедра
География
Геодезия
Геология
Геополитика
Государство и право
Гражданское право и процесс
Делопроизводство
Деньги и кредит
Естествознание
Журналистика
Зоология
Инвестиции
Иностранные языки
Информатика
Искусство и культура
Исторические личности
История
Кибернетика
Коммуникации и связь
Компьютеры
Косметология
Криминалистика
Криминология
Криптология
Кулинария
Культурология
Литература
Литература : зарубежная
Литература : русская
Логика
Логистика
Маркетинг
Масс-медиа и реклама
Математика
Международное публичное право
Международное частное право
Международные отношения
Менеджмент
Металлургия
Мифология
Москвоведение
Музыка
Муниципальное право
Налоги
Начертательная геометрия
Оккультизм
Педагогика
Полиграфия
Политология
Право
Предпринимательство
Программирование
Психология
Радиоэлектроника
Религия
Риторика
Сельское хозяйство
Социология
Спорт
Статистика
Страхование
Строительство
Схемотехника
Таможенная система
Теория государства и права
Теория организации
Теплотехника
Технология
Товароведение
Транспорт
Трудовое право
Туризм
Уголовное право и процесс
Управление
Физика
Физкультура
Философия
Финансы
Фотография
Химия
Хозяйственное право
Цифровые устройства
Экологическое право
   

Реферат: Решение дифференциального уравнения с последующей аппроксимацией (Компьютеры)



МИНИСТЕРСТВО СВЯЗИ РФ

СИБИРСКИЙ ГОСУДАРСТВЕННЫЙ УНИВЕРСИТЕТ
ТЕЛЕКОММУНИКАЦИЙ И ИНФОРМАТИКИ
ХАБАРОВСКИЙ ФИЛИАЛ



К У Р С О В А Я Р А Б О Т А

ПО ИНФОРМАТИКЕ
на тему:

РЕШЕНИЕ ДИФФЕРЕНЦИАЛЬНОГО УРАВНЕНИЯ
С ПОСЛЕДУЮЩЕЙ АППРОКСИМАЦИЕЙ РЕЗУЛЬТАТОВ



Работу выполнила:
студентка I курса
специальности РРТ (ускор.)
Турчина
шифр: 011р-469



2001 г.
С О Д Е Р Ж А Н И Е



Индивидуальное задание -
3
1. Решение дифференциального уравнения методом Эйлера - Коши
- 4
1.1. Теоретические сведения -
4
1.2. Ручной расчёт решаемой задачи -
6
2. Аппроксимация. Метод наименьших квадратов - 9
2.1. Теоретические сведения -
9
2.2. Ручной расчёт коэффициентов системы линейных уравнений -
10
3. Решение системы уравнений методом Гаусса -
11
4. Нахождение значений аппроксимирующей функции - 13
5. Расчёт погрешности аппроксимации -
14
6. Построение блок-схемы и разработка программы аппроксимации - 16
Литература -
21



ИНДИВИДУАЛЬНОЕ ЗАДАНИЕ

1. Решить дифференциальное уравнение y = x + cos ( y / (0.3 ) с
начальными условиями x0 = 0.7 y0 = 2.1 на интервале [ 0.7 ; 1.7 ] с шагом
h = 0.1.
2. Оценить погрешность вычислений при решении дифференциального уравнения
методом Эйлера - Коши.
3. Аппроксимировать полученное в п.1. решение параболой методом наименьших
квадратов.
4. Рассчитать погрешность аппроксимации.
5. Построить графики решения дифференциального уравнения, аппроксимирующей
функции и погрешности аппроксимации.
6. Составить блок-схемы алгоритмов и программы для решения
дифференциального уравнения, вычисления коэффициентов аппроксимирующей
параболы, расчёта погрешности аппроксимации на языке QBASIC. На печать
выдать :
- значения функции y( xi ), являющейся решением дифференциального
уравнения в точках xi, найденные с шагом h и с шагом h/2 ;
- значения аппроксимирующей функции F( xi ) в точках xi ;
- значение погрешности аппроксимации [pic]i = F( xi ) - yi.
- величину средне - квадратичного отклонения.



1. РЕШЕНИЕ ДИФФЕРЕНЦИАЛЬНОГО УРАВНЕНИЯ
МЕТОДОМ ЭЙЛЕРА - КОШИ
1.1. ТЕОРЕТИЧЕСКИЕ СВЕДЕНИЯ

В соответствии с постановкой задачи нужно найти решение дифференциального
уравнения первого порядка, т.е. найти такие решения y(x), которые
превратили бы дифференциальное уравнение в тождество. Но так как таких
решений множество, заданы начальные условия - значения функции y(x) в точке
x0, т.е. y(x0) = y0, а так же интервал [ x0 - xn ].
Рис. 1. показывает, что с помощью начальных условий из множества решений
можно выбрать одно.

[pic]

Рис 1. Множество решений дифференциального уравнения.

Метод Эйлера - Коши - наиболее точный метод решения дифференциального
уравнения (второй порядок точности). Этот метод предполагает следующий
порядок вычислений:
yi+1( = yi + h f( xi ; yi ), где i = 0,1,2 ... n
yi+1 = yi + h (f( xi ; yi ) + f(
xi+1 ; yi+1()) / 2
Число значений n можно найти, разделив интервал на шаг:

n = (xn - xo) / h

Геометрически это означает, что определяется направление касательной к
интегральной кривой в исходной точке хi,yi и во вспомогательной точке
хi+1,yi+1(, а в качестве окончательного направления берется среднее этих
направлений (показано пунктирной линией на рис. 2)

[pic]
Рис.2. Графическая интерпретация метода Эйлера - Коши.

Решение yi+1, найденное методом Эйлера - Коши, намного ближе к точному
решению, чем решение yi+1(, найденное методом Эйлера. Погрешность метода
пропорциональна шагу h во второй степени, т.е. метод Эйлера - Коши имеет
второй порядок точности.



2. РУЧНОЙ РАСЧЁТ РЕШАЕМОЙ ЗАДАЧИ
По условию задачи нужно решить дифференциальное уравнение
y = x + cos ( y / (0.3 ) с начальными условиями x0 = 0.7,
y0 = 2.1 на интервале [ 0.7 ; 1.7 ] с шагом h = 0.1 .
По формуле метода Эйлера -Коши
yi+1( = yi + h f( xi ; yi ),
yi+1 = yi + h (f( xi ; yi ) + f(
xi+1 ; yi+1()) / 2
Найдем y1( и y1
f( x0 ; y0 ) = 0.7 + cos (2.1 / (0.3 ) = - 0.069675
x1 = x0 + h = 0.7 + 0.1=0.8
y1* = y0 + h * f( x0 ; y0 ) = 2.1 + 0.1 * (- 0.069675) = 2.093032
y1 = y0 + h * (f( x0 ; y0 ) + f( x0 + h ; y1* )) / 2 = 2.1 + 0.1 * ((-
0.069675) + 0.022266)/2 =
= 2.09763
Аналогично найдём остальные значения x и y :
f( x1 ; y1 ) = 0.8 + cos (2.09763/ (0.3 ) = 0.02757
x2 = 0.8 + 0.1 = 0.9
y2* = 2.09763 + 0.1 * 0.02757 = 2.100387
y2 = 2.09763 + 0.1 * (0.02757 + 0.130776) / 2 = 2.105547
f( x2 ; y2 ) = 0.9 + cos (2.105547 / (0.3 ) = 0.136831
x3 = 0.9 + 0.1 = 1
y3* = 2.105547 + 0.1 * 0.136831 = 2.11923
y3 = 2.105547 + 0.1 * (0.136831 + 0.25321) / 2 = 2.125049
f( x3 ; y3 ) = 1 + cos (2.125049 / (0.3 ) = 0.260317
x4 = 1+ 0.1 = 1.1
y4* = 2.125049 + 0.1 * 0.260317 = 2.1510807
y4 = 2.125049 + 0.1 * (0.260317 + 0.393124) / 2 = 2.157721
f( x4 ; y4 ) = 1.1 + cos (2.157721 / (0.3 ) = 0.401751
x5 = 1.1 + 0.1 = 1.2
y5* = 2.157721+ 0.1 * 0.401751 = 2.1978961
y5 = 2.157721 + 0.1 * (0.401751 + 0.556089) / 2 = 2.205613
f( x5 ; y5 ) = 1.2 + cos (2.205613 / (1.3 ) = 0.566933
x6 = 1.2 + 0.1 = 1.3
y6* = 2.205613 + 0.1 * 0.566933 = 2.2623063
y6 = 2.205613 + 0.1 * (0.566933 + 0.750302) / 2 = 2.271475
f( x6 ; y6 ) = 1.3 + cos (2.271475 / (0.3 ) = 0.764362
x7 = 1.3 + 0.1 = 1.4
y7* = 2.271475 + 0.1 * 0.764362 = 2.347911
y7 = 2.271475 + 0.1 * (0.764362 + 0.987033) / 2 = 2.359045
f( x7 ; y7 ) = 1.4 + cos (2.359045/ (0.3 ) = 1.005629
x8 = 1.4 + 0.1 = 1.5
y8* = 2.359045 + 0.1 * 1.005629 = 2.4596079
y8 = 2.359045 + 0.1 * (1.005629 + 1.280033) / 2 = 2.473328
f( x8 ; y8 ) = 1.5 + cos (2.473328 / (0.3 ) = 1.304536
x9 = 1.5+ 0.1 = 1.6
y9* = 2.473328 + 0.1 * 1.304536 = 2.6037816
y9 = 2.473328 + 0.1 * (1.304536 + 1.6414317) / 2 = 2.620626
f( x9 ; y9 ) = 1.6 + cos (2.620626 / (0.3 ) = 1.6721351
x10 = 1.6 + 0.1 = 1.7
y10* = 2.620626 + 0.1 * 1.6721351 = 2.7878395
y10 = 2.620626 + 0.1 * (1.6721351 + 2.068584) / 2 = 2.807662
Для оценки погрешности вычислений найдём решение дифференциального
уравнения с шагом h / 2 до третьей точки:
f( x0 ; y0 ) = 0.7 + cos (2.1 / (0.3 ) = - 0.069675
x1 = 0.7 + 0.05 = 0.75
y1* = 2.1 + 0.05 * (- 0.069675) = 2.096516
y1 = 2.1 + 0.05 * ((- 0.069675) + ( - 0.02372)) / 2 = 2.097665
f( x1 ; y1 ) = 0.75 + cos (2.097665 / (0.3 ) = - 0.022389
x2 = 0.75 + 0.05 = 0.8

y2* = 2.097665 + 0.05 * (- 0.022389) = 2.096546
y2 = 2.097665 + 0.05 * ((- 0.022389) + 0.026314) / 2 = 2.097763
f( x2 ; y2) = 0.8 + cos (2.097763 / (0.3 ) = 0.027724
x3 = 0.8 + 0.05 = 0.85
y3* = 2.097763 + 0.05 * 0.027724 = 2.0991492
y3 = 2.097763 + 0.05 * (0.027724 + 0.079334) / 2 = 2.10044
f( x3 ; y3) = 0.85 + cos (2.10044 / (0.3 ) = 0.080838
x4 = 0.85 + 0.05 = 0.9
y4* = 2.10044 + 0.05 * 0.080838 = 2.1044819
y4 = 2.10044 + 0.05 * (0.080838 + 0.135575) / 2 = 2.10585
f( x4; y4) = 0.9 + cos (2.10585 / (0.3 ) = 0.137188
x5 = 0.9 + 0.05 = 0.95
y5* = 2.10585 + 0.05 * 0.137188 = 2.1127094
y5 = 2.10585 + 0.05 * (0.137188 + 0.195345) / 2 = 2.114164
f( x5; y5) = 0.95 + cos (2.114164 / (0.3 ) = 0.19709
x6 = 0.95 + 0.05 = 1
y6* = 2.114164 + 0.05 * 0.19709 = 2.1240185
y6 = 2.114164 + 0.05 * (0.19709 + 0.259053) / 2 = 2.125567

Для оценки погрешности вычислений используется правило Рунге:

yi+1 = yih + (yih/2 - yih ) / (2p - 1) , где:
р - порядок метода, для Эйлера - Коши р = 2
Рассчитаем погрешность вычисления в точке х = 1. Найдем уточненное
решение:
y(1) = 2.125049 + (2.125567 - 2.125049) / (22 - 1) = 2.1252216
( ih = 2p (yih - yih/2) / (2p - 1) = 22 (2.125567 - 2.125049) / 3 = 6.9
* 10 -4
( ih/2 = (yih - yih/2) / (2p - 1) = (2.125567 - 2.125049) / 3 = 1.73 *
10 -4



Таблица 1. Значения X и Y, полученные с помощью ручного расчёта.
|I |X ( I ) |Y ( I ) |
|0 |0.7 |2.1 |
|1 |0.8 |2.09763 |
|2 |0.9 |2.105547 |
|3 |1 |2.125049 |
|4 |1.1 |2.157721 |
|5 |1.2 |2.205613 |
|6 |1.3 |2.271475 |
|7 |1.4 |2.359045 |
|8 |1.5 |2.473328 |
|9 |1.6 |2.620626 |
|10 |1.7 |2.807662 |

График решения дифференциального уравнения представлен на рисунке 3.
[pic]

2. АППРОКСИМАЦИЯ. МЕТОД НАИМЕНЬШИХ КВАДРАТОВ
1. ТЕОРЕТИЧЕСКИЕ СВЕДЕНИЯ

Исходя из постановки задачи, нужно аппроксимировать полученное в п.1.
решение ( Таблица 1. ) параболой методом наименьших квадратов, т.е. нужно
найти функцию, в данном случае параболу, которая в точках X ( I ) принимала
бы значения, как можно более близкие к значениям Y ( I ). Парабола
является функцией с тремя параметрами: F (x) = ax2 + bx + c
Сумма квадратов разностей значений функции и решений дифференциального
уравнения (Таблица 1.) должна быть минимальной, т.е.:
[pic]( ax2 + bx + c - yi )2 => min
Функция будет иметь минимум, когда все частные производные равны нулю.
DF / da = 0, dF / db = 0, dF / dc = 0
После преобразований получим систему уравнений:
a11a + a12b + a13c = b1
a21a + a22b + a23c = b2
a31a + a32b + a33c = b3
где a11 = [pic] , a12 = a21 = [pic] , a13 = a22 = a31 = [pic], a23 = a32
=[pic]xi , a33 = n + 1
b1 = [pic]yi , b2 =[pic]xi yi , b3 =[pic]yi .

2.2. РУЧНОЙ РАСЧЁТ КОЭФФИЦИЕНТОВ СИСТЕМЫ ЛИНЕЙНЫХ УРАВНЕНИЙ

Рассчитаем коэффициенты системы трёх линейных уравнений по формулам,
взятым из п.2.2.:
а11 = 0.74 + 0.84 + 0.94 + 1.04 + 1.14 + 1.24 + 1.34 + 1.44 + 1.54 + 1.64 +
1.74 = 32.5094
а12 = а21 = 0.73 + 0.83 + 0.93 + 1.03 + 1.13 + 1.23 + 1.33 + 1.43 + 1.53 +
1.63 + 1.73 = 22.9680
а13 = а22 = а31 = 0.72 + 0.82 + 0.92 + 1.02 + 1.12 + 1.22 + 1.32
+1.42+1.52+1.62+1.72 = 16.9400
а23 = а32 = 0.7 + 0.8 + 0.9 + 1 + 1.1 + 1.2 + 1.3 + 1.4 + 1.5 + 1.6 + 1.7
= 13.2000
а33 = n + 1 = 11
b1 = 2.1 * 0.72 + 2.09763 * 0.82 + 2.105547 * 0.92 + 2.125049 * 1.02 +
2.157721 * 1.12 + 2.205613 * 1.22 + 2.271475 * 1.32 + 2.359045 * 1.42 +
2.473328 * 1.52 + 2.620626 * 1.62 + 2.807662 * 1.72 = 40.83941
b2 = 2.1 * 0.7 + 2.09763 * 0.8 + 2.105547 * 0.9 + 2.125049 * 1.0 + 2.157721
* 1.1 + 2.205613 * 1.2 + 2.271475 * 1.3 + 2.359045 * 1.4 + 2.473328 * 1.5
+ 2.620626 * 1.6 + 2.807662 * 1.7 = 31.119972
b3 = 2.1 + 2.09763 + 2.105547 + 2.125049 + 2.157721 + 2.205613 + 2.271475
+ 2.359045 + 2.473328 + 2.620626 + 2.807662 = 25.3237

Получим систему уравнений:

32.5094a + 22.968b + 16.94c = 40.83941
22.968a + 16.94b + 13.2c = 31.119972
16.94a + 13.2b + 11c = 25.3237

Теперь нужно решить эту систему методом Гаусса и найти коэффициенты a,b,c.

3. РЕШЕНИЕ СИСТЕМЫ УРАВНЕНИЙ МЕТОДОМ ГАУССА
Суть этого метода состоит в том, что систему линейных уравнений
преобразуют к системе с треугольной матрицей, а потом решают уравнения,
начиная с последнего.
Решим систему уравнений, полученную в п. 2.2.:

Первое уравнение считается основным, его мы не изменяем. Второе уравнение
нужно преобразовать так, чтобы первый его коэффициент стал равен нулю. Для
этого второе уравнение нужно умножить на такой множитель, чтобы первые
коэффициенты первого и второго уравнения стали равны.
Найдём множитель:
?21 = а21 / а11 = 22.968 / 32.5094 = 0.7065
Умножим на него первое уравнение:
32.5094a * 0.7065 + 22.968b * 0.7065 + 16.94 * 0.7065 = 40.83941 * 0.7065
Получим:
22.968a + 16.2269b + 11.9681c = 28.853043
Теперь нужно это уравнение почленно вычесть из второго:
0a + 0.7131b + 1.2319c = 2.266929
Аналогично преобразуем третье уравнение:
i31 = a31 / a11 = 16.94 / 32.5094 = 0.5211
32.5094a * 0.5211 + 22.968b * 0.5211 + 16.94c * 0.5211 = 40.83941 * 0.5211
16.94a + 11.9686b + 8.8274c = 21.281416
Вычтем это уравнение из третьего, получим:
0a +1.2314b + 2.1726c = 4.042284
Таким образом, получится система, эквивалентная исходной:

32.5094a + 22.968b + 16.94c = 40.83941
0.7131b + 1.2319c = 2.266929
1.2314b + 2.1726c = 4.042284
Третье уравнение нужно преобразовать так, чтобы второй его коэффициент стал
равен нулю. Найдём множитель:
?32 = a32 / a22 = 1.2314 / 0.7131 = 1.7268
Умножим второе уравнение на него:
0.7131b * 1.7268 + 1.2319c * 1.7268 = 2.266929 * 1.7268
1.2314b + 2.1272c = 3.914533
Вычтем получившееся уравнение из третьего:
0b + 0.0454c = 0.127751
Получим треугольную матрицу, эквивалентную исходной:
32.5094a + 22.968b + 16.94c = 40.83941
0.7131b + 1.2319c = 2.266929
0.0454c = 0.127751
Теперь найдём коэффициенты:
c = 0.127751 / 0.0454 = 2.813899
b = (2.266929 - 1.2319 * 2.813899) / 0.7131 = - 1.682111
a = (40.83941 - 16.94 * 2.813899 - 22.968 * (- 1.682111) ) / 32.5094 =
0.978384
Проверим результаты вычислений, подставив полученные значения корней в
исходную систему:
32.5094 * 0.978384 + 22.968 * (- 1.682111) + 16.94 * 2.813899 =
40.83941
22.968 * 0.978384 + 16.94 * (- 1.682111) + 13.2 * 2.813899 = 31.119972
16.94 * 0.978384 + 13.2 * (- 1.682111) + 11 * 2.813899 = 25.3237

40.8394 ( 40.83941
31.12 ( 31.119972
25.3228 ( 25.3237

Таким образом, уравнение аппроксимирующей параболы имеет вид:
F (x) = 0.978384x2 - 1.682111x + 2.813899

4. НАХОЖДЕНИЕ ЗНАЧЕНИЙ АППРОКСИМИРУЮЩЕЙ ФУНКЦИИ

Найдём значения функции F(x) = 0.978384 x2 - 1.682111 x + 2.813899
на интервале [0.7; 1.7] с шагом h=0.1
x0 = 0.7
F( x0 ) = 0.978384 * 0.72 - 1.682111 * 0.7 + 2.813899 = 2.118622
x1 = x0 + h = 0.7 + 0.1 = 0.8
F( x1 ) = 0.978384 * 0.82 - 1.682111 * 0.8 + 2.813899 = 2.095734
x2 = 0.8 + 0.1 = 0.9
F( x2 ) = 0.978384 * 0.92 - 1.682111 * 0.9 + 2.813899 = 2.092711
x3 = 0.9 + 0.1 = 1.0
F( x3 ) = 0.978384 * 1.02 - 1.682111 * 1.0 + 2.813899 = 2.109553
x4 = 1.0 + 0.1 = 1.1
F( x4 ) = 0.978384 * 1.12 - 1.682111 * 1.1 + 2.813899 = 2.14626
x5 = 1.1 + 0.1 = 1.2
F( x5 ) = 0.978384 * 1.22 - 1.682111 * 1.2 + 2.813899 = 2.202831
x6 = 1.2 + 0.1 = 1.3
F( x6 ) = 0.978384 * 1.32 -1.682111 * 1.3 + 2.813899 = 2.279266
x7 = 1.3 + 0.1 = 1.4
F( x7 ) = 0.978384 * 1.42 - 1.682111 * 1.4 + 2.813899 = 2.375567
x8 = 1.4 + 0.1 = 1.5
F( x8 ) = 0.978384 * 1.52 - 1.682111 * 1.5 + 2.813899 = 2.491732
x9 = 1.5 + 0.1 = 1.6
F( x9 ) = 0.978384 * 1.62 - 1.682111 * 1.6 + 2.813899 = 2.627762
x10 = 1.6 + 0.1 = 1.7
F( x10 ) = 0.978384 * 1.72 - 1.682111 * 1.7 + 2.813899= 2.783656

5. РАСЧЕТ ПОГРЕШНОСТИ АПРОКСИМАЦИИ.
Для вычисления погрешности аппроксимации вычислим величину
среднеквадратичного отклонения:
[pic]
Здесь yi - значения решения дифференциального уравнения, полученные в
п.1.2. (см. Таблицу 1), F(xi) - значения аппроксимирующей функции при тех
же значениях xi, полученные в п. 4. Их разность показывает величину
отклонения аппроксимирующей функции от аппроксимируемой в узлах xi.
Рассчитаем погрешность аппроксимации:
[pic]0 = F( x0 ) - y0 = 2.118622 - 2.1 = 0.018622
[pic]02 = 3.46779 * 10 - 4
[pic]1 = F( x1 ) - y1 = 2.095734 - 2.09763 = - 0.001896
[pic]12 = 3.59482 *10 - 6
[pic]2 = F( x2 ) - y2 = 2.092711 - 2.105547 = - 0.012836
[pic]22 = 1.64763 * 10 - 4
[pic]3 = F( x3 ) - y3 = 2.109553 - 2.125049 = - 0.015496
[pic]32 = 2.40126 * 10 - 4
[pic]4 = F( x4 ) - y4 = 2.14626 - 2.157721 = - 0.011461
[pic]42 = 1.31355 * 10 - 4
[pic]5 = F( x5 ) - y5 = 2.202831 - 2.205613 = - 0.002782
[pic]52 = 7.73953 * 10 - 6
[pic]6 = F( x6 ) - y6 = 2.279266 - 2.271475 = 0.007791
[pic]62 = 6.06997 * 10 - 5
[pic]7 = F( x7 ) - y7 = 2.375567 - 2.359045 = 0.06522
[pic]72 = 2.72977 * 10 - 4
[pic]8 = F( x8 ) - y8 = 2.491732 - 2.473328 = 0.08404
[pic]82 = 3.38707 * 10 - 4
[pic]9 = F( x9 ) - y9 = 2.627762 - 2.620626 = 0.007136
[pic]92 = 5.09225 * 10 - 5
[pic]10 = F( x10 ) - y10 = 2.783656 - 2.807662 = - 0.024006
[pic]102 = 5.76288 * 10 -4

( = ( 0.0021939515 = ( 1.9945013 * 10 - 4 = 0.014122681 [pic]1.412268 *
10 - 2

Данные расчётов снесены в Таблицу 2.

Таблица 2. Расчёт погрешности аппроксимации.
|I |xi |yi |F(xi) |[pic]i |[pic]i2 |
|0 |0.7 |2.1 |2.118622 |0.018622 |3.46779 * 10 - 4|
|1 |0.8 |2.09763 |2.095734 |- 0.001896 |3.59482 * 10 - 6|
|2 |0.9 |2.105547 |2.092711 |- 0.012836 |1.64763 * 10 - 4|
|3 |1.0 |2.125049 |2.109553 |- 0.015496 |2.40126 * 10 - 4|
|4 |1.1 |2.157721 |2.14626 |- 0.011461 |1.31355 * 10 - 4|
|5 |1.2 |2.205613 |2.202831 |- 0.002782 |7.73953 * 10 - 6|
|6 |1.3 |2.271475 |2.279266 |0.007791 |6.06997 * 10 - 5|
|7 |1.4 |2.359045 |2.375567 |0.06522 |2.72977 * 10 - 4|
|8 |1.5 |2.473328 |2.491732 |0.08404 |3.38707 * 10 - 4|
|9 |1.6 |2.620626 |2.627762 |0.007136 |5.09225 * 10 - 5|
|10 |1.7 |2.807662 |2.783656 |- 0.024006 |5.76288 * 10 - 4|



График погрешности аппроксимации представлен на рисунке 4.
[pic]
График аппроксимирующей
функции представлен на рисунке 5.



6. ПОСТРОЕНИЕ БЛОК-СХЕМЫ И РАЗРАБОТКА ПРОГРАММЫ АППРОКСИМАЦИИ

Блок-схема алгоритма решения задачи аппроксимации методом наименьших
квадратов представлена на Рис. 6.
Первым шагом осуществляется ввод значений X(I),Y(I),N.
Далее обнуляются значения всех коэффициентов. В цикле рассчитываются
коэффициенты 3-х линейных уравнений. (см. п. 2.2). После цикла
приравниваем одинаковые коэффициенты в матрице. Потом выполняется
подпрограмма решения линейных уравнений.
Следующим шагом происходит описание функции пользователя:

FNY(X) = K(1) X 2 + K(2) X + K(3)

Следующий цикл находит значения аппроксимирующей функции, разность между
этими значениями и корнями дифференциального уравнения Y(I), квадрат
разности, а также производит их суммирование. Далее находится величина
погрешности аппроксимации и все данные выводятся на экран.
Общая программа решения дифференциального уравнения с последующей
аппроксимацией результатов представлена на рис. 7 вместе с программой
решения дифференциального уравнения, так как из нее получают значения X(I)
и Y(I).



[pic]

Рис. 6. Блок-схема алгоритма решения задачи аппроксимации методом
наименьших квадратов.



CLS
PRINT " Нахождение коэффициентов по методу Эйлера - Коши"
X0 = 0.7
XN = 1.7
Y0 = 2.1
H = 0.1
N = (XN - X0) / H
DIM X(N)
DIM Y(N)
X(0) = X0
Y(0) = Y0
FOR I = 0 TO N - 1
X(I + 1) = X(I) + H
Y(I + 1)* = Y(I) + H * (X(I) + COS(Y(I) / SQR(0.3)))
Y(I +1) = Y(I)+H*((X(I)+COS(Y(I)/SQR(0.3)))+(X(I+1)+COS(Y(I+1)* /
SQR(0.3))))/2
PRINT " X("; I; ")="; X(I), , "Y("; I; ")="; Y(I)
NEXT I
I = 10: PRINT " X("; I; ")="; X(I), "Y("; I; ")="; Y(I)
PRINT "Нахождение коэффициентов по методу наименьших квадратов"
PRINT "и погрешности аппроксимации"
a11 = 0: b1 = 0: a12 = 0: b2 = 0: a13 = 0: b3 = 0: a23 = 0: a33 = N + 1
FOR I = 0 TO N
a11 = a11 + X(I) ^ 4
a12 = a12 + X(I) ^ 3
a13 = a13 + X(I) ^ 2
a23 = a23 + X(I)
b1 = b1 + (X(I) ^ 2) * Y(I)
b2 = b2 + X(I) * Y(I)
b3 = b3 + Y(I)
NEXT I
a21 = a12: a22 = a13: a31 = a13: a32 = a23: S = 0
REM Начало подпрограммы решения СЛУ методом Гаусса
DIM К(3)
m21 = a21 / a11
m31 = a31 / a11
a22 = a22 - a12 * m21
a23 = a23 - a13 * m21
b2 = b2 - b1 * m21
a32 = a32 - a12 * m31
a33 = a33 - a13 * m31
b3 = b3 - b1 * m31
m32 = a32 / a22
a33 = a33 - a23 * m32
b3 = b3 - b2 * m32
К(3) = b3 / a33
К(2) = (b2 - К(3) * a23) / a22
К(1) = (b1 - К(3) * a13 - К(2) * a12) / a11
REM Конец подпрограммы решения СЛУ методом Гаусса
DIM F(N)
DEF FNY(X) = K(1) * X ^ 2 + K(2) * X + K(3)
PRINT "-------------------------------------------------------------------
----------------"
PRINT " X(I) | y(I) | F(x(I)) | F(x(I))-
y(I) | d^2 "
PRINT "-------------------------------------------------------------------
----------------"
FOR I = 0 TO N
F(I) = FNY(X(I))
D = F(I) - Y(I)
S = S + D ^ 2
PRINT X(I), Y(I), f(I), D, D^2
NEXT I
E = SQR(S / (N + 1))
PRINT "Погрешность ="; E
END



ЛИТЕРАТУРА

1. Витенберг И.М. Программирование на языке БЕЙСИК. Москва. «Радио и
связь».1991.
2. Гери М., Джонсон Д. Вычислительные машины и труднорешаемые задачи.
Пер. с англ. – Москва. «МИР» 1982.
3. Горбунова Н.Г. Методические указания к лабораторным работам по курсу
Информатика, ч.2 «Численные методы» - Хабаровск, 1996.
4. Спесивцев А.В. Руководство пользователя по языку Бейсик. Москва.
«Радио и связь». 1992. «ВЕСТА».
5. Методические указания для оформления пояснительных записок курсовых и
дипломных проектов - Хабаровск, 1997.


-----------------------
11






Реферат на тему: Решение дифференциальных уравнений 1 порядка методом Эйлера
Содержание
Введение 3
1. Постановка задачи 5
2. Обзор существующих методов решения задачи 6
2.1.Метод Рунге-Кутта четвертого порядка для решения
уравнения первого порядка
6
2.2.Задача Коши
6
2.3.Метод Булирша- Штера с использованием
рациональной экстраполяции для системы уравнений
7
2.4 Метод Адамса 8
2.5. Метод Эйлера 9
3. Описание алгоритмов решения задания 13
3.1. Описание переменных
13
3.2. Блок- схема главного модуля
14
3.3. Описание алгоритма главной программы 14
3.4. Блок-схема функции “func” 15

3.5. Описание блок- схемы функции “func” 15
4. Описание программного обеспечения 16
4.1. Описание операционной системы 16
4.2. Описание языка программирования 18
4.3. Описание программы 19

5. Контрольный пример
21
6.Анализ полученных результатов 22

Список литературы 24
Приложение
25



Введение
Уравнение [pic][pic] называется обыкновенным дифференциальным n-го
порядка, если F определена и непрерывна в некоторой области [pic]и, во
всяком случае, зависит от [pic]. Его решением является любая функция u(x),
которая этому уравнению удовлетворяет при всех x в определённом конечном
или бесконечном интервале. Дифференциальное уравнение, разрешенное
относительно старшей производной имеет вид
[pic]
Решением этого уравнения на интервале I=[a,b] называется функция u(x)
Решить дифференциальное уравнение у/=f(x,y) численным методом - это
значит для заданной последовательности аргументов х0, х1…, хn и числа у0,
не определяя функцию у=F(x), найти такие значения у1, у2,…, уn, что
уi=F(xi)(i=1,2,…, n) и F(x0)=y0.

Таким образом, численные методы позволяют вместо нахождения функции
y=F(x) (3) получить таблицу значений этой функции для заданной
последовательности аргументов. Величина h=xk-xk-1 называется шагом
интегрирования.
Метод Эйлера относиться к численным методам, дающим решение в виде
таблицы приближенных значений искомой функции у(х). Он является
сравнительно грубым и применяется в основном для ориентировочных расчетов.
Однако идеи, положенные в основу метода Эйлера, являются исходными для ряда
других методов.
Метод Эйлера для обыкновенных дифференциальных уравнений
используется для решений многих задач естествознания в качестве
математической модели. Например задачи электродинамики системы
взаимодействующих тел (в модели материальных точек), задачи химической
кинетики, электрических цепей. Ряд важных уравнений в частных производных в
случаях, допускающих разделение переменных, приводит к задачам для
обыкновенных дифференциальных уравнений – это, как правило, краевые задачи
(задачи о собственных колебаниях упругих балок и пластин, определение
спектра собственных значений энергии частицы в сферически-симметричных
полях и многое другое).



1.Постановка задачи
1.1. Решить приближенно дифференциальное уравнение вида [pic]методом Эйлера
1.2. Составить блок-схему алгоритма для решения данного задания.
1.3. Разработать программу на языке Microsoft Visual C++
1.4. Протестировать программу на примере y’=2x+y (n=5, [0,1], y0=1)
1.5. Выполнить анализ результатов.
1.6. Оформить пояснительную записку с приложением.



2.Обзор методов решения задачи.
2.1. Метод Рунге-Кутта четвертого порядка для решения уравнения первого
порядка.
Идея Рунге-Кута состоит в том, чтобы использовать метод неопределённых
коэффициентов. Наиболее употребительным методом Рунге-Кутта решения
уравнения первого порядка y' = F(x,y) (2.1.1) является метод четвертого
порядка, в котором вычисления производятся по формуле:
yk+1 = yk +(k1 +2k2 +2k3 +k4 )/6,
(2.1.2)
где
k1 = Fk h = F(xk , yk )h
k2 = F(xk +h/2, yk +k1 /2)h
k3 = F(xk +h/2, yk +k2 /2)h
k4 = F(xk +h, yk +k3 )h,
k = 0, ..., n-1
h = (xf -x0 )/n
(2.1.3)

2.2. Задача Коши.
Рассмотрим задачу Коши для уравнений первого порядка на отрезке [a,b]:
[pic], [pic] (2.1.4)
Разобьём промежуток [a,b] на N частей [pic]. Обозначим , где u(x) –точное
решение задачи Коши, и через [pic] значения приближенного решения в точках
[pic]. Существует 2 типа численных схем :
1. явные: [pic]) (2.2.1)
2. неявные: [pic] (2.2.2)
Здесь F некоторая функция, связывающая приближения. В явных схемах
приближенное значение [pic] в точке [pic] определяется через некоторое
число k уже определённых приближенных значений. В неявных схемах [pic]
определяется не рекурентным способом, как в явных схемах, а для его
определения возникает уравнение, поскольку равенство (2.2.2) представляет
из себя именно уравнение на [pic]. Явные схемы проще, однако зачастую
неявные схемы предпочтительнее.

2.3. Метод Булирша-Штера с использованием рациональной экстраполяции для
системы уравнений

Метод Булирша-Штера (Bulirsch-Stoer Method) - это метод решения системы
обыкновенных дифференциальных уравнений первого порядка с гладкими правыми
частями. Гладкость правых частей является необходимой для работы метода.
Если правые части вашей системы не являются гладкими или содержат разрывы,
то лучше использовать метод Рунге-Кутта. В случае же гладкой системы метод
Булирша-Штера позволяет добиться существенно большей точности, чем метод
Рунге-Кутта.

Принцип работы метода
Основной идеей метода является вычисление состояния системы в точке x+h,
как результата двух шагов длины h/2, четырех шагов длины h/4, восьми шагов
длины h/8 и так далее с последующей экстраполяцией результатов. Метод
строит рациональную интерполирующую функцию, которая в точке h/2 проходит
через состояние системы после двух таких шагов, в точке h/4 проходит через
состояние системы после четырех таких шагов, и т.д., а затем вычисляет
значение этой функции в точке h = 0, проводя экстраполяцию.
Гладкость правых частей приводит к тому, что вычисленное при помощи
экстраполяции состояние системы оказывается очень близко к действительному,
а использование рациональной экстраполяции вместо полиномиальной позволяет
ещё больше повысить точность.
Таким образом проводится один шаг метода, после чего принимается решение -
следует ли изменять шаг, а если да - то в какую сторону. При этом
используется оценка погрешности, которую мы получаем в качестве
дополнительного результата при рациональной экстраполяции. Следует
отметить, что алгоритм решает автономную систему, т.е. если уравнения
системы содержат время, то необходимо ввести время в качестве переменной,
производная от которой тождественно равна единице.
4. Метод Адамса
Явная схема Адамса.
Рассмотренные выше методы являются явными одношаговыми (для нахождения
последующего приближения используется лишь одно предыдущее). Приведённый
ниже метод является многошаговым.
Пусть задана задача Коши:
[pic] (2.4.1)
Для точного решения (которое нам не известно) выполнено:
[pic] (2.4.2)
Предположим, нам известны приближенные значения [pic] функции u(x) в k
точках [pic] (стартовые k точек, в частности, можно найти методом Эйлера
или методом Рунге-Кутта того или иного порядка), тогда функцию f(x,u(x)) в
(2.4.2) для приближенного вычисления интеграла можно заменить на
интерполяционный полином [pic] порядка k-1, построенный по k точкам [pic],
интеграл от которого считается явно и представляет собой линейную
комбинацию значений [pic]c некоторыми множителями [pic]. Таким образом,
мы получаем следующую рекуррентную процедуру вычисления приближенных
значений [pic] функции u(x) (являющимся точным решением задачи Коши) в
точках [pic] :
[pic] (2.4.3)
Описанная схема является k-шаговой явной формулой Адамса.
Неявная схема Адамса.
Пусть [pic]- интерполяционный полином порядка k, построенный по k+1
значению [pic]б одно из которых, именно [pic], мы будем считать
неизвестным. Модифицируем (2.4.3), заменив в нём [pic] на полином более
высокой степени [pic], интеграл от которого выражается в виде линейной
комбинации значений [pic] с некоторыми новыми коэффициентами [pic]:
[pic] (2.4.4)
Формула (2.4.4) представляет собой неявную схему Адамса и является
уравнением на [pic], которое можно решать методом последовательных
приближений. Естественно, что начальное приближение [pic], должно быть
разумно выбрано. Для этого удобно объединить явную и неявную схемы Адамса в
одну, называемую «методом коррекции». Именно с помощью явной схемы
определяется начальное приближение [pic](прогноз), а затем по неявной
схеме оно необходимое число раз (обычно один или два) корректируется
методом последовательных приближений до достижения заданной точности
(коррекция).

2.5.Метод Эйлера.
Решить дифференциальное уравнение у/=f(x,y) численным методом - это
значит для заданной последовательности аргументов х0, х1…, хn и числа у0,
не определяя функцию у=F(x), найти такие значения у1, у2,…, уn, что
уi=F(xi)(i=1,2,…, n) и F(x0)=y0. (2.5.1)
Таким образом, численные методы позволяют вместо нахождения функции
У=F(x) получить таблицу значений этой функции для заданной
последовательности аргументов. Величина h=xk-xk-1 называется шагом
интегрирования.
Метод Эйлера относиться к численным методам, дающим решение в виде
таблицы приближенных значений искомой функции у(х). Он является
сравнительно грубым и применяется в основном для ориентировочных расчетов.
Однако идеи, положенные в основу метода Эйлера, являются исходными для ряда
других методов.
Рассмотрим дифференциальное уравнение первого порядка (2.5.1)
с начальным условием
x=x0, y(x0)=y0 (2.5.2)
Требуется найти решение уравнения (2.5.1) на отрезке [а,b].
Разобьем отрезок [a, b] на n равных частей и получим последовательность х0,
х1, х2,…, хn, где xi=x0+ih (i=0,1,…, n), а h=(b-a)/n-шаг интегрирования.
В методе Эйлера приближенные значения у(хi)(yi вычисляются
последовательно по формулам уi+hf(xi, yi) (i=0,1,2…).
При этом искомая интегральная кривая у=у(х), проходящая через точку М0(х0,
у0), заменяется ломаной М0М1М2… с вершинами Мi(xi, yi) (i=0,1,2,…); каждое
звено МiMi+1 этой ломаной, называемой ломаной Эйлера, имеет направление,
совпадающее с направлением той интегральной кривой уравнения (2.5.1),
которая проходит через точку Мi. Если правая часть уравнения (2.5.1) в
некотором прямоугольнике R{|x-x0|(a, |y-y0|(b}удовлетворяет условиям:


|f(x, y1)- f(x, y2)| ( N|y1-
y2| (N=const), (2.5.3)
|df/dx|=|df/dx+f(df/dy)| ( M (M=const),
то имеет место следующая оценка погрешности:
|y(xn)-yn| ( hM/2N[(1+hN)n-1],
(2.5.4)
где у(хn)-значение точного решения уравнения (2.5.1) при х=хn, а уn-
приближенное значение, полученное на n-ом шаге.
Формула (13) имеет в основном теоретическое применение. На практике иногда
оказывается более удобным двойной просчет: сначала расчет ведется с шагом
h, затем шаг дробят и повторный расчет ведется с шагом h/2. Погрешность
более точного значения уn* оценивается формулой
|yn-y(xn)|(|yn*-yn|.
(2.5.5)
Метод Эйлера легко распространяется на системы дифференциальных
уравнений и на дифференциальные уравнения высших порядков. Последние должны
быть предварительно приведены к системе дифференциальных уравнений первого
порядка.
Модифицированный метод Эйлера
Рассмотрим дифференциальное уравнение (2.5.1) y/=f(x,y) с начальным
условием y(x0)=y0. Разобьем наш участок интегрирования на n равных частей.
На малом участ интегральную кривую заменим прямой
линией.
[pic]
Рис.1 Метод Эйлера в графическом
видa

Получаем точку Мк(хк,ук). Через Мк проводим касательную: у=ук=f(xk,yk)(x-
xk). Делим отрезок (хк,хк1) пополам:
xNk/=xk+h/2=xk+1/2
(2.5.6)

yNk/=yk+f(xk,yk)h/2=yk+yk+1/2
Получаем точку Nk/. В этой точке строим следующую касательную:
y(xk+1/2)=f(xk+1/2, yk+1/2)=?k
(2.5.7)
Из точки Мк проводим прямую с угловым коэффициентом ?к и определяем точку
пересечения этой прямой с прямой Хк1. Получаем точку Мк/. В качестве ук+1
принимаем ординату точки Мк/. Тогда:
ук+1=ук+?кh
xk+1=xk+h
(2.5.8) ?k=f(xk+h/2,
yk+f(xk,Yk)h/2)
yk=yk-1+f(xk-1,yk-1)h
(2.5.8)-рекурентные формулы метода Эйлера.
Сначала вычисляют вспомогательные значения искомой функции ук+1/2 в
точках хк+1/2, затем находят значение правой части уравнения (11) в средней
точке y/k+1/2=f(xk+1/2, yk+1/2) и определяют ук+1.
Для оценки погрешности в точке хк проводят вычисления ук с шагом h,
затем с шагом 2h и берут 1/3 разницы этих значений:
| ук*-у(хк)|=1/3(yk*-yk),
(2.5.9)
где у(х)-точное решение дифференциального уравнения.
Таким образом, методом Эйлера можно решать уравнения любых порядков.
Например, чтобы решить уравнение второго порядка y//=f(y/,y,x) c начальными
условиями y/(x0)=y/0, y(x0)=y0, выполняется замена:
y/=z
(2.5.10)
z/=f(x,y,z)
Тем самым преобразуются начальные условия: y(x0)=y0, z(x0)=z0, z0=y/0.
(2.5.12)



3.Описание алгоритмов решения задачи
3.1.Описание переменных.
|Наименование |Тип |Описание |
|Входные данные |
|Xi |double |Начальное значение (x) |
| | |интервала вычисления |
|Xkon |double |Конечное значение (x) |
| | |интервала вычисления |
|n |integer |Количество шагов |
|Yi |double |Начальное значение y |
|kx |double |Коэффициент при переменой|
| | |x |
|ky |double |Коэффициент при |
| | |переменной y |
|Выходные данные |
|h |double |Фиксированное приращение |
| | |аргумента (x) |
|res |double |Расчётное значение |
| | |уравнение y’=F(x,y) в |
| | |точке (x) |
|Промежуточные |
|i |integer |Счётчик цикла |
|Yprom |double |Промежуточное значение y |
| | |в точке Xprom |
|Xprom |double |Промежуточное значение x |
| | |при h/2 |
|a |double |Решение уравнения в |
| | |точках f(Xprom,Yprom) |
|f1 |double |Функция f(x,y) |


3.2. Блок- схема главного модуля

[pic]
3.3 Описание алгоритма главной программы.
|Номер блока |Описание |
|1 |Ввод начального и конечного значений интервала вычисления |
| |уравнения, количество шагов, начальное значение у, а также |
| |коэффициенты при kx и ky. |
|2 |Вычисление фиксированного приращения аргумента х |
|3 |Цикл с шагом 1 и конечным значением не превышающим количество |
| |шагов, который высчитывает значение y на определённом |
| |интервале |
|4 |Функция для расчёта уравнения вида y’=f(x,y); |
| | |
|5 |Вывод результатов на интервале X |


3.4 Блок-схема функции “func”.
[pic]3.5 Описание блок- схемы функции “func”.
|Номер |Описание |
|блока | |
|1 |Вычисление: функции f1 с подстановкой начальных значений; |
| |промежуточных значений Yprom и Xprom, значения a для вычисления |
| |f(Xprom,Yprom) и расчёт результатов функции и переход на следующий |
| |шаг. |
|2 |Приращение аргумента x на h |
|3 |Вывод результатов уравнения и интервала |



*Реализация алгоритма на языке программирования C++ представлена в
приложении .



4.Описание программного обеспечения.
4.1 Описание операционной системы

Основное требование к операционной системе (ОС), предъявляемое
поставленной задачей, это наличие ANSI или POSIX совместимого компилятора
языка C++.
Для реализации задачи была выбрана последняя клиентская версия
операционной системы Microsoft, основанная на ядре NT – Microsoft Windows
XP Professional.
Указанная операционная система обладает рядом преимуществ:
. наличие достаточного количество ANSI или POSIX совместимых
компиляторов языка C++, разработанных для данной ОС, а именно –
o Microsoft C++ (version 2-6)
o gcc
o Borland C++
o Intel C++
o прочие;
. достаточная управляемость, надежность и безопасность;
. широкое распространение основанных на ядре NT операционных систем
Microsoft, совместимых по программному обеспечению с Windows XP
Professional (NT/2000/XP/2003 – client & server);
. высокая скорость работы приложений, разработанных для данной ОС с
использованием компиляторов C++.

Исходный код программы может быть откомпилирован и под другой
операционной системой, если для таковой имеется ANSI или POSIX совместимый
компилятор языка C++.
Программа была протестирована на операционной системе Microsoft
Windows XP Professional SP1.
Технические данные :
. HDD: 60 Gb
. Процессор x86 Family 15 Model 2 Stepping 7 GenuineIntel ~1817
МГц
. Версия BIOS Award Software International, Inc. F4,
06.03.2003
. Аппаратно-зависимый уровень (HAL) Версия = "5.1.2600.1106
(xpsp1.020828-1920)"
. Полный объем физической памяти 256,00 МБ
. Доступно физической памяти 29,97 МБ
. Всего виртуальной памяти 873,69 МБ
. Доступно виртуальной памяти 350,04 МБ
. Файл подкачки 618,21 МБ



4.2 Описание языка программирования
Язык программирования С++
С++ - это универсальный язык программирования, задуманный так, чтобы
сделать программирование более приятным для серьезного программиста. За
исключением второстепенных деталей С++ является надмножеством языка
программирования C. Помимо возможностей, которые дает C, С++ предоставляет
гибкие и эффективные средства определения новых типов. Используя
определения новых типов, точно отвечающих концепциям приложения,
программист может разделять разрабатываемую программу на лег ко поддающиеся
контролю части. Такой метод построения программ часто называют абстракцией
данных. Информация о типах содержится в некоторых объектах типов,
определенных пользователем. Такие объекты просты и надежны в использовании
в тех ситуациях, когда их тип нельзя установить на стадии компиляции.
Программирование с применением таких объектов часто называют объектно-
ориентированным. При правильном использовании этот метод дает более
короткие, проще понимаемые и легче контролируемые программы.
В С++ нет типов данных высокого уровня и нет первичных операций
высокого уровня. В нем нет, например, матричного типа с операцией обращения
или типа строка с операцией конкатенации. Если пользователю понадобятся
подобные типы, их можно определить в самом языке. По сути дела, основное,
чем занимается программирование на С++ - это определение универсальных и
специально-прикладных типов. Хорошо разработанный тип, определяемый
пользователем, отличается от встроенного типа только способом определения,
но не способом использования.
Реализация С++ очень легко переносима. Однако есть полные основания
использовать С++ в среде, где имеется гораздо более существенная поддержка.
Такие средства, как динамическая загрузка, пошаговая трансляция и база
данных определений типов могут с пользой применяться без воздействия на
язык.
Типы и средства сокрытия данных в С++ опираются на проводимый во время
компиляции анализ программ с целью предотвращения случайного искажения
данных. Они не обеспечивают секретности или защиты от умышленного нарушения
правил. Однако эти средства можно использовать без ограничений, что не
приводит к дополнительным расходам времени на выполнение или пространства
памяти.

Компилятор Microsoft C++ и среда разработки Microsoft Visual Studio

В качестве компилятора для разработки приложения был выбран Microsoft
C++ по следующим причинам:
. практически полная совместимость со стандартом ANSI C++;
. наличие удобной среды разработки Microsoft Visual Studio;
. наличие отличной документации;
. высокая скорость работы результирующих приложений;
. совместимость разработанных приложений с большим количеством широко
распространенных операционных систем;
. достаточная скорость компиляции.
4.3 Описание программы
Разработанное приложение поставляется в виде 2-ух файлов:
1. method Eulera.cpp – исходный код программы на языке C++;
2. method Eulera.exe – исполняемый файл.
Для выполнения исполняемого файла необходима одна из ниже
перечисленных операционных систем:
. Microsoft Windows 3.11+Win32s;
. Microsoft Windows 95/98/Me;
. Microsoft Windows NT/2000/XP/2003 – клиентская или серверная версия.
Программа не требует предварительной установки и может быть сразу же
запущена на выполнение.
Исходный код приложения может быть откомпилирован в любом ANSI или
POSIX совместимом компиляторе С++ для получения выполнимой программы. Для
успешной компиляции требуется наличие стандартной библиотеки «iostream».



5. Контрольный пример
Данный метод протестирован на контрольном примере и реализован с помощью
языка программирования С++.
В результате вычислений контрольного примера вида y’=2x+y с интервалом
[0,1],
количеством шагов равному 5 и начальным условием у равным 1, с помощью
программы, получились следующие результаты:
[pic] Рис. 2. Экран с результатами выполнения программы.
Как видно, при вычислении программа на первом шаге берёт начальные
значения для вычисления, а на последующих берёт значения полученные с
предыдущих шагов. Можно сделать вывод, что точность вычисления данного
метода зависит от количества выбранных шагов: чем больше шагов, тем меньше
фиксированное приращение , а следовательно она более точно вычисляет
значение всего интервала.
По работе программы стало видно, что с её использованием намного
упростилась работа пользователя. Пользователь просто вводит интервал на
котором должен вычисляться пример, количество шагов и начальное значения и
программа выдаёт уже готовое решение данного примера.

6.Анализ полученных результатов.
По результатам программы можно составить таблицу сравнения результатов
полученных при использовании программы и результатов, полученных ручным
способом:
|Ручной способ вычисления |Программный способ вычисления |
|Х |Y |X |Y |
|0 |0,82 |0 |0,82 |
|0,2 |0,75 |0,2 |0,7516 |
|0,4 |0,77 |0,4 |0,770248 |
|0,6 |0,85 |0,6 |0,856793 |
|0,8 |0,99 |0,8 |0,996299 |

Из приведенного сравнения можно сделать вывод, что один результат
отличается от другого тем, что в примере, решенном программным способом
ответ вычисляется с наибольшей точностью, чем при ручном способе. Это может
быть связано с тем, что в ручном способе результат округляется для удобства
вычисления примера.
Решение дифференциальных уравнений методом Эйлера можно также отобразить в
графическом виде:
[pic]
Рис.3.Графическое изображение решения примера y’=2x+y
Как видно из рис.3 графиком решения уравнения является кривая , форма
которой зависит от количества разбиений интервала.
По результатам выполненной работы можно сделать вывод, что решение
дифференциальных уравнений методом Эйлера является методом вычисления со
средней точностью и точность вычисления данного метода зависит от
количества разбиений интервала интегрирования. При сравнении результатов
решенными разными способами можно сказать, что данный метод был верно
реализован на языке программирования Microsoft Visual C++. Полученные
результаты сходятся с небольшой погрешностью.



Список литературы.
1. Численные методы (анализ, алгебра, обыкновенные дифференциальные
уравнения), Н.С. Бахвалов. Главная редакция физико- математической
литературы изд-ва «Наука», М., 1975г.
2. Методы, теории обыкновенных дифференциальных уравнений. Н.И. Гаврилов
. Государственное издательство «Высшая школа» Москва-1962г.
3. В.В.Пак., Ю.Л. Носенко. Высшая математика: Учебник.- Д.: Сталкер,
1997г.
4. Б. П. Демидович, И. А. Марон Основы вычислительной математике. – М.,
1966
5. Загускин В. Л. – Справочник по численным методам решения уравнений.
– М.: ФИЗМАТГИЗ, 1960. – 216 с.
6. Либерти, Джесс.
Освой самостоятельно С++ за 21 день, 4-е издание.:Пер с англ.-М.:
Издательский дом «Вильямс», 2003.-832с.
7. П.Нортон, П.Иао «Программирование на С++ в среде Windows»
(«Диалектика» Киев 2003г.)
8. Янг М. Microsoft Visual C++ - М.:ЭНТРОП, 2000.
9. Марченко А.И., Марченко Л.А. – Программирование в среде
Turbo Pascal 7.0 – К.: ВЕК+, М.: Бином Универсал, 1998. – 496 с.
10. Высшая математика: Справ. материалы: Книга для учащихся .- М.:
Просвещение, 1988.-416 с.: ил.



Приложение.
Листинг программы.
#include
using namespace std;
void func(double& Xi, double& Yi,double kx, double ky, double h);
int main()

{
double h,Xi,Yi,Xkon,kx,ky;
int n;
cout

Новинки рефератов ::

Реферат: Жан Пиаже (Психология)


Реферат: Найм и отбор персонала (Менеджмент)


Реферат: Необходимость, сущность аудита. Содержание аудиторских отчетов и правила их оформления (Бухгалтерский учет)


Реферат: Методы формирования кадрового состава (Менеджмент)


Реферат: Бухгалтерский учет валютных операций (Бухгалтерский учет)


Реферат: Контрольная работа (Делопроизводство)


Реферат: МАСОНСТВО. ТРИСТА ЛЕТ В РОССИИ (Политология)


Реферат: Рабочая жидкость (Технология)


Реферат: Активные формы работ на уроках математики (Педагогика)


Реферат: Устройство парков и внутренняя служба в них (Технология)


Реферат: Реформа Столыпина (История)


Реферат: Система образования в Германии (Педагогика)


Реферат: Магний (Химия)


Реферат: Диктатура над русским народом (История)


Реферат: Гимнастика (Спорт)


Реферат: Культура России второй половины 19 века (Культурология)


Реферат: Грузовое устройство (Технология)


Реферат: Муниципальное право (Государство и право)


Реферат: Стратегические цели экономической политики России в современных условиях (Менеджмент)


Реферат: Темы по английскому за 9 класс (Иностранные языки)



Copyright © GeoRUS, Геологические сайты альтруист