Рис. 7.11. Пример решения одиночного дифференциального уравнения
В этом примере решается дифференциальное уравнение
у'(х) = cos(x²y(x))
при у(0)=2 и х, меняющемся от -5 до 5. Левая часть уравнения записана с помощью функции вычисления производной diff. Результатом построения является график решения y(x).
В другом примере (рис. 7.12) представлено решение системы из двух нелинейных дифференциальных уравнений. Здесь с помощью функции odeplot строятся графики двух функций — y(х) и z(x).
Рис. 7.12. Пример решения системы из двух дифференциальных уравнений
В этом примере решается система:
y'(х) = z(х),
z'(x) = 3 sin(y(x))
при начальных условиях y(0)=0, z(0)=1 и х, меняющемся от -4 до 4 при числе точек решения, равном 25.
Иногда решение системы из двух дифференциальных уравнений (или одного дифференциального уравнения второго порядка) представляется в виде фазового портрета — при этом по осям графика откладываются значения у(х) и z(х) при изменении х в определенных пределах. Рисунок 7.13 демонстрирует построение фазового портрета для системы, представленной выше.
Рис. 7.13. Представление решения системы дифференциальных уравнений в виде фазового портрета
Обычное решение, как правило, более наглядно, чем фазовый портрет решения. Однако для специалистов (например, в теории колебаний) фазовый портрет порою дает больше информации, чем обычное решение. Он более трудоемок для построения, поэтому возможность Maple быстро строить фазовые портреты трудно переоценить.
7.5.2. Функция DEplot из пакета DEtools
Специально для решения и визуализации решений дифференциальных уравнений и систем с дифференциальными уравнениями служит инструментальный пакет DEtools. В него входит ряд функций для построения наиболее сложных и изысканных графиков решения дифференциальных уравнений. Основной из этих функций является функция DEplot.
Функция DEplot может записываться в нескольких формах:
DEplot(deqns, vars, trange, eqns)
DEplot(deqns, vars, trange, inits, eqns)
DEplot(deqns, vars, trange, yrange, xrange, eqns)
DEplot(deqns, vars, trange, inits, xrange, yrange, eqns)
Здесь deqns — список или множество, содержащее систему дифференциальных уравнений первого порядка или одиночное уравнение любого порядка; vars — зависимая переменная или список либо множество зависимых переменных; trange — область изменения независимой переменной t; inits — начальные условия для решения; yrange — область изменения для первой зависимой пере-
менной, xrange — область изменения для второй зависимой переменной; eqns — опция, записываемая в виде keyword=value. Замена имен переменных другими в данном случае недопустима.
Эта функция обеспечивает численное решение дифференциальных уравнений или их систем при одной независимой переменной t и строит графики решения. Для автономных систем эти графики строятся в виде векторного поля направлений, а для неавтономных систем — только в виде кривых решения. По умолчанию реализуется метод Рунге-Кутта 4-го порядка, что соответствует опции method=classical[rk4],
С функцией DEplot могут использоваться следующие параметры:
• arrows=type — тип стрелки векторного поля ('SMALL', 'MEDIUM', 'LARGE', 'LINE' или 'NONE');
• colour, color = arfowcolour — цвет стрелок (задается 7 способами);
• dirgrid = [integer,integer] — число линий сетки (по умолчанию [20, 20]);
• iterations = integer — количество итераций, представленное целым числом;
• linecolor, linecolor = line_info — цвет линии (задается 5 способами);
• method='rk4' — задает метод решения ('euler', 'backeuler', 'impeuler' или 'rk4');
• obsrange = TRUE,FALSE — задает (при TRUE) прерывание вычислений, если кривая решения выходит из области обзора;
• scene = [name,name] — задает имена зависимых переменных, для которых строится график;
• stepsize=h — шаг решения, по умолчанию равный abs((b-a))/20, и представленный вещественным значением.
7.5.3. Решение системы дифференциальных уравнений модели Лотки-Вольтера
Читать дальше
Конец ознакомительного отрывка
Купить книгу