Метод предиктор корректор решения дифференциальных уравнений

Задачи с начальными условиями для систем обыкновенных дифференциальных уравнений

Рассмотрим задачу Коши для системы обыкновенных дифференциальных уравнений $$ begin tag frac &= f_i (t, u_1, u_2, ldots, u_n), quad t > 0\ tag u_i(0) &= u_i^0, quad i = 1, 2, ldots, m. end $$

Используя векторные обозначения, задачу (1), (2) можно записать как задачу Коши $$ begin tag frac<d pmb> &= pmb(t, pmb), quad t > 0, \ tag pmb(0) &= pmb_0 end $$ В задаче Коши необходимо по известному решению в точке ( t = 0 ) необходимо найти из уравнения (3) решение при других ( t ).

Видео:3_02. Алгоритмы решения ОДУСкачать

3_02. Алгоритмы решения ОДУ

Численные методы решения задачи Коши

Существует большое количество методов численного решения задачи (3), (4). Вначале рассмотрим простейший явный метод Эйлера и его программную реализацию. Затем будут представлены методы Рунге—Кутта и многошаговые методы.

При построении численных алгоритмов будем считать, что решение этой дифференциальной задачи существует, оно единственно и обладает необходимыми свойствами гладкости.

Идея численных методов решения задачи (3), (4) состоит из четырех частей:

1. Вводится расчетная сетка по переменной ( t ) (время) из ( N_t + 1 ) точки ( t_0 ), ( t_1 ), ( ldots ), ( t_ ). Нужно найти значения неизвестной функции ( pmb ) в узлах сетки ( t_n ). Обозначим через ( pmb^n ) приближенное значение ( pmb(t_n) ).

2. Предполагаем, что дифференциальное уравнение выполнено в узлах сетки.

3. Аппроксимируем производные конечными разностями.

4. Формулируем алгоритм, который вычисляет новые значения ( pmb^ ) на основе предыдущих вычисленных значений ( pmb^k ), ( k 0 ) при ( tauto 0 ).

Видео:18+ Математика без Ху!ни. Дифференциальные уравнения.Скачать

18+ Математика без Ху!ни. Дифференциальные уравнения.

Явный метод Эйлера

Проиллюстрируем указанные шаги. Для начала введем расчетную сетку. Очень часто сетка является равномерной, т.е. имеет одинаковое расстояние между узлами ( t_n ) и ( t_ ): $$ omega_tau = . $$

Затем, предполагаем, что уравнение выполнено в узлах сетки, т.е.: $$ pmb^prime (t_n) = pmb(t_n, u(t_n)), quad t_n in omega_tau. $$

Заменяем производные конечными разностями. С этой целью, нам нужно знать конкретные формулы, как производные могут быть аппроксимированы конечными разностями. Простейший подход заключается в использовании определения производной: $$ pmb^prime(t) = lim_ frac<pmb(t+tau) — pmb(t)>. $$

В произвольном узле сетки ( t_n ) это определение можно переписать в виде: $$ begin pmb^prime(t_n) = lim_ frac<pmb(t_n+tau) — pmb(t_n)>. end $$ Вместо того, чтобы устремлять шаг сетки к нулю, мы можем использовать малый шаг ( tau ), который даст численное приближение ( u^prime(t_n) ): $$ begin pmb^prime(t_n) approx frac<pmb^ — pmb^>. end $$ Такая аппроксимация известна как разностная производная вперед и имеет первый порядок по ( tau ), т.е. ( O(tau) ). Теперь можно использовать аппроксимацию производной. Таким образом получим явный метод Эйлера: $$ begin tag frac<pmb^ — pmb^n> = pmb(t_n, pmb^). end $$

Четвертый шаг заключается в получении численного алгоритма. Из (5) следует, что мы должны знать значение ( y^n ) для того, чтобы решить уравнение (5) относительно ( y^ ) и получить формулу для нахождения приближенного значения искомой функции на следующем временном слое ( t_ ): $$ begin tag pmb^ = pmb^n + tau pmb(t_n, pmb^) end $$

При условии, что у нас известно начальное значение ( pmb^0 = pmb_0 ), мы можем использовать (6) для нахождения решений на последующих временных слоях.

Программная реализация явного метода Эйлера

Выражение (6) может быть как скалярным так и векторным уравнением. И в скалярном и в векторном случае на языке Python его можно реализовать следующим образом

При решении системы (векторный случай), u[n] — одномерный массив numpy длины ( m+1 ) (( m ) — размерность задачи), а функция F должна возвращать numpy -массив размерности ( m+1 ), t[n] — значение в момент времени ( t_n ).

Таким образом численное решение на отрезке ( [0, T] ) должно быть представлено двумерным массивом, инициализируемым нулями u = np.zeros((N_t+1, m+1)) . Первый индекс соответствует временному слою, а второй компоненте вектора решения на соответствующем временном слое. Использование только одного индекса, u[n] или, что то же самое, u[n, :] , соответствует всем компонентам вектора решения.

Функция euler решения системы уравнений реализована в файле euler.py:

