Операциям присвоения и инверсии требуется одна строка (рис. 37), операциям синхронизации — две (рис. 38). На первой строке для операции синхронизации формируется сигнал, передний или задний фронт которого необходимо обнаружить. На строке ниже записывается операция синхронизации и вычисляется результат. Примеры операций синхронизации показаны на рис. 38. Результат текущего пересчета таблицы обозначим как b1a, а как b0 — результат предыдущего. Если предыдущее значение операнда было ноль, а текущее значение — единица, то программа пересчета таблицы фиксирует переход из ноля в единицу — передний фронт. Если был переход из единицы в ноль, то это задний фронт. При обнаружении фронта сигнала результату операции синхронизации будет присвоена единица, которая продержится всего один цикл пересчета таблицы, после чего результат операции синхронизации вернется в ноль. В течение одного цикла единица на выходе операции синхронизации может запустить таймер, сбросить или установить значение в триггерной ячейке, изменить результат логического И по столбцу.
Аналоговая операция присвоения устанавливает результат, равный входному значению переменной (рис. 39).
Битовым логическим операциям, операциям сравнения аналоговых переменных и арифметическим операциям требуется два операнда, один из которых находится в предыдущей строке, а другой — в строке выше предыдущей. Всего для этих операций требуется три строки.
Представленный в таблице на рис. 40 базовый набор операций может быть дополнен другими математическими операциями. Написание тестовых программ для различного оборудования показало, что для большинства применений достаточно использования базового набора. При необходимости сложных расчетов значений от датчиков лучше применить дополнительные контроллеры первичной обработки сигналов — для того, чтобы не усложнять логику управляющей программы.
Ход выполнения операции с двумя битовыми операндами можно рассмотреть на примере логического И. На рис. 41 представлен ход выполнения такой операции. Так как программа пересчета таблицы проходит по строкам сверху вниз, то сначала будет вычислен первый операнд, b1a. Его значение будет зависеть от состояния переменной b1 и от необходимости ее инвертировать. Если переменную b1 необходимо инвертировать, то b1a получит инвертированное значение b1, а если такой необходимости нет, то b1a станет равной b1. Аналогичное действие будет проведено с переменной b2. После этого результату b3 будет присвоено значение логического И b1a и b2a.
Арифметические операции с аналоговым результатом можно рассмотреть на примере сложения (рис. 42). Аналогично производятся операции вычитания, умножения и деления.
Операции сравнения используют аналоговые операнды и имеют битовый результат, который может далее использоваться в любых битовых операциях. На рис. 43 показана операция «больше» для двух аналоговых переменных. Справа от результата записана эта же операция на текстовом языке программирования.
Операции выбора используют три операнда, два из которых — входные переменные, а третий определяет, значение какой переменной появится на выходе (рис. 44). По сути, это аналоговый или битовый мультиплексоры.
На рис. 45 показана операция выбора одного из двух битовых значений SELB, в которой все три операнда и результат битовые.
Для выбора одного из двух аналоговых значений используется операция SEL, в которой первые два операнда и результат аналоговые, а битовый операнд определяет, какое из входных аналоговых значений будет присвоено результату (рис. 46).