Решение уравнения теплопроводности в паскале

Двумерное уравнение теплопроводности. Фролова Ксения. 6 курс

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

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

Содержание

Видео:Программа решения квадратного уравнения. Паскаль 5.Скачать

Программа решения квадратного уравнения. Паскаль 5.

Постановка задачи [ править ]

Необходимо решить задачу Коши для двумерного уравнения теплопроводности (дифференциальное уравнение в частных производных второго порядка, которое описывает распределение температуры в заданной области пространства и его изменение во времени.) с использованием средств параллельного программирования на основе MPI. Задача решается для однородного уравнения теплопроводности (система теплоизолирована) в области [0..L]x[0..L]:
[math]frac — a^2(frac+frac) = 0[/math]
[math]U(t=0) = U_0[/math]
при граничных условиях:
[math] U(x,y,t) = beginT_0, x=0\ T_1, x!=0 end[/math]
Используемые величины параметров:
[math]L=1, T_0=100, T_1=0[/math]

Видео:8.1 Решение уравнения теплопроводности на отрезкеСкачать

8.1 Решение уравнения теплопроводности на отрезке

Используемый метод [ править ]

В вычислительных системах с распределенной памятью процессоры работают независимо друг от друга. Для организации параллельных вычислений в таких условиях необходимо иметь возможность распределять вычислительную нагрузку и организовать информационное взаимодействие (передачу данных) между процессорами. Параллельное программирование служит для создания программ, эффективно использующих вычислительные ресурсы за счет одновременного исполнения кода на нескольких вычислительных узлах. Для создания параллельных приложений используются параллельные языки программирования и специализированные системы поддержки параллельного программирования, такие как MPI и OpenMP. Итак, MPI — это библиотека передачи сообщений, собрание функций на C/C++ (или подпрограмм в Фортране), облегчающих коммуникацию (обмен данными и синхронизацию задач) между процессами параллельной программы с распределенной памятью. Акроним MPI установлен для Message Passing Interface (интерфейс передачи сообщений). Под параллельной программой в рамках MPI понимается множество одновременно выполняемых процессов. Все процессы порождаются один раз, образуя параллельную часть программы. Каждый процесс работает в своем адресном пространстве, никаких общих переменных или данных в MPI нет. Процессы могут выполняться на разных процессорах, но на одном процессоре могут располагаться и несколько процессов (в этом случае их исполнение осуществляется в режиме разделения времени).

Видео:Пример решения задач на Pascal #1Скачать

Пример решения задач на Pascal #1

Реализация [ править ]

При решении поставленной задачи будем использовать замену частных производных в дифференциальных уравнениях их разностными аналогами. Сеточный метод, основанный на замене в дифференциальном уравнении производных конечными разностями, называют методом конечных разностей, а сеточную схему такого метода — конечно-разностной.
По аналогии с одномерной задачей для уравнения теплопроводности вводим явную конечно-разностную схему. Область [0..L]x[0..L] разбивается на подобласти согласно количеству процессов в выполняемой параллельной программе. На каждом полученном таким способом интервале процесс интегрирования осуществляется отдельным процессом, при этом в связи с использованием явной схемы соседние процессы должны обмениваться крайними значениями, полученными на предыдущем шаге, для выполнения следующего шага.
Программа для решения двумерного уравнения теплопроводности: программа

Видео:Лекция №1.1 Явная и неявная схемы для уравнения теплопроводностиСкачать

Лекция №1.1 Явная и неявная схемы для уравнения теплопроводности

Результаты [ править ]

Найдено решение однородного уравнения теплопроводности в двумерной постановке для следующей сетки узлов: 300х300.

