Матрица оценки разности - Difference bound matrix

В проверка модели, поле Информатика, а матрица границ разностей (DBM) это структура данных используется для обозначения выпуклых многогранники называется зоны. Эта структура может использоваться для эффективного выполнения некоторых геометрических операций над зонами, таких как проверка пустоты, включения, равенства и вычисление пересечения и суммы двух зон. Он, например, используется в Аппальская модель проверки; где он также распространяется как независимая библиотека.[1]

Точнее, есть понятие канонической DBM; существует взаимно однозначное отношение между каноническими DBM и зонами, и из каждой DBM можно эффективно вычислить канонический эквивалент DBM. Таким образом, равенство зон можно проверить, проверив равенство канонических DBM.

Зона

Матрица разностных границ используется для представления выпуклых многогранников. Эти многогранники называются зона. Теперь они определены. Формально зона определяется уравнениями вида , , и , с и некоторые переменные и константа.

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

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

Пример

Как сказано во введении, мы рассматриваем зону, определяемую набором операторов вида , , и , с и некоторые переменные и константа. Однако некоторые из этих ограничений либо противоречивы, либо избыточны. Приведем такие примеры.

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

Мы также приводим пример, показывающий, как создавать новые ограничения из существующих ограничений. Для каждой пары часов и , у DBM есть ограничение в виде , куда либо <, либо ≤. Если такое ограничение не может быть найдено, ограничение может быть добавлен к определению зоны без потери общности. Но в некоторых случаях можно найти более точное ограничение. Сейчас будет приведен такой пример.

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

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

Определение

Теперь исправим моноид который является подмножеством реальной линии. Этот моноид традиционно представляет собой набор целые числа, рациональные, реалы, или их подмножество неотрицательных чисел.

Ограничения

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

  • Вместо можно использовать произвольный упорядоченный моноид.
  • Чтобы различать "" и ""набор элементов алгебры должен содержать информацию о том, строгий порядок или нет.

Определение ограничений

Набор удовлетворительные ограничения определяется как набор пар вида:

  • , с , который представляет собой ограничение вида ,
  • , с , куда не является минимальным элементом , который представляет собой ограничение вида ,
  • , что означает отсутствие ограничения.

Набор ограничений содержит все выполнимые ограничения, а также следующее невыполнимое ограничение:

  • .

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

Работа с ограничениями

Чтобы сгенерировать единственное ограничение из пары ограничений, применяемых к одной (паре) переменной, мы формализуем понятие пересечения ограничений и порядка над ограничениями. Точно так же, чтобы определить новые ограничения из существующих ограничений, также должно быть определено понятие суммы ограничений.

Порядок ограничений

Теперь мы определим отношение порядка над ограничениями. Этот порядок символизирует отношение включения.

Во-первых, набор рассматривается как упорядоченный набор, где <уступает ≤. Интуитивно этот порядок выбран, потому что набор, определенный строго входит в набор, определяемый . Затем мы утверждаем, что ограничение меньше чем если либо или же ( и меньше чем ). То есть порядок ограничений - это лексикографический порядок применяется справа налево. Обратите внимание, что этот заказ общий заказ. Если имеет свойство с наименьшей верхней границей (или же свойство наибольшей нижней границы ) то набор ограничений тоже есть.

Пересечение ограничений

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

Сумма ограничений

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

Ограничения как алгебра

Вот список алгебраических свойств, которым удовлетворяет набор ограничений.

  • Обе операции ассоциативный и коммутативный,
  • Сумма распределительный на пересечении, то есть для любых трех ограничений, равно ,
  • Операция пересечения идемпотентна,
  • Ограничение тождество операции пересечения,
  • Ограничение тождество для операции суммы,

Кроме того, над выполнимыми ограничениями верны следующие алгебраические свойства:

  • Ограничение является нулем для операции суммирования,
  • Отсюда следует, что множество выполнимых ограничений есть идемпотентное полукольцо, с как ноль и как единство.
  • Если 0 - минимальный элемент , тогда является нулем для ограничений пересечения над выполнимыми ограничениями.

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

DBM

Учитывая набор переменные, , DBM - это матрица со столбцом и строками, индексированными и записи являются ограничениями. Интуитивно для столбца и ряд , Значение на позиции представляет . Таким образом зона, определяемая матрицей , обозначаемый , является .

Обратите внимание, что эквивалентно , поэтому запись по сути все еще является верхней границей. Заметим, однако, что, поскольку мы рассматриваем моноид , для некоторых значений и реальный фактически не принадлежит моноиду.

Прежде чем вводить определение канонической DBM, нам нужно определить и обсудить отношение порядка для этих матриц.

Заказ на эти матрицы

Матрица считается меньше матрицы если каждая из его записей меньше. Обратите внимание, что этот заказ не является полным. Учитывая две DBM и , если меньше или равно , тогда .

Точная нижняя грань двух матриц и , обозначаемый , имеет в качестве введите значение . Обратите внимание, что поскольку - операция «сумма» полукольца ограничений, операция представляет собой «сумму» двух DBM, где набор DBM рассматривается как модуль.

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

Определено пересечение матриц / зон. Операция объединения не определена, и действительно, объединение зоны не является зоной в целом.

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

Первое определение канонической DBM

Мы повторяем определение каноническая разностная граничная матрица. Это DBM, в которой никакая меньшая матрица не определяет тот же набор. Ниже объясняется, как проверить, является ли матрица DBM, и как вычислить DBM из произвольной матрицы, чтобы обе матрицы представляли один и тот же набор. Но сначала приведем несколько примеров.

Примеры матриц

Сначала рассмотрим случай, когда есть одни часы .

Настоящая линия

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

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

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

Пустой набор

Теперь мы рассмотрим множество матриц, каждая из которых кодирует пустой набор. Сначала дадим канонический DBM для пустого набора. Затем мы объясняем, почему каждый из DBM кодирует пустой набор. Это позволяет находить ограничения, которым должна удовлетворять любая DBM.

Каноническая DBM пустого множества по одной переменной равна . В самом деле, он представляет собой множество, удовлетворяющее ограничению , , и . Эти ограничения невыполнимы.

DBM также кодирует пустой набор. В самом деле, он содержит ограничение что неудовлетворительно. В более общем плане это показывает, что запись не может быть если все записи не .

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

DBM также кодирует пустой набор. Действительно, он содержит ограничения и которые противоречивы. В более общем плане это показывает, что для каждого , если , тогда и оба равны ≤.

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

Строгие ограничения

Примеры, приведенные в этом разделе, аналогичны примерам, приведенным в разделе «Примеры» выше. На этот раз они представлены как DBM.

DBM представляет набор, удовлетворяющий ограничениям и . Как упоминалось в разделе «Пример», оба этих ограничения подразумевают, что . Это означает, что DBM кодирует ту же зону. Собственно, это DBM этой зоны. Это показывает, что в любой DBM , для каждого , ограничение меньше, чем ограничение .

Как объяснялось в разделе «Пример», константа 0 может рассматриваться как любая переменная, что приводит к более общему правилу: в любой DBM , для каждого , ограничение меньше, чем ограничение .

Три определения канонической DBM

Как объяснено во введении к разделу Матрица разности границ, канонический DBM - это DBM, строки и столбцы которого индексируются , записи которого являются ограничениями. Кроме того, он обладает одним из следующих эквивалентных свойств.

  • не существует DBM меньшего размера, определяющего ту же зону,
  • для каждого , ограничение меньше, чем ограничение
  • Учитывая ориентированный граф с краями и стрелы помеченный , кратчайший путь от любого края к любому краю это стрела . Этот граф называется потенциальный граф DBM.

Последнее определение можно напрямую использовать для вычисления канонической DBM, связанной с DBM. Достаточно применить Алгоритм Флойда-Уоршолла к графу и ассоциированным к каждой записи кратчайший путь от к в графике. Если этот алгоритм обнаруживает цикл отрицательной длины, это означает, что ограничения невыполнимы, и, следовательно, зона пуста.

Операции по зонам

Как было сказано во введении, основной интерес DBM заключается в том, что они позволяют легко и эффективно выполнять операции с зонами.

Напомним сначала операции, которые были рассмотрены выше:

  • тестирование на включение зоны в зоне выполняется путем проверки того, что каноническая DBM меньше или равен каноническому BDM ,
  • DBM для пересечения набора зон - это наибольшая нижняя граница DBM этих зон,
  • проверка на пустоту зоны заключается в проверке того, состоит ли каноническая DBM зоны только из ,
  • проверка того, является ли зона всем пространством, заключается в проверке того, состоит ли DBM зоны только из .

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

Сумма зон

В Сумма Минковского двух зон, определяемых двумя DBM и , определяется DBM чей запись . Обратите внимание, что поскольку - операция «произведение» полукольца ограничений, операция над DBM на самом деле не является операцией модуль DBM.

В частности, следует, что для того, чтобы перевести зону по направлению , достаточно добавить DBM в DBM .

Проекция компонента на фиксированное значение

Позволять константа.

Учитывая вектор , а индекс , проекция -й компонент к это вектор . На языке часов для , это соответствует сбросу -ые часы.

Проектирование -й компонент зоны к состоит просто из множества векторов с их -й компонент к . Это реализовано в DBM путем настройки компонентов к и компоненты к

Будущее и прошлое зоны

Назовем будущее зона и прошлый зона . Учитывая точку , то будущее определяется как , а прошлое определяется как .

Имена будущего и прошлого происходят от понятия Часы. Если набор часам присваиваются значения , и т. д., то в их будущем набор задач, которые у них будут, - это будущее .

Учитывая зону , то будущее являются объединением будущего каждой точки зоны. Определение прошлое зоны похож. Таким образом, будущее зоны можно определить как , и, следовательно, может быть легко реализован как сумма DBM. Однако есть даже более простой алгоритм, который можно применить к DBM. Достаточно изменить каждую запись к . Точно так же прошлое зоны можно вычислить, установив каждую запись к .

Смотрите также

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

  1. ^ http://people.cs.aau.dk/~adavid/UDBM/index.html
  2. ^ Укроп, Дэвид L (1990). «Временные предположения и проверка конечных параллельных систем». Конспект лекций по информатике. 407: 197–212. Дои:10.1007/3-540-52148-8_17. ISBN  978-3-540-52148-8.