WikiDer > TomSym
Разработчики) | Tomlab Optimization Inc. |
---|---|
Стабильный выпуск | 7.8 / 16 декабря 2011 г. |
Операционная система | TOMLAB - Поддержка ОС |
Тип | Технические вычисления |
Лицензия | Проприетарный |
Интернет сайт | Страница продукта TomSym |
В TomSym[1] MATLAB Механизм символьного моделирования - это платформа для моделирования прикладных задач оптимизации и оптимального управления.
Описание
TomSym завершен моделирование среда в Matlab с поддержкой большинства встроенных математических операторы в Matlab. Это комбинированный моделирование, сборник и интерфейс к ТОМЛАБ решатели. В производная матрицы матричной функции является четвертым рангом тензор - то есть матрица, каждый элемент которой является матрицей. Вместо использования четырехмерных матриц для представления этого TomSym продолжает работать в двух измерениях. Это позволяет использовать преимущества очень эффективного обращения с редкий матрицы в Matlab, который недоступен для матриц более высокой размерности.
TomSym имеет множество функций, среди которых:
- Возможность преобразовывать выражения и генерировать аналитические данные первого и второго порядка. производные, включая образцы разреженности.
- Интерфейс и совместимость с СУМАСШЕДШИЙ, т.е. MAD можно использовать, когда символьное моделирование не подходит.
- Для частей модели можно использовать численное дифференцирование.
- Функциональность для построения и вычисления разнообразной информации для решения проблемы.
- Поддержка операторов if, then, else.
- Умение анализировать p-кодированный Файлы Matlab.
- Например, автоматическое упрощение кода для сгенерированных моделей.
- Умножение на 1 или единичная матрица исключено: 1 * A = A
- Добавление/вычитание 0 исключается: 0 + A = A
- Все те же матрицы сводятся к скаляры: [3; 3; 3] + x = 3 + x
- Скаляры перемещаются влево при сложении / вычитании: A-y = -y + A
- Отмена обратных операций: sqrt (x) ^ 2 = x
Моделирование
Преобразование символьного источника 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);
Рекомендации
- ^ Рутквист, Пер; М. М. Эдвалл (ноябрь 2008 г.). Руководство пользователя TOMLAB (PDF). 1260 SE Bishop Blvd Ste E, Pullman, WA 99163, USA: Tomlab Optimization Inc.CS1 maint: location (связь)
- ^ "Расположение узла авиакомпании", Домашняя страница TOMSYM Апрель 2009 г.