Количество процессов [-]Время рассчета [сек]
140.2082
313.7626
58.38831
76.56195
153.08675
353.90614

    Решение уравнения теплопроводности в паскале

    Показано, что при увеличении количества процессов уменьшается время расчета. Также из приведенного графика видно, что для малого числа узлов в сетке использование большого количества процессов не обосновано — выигрыш во времени либо незначителен, либо же затраченное время увеличивается.

    Видео:Программа для решения корней квадратного уравнения с использованием дискриминанта на языке ПаскальСкачать

    Программа для решения корней квадратного уравнения с использованием дискриминанта на языке Паскаль

    Метод Finite Volume — реализация на примере теплопроводности

    Решение уравнения теплопроводности в паскале

    Метод Finite Volume (FVM)

    В основе метода лежит разбиение области на непересекающиеся контрольные объемы(элементы), узловые точки, в которых ищется решение.Узловые точки находятся в центрах контрольных объемов.Также, как и для метода конечных разностей, для каждого элемента составляется уравнение, получается система линейных уравнений.Решая ее — находим значения
    искомых переменных в узловых точках.Для отдельного элемента уравнение получается путем интегрирования исходного дифф уравнения по элементу и аппроксимации интегралов.

    Термин конечный объем в статье будет часто заменятся на Элемент, будем для удобства считать их эквивалентами (элемент в данной статье не имеет ничего общего с методом конечных элементов).

    Есть 2 различных способа решения задачи по FVM:
    1) грани контрольного объема совпадают с гранями элемента
    2) грани контрольного объема проходят через центры граней элементов(на которые разбита область).Искомые переменные хранятся в вершинах этих элементов.Вокруг каждой вершины строится контрольный объем. Для непрямоугольной сетки этот способ имеет еще 2 подвида.

    Решение уравнения теплопроводности в паскале

    Мы будем использовать способ 1) с контрольными объемами совпадающими с элементами на которые разбита область.

    Некоторые плюсы FVM:

    • сохранение основных величин по всей области, таких как энергия системы, масса, тепловые потоки и тд.Причом это условие выполняется даже для грубой расчетной сетки
    • высокая скорость расчета.Многие расчетные величины можно вычислить при разбиении области на элементы, и вычислять их на каждом шаге по времени нет необходимости.
    • легкость использования для задач со сложной геометрией и криволинейными границами.Легкость использования разных геометрических типов элементов — треугольники, полигоны.

    Метод FVM реализуем на примере уравнения теплопроводности:

    Решение уравнения теплопроводности в паскале

    Итак основные шаги при реализации FVM:

    1. Перевод дифф уравнения в форму пригодную для FVM — интегрирование по контрольному объему
    2. Составление дискретного аналога, выбор способа перевода производных и других подынтегральных выражений в дискретную форму
    3. Получение уравнения для каждого из контрольных объемов, на которые разбита область.Составление системы линейных уравнений и ее решение.

    Дискретизация по времени.

    Решение уравнения теплопроводности в паскале

    Немного теории или первый шаг в реализации FVM

    Решение уравнения теплопроводности в паскале

    FVM на стандартной прямоугольной сетке

    Решение уравнения теплопроводности в паскале

    На рисунке изображен Элемент С и его соседние элементы справа(E), слева(W), сверху(N) и снизу(S).У элемента С есть 4 грани обозначенные буквами e w n s.Именно эти 4 грани и составляют периметр элемента и по ним производится интегрирование.Для каждого элемента в результате получаем дискретный аналог исходного дифф уравнения.

    Составим дискретный аналог для элемента С.Для начала нужно разобраться с интегралом (3).Интеграл это ведь по факту сумма.Поэтому мы и заменяем интеграл по всей поверхности элемента, на сумму по 4-м составляющим этой поверхности, тоесть 4 граням элемента.

    Решение уравнения теплопроводности в паскале

    Решение уравнения теплопроводности в паскале

    Решение уравнения теплопроводности в паскале

    Решение уравнения теплопроводности в паскале

    Уравнение (7) и есть конечное уравнение для элемента С, из него мы на каждом шаге по времени получаем новое значение температуры (Tnew) в элементе С.

    Граничные условия на прямоугольной сетке

    Решение уравнения теплопроводности в паскале

    Мы рассмотрим только 2 вида граничных условий.

    1. Задана температура Tb на границе
    2. Задан поток FluxB на границе, рассмотрим только случай когда FluxB=0, т.е. грань e будет теплоизолирована(Insulated)

    Случай 2) самый простой, поскольку получается что грань e не потребуется при дискретизации(т.к. все коэффициенты Flux=0) и можно ее просто пропустить.

    Теперь рассмотрим случай 1).Дискретизация грани e будет в целом похожа на ту что уже была описана.Будут только 2 изменения — вместо Te будет известное граничное значение Tb и вместо расстояния DXe будет DXe/2.В остальном можно рассматривать значение Te так, как будто это был бы обычный соседний узел E.Теперь подробнее распишем терм для граничного элемента С.

    Решение уравнения теплопроводности в паскале

    Пример численных расчетов на прямоугольной сетке

    Решение уравнения теплопроводности в паскале

    FVM в задачах со сложной геометрией

    Здесь как раз проявляется преимущество FVM, где также, как и в методе конечных элементов, можно представлять область с круглыми границами через разбиение на треугольники или любые другие полигоны.Но FVM имеет еще 1 плюс — при переходе от треугольников к полигонам с большим числом сторон не требуется абсолютно ничего менять, конечно если код был написан для произвольного треугольника а не равностороннего.Более того, можно без изменения кода использовать смесь разных элементов — треугольники, полигоны, квадраты и тд.

    Рассмотрим общий случай, когда вектор соединяющий центры 2-х элементов не совпадает с вектором нормали к общей грани этих элементов.Вычисление потока flux через грань теперь будет состоять из 2-х частей.В первой будет расcчитываться ортогональная составляющая а во второй так называемая «кросс-диффузия».

    На картинке изображены 2 элемента, С — текущий рассматриваемый элемент и F — соседний элемент.Опишем дискретизацию для грани, разделяющей эти 2 элемента.Вектор соединяющий центры элементов — DCF.Вектор e — это единичный вектор по направлению DCF.Вектор Sf — направлен по нормали к грани, его длинна равна длине грани.

    Решение уравнения теплопроводности в паскале

    Решение уравнения теплопроводности в паскале

    Решение уравнения теплопроводности в паскале

    В исходниках я не стал реализовывать терм с кроссдиффузией, т.к встал вопрос — как проверить корректность такой реализации.Визуально сравнение результатов Матлаб и моих ничем не отличалось в отсутствии кросс-диффузии.Видимо это связано с тем что Матлаб любит треугольники близкие к равносторонним, что в итоге делает кроссдиффузию=0.Возможно позже еще вернусь к этому вопросу.

    Расчет граничных элементов ничем не отличается от расчетов не на границе, вместо центра соседнего элемента берется центр грани, ну и как обычно подставляется температура на границе.
    В моей реализации в итоге получается так:

    Решение уравнения теплопроводности в паскале

    Примеры и проверка результатов

    Решение уравнения теплопроводности в паскале

    Описание структуры исходников

    Гитхаб с исходниками лежит тут
    Основная версия в папке heat2PolyV2.То что относится к вычислительной части лежит в heat2PolyV2SrcFiniteVolume.

    Вначале файла Scene2.cs — параметры которые можно менять для отображения в разных цветовых схемах, масштаб, отображение mesh и т.д.Сами примеры хранятся в heat2PolyV2binDebugDemos
    Выгрузку из Матлаба сделать просто — нужно открыть pde toolbox, открыть m файл (либо создать самому с нуля), зайти в меню Mesh-Экспорт mesh, нажать ОК; перейти в основной Матлаб, в панельке появятся переменные — матрицы p e t, открыть файл savemymesh.m, выполнить его, появится файл p.out, перенести его в папку Demos.
    В исходниках для выбора примера необходимо задать имя файла в строке param.file = «p»;(FormParam.cs).Далее необходимо применить граничные условия — для готовых примеров можно просто раскомментировать соответствующие блоки в MainSolver.cs:

    Смысл тут простой — Матлаб разделяет границы по доменам, например внешние и внутренние.Также для каждого домена границы разбиты на части (группы), чтобы можно было задавать условия на участках границы по отдельности — например справа или снизу.
    Возможно и вовсе не использовать Матлаб, а вручную прописать все элементы(треугольники) и их вершины + грани(только для граничных элементов)

    📺 Видео

    12. Как остывает шар (решение уравнения теплопроводности)Скачать

    12. Как остывает шар (решение уравнения теплопроводности)

    Pascal (Урок 4) Квадратное уравнениеСкачать

    Pascal (Урок 4) Квадратное уравнение

    А вы любите информатику? Pascal #2023 #школа #информатика #паскаль #программа #решениеСкачать

    А вы любите информатику? Pascal #2023 #школа #информатика #паскаль #программа #решение

    Уравнение в частных производных Уравнение теплопроводностиСкачать

    Уравнение в частных производных  Уравнение теплопроводности

    Работа с массивами PascalСкачать

    Работа с массивами Pascal

    Решение уравнения теплопроводности в одномерной постановке в ExcelСкачать

    Решение уравнения теплопроводности в одномерной постановке в Excel

    Паскаль с нуля [ч7]. Одномерные массивы.Скачать

    Паскаль с нуля [ч7]. Одномерные массивы.

    6-1. Уравнение теплопроводностиСкачать

    6-1. Уравнение теплопроводности

    Паскаль с Нуля. Арифметические действия, DIV, MOD. Урок 3Скачать

    Паскаль с Нуля. Арифметические действия, DIV, MOD. Урок 3

    Уравнение теплопроводности на полупрямой (решение задачи)Скачать

    Уравнение теплопроводности на полупрямой (решение задачи)

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

    Решение нестационарного уравнения теплопроводности в двухмерной постановке в Excel

    Задачи с массивами | Pascal | Сумма и поиск элементовСкачать

    Задачи с массивами | Pascal |  Сумма и поиск элементов
    Поделиться или сохранить к себе: