Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.87/162: Рейтинг темы: голосов - 162, средняя оценка - 4.87
0 / 0 / 0
Регистрация: 22.04.2018
Сообщений: 5

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

24.04.2018, 23:09. Показов 33303. Ответов 25
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите составить программу в С++: Используя метод конечных разностей, найти решение краевой задаxи с шагом h=0,1

y''-2 y'/x -0.4y=1.5
y'(0.9)=1.5
-y'(0.6)=0.6
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.04.2018, 23:09
Ответы с готовыми решениями:

Методом конечных разностей найти решение краевой задачи
Методом конечных разностей найти решение краевой задачи y''-7*x*y'-y=5*x^2 u(0)-u'(0)=0; u(1)=1 Да да можете не говорить про гугление...

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

Решение краевой задачи нелинейного дифференциального уравнения второго порядка методом конечных разностей
помогите пожалуйста с решением уравнения y''-y*y'-y^2=0 граничные условия y(1)=0 y'(0)=1 шаг h=0.2

25
0 / 0 / 0
Регистрация: 17.05.2019
Сообщений: 2
17.05.2019, 16:28
Студворк — интернет-сервис помощи студентам
slava_psk,
Да, ошиблась

Добавлено через 1 минуту
Да. Ошиблась
Программу нужно сделать методом прогона
0
694 / 491 / 251
Регистрация: 10.06.2016
Сообщений: 2,372
17.05.2019, 18:26
Пишите.
0
0 / 0 / 0
Регистрация: 03.12.2017
Сообщений: 81
26.02.2020, 15:19
Помогите с краевой задачей.Спасибо.
0
-2 / 0 / 0
Регистрация: 01.03.2020
Сообщений: 198
17.01.2021, 23:37
slava_psk, а как сделать метод прогонки с этим самым заданием?
0
0 / 0 / 0
Регистрация: 09.03.2020
Сообщений: 10
01.05.2022, 13:50
Подниму тему, собственно вот условия (изображения 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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
#include <cstdlib> 
#include <iostream> 
#include <string>
using namespace std;
 
double c1, c2, h, tmp;
int n = 100, i, j, l, k;
double a[100][100];
double b[100], y[100], x[100];
double xbeg, xend;
void gauss();
double f(double);
double p(double);
double q(double);
int main()
{
    setlocale(0, "");
    n=11;
 
    xbeg=-1;
    xend=1;
    h = 0.2;
 
    for (i = 0; i < n; i++)
    {
        b[i] = 0;
        y[i] = 0;
        x[i] = xbeg + i * h;
    }
 
    //Инициализация двумерного динамического массива
    for (i = 0; i < 100; i++)
        for (j = 0; j < i + 1; j++) {
            a[i][j] = 0;
        }
    //Граничные условия
    c1 = -3;
    c2 = 2.5;
    // Правые части системы
    for (i = 0; i < n - 2; i++)
        b[i] = f(x[i]);
    //Граничные условия
    b[n - 2] = c1;
    b[n - 1] = c2;
    // Коэффициенты системы
    for (i = 0; i <= n - 3; i++)
    {
        a[i][i] = 1 / (h * h);
        a[i][i + 1] = -(2 / (h * h) + 2 * p(x[i]) / h - q(x[i]));
        a[i][i + 2] = 1 / (h * h) + 2 * p(x[i]) / h;
    }
    //Граничный условия
    a[n - 2][0] = 1;
    a[n - 1][n - 1] = 1;
    gauss();
    for (i = 0; i < n; i++)
        cout << "x(" << i << ")= " << x[i] << "  " << "y(" << i << ")=" << y[i] << endl;
    //Проверка решения на граничные условия
    cout << "Проверка решения на граничные условия" << endl;
    cout << y[0] << " " << y[n - 1] << endl;
    system("pause"); 
}
void gauss()
{
    //Прямой проход
    for (k = 0; k <= n - 2; k++)
    {
        for (i = k + 1; i <= n - 1; i++)
        {
            tmp = a[i][k];
            b[i] = b[i] - b[k] * tmp / a[k][k];
            for (j = 0; j <= n - 1; j++)
                a[i][j] = a[i][j] - a[k][j] * tmp / a[k][k];
        }
    }
    //Обратный проход
    y[n - 1] = b[n - 1] / a[n - 1][n - 1];
    for (i = n - 2; i >= 0; i = i - 1)
    {
        y[i] = b[i];
        for (j = i + 1; j <= n - 1; j++)
            y[i] = y[i] - a[i][j] * y[j];
        y[i] = y[i] / a[i][i];
    }
}
 
double f(double x)
{
    x = 2.5 * pow(x, 2) + (-3)*x;
    return x;
}
 
double p(double x)
{
    x = 2.5 * pow(x, 3)+ 3;
    return x;
}
 
double q(double x)
{
    x = (-3)*x + 2.5;
    return x;
}

Подскажите правильно ли я изменил?
Миниатюры
Решение краевой задачи для линейного дифференциального уравнения второго порядка методом конечных разностей  
0
0 / 0 / 0
Регистрация: 09.03.2020
Сообщений: 10
01.05.2022, 14:08
upd Ошибку нашел
c1 = -4;
c2 = -0.6;
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.05.2022, 14:08

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

Решение первой краевой задачи для уравнения теплопроводности методом конечных разностей
Здравствуйте помогите пожалуйста решить задачу, используя программный фрагмент Mathcad. Для примера есть задача на С++ У меня...

Численное решение линейной краевой задачи для обыкновенного дифференциального уравнения второго порядка
Добрый день! Дано задание: Вычислить установившееся распределение концентрации газа в одномерной системе из краевой задачи (условие...

Решение задачи Коши для дифференциального уравнения второго порядка
решить задачу Коши для дифференциального уравнения второго порядка y''+4y'+4y=32xe^2x, y(0)=-1, y'(0)=1 Помогите)

Найти общее решение линейного дифференциального уравнения второго порядка 1
Найти общее решение линейного дифференциального уравнения второго порядка {y}^{''}+6{y}^{'}+9y=0


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

Или воспользуйтесь поиском по форуму:
26
Ответ Создать тему
Новые блоги и статьи
Doom для терминала без стрельбы и монстров. 3D Raycasting на ascii.
dcc0 05.07.2026
Попросил нейронную сеть deepai. org написать рейкастинг 3D с библиотекой ncurses для Linux. Чтобы можно было ходить на стрелочки. Чтобы стены были отрисованы символами. Справилась. Первый вариант. . .
Установка статуса документа по условию
Maks 05.07.2026
Алгоритм из решения ниже реализован на нетиповом документе "НарядПутевка" разработанного в КА2. Задача: в табличной части "Материалы" документа при записи автоматически устанавливать статус. . .
Сезонность и суточность закисления почв
anaschu 04.07.2026
200 часов это все равно моловато. Есть ситуации, но нестандартные, когда смена происходит за 5 лет. Но обычно это 50 лет и более. Наверное, закисление почвы происходит сезонно в средней. . .
В чем ценность человеческого опыта в глобальном смысле?
kumehtar 03.07.2026
Возможно, ценность человека не в том, что он однажды достигает мудрости, а в том, что он становится носителем карты пути. Он знает не только истину, но и последовательность внутренних изменений,. . .
интеграция AnyLogic с самописным REST API и переход на Odoo
anaschu 03.07.2026
Успешная интеграция AnyLogic с самописным REST API и переход на промышленную Odoo WMS Сегодня проделал огромный путь от простой симуляции физических процессов до построения полноценной. . .
Поиск всех путей на ориентированном графе. Linux
dcc0 02.07.2026
Переработка старого кода из моей статьи. Через несколько переработок от PHP кода к C89 (надеюсь, 89). Но довольно запутанно получилось. Код для Linux. Но если убрать time и то, что с ним. . .
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы Всем привет! Хочу поделиться свежим (и довольно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru