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

Решение ОДУ в Matlab

Доброго времени суток! Сегодня мы поговорим о решении ОДУ (обыкновенных дифференциальных уравнений) в Matlab. Перед тем как мы начнём обсуждать данную тему, советую вам ознакомиться с темой: Численное дифференцирование в Matlab, чтобы лучше понимать теоретическую составляющую решения ОДУ.

Обыкновенные дифференциальные уравнения

С помощью дифференциальных уравнений можно описать разные задачи: движения системы, взаимодействующих материальных точек, химической кинетики и т.д. Различают три типа задач для систем диф. уравнений:

  • Задача Коши
  • Краевая задача
  • Задача на собственные значения

Кратко расскажу о их сути:

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

Видео:Решение систем Д/У: 1. Знакомство с функциями odeXYСкачать

Решение систем Д/У: 1. Знакомство с функциями odeXY

Методы решения дифференциальных уравнений

Решение ОДУ в Matlab и не только, в первую очередь, сводится к выбору порядка численного метода решения. Порядок численного метода не связан с порядком дифференциального уравнения. Высокий порядок у численного метода означает его скорость сходимости.

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

Решение обыкновенных дифференциальных уравнений в Matlab можно реализовать «своими ручками», прописав алгоритм по разным схемам. Но также в Matlab есть встроенные функции, выполняющие все стандартные задачи.

Метод Рунге-Кутта первого порядка

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

Например, Метод Рунге-Кутта первого порядка, также известен как Метод Эйлера или Метод ломаных. Информацию о его математическом и графическом представлении советую поискать в гугл. Мы же поговорим о том, как Метод Рунге-Кутта первого порядка реализуется в Matlab для решения ОДУ. Например:

Решить и привести график ошибки уравнения y’ = y*x методом Рунге-Кутта первого порядка (Методом Эйлера, Методом ломаных).

Погрешность Метода Рунге-Кутта 1 порядка

» data-medium-file=»https://i2.wp.com/codetown.ru/wp-content/uploads/2017/02/Рунге-1-погрешность.png?fit=300%2C236&ssl=1″ data-large-file=»https://i2.wp.com/codetown.ru/wp-content/uploads/2017/02/Рунге-1-погрешность.png?fit=622%2C489&ssl=1″ loading=»lazy» src=»https://i2.wp.com/codetown.ru/wp-content/uploads/2017/02/%D0%A0%D1%83%D0%BD%D0%B3%D0%B5-1-%D0%BF%D0%BE%D0%B3%D1%80%D0%B5%D1%88%D0%BD%D0%BE%D1%81%D1%82%D1%8C.png?resize=622%2C489″ alt=»Погрешность метода 1 порядка» width=»622″ height=»489″ srcset=»https://i2.wp.com/codetown.ru/wp-content/uploads/2017/02/Рунге-1-погрешность.png?w=629&ssl=1 629w, https://i2.wp.com/codetown.ru/wp-content/uploads/2017/02/Рунге-1-погрешность.png?resize=300%2C236&ssl=1 300w» sizes=»(max-width: 622px) 100vw, 622px» data-recalc-dims=»1″ />
На данном графике показана зависимость величины ошибки от шага.

Метод Рунге-Кутта второго порядка

Также известен как Метод Эйлера-Коши. Как видите, во второй части уравнения происходит обращения к следующему шагу. Но как тогда быть, если нам ещё не известен следующий шаг? Всё просто. Метод Рунге-Кутта второго порядка — это всё тот же метод первого порядка, однако, на половине шага происходит нахождение «первичного» решения, а затем происходит его уточнение. Это позволяет поднять порядок скорости сходимости до двух.

Решить и привести график ошибки уравнения u’ = u*x методом Рунге-Кутта второго порядка.

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

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

Метод Рунге-Кутта четвёртого порядка

Метод Рунге-Кутта четвёртого порядка считается самым распространённым. Тем не менее, работает он аналогично второму и третьему порядку.

Решить и привести график ошибки уравнения u’ = u*x методом Рунге-Кутта четвёртого порядка.

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

Решение ОДУ в Matlab стандартными средствами

Стоит отметить, что мы с вами разобрали только один самый известный метод решения ОДУ с разными порядками. Однако, методов очень много.

Для решения дифференциальных уравнений и систем в MATLAB предусмотрены следующие функции:

ode45 (f, interval, X0, [options])
ode23 (f, interval, X0, [options])
ode113 (f, interval, X0, [options])
ode15s (f, interval, X0, [options])
ode23s (f, interval, X0, [options])
ode23t (f, interval, X0, [options])
ode23tb (f, interval, X0, [options])

