Автор работы: Пользователь скрыл имя, 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
Содержание
Введение 3
уравнения первого порядка 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
Введение
Уравнение называется обыкновенным дифференциальным n-го порядка, если F определена и непрерывна в некоторой области и, во всяком случае, зависит от . Его решением является любая функция u(x), которая этому уравнению удовлетворяет при всех x в определённом конечном или бесконечном интервале. Дифференциальное уравнение, разрешенное относительно старшей производной имеет вид
Решением этого уравнения на интервале I=[a,b] называется функция u(x)
Решить дифференциальное
Таким образом, численные методы позволяют вместо нахождения функции y=F(x) (3) получить таблицу значений этой функции для заданной последовательности аргументов. Величина h=xk-xk-1 называется шагом интегрирования.
Метод Эйлера относиться к
численным методам, дающим
Метод Эйлера для обыкновенных дифференциальных
уравнений используется для решений многих
задач естествознания в качестве математической
модели. Например задачи электродинамики
системы взаимодействующих тел (в модели
материальных точек), задачи химической
кинетики, электрических цепей. Ряд важных
уравнений в частных производных в случаях,
допускающих разделение переменных, приводит
к задачам для обыкновенных дифференциальных
уравнений – это, как правило, краевые
задачи (задачи о собственных колебаниях
упругих балок и пластин, определение
спектра собственных значений энергии
частицы в сферически-симметричных полях
и многое другое).
1.Постановка задачи
1.1. Решить приближенно дифференциальное уравнение вида методом Эйлера
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,
где
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.2. Задача Коши.
Рассмотрим задачу Коши для уравнений первого порядка на отрезке [a,b]:
, (2.1.4)
Разобьём промежуток [a,b] на N частей . Обозначим , где u(x) –точное решение задачи Коши, и через значения приближенного решения в точках . Существует 2 типа численных схем :
Здесь
F некоторая функция, связывающая приближения.
В явных схемах приближенное значение
в точке
определяется через некоторое число
k уже определённых приближенных значений.
В неявных схемах
определяется не рекурентным способом,
как в явных схемах, а для его определения
возникает уравнение, поскольку равенство (2.2.2) представляет
из себя именно уравнение на
. Явные схемы проще, однако зачастую
неявные схемы предпочтительнее.
2.3. Метод
Булирша-Штера с использованием
рациональной экстраполяции
для системы уравнений
Метод
Булирша-Штера (Bulirsch-Stoer Method) - это метод
решения системы обыкновенных дифференциальных
уравнений первого порядка с
гладкими правыми частями. Гладкость
правых частей является необходимой для
работы метода. Если правые части вашей
системы не являются гладкими или содержат
разрывы, то лучше использовать метод
Рунге-Кутта. В случае же гладкой системы
метод Булирша-Штера позволяет добиться
существенно большей точности, чем метод
Рунге-Кутта.
Принцип работы метода
Основной
идеей метода является вычисление состояния
системы в точке x+h, как результата
двух шагов длины h/2, четырех шагов
длины h/4, восьми шагов длины h/8 и
так далее с последующей
Гладкость правых частей приводит к тому, что вычисленное при помощи экстраполяции состояние системы оказывается очень близко к действительному, а использование рациональной экстраполяции вместо полиномиальной позволяет ещё больше повысить точность.
Таким образом проводится один шаг метода, после чего принимается решение - следует ли изменять шаг, а если да - то в какую сторону. При этом используется оценка погрешности, которую мы получаем в качестве дополнительного результата при рациональной экстраполяции. Следует отметить, что алгоритм решает автономную систему, т.е. если уравнения системы содержат время, то необходимо ввести время в качестве переменной, производная от которой тождественно равна единице.
Явная схема Адамса.
Рассмотренные выше методы являются явными одношаговыми (для нахождения последующего приближения используется лишь одно предыдущее). Приведённый ниже метод является многошаговым.
Пусть задана задача Коши:
Для точного решения (которое нам не известно) выполнено:
Предположим, нам известны приближенные значения функции u(x) в k точках (стартовые k точек, в частности, можно найти методом Эйлера или методом Рунге-Кутта того или иного порядка), тогда функцию f(x,u(x)) в (2.4.2) для приближенного вычисления интеграла можно заменить на интерполяционный полином порядка k-1, построенный по k точкам , интеграл от которого считается явно и представляет собой линейную комбинацию значений c некоторыми множителями . Таким образом, мы получаем следующую рекуррентную процедуру вычисления приближенных значений функции u(x) (являющимся точным решением задачи Коши) в точках :
Описанная схема является k-шаговой явной формулой Адамса.
Неявная схема Адамса.
Пусть - интерполяционный полином порядка k, построенный по k+1 значению б одно из которых, именно , мы будем считать неизвестным. Модифицируем (2.4.3), заменив в нём на полином более высокой степени , интеграл от которого выражается в виде линейной комбинации значений с некоторыми новыми коэффициентами :
Формула
(2.4.4) представляет собой неявную схему
Адамса и является уравнением на
, которое можно решать методом последовательных
приближений. Естественно, что начальное
приближение
, должно быть разумно выбрано. Для
этого удобно объединить явную и неявную
схемы Адамса в одну, называемую «методом
коррекции». Именно с помощью явной схемы
определяется начальное приближение
(прогноз), а затем по неявной схеме
оно необходимое число раз (обычно один
или два) корректируется методом последовательных
приближений до достижения заданной точности
(коррекция).
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 называется шагом интегрирования.
Метод Эйлера относиться к
численным методам, дающим
Рассмотрим дифференциальное
с начальным условием