Дифференциальные уравнения методом эйлера маткад

методами Эйлера и Рунге-Кутта в системе MathCAD

Построение решений обыкновенных дифференциальных уравнений

Решение дифференциального уравнения 1-го порядка

, .

Простой метод Эйлера реализуется применением на каждом шаге вычислений следующих итерационных выражений:

,

.

Рассмотрим реализацию метода в MathCADна примере уравнения:

, , .

Аналитическое решение известно и имеет вид:

.

Краткие сведения о составлении программ в MathCAD

знак присваивает функции или переменной (они помещаются слева) выражение или число, которые помещаются справа. Набирается клавишей двоеточие «:» или из меню по цепочке View→ Toolbars→ Calculator.

знак обозначает последовательное изменение переменной через единицу от значения слева до значения справа. Набирается клавишей точка с запятой «;».

матрица вставляется командой меню Insert→ Matrixили клавишами Ctrl-M. Нижний индекс добавляется клавишей квадратная скобка «[».

Графиквставляется командой Insert→ Graph→ X-YPlotили клавишей «@».

Для удобства в работе рекомендуется отключить автоматическое вычисление, убрав галочку с опции меню Tools→ Calculate→ AutomaticCalculation. Тогда расчет не будет выполняться в ходе набора программы, а запуститься только после нажатия кнопки Calculate, расположенной на панели инструментов (в виде значка ).

Ниже приведена расчетная программа. Повторите её. Получите графики с тем же форматом линий. Формат линий графика можно изменить, открыв с помощью ПК мыши контекстное меню и выбрав Format… → Traces.

Программа для простого метода Эйлера

Шаг изменения x
Число шагов
Функция, определяющая производную
Задание цикла
Задание начальных условий
Итерационные уравнения
Результаты решения:

Следующая программа реализует модифицированный метод Эйлера. Отличие от простого метода заключается в итерационных уравнениях.

Программа для модифицированного метода Эйлера

Шаг изменения x
Число шагов
Функция, определяющая производную
Задание цикла
Задание начальных условий
Итерационные уравнения
Результаты решения:

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

Программа для метода Рунге-Кутта

Шаг изменения x
Число шагов
Функция, определяющая производную
Задание коэффициентов k1, k2, k3, k4 как функций пользователя:
Усредненная функция
Задание цикла
Задание начальных условий
Итерационные уравнения
Результаты решения:

Решение дифференциальных уравнений 2-го порядкаметодом Рунге-Кутта.

Подход к реализации метода основан на использовании дополнительной функции . Это позволяет перейти к системе уравнений, содержащих только первые производные. Итак, пусть требуется найти решение задачи:

, , .

Преобразуем задачу к системе из двух уравнений:

, ,

, .

Тогда получим следующее обобщение итерационной схемы:

. ,

, ,

, ,

, ,

, .

Отметим, что значения на каждом следующем шаге рассчитываются по значениям, полученным на предыдущем. Кроме того, использованы прежние правила «взвешивания» коэффициентов при усреднении.

Пример математической модели с дифференциальным уравнением 2-го порядка

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

,

где t– время, и искомой является зависимость ;

– круговая частота собственных колебаний;

– круговая частота внешнего воздействия с амплитудой «a».

Если , то общее решение уравнения имеет вид (проверьте подстановкой):

,

где Aи – произвольные постоянные. Частное решение выбирается заданием значений этих постоянных. Второе слагаемое решения показывает, что с течением времени амплитуда колебаний неограниченно возрастает. Это явление называется резонансом.

Когда , общее решение имеет вид:

.

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

Моделирование резонансных колебаний

Методом Рунге-Кутта найдем решение задачи:

, , , .

Согласно изложенной выше теории, аналитическое решение уравнения имеет вид:

.

Ниже приведен алгоритм расчета и его реализация в MathCAD.

Программа расчета резонансных колебаний методом Рунге-Кутта

Шаг изменения x
Число шагов
Функция в системе уравнений dy/dx = z и dz/dx = f(x,y,z)
Задание коэффициентов как функций пользователя:
Усредненные функции:
Задание цикла
Задание начальных условий
Итерационные уравнения
Результаты решения:

Задание для самостоятельного выполнения

Найти решение уравнения вынужденных колебаний:

, , , .

Решение представить в виде графика. Для сравнения привести и график точного решения (также как это было сделано для резонансных колебаний).

Дифференциальные уравнения в MathCad

Дифференциальные уравнения достаточно часто используются для того, чтобы описать значение часто меняющихся процессов. Сначала обратим внимание на самое стандартное уравнение данного типа.

Решение данного уравнения будет представлено следующим образом.

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

Метод Эйлера

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

Постепенно проследим изменения

Сравниваем результативность и правильный ответ

Необходимо учитывать, что методика Эйлера в некоторой степени отличается от точного решения задачи. И чем выше аргумент, тем внушительнее оказывается полученная разница. Чтобы свести к минимуму ошибку, нужно увеличить количество шагов.

Блок решения ОДУ

Mathcad вмещает в себя все самые важные опции для решения уравнения дифференциального типа. В данном уроке мы обратим внимание на самую важную функцию такого типа. Она характеризуется максимальной точностью и простотой использования. Методика сочетает пользование блоком решения и опцией odesolve(). Перед решением устанавливаем такие параметры:

Каждое вхождение переменной с в блок решения представляется как функция независимой переменной.

Данный метод во многом похож на принципы аналитического решения. Точно такой же результат удается получить после записи производной через штрих (Ctrl+’)

Сердце и артерии

Функционирование сердца и артерий во многом похожи на работу насоса. Они оба могут расшириться и сжаться, а клапаны перегоняют жидкость исключительно в одном направлении.

Пульсирование потока можно снизить, расширяя и сжимая стенки артерии.

Перепады давления возле легких достаточно низкие. Давайте установим, что повышенное давлении в точках А и В равняется нулю. Центральный элемент – это артерия, которая может изменяться в объемах.

Допустим, что объемы сердца могут изменяться в соответствии с особенностями синусоидального закона. Однако впырск крови происходит исключительно во время положительных полуволн.

График для восьми ударов:

Средний поток представляет собой интеграл объема, который задействован при одном ударе и поделен на его продолжительность.

Расширение артерий прямо зависит от общей эластичности стенок и особенностей их строений. Однако мы в математических целях предположим, будто объем прямо зависит от превышения давления.

Чем выше эластичность стенки, тем больше оказывается значение k. Установим ему три значения.

Баланс объемов артерий:

Вышеуказанная формула приводит к таковым результатам:

Данную функцию можно решить примерно так же, как и предыдущую. Единственное различие состоит в том, что k будет перенесено в блок решения уже в качестве параметра.

Теперь конвертируем решения.

Максимальные показания давления прямо зависят от уровня эластичности давления. Чем она выше, тем ниже оказывается само давление.

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

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

Выбрав нужную версию программы и кликнув ссылку, Вам на компьютер скачивается дистрибутив приложения MediaGet, который будет находиться в папке «Загрузки» для Вашего браузера. Находим этот файл с именем программы и запускаем его. И видим первый этап установки. Нажимаем унопку «Далее»

Далее Вам предлагается прочитать и одобрить лицензионное соглашение. Нажимаем кнопку «Принимаю»

В следующем окне Вам предлагается бесплатное полезное дополнительное программоное обеспечение, будь то антивирус или бразуер. Нажимаем кнопку «Принимаю». Также Вы можете отказаться от установки дополнительного ПО, нажав кнопку «Отклоняю»

Далее происходит процесс установки программы. Вам нужно выбрать папку, в которую будут скачиваться нужные Вам файлы.

Происходит завершение установки. Программа автоматически открывается и скачивает нужные Вам исходные файлы.

Обратите внимание, что предоставляемое программное обеспечение выкладывается исключительно для личного использования и ознакомления. Все файлы, доступные для скачивания, не содержат вирусов и вредоносных программ.

Дифференциальные уравнения методом эйлера маткад

Электронный курс по MathCAD

5.2 Решение дифференциальных уравнений и систем.(Задача Коши и граничные задачи).


Решение одиночного дифференциального уравнения.

Для численного решения одиночного дифференциального уравнения в MathCAD имеется функция Odesolve, с помощью которой может быть решена как задача Коши для обыкновенного дифференциального уравнения, так и граничная задача. Эта функция входит в состав блока решения и сявляется его заключительным ключевым словом.

Odesolve(x,b,[step]) — Возвращает функцию, которая является решением дифференциального уравнения. Используется в блоке с оператором Given.
x — переменная интегрирования, действительное число
b — конечная точка отрезка интегрирования
step — величина шага по переменной интегрирования (необязательный аргумент)

Замечания:

  1. Уравнение должно быть линейным относительно старшей производной.
  2. Число заданных начальных или граничных условий внутри блока должно быть равно порядку уравнения.
  3. При записи уравнения для обозначения производных функции используйте специальные кнопки с панели Math или ‘ (штрих) — [Ctrl+F7], для знака равенства = [Ctrl+=] (в том числе и для дополнительных условий).
  4. Конечная точка должна быть больше начальной.
  5. Не допускаются начальные и граничные условия смешанного типа (f ‘(a)+f(a)=5).
  6. Искомая функция в блоке дложна быть обязательно с аргументом ( f(x))

Численное решение задачи Коши для дифференциальных уравнений и систем.

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

rkfixed(y,x1,x2,n,F) — возвращает матрицу решений системы уравнений методом Рунге-Кутта 4-го порядка при фиксированном шаге по x

rkadapt(y,x1,x2,n,F) — ищет решение с переменным шагом ( там, где решение меняется медленнее, шаг увеличивается, а в области быстрого изменения решения шаг функции уменьшается). Возвращается решение с равным шагом. Функция работает быстрее, чем rkfixed

Bulstoer(y,x1,x2,n,F) — дает более точное решение (методом Bulirsch-Stoer)

Агрумкнты вышеуказанных функций:
y — вектор начальных условий
x1,x2 — границы интервала для поиска решения
n — количество точек на интервале
F(x,y) — вектор-функция первых производных

При решении дифференциальных уравнений порядка выше первого (или систем уравнений, выше первого порядка) исходное уравнение (систему) необходимо преобразовать к системе дифференциальных уравнений первого порядка.

В результате работы укзанных функций рассчитывается матрица, количество стобцов которой равно порядку уравнения +1(или сумме порядков уравнений в системе +1), а количество строк равно параметру n. Первый столбец содержит значения независимой переменной, второй — значение функции, третий — для диф. уравнений 2-го порядка — значение производной искомой функции (если решается система двух уравнений 1-го порядка, то третий столбец будет содержать значения второй функции). Для выделения решений (функций или их производных) можно воспользоваться стандартным оператором вывода столбцов матрицы M &lt &gt

Если матрица правых частей дифференциальных уравнений почти вырождена, то такие системы называются жесткими. В этом случае решения, возвращаемые функцией rkfixed будет неустойчивым и для решения таких систем необходимо применять функции Stiffb , Stiffr

Stiffb(y,x1,x2,n,F,J) — ищет решение диф. уравнения или системы дифференциальных уравнений методом Bulirsch-Stoer

Stiffr(y,x1,x2,n,F,J) — ищет решение диф. уравнения или системы дифференциальных уравнений методом Rosenbrock

Первые пять аргументов такие же,как и при решении хорошо обусловленных систем дифференциальных уравнений . Дополнительный аргумент — матрица J размером nx(n+1), первый столбец которой содержит частные производные dF/dx, остальные столбцы и строки представляют собой матрицу Якоби dF/dy

Пример решения жесткой системы дифференциальных уравнений.

Для отыскания решения системы диф. уравнений только в конечной точке используются функции bulstoer,rkadapt, stiffb, stiffr (начинаются с прописной буквы).

Набор парамтров для этих функций :
bulstoer(y,x1,x2,acc,F,kmax,save)
rkadapt(y,x1,x2,acc,F,kmax,save)
stiffb(y,x1,x2,acc,F,J,kmax,save)
stiffr(y,x1,x2,acc,F,J,kmax,save)

Первые три параметра и пятый (F) этих функций те же, что идля функции Rkadapt. Дополнительные параметры:
acc — параметр, контролирующий точность решения (реком. асс=0.001)
kmax — максимальное число промежуточных точек в которых ищется решение
save — минимально допустимый интервал между точками, в которых ищется решение

Решение граничных задач для обыкновенных дифференциальных уравнений.

Если для дифференциального уравнения n-го порядка k граничных условий заданы в начальной точке х1, а (n-k) граничных условий — в конечной точке х2, то такая задача называется краевой. В MathCAD реализованы две функции, позволяющие численно найти недостающие условия в точках х1 и х2.

Двухточечная краевая задача

Задача решается в два этапа. Сначала с помощью функции sbval находятся недостающие начальные значения, а затем применяется одна из выше описанных функций для решения стандартной задачи Коши на отрезке.

sbval(v,x1,x2,F,load,score) — ищет недостающие начальные условия в точке х1
v — вектор началных приближений для искомых начальных значений в точке х1,
х1,х2 — граничные точки интервала
F(x,y) — вектор-столбец из n элементов, содержит правые части дифференциальных уравнений
load(x1,v) — вектор-столбец из n элементов, содержит начальные значения в точке х1; некоторые из значений- константы, другие неизвестны и будут найдены в процессе решения.
score(x2,y) — вектор-столбец размерности вектора v, содержащий разность между начальным условием в точке х2 и значеием искомого решения в этой точке.

Краевая задача с условиями внутри интервала.

На первом этапе используется функция

balfit(V1,V2,x1,x2,xf,F,load1,load2,score) — ищет недостающие начальные условия в точках х1 и х2, сшивая решения, выходящие из этих точек, в точке xf
V1,V2 — вектора началных приближений для искомых начальных значений в точках х1 и х2
х1,х2 — граничные точки интервала
load1(x1,V1) — вектор-столбец из n элементов, содержит начальные значения в точке х1; некоторые из значений- константы, другие неизвестны и будут найдены в процессе решения
load2(x2,V2) — вектор-столбец из n элементов, содержит начальные значения в точке х2; некоторые из значений- константы, другие неизвестны и будут найдены в процессе решения.
score(xf,y) — вектор-столбец размерности n, содержащий разность между решениями, начинающимися в точках х1 и х2, в точке xf


источники:

http://stylingsoft.com/sapr/mathcad/uroki-mathcad/1433-differentsialnye-uravneniya-v-mathcad

http://msk.edu.ua/ivk/Informatika/Uch_posobiya/MathCad/detc/l5_2.htm