Входными параметрами этих функций являются:

  • f — вектор-функция для вычисления правой части уравнения системы уравнений;
  • interval — массив из двух чисел, определяющий интервал интегрирования дифференциального уравнения или системы;
  • Х0 — вектор начальных условий системы дифференциальных уравнений;
  • options — параметры управления ходом решения дифференциального уравнения или системы.

Все функции возвращают:

  • массив Т — координаты узлов сетки, в которых ищется решение;
  • матрицу X, i-й столбец которой является значением вектор-функции решения в узле Тi.

В функции ode45 реализован метод Рунге-Кутта 4-5 порядка точности, в функции ode23 также реализован метод Рунге-Кутта, но 2-3 порядка, а функция ode113 реализует метод Адамса.

Для решения жёстких систем предназначены функция ode15s, в которой реализован метод Гира, и функция ode23s, реализующая метод Розенброка. Для получения более точного решения жёсткой системы лучше использовать функцию ode15s. Для решения системы с небольшим числом жёсткости можно использовать функцию ode23t, а для грубой оценки подобных систем служит функция ode23tb.

Символьное решение обыкновенных дифференциальных уравнений произвольного порядка осуществляет функция dsolve r = dsolve(‘eq1,eq2,…’, ‘cond1,cond2,…‘, ‘v’)
Пример использования:

На этом мы закончим. Если остались вопросы, задавайте их в комментариях. Также вы можете скачать исходники чтобы лучше понять тему: «Решение ОДУ в Matlab».

Видео:Численное решение системы дифференциальных уравнений(задачи Коши)Скачать

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

Решение краевой задачи с использованием MATLAB

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

функция граничный солвер дифференциальный

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

Данный вид уравнения представляет собой ОДУ второго порядка

и граничными условиями

б • y (a) + в ? y'(a) = A, г • y(b) + д ? y'(b) = B,

где х, y — координаты;

б, в, г, д, A, B — заданные числа.

Решение этой задачи в MATLAB состоит из следующих этапов:

  • 1) преобразование дифференциального уравнения второго порядка к системе двух уравнений первого порядка;
  • 2) написание функции для вычисления правой части системы;
  • 3) написание функции, определяющей граничные условия;
  • 4) формирование начального приближения при помощи специальной функции bvpinit;
  • 5) вызов солвера bvp4c для решения граничной задачи;
  • 6) визуализация результата.
  • 1) Для решения ОДУ второго порядка введем две вспомогательные функции, количество которых определяется порядком уравнения.

Составим систему уравнений первого порядка

y2′ = y2/x — 2/x2; y2(0,5) 2

2) Функция правой части системы зависит от x и вектора y, состоящего из двух компонентов, y(1) соответствует y1, а y(2) — y2.

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

Можно использовать функции вычисления вектора правых частей (twoode.m) и соблюдения граничных условий (twobc.m).

3) При постановке граничных условий для вспомогательных функций требуется преобразовать их так, чтобы в правых частях стояли нули. Функция, описывающая граничные условия, зависит от двух аргументов — векторов ya и yb.

В данной задаче ya(2)-2=0, yb(1)-0=0

4) Для задания начальной сетки и приближения предназначена функция bvpinit, обращение к которой в самом простом случае выглядит следующим образом:

bvpinit (начальная сетка, начальное приближение к решению).

Начальная сетка определяется вектором координат узлов, упорядоченных по возрастанию и принадлежащих отрезку [a,b]. Формирование равномерной сетки целесообразно производить функцией linspace:

возвращающей вектор х из n равноотстоящих узлов между a и b, включая границы.

Заданная сетка модифицируется солвером в процессе решения для обеспечения требуемой точности. Постоянное начальное приближение задается вектором из двух элементов для функций y1 (х), y2 (х).

  • 5) Солвер bvp4c основан на методе конечных разностей, т.е получающееся решение есть векторы значений неизвестных функций в точках отрезка (в узлах сетки). Выбор начальной сетки и приближения может оказать влияние на решение.
  • 6) Отображаем графически приближенное решение, извлекая нужные компоненты из структуры, возвращаемой солвером (рис.1).

Листинг. Файл-функция для решения граничной задачи

Видео:MatLab. Решение дифференциального уравнения.Скачать

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

Численное решение краевых (граничных) задач

Дата добавления: 2014-11-28 ; просмотров: 1782 ; Нарушение авторских прав

