WikiDer > TomSym

TomSym
TomSym
Разработчики)Tomlab Optimization Inc.
Стабильный выпуск
7.8 / 16 декабря 2011 г. (2011-12-16)
Операционная системаTOMLAB - Поддержка ОС
ТипТехнические вычисления
ЛицензияПроприетарный
Интернет сайтСтраница продукта TomSym

В TomSym[1] MATLAB Механизм символьного моделирования - это платформа для моделирования прикладных задач оптимизации и оптимального управления.

Описание

TomSym завершен моделирование среда в Matlab с поддержкой большинства встроенных математических операторы в Matlab. Это комбинированный моделирование, сборник и интерфейс к ТОМЛАБ решатели. В производная матрицы матричной функции является четвертым рангом тензор - то есть матрица, каждый элемент которой является матрицей. Вместо использования четырехмерных матриц для представления этого TomSym продолжает работать в двух измерениях. Это позволяет использовать преимущества очень эффективного обращения с редкий матрицы в Matlab, который недоступен для матриц более высокой размерности.

TomSym имеет множество функций, среди которых:

  • Возможность преобразовывать выражения и генерировать аналитические данные первого и второго порядка. производные, включая образцы разреженности.
  • Интерфейс и совместимость с СУМАСШЕДШИЙ, т.е. MAD можно использовать, когда символьное моделирование не подходит.
  • Для частей модели можно использовать численное дифференцирование.
  • Функциональность для построения и вычисления разнообразной информации для решения проблемы.
  • Поддержка операторов if, then, else.
  • Умение анализировать p-кодированный Файлы Matlab.
  • Например, автоматическое упрощение кода для сгенерированных моделей.

Моделирование

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

Линейное программирование

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

 c = [-7; -5]; А = [ 1 2         4 1 ]; b_U = [ 6; 12 ]; x_L = [ 0; 0 ]; томы 2x1 х решение = Ezsolve(c'*Икс, {А*Икс<=b_U, x_L<=Икс});

Смешано-целочисленное нелинейное программирование

Задача MINLP определяется так же, как задача линейного программирования. В этом примере также показано, как преобразовать модель в общую задачу TOMLAB.

 Имя='minlp1Demo - Кочис / Гроссман.'; томы 2x1 х томы 3x1 целое число y цель = [2 3 1.5 2 -0.5]*[Икс;у]; ограничения = { ...    Икс(1) >= 0, ...    Икс(2) >= 1e-8, ...    Икс <= 1e8, ...    0 <= у <=1, ...    [1 0 1 0 0]*[Икс;у] <= 1.6, ...    1.333*Икс(2) + у(2) <= 3, ...    [-1 -1 1]*у <= 0, ...    Икс(1)^2+у(1) == 1.25, ...    sqrt(Икс(2)^3)+1.5*у(2) == 3, ... }; Угадай = структура('Икс',те(размер(Икс)),'y',те(размер(у))); опции = структура; опции.имя = Имя; Вероятно = sym2prob('minlp',цель,ограничения,Угадай,опции); Вероятно.ДАНДИ.optPar(20) = 1; Результат = tomRun('minlpBB',Вероятно,2);

Мультииндексное моделирование

tomSym позволяет строить модели с двумя или более индексами переменных в MATLAB.[2] В следующем примере создается переменная flow с четырьмя индексами. Затем переменная используется для создания ограничения для двух индексов и для суммирования умножения с двумерной матрицей.

% Создать индексы, используемые в моделия = tomArrayIdx('я',1:6);j = tomArrayIdx('j',1:6);k = tomArrayIdx('k',1:6);л = tomArrayIdx('l',1:6);% Создать целочисленную переменную полной длиныпоток = Том('поток',6^4,1,'int');% Преобразуйте переменную в матрицу с четырьмя индексами.поток = tomArray(поток,[6,6,6,6]);% Создать ограничение, действительное для всех i и jминусы = {сумма(сумма(поток(я,j,k,л),k),л) == 1};% Создайте скаляр на основе многоиндексного умножениярасстояние = tomArray([   0   945   605   4667   4749    4394;...    945     0   866   3726   3806    3448;...    605   866     0   4471   4541    4152;...    4667  3726  4471      0    109     415;...    4749  3806  4541    109      0     431;...    4394  3448  4152    415    431       0]);Итого = сумма(vec((расстояние(я,k)+расстояние(л,j)+...    расстояние(k,л)*.8).*поток(я,j,k,л)));

Автоматическое и числовое дифференцирование

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

томы х1 х2альфа = 100;% ИСПОЛЬЗОВАНИЯ MAD (АВТОМАТИЧЕСКАЯ ДИФФЕРЕНЦИАЦИЯ) ДЛЯ ОДНОЙ ФУНКЦИИ%% Создать функцию-оболочку. В данном случае мы используем грех, но это может быть любойФункция, поддерживаемая% MAD.у = сворачивать(структура('весело','грех','п',1,'sz1',1,'sz2',1,'JFuns','СУМАСШЕДШИЙ'),x1/x2);ж = альфа*(x2-x1^2)^2 + (1-x1)^2 + у;% Настройте и решите проблемуc = -x1^2 - x2;против = {-1000 <= c <= 0    -10 <= x1 <= 2    -10 <= x2 <= 2};x0 = {x1 == -1.2    x2 == 1};решение1 = Ezsolve(ж,против,x0);% ИСПОЛЬЗУЙТЕ ЧИСЛЕННУЮ ДИФФЕРЕНЦИЮ ДЛЯ ОДНОЙ ФУНКЦИИ% Создать новую функцию-оболочку. В этом случае мы используем грех, но это может быть% любая функция, поскольку мы используем числовые производные.у = сворачивать(структура('весело','грех','п',1,'sz1',1,'sz2',1,'JFuns','FDJac'),x1/x2);ж = альфа*(x2-x1^2)^2 + (1-x1)^2 + у;решение2 = Ezsolve(ж,против,x0);

Рекомендации

  1. ^ Рутквист, Пер; М. М. Эдвалл (ноябрь 2008 г.). Руководство пользователя TOMLAB (PDF). 1260 SE Bishop Blvd Ste E, Pullman, WA 99163, USA: Tomlab Optimization Inc.CS1 maint: location (связь)
  2. ^ "Расположение узла авиакомпании", Домашняя страница TOMSYM Апрель 2009 г.

внешняя ссылка