Форум программистов, компьютерный форум, киберфорум
Численные методы
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/40: Рейтинг темы: голосов - 40, средняя оценка - 4.75
0 / 0 / 2
Регистрация: 06.02.2015
Сообщений: 67

Метод Рунге-Кутты для дифференциального уравнения второго порядка

28.04.2018, 22:04. Показов 7429. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дано уравнение y''+y'-2y=cos(x)-3sin(x), решить методом Рунге-Кутты. Данные сильно отличаются от аналитического решения, начальные условия y(0)=1, y'(0)=2. Правильно ли составлены формулы?
f(x,y,z) = z;
g(x,y,z) = -z+2*y+cos(x)-3*sin(x);

K1[i] = h * f(x[i], y[i], z[i]);
L1[i] = h * g(x[i], y[i], z[i]);

K2[i] = h * f(x[i]+0.5*h, y[i]+0.5*K1[i], z[i]+0.5*L1[i]);
L2[i] = h * g(x[i]+0.5*h, y[i]+0.5*K1[i], z[i]+0.5*L1[i]);

K3[i] = h * f(x[i]+0.5*h, y[i]+0.5*K2[i], z[i]+0.5*L2[i]);
L3[i] = h * g(x[i]+0.5*h, y[i]+0.5*K2[i], z[i]+0.5*L2[i]);

K4[i] = h * f(x[i]+h, y[i]+K3[i], z[i]+L3[i]);
L4[i] = h * g(x[i]+h, y[i]+K3[i], z[i]+L3[i]);

deltay[i] = (K1[i] + K2[i] + K3[i] + K4[i]) / 6;
deltaz[i] = (L1[i] + L2[i] + L3[i] + L4[i]) / 6;

y[i+1] = y[i] + deltay[i];
z[i+1] = z[i] + deltaz[i];
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.04.2018, 22:04
Ответы с готовыми решениями:

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

Метод Рунге-Кутты 3 порядка
Помогите найти литературу по данному методу пожалуйста, хотя бы формулы. Применить метод я сам в силах, а вот найти что то не могу. 4-й...

Как применять методы Рунге-Кутты к задачам Коши второго порядка
Откуда брать значение первой производной на каждом шаге? На первом шаге понятно-оно будет дано, а потом?

5
Эксперт по математике/физике
11079 / 7379 / 3991
Регистрация: 14.01.2014
Сообщений: 16,813
28.04.2018, 22:07
Лучший ответ Сообщение было отмечено Milipops как решение

Решение

В знаменателях должно быть 4, а не 6
1
0 / 0 / 2
Регистрация: 06.02.2015
Сообщений: 67
28.04.2018, 22:39  [ТС]
mathidiot, спасибо большое

Добавлено через 5 минут
mathidiot, а от чего зависит этот знаменатель? или я неправильные формулы нашел?
0
Эксперт по математике/физике
11079 / 7379 / 3991
Регистрация: 14.01.2014
Сообщений: 16,813
28.04.2018, 22:43
От числа слагаемых зависит. Причем, если слагаемые берутся с различными весами, то в знаменателе должна быть сумма всех этих весов.
1
 Аватар для palva
4278 / 2970 / 693
Регистрация: 08.06.2007
Сообщений: 9,930
Записей в блоге: 5
28.04.2018, 23:08
Лучший ответ Сообщение было отмечено Milipops как решение

Решение

Формулы немного отличаются друг от друга. Их надо правильно переписать. Посмотрите, возможно у вас ошибка не в знаменателе а в коэффициентах. Может быть вы как раз веса и пропустили.
deltay[i] = (K1[i] + 2*K2[i] + 2*K3[i] + K4[i]) / 6;
deltaz[i] = (L1[i] + 2*L2[i] + 2*L3[i] + L4[i]) / 6;

Добавлено через 6 минут
Вот у меня тут два варианта формул из одной рабочей программы. Но это была одномерная задача.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
// Метод Рунге-Кутты 4 порядка 2 варианта формул из книги Ланса с.74
// Одномерный вариант
double rk4_1(double xn, double yn, double h, double (*f)(double x, double y)) {
    double k1,k2,k3,k4,yn1;
    k1=h*f(xn, yn);
    k2=h*f(xn+0.5*h, yn+0.5*k1);
    k3=h*f(xn+0.5*h, yn+0.5*k2);
    k4=h*f(xn+h, yn+k3);
    yn1=yn+(1.0/6.0)*(k1+2.0*k2+2.0*k3+k4);
    return yn1;
}
 
double rk4_2(double xn, double yn, double h, double (*f)(double x, double y)) {
    double k1,k2,k3,k4,yn1;
    k1=h*f(xn, yn);
    k2=h*f(xn+0.5*h, yn+0.5*k1);
    k3=h*f(xn+0.5*h, yn-0.5*k1+k2);
    k4=h*f(xn+h, yn+0.5*k2+0.5*k3);
    yn1=yn+(1.0/6.0)*(k1+3.0*k2+k3+k4);
    return yn1;
}
1
0 / 0 / 2
Регистрация: 06.02.2015
Сообщений: 67
29.04.2018, 00:26  [ТС]
palva, да, действительно пропустил двойки, извиняюсь за свою невнимательность
palva, спасибо большое за помощь
Миниатюры
Метод Рунге-Кутты для дифференциального уравнения второго порядка  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.04.2018, 00:26
Помогаю со студенческими работами здесь

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

Метод Рунге-Кутта-Фельберга для уравнения 2 порядка
Товарищи, прошу помощи, было дано задание - реализовать на маткад метод РКФ для уравнения 2 порядка с саморегулирующимся шагом. Собственно...

Неявный метод Рунге-Кутты или неявный метод Эйлера(1-го порядка)
Помогите примерами для курсовой на тему Неявный метод Рунге-Кутты

Метод Эйлера для уравнения второго порядка
Здравствуйте. Есть уравнение вида y''=f(y, y') которое необходимо решить методом Эйлера. На ум приходит понижение порядка...

Метод Рунге -Кутта второго порядка
Мне немного не понятен метод Рунге-Кутта второго порядка и не могу решить одну задачу. все описано в этом архиве в файле ссылка удалена ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru