Задайте коэффициенты в приложении PDE Modeler

Коэффициенты для скалярных УЧП

Чтобы ввести коэффициенты для вашего УЧП, выберите PDE > PDE Specification.

Введите текстовые выражения с помощью этих соглашений:

  • xx - координата

  • yy - координата

  • u — Решение уравнения

  • ux — Производная u в x - направление

  • uy — Производная u в y - направление

  • t — Время (параболические и гиперболические уравнения)

  • sd — Номер субдомена

Например, вы могли использовать это выражение, чтобы представлять коэффициент:

(x + y)./(x.^2 + y.^2 + 1) + 3 + sin(t)./(1 + u.^4)

Для эллиптических проблем, когда вы включаете u, ux, или uy, необходимо использовать нелинейный решатель. Выберите Solve > Parameters > Use nonlinear solver.

Примечание

  • Не используйте кавычки или ненужные пробелы в ваших записях. Синтаксический анализатор может неправильно истолковать пробел как векторную диафрагму, как тогда, когда вектор MATLAB® использует пространство, чтобы разделить элементы вектора.

  • Использование, ./, и .^ для умножения, деления и операций возведения в степень. Текстовые выражения работают с векторами-строками, таким образом, операции должны быть целесообразными для векторов-строк. Векторы-строки являются значениями в треугольных центроидах в mesh.

Можно записать функции MATLAB для выражений простого текста, а также коэффициентов. Например, предположите свой коэффициент f дан файлом fcoeff.m.

function f = fcoeff(x,y,t,sd)

f = (x.*y)./(1 + x.^2 + y.^2); % f on subdomain 1
f = f + log(1 + t); % include time
r = (sd == 2); % subdomain 2
f2 = cos(x + y); % coefficient on subdomain 2 
f(r) = f2(r); % f on subdomain 2

Используйте fcoeff(x,y,t,sd) как коэффициент f в parabolic решатель.

Коэффициент c является матрицей 2 на 2. Можно дать 1-, 2-, 3-, или матричные выражения с 4 элементами. Разделите выражения для элементов пробелами. Эти выражения среднее значение:

  • Выражение с 1 элементом: (c00c)

  • Выражение с 2 элементами: (c(1)00c(2))

  • Выражение с 3 элементами: (c(1)c(2)c(2)c(3))

  • Выражение с 4 элементами: (c(1)c(3)c(2)c(4))

Например, c является симметрической матрицей с постоянными диагональными элементами и cos(xy) как недиагональные условия:

1.1 cos(x.*y) 5.5(1)

Это соответствует коэффициентам для параболического уравнения

ut·((1.1cos(xy)cos(xy)5.5)u)=10.

Коэффициенты для систем УЧП

Можно ввести коэффициенты для системы с N = 2 уравнения в приложении PDE Modeler. Для этого откройте приложение PDE Modeler и выберите Generic System.

Затем выберите PDE > PDE Specification.

Введите символьные выражения для коэффициентов с помощью формы в Коэффициентах для Скалярных УЧП с дополнительными опциями для нелинейных уравнений. Дополнительные опции:

  • Представляйте iкомпонент th решения u использование 'u(i)' для i = 1 или 2.

  • Точно так же представляйте iкомпоненты th градиентов решения u использование 'ux(i)' и 'uy(i)' для i = 1 или 2.

Примечание

Для эллиптических проблем, когда вы включаете коэффициенты u(i), ux(i), или uy(i), необходимо использовать нелинейный решатель. Выберите Solve > Parameters > Use nonlinear solver.

Не используйте кавычки или ненужные пробелы в ваших записях.

Для более многомерных систем не используйте приложение PDE Modeler. Представляйте свои проблемные коэффициенты в командной строке.

Можно ввести скаляры в c матрица, соответствуя этим уравнениям:

·(c11u1)·(c12u2)+a11u1+a12u2=f1·(c21u1)·(c22u2)+a21u1+a22u2=f2

Если вам нужны матричные версии какого-либо cij коэффициенты, введите выражения, разделенные пробелами. Можно дать 1-, 2-, 3-, или матричные выражения с 4 элементами. Они означают:

  • Выражение с 1 элементом: (c00c)

  • Выражение с 2 элементами: (c(1)00c(2))

  • Выражение с 3 элементами: (c(1)c(2)c(2)c(3))

  • Выражение с 4 элементами: (c(1)c(3)c(2)c(4))

Например, эти выражения показывают один из каждого типа (1-, 2-, 3-, и выражения с 4 элементами)

Эти выражения соответствуют уравнениям

·((4+cos(xy)004+cos(xy))u1)·((1001)u2)=1·((.1.2.2.3)u1)·((7.6.5exp(xy))u2)=2

Коэффициенты, которые зависят вовремя и пробел

В этом примере показано, как ввести время - и координатно-зависимые коэффициенты в приложении PDE Modeler.

Решите параболический УЧП,

dut(cu)+au=f

со следующими коэффициентами:

  • d = 5

  • a = 0

  • f является линейным подъемом до 10, содержит в 10, затем сползает, отступают к 0:

    f=10*{10t0t0.110.1t0.91010t0.9t1

  • c = 1 +.x2 + y 2

Чтобы решить это уравнение в приложении PDE Modeler, выполните эти шаги:

  1. Запишите файл framp.m и сохраните его на своем пути MATLAB.

    function f = framp(t)
    
    if t <= 0.1
        f = 10*t;
    elseif t <= 0.9
        f = 1;
    else
        f = 10-10*t;
    end
    f = 10*f;
  2. Откройте приложение PDE Modeler при помощи pdeModeler команда.

  3. Отобразите линии сетки путем выбора Options> Grid.

  4. Выровняйте новые формы к линиям сетки путем выбора Options> Snap.

  5. Чертите прямоугольник с углами в (-1,-0.4), (-1 0.4), (1 0.4), и (1,-0.4). Для этого сначала нажмите кнопку. Затем кликните по одному из углов с помощью левой кнопки мыши и перетащите, чтобы чертить прямоугольник.

  6. Нарисуйте круг с радиусом 0.2 и центр в (0.5,0). Для этого сначала нажмите кнопку. Затем щелкните правой кнопкой по источнику и перетащите, чтобы нарисовать круг. Щелчок правой кнопкой ограничивает форму, которую вы чертите так, чтобы это был круг, а не эллипс. Если круг не является совершенным модульным кругом, дважды кликните его. В получившемся диалоговом окне задайте точное центральное местоположение и радиус круга.

  7. Смоделируйте геометрию путем ввода R1-C1 в поле Set formula.

  8. Проверяйте, что режим приложения установлен в Generic Scalar.

  9. Задайте граничные условия. Для этого переключитесь на граничный режим путем выбора Boundary> Boundary Mode. Используйте Shift +click, чтобы выбрать несколько контуров. Затем выберите Boundary> Specify Boundary Conditions.

    • Для прямоугольника используйте граничное условие Дирихле с h = 1 и r = t*(x-y).

    • Для круга используйте Нейманово граничное условие с g = x.^2+y.^2 и q = 1.

  10. Задайте коэффициенты путем выбора PDE> PDE Specification или нажатия кнопки PDE на панели инструментов. Выберите тип Parabolic УЧП. Задайте c = 1+x.^2+y.^2, a = 0, f = framp(t), и d = 5.

    Примечание

    Не включайте кавычки или пробелы, когда вы зададите свои коэффициенты приложение PDE Modeler. Синтаксический анализатор интерпретирует все входные параметры как векторы символов. Это может неправильно истолковать пробел как векторную диафрагму, как тогда, когда вектор MATLAB использует пространство, чтобы разделить элементы вектора.

  11. Инициализируйте mesh путем выбора Mesh> Initialize Mesh.

  12. Совершенствуйте mesh дважды путем выбора Mesh> Refine Mesh.

  13. Улучшите треугольное качество путем выбора Mesh> Jiggle Mesh.

  14. Установите начальное значение и время решения. Для этого выберите Solve> Parameters.

    В получившемся диалоговом окне, набор время к linspace(0,1,50) и начальное значение u (t 0) к 0.

  15. Решите уравнение путем выбора Solve> Solve PDE или нажатия кнопки = на панели инструментов.

  16. Визуализируйте решение как 3-D статический график. Для этого:

    1. Выберите Plot> Parameters.

    2. В получившемся диалоговом окне выберите опции Height (3-D plot) и Color.

    3. Выберите опцию Show mesh.

    4. Измените палитру в jet при помощи соответствующего выпадающего меню в том же диалоговом окне.