Курсовая работа: Рішення систем диференціальних рівнянь за допомогою неявної схеми Адамса 3-го порядку
(2.22)
Схема двох крокова, тому необхідно спершу знайти й за схемою предиктор-коректор 4-го порядку, після чого , , … обчислюють по формулі (2.22).
3. Опис використовуваного методу
Для рішення системи диференціальних рівнянь обрана неявна схема Адамса 3-го порядки, як одна з найбільш точних схем для рішення задачі Коші. Щоб прийти до неявної схеми Адамса, замінимо вираження в рівнянні:
(3.1)
інтерполяційним багаточленом Ньютона 2-го порядки, виду:
(3.2)
Після інтегрування отриманого вираження на інтервалі , приходимо до рівняння неявної схеми Адамса 3-го порядки:
. (3.3)
Дана схема не дозволена явно відносно , тому спочатку необхідно обчислити будь-яким підходящим методом, наприклад методом Рунге-Кутта четвертого порядку. Потім для знаходження потрібно використовувати метод простої ітерації:
, (3.4)
де s=1,2,3,… – номер ітерації. Умова виходу із циклу ітераційної процедури:
, (3.5)
де? – задана погрішність.
Початкове наближення задається формулою для явної схеми Адамса 2-го порядки:
. (3.6)
Схема стійка, сходиться швидко. Найчастіше досить однієї ітерації. Порядок погрішності? (h) неявної схеми Адамса третього порядку дорівнює чотирьом.
4. Опис блок-схеми алгоритму
При розробці програми були побудовані блок-схеми алгоритму програми, що спрощують процес проектування й полегшують розуміння вихідного коду готової програми (див. Додаток 1).
Блок-схема алгоритму умовно розбита на 11 блоків.
Головна функція програми відповідає за обробку події створення форми, взаємодія зі стандартним компонентом Tсhart, а також за реалізацію рішення системи диференціальних рівнянь неявною схемою Адамса 3-го порядки. Блок-схема алгоритму рішення задачі Коші розбитий умовно на 35 блоків:
1-й блок відповідає за ручне уведення інтервалу [a, b], на якому шукається рішення системи; кількості кроків сітки nx; крок висновку результатів на екран np; рядків u1 і v1, що відповідають рівнянням системи; значення шуканих функцій на початку заданого інтервалу; припустима погрішність e.
У другому блоці відбувається обчислення кроку h і установка поточного вузла на x=a. Блок 3 – функція перетворення вихідних записів рівнянь системи в рівносильні їм рядка з формою записом математичних операцій (див. далі «алгоритм зворотного польського запису»). Як аргументи функції виступають уведені раніше рядка u1 і v1.
Блоки 4–15 – розрахунок перших 2-х крапок заданої сітки методом Рунге-Кутта 4-го порядку. У даних блоках і далі використовується користувальницька функція FPR, що розраховує значення рівнянь, що вводяться користувачем, у вузлах заданої сітки. Як аргументи функції виступають: уже перетворені у зворотний польський запис рядка, що задають рівняння системи; поточне значення x; значення шуканих функцій на попередньому кроці (умовно позначаємо ).
У блоках 16–34 у циклі (16) розраховуються значення шуканих рішень у вузлах 2-nx заданої сітки неявною схемою Адамса 3-го порядки. Цикл 21–29 здійснює ітераційну процедуру неявної схеми. Умова виходу із цього циклу – виконання нерівності de<e, де de – найбільший з модулів , e – задана точність. Оскільки на екран виводяться значення шуканих функцій не у всіх вузлах, а тільки у вузлах з номером, кратним кроку висновку nx, що вводиться із клавіатури, то блоки 33–34 здійснюють вибір цих вузлів.
Перетворення у зворотний польський запис відбувається за наступними правилами:
Розглядаємо по черзі кожний символ:
1. Якщо цей символ – число (або змінна), то просто поміщаємо його у вихідний рядок.
2. Якщо символ – знак операції (+, -, *, /,^), то перевіряємо пріоритет даної операції. Операція піднесення в ступінь має найвищий пріоритет (дорівнює 4). Операції додавання й вирахування мають менший пріоритет (дорівнює 2). Найменший пріоритет (дорівнює 1) має відкриваюча дужка.