Для решения краевых задач, т.е. дифференциальных уравнений произвольного порядка n, или систем из n уравнений первого порядка вида Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlab, Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlabслужит РЕШАТЕЛЬ bvp4c.

Точность решения контролируется при помощи двух опций управляющей структуры RelTol – для относительной точности и AbsTol – для абсолютной. Сама управляющая структура генерируется функцией bvpset

Opsions = bvpset (‘RelTol‘, 1.0e-05, ‘AbsTol’, 1.0e-07)

и задается в качестве четвертого входного аргумента солвера bvp4c.

Рассмотрим решение краевых задач на примере обыкновенного дифференциального уравнения второго порядка (n=2). Требуется найти функцию у(х), удовлетворяющую на отрезке [a, b] дифференциальному уравнению и граничными условиями:

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

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

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

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

Решение этой задачи состоит из следующих этапов:

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

2. Написание функции для вычисления правой части системы.

3. Написание функции, определяющей граничные условия.

4. Формирование начального приближения при помощи специальной функции bvpinit.

5. Вызов солвера bvp4c для решения граничной задачи.

6. Визуализация результата.

Этап 1. Введение вспомогательных функций y1(x)=y и y2(x)=y1¢=y¢, приводит к системе из двух уравнений первого порядка относительно них (при постановке граничных условий для вспомогательных функций требуется преобразовать их так, чтобы в правых частях стояли нули):

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

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

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

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

Этап 2. Функция правой части системы зависит от х и вектора у, состоящего из двух компонент, у(1) соответствует Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlab Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlab, а у(2) – Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlab.

Этап 3. Функция, описывающая граничные условия, зависит от двух аргументов векторов ya и yb и имеет следующую структуру:

function g = bound(ya,yb)

g = [alpha1*ya(1)+beta1*ya(2)–gamma1; alpha2*yb(1)+beta2*yb(2) –gamma2];

причем вместо alpha1, beta1, gamma1, alpha2, beta2, gamma2 следует подставить заданные числа.

Этап 4. Солвер bvp4c основан на методе конечных разностей, т. е. получающееся решение есть векторы значений неизвестных функций в точках отрезка (в узлах сетки). Выбор начальной сетки и приближение может оказать влияние на решение, выдаваемое солвером bvp4c. Для задания начальной сетки и приближения предназначена функция bvpinit, обращение к которой в самом простом случае выглядит в виде

initsol = bvpinit (начальная сетка, начальное приближение к решению),

где начальная сетка определяется вектором координат узлов, упорядоченных по возрастанию и принадлежащих отрезку [a, b]. Если имеется априорная информация о решении, то разумно среди точек начальной сетки указать те, в которых решение сильно изменяется.

Формирование равномерной сетки целесообразно производить функцией linspace,которая возвращает вектор х из n равноотстоящих узлов между a и b, включая границы:

X = linspace (a, b, n).

Заданная сетка модифицируется солвером в процессе решения для обеспечения требуемой точности. Постоянное начальное приближение задается вектором из двух элементов функций Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlab. Начальное приближение может зависеть от х, в этом случае:

1) требуется запрограммировать функцию, которая по заданному х возвращает вектор из двух компонент со значениями Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlab,

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

Этап 5. После определения начального приближения вызывается солвер bvp4c, входными аргументами которого являются указатели на функции правой части системы и граничных условий, начальное приближение и, при необходимости, управляющая структура с параметрами вычислительного процесса. Управляющая структура формируется при помощи функции bvpset. Солвер bvp4c возвращает единственный выходной аргумент – структуру с информацией о расчетной сетке, значения искомой функции и ее производной. Солвер bvp4c так же, как и и солвер dde23 для ДУ с запаздыванием, позволяет получить результат только в виде структуры.

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

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

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

После преобразования получаем следующую систему ДУ первого порядка (этап 1)

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

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

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

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

Подготовим функцию по имени rside для правых частей системы ДУ в виде m-файла (этап 2).

function f = rside(x, y)

Подготовим функцию по имени bound дл я граничных условий в виде m-файла (этап 3).

function f = bound(ya, yb)

f = [ya(1); yb(1) + yb(2) + 1];

При помощи bvpinit зададим начальную сетку на отрезке [0, Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlab], например из 20 узлов, и постоянное начальное приближение: Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlab, Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlab.

% формирование начальной сетки meshinit и начального приближения yinit

»meshinit = linspace(0, 11*pi/2, 20);

»initsol = bvpinit(meshinit, yinit);

Вызовем солвер bvp4c и получим приближенное решение.