Строка F_ = lambda . требует пояснений. Для пользователя, решающего систему ОДУ, удобно задавать функцию правой части в виде списка компонент. Можно, конечно, требовать чтобы пользователь возвращал из функции массив numpy , но очень легко осуществлять преобразование в самой функции решателе. Чтобы быть уверенным, что результат F будет нужным массивом, который можно использовать в векторных вычислениях, мы вводим новую функцию F_ , которая вызывает пользовательскую функцию F «прогоняет» результат через функцию assaray модуля numpy .

Видео:Решение системы дифференциальных уравнений методом ЭйлераСкачать

Решение системы дифференциальных уравнений методом Эйлера

Неявный метод Эйлера

При построении неявного метода Эйлера значение функции ( F ) берется на новом временном слое, т.е. для решении задачи (5) используется следующий метод: $$ begin tag frac<pmb^ — pmb^n> = pmb(t_, pmb^). end $$

Таким образом для нахождения приближенного значения искомой функции на новом временном слое ( t_ ) нужно решить нелинейное уравнение относительно ( pmb^ ): $$ begin tag pmb^ — tau pmb(t_, pmb^) — y^n = 0. end $$

Для решения уравнения (8) можно использовать, например, метод Ньютона.

Программная реализация неявного метода Эйлера

Функция backward_euler решения системы уравнений реализована в файле euler.py:

Отметим, что для нахождения значения u[n+1] используется функция fsolve модуля optimize библиотеки scipy . В качестве начального приближения для решения нелинейного уравнения используется значение искомой функции с предыдущего слоя u[n] .

Видео:Задача Коши ➜ Частное решение линейного однородного дифференциального уравненияСкачать

Задача Коши ➜ Частное решение линейного однородного дифференциального уравнения

Методы Рунге—Кутта

Одношаговый метод Рунге—Кутта в общем виде записывается следующим образом: $$ begin tag frac<pmb^ — pmb^n> = sum_^s b_i pmb_i, end $$ где $$ begin tag pmb_i = pmbleft( t_n + c_itau, pmb^n + tau sum_^s a_pmb_j right), quad i = 1, 2, ldots, s. end $$ Формула (9) основана на ( s ) вычислениях функции ( pmb ) и называется ( s )-стадийной. Если ( a_ = 0 ) при ( j geq i ) имеем явный метод Рунге—Кутта. Если ( a_ = 0 ) при ( j > i ) и ( a_ ne 0 ), то ( pmb_i ) определяется неявно из уравнения $$ begin tag pmb_i = pmbleft( t_n + c_itau, pmb^n + tau sum_^ a_pmb_j + tau a_ pmb_i right), quad i = 1, 2, ldots, s. end $$ О таком методе Рунге—Кутта говорят как о диагонально-неявном.

Одним из наиболее распространенных является явный метод Рунге-Кутта четвертого порядка: $$ begin tag pmb_1 & = pmb(t_n, pmb^n), &quad pmb_2 &= pmbleft( t_n + frac, pmb^n + tau frac<pmb_1> right),\ pmb_3 &= pmbleft( t_n + frac, pmb^n + tau frac<pmb_2> right), &quad pmb_4 &= pmbleft( t_n + tau, pmb^n + tau pmb_3 right),\ frac<pmb^ -pmb^n> &= frac (pmb_1 + 2pmb_2 + 2pmb_3 + pmb_4) & & end $$

Видео:7. Линейные дифференциальные уравнения первого порядка. Метод Бернулли.Скачать

7. Линейные дифференциальные уравнения первого порядка. Метод Бернулли.

Многошаговые методы

В методах Рунге—Кутта в вычислениях участвуют значения приближенного решения только в двух соседних узлах ( pmb^n ) и ( pmb^ ) — один шаг по переменной ( t ). Линейный ( m )-шаговый разностный метод записывается в виде $$ begin tag frac sum_^m a_i pmb^ = sum_^ b_i pmb(t_, pmb^), quad n = m-1, m, ldots end $$ Вариант численного метода определяется заданием коэффициентов ( a_i ), ( b_i ), ( i = 0, 1, ldots, m ), причем ( a_0 ne 0 ). Для начала расчетов по рекуррентной формуле (13) необходимо задать ( m ) начальных значений ( pmb^0 ), ( pmb^1 ), ( dots ), ( pmb^ ) (например, можно использовать для их вычисления метод Эйлера).

Различные варианты многошаговых методов (методы Адамса) решения задачи с начальными условиями для систем обыкновенных дифференциальных уравнений могут быть получены на основе использования квадратурных формул для правой части равенства $$ begin tag pmb(t_) — pmb(t_n) = int_^<t_> pmb(t, pmb) dt end $$

Для получения неявного многошагового метода используем для подынтегральной функции интерполяционную формулу по значениям функции ( pmb^ = pmb(t_, pmb^) ), ( pmb^n ), ( dots ), ( pmb^ ), т.е. $$ begin tag frac<pmb^ — pmb^n> = sum_^ b_i pmb(t_, pmb^) end $$

Для интерполяционного метода Адамса (15) наивысший порядок аппроксимации равен ( m+1 ).

Для построения явных многошаговых методов можно использовать процедуру экстраполяции подынтегральной функции в правой части (14). В этом случае приближение осуществляется по значениям ( pmb^n ), ( pmb^ ), ( dots ), ( pmb^ ) и поэтому $$ begin tag frac<pmb^ — pmb^n> = sum_^ b_i pmb(t_, pmb^) end $$

Для экстраполяционного метода Адамса (16) погрешность аппроксимации имеет ( m )-ый порядок.

На основе методов Адамса строятся и схемы предиктор–корректор. На этапе предиктор используется явный метод Адамса, на этапе корректора — аналог неявного метода Адамса. Например, при использовании методов третьего порядка аппроксимации в соответствии с (18) для предсказания решения положим $$ frac<pmb^ — pmb^n> = frac (23 pmb^ -16pmb^ + 5pmb^). $$ Для уточнеия решения (см. (17)) используется схема $$ frac<pmb^ — pmb^n> = frac (9pmb^ + 19pmb^ — 5pmb^ + pmb^). $$ Аналогично строятся и другие классы многошаговых методов.

Видео:Сеточные методы решения дифференциальных уравнений в частных производных.Скачать

Сеточные методы решения дифференциальных уравнений в частных производных.

Жесткие системы ОДУ

При численном решении задачи Коши для систем обыкновенных дифференциальных уравнений (3), (4) могут возникнуть дополнительные трудности, порожденные жесткостью системы. Локальные особенности поведения решения в точке ( u = w ) передаются линейной системой $$ begin frac

= sum_^ frac (t, w) v + bar(t), quad t > 0. end $$

Пусть ( lambda_i(t) ), ( i = 1, 2, ldots, m ) — собственные числа матрицы $$ begin A(t) = < a_(t) >, quad a_(t) = frac(t, w). end $$ Система уравнений (3) является жесткой, если число $$ begin S(t) = frac <max_|Re lambda_i(t)|> <min_|Re lambda_i(t)|> end $$ велико. Это означает, что в решении присутствуют составляющие с сильно различающимися масштабами изменения по переменной ( t ).

Для численное решения жестких задач используются вычислительные алгоритмы, которые имеют повышенный запас устойчивости. Необходимо ориентироваться на использование ( A )-устойчивых или ( A(alpha) )-устойчивых методов.

Метод называется ( A )-устойчивым, если при решении задачи Коши для системы (3) область его устойчивости содержит угол $$ begin |arg(-mu)| —>

Видео:Линейное неоднородное дифференциальное уравнение второго порядка с постоянными коэффициентамиСкачать

Линейное неоднородное дифференциальное уравнение второго порядка с постоянными коэффициентами

Предиктор-корректор или модифицированный метод Эйлера для решения дифференциального уравнения

Для заданного дифференциального уравнения Метод предиктор корректор решения дифференциальных уравненийс начальным условием Метод предиктор корректор решения дифференциальных уравнений
найти приближенное решение, используя метод Predictor-Corrector.

Метод Предиктор-Корректор:
Метод предиктор-корректор также известен как метод Модифицированного Эйлера .
В методе Эйлера касательная рисуется в точке, а наклон рассчитывается для заданного размера шага. Таким образом, этот метод лучше всего работает с линейными функциями, но для других случаев остается ошибка усечения. Для решения этой проблемы введен модифицированный метод Эйлера. В этом методе вместо точки среднее арифметическое наклона за интервал Метод предиктор корректор решения дифференциальных уравненийиспользуется.

Таким образом, в методе Predictor-Corrector для каждого шага прогнозируемое значение Метод предиктор корректор решения дифференциальных уравненийсначала рассчитывается по методу Эйлера, а затем наклоны в точках Метод предиктор корректор решения дифференциальных уравненийи Метод предиктор корректор решения дифференциальных уравненийрассчитывается и среднее арифметическое этих склонов добавляются к Метод предиктор корректор решения дифференциальных уравненийрассчитать скорректированное значение Метод предиктор корректор решения дифференциальных уравнений,

  • Шаг — 1: сначала прогнозируется значение для шага (здесь t + 1): Метод предиктор корректор решения дифференциальных уравнений,
    здесь h — размер шага для каждого приращения
  • Шаг — 2: Затем прогнозируемое значение корректируется : Метод предиктор корректор решения дифференциальных уравнений
  • Шаг — 3: Увеличение сделано: Метод предиктор корректор решения дифференциальных уравнений
  • Шаг 4: Проверить продолжение, если Метод предиктор корректор решения дифференциальных уравненийзатем перейдите к шагу — 1.
  • Шаг 5: Завершить процесс.

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

    Примеры:

    The final value of y at x = 1 is y=2.18147

    Реализация: здесь мы рассматриваем дифференциальное уравнение: Метод предиктор корректор решения дифференциальных уравнений

    // C ++ код для решения дифференциального уравнения
    // используя метод Predictor-Corrector или Modified-Euler
    // с заданными условиями, y (0) = 0,5, размер шага (h) = 0,2
    // найти y (1)

    using namespace std;

    // рассмотрим дифференциальное уравнение
    // для заданных x и y возвращаем v

    double f( double x, double y)

    double v = y — 2 * x * x + 1;

    // предсказывает следующее значение для данного (x, y)
    // и размер шага h с использованием метода Эйлера

    double predict( double x, double y, double h)

    // возвращается значение следующего y (прогнозируемого)

    double y1p = y + h * f(x, y);

    // исправляет прогнозируемое значение
    // используя модифицированный метод Эйлера

    double correct( double x, double y,

    double x1, double y1,

    // (x, y) предыдущего шага

    // и x1 — увеличенный x для следующего шага

    // и у1 прогнозируется у для следующего шага

    double e = 0.00001;

    y1c = y + 0.5 * h * (f(x, y) + f(x1, y1));

    > while ( fabs (y1c — y1) > e);

    // каждая итерация корректирует значение

    // of y используя средний уклон

    void printFinalValues( double x, double xn,

    double y, double h)

    double x1 = x + h;

    double y1p = predict(x, y, h);

    double y1c = correct(x, y, x1, y1p, h);

    // на каждой итерации сначала значение

    // для следующего шага сначала прогнозируется

    // а затем исправлено.

    cout «The final value of y at x = «

    // здесь x и y являются начальными

    // заданное условие, поэтому x = 0 и y = 0.5

    double x = 0, y = 0.5;

    // конечное значение x, для которого требуется y

    printFinalValues(x, xn, y, h);

    // Java-код для решения дифференциала
    // уравнение с использованием Predictor-Corrector
    // или модифицированный метод Эйлера с
    // заданные условия, y (0) = 0,5, шаг
    // размер (h) = 0,2, чтобы найти y (1)

    // рассмотрим дифференциальное уравнение
    // для заданных x и y возвращаем v

    static double f( double x, double y)

    double v = y — 2 * x * x + 1 ;

    // предсказывает следующее значение для данного (x, y)
    // и размер шага h с использованием метода Эйлера

    static double predict( double x, double y, double h)

    // возвращается значение следующего y (прогнозируемого)

    double y1p = y + h * f(x, y);

    // исправляет прогнозируемое значение
    // используя модифицированный метод Эйлера

    static double correct( double x, double y,

    double x1, double y1,

    // (x, y) предыдущего шага

    // и x1 — увеличенный x для следующего шага

    // и у1 прогнозируется у для следующего шага

    double e = 0.00001 ;

    y1c = y + 0.5 * h * (f(x, y) + f(x1, y1));

    while (Math.abs(y1c — y1) > e);

    // каждая итерация корректирует значение

    // of y используя средний уклон

    static void printFinalValues( double x, double xn,

    double y, double h)

    double x1 = x + h;

    double y1p = predict(x, y, h);

    double y1c = correct(x, y, x1, y1p, h);

    // на каждой итерации сначала значение

    // для следующего шага сначала прогнозируется

    // а затем исправлено.

    DecimalFormat df = new DecimalFormat( «#.#####» );

    System.out.println( «The final value of y at x = » +

    x + » is : » +df.format(y));

    public static void main (String[] args)

    // здесь x и y являются начальными

    // заданное условие, поэтому x = 0 и y = 0.5

    double x = 0 , y = 0.5 ;

    // конечное значение x, для которого требуется y

    printFinalValues(x, xn, y, h);

    // Этот код предоставлен mits

    # Python3 код для решения дифференциального уравнения
    # с использованием метода Predictor-Corrector или Modified-Euler
    # с заданными условиями, y (0) = 0,5, размер шага (h) = 0,2
    # найти y (1)

    # рассмотрим дифференциальное уравнение
    # для заданных x и y, вернуть v

    v = y — 2 * x * x + 1 ;

    # предсказывает следующее значение для данного (x, y)
    # и размер шага h методом Эйлера

    def predict(x, y, h):

    # значение следующего y (прогнозируемого) возвращается

    y1p = y + h * f(x, y);

    # исправляет прогнозируемое значение
    # с использованием модифицированного метода Эйлера

    def correct(x, y, x1, y1, h):

    # (x, y) предыдущего шага

    # и x1 — увеличенный x для следующего шага

    # и y1 прогнозируется y для следующего шага

    while ( abs (y1c — y1) > e + 1 ):

    y1c = y + 0.5 * h * (f(x, y) + f(x1, y1));

    # каждая итерация корректирует значение

    # у, используя средний наклон

    def printFinalValues(x, xn, y, h):

    y1p = predict(x, y, h);

    y1c = correct(x, y, x1, y1p, h);

    # на каждой итерации сначала значение

    # для следующего шага сначала прогнозируется

    # а затем исправлено.

    print ( «The final value of y at x =» ,

    if __name__ = = ‘__main__’ :

    # здесь x и y являются начальными

    # заданное условие, поэтому x = 0 и y = 0.5

    # конечное значение x, для которого требуется y

    printFinalValues(x, xn, y, h);

    # Этот код предоставлен Rajput-Ji

    // C # код для решения дифференциала
    // уравнение с использованием Predictor-Corrector
    // или модифицированный метод Эйлера с
    // заданные условия, y (0) = 0,5, шаг
    // размер (h) = 0,2, чтобы найти y (1)

    // рассмотрим дифференциальное уравнение
    // для заданных x и y возвращаем v

    static double f( double x, double y)

    double v = y — 2 * x * x + 1;

    // предсказывает следующее значение для данного (x, y)
    // и размер шага h с использованием метода Эйлера

    static double predict( double x, double y, double h)

    // возвращается значение следующего y (прогнозируемого)

    double y1p = y + h * f(x, y);

    // исправляет прогнозируемое значение
    // используя модифицированный метод Эйлера

    static double correct( double x, double y,

    double x1, double y1,

    // (x, y) предыдущего шага

    // и x1 — увеличенный x для следующего шага

    // и у1 прогнозируется у для следующего шага

    double e = 0.00001;

    y1c = y + 0.5 * h * (f(x, y) + f(x1, y1));

    while (Math.Abs(y1c — y1) > e);

    // каждая итерация корректирует значение

    // of y используя средний уклон

    static void printFinalValues( double x, double xn,

    double y, double h)

    double x1 = x + h;

    double y1p = predict(x, y, h);

    double y1c = correct(x, y, x1, y1p, h);

    // на каждой итерации сначала значение

    // для следующего шага сначала прогнозируется

    // а затем исправлено.

    Console.WriteLine( «The final value of y at x = » +

    x + » is : » + Math.Round(y, 5));

    static void Main()

    // здесь x и y являются начальными

    // заданное условие, поэтому x = 0 и y = 0.5

    double x = 0, y = 0.5;

    // конечное значение x, для которого требуется y

    printFinalValues(x, xn, y, h);

    // Этот код предоставлен mits

    // PHP-код для решения дифференциального уравнения
    // используя Predictor-Corrector или Modified-Euler
    // метод с заданными условиями, y (0) = 0,5,
    // размер шага (h) = 0,2, чтобы найти y (1)

    // рассмотрим дифференциальное уравнение
    // для заданных x и y возвращаем v

    function f( $x , $y )

    $v = $y — 2 * $x * $x + 1;

    // предсказывает следующее значение для данного (x, y)
    // и размер шага h с использованием метода Эйлера

    function predict( $x , $y , $h )

    // возвращается значение следующего y (прогнозируемого)

    $y1p = $y + $h * f( $x , $y );

    // исправляет прогнозируемое значение
    // используя модифицированный метод Эйлера

    function correct( $x , $y , $x1 , $y1 , $h )

    // (x, y) предыдущего шага и

    // х1 — увеличенный х для следующего шага

    // и у1 прогнозируется у для следующего шага

    $y1c = $y + 0.5 * $h * (f( $x , $y ) +

    > while ( abs ( $y1c — $y1 ) > $e );

    // каждая итерация корректирует

    // значение y с использованием среднего наклона

    function printFinalValues( $x , $xn , $y , $h )

    $y1p = predict( $x , $y , $h );

    $y1c = correct( $x , $y , $x1 , $y1p , $h );

    // на каждой итерации сначала значение

    // для следующего шага сначала прогнозируется

    // а затем исправлено.

    echo «The final value of y at x = » . $x .

    » is : » . round ( $y , 5) . «n» ;

    // здесь x и y являются начальными

    // заданное условие, поэтому x = 0 и y = 0.5

    // конечное значение x, для которого требуется y

    printFinalValues( $x , $xn , $y , $h );

    // Этот код предоставлен mits
    ?>

    Видео:19. Метод вариации произвольных постоянных. Линейные неоднородные диф уравнения 2-го порядкаСкачать

    19. Метод вариации произвольных постоянных. Линейные неоднородные диф уравнения 2-го порядка

    Общая формулировка многошаговых методов

    Многошаговые методы

    Решения задачи коши

    9.1. Метод “предиктор-корректор” 2

    9.2. Общая формулировка многошаговых методов 4

    9.3. Устойчивость и сходимость разностных методов 7

    9.1. Метод “предиктор-корректор”

    В одношаговых методах значение yn+1 определяется лишь значениями tn, yn и значением шага приращения аргумента h. В многошаговых методах используется также информация в предыдущих точках yn-1, yn-2,

    Метод предиктор корректор решения дифференциальных уравнений

    Многошаговые методы строятся на равномерной сетке

    Метод предиктор корректор решения дифференциальных уравнений, где h – шаг сетки.

    Обозначим: Метод предиктор корректор решения дифференциальных уравнений, Метод предиктор корректор решения дифференциальных уравнений.

    Линейный m-шаговый метод можно описать формулой:

    Метод предиктор корректор решения дифференциальных уравнений. (9.1)

    Многошаговые методы не являются самостартующими. Для использования m-шагового метода необходимо предварительно задать m предыдущих значений y. Однако после того как многошаговый метод стартует, он работает быстрее, чем одношаговый. Например, при использовании метода Рунге-Кутта-Фельберга на каждом шаге приращения аргумента требуется шесть раз вычислять правую часть дифференциального уравнения Метод предиктор корректор решения дифференциальных уравнений. В то же время при использовании многошагового метода на каждом шаге приращения вычисляется только одно новое значение правой части.

    Еще одним ограничением использования многошаговых методов является наличие равномерной сетки. Однако это ограничение легко преодолевается, например, с помощью интерполяции.

    Многошаговые методы используются при решении жестких уравнений.

    Порядок многошагового метода может выбираться автоматически и динамически изменяться.

    Если Метод предиктор корректор решения дифференциальных уравнений, то многошаговый метод называется явным.

    Если Метод предиктор корректор решения дифференциальных уравнений, то метод является неявным, т.к. в случае невырожденного дифференциального уравнения fn+1 зависит от yn+1. Следовательно, на каждом шаге приращения аргумента необходимо решать уравнение относительно yn+1. Трудности, возникающие при использовании неявных методов, компенсируются тем, что эти методы являются более точными и более устойчивыми.

    Частным случаем многошаговых методов являются методы Адамса:

    Метод предиктор корректор решения дифференциальных уравнений(9.2)

    Методы Адамса также могут быть явными и неявными.

    Трудности использования неявной формулы преодолевается в методе Предиктор–Корректор. В этом методе значение неизвестной функции в каждой точке сетки вычисляется дважды. Сначала вычисляется новое значение неизвестной функции Метод предиктор корректор решения дифференциальных уравненийс помощью менее точной явной формулы – формулы предиктор. Затем это значение уточняется с помощью неявной формулы – формулы корректор; при этом для вычисления величины Метод предиктор корректор решения дифференциальных уравненийиспользуется найденное значение Метод предиктор корректор решения дифференциальных уравнений

    Простейшим примером метода Предиктор–Корректор является второй модифицированный метод Эйлера, который можно описать с помощью последовательности формул:

    Метод предиктор корректор решения дифференциальных уравнений– предиктор,

    Метод предиктор корректор решения дифференциальных уравнений– корректор.

    Метод Эйлера является одношаговым методом. Для построения многошаговых методов вновь используем утверждение: решение задачи Коши эквивалентно решению интегрального уравнения

    Метод предиктор корректор решения дифференциальных уравнений. (9.3)

    Для приближенного решения задачи Коши аппроксимируем подынтегральную функцию в формуле (9.3) с помощью интерполяционного многочлена. Интерполяционный многочлен Ньютона степени m для интерполирования назад от точки xn можно записать следующим образом

    Метод предиктор корректор решения дифференциальных уравнений. (9.4)

    В формуле (9.4) Метод предиктор корректор решения дифференциальных уравнений, а Метод предиктор корректор решения дифференциальных уравненийобозначает конечную разность порядка k, отсчитываемую от точки xi:

    Метод предиктор корректор решения дифференциальных уравнений, Метод предиктор корректор решения дифференциальных уравнений. (9.5)

    Метод предиктор корректор решения дифференциальных уравнений(9.6)

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

    Для вывода формулы предиктор вычислим интеграл (9.6) на отрезке экстраполяции Метод предиктор корректор решения дифференциальных уравнений. После замены переменной интегрирования получим

    Метод предиктор корректор решения дифференциальных уравнений(9.7)

    и Метод предиктор корректор решения дифференциальных уравнений.

    Подставив найденное значение интеграла в формулу (9.3), получим экстраполяционную формулу – формулу предиктор:

    Метод предиктор корректор решения дифференциальных уравнений(9.8)

    При выводе формулы корректор используем многочлен Ньютона для интерполирования от точки xn+1. Соответственно, в формуле (9.7) все индексы нужно увеличить на 1, а пределы интегрирования изменить на Метод предиктор корректор решения дифференциальных уравнений:

    Метод предиктор корректор решения дифференциальных уравнений(9.9)

    Метод предиктор корректор решения дифференциальных уравнений

    Подставив найденное значение интеграла в формулу (9.3), получим интерполяционную формулу – формулу корректор:

    Метод предиктор корректор решения дифференциальных уравнений(9.10)

    С помощью двухшагового метода предиктор-корректор найдем решение начальной задачи:

    Метод предиктор корректор решения дифференциальных уравнений

    Точное решение представляет собой экспоненту Метод предиктор корректор решения дифференциальных уравнений.

    Выберем шаг приращения Метод предиктор корректор решения дифференциальных уравнений.

    Начальное условие: Метод предиктор корректор решения дифференциальных уравнений.

    Дополнительное условие: Метод предиктор корректор решения дифференциальных уравнений.

    С помощью формул (9.8) и (9.10) вычислим значение Метод предиктор корректор решения дифференциальных уравнений.

    По формуле предиктор получаем: Метод предиктор корректор решения дифференциальных уравнений.

    По формуле корректор уточняем решение: Метод предиктор корректор решения дифференциальных уравнений.

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

    Метод предиктор корректор решения дифференциальных уравнений.

    На практике обычно применяется четырехшаговый метод Адамса. Найдем формулы для четырехшагового метода. Повторяем весь ход рассуждений, использованных при выводе формул 2-шагового метода, но в отличие от предыдущего используем теперь многочлен Ньютона третьей степени.

    Вывод формулы предиктор.

    Метод предиктор корректор решения дифференциальных уравнений

    Метод предиктор корректор решения дифференциальных уравнений

    Подставив найденное значение интеграла в формулу (9.3), получим с учетом выражений (9.5) для конечных разностей формулу предиктор – формулу Адамса-Башфорта (Adams-Bashforth):

    Метод предиктор корректор решения дифференциальных уравнений(9.11)

    Вывод формулы корректор.

    Метод предиктор корректор решения дифференциальных уравнений

    Метод предиктор корректор решения дифференциальных уравнений

    Аналогично предыдущему с учетом (9.3) и (9.5) получим формулу корректор – формулу Адамса-Мультона (Adams-Moulton):

    Метод предиктор корректор решения дифференциальных уравнений(9.12)

    Общая формулировка многошаговых методов

    Для решения задачи Коши

    Метод предиктор корректор решения дифференциальных уравнений(9.13)

    введем сетку с постоянным шагом Метод предиктор корректор решения дифференциальных уравненийи сеточные функции:

    Метод предиктор корректор решения дифференциальных уравнений– точное решение задачи Коши;

    Метод предиктор корректор решения дифференциальных уравнений– приближенное решение;

    Метод предиктор корректор решения дифференциальных уравнений.

    Линейным m-шаговым разностным методом называется система разностных уравнений

    Метод предиктор корректор решения дифференциальных уравнений, (9.14)

    где Метод предиктор корректор решения дифференциальных уравнений– числовые коэффициенты, независящие от n, причем Метод предиктор корректор решения дифференциальных уравнений.

    Уравнение (9.14) представляет собой рекуррентное соотношение, выражающее новое значение Метод предиктор корректор решения дифференциальных уравненийчерез найденные ранее значения Метод предиктор корректор решения дифференциальных уравнений.

    Заметим, что коэффициенты уравнения (9.14) определены с точностью до множителя. Для устранения неоднозначности будем считать, что выполнено условие нормировки

    Метод предиктор корректор решения дифференциальных уравнений(9.15)

    Метод называется явным, если Метод предиктор корректор решения дифференциальных уравнений.

    Если Метод предиктор корректор решения дифференциальных уравнений, то метод называется неявным. В этом случае для нахождения Метод предиктор корректор решения дифференциальных уравненийприходится решать нелинейное уравнение

    Метод предиктор корректор решения дифференциальных уравнений.

    Это уравнение можно решить методом Ньютона, в качестве начального приближения взяв Метод предиктор корректор решения дифференциальных уравнений.

    Погрешностью аппроксимации на решении или невязкой разностного метода (9.14) называется функция

    Метод предиктор корректор решения дифференциальных уравнений(9.16)

    Функция невязки получается в результате подстановки точного решения дифференциального уравнения в разностное уравнение (9.14).

    Метод предиктор корректор решения дифференциальных уравнений

    Метод предиктор корректор решения дифференциальных уравнений

    Подставим эти разложения в формулу для невязки

    Метод предиктор корректор решения дифференциальных уравнений

    Изменим порядок суммирования. При этом во второй сумме будем суммировать по индексу i от 1 до p, соответственно уменьшив всюду индекс i на единицу.

    Метод предиктор корректор решения дифференциальных уравнений

    Объединим суммы, выделив в первой сумме отдельно слагаемое с j=0.

    Метод предиктор корректор решения дифференциальных уравнений

    Отсюда следует, что погрешность метода будет иметь порядок p, если выполнены условия:

    Метод предиктор корректор решения дифференциальных уравненийи Метод предиктор корректор решения дифференциальных уравненийпри Метод предиктор корректор решения дифференциальных уравнений(9.17)

    Заметим что, если в системе (9.17) отбросить последние s уравнений, то порядок метода понизится на s.

    Итак, получили систему уравнений для коэффициентов ak, bk. К этим уравнениям нужно добавить еще условие нормировки (9.15): Метод предиктор корректор решения дифференциальных уравнений. Получаем, таким образом p+2 уравнений. Чтобы система уравнений не была переопределена, нужно, чтобы количество уравнений не превышало количество неизвестных.

    Для неявного метода имеем 2m+2 неизвестных: Метод предиктор корректор решения дифференциальных уравнений. Должно быть:

    Метод предиктор корректор решения дифференциальных уравнений

    – для неявного метода порядок аппроксимации не превышает 2m.

    Для явного метода имеем 2m+1 неизвестных: Метод предиктор корректор решения дифференциальных уравнений. Следовательно Метод предиктор корректор решения дифференциальных уравненийи порядок аппроксимации не превышает 2m-1.

    Преобразуем систему уравнений для коэффициентов ak, bk. С учетом условия нормировки уравнение Метод предиктор корректор решения дифференциальных уравненийпри Метод предиктор корректор решения дифференциальных уравненийможно переписать в виде Метод предиктор корректор решения дифференциальных уравнений. Учтем также, что коэффициент a0 входит только в одно уравнение, так что разрешим это уравнение относительно a0.

    Окончательно получаем систему уравнений для коэффициентов линейного m-шагового разностного метода общего вида:

    Метод предиктор корректор решения дифференциальных уравнений(9.18)

    На практике часто используются методы Адамса, которые описываются формулой

    Метод предиктор корректор решения дифференциальных уравнений(9.19)

    Для методов Адамса в системе (9.18) остаются только уравнения, определяющие коэффициенты bk.

    Метод предиктор корректор решения дифференциальных уравнений(условие нормировки) и уравнения: Метод предиктор корректор решения дифференциальных уравнений(9.20)

    Имеем p уравнений. В случае неявного метода Адамса имеется m+1 неизвестных: Метод предиктор корректор решения дифференциальных уравнений. Следовательно, наивысший порядок неявного метода равен p=m+1. В случае явного метода имеем m неизвестных, следовательно, максимальный порядок явного метода Адамса равен p=m.

    Рассмотрим варианты двухшаговых методов m=2. Максимальный порядок двухшагового метода равен p=4, так что можно написать следующую систему уравнений.

    Метод предиктор корректор решения дифференциальных уравнений

    Ограничившись первыми четырьмя уравнениями этой системы, можно построить методы 2-го порядка. Если использовать пять уравнений, получим методы 3-го порядка. Система из шести уравнений определяет единственный двухшаговый метод 4-го порядка.

    Варианты методов второго порядка.

    1) Положим Метод предиктор корректор решения дифференциальных уравнений, тогда Метод предиктор корректор решения дифференциальных уравнений. Получаем явный метод Адамса: Метод предиктор корректор решения дифференциальных уравнений.

    2) Положив Метод предиктор корректор решения дифференциальных уравнений, получим метод Милна: Метод предиктор корректор решения дифференциальных уравнений.

    3) Положив Метод предиктор корректор решения дифференциальных уравнений, построим неявный метод: Метод предиктор корректор решения дифференциальных уравнений.

    Варианты методов третьего порядка.

    1) Положив Метод предиктор корректор решения дифференциальных уравнений, получим явный метод Метод предиктор корректор решения дифференциальных уравнений.

    2) Если выбрать Метод предиктор корректор решения дифференциальных уравнений, построим неявный метод Метод предиктор корректор решения дифференциальных уравнений.

    3) Выбрав Метод предиктор корректор решения дифференциальных уравнений, получим неявный метод Адамса Метод предиктор корректор решения дифференциальных уравнений.

    Метод четвертого порядка получим, используя все шесть уравнений:

    Метод предиктор корректор решения дифференциальных уравнений

    Метод предиктор корректор решения дифференциальных уравненийПостроим трехшаговые методы Адамса.

    Явный трехшаговый метод имеет порядок p=3. В соответствии с формулами (9.20) для нахождения коэффициентов bk имеем систему уравнений, включающую условие нормировки и еще два уравнения для двух значений i: Метод предиктор корректор решения дифференциальных уравнений.

    Метод предиктор корректор решения дифференциальных уравнений

    Метод предиктор корректор решения дифференциальных уравненийРешение этой системы в среде Mathcad приведено на рис. 9.1. Здесь M – матрица системы, C – столбец свободных коэффициентов. Функция lsolve находит решение системы линейных алгебраических уравнений. Вектор B включает найденное решение. Чтобы получить точные значения найденных коэффициентов используем знак аналитических вычислений (стрелка). Получаем явный трехшаговый метод Адамса третьего порядка:

    Метод предиктор корректор решения дифференциальных уравнений

    Неявный метод имеет четвертый порядок, и для коэффициентов Метод предиктор корректор решения дифференциальных уравненийимеем систему из трех уравнений, где i принимает значения 2, 3 и 4. Значение b0 определяем из условия нормировки. Решение в системе Mathcad приведено на рис. 9.2. Получаем вновь формулу Адамса-Мультона, которая ранее была найдена путем непосредственного вычисления интеграла от интерполяционного многочлена Ньютона (9.12):

    Метод предиктор корректор решения дифференциальных уравнений

    Метод предиктор корректор решения дифференциальных уравнений

    Пример 9.4. На рис. 9.3 приведено решение системы уравнений для коэффициентов явного и неявного четырехшаговых методов Адамса. Решение аналогично решению в примере 9.2 для трехшаговых методов. Обозначения M, C и B относятся к явному методу; обозначения MI, CI, BI и bI0 используются для описания неявного метода. Получаем в итоге:

    • явный метод четвертого порядка (формула Адамса-Башфорта)

    Метод предиктор корректор решения дифференциальных уравнений;

    • неявный метод пятого порядка

    Метод предиктор корректор решения дифференциальных уравнений.

    🎥 Видео

    16. Линейные неоднородные дифференциальные уравнения 2-го порядка с постоянными коэффициентамиСкачать

    16. Линейные неоднородные дифференциальные уравнения 2-го порядка с постоянными коэффициентами

    Решение ДУ.Операционный методСкачать

    Решение ДУ.Операционный метод

    Видеоурок "Нахождение частных решений по виду правой части"Скачать

    Видеоурок "Нахождение частных решений по виду правой части"

    Практика 1 ИзоклиныСкачать

    Практика 1  Изоклины

    9. Метод вариации произвольной постоянной ( метод Лагранжа ). Линейные дифференциальные уравнения.Скачать

    9. Метод вариации произвольной постоянной ( метод Лагранжа ). Линейные дифференциальные уравнения.

    3_05. Многошаговые алгоритмы решения ОДУСкачать

    3_05. Многошаговые алгоритмы решения ОДУ

    13. Как решить дифференциальное уравнение первого порядка?Скачать

    13. Как решить дифференциальное уравнение первого порядка?
  • Поделиться или сохранить к себе: