Одномерное уравнение теплопроводности. Буй Ван Шань. 6 курс — различия между версиями
(→Применение технологии MPI) |
(→Ссылки для скачивания) |
||
Строка 81: | Строка 81: | ||
Заметим что при увеличении количества процессов, скорость расчета параллельно повысилась | Заметим что при увеличении количества процессов, скорость расчета параллельно повысилась | ||
==Ссылки для скачивания== | ==Ссылки для скачивания== | ||
+ | :Скачать пример численного интегрирование [[File:Integral.rar|Интергал 766 KB]] | ||
:Скачать реализацию 1d [[File:HeatEquation.rar|HeatEquation 2KB]] | :Скачать реализацию 1d [[File:HeatEquation.rar|HeatEquation 2KB]] | ||
:Скачать реализацию 2d [[File:MPI2x.rar|MPI2x.rar 2KB]] | :Скачать реализацию 2d [[File:MPI2x.rar|MPI2x.rar 2KB]] |
Версия 13:22, 16 декабря 2015
Содержание
Постановка задачи
Решается однородное уравнение теплопроводности на промежутке
С граничными условиями
и начальным распределением температуры
- Где : - Известные функции
Реализация
Конечно-разностная схема
Задача содержит производную по времени первого порядка и производную по пространственной координате второго порядка. Запишем исходное уравнение в виде
Введем равномерную сетку
с шагом разбиения . Шаг по времени назовем Построим явную конечно-разностную схему:Где,
— значение температуры в -ом узле.- Условие сходимости явной схемы: , где dt - шаг по времени, dx - шаг по координате
Применение технологии MPI
Разветвление для уравнения теплопроводности осуществляется путем разбиением отрезка интегрирования на некоторые интервалы. На каждом интервале, процесс интегрирования осуществляется отдельным процессом, при этом в связи с использованием явной схемы, соседние процессы должны обменивать крайними значениями, получены на предыдущем шаге, для выполнения следующего шага.
- Первый процесс обменивается данными только с вторым процессом
- Последний процесс обменивается данными только с предпоследним процессом
- Все центральные процессы обмениваются с процессами слево, и справо
- Начальные и краиние значения на каждом шаге вычисляются по начальным и граничным условиям.
Данные для расчета
Результаты
- Решение
- 2 процесса
- 4 процесса
- Погрешность вычисления
- Зависимость времени расчета от количества процессов при постоянных шагах вычисления: dx = 0.001; dt = 0.000001
Количество процессов | Время рассчета (сек) |
---|---|
2 | 96.58 |
4 | 49.4 |
8 | 28.66 |
10 | 23.63 |
20 | 12.89 |
30 | 9.27 |
40 | 7.52 |
Для малого числа узлов в сетке использовать многопроцессорные вычисления не выгодно: время работы программы неуменьшается. Заметим что при увеличении количества процессов, скорость расчета параллельно повысилась
Ссылки для скачивания
- Скачать пример численного интегрирование Файл:Integral.rar
- Скачать реализацию 1d Файл:HeatEquation.rar
- Скачать реализацию 2d Файл:MPI2x.rar