»sol = bvp4c(@rside, @bound, initsol);

Отобразим графически приближенное решение, извлекая нужные компоненты из структуры возвращаемой солвером, т.е. используем поля x и y структуры sol для построения решения:

% в sol.x содержатся координаты сетки

% в sol.y(1, 🙂 соответствует значениям функции y1 в sol.x(:)

% в sol.y(2, 🙂 соответствует значениям функции y2 в sol.x(:)

Отобразим графически точное решение Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlabна отрезке [0, Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlab] для сравнения.

»fplot(@sin, [0 11*pi/2]);

»title(‘Решение граничной задачи при помощи bvp4c’);

»legend(‘Приближенное решение’, ‘Точное решение’);

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

Как следует из полученных графиков (в виде точек и сплошной линии) для простых задач солвер bvp4c дает хорошие результаты. По умолчанию решение найдено с относительной точностью 10 -3 и относительной 10 -6 по невязке.

Приложение 4

|следующая лекция ==>
Численное решение ОДУ и их систем|Алгебраических уравнений

Не нашли то, что искали? Google вам в помощь!

Видео:Как в MATLAB Simulink моделировать уравнения (Структурная схема САУ)Скачать

Как в MATLAB Simulink моделировать уравнения (Структурная схема САУ)

Лабораторная работа Решение дифференциальных уравнений в Matlab

НазваниеЛабораторная работа Решение дифференциальных уравнений в Matlab
Дата15.02.2018
Размер0.51 Mb.
Формат файлаРешение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlab
Имя файлаlab#5DiffEquationsMatlab.docx
ТипЛабораторная работа
#36539
Подборка по базе: Расчетная работа1.docx, ВЫПУСКНАЯ КВАЛИФИКАЦИОННАЯ РАБОТА. Тема_ «Модернизация компьютер, Практическая работа Иванова 28.04.21.docx, Практическая работа 4docx.docx, практическая работа 2.docx, Практическая работа 8.doc, Самостоятельная работа по теме 4.3.docx, Практическая работа 4.docx, Практическая работа 1_1 2 кл (1) (1) (1).docx, практическая работа 4.docx

РОССИЙСКИЙ УНИВЕРСИТЕТ ТРАНСПОРТА (МИИТ)

Кафедра «Управление и защита информации»

«Решение дифференциальных уравнений в Matlab»

«ИСТОРИЯ И МЕТОДОЛОГИЯ НАУКИ И ТЕХНИКИ

В ОБЛАСТИ УПРАВЛЕНИЯ»

Выполнила: студентка группы ТУУ-151

Проверила: доц. Зольникова Н.Н.

Решить дифференциальное уравнение:

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

при начальном условии

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

Решим данную задачу Коши с помощью метода Рунге-Кутта 4-5 порядка точности, используя функцию ode45(). Для этого запишем исходное уравнение как функцию в Matlab:

function y = dy( x, y )

%Уравнение, задающее производную

y = 2*cos(2*x) + sin(y);

end
Также необходимо задать начальные условия и интервал, на котором будет искаться решение.

interval = [0, 50];
%Решение с помощью метода Рунге-Кутта 4-5 порядка точности

[X,Y] = ode45(@dy, interval, y0);

plot(X, Y) %изображение графика функции

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

Решить задачу Коши и краевую задачу для дифференциального уравнения

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

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

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

Для нахождения решения данного дифференциального уравнения следует найти общее решение соответствующего однородного дифференциального уравнения

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

Составляем и решаем характеристическое уравнение:

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

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

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

Характеристическое уравнение имеет два кратных действительных корня, следовательно, общее решение однородного уравнения имеет вид:

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

Найдем частное решение. Так как в исходном уравнении правая часть представляет собой константу, то частное решение будет иметь вид:

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

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

Подставляем частное решение в исходное уравнение. Получаем:

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

Таким образом, частное решение имеет вид:

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

Общее решение исходного дифференциального уравнения записывается в виде:

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

При этом производная

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

Решение задачи Коши.

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

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

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

Таким образом, при данных начальных условиях получаем решение в виде:

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

Решение краевой задачи.

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

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

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

Таким образом, при данных краевых условиях получаем решение в виде:

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

Решим задачу Коши аналитически с помощью метода dsolve() и методом Рунге-Кутта с помощью функции ode45().

В функцию dsolve() необходимо записать исходное уравнение, начальные или граничные условия и переменную, по которой происходит дифференцирование. Символ «Dy» обозначает первую производную, «D2y» соответственно вторую производную.

Y = dsolve(‘D2y+2*Dy+y=1.5’, ‘y(0)=0’, ‘Dy(0)=0’, ‘x’)

y = ezplot(Y, [0,20]) %изображение графика символьного выражения

set(y, ‘LineWidth’, 2); %установка толщины линии

axis([0 20 0 2]); %задание границ графика

grid on; %создание сетки на графике

hold on; %следующий график будет рисоваться в этом же окне
Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlab
Для использования функции ode45() запишем исходное уравнение в виде системы:

function F = dy2( x, y )

% ОДУ первого порядка

%Решение с помощью метода Рунге-Кутта 4-5 порядка точности

%Интервал, на которм будет находится решение

[X,Y] = ode45(@dy2, interval, y0);

%Значения искомой функции находятся в первом столбце матрицы Y

plot(X, Y(:,1), ‘:r’, ‘LineWidth’, 1.5) %изображение графика функции

legend(‘Аналитическое решение’,’Метод Рунге-Кутта’);
Оба графика решений полностью совпали.

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

Решение краевой задачи также найдем аналитически через функцию dsolve() и с помощью методов bvp4c() и ode45().

Y = dsolve(‘D2y+2*Dy+y=1.5’, ‘y(0)= 1’, ‘Dy(5)=6.5’, ‘x’)

y = ezplot(Y, [0,20]); %изображение графика символьного выражения

set(y, ‘LineWidth’, 2); %установка толщины линии

axis([0 20 -100 50]); %задание границ графика

grid on; %создание сетки на графике

hold on; %следующий график будет рисоваться в этом же окне

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

function res = boundCon( ya, yb )

%Функция, вычисляющая разность между значением в граничной точке

% и точным значением

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

solinit = bvpinit(linspace(0,5), [1 1]);

%Нахождение значений y(x) и y'(x) на интервале [0;5]

sol = bvp4c(@dy2, @boundCon, solinit);

[X,Y] = ode45(@dy2, interval, y0);

%Значения искомой функции находятся в первом столбце матрицы Y

plot(X, Y(:,1), ‘:r’, ‘LineWidth’, 1.5) %изображение графика функции

legend(‘Аналитическое решение’,’Метод Рунге-Кутта’);
Решение краевой задачи для обыкновенных дифференциальных уравнений второго порядка matlab

Графики решений полностью совпали.

Изобразим фазовый портрет системы. Для этого решим ее с помощью функции ode45() при различных начальных условиях.

%Интервал, на которм будет находится решение

[X,Y] = ode45(@dy2, interval, y0);

%Значения функции y(x) находятся в первом столбце

%Значения производной y'(x) находятся во втором столбце

🔥 Видео

Математика это не ИсламСкачать

Математика это не Ислам

Линейное неоднородное дифференциальное уравнение второго порядка с постоянными коэффициентамиСкачать

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

Численное решение дифференциальных уравнений (задачи Коши)Скачать

Численное решение дифференциальных уравнений (задачи Коши)

Задача Коши ➜ Частное решение линейного однородного дифференциального уравненияСкачать

Задача Коши ➜ Частное решение линейного однородного дифференциального уравнения

5 Численное решение дифференциальных уравнений Part 1Скачать

5  Численное решение дифференциальных уравнений Part 1

5 Численное решение дифференциальных уравнений Part 1Скачать

5  Численное решение дифференциальных уравнений Part 1

Решение дифференциальных уравнений и систем. Урок 150Скачать

Решение дифференциальных уравнений и систем. Урок 150

Методы решения нелинейных краевых задач для ОДУСкачать

Методы решения нелинейных краевых задач для ОДУ

Метод ЭйлераСкачать

Метод Эйлера

ТАУ. Matlab/SIMULINK Фазовые портреты систем нелинейных диф. уравненийСкачать

ТАУ. Matlab/SIMULINK Фазовые портреты систем нелинейных диф. уравнений

7. Линейные дифференциальные уравнения первого порядка. Метод Бернулли.Скачать

7. Линейные дифференциальные уравнения первого порядка. Метод Бернулли.

Работа в MATLAB. МКР. Задача КошиСкачать

Работа в MATLAB. МКР. Задача Коши

Решение систем Д/У: 2. Опции решателей odeXYСкачать

Решение систем Д/У: 2. Опции решателей odeXY

MatLab. 7.9. Системы дифференциальных уравненийСкачать

MatLab. 7.9. Системы дифференциальных уравнений
Поделиться или сохранить к себе: