Дифференциал уравнение n-го порядка

Автор работы: Пользователь скрыл имя, 30 Января 2011 в 20:35, курсовая работа

Описание работы

Уравнение называется обыкновенным дифференциальным n-го порядка, если F определена и непрерывна в некоторой области и, во всяком случае, зависит от . Его решением является любая функция u(x), которая этому уравнению удовлетворяет при всех x в определённом конечном или бесконечном интервале. Дифференциальное уравнение, разрешенное относительно старшей производной имеет вид

Содержание работы

Введение 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

Файлы: 1 файл

дифференциал.doc

— 273.50 Кб (Скачать файл)

Требуется найти решение уравнения (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…).

При этом искомая интегральная кривая у=у(х), проходящая через точку М00, у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 равных частей. На малом участ интегральную кривую заменим    прямой                      линией.

                                           Рис.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. Блок- схема главного модуля 

3.3 Описание алгоритма главной программы.

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

3.4 Блок-схема функции “func”.

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++, разработанных для данной ОС, а именно –
    • Microsoft C++ (version 2-6)
    • gcc
    • Borland  C++
    • Intel C++
    • прочие;
  • достаточная управляемость,  надежность и безопасность;
  • широкое распространение основанных на ядре 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, С++ предоставляет гибкие и эффективные средства определения новых типов. Используя определения новых типов, точно отвечающих концепциям приложения, программист может разделять разрабатываемую программу на лег ко поддающиеся контролю части.  Такой метод построения программ часто называют абстракцией данных. Информация о типах содержится в некоторых объектах типов, определенных пользователем. Такие объекты просты и надежны в использовании в тех ситуациях, когда их тип нельзя установить на стадии компиляции. Программирование с применением таких объектов часто называют объектно-ориентированным. При правильном использовании этот метод дает более короткие, проще понимаемые и легче контролируемые программы.

Информация о работе Дифференциал уравнение n-го порядка