Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/25: Рейтинг темы: голосов - 25, средняя оценка - 4.72
2 / 2 / 0
Регистрация: 22.11.2013
Сообщений: 101

Метод Рунге-Кутта для системы из 5 уравнений

26.09.2016, 17:18. Показов 5241. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно написать программу для решения системы дифуров. Задано 5 уравнений, необходимо вывести таблицу значений х1...х5 в зависимости от t. Подскажите, пожалуйста, как правильно записать формулы для расчетов всех значений х1...х5? Вот что получилось, но расчет производится только для х1...
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
#include <iostream>
#include <cmath>
 
using namespace std;
 
double f1(double x1, double x2,double x3,double x4) 
{
    return 0.1*x1+0.7*x3-1.5*x1+0.1*x4;               
}
 
double f2(double x1, double x2,double x3) 
{
    return 2*x1-3*x2+4*x3;               
} 
double f3(double x1, double x2,double x3,double x5) 
{
    return 0.4*x5+0.3*x1+0.2*x2-2*x3;               
} 
double f4(double x1,double x2, double x3,double x4,double x5) 
{
    return 2*x2+x3-3*x4;               
} 
double f5(double x1,x2,x3,x5)
{return 0.02*x1+1.1*x2+0.5*x3-0.4*x5;
}
int main()
{
   
 
    double h = 0.1;     
 
    double x1 = 1.0;
    double x2 = 0.0;
    double x3=0.0;
    double x4=0.0;
    double t  = 0.0;
while (t <= 4.0)
    {
    double k1 =  h*f1(t,x1,x2,x3,x4);
double k2 =  h*f1(t+h/2,x1+k1/2,x2+k1/2,x3+k1/2,x4+k1/2);
double k3 =  h*f1(t+h/2,x1+k2/2,x2+k2/2,x3+k2/2,x4+k2/2);
double k4 =  h*f1(t+h,x1+k3,x2+k3,x3+k3,x4+k4);
x1 += (k1+2*k2+2*k3+k4)/6;
  t += h;}
 
}
Миниатюры
Метод Рунге-Кутта для системы из 5 уравнений  
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
26.09.2016, 17:18
Ответы с готовыми решениями:

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

Метод Рунге-Кутта для системы уравнений
Написал метод рунге-кутта для динамо риккитаке, но проблема в том, что данные мне формулы не зависят от (т) и я не знаю куда ставить шаг,...

Метод Рунге-Кутта 4 порядка для решения системы дифференциальных уравнений
Имеется код программы, но по не очевидным для меня причинам работает не корректно, во время отладки выдает сообщения типа : Run-Time...

2
2 / 2 / 0
Регистрация: 22.11.2013
Сообщений: 101
27.09.2016, 12:57  [ТС]
0
 Аватар для _SayHello
874 / 535 / 175
Регистрация: 30.07.2015
Сообщений: 1,739
27.09.2016, 14:23
Лучший ответ Сообщение было отмечено Линда95 как решение

Решение

Линда95, у себя код не проверял, но так в глаза бросается:
C++
1
2
3
double f5(double x1,x2,x3,x5)
{return 0.02*x1+1.1*x2+0.5*x3-0.4*x5;
}
тип к каждому аргументу приписывается
и
C++
1
double k1 =  h*f1(t,x1,x2,x3,x4);
В функцию загоняете 5 аргументов, а в объявлении функции делаете только 4
C++
1
2
3
4
double f1(double x1, double x2,double x3,double x4) 
{
    return 0.1*x1+0.7*x3-1.5*x1+0.1*x4;               
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.09.2016, 14:23
Помогаю со студенческими работами здесь

Функция для численного интегрирования системы дифференциальных уравнений методом Рунге - Кутта
Доброго времени суток. У меня есть вот такая задачка: Разработать функцию для численного интегрирования системы дифференциальных...

Метод Рунге Кутты для системы уравнений
Добрый день! Столкнулся с проблемой, при решении задачи, а именно : Реализовать решение системы оду с количеством уравнений N,...

Численное интегрирование системы дифференциальных уравнений методом Рунге - Кутта
Доброго времени суток. Пытаюсь разработать функцию для численного интегрирования систем дифференциальных уравнений методом Рунге-Кутта. При...

Решение уравнений методами Рунге-Кутта и Эйлера
Решить уравнение при помощи методов Эйлера и Рунге Кутта, описывающее смещение x электрона в атоме под действием электрического поля...

метод Рунге-Кутта
Всем доброго времени суток, меня интересует, пользуясь методом Рунге -Кута для диф уравнений, я получу в ответе точки, графика диф...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! в-строка - входное арифметическое выражение в инфиксной(обычной). . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru