Перейдем к вычислению логических функций по графу для более широкого класса поведений. Будем рассматривать циклические автономные поведения, не содержащие кратных сигналов (или по другому: не содержащие индексированных событий). Еще одно ограничение: для удобства не будем рассматривать соединение параллельных ветвей по ИЛИ. Рассматриваем только соединение по И, то есть событие инициируется только тогда, когда сработают все его события-предшественники.

Для описания поведения будем использовать STG, но с дополнительными ограничениями. Для каждого плэйса количество входящих в него и выходящих из него дуг равно строго по одной. Соответственно, плэйс с входящей и выходящей дугами можно рассматривать как одну дугу, соединяющую два события (перехода). Соответственно маркировка перемещается по дугам. Так как поведения с кратными сигналами сейчас не рассматриваются, индексы при событиях запрещены, они не нужны. Пустые события запрещены. Также запрещена ситуация, когда две дуги, входящие в одно событие, выходят из событий, которые не параллельны друг другу (частный случай — из одного и того же события). Цель этого — избавиться от дуг, не несущих смысловой нагрузки. В остальном рассматривается корректное (нормальное, живое, безопасное) с точки зрения STG поведение с учетом вышеизложенных ограничений. Поведение не содержит CSC конфликтов.

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

Определение 2. Путь — бесконечная последовательность событий — результат изменений маркировки графа, начиная с какой-то конкретной. Каждое событие входит в последовательность бесконечное количество раз. Каждое такое вхождение уникально.

Определение 3. След события A — путь, в котором все события или непосредственное следствие события A, или результат транзитивного замыкания отношения следственности событий относительно события A. Начальная маркировка для следа события A устанавливается следующим образом. При произвольном изменении маркировки, после того как сработает событие A, маркеры в выходных дугах события A фиксируются. Далее происходит движение остальных маркеров до тех пор, пока движение маркеров не станет невозможным без снятия фиксации маркеров в выходных дугах события A. Получившаяся маркировка и есть начальная маркировка для следа события A.

Определение 4. Введем отношение упорядоченности для трех событий (A, B, C). Три события упорядочены (записывается A>B>C) тогда и только тогда, когда для любого следа события A первое вхождение события B в последовательность всегда будет происходить раньше, чем первое вхождение события C.

Замечание. Событие A может быть параллельно обоим событиям B и C (или только C), либо оба события A и B могут быть параллельны событию C.

Варианты расположения упорядоченных событий A, B и C (A>B>C).

image

Определение 5. Сигнал b (переключения B1 и B2) подхватывает сигнал a (переключения A1 и A2) относительно событий X и Y (события X и Y параллельны или совпадают), если выполняются следующие условия:

1) X>A1>A2;
2) если событие A2 параллельно событию X и не параллельно событию Y, то X>A2>Y;
3) Y>B1>B2;
4) если событие B2 параллельно событию Y и не параллельно событию X, то Y>B2>X;
5) Y>B1>A2;
6) если событие A2 параллельно событию Y и не параллельно событию X, то Y>A2>X.

image

Замечание 1. Условия 1, 2 и 3, 4 задают упорядоченность переключений сигналов a и b соответственно. Условия 5, 6 задают упорядоченность подхватывающего события B1 и подхватываемого события A2.

Замечание 2. В качестве события X может выступать событие A1. В этом случае условия 1 и 2 вырождаются.

Замечание 3. В качестве события Y может выступать событие B1. В этом случае условия 3, 4 и 5 вырождаются.

Замечание 4. В качестве события X может выступать событие A1, а также одновременно в качестве события Y может выступать событие B1. В этом случае условия 1, 2, 3, 4 и 5 вырождаются.

Теперь приступим к рассмотрению, что такое импликанта. Импликанта характеризуется событиями, в результате наступления которых импликанта меняет свое значение.

Определение 6. Событие, в результате наступления которого импликанта И (ИЛИ) меняет свое значение с 1 (0) на 0 (1), будем называть правой границей импликанты. Сигнал, соответствующий данному событию, будем называть включающим. Импликанта при этом включается.

Определение 7. Событие, в результате наступления которого импликанта И (ИЛИ) меняет свое значение с 0 (1) на 1 (0), будем называть левой границей импликанты. Сигнал, соответствующий данному событию, будем называть выключающим. Импликанта при этом выключается.

Определение 8. Импликанту, у которой какие-либо две правые (или же какие-либо две левые) границы не параллельны друг другу, будем называть прерывающейся.

Пока прерывающиеся импликанты рассматривать не будем. К их рассмотрению вернемся ниже.

Итак, мы имеем: все правые границы импликанты попарно параллельны друг другу, также и левые границы импликанты попарно параллельны друг другу.

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

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

Определение 9. Сигнал, входящий в состав импликанты, будем называть переменной.

Первое свойство переменных. Включающие и выключающие сигналы являются переменными.

Второе свойство переменных. Для всякой выключающей переменной (одно из переключений которой — левая граница импликанты L, другое — некоторое событие X) должно существовать событие — какая-то правая граница R этой же импликанты такое, что либо X и R это одно и то же событие, либо R>X>L.

Третье свойство переменных. Для всякой включающей переменной (одно из переключений которой — правая граница импликанты R, другое — некоторое событие X) должно существовать событие — какая-то левая граница L этой же импликанты такое, что либо X и L это одно и то же событие, либо R>X>L.

Четвертое свойство переменных. Для всякой переменной (переключения X1 и X2), не являющейся включающей или выключающей, должны существовать два события: какая-то левая граница импликанты L и какая-то правая граница импликанты R такие, что R>X1>L и R>X2>L. В противном случае импликанта не могла бы сохранять неизменное значение в выключенном положениии.

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

Шестое свойство переменных. Для всякой включающей переменной a, если правой границей импликанты является событие a+ (a-), то такая переменная a входит в запись импликанты И (ИЛИ) с инверсией, а в запись импликанты ИЛИ (И) без инверсии. Для всякой выключающей переменной a, если левой границей импликанты является событие a- (a+), то такая переменная a входит в запись импликанты И (ИЛИ) с инверсией, а в запись импликанты ИЛИ (И) без инверсии.

Седьмое свойство переменных. В силу четвертого свойства переменных, для всякой переменной a, не являющейся включающей или выключающей, существуют правая граница импликанты R и левая граница импликанты L такие, что R>a+>L и R>a->L. Если R>a+>a-, то такая переменная a входит в импликанту И с инверсией, а в импликанту ИЛИ без инверсии. Если R>a->a+, то такая переменная a входит в импликанту И без инверсии, а в импликанту ИЛИ с инверсией.

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

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

Теперь рассмотрим как из импликант строится нормальная форма логической функции.

Определение 10. Если для какого-то состояния импликанта находится в выключенном положении (значение импликанты И (ИЛИ) равно 1 (0)), будем говорить, что импликанта покрывает это состояние.

Рассмотрим некий сигнал x, для которого надо вычислить логическую функцию. Для построения ДНФ (КНФ) необходимо И(ИЛИ)-импликантами покрыть все состояния, на которых функция x равна 1 (0). При этом необходимо, чтобы ни одна из этих И(ИЛИ)-импликант не покрывала состояния, на которых функция x равна 0 (1). Также при вычислении логических функций необходимо учитывать специфику схемотехники: импликанты должны «перекрываться». То есть, если в каком-то состоянии импликанта может включиться (то есть может быть инициировано событие, являющееся правой границей этой импликанты) и при этом значение функции сигнала x не изменится при этом переключении, то должна существовать другая ипликанта, которая покрывает это состояние и не включается при инициации данного события.

Теперь нам надо разъяснить три вопроса. Что такое состояние в терминах графа? Как определить состояния, на которых функция сигнала x равна 1 (0)? Как определить состояния, которые импликанта покрывает?

Начнем с состояний. Всякая достижимая маркировка это состояние. Поскольку CSC конфликты отсутствуют, каждой достижимой маркировке соответствует уникальное состояние (достижимое). На недостижимых состояниях значение функции произвольно и рассматривать их нет необходимости. Таким образом, каждое состояние, которое мы рассматриваем, однозначно описывается соответствующей маркировкой. Положение каждого маркера однозначно определяется дугой, которую он маркирует. Каждой дуге однозначно сопоставляется пара (упорядоченная) событий: событие, из которого дуга выходит, и событие, в которое дуга входит. Таким образом, всякое достижимое состояние однозначно описывается множеством, состоящим из упорядоченных пар событий.

Определение 11. Пару событий, обозначающую маркированную дугу, будем записывать {P, S}, где P — событие причина, а S — событие следствие.

Определение 12. MM будем называть множество из упорядоченных пар {P, S}, которое описывает какое-то достижимое состояние.

Теперь определим для каких состояний значение функции x равно 1, а для каких — 0. Пусть причинами события x+ являются n событий A1, A2, ..., An, а причинами события x- являются m событий B1, B2, ..., Bm.

Значение функции x равно 1 если:

либо 1) для каждого i от 1 до n, пара {Ai, x+} принадлежит множеству MM;
либо 2) пара {x+, S}, такая что x+>S>x-, принадлежит множеству MM;
либо 3) пара {P, S}, такая что x+>P>x- и x+>S>x-, принадлежит множеству MM;
либо 4) пара {P, x-}, такая что x+>P>x-, принадлежит множеству MM и существует i от 1 до m, такой что пара {Bi, x-} не принадлежит множеству MM.

Значение функции x равно 0 если:

либо 1) для каждого i от 1 до m, пара {Bi, x-} принадлежит множеству MM;
либо 2) пара {x-, S}, такая что x->S>x+, принадлежит множеству MM;
либо 3) пара {P, S}, такая что x->P>x+ и x->S>x+, принадлежит множеству MM;
либо 4) пара {P, x+}, такая что x->P>x+, принадлежит множеству MM и существует i от 1 до n, такой что пара {Ai, x+} не принадлежит множеству MM.

Теперь выясним какие состояния покрывает импликанта. Пусть у импликанты n левых границ L1, L2, ..., Ln и m правых границ R1, R2, ..., Rm.

Импликанта не покрывает состояние, описываемое множеством MM, если хотя бы для одной из пар {P, S}, принадлежащей множеству MM, выполнено следующее условие: существуют такие i от 1 до n и j от 1 до m, что

либо 1) Li и S это одно и то же событие и Rj>P>Li,
либо 2) Rj и P это одно и то же событие и Rj>S>Li,
либо 3) Rj>P>Li и Rj>S>Li.

Это утверждение верно в силу пятого свойства переменных.

Импликанта покрывает состояние, описываемое множеством MM, если ни для одной из пар {P, S}, принадлежащих множеству MM, не выполненяется следующее условие: существуют такие i от 1 до n и j от 1 до m, что

либо 1) Li и S это одно и то же событие и Rj>P>Li,
либо 2) Rj и P это одно и то же событие и Rj>S>Li,
либо 3) Rj>P>Li и Rj>S>Li.

Это утверждение верно в силу второго, третьего и четвертого свойств переменных.

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

Теперь у нас есть инструмент для вычисления нормальных форм (не выяснен, правда, еще вопрос с прерывающимися импликантами). Но нас интересуют минимальные нормальные формы (с учетом специфики схемотехники). Прежде чем продолжить дальше, вернемся к рассмотрению прерывающихся импликант. Рассмотрим И-импликанту для ДНФ сигнала x (случай с ИЛИ-импликантой для КНФ аналогичен). Пусть две левые границы одной и той же импликанты L1 и L2 не параллельны друг другу и L1>L2>x- (случай для двух правых границ рассматривается аналогично). Тогда должны существовать две правые границы импликанты R1 и R2 такие, что для пар как L1 и R2, так и L2 и R1 должны выполняться второе, третье, четвертое и пятое свойства переменных. Если существует левая граница L3, параллельная L1, то для пары L3 и R2 также должны выполняться вышеуказанные свойства (аналогично в случае существования соответствующих границ импликанты, которые параллельны границам L2, R1 и R2). Но, так как кратные сигналы не используются, должна существовать не прерывающаяся импликанта с границами L1 и R2 (и с параллельными им соответствующими границами, если таковые были у прерывающейся импликанты). При этом не прерывающаяся импликанта состоит из меньшего количества переменных и покрывает все состояния, покрываемые прерывающейся импликантой, на которых значение функции сигнала x равно 1. Отсюда вывод: прерывающиеся импликанты не являются экстремалями и они не могут быть использованы для вычисления минимальных функций.

Подробнее о вычислении минимальных функций в следующей части.

Комментарии (11)


  1. Sergey_Kovalenko
    22.07.2019 12:26

    Я занимался чем-то подобным и вижу, что у Вас довольно содержательная статья. Если бы Вы смогли рассказать ее смысл используя чуть менее специальные слова, аудитория и популярность Вашей публикации могла быть значительно больше. Я сам долго учился избавляться от жаргонизмов и ставить в приоритет понятность, а не математическую точность, но это ремесло вряд ли можно постичь иначе, чем на собственном опыте проб и ошибок. У Халмоша есть книга: «Как писать математические тексты», быть может она тоже окажется Вам полезной.
    С уважением,
    Сергей Коваленко.


    1. user_man
      22.07.2019 16:31

      Да уж, все эти «плэйсы», да ещё с тривиализацией задачи — не надо нам ваших «или».

      В общем автор сумел отбить желание читать статью.


      1. ajrec Автор
        23.07.2019 16:43

        В следующий раз буду анекдотами перемежать.


        1. user_man
          24.07.2019 14:08

          Лишь бы это помогало пониманию.


    1. ajrec Автор
      23.07.2019 16:41

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


      1. Sergey_Kovalenko
        23.07.2019 17:40

        Я вижу, что Вы — специалист и пишите, наверняка, общепринятым языком для специалистов Вашей профессии. Некоторое время назад я участвовал в проекте по разработке микроэлектроники, мне знакома логика и тоже интересно то, о чем Вы рассуждаете. Могу ли я полностью понять Ваши идеи, если никогда не программировал прошивки для ПЛИС? Можно ли передать смысл исследуемой Вами проблемы, каким-то образом скрыв несущественные технические подробности? Я вполне допускаю, что часто сделать так не получается, но, если это все же удается, то результаты работы оказываются потенциально ценными далеко за пределами той области, в которой они были впервые получены.


  1. ajrec Автор
    24.07.2019 03:07

    Исследуемая проблема специальными знаниями не перегружена. В свое время мой руководитель ввел меня в курс дела буквально за полчаса. Этого хватило, чтобы сразу начать двигаться вперед.
    Суть проблемы. Имеем двоичный вектор. Координаты вектора принимают значение 0 или 1. Координаты принято называть сигналами. Исследуется процесс изменения значений сигналов. Изменение значения сигнала принято называть переключением или событием. Процесс изменения значений сигналов называют поведением. Поведение описывается на языке STG. О языке можно почитать здесь. Но вполне достаточно знать, что STG это интерпретированная сеть Петри, где каждому переходу в соответствие ставится какое-то событие. Основное требование: между двумя переключениями одного знака одного и того же сигнала обязательно должно быть переключение того же сигнала противоположного знака.
    Поведение (описанное на языке STG) — это исходное задание. Задача: построить систему логических функций, которая реализует данное поведение. При этом каждому сигналу ставится в соответствие одна функция. Логическая функция определяется на множестве всех возможных значений двоичного вектора. Каждое конкретное значение вектора называется состоянием.
    Логическая функция для сигнала определяется так. Вводится понятие возбуждения сигнала. Сигнал возбужден, если (применительно к языку описания) созданы условия для срабатывания перехода (события, переключения данного сигнала), но сам переход еще не сработал. При срабатывании перехода (переключении сигнала) возбуждение снимается. Итак логическая функция сигнала равна 1 для тех состояний, в которых сигнал равен 1 и не возбужден или же сигнал равен 0 и возбужден. Значение 0 определяется аналогично.
    Казалось бы задача тривиальная: по таблице истинности вычислить минимальную функцию. Но есть 2 «НО».
    1. Предел для машинных вычислений 20-30 сигналов («взрыв состояний»).
    2. Чем сложнее функция, тем менее реальный физический логический элемент соответствует модельным представлениям. Современные технологии подошли к порогу необходимости использования только минимальных двухвходовых элементов.
    Первая проблема решается с помощью вычисления функций непосредственно по графу (STG). Эта публикация вводная часть. Сложность вычисления одной функции пропорциональна (приблизительно) квадрату от количества событий в графе.
    Вторая проблема решается добавлением новых координат (сигналов) в двоичный вектор и соответственно в STG. При этом проекция полученного STG на первоначальные сигналы совпадает с исходным заданием. Этому посвящены другие посты.
    Данная тематика используется применительно к синтезу самосинхронных схем, поскольку в STG заложен неограниченный промежуток времени на переключение возбужденного сигнала и соответственно этим же свойством обладают полученные логические функции (логические элементы в схеме).


    1. user_man
      24.07.2019 14:00

      Вот — умеете ведь понятно объяснять!

      Но почему предел такой маленький — 20-30 сигналов? Это же 2 в степени 20-30 возможных состояний, то есть миллион-миллиард, тогда как для компьютера и триллион состояний не такая большая проблема даже при использовании простейшего перебора (ну посчитает часик, но зато всё пространство в триллион состояний охватит). При более эффективном обходе пространства состояний можно получить результат много быстрее (чем вы, похоже, как раз занимаетесь). Или рассматриваются исключительно железные реализации перебора?

      Так же интересно — как предлагаемая в статье модель описания системы соответствует подходам к моделированию нейро-сетей? Там тоже «включено-выключено» на каждом нейроне, правда с учётом весов связей, но в случае одинаковых весов — очень похоже, то есть имеем частный случай.

      И почему сложность вычисления функции пропорциональна квадрату количества переключений? Функция (комбинацию которых ставится задача найти) может описывать один элемент, и может миллион элементов — как осуществляется выбор количества элементов? Например, в случае цепочки элементов сложность будет константой, ибо входной элемент определяет выход всей цепочки (или я не понимаю способа взаимодействия элементов?).

      То есть по каждому шагу вашего рассуждения о графах из элементов нужно пройтись с точки зрения «а понятен ли данный шаг не разбирающемуся в данной специфической области технически грамотному человеку?». И тогда получится прекрасная статья.


      1. ajrec Автор
        24.07.2019 23:15

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


  1. Sergey_Kovalenko
    24.07.2019 12:55

    Благодарю за подробное объяснение, Вы решаете действительно интересную задачу. На досуге постараюсь внимательно прочитать Ваши статьи и дать обратную связь.


    1. ajrec Автор
      24.07.2019 22:57

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