Троичные функции

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

Элементы множества — цифровые знаки 0, 1 и 2 могут интерпретироваться как логические «ложь», «неизвестно» и «истина», в общем случае их смысл может быть любым. Элементы называют троичными векторами. В случае n = 0 троичная функция превращается в троичную константу.

Каждая троичная функция арности n полностью определяется заданием своих значений на своей области определения, то есть на всех троичных векторах длины n. Число таких векторов равно 3n. Поскольку на каждом векторе трёхзначная функция может принимать одно из трёх различных значений, то количество всех n-арных троичных функций равно 3(3n) (скобки нужны, так как запись 33n не обладает свойством ассоциативности и 3(32)=39=19683, а (33)2=272=729).

Например, существует 3(30) = 3 нульарных троичных логических функций — константы 0, 1 и 2; 3(31) = 27 унарных троичных логических функций, 3(32) = 19683 бинарных троичных логических функций и т. д.

Троичные логические функции (классификация)

Уровни привязки значений к трём состояниям троичных устройств

В некоторых троичных устройствах все три состояния одинаковы и ни логические ни арифметические значения не определены[1], не определено и направление сдвига, либо правое (по часовой стрелке), либо левое (против часовой стрелки), но на этом уровне уже можно закрепить одно из двух направлений вращения и уже отличать левое вращение от правого вращения.
На втором уровне за тремя состояниями могут быть закреплены три значения, но ещё без привязки арифметических значений, например, треугольник, квадрат и круг. На втором уровне становится возможным привязка логических значений («ложно», «не определено», «истинно»), например:
«треугольник» = «ложно»,
«квадрат» = «не определено»,
«круг» = «истинно»,
хотя в общем случае привязка может быть и другой.
На втором уровне логические значения арифметических значений не имеют.
На третьем уровне трём состояниям приписываются арифметические значения: 0, 1 и 2 или −1, 0 и +1. На третьем уровне логические значения условно имеют и арифметические значения. Наиболее часто встречается привязка арифметических значений не совместимая с обычной привязкой в двоичной логике:
«ложно» = −1,
«не определено» = 0,
«истинно» = +1,
хотя в общем случае привязка арифметических значений может быть и другой, например, привязка:
«ложно» = 0,
«не определено» = 2,
«истинно» = 1,
совместима с обычной привязкой в двоичной логике и соответствует левому вращению при обычной привязке последовательности арифметических значений (0,1,2).

В других троичных устройствах три состояния отличаются, например, по полярности напряжения, и не равнозначны[2]. В этих устройствах очень сильна привязка к уровням напряжения и арифметических и логических значений:
«отрицательное напряжение» = «-1» = «-» = «ложно»,
«близкое к нулю напряжение» = «0» = «не определено»,
«положительное напряжение» = «+1» = «+» = «истинно»,
но и в этих устройствах возможны другие привязки.

Для работы с третьим логическим значением — «не определено» лучше подходят четверичная логика, восьмиричная логика и другие логики кратные 4, чем троичная логика.

Обозначения троичных функций

В общем случае, как в патентном деле, обозначение может быть любым, но необходимо указывать что обозначает каждый элемент в обозначении.
Единой системы обозначений троичных функций ещё не сложилось. Разные авторы применяют разные системы обозначений троичных функций. Пример различных обозначений унарных троичных функций разными авторами приведён в таблице 3 и в подразделе «Обозначения» там же.

При одновременной работе с троичными и двоичными функциями необходимо указывать троичность или двоичность. Это можно сделать буквами T (Ternary) и B (Binary). Например, FT — троичная функция, а FB — двоичная функция.

Так как функции могут иметь разное количество аргументов (арность), то необходимо указывать и арность функций. Так как унарные, бинарные, тринарные и т. д. функции имеются и в двоичной и в троичной и в более -ичных системах, то обозначение системы должно предшествовать обозначению арности. Например, FT1 — троичная унарная функция, FT2 — троичная бинарная функция, FT3 — троичная тринарная функция.

Так как половина номеров разных троичных симметричных и троичных несимметричных функций совпадают, то нужно указывать симмеричность или несимметричность номера функции. Это можно сделать буквами S (Symmetric) и N (Nonsymmetric). Например, FT1S — троичная унарная функция с симметричным номером, FT1N — троичная унарная функция с несимметричным номером, а FT2B1N — смешанная функция с двумя троичными аргументами, с одним двоичным аргументом и с несимметричным номером.

После можно поставить номер функции. Например, FT1N7 — троичная унарная функция с несимметричным номером «7».

Так как некоторые разные номера в троичном и в десятичном виде совпадают, например, 22 троичное равно 8 десятичным, то после номера нужно ставить индекс обозначающий основание системы счисления. Например, FB2N2210, FT2S223, FT2N2210 — это три разные функции.

Названия троичных функций

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

Соответствия троичной несимметричной и троичной симметричной систем обозначений

В троичной симметричной системе обозначений арифметические значения −1, 0 и +1 очень сильно связаны с логическими обозначениями (−1, 0, +1) или (−, 0, +). Во втором обозначении 1 явно не присутствует, но неявно подразумевается.

В троичной несимметричной системе обозначений, кроме 0 и +1, арифметические значения −1, 0 и +1 менее сильно связаны с логическими обозначениями (0,1,2).

Из таблицы 4 следует, что:

F1TN0 = F1TS-13
F1TN13 = F1TS0
F1TN26 = F1TS+13

или

F1TS-13 = F1TN0
F1TS0 = F1TN13
F1TS+13 = F1TN26,

то есть трёхразрядные троичные номера унарных троичных функций с симметричным кодированием сдвинуты по отношению к номерам унарных троичных функций с несимметричным кодированием на
Девятиразрядные троичные номера бинарных троичных функций с симметричным кодированием сдвинуты по отношению к номерам бинарных троичных функций с несимметричным кодированием на

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

Перевод троичных несимметричных чисел в троичные симметричные числа

Троичные несимметричные числа с кодировкой (-1,0,+1)=(0,1,2) относительно просто преобразуются в троичные симметричные числа с кодировкой (-1,0,+1)=(2,0,1) с помощью следующего алгоритма[3] (Ошибка Депмана И. Я.: Для записи цифр в трёхзначных системах, в том числе и в числовых троичных системах, требуется три знака. В обозначениях Депмана третьим знаком является надчёркнутая единица — «1», но третьим знаком может быть и «2» и «i» и «7» и «N» и «n» и любой другой знак отличный от знаков «0» и «1».):
1. Начиная со младшего разряда троичного несимметричного числа с кодировкой (-1,0,+1)=(0,1,2):
2. Если число в текущем разряде больше 1 (2 или 3), то в следующий разряд прибавляется 1 (2 остаётся, но уже как обозначение −1); если число в текущем разряде равно 3, то текущий разряд устанавливается в 0.
3. Переход к следующему по старшинству разряду.
Для отрицательных троичных несимметричных чисел преобразование делают от модуля троичного несимметричного числа, а в результате, во всех разрядах, заменяют «1» на «2», а «2» на «1» с помощью троичной симметричной функции Swap12(X).

Нульарные троичные логические операции (функции) с унарным выходом

Всего существуют простейшие нульарные троичные функции (троичные константы).
С кодированием в троичной несимметричной системе счисления:

Таблица 1
ОбозначениеНазваниеЗначение
FT0N0 Логический тождественный ноль0
FT0N1 Логическая тождественная единица1
FT0N2 Логическая тождественная двойка2

С кодированием в троичной симметричной системе счисления:

Таблица 2
ОбозначениеНазваниеЗначение
FT0S-1 Тождественная минус единица-1
FT0S0 Тождественный ноль0
FT0S1 Тождественная плюс единица1

Унарные троичные логические функции

Унарные троичные логические функции с унарным выходом

Всего существует простейших унарных (с одним входом, с одним аргументом, с одним операндом, одноместных) троичных функций, где m — число выходов, выходная арность функции. Для унарных (с одним входом) троичных функций с унарным выходом m=1 и их число равно .
Количество простейших унарных троичных функций равно числу размещений с повторениями (выборок с возвращением) при k=n=3:

Так как возможны более сложные функции, дающие при подаче на вход одного трита тот же результат, что и простейшие унарные троичные функции, то число более сложных троичных функций с нижеприведёнными результатами от одного трита теоретически бесконечно.
Таблица 1. Результаты действия простейших унарных троичных функций при последовательной подаче на вход трёх значений троичного разряда (трита): 0, 1 и 2.
В несимметричной троичной системе кодирования (-1,0,+1) = (0,1,2):
Таблица 3.

y\x210названиеобозначение
FT1N0=FT1S-13 000тождественный минимум, тождественный ноль, переход в 0F000(X) = 0
FT1N1=FT1S-12 001троичная эмуляция двоичной функции NOT2, переходник в двоичнуюF001(X) = NOT2(X)
FT1N2=FT1S-11 002переходник в двоичнуюF002(X)
FT1N3=FT1S-10 010троичная эмуляция двоичной функции YES2, переходник в двоичнуюF010(X) = YES2(X)
FT1N4=FT1S-9 011троичная эмуляция двоичной функции «тождественная 1», переходник в двоичнуюF011(X) = 12
FT1N5=FT1S-8 012обмен 0 и 2, обмен двух младших значений при кодировании (-1,0,+1)=(2,0,1), обмен двух крайних значений («инверсия Лукасевича») при кодировании (-1,0,+1)=(0,1,2) F1TN510(X) = F0123(X) = Swap02(X)
FT1N6=FT1S-7 020переходник в двоичнуюF020(X)
FT1N7=FT1S-6 021вращение вправо (вперёд, вверх) на 1 шаг (+1 шаг, +1/3 оборота, +120°), циклический сдвиг вправо (вперёд, вверх) на 1 шаг (+1 шаг, +1/3 оборота, +120°), Rotate Up по Стиву Граббу[4], Cicle Up[5] F021(X) = RotF(x) = RotU(x) = RotR(x) = CicleShiftU(x)
FT1N8=FT1S-5 022переходник в двоичную FT1N810(X) = F0223(X)
FT1N9=FT1S-4 100не циклический сдвиг влево (назад, вниз) с пределом 0, не циклический сдвиг влево (назад, вниз) на −1 с пределом 0, не циклический Decrement с пределом 0, Shift Down по Стиву Граббу[6] F100(X) = ShiftD(x) = ShiftL(X)
FT1N10=FT1S-3 101переходник в двоичнуюF101(X)
FT1N11=FT1S-2 102вращение влево (назад, вниз) на 1 шаг (-1 шаг, −1/3 оборота, −120°), циклический сдвиг влево (назад, вниз) на 1 шаг (-1 шаг, −1/3 оборота, −120°), Rotate Down по Стиву Граббу[7], Cicle Down[5] F102(X) = RotB(x) = RotD(x) = RotL(x) = CicleShiftD(x)
FT1N12=FT1S-1 110переходник в двоичнуюF110(X)
FT1N13=FT1S0 111тождественная середина, переход в 1, тождественная единицаF111(X) = 1
FT1N14=FT1S+1 112переходник в двоичную FT1N1410(X) = F1123(X)
FT1N15=FT1S+2 120обмен 1 и 2, обмен двух крайних значений («инверсия Лукасевича») при кодировании (-1,0,+1)=(2,0,1), обмен двух старших значений при кодировании (-1,0,+1)=(0,1,2)FT1N1510(X) = F1203(X) = Swap12(X)
FT1N16=FT1S+3 121переходник в двоичнуюF121(X)
FT1N17=FT1S+4 122переходник в двоичную FT1N1710(X) = F1223(X)
FT1N18=FT1S+5 200переходник в двоичнуюF200(X)
FT1N19=FT1S+6 201обмен 0 и 1, обмен двух старших значений при кодировании (-1,0,+1)=(2,0,1), обмен двух младших значений при кодировании (-1,0,+1)=(0,1,2)FT1N1910(X) = F2013(X) = Swap01(X)
FT1N20=FT1S+7 202переходник в двоичнуюF202(X)
FT1N21=FT1S+8 210вращение нулевое, повторитель, Yes, Buffer1, Delay1 (линия задержки на 1 типовую задержку), тождественная функцияF210(X) = Yes(x) = Rot0(x) = CicleShift0(X) = x
FT1N22=FT1S+9 211переходник в двоичнуюF211(X)
FT1N23=FT1S+10 212переходник в двоичнуюF212(X)
FT1N24=FT1S+11 220переходник в двоичнуюF220(X)
FT1N25=FT1S+12 221не циклический сдвиг вправо (вперёд, вверх) с пределом 2, не циклический сдвиг вправо (вперёд, вверх) на +1 с пределом 2, не циклический Increment с пределом 2, Shift Up по Стиву Граббу[8] F221(X) = ShiftU(x)
FT1N26=FT1S+13 222тождественный максимум, переход в 2, тождественная двойкаF222(X) = 2

По таблице видно, что при последовательной подаче на вход функции значений от 0 до 2, на выходе функции образуется строка, например, «022»3, которая является и номером функции и строкой её действия, то есть и номер функции и строка её действия содержатся в самой функции. Это свойство может оказаться полезным в случае невозможности чтения номера функции на корпусе микросхемы (стёрся, закрашен, не доступен).

По таблице видно, что выходные триты, после действия функций, в 21 случае из 27 теряют трёхзначность и в 18 случаях становятся двухзначными (переходниками в двоичную логику), а в 3 случаях становятся однозначными константами (переходниками к константам) (FT1N0, FT1N13 и FT1N26), и только в 6 случаях (три обмена, два вращения и повторитель) остаются трёхзначными (FT1N5, FT1N7, FT1N11, FT1N15, FT1N19 и FT1N21).

Снимок модели троичного унарного с унарным выходом АЛУ (1Трит-1Трит) в трёхбитной одноединичной системе троичных логических элементов в логическом симуляторе Atanua[9]

Все 27 унарных троичных операций (функций) выполняются троичным унарным с унарным выходом АЛУ (1Трит-1Трит) в трёхбитной одноединичной системе троичных логических элементов, снимок модели которого в логическом симуляторе Atanua приведён на рисунке справа, и записываются в троичный триггер с соответствующей логикой управления.

Обозначения

Для обозначения унарных троичных функций достаточно любых трёх троичных знаков (33=27), 4/3 девятеричного знака (9(4/3)=27) или одного двадцатисемеричного знака, следовательно, так как возможно бесконечное количество таких знаков, возможно бесконечное множество обозначений унарных троичных функций. Из этого множества обозначений числовые обозначения по результатам действия функций являются естественными обозначениями.

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

Grabb[10] использует для обозначения шесть знаков: ∪, ∩, ↘, ↗, A, A, из которых 5 труднонабираемы на клавиатуре. Два шестеричных знака могут выразить до 62=36 функций, тем не менее Grabb использует для обозначения −7, −3, 3 и 7 функций четыре знака, что относительно избыточно (64=1296).

Mouftah использует для обозначения 16 знаков: ¬, ¬, ⌐, , ┘, , └, , ⊼, ⊽, 0, +, (,), A, A, из которых 11 трудно набираемы на клавиатуре. Два шестнадцатеричных знака могут выразить до 112=256 функций, тем не менее для −6 и −2 функций Mouftah использует 11 знаков, что относительно избыточно (1611=17592186044416).

Yoeli обозначает положительные декодеры −1, 0 и +1 с двумя и тремя трудно набираемыми на клавиатуре надстрочными индексами, при этом не описываются положительные декодеры с двумя 0, нулевые декодеры с двумя 1 и с двумя −1, отрицательные декодеры с двумя 0 и с двумя 1.

В симметричной троичной системе:
Таблица 4.

y\x10iназваниеобозначениеF#[5]GrubbMouftahНазвание по Mouftah/Yoeli[5]Diff:101Маслов С. П.[11]
FT1S-13=FT1N0 iiiпереходник в −1, тождественная −1, тождественный минимумFiii(X) = −1111always output 1
FT1S-12=FT1N1 ii0сдвиг вниз, сдвиг на −1Fii0(X)ii0↘A = Shift Down¬┘A-L, M3
FT1S-11=FT1N2 ii1переходник в двоичную, детектор −1 с true=1 false=-1Fii1(X)ii1∩↗A└┘A = ┘A = ┘A = ┘┘Ax1 (Yoeli), decode-1
FT1S-10=FT1N3 i0iпереходник в двоичную, замена 1 на −1Fi0i(X)i0i↘∩A
FT1S-9=FT1N4 i00переходник в двоичнуюFi00(X)i00↘↗A⌐AReverse DiodeM8
FT1S-8=FT1N5 i01обмен +1 и −1, «инверсия Лукасевича», «Invert» по Стиву Граббу[12], Complement(F210) по Полю Фальстаду[13]Fi01(X) = «NOTL(Х)» = «NotL(X)» = «InvL(X)» = «Not0(X)» = Swap+1/-1101swap1/1, AASimple Ternary Inverter\'/
FT1S-7=FT1N6 i1iпереходник в двоичную, детектор 0 с true=1 false=-1Fi1i(X)i1i∩↗∪A┘(A + A)x0 (Yoeli), decode-0
FT1S-6=FT1N7 i10вращение вперёд на 1/3 оборота (+120°)Fi10(X) = RotF(X) = RotU(X) = RotRight(x)011rotate up,
∩A
(└A ⊼ 0)⊼(┘A) — inverse cycling gatecycle up///
FT1S-5=FT1N8 i11переходник в двоичную, F220 по Полю Фальстаду[14], «инверсия Лукасевича» от детектора +1Fi11(X)i11∪↘A┘└A = ┘A = └└A
FT1S-4=FT1N9 0iiне циклический сдвиг вниз, не циклический сдвиг на −1F0ii(X)0iiA⌐└AEarthed Negative Ternary InverterM7
FT1S-3=FT1N10 0i0переходник в двоичнуюF0i0(X)0i0∪↗∪A
FT1S-2=FT1N11 0i1вращение назад на 1/3 оборота (−120°)F0i1(X) = RotB(x) = RotD(X) = RotLeft(x)110rotate down,
∪A
(┘A ⊽ 0)⊽(└A) — cycling gatecycle down\\\
FT1S-1=FT1N12 00iпереходник в двоичную, замена +1 на 0F00i(X)00i∪↗A⌐└A = ⌐A-R, M4
FT1S0=FT1N13 000переходник в 0, тождественный 0, тождественная серединаF000(X) = 0000always output 0
FT1S+1=FT1N14 001F211 по Полю Фальстаду[15], переходник в двоичнуюF001(X)001↗↘A¬AForward DiodeM5
FT1S+2=FT1N15 01iобмен 0 и 1F01i(X) = «NOT0(Х)» = «NOT-1(X)»110swap 0/1swap 0/1'/\
FT1S+3=FT1N16 010переходник в двоичнуюF010(X)010∩↘∩A
FT1S+4=FT1N17 011F221 по Полю Фальстаду[16], переходник в двоичнуюF011(X)011⌐└A+L, M2
FT1S+5=FT1N18 1iiпереходник в двоичную, детектор 1 с true=1 false=-1F1ii(X)1ii∩↗A└ANegative Ternary Inverter (Mouftah), xi (Yoeli), decode-i
FT1S+6=FT1N19 1i0обмен 0 и −1F1i0(X) = «NOT2(Х)» = «NOT+1(x)»011swap 1/0swap 1/0/\'
FT1S+7=FT1N20 1i1переходник в двоичную, «инверсия Лукасевича» от детектора 0F1i1(X)1i1∪↘∩A
FT1S+8=FT1N21 10iвращение нулевое, повторитель, Yes, тождественная функция, линия задержки, знак числаF10i(X) = Sgn(X)101Buffer
A
ABuffer
FT1S+9=FT1N22 100переходник в двоичнуюF100(X)100∩↘A¬A+R, M1
FT1S+10=FT1N23 101переходник в двоичнуюF101(X)101↗∪A
FT1S+11=FT1N24 11iпереходник в двоичную, «инверсия Лукасевича» от детектора −1F11i(X)11i∪↘A┘APositive Ternary Inverter
FT1S+12=FT1N25 110не циклический сдвиг вверх, не циклический сдвиг на +1F110(X)110↗A = Shift Up,↗A¬┘AEarthed Positive Ternary InverterM6
FT1S+13=FT1N26 111переходник в +1, тождественная +1, тождественный максимумF111(X) = 1111always output 1

Знаки «i», «1», «7» и «2» обозначают «-1».
По таблице видно, что при симметричном кодировании, функции являются теми же самыми, что и при несимметричном кодировании, только номера функций смещены на −13, и при замене знаков (-1,0,+1) на знаки (0,1,2) получается таблица унарных троичных функций в несимметричной троичной системе с соответствием (-1,0,+1) = (0,1,2).
Если знак «i» заменить на знак «2», то номера функций будут отличаться от номеров функций в таблице с несимметричным кодированием только на «вращение на 1 вперёд» несимметричного номера, то есть на функцию FT1N7 (RotF) от несимметричного номера.
Соответственно, что бы получить номер функции в таблице с несимметричным кодированием, в номере с симметричным кодированием нужно заменить знак «i» на знак «2» и взять от каждого его разряда троичную функцию «вращение на 1 назад» (FT1N11, RotB).

Троичная логическая тождественная функция

Троичный логический повторитель. Является простейшей линией задержки.

Обмены и вращения

Отрицание (инверсия, переворот, обращение) Not (Inv) существует только в чётных логиках: двоичной, четверичной, шестеричной и т. д.
В троичной логике вместо отрицания (инверсии, переворота, обращения) Not (Inv) существует пять подобных функций: три обмена — Swap и два вращения — Rot, которые не являются точными подобиями отрицания (инверсии), но немного похожи на отрицание (инверсию).
В восьмиричной логике обмен двух значений на восьмиричной окружности изменяет только два значения из восьми и очень мало похож на двоичную инверсию. Четыре циклических сдвига же на 1 шаг (Rot) на восьмиричной окружности делают полную инверсию всех восьми значений. Таким образом, почти полным подобием двоичной инверсии Not (вращению на 180°) в восьмиричной логике являются 4 циклических сдвига на 1 шаг (на 45°) влево или вправо (RotateLeft и RotateRight). Так же и в троичной логике подобиями двоичной инверсии Not являются циклические сдвиги влево и вправо на 1 шаг (на 120°) (RotateLeft и RotateRight), а не обмены только двух значений из всех трёх (Swap), с той лишь разницей, что в троичной логике, из-за шага 120°, нет такого подобия двоичной инверсии Not, как в восьмиричной и в других чётных логиках.
Во времена, когда этого не знали, сложились ошибочные названия типа «инверсия Лукасевича», которая, на самом деле, является центральным из трёх обменов — Swap+1/-1 и менее подобна двоичной инверсии Not, чем циклические сдвиги на 1 шаг влево и вправо (вращения на 120° влево и вправо, RotateLeft и RotateRight).

Обмены в троичной логике

Обмены — унарные операции, меняющие местами два из трёх логических состояний.
В отличие от двоичной логики, в которой есть только один обмен Swap0/+1, совпадающий с инверсией (отрицанием) Not, в троичной логике существуют три обмена[17]:
— FT1N19, FT1S+2, Swap0/+1 (обмен 0 и +1), («NOT-1»)
— FT1N15, FT1S-8, Swap+1/-1 (обмен +1 и −1), («NOT0», «NOTL» — «инверсия Лукасевича»)
— FT1N5, FT1S+6, Swap0/-1 (обмен 0 и −1), («NOT+1»)

Традиционный обмен Swap+1/-1 (называемый обращением или дополнением, неполным отрицанием), не влияющий на состояние «0» («неизвестно»), в некоторых статьях по троичной логике ошибочно называют «отрицанием Лукасевича» («инверсией Лукасевича») и обозначают как «~Lx» («NLx», «¬Lx», «x’L», «NOTL» или «NOT0»). Функция «инверсии (отрицания) Лукасевича» входит в логику Клини. Логика Лукасевича и логика Клини были ранними исследованиями троичных функций и не охватывали все троичные функции. Они являются усечёнными подмножествами общего множества простейших троичных функций.

Графы переходов в физических троичных системах 3L LCT, 2B BCT и 3B BCT

Кроме традиционного обмена Swap+1/-1 («инверсия Лукасевича»), который сохраняет неизменным состояние 0 («неизвестно»), выделяют ещё две операции обмена, которые обозначают как Swap0/+1 («NOT-1») и Swap0/-1 («NOT+1»). Первый сохраняет неизменным состояние −1 («ложь»), а второй сохраняет +1 («истина»):
Таблица 5. (По этой таблице определяются номера Swap’ов в троичной симметричной системе кодирования.)

y\x+10-1
FT1S+2 0+1-1Swap0/+1, "NOT-1", обмен двух старших значений
FT1S-8 -10+1Swap+1/-1, "NOT0", "NOTL", обмен двух крайних значений ("инверсия Лукасевича")
FT1S+6 +1-10Swap0/-1, "NOT+1", обмен двух младших значений

В троичной несимметричной системе кодирования возможны шесть соответствий троичной симметричной системе кодирования, но наиболее значимыми являются только два соответствия из шести: с заменой знака «-1» на «2» без циклического сдвига вперёд (вверх, вправо) на +1 (-1,0,+1)=(2,0,1) и с циклическим сдвигом вперёд (вверх, вправо) на +1 (-1,0,+1)=(0,1,2).
Эта же таблица, но с обозначениями (-1,0,+1)=(2,0,1) и с перебором значений аргумента: 2, 0, 1):

y\x102
FT1S+2 012Swap01, обмен двух старших значений
FT1S-8 201Swap12, обмен двух крайних значений ("инверсия Лукасевича")
FT1S+6 120Swap02, обмен двух младших значений

Эта же таблица в троичной несимметричной системе кодирования без сдвига, а только с заменой знака «-1» на «2» (-1,0,+1)=(2,0,1), но с перебором значений аргумента: 0, 1, 2 (по этой таблице определяются номера функций в троичной несимметричной системе кодирования) (в этой таблице «инверсия Лукасевича» уже является обменом двух старших значений, а не двух крайних значений, как в предыдущих таблицах, так же и две других функции обмена, но, для лучшего различения функций обмена лучше оставить названия их действий в троичной симметричной системе кодирования):

y\x210
FT1N19=FT1S+2 201Swap01, обмен двух старших значений
FT1N15=FT1S-8 120Swap12, обмен двух крайних значений ("инверсия Лукасевича")
FT1N5=FT1S+6 012Swap02, обмен двух младших значений

В таблице же в троичной несимметричной системе кодирования со сдвигом на RotR(X) (-1,0,+1)=(0,1,2), те же функции в таблице оказываются циклически сдвинутыми на одну строку, то есть «инверсией Лукасевича» уже является не FT1N15 (Swap12), а FT1N5 (Swap02), так же сдвинуты и две другие функции Swap:

y\x210
FT1N15 120Swap12 (обмен двух старших значений)
FT1N5 012Swap02 (обмен двух крайних значений), ("инверсия Лукасевича")
FT1N19 201Swap01 (обмен двух младших значений)

Граф операции Swap0/+1 («NOT-1») — одно ребро треугольника с двухсторонними переходами от 0 к +1 и обратно.
Граф переходов в операции Swap+1/-1 («инверсии Лукасевича») — одно ребро треугольника с двухсторонними переходами от +1 к −1 и обратно. Граф операции Swap0/-1 («NOT+1») — одно ребро треугольника с двухсторонними переходами от 0 к −1 и обратно.
Все три операции линейные, одномерные, из линии в плоскость не выходят.

Закон двойного обмена справедлив для всех многозначных логик.
Для всех трёх обменов, как и для Swap0/+1(Swap01(X)) = X в двоичной логике, справедливы уравнения:

Swap0/+1(Swap0/+1(X)) = X
Swap+1/-1(Swap+1/-1(X)) = X
Swap0/-1(Swap0/-1(X)) = X

Вращения и инверсии

В двоичной логике вращение, отрицание, обращение, инверсия и негация совпадают и выражаются одной операцией вращения на 180° — этаким «5 в 1» NOT(X).
Точное подобие двоичной функции NOT(X) существует только в чётных многозначных логиках: четверичной, шестеричной, восьмиричной и т. д.
В троичной и более значных логиках вращения, отрицания, обращения, инверсии и негации являются разными функциями и не совпадают.
Вместо вращения на 180° (Not) в двоичной логике, в троичной логике существуют два вращения на 120°: RotLeft (-120°) и RotRight (+120°).
Так как электромеханические (реле) и электронные устройства (транзисторные каскады) переворачивают фазу на 180°, то они очень хорошо подошли для устройств двоичной логики. В троичной же логике нужны устройства поворачивающие фазу на 120°. Такие устройства относительно просто выполняются в механическом виде, но более сложно выполняются в электронном виде. Одним из решений этой задачи являются устройства выполненные в трёхбитной (3Bit BinaryCodedTernary, 3B BCT) системе троичных логических элементов[18].

В многозначных логиках

В двоичной логике существует закон двойного вращения на 1 шаг (180°) в одном направлении (двойного отрицания):

Not(Not(x)) = x
Rot(Rot(x)) = x

Направление вращения не различается. Из-за шага вращения 180° происходит занятие прямо противоположного положения на окружности (отрицание, обращение, инверсия и негация), поэтому функции Rot(x) (вращение), Not(x) (отрицание), Inv(x) (переворот) и Neg(x) совпадают.

В троичной логике существует закон тройного вращения на 1 шаг (120°) (циклического сдвига на 1 шаг) в одном направлении:

RotF(RotF(RotF(x))) = x
RotB(RotB(RotB(x))) = x

направление вращения различается, но занятия прямо противоположного положения на окружности (отрицания), из-за шага вращения 120°, не происходит, поэтому название Swap (обмен) для трёх известных троичных функций более точно, чем Not (отрицание) и Inv (переворот).

В четверичной логике существует закон четверного вращения на 1 шаг (90°) (циклического сдвига на 1 шаг) в одном направлении:

RotF(RotF(RotF(RotF(x)))) = x
RotB(RotB(RotB(RotB(x)))) = x

Направление вращения различается. Из-за шага вращения 90° возможно занятие прямо противоположного положения на окружности (Not (отрицание) и Inv (переворот)), но отрицание (Not) одно, а не три.

В пятиричной логике существует закон пятерного вращения на 1 шаг (72°) (циклического сдвига на 1 шаг) в одном направлении:

RotF(RotF(RotF(RotF(RotF(x))))) = x
RotB(RotB(RotB(RotB(RotB(x))))) = x

Направление вращения различается. Из-за шага вращения 72° занятие прямо противоположного положения на окружности (отрицание (Not) и переворот (Inv)) невозможны. …

В N-ичной логике существует закон N-го вращения на 1 шаг:

N вращений на 1 шаг в одном направлении равносильны повторению (утверждению).

В (N+1)-ичной логике существует закон (N+1)-го вращения:

(N+1) вращений на 1 шаг в одном направлении равносильны повторению (утверждению).

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

Отрицания (Not) и инверсии (Inv) существуют только в чётных многозначных логиках.

В объёмных логиках место окружности занимают многомерные (в простейшем случае трёхмерные) сферы.

Вращения в троичной логике

Вращения (циклические сдвиги, отрицания, инверсии, обмены) вперёд и назад (вращение вверх и вращение вниз)[17].

Если рассмотреть многовершинные графы, то в них возможны вращение на 1 шаг вперёд (циклический сдвиг на 1 вперёд), вращение на 1 шаг назад (циклический сдвиг на 1 назад) и инверсии (перевороты).

Вращения не являются инверсиями и отличаются от функции обмена — Swap+1/-1 («инверсии (отрицания) Лукасевича») и от двух операций обмена — Swap0/+1 («инверсия NOT−1») и Swap0/-1 («инверсия NOT+1»). Они более просты и более полно описывают возможные переходы. В проекте Стива Грабба эти функции называются вращение вверх (RotU) и вращение вниз (RotD), кроме этого, их ещё называют вращением вперёд RotF и вращением назад RotB и вращением влево RotLeft и вращением вправо RotRight.

В троичной симметричной системе кодирования с обозначениями (-1,0+1)=(1,0,+1):

y\x101
FT1S-6=FT1N7 110RotF, RotU
FT1S-2=FT1N11 011RotB, RotD

В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):

y\x210
FT1N7 021RotF (Rotate Forward), RotU (Rotate Up)
FT1N11 102RotB (Rotate Back), RotD (Rotate Down)

Для обеих функций справедливы уравнения:
RotF(RotF(RotF(x))) = x
RotB(RotB(RotB(x))) = x
которые являются законом тройного вращения:
три троичных вращения равносильны утверждению,
который является подобием закона двойного вращения в двоичной логике.

Только в троичной логике вращение на 2 шага вправо равно вращению на 1 шаг влево:
RotF(x) = RotB(RotB(x))
RotB(x) = RotF(RotF(x))

Следующие уравнения справедливы и в более, чем трёхзначной логиках:
Rot1B(Rot1F(x)) = x
Rot1F(Rot1B(x)) = x

Унарные троичные логические функции (операции, элементы) с бинарным результатом (выходом)

Всего существует простейших унарных троичных функций с бинарным выходом.

К этим функциям относятся демультиплексоры и дешифраторы с бинарным (двухразрядным) (результатом) выходом.

Унарные троичные логические функции (операции, элементы) с тринарным результатом (выходом)

Всего существует простейших унарных троичных функций с тринарным выходом.

К этим функциям относятся демультиплексоры и дешифраторы с тринарным (трёхразрядным) результатом (выходом).

Троичный дешифратор «1 трит в 3 строки»

Можно рассматривать как объединение трёх унарных троичных функций с унарными результатами из таблицы 1.

y\x0=x210
0 001FT1N1
1 010FT1N3
2 100FT1N9

Унарные троичные логические функции (операции, элементы) с m-арными выходами

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

К этим функциям относятся демультиплексоры и дешифраторы с m-арным (m-разрядным) результатом (выходом).

Бинарные троичные логические функции (операции, элементы)

Бинарные троичные логические функции с унарным результатом

Всего возможно простейших бинарных (двуместных, двухоперандных, двухаргументных, двухвходовых) троичных функций с унарным выходом, некоторые из них приведены в таблице:

Таблица некоторых бинарных троичных функций с унарным выходом с несимметричным кодированием

Таблица 5.

x0=x210210210
x1=y222111000Название действия (функции)Обозначение f(x,y)
FT2N010000000000Тождественный ноль, тождественный минимумFT2N0(x,y) = 0(x,y) = 0
FT2N110000000001Троичная эмуляция двоичной 2ИЛИ-НЕ2, стрелки ПирсаFT2N1(x,y) = x↓2y
FT2N1810000000200Детектор (x-y)=2 (true=2, false=0)
FT2N2110000000210
FT2N3010000001010Троичная эмуляция двоичного сложения по модулю 2, XOR2FT2N30(x,y) = XOR2(x,y)
FT2N3110000001011Троичная эмуляция двоичной 2И-НЕ2, штриха ШеффераFT2N31(x,y) = NAND2(x,y) = НЕ-И2(x,y) = Not2(Min2(x,y))
FT2N8110000010000Троичная эмуляция двоичной 2-in AND2, 2И2, min2(x,y)FT2N81(x,y) = min2(x,y) = AND2(x,y) = И2(x,y)
FT2N10910000011001Троичная эмуляция двоичной прямой (материальной) импликации, X <=2 YFT2N109(x,y) = IMP2(x,y) = (x LE2 y)
FT2N11110000011010Троичная эмуляция двоичной 2ИЛИ2, max2(x,y)FT2N111(x,y) = max2(x,y) = OR2(x,y) = ИЛИ2(x,y)
FT2N11310000011012Троичное подобие двоичной функции Вебба, по Полю Фальстаду CGOR[19]FT2N113(x,y) = Swap20(Max(x,y))
FT2N21010000021210Сложение по модулю 3 при одном неполном слагаемом
FT2N22310000022021Троичное подобие двоичной функции ВеббаFT2N223(x,y) = RotR(Max(x,y))
FT2N24310000010000Разряд переноса при сложении с неполным слагаемым
FT2N49210000200020детектор (x-y)=1 (true=2, false=0)
FT2N51010000200220x>y (true=2, false=0)
FT2N56710000210000
FT2N145810002000000Детектор x-y=-2 (true=2, false=0)
FT2N262210010121010Mean Function по Стиву Граббу[20] x→y[21]
FT2N317010011100102Троичное подобие двоичной функции ВеббаFT2N3170(x,y) = RotL(Max(x,y))
FT2N404910012112222CGAND[22]FT2N4049(x,y)
FT2N442810020002000Детектор x-y=-1 (true=2, false=0)FT2N4428(x,y)
FT2N529910021021021циклический сдвиг вправо (вперёд) на 1 (1/3 оборота) только одного второго аргумента (операнда)FT2N5299(x,y) = RotR(x)
FT2N568110021210102Младший разряд суммы (разности) в троичной симметричной системе счисления в соответствии
{-1,0,+1}={0,1,2}, sum3s(x,y)
FT2N588610022002000x<y (true=2, false=0)
FT2N639610022202220Детектор x≠y (true=2, false=0)
FT2N715310100210221Magnitude Function по Стиву Граббу[23]
FT2N822910102021210Сложение по модулю 3 в симметричной системе с соответствием {-1,0,+1}={0,1,2}, SumMod3s(x,y)
FT2N899110110100000Разряд переноса при бинарном сложении в несимметричной системеFT2N8991(x,y) = Carry3n(x,y)
FT2N984110111111111Тождественная единица, тождественная серединаFT2N9841(x,y) = 1(x,y) = 1
FT2N995110111122120Троичное подобие двоичной функции ВеббаFT2N9951(x,y) = Swap21(Max(x,y))
FT2N1320310200010000Разряд переноса при бинарном сложении в троичной симметричной системе счисления с соответствием {0,1,-1}={0,1,2} или {-1,0,+1}={2,0,1}FT2N13203(x,y)= Carry3s(x,y)
FT2N1328610200020002x=y (true=2, false=0)
FT2N1379610200220222x>=y (true=2, false=0)
FT2N1530910210000000
FT2N1563310210110000Минимум (меньшее из двух), Min Function по Стиву Граббу[24][25] FT2N15633(x, y) = Min(x, y)
FT2N1567410210111112Троичная функция следования БрусенцоваF2TN15674(x,y)
FT2N1574010210120222Импликация Гейтинга FT2N15740(x, y)
FT2N1589710210210210повтор только первого аргумента (операнда)FT2N15897(x,y) = Yes1(x,y) = x
F2TN1592910210211222Импликация материальнаяFT2N15929(x,y)
F2TN1601010210221222Импликация ЛукасевичаF2TN16010(x,y)
FT2N1640110211111110Разряд переноса при бинарном сложении-вычитании в симметричной троичной системе в соответствии {-1,0,+1}={0,1,2}FT2N16401(x,y) = Carry3s(x,y)
FT2N1917210222022002x<=y (true=2, false=0)FT2N19172(x,y)
FT2N1930510222111000повтор только второго аргумента (операнда)FT2N19305(x,y) = Yes2(x,y) = y
FT2N1945910222200201Троичное подобие двоичной функции ВеббаFT2N19459(x,y) = Swap10(Max(x,y))
FT2N1956910222211210Максимум (большее из двух), Max Function по Стиву Граббу[26][27] FT2N19569(x, y) = Max(x, y)
FT2N1968210222222222Тождественная двойка, тождественный максимумFT2N19682(x,y) = 2(x,y) = 2
Таблица некоторых бинарных троичных функций с унарным выходом с симметричным кодированием

Таблица 6.

x0=x10i10i10i
x1=y111000iiiНазвание действия (функции)Обозначение
FT2S-9841 iiiiiiiiiТождественная -1, тождественный минимумF-9841(x,y) = -1
FT2S-9618 iiii11i10Функция ВеббаF-9618 = Webb(x,y)
FT2S-6388 i001i011iF-6388
FT2S-4542 i10i10i10циклический сдвиг вперёд на 1/3 оборота только одного второго аргумента (операнда)F-4542 = SHIFTF(X,Y) = SHIFTF(X)
FT2S-4160 i1010i0i1Младший разряд суммы (разности) при сложении в троичной симметричной системе счисления, sum3s(x,y)F-4160
FT2S-3700 i110i100iF-3700
FT2S-3445 i111i111ix≠y, notL(x=y), детектор x≠y (true=+1 и false=-1)F-3445
FT2S-2688 0ii10i110sign(y-x), Magnitude Function Стива Грабба[23]F-2688 = sign(y-x)
FT2S-1612 0i1i1010iСложение по модулю 3 в несимметричной системе, summod3n(x,y)F-1612
FT2S-850 00i0iiiiiРазряд переноса при бинарном сложении в несимметричной системеF-850
F2TS0 000000000Тождественный ноль, тождественная серединаF0(x,y) = 0
FT2S2688 011i01ii0notL(sign(y-x)), инверсия Лукасевича от Magnitude Function по Стиву ГраббуF2688
FT2S3700 1ii01i001F3700
FT2S3955 1ii11i111(x<y, notL(x>y)) (true=+1 и false=-1)F3955
FT2S5792 10i00iiiiМеньшее из двух, минимумF5792 = min(x,y)
FT2S5833 10i000001Троичная функция следования БрусенцоваF5833
FT2S6056 10i10i10iповтор только второго аргумента (операнда)F6056 = YES1(x,y) = x
FT2S6088 10i100111Импликация материальнаяF6088
FT2S6142 10i11i111Импликация Гейтинга F6142
FT2S6169 10i110111Импликация ЛукасевичаF6169
FT2S6388 100i10ii1F6388
FT2S6550 10000000iРазряд переноса при бинарном сложении в симметричной троичной системеF6560
FT2S9331 111i11ii1x>y, notL(x-y) (true=+1 и false=-1)F9331
FT2S9464 111000iiiповтор только первого аргумента (операнда)F9464 = YES2(x,y) = y
FT2S9728 11110010iБольшее из двух, максимумF9728 = max(x,y)
FT2S9841. 111111111Тождественная +1, тождественный максимумF9841(x,y) = 1

«i», «1», «7» или «2» означают «-1»

Снимок модели троичного бинарного с унарным выходом АЛУ в трёхбитной одноединичной системе троичных логических элементов в логическом симуляторе Atanua[9]

Все 19 683 простейшие троичные бинарные функции выполняются троичным АЛУ (2Трита в 1Трит) в трёхбитной одноединичной системе троичных логических элементов, снимок модели которого в логическом симуляторе Atanua приведён на рисунке.

Троичная эмуляция двоичной 2ИЛИ-НЕ (стрелки Пирса)

Троичная эмуляция двоичной бинарной функции 2ИЛИ-НЕ (стрелка Пирса).
Результат является двоичным.
В троичной несимметричной системе кодирования с обозначениями (-1,0,1)=(0,1,2):
Истинно=2, ложно=0.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  0  0
  0  0  0 
- 1  0  0 -> x
  |

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N110 000000001FT2N1 = x↓y

Троичная эмуляция двоичного сложения по модулю 2, XOR

Троичная эмуляция двоичной функции «бинарное сложение по модулю 2», XOR.
Результат является двоичным.
В троичной несимметричной системе кодирования с обозначениями (-1,0,1)=(0,1,2):
Истинно=2, ложно=0.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  0  0
  1  0  0 
- 0  1  0 -> x
  |

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N3010 000001010FT2N30 = XOR(x,y)

Троичная эмуляция двоичной 2И-НЕ (штриха Шеффера)

Троичная эмуляция двоичной бинарной функции 2И-НЕ (штриха Шеффера).
Результат является двоичным.
В троичной несимметричной системе кодирования с обозначениями (-1,0,1)=(0,1,2):
Истинно=2, ложно=0.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  0  0
  1  0  0 
- 1  1  0 -> x
  |

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N3110 000001011FT2N31 = NAND(x,y) = НЕ-И(x,y) = Not(Min(x,y))

Троичная эмуляция двоичной 2И, min(x, y)

Троичная эмуляция двоичной бинарной функции 2-in AND, 2И, min(x, y).
Результат является двоичным.
В троичной несимметричной системе кодирования с обозначениями (-1,0,1)=(0,1,2):
Истинно=2, ложно=0.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  0  0
  0  1  0 
- 0  0  0 -> x
  |

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N8110 000010000FT2N81 = min(x,y) = AND(x,y) = И(x,y)

Троичная эмуляция двоичной прямой (материальной) импликации, x <= y

Троичная эмуляция двоичной бинарной функции «прямая (материальная) импликация», x <= y.
Результат является двоичным.
В троичной несимметричной системе кодирования с обозначениями (-1,0,1)=(0,1,2):
Истинно=2, ложно=0.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  0  0
  1  1  0 
- 1  0  0 -> x
  |

На диаграмме хорошо видна несимметричность функции.
В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N10910 000011001FT2N109 = IMP(x,y) = (x LE y)

Троичная эмуляция двоичной 2ИЛИ, max(x, y)

Троичная эмуляция двоичной бинарной функции 2-in OR, 2ИЛИ, max(x, y).
Результат является двоичным.
В троичной несимметричной системе кодирования с обозначениями (-1,0,1)=(0,1,2):
Истинно=2, ложно=0.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  0  0
  1  1  0 
- 0  1  0 -> x
  |

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N11110 000011010FT2N111 = max(x,y) = OR(x,y) = ИЛИ(x,y)

Больше

Результат по сути является двоичным.
В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
Истинно=1, ложно=1.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  1  1
- 1  1  1 -> x
  1  1  1 
     |

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

x0=x 101101101
x1=y 111000111
FT2S-933110 111111111x>y


В троичной симметричной системе счисления с обозначениями (-1,0,+1)=(2,0,1):
Истинно=1, ложно=2 (-1).
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  2  2  2
- 2  2  1 -> x
  2  1  1 
     |

В виде таблицы истинности:

x0=x 102102102
x1=y 111000222
FT2N1942710 222122112x>y

В троичной несимметричной системе счисления с обозначениями (-1,0,+1)=(0,1,2):
Истинно=2, ложно=0.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  0  0
  0  0  2 
- 0  2  2 -> x
  |

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N51010 000200220x>y

Больше либо равно

Результат по сути является двоичным.
В троичной симметричной системе кодирования с обозначениями (-1,0,1)=(1,0,1):
Истинно=1, ложно=1.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  1  1
- 1  1  1 -> x
  1  1  1 
     |

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

x0=x 101101101
x1=y 111000111
FT2S395510 111111111x>=y

В троичной несимметричной системе кодирования с обозначеениями (-1,0,1)=(0,1,2):
Истинно=2, ложно=0.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  0  2
  0  2  2 
- 2  2  2 -> x
  |

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N1379610 200220222x>=y

Меньше

Результат по сути является двоичным.
В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
Истинно=1, ложно=1.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  1  1
- 1  1  1 -> x
  1  1  1 
     |

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

x0=x 101101101
x1=y 111000111
FT2S-395510 111111111x<y


В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
Истинно=2, ложно=0.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  2  2  0
  2  0  0 
- 0  0  0 -> x
  |

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N588610 022002000x<y

Меньше либо равно

Результат по сути является двоичным. В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
Результат по сути является двоичным.
Истинно=1, ложно=1.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  1  1
- 1  1  1 -> x
  1  1  1 
     |

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

x0=x 101101101
x1=y 111000111
FT2S933110 111111111x<=y


В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
Истинно=2, ложно=0.
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  2  2  2
  2  2  0 
- 2  0  0 -> x
  |

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N1917210 222022002x<=y

Равно

Вычисляется eqv(x, y); x eqv y.
В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
Результат по сути является двоичным.
Истинно — 1, ложно — 1.
В виде двухмерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  1  1
- 1  1  1 -> x
  1  1  1
     | 

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

x0=x 101101101
x1=y 111000111
FT2S3445 111111111x=y


В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
При обозначениях результата: истинно=2, ложно=0.
В виде двухмерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  0  2
  0  2  0
- 2  0  0 -> x
  | 

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N1328610 200020002x=y

В виде матрицы

Троичная функция отношения

Троичный компаратор с унарным троичным выходом.
Magnitude Function по Стиву Граббу[23]
С однозначным результатом[28]
Определяет отношения тритов в разрядах.
Кроме равенства Лукасевича, которое имеет двоичный результат и подобно двоичному равенству, в общей троичной логике появляются троичные функции отношения, которые сразу определяют три возможных отношения операндов — меньше, равно или больше. Так как в двоичной логике результат может принимать только два значения, то в двоичной логике таких функций нет.
Результат изменяется при перемене мест операндов.
В зависимости от порядка следования отношений в результате, может быть несколько разновидностей этой функции. Например (<,=,>), (>,=,<) и экзотические (<,>,=), (>,<,=), (=,<,>) и др.
В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
С обозначениями результата (x<y,x=y,x>y) = (<,=,>) = (1,0,1).
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  1  0
- 1  0  1 -> x
  0  1  1
     |

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

x0=x 101101101
x1=y 111000111
FT2S-268810 011101110sign(y-x)

В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
С обозначениями результата (x<y,x=y,x>y) = (<,=,>) = (0,1,2).
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  0  1
  0  1  2 
- 1  2  2 -> x
  |

В виде таблицы истинности:

x0=x 2102102101-й операнд
x1=y 2221110002-й операнд
FT2N715310 100210221F(x,y)

Троичный компаратор с тринарным двоичным выходом

Сравнивает поразрядно триты двух чисел и имеет тринарный двоичный выход: меньше, равно, больше. Является объединением трёх предыдущих отдельных троичных бинарных функций.
Результат изменяется при перемене мест операндов.
true=2, false=0

x0=x 2102102101-й операнд
x1=y 2221110002-й операнд
x<y 022002000
x=y 200020002
x>y 000200220

Минимум (наименьшее)

Вычисляется min(x,y).
В двоичной логике функции min(x, y) соответствует конъюнкция: x ∧ y, x И y, 2И.
Входит в логику Клини.
В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  0  1
- 1  0  0 -> x
  1  1  1
     |

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

x1=y101101101
x0=x111000111
FT2S5792(x,y) 101001111min(x,y)

В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  1  2
  0  1  1 
- 0  0  0 -> x
  |

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N1563310 210110000min(x,y)

Максимум (наибольшее)

Вычисляется max(x, y).
В двоичной логике функции max(x, y) соответствует дизъюнкция: x ∨ y, x ИЛИ y, 2ИЛИ(x, y).
Входит в логику Клини.
В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

      y
      ^
      |
   1  1  1
-  0  0  1 -> x
   1  0  1
      | 

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

x0=x 101101101
x1=y 111000111
FT2S972810 111100101max(x,y)


В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  2  2  2
  1  1  2 
- 0  1  2 -> x
  |

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N1956910 222211210max(x,y)

В виде матрицы

Сложение по модулю 3 в несимметричной троичной системе счисления

Вычисляется сумма по модулю 3: x MOD3 y, MOD3(x, y,).
Аналог сложения по модулю 2. Название «исключающее ИЛИ» («XOR»), применяемое для «двоичного сложения по модулю 2», для «троичного сложения по модулю 3» неприемлемо, то есть оказалось поверхностным, не глубоким.
В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  1  0
- 0  1  1 -> x
  1  0  1 
     | 

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

x0=x 101101101
x1=y 111000111
FT2S-161210 011110101x MOD3 y, MOD3(x,y)


В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  2  0  1
  1  2  0
- 0  1  2 -> x
  | 

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N822910 102021210x MOD3 y, MOD3(x,y)

В виде матрицы

Сложение по модулю три напоминает двоичный XOR. Это обычное сложение, только без переноса: в случае переполнения разрядной сетки оно сохраняет лишь младший троичный разряд. Как и двоичный XOR, сложение по модулю три либо оставляет троичный разряд неизменным, либо изменяет его (производит операции RotF/RotB, в зависимости от знака соответствующего троичного разряда).

Эта функция может быть полезна для реализации троичных несимметричных полусумматора и сумматора.

Разряд переноса при бинарном (двухаргументном, двухоперандном) сложении в троичной несимметричной системе счисления

То есть разряд переноса при троичном несимметричном сложении в троичном несимметричном полусумматоре.
В троичной симметричной системе кодирования обозначениями (-1,0,+1)=(1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  0  0
- 1  1  0 -> x 
  1  1  1 
     |

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

x0=x 101101101
x1=y 111000111
FT2S-85010 001011111

В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  1  1
  0  0  1 
- 0  0  0 -> x
  |

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N899110 110100000

В виде матрицы

Младший разряд результата в троичном симметричном сложении

То есть младший разряд в троичном симметричном полусумматоре.
В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  0  1  1
- 1  0  1 -> x
  1  1  0
     |

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

x0=x 101101101
x1=y 111000111
FT2S-416010 110101011Младший разряд в троичном симметричном полусумматоре


В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  1  2  0
  0  1  2 
- 2  0  1 -> x
  |

В виде таблицы истинности:

x0=x 210210210
x1=y 222111000
FT2N568110 021210102Младший разряд в троичном симметричном полусумматоре

Трит переноса при бинарном (двухаргументном, двухоперандном) сложении при троичном симметричном сложении

То есть трит переноса в троичном симметричном полусумматоре.
В троичной симметричной системе кодирования с обозначениями (-1,0,1)=(1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  0  0  1
- 0  0  0 -> x
  1  0  0
     |

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

x0=x 101101101
x1=y 111000111
FT2S656010 100000001Трит переноса в троичном симметричном полусумматоре


В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  1  1  2
  1  1  1 
- 0  1  1 -> x
  |

Троичное умножение

В троичной несимметричной системе (-1,0,+1)=(0,1,2):
В виде таблицы истинности:

x0=x 210210210Умножаемое
x1=y 222111000Множитель
FT2N1150210 120210000Младший трит результата
FT2N656110 100000000Старший трит результата (трит переноса)

Перенос возникает в одном случае из девяти.

В виде двух двумерных (двухаргументных, двухкоординатных) диаграмм:

FT2N11502        FT2N6561
  y                y   
  ^                ^   
  |                | 
  0  2  1          0  0  1
  0  1  2          0  0  0 
- 0  0  0 -> x   - 0  0  0 -> x
  |                |      


В троичной симметричной системе (-1,0,+1)=(2,0,1):
В виде таблицы истинности:

x0=x 102102102Умножаемое
x1=y 111000222Множитель
FT2N803810 102000201Трит результата

Перенос не возникает вовсе.

В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  FT2N8038
     y
     ^
     |
  2  0  1
- 0  0  0 -> x
  1  0  2 
     |

Импликации

Импликация (от лат. implicatio — сплетение, implico — тесно связываю) — логическая связка, соответствующая грамматической конструкции «если …, то …», с помощью которой из двух простых высказываний образуется сложное высказывание. В импликативном высказывании различают антецедент (основание) — высказывание, идущее после слова «если», и консеквент (следствие) — высказывание, идущее за словом «то». Импликативное высказывание представляет в языке логики условное высказывание обычного языка. Последнее играет особую роль как в повседневных, так и в научных рассуждениях, основной его функцией является обоснование одного путём ссылки на нечто другое. В современной логике имеется большое число импликаций, различающихся своими формальными свойствами:

Троичная функция следования Брусенцова

Вычисляется :
В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  0  1
- 0  0  0 -> x
  1  0  0
     |

На двумерной (двухаргументной, двухкоординатной) диаграмме хорошо видно, что Функция несимметрична, то есть при перемене мест аргументов результат изменяется.

В виде таблицы истинности:

x 1011011011-е высказывание
y 1110001112-е высказывание
FT2S583310 101000001Троичная функция следования Брусенцова

В троичной несимметричной системе кодирования с обозначениями (-1,0,+1) = (0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  1  2
  1  1  1 
- 2  1  1 -> x
  |

В виде таблицы истинности:

x 2102102101-е высказывание
y 2221110002-е высказывание
FT2N1567410 210111112Троичная функция следования Брусенцова

Импликация материальная

Материальная импликация — одна из основных связок классической логики. Определяется она таким образом: импликация ложна только в случае истинности основания (антецедента) и ложности следствия (консеквента), а истинна во всех остальных случаях. Условное высказывание «если x, то y» предполагает некоторую реальную связь между тем, о чём говорится в x и y; выражение «x материально имплицирует y» такой связи не предполагает.

Вычисляется материальная импликация: max(x,-y); ; x ∨ -y.
В троичной симметричной системе кодирования с обозначениями (-1,0,+1) = (1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  0  1
- 0  0  1 -> x
  1  1  1
     |

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

x 1011011011-е высказывание
y 1110001112-е высказывание
FT2S608810 101100111Импликация материальная

В троичной несимметричной системе кодирования с обозначениями {-1,0,+1} = {0,1,2}:
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  1  2
  1  1  2 
- 2  2  2 -> x
  |

В виде таблицы истинности:

x 2102102101-е высказывание
y 2221110002-е высказывание
FT2N1592910 210211222Импликация материальная

Импликация Гейтинга

Это часть многозначной логики. Логика Гейтинга охватывала лишь часть классической формальной логики.
Импликацию (если р, то q) можно утверждать, только если имеется такое построение, которое, будучи объединено с построением р, автоматически даёт построение q. Например, из истинности высказывания p следует «неверно, что p ложно». Но из утверждения «неверно, что p ложно» ещё не следует, что p — истинно, так как высказывание p может оказаться неконструктивным.

В троичной симметричной системе кодирования с обозначениями (-1,0,+1) = (1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  0  1
- 1  1  1 -> x
  1  1  1
     |

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

x 1011011011-е высказывание
y 1110001112-е высказывание
FT2S-984110 101111111Импликация Гейтинга

В троичной несимметричной системе кодирования с обозначениями (-1,0,+1) = (0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  1  2
  0  2  2 
- 2  2  2 -> x
  |

В виде таблицы истинности:

x 2102102101-е высказывание
y 2221110002-е высказывание
FT2N1574010 210120222Импликация Гейтинга

Импликация Лукасевича

[29][30] Это часть модальной логики.

В троичной симметричной системе кодирования с обозначениями (-1,0,+1) = (1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  0  1
- 0  1  1 -> x
  1  1  1
     |

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

x 1011011011-е высказывание
y 1110001112-е высказывание
FT2S616910 101110111Импликация Лукасевича

В троичной несимметричной системе кодирования с обозначениями (-1,0,+1) = (0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  1  2
  1  2  2 
- 2  2  2 -> x
  |

В виде таблицы истинности:

x 2102102101-е высказывание
y 2221110002-е высказывание
FT2N1601010 210221222Импликация Лукасевича

Сложение по модулю 3 при одном неполном слагаемом

Для сложения одного троичного разряда с разрядом переноса.
Результат не изменяется при перемене мест операндов.
В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  1  2  0 
- 0  1  2 -> x
  |

В виде таблицы истинности:

x0=x 2102101-е слагаемое
x1=y 1110002-е слагаемое
FT1B1N21010 021210Сумма по модулю 3

В виде матрицы:

Разряд переноса при сложении с неполным слагаемым

Для сложения одного троичного разряда с разрядом переноса.
Результат не изменяется при перемене мест операндов.
В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  0  1 
- 0  0  0 -> x
  |

В виде таблицы истинности:

x0=x 2102101-е слагаемое
x1=y 1110002-е слагаемое
FT1B1N24310 100000Перенос в n+1

В виде матрицы:

Троичные подобия двоичной функции Вебба

В троичной логике двоичной функции max(x, y) (OR, V) соответствует троичная функция max(x, y), которая уже не является функцией OR (V).
Так как вращению на 180° — Rot (перевороту, отрицанию, инверсии, негации) (Rot, Not, Inv, Neg) в двоичной логике в троичной логике соответствуют три функции обмена — Swap и две функции вращения — Rot, то в троичной логике существуют пять троичных подобий двоичной функции Вебба равной Not(max(x, y)).

Троичное подобие двоичной функции Вебба со Swap0/+1

Вычисляется: троичное подобие двоичной функции Webb со Swap0/+1 = Swap0/+1(max(x, y)).

В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  0  0  0
- 1  1  0 -> x
  1  1  0  
     | 

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

x0=x 1011011011-е высказывание
x1=y 1110001112-е высказывание
FT2S11010 000011011подобие Webb со Swap0/+1 = Swap0/+1(max(x,y))

В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  1  1  1
  2  2  1
- 0  2  1 -> x
  |

В виде таблицы истинности:

x0=x 2102102101-е высказывание
x1=y 2221110002-е высказывание
FT2N995110 111122120подобие Webb со Swap2/1 = Swap2/1(max(x,y))

В виде матрицы

Троичное подобие двоичной функции Вебба со Swap+1/-1

Вычисляется: троичное подобие двоичной функции Webb со Swap+1/-1 = Swap+1/-1(max(x, y)).

В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  1  1
- 0  0  1 -> x
  1  0  1  
     | 

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

x0=x 1011011011-е высказывание
x1=y 1110001112-е высказывание
FT2S-972810 111111110подобие Webb со Swap+1/-1 = Swap+1/-1(max(x,y))

В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  0  0
  1  1  0
- 2  1  0 -> x
  |

В виде таблицы истинности:

x0=x 2102102101-е высказывание
x1=y 2221110002-е высказывание
FT2N11310 000011012подобие Webb со Swap2/0 = Swap2/0(max(x,y))

В виде матрицы

Троичное подобие двоичной функции Вебба со Swap0/-1

Вычисляется: троичное подобие двоичной функции Webb со Swap0/-1 = Swap0/-1(max(x, y)).

В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  1  1
- 1  1  1 -> x
  0  1  1
     | 

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

x0=x 1011011011-е высказывание
x1=y 1110001112-е высказывание
FT2S961810 111111110подобие Webb со Swap0/-1 = Swap0/-1(max(x,y))

В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  2  2  2
  0  0  2
- 1  0  2 -> x
  |

В виде таблицы истинности:

x0=x 2102102101-е высказывание
x1=y 2221110002-е высказывание
FT2N1945910 222200201Webb(Swap1/0)(x,y) = Swap1/0(max(x,y))

В виде матрицы

Троичное подобие двоичной функции Вебба с RotF

Вычисляется: троичное подобие двоичной функции Webb с RotF = RotF(max(x, y)).

В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  1  1  1
- 1  1  1 -> x
  0  1  1
     | 

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

x0=x 1011011011-е высказывание
x1=y 1110001112-е высказывание
FT2S-961810 111111110подобие Webb c RotF = RotF(max(x,y))

В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  0  0  0
  2  2  0
- 1  2  0 -> x
  |

В виде таблицы истинности:

x0=x 2102102101-е высказывание
x1=y 2221110002-е высказывание
FT2N22310 000022021подобие Webb с RotF(x,y) = RotF(max(x,y))

В виде матрицы

В двоичной логике функция Вебба обозначается стрелкой Пирса (↓) и определяется, как антидизъюнкция Webb(x, y) = x ↓ y = Not(x OR y) = Not(max(x, y)).
Автор же статьи «Сведения по трёхзначной логике»[31] обозначает троичное подобие двоичной функции Вебба штрихом Шеффера, которым в двоичной логике обозначают антиконъюнкцию, которая равна Sheff(x, y) = x | y = Not(x AND y) = Not(min(x, y)).
Автор статьи даёт определение трёхзначной функции Вебба, как Webb(a, b) = a | b = mod3(max(a, b) + 1)) (7) = RotF(max(a, b)), хотя в двоичной логике функцию Вебба обозначают стрелкой Пирса, а не штрихом Шеффера, а при обозначении штрихом Шеффера двоичная функция явяляется антиконъюнкцией, а не функцией Вебба (антидизъюнкцией), и равна Not(min(a, b)) = Not(a AND b), а не Not(max(a, b)) = Not(a OR b), но в первой части функции автор вычисляет max(a, b), то есть вместо стрелки Пирса (↓) поставил штрих Шеффера (|), но вычислял a OR b = max(a, b), а не a AND b = min(a, b). Во второй части функции автор мудрёным способом вычисляет одно из пяти троичных подобий двоичной инверсии (отрицания, негации) — RotF и почему то считает функцию FT2N223 единственной представительницей троичных подобий функции Вебба из пяти троичных подобий двоичной функции Вебба, хотя функция FT2N113(x, y) = Swap2/0(max(x, y)) более веббистая, чем FT2N223.

Троичное подобие двоичной функции Вебба с RotB

Вычисляется: троичное подобие двоичной функции Webb с RotB = RotB(max(x, y)).

В троичной симметричной системе кодирования с обозначениями (-1,0,+1)=(1,0,1):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

     y
     ^
     |
  0  0  1
- 1  1  0 -> x
  1  1  0  
     | 

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

x0=x 1011011011-е высказывание
x1=y 1110001112-е высказывание
FT2S-667110 100011011подобие Webb с RotB = RotB(max(x,y))

В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде двумерной (двухаргументной, двухкоординатной) диаграммы:

  y
  ^
  |
  1  1  0
  0  0  1
- 2  0  1 -> x
  |

В виде таблицы истинности:

x0=x 2102102101-е высказывание
x1=y 2221110002-е высказывание
FT2N317010 011100102подобие Webb с RotB = RotB(max(x,y))

В виде матрицы

Рассуждения на тему функции Вебба

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

Одноместные:

  • RotF(X) = X | X
/* Результат двухместной (двухоперандной) операции может быть равен результату 
одноместной (одноаргументной) функции, но из этого не следует равенства самой 
одноместной функции и двухместной (двухоперандной) операции. 
RotF(X) и RotB(X) - функции одноместные (одноаргументные), а троичное подобие 
двоичной двухместной (двухаргументной,  двухоперандной) функции Вебба или 
оператора Вебба должно быть, как и в двоичной логике двухместным (двухаргументным,  
двухоперандным).  
Вообще же, для того, что хотят выразить с помощью троичной логики, лучше
подходит четверичная или восмиричная логики, у троичной же логики другое
назначение. */ 
  • RotB(X) = RotF(RotF(X),RotF(X)) = (X | X) | (X | X)
/* RotF(X) - функция одноместная (одноаргументная, однооперандная), автор 
же использует её, как двухместную (двухаргументную, двухоперандную). */
  • NOT(X) = (RotB(X) | RotF(X) | RotF(RotB(X) | X))
/* Двоичная операция 2И-НЕ (штрих Шеффера - "|") невозможна с троичными операндами RotB и
RotF. Определения же троичного подобия двоичной функции 2И-НЕ (штриху Шеффера - "|") автор не дал. */

Двухместные:

  • X ∨ Y = RotB(X | Y)
/* Прежде, чем брать функцию RotB() нужно дать определение троичного подобия
двоичной функции 2И-НЕ (штриху Шеффера). */ 
  • X ∧ Y = Not(Not(X) ∨ Not(Y))
/* Прежде, чем брать двоичную функцию Not() от подразумеваемого троичного результата нужно 
дать определение троичного подобия двоичной функции 2ИЛИ-НЕ (стрелке Пирса) или дать определение троичному подобию двоичной функции Not(). */

Вполне возможно, что именно логическим элементам, реализующим функцию Вебба, придётся сыграть роль троичных ЛА3’их (ИС SN7400, 4 логических элемента 2И-НЕ[32]). И от качества реализации этой функции, количества транзисторов, будет зависеть эффективность будущих троичных процессоров.

/* В троичной трёхуровневой системе троичных логических элементов (3-Level LevelCodedTernaty, 
3L LCT) при переходах из состояния +1 в состояние -1 и наоборот потенциал (напряжение)
проходит через состояние 0, что неизбежно приводит к ложным срабатываниям и низкому 
качеству реализации троичных функций. 
В троичной двухуровневой трёхбитной одноединичной системе троичных логических элементов 
(2-Level 3-Bit BinaryCodedTernary UnoUnary, 2L 3B BCT UU, 2L 3B BCT, 3B BCT) в каждой  
отдельной линии фаза переворачивается на ±180° и физических поворотов фазы на +120° и 
-120° нет, но все три состояния логически распознаются и эта система может быть 
логическим подобием троичной системы с поворотами на +120° и -120°. При любых переходах 
перехода через третье состояние не происходит, что повышает качество реализации троичных 
функций.*/

Впрочем, функция RotB(X ∨ Y) (а возможно, что и RotF(X ∧ Y), RotB(X ∧ Y) ничем не хуже. Вопрос лишь в том, какую из них мы сможем реализовать наиболее эффективно.

/* Чтобы сделать троичное подобие двоичного поворота на ±180° (Not(X)), автор из 
пяти троичных подобий двоичного Not(X) выбрал только поворот на -120° (RotB()),  
который более подобен двоичному повороту на ±180° (Not), чем неполные обмены только 
двух значений из трёх (Swap'ы), но поворот на +120° (RotF()) не хуже поворота на -120°  
(RotB()), о чём и пишет автор. */

Бинарные троичные логические функции (операции, элементы) с бинарным выходом

Снимок модели бинарного с бинарным выходом АЛУ в трёхбитной одноединичной системе троичных логических элементов в логическом симуляторе Atanua[9]

Всего возможно простейших бинарных с бинарным выходом троичных функций (2Трита-2Трита).

Все 387 420 489 простейших троичных бинарных с бинарным выходом функций выполняются АЛУ в трёхбитной одноединичной системе троичных логических элементов, приведённым на рисунке справа.

Троичный полусумматор с одним неполным слагаемым

Первая ступень трёхступенчатого полного троичного сумматора.
Для сложения одного троичного разряда с разрядом переноса.
Результат не изменяется при перемене мест операндов.
В троичной несимметричной системе кодирования с обозначениями (-1,0,+1)=(0,1,2):
В виде таблицы исстинности:

x0=x 210210полное слагаемое
x1=y 111000неполное слагаемое
FT1B1N21010 021210Сумма по модулю 3
FT1B1N24310 100000Перенос в n+1

Результат операции занимает 1 и 2/3 троичных разряда.

Бинарное сложение в несимметричной троичной системе счисления (троичный полусумматор)

Бинарное (двухаргументное, двухоперандное) сложение в троичной несимметричной системе счисления, то есть троичный несимметричный полусумматор.

Троичный полусумматор можно рассматривать, как объединение двух бинарных (двухаргументных, двухоперандных) троичных функций: «сложение по модулю 3 в троичной несимметричной системе счисления» и «разряд переноса при сложении в троичной несимметричной системе счисления».
Так как при сложении в троичной несимметричной системе в разряде переноса не бывает значения больше единицы, то, в отличие от предыдущих бинарных троичных функций с одноразрядным результатом, бинарный результат функции занимает 1 и 1/3 троичных разрядов.
Результат не изменяется при перемене мест аргументов.

x0=x 2102102101-е слагаемое
x1=y 2221110002-е слагаемое
FT2N822910 102021210Сумма по модулю 3, несимметричная; x SUMMOD3 y, SUMMOD3(x,y)
FT2N899110 110100000Перенос в n+1, несимметричный
Снимок модели троичного несимметричного полусумматора в троичной несимметричной троичной системе счисления в трёхбитной одноединичной системе логических элементов в логическом симуляторе Atanua[33].

или в виде матрицы

Бинарное сложение-вычитание в троичной симметричной системе счисления Фибоначчи

Троичный полусумматор-полувычитатель.

Троичное логическое сложение-вычитание двух троичных разрядов с разрядом переноса в троичной симметричной системе счисления.

Результат не изменяется при перемене мест операндов.

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

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

В троичной симметричной системе кодирования с обозначениями (−1, 0, +1) = (i, 0, 1):
В виде двух двухаргументных (двухоперандных, двухкоординатных) диаграмм:

  FT2S-4160       FT2S6560   
     y               y
     ^               ^
     |               |    
  0  1  1         0  0  1 
- 1  0  1 -> x  - 0  0  0 -> x
  1  1  0         1  0  0
     |               | 

В виде одной двухаргументной (двухоперандной, двухкоординатной) диаграммы:

      y
      ^
      |
  00  01  11
- 01  00  01 -> x
  11  01  00
      |

В виде таблицы истинности:

x0=x 10i10i10i1-е слагаемое-уменьшаемое
x1=y 111000iii2-е слагаемое-вычитаемое
FT2S-416010 i1010i0i1Младший разряд (трит) симметричной суммы
FT2S656010 10000000iСтарший разряд (трит) симметричной суммы, трит переноса в n+1 разряд

В виде матрицы

В троичной симметричной системе кодирования с обозначениями (-1,0,+1) = (2,0,1):
В виде двух двухаргументных (двухоперандных, двухкоординатных) диаграмм:

  FT2N15613       FT2N6563
     y               y     
     ^               ^
     |               | 
  0  1  2         0  0  1 
- 2  0  1 -> x  - 0  0  0 -> x
  1  2  0         2  0  0
     |               |    

В виде одной двухаргументной (двухоперандной, двухкоординатной) диаграммы:

      y
      ^
      |
  00  01  12
- 02  00  01 -> x
  21  02  00
      |

В виде таблицы истинности:

x0=x 1021021021-е слагаемое-вычитаемое
x1=y 1110002222-е слагаемое-вычитаемое
FT2N1561310 210102021Младший разряд (трит) симметричной суммы
FT2N656310 100000002Старший разряд (трит) симметричной суммы, трит переноса в n+1 разряд

В троичной несимметричной системе кодирования с обозначениями (-1,0,+1) = (0,1,2):
В виде двухаргументной (двухоперандной, двухкоординатной) диаграммы:

      y
      ^
      |
  11  12  20
- 10  11  12 -> x
  02  10  11
      |

В виде таблицы истинности:

x0=x 2102102101-е слагаемое-вычитаемое
x1=y 2221110002-е слагаемое-вычитаемое
FT2N568110 021210102Младший разряд (трит) симметричной суммы
FT2N1640110 211111110Старший разряд (трит) симметричной суммы, трит переноса в n+1 разряд
Снимок модели одноразрядного троичного симметричного полусумматора-полувычитателя в трёхбитной системе логических элементов в логическом симуляторе Atanua[33].


В виде матрицы

Бинарные троичные логические функции с нонарным результатом (выходом)

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

Троичный дешифратор «2 трита в 9 строк»

Результат изменяется при перемене мест операндов.
Можно рассматривать как объединение девяти бинарных троичных функций с унарными результатами.

x0=x 210210210
x1=y 222111000
0 000000001
1 000000010
2 000000100
3 000001000
4 000010000
5 000100000
6 001000000
7 010000000
8 100000000

Бинарные троичные логические функции с m-арными результатами (выходами)

Всего возможно бинарных троичных функций с m-арным выходом, то есть бесконечное число.

К этим функциям относятся бинарные (двухразрядные) дешифраторы и демультиплексоры с m-арными (m-разрядными) выходами.

Тринарные троичные логические функции (операции, элементы)

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

Тринарные троичные логические функции (операции) с унарным выходом

Всего возможно (7 триллионов 625 миллиардов 597 миллионов 484 тысячи 987) простейших тринарных (триарных) троичных функций с унарным выходом.

Минимум

Вычисляется min(x, y, z)
27 входных комтринаций
Результат не изменяется при перемене мест операндов.

x0=x 2102102102102102102102102101-й аргумент (операнд)
x1=y 2221110002221110002221110002-й аргумент (операнд)
x2=z 2222222221111111110000000003-й аргумент (операнд)
FT3N6 056 723 349 50410 210110000110110000000000000результат min(x,y,z)

Максимум

Вычисляется max(x, y, z)
27 входных комтринаций
Результат не изменяется при перемене мест операндов.

x0=x 2102102102102102102102102101-й аргумент (операнд)
x1=y 2221110002221110002221110002-й аргумент (операнд)
x2=z 2222222221111111110000000003-й аргумент (операнд)
FT3N7 625 595 420 67210 222222222222211211222211210результат max(x,y,z)

Равенство

Вычисляется равенство всех трёх операндов x=y=z; eq20(x, y, z)
Результат не изменяется при перемене мест операндов.

x0=x 2102102102102102102102102101-й аргумент (операнд)
x1=y 2221110002221110002221110002-й аргумент (операнд)
x2=z 2222222221111111110000000003-й аргумент (операнд)
FT3N5 083 734 999 04010 200000000000020000000000002результат eq20(x,y,z)

Бинарный мультиплексор «2 в 1» с выключением

При z=0 пропускает на выход только первый аргумент,
при z=1 пропускает на выход только второй аргумент,
при z=2 выключается и ничего не пропускает на выход.
В троичной несимметричной системе кодирования с обозначением (-1,0,+1)=(0,1,2).
В виде таблицы истинности:

x0=x 2102102102102102102102102101-й аргумент (операнд)
x1=y 2221110002221110002221110002-й аргумент (операнд)
x2=z 2222222221111111110000000003-й аргумент (операнд) управляющий
FT3N379 996 22410 000000000222111000210210210результат MUX(x,y,z)

Бинарный мультиплексор «2 в 1»

Смешанная троично-двоичная функция, два аргумента которой x и y — троичные, а третий z — двоичный.
При z=0 пропускает на выход только первый аргумент,
при z=1 пропускает на выход только второй аргумент.

В троичной несимметричной системе кодирования с обозначением (-1,0,+1)=(0,1,2).
В виде таблицы истинности:

x0=x 2102102102102102101-й аргумент (операнд)
x1=y 2221110002221110002-й аргумент (операнд)
x2=z 1111111110000000003-й аргумент (операнд) управляющий
FT2B1N379 996 22410 222111000210210210результат MUX(x,y,z)

Функция имеет тот же номер, что и предыдущая, но 3-й аргумент двоичный, а не троичный. T2 обозначает, что два аргумента троичные несимметричные, а B1 (Binary) обозначает, что один аргумент двоичный.

Единица переноса при полном троичном сложении в несимметричной троичной системе счисления

Функция смешанная, троично-двоичная. Два аргумента x и y — троичные, а третий аргумент z — двоичный.
Результат не изменяется при перемене мест операндов.

x0=x 2102102102102102101-е слагаемое
x1=y 2221110002221110002-е слагаемое
x2=z 111111111000000000Перенос из (n − 1)-го разряда
FT2B1N193 099 21610 111110100110100000Перенос в (n + 1)-й разряд

Функция со всеми тремя троичными аргументами, имеет такой же номер, но T2 обозначает, что два аргумента троичные несимметричные, а 1B (Binary) обозначает, что один аргумент двоичный.

Сумма по модулю 3 при полном троичном сложении в несимметричной троичной системе счисления

Полное троичное сложение — тринарная (трёхаргументная, трёхоперандная) троичная функция учитывающая единицу переноса из предыдущего разряда.
Функция смешанная, троично-двоичная. Два аргумента x и y — троичные, а третий аргумент z — двоичный.
Результат не изменяется при перемене мест операндов.

x0=x 2102102102102102101-е слагаемое
x1=y 2221110002221110002-е слагаемое
x2=z 111111111000000000Перенос из (n − 1)-го разряда
FT2B1N30731891210 210102021102021210Сумма по модулю 3

Функция со всеми тремя троичными аргументами, имеет такой же номер, но T2 обозначает, что два аргумента троичные несимметричные, а B1 (Binary) обозначает, что один аргумент двоичный.

Тринарные троичные логические функции (операции, элементы) с бинарным (двухразрядным) результатом (выходом)

Всего возможно (58 септиллионов 149 секстиллионов 737 квинтиллионов 003 квадриллиона 040 триллионов 059 миллиардов 690 миллионов 390 тысяч 169) простейших тринарных (триарных) троичных функций с бинарным выходом. Из этого числа наибольшую значимость имеют такие тринарные троичные функции, имеющие собственные названия, как сумматоры, шифраторы, дешифраторы, мультиплексоры, демультиплексоры.

Полное троичное несимметричное сложение в несимметричной троичной системе счисления

Полный одноразрядный троичный несимметричный сумматор является тринарной троичной логической функцией. Разряд (трит) переноса имеет только два значения 0 и 1 из трёх возможных. В отличие от предыдущих троичных тринарных функций с одноразрядным результатом, результат имеет длину 1 и 2/3 троичных разряда.
Результат не изменяется при перемене мест операндов.

x0 2102102102102102101-е слагаемое
x1 2221110002221110002-е слагаемое
x2 111111111000000000Перенос из (n − 1)-го разряда
FT2B1N307 318 91210 210102021102021210МЗР (трит) несимметричной суммы, сумма по модулю 3
FT2B1N193 099 21610 111110100110100000СЗР (бит) несимметричной суммы, бит переноса в (n + 1)-й разряд
Снимок модели одноразрядного полного троичного сумматора в троичной несимметричной системе счисления в трёхбитной одноединичной системе логических элементов в логическом симуляторе Atanua[33].

В разряде переноса не бывает третьего значения троичного разряда (2), так как в «худшем» случае , то есть в старшем разряде «1». Единица переноса возникает в 9 случаях из 18.
Как в двоичной логике двоичный тринарный полный сумматор заменяется двумя бинарными полусумматорами, так и в троичной логике троичный тринарный полный сумматор можно заменить на два троичных бинарных полусумматора, только с той разницей, что два двоичных бинарных полусумматора одинаковые, а два троичных бинарных полусумматора разные.
1. Один полусумматор полный бинарный («сложение двух полных троичных разрядов»). Второй полусумматор — не полный бинарный («сложение одного полного троичного разряда с неполным троичным разрядом (с 2/3 от полного троичного разряда)»), так как в разряде переноса не бывает значений больших чем «1».
2. Один неполный бинарный «сложение 1 троичного разряда с 2/3 троичного разряда». Второй бинарный несимметричный «сложение 1 троичного разряда с 1 и 2/3 троичного разряда». Результат — двухразрядный длиной 1 и 2/3 троичных разряда.

Полное троичное логическое вычитание с займом в несимметричной троичной системе счисления

Полный троичный одноразрядный вычитатель является неполной тринарной троичной логической функцией, так как в разряде займа только два значения 0 и 1. Результат имеет длину 1 и 2/3 троичных разряда.
Результат изменяется при перемене мест операндов.

x0 210210210210210210уменьшаемое
x1 2221110002221110001-е вычитаемое
x2 1111111110000000002-е вычитаемое, заём в (n − 1)-й разряд
FT2B1N305 269 05610 210021102021102210МЗР разности, разность по модулю 3
FT2B1N188 684 17610 111011001011001000СЗР разности, заём из (n + 1)-го разряда

В разряде займа не бывает третьего значения троичного разряда (2), так как в «худшем» случае , то есть в старшем разряде «1». Единица займа возникает в 9 случаях из 18.

Троичный симметричный сумматор-вычитатель

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

Троичный симметричный сумматор-вычитатель
Снимок модели одноразрядного полного троичного сумматора в троичной симметричной системе счисления (Фибоначчи) в трёхбитной одноединичной системе логических элементов в логическом симуляторе Atanua[33].
Снимок модели троичного тринарного (трёхоперандного, полного) сумматора-вычитателя в троичной симметричной системе счисления Фибоначчи в двухбитной системе троичных логических элементов в логическом симуляторе Atanua[33].

В отличие от сложения в несимметричной троичной системе счисления при сложении в симметричной троичной системе счисления в разряде переноса могут быть все три значения (-1,0,1), поэтому число комтринаций увеличивается с 18 до 27.
Результат не изменяется при перемене мест операндов.

В троичной симметричной системе счисления со знаками (i,0,1)=(-1,0,+1).

В виде таблицы истинности:

x0=x 10i10i10i10i10i10i10i10i10iОбозначение1-е слагаемое
x1=y 111000iii111000iii111000iii2-е слагаемое
x2=z 111111111000000000iiiiiiiiiПеренос из (n − 1)-го разряда
0i1i1010ii1010i0i110i0i1i10FT3S-62460370377610(x,y,z)МЗР (мл. знач. разр.) суммы
11010000010000000i00000i0iiFT3S348342673704810(x,y,z)СЗР суммы, перенос в n+1

перенос (1 или −1) возникает в 8 случаях из 27, четыре раза −1 и четыре раза 1.

В троичной симметричной системе счисления со знаками (2,0,1)=(-1,0,+1).

В виде двух кубов размером 3x3x3 (типа кубика Рубика):
Куба младшего разряда суммы, состоящего из трёх слоёв:

     y  z = 0         y  z = 1        y  z = 2
     ^                ^               ^
     |                |               |
  2  0  1          0  1  2         1  2  0 
- 1  2  0 -> x   - 2  0  1 -> x  - 0  1  2 -> x 
  0  1  2          1  2  0         2  0  1  
     |                |               |
  FT2N8229         FT2N15613       FT2N5681

и куба старшего разряда суммы (переноса), состоящего из трёх слоёв:

     y  z = 0         y  z = 1        y  z = 2
     ^                ^               ^
     |                |               |
  0  0  2          0  0  0         2  0  2
- 0  1  0 -> x   - 1  1  0 -> x  - 0  0  0 -> x
  0  0  0          0  1  0         0  0  2  
     |                |               |
  FT2N13203        FT2N111         FT2N14598

В виде таблицы истинности:

x0=x 210210210210210210210210210A, 1-е слагаемое
x1=y 222111000222111000222111000B, 2-е слагаемое
x2=z 222222222111111111000000000Cin, перенос из (n − 1)-го разряда
FT3N220124309094410 021210102210102021102021210S, МЗР (мл. знач. разр.) суммы
FT3N565556647361510 202000200000011010200010000Cout, СЗР суммы, перенос в n+1

В виде двух строк:
строки значений младшего разряда (трита) S суммы:
021210102210102021102021210 или c зада наперёд 012120201120201012201012120
строки значений старшего разряда (трита) Cout суммы (трита переноса):
202000200000011010200010000 или с зада наперёд 000010002010110000002000202

Одна из множества возможных реализаций табличного троичного симметричного сумматора:
на Java:

// Табличный одноразрядный (однотритный) троичный симметричный сумматор-вычитатель
// в системе обозначений (-1,0,+1)=(2,0,1) 
import java.io.*;

class TernaryAdderSubstractor
{
public static void main (String[] args) throws java.lang.Exception
{
int[][][]S={{{0,1,2},{1,2,0},{2,0,1}},{{1,2,0},{2,0,1},{0,1,2}},{{2,0,1},{0,1,2},{1,2,0}}};
int[][][]C={{{0,0,0},{0,1,0},{0,0,2}},{{0,1,0},{1,1,0},{0,0,0}},{{0,0,2},{0,0,0},{2,0,2}}}; 
int A = 2;   // (2,0,1)=(-1,0,+1)
int B = 2;   // (2,0,1)=(-1,0,+1)
int Cin=2;   // (2,0,1)=(-1,0,+1)
System.out.println("" + C[A][B][Cin] + S[A][B][Cin]);
}
}

на JavaScript:

// Табличный одноразрядный (однотритный) троичный симметричный сумматор-вычитатель
// в системе обозначений (-1,0,+1)=(2,0,1) 
//importPackage(java.io);
importPackage(java.lang);

var S=[[[0,1,2],[1,2,0],[2,0,1]],[[1,2,0],[2,0,1],[0,1,2]],[[2,0,1],[0,1,2],[1,2,0]]];
var C=[[[0,0,0],[0,1,0],[0,0,2]],[[0,1,0],[1,1,0],[0,0,0]],[[0,0,2],[0,0,0],[2,0,2]]];
var A = 2;   // (2,0,1)=(-1,0,+1)
var B = 2;   // (2,0,1)=(-1,0,+1)
var Cin=2;   // (2,0,1)=(-1,0,+1)
System.out.println( C[A][B][Cin].toString() + S[A][B][Cin].toString() ); 
//alert( C[A][B][Cin].toString() + S[A][B][Cin].toString() ); // For Plunker (plnkr.co/edit)

на Python:

"""Табличный одноразрядный (однотритный) троичный симметричный сумматор-вычитатель
в системе обозначений (-1,0,+1)=(2,0,1)"""
S = [[[0,1,2],[1,2,0],[2,0,1]],[[1,2,0],[2,0,1],[0,1,2]],[[2,0,1],[0,1,2],[1,2,0]]]
C = [[[0,0,0],[0,1,0],[0,0,2]],[[0,1,0],[1,1,0],[0,0,0]],[[0,0,2],[0,0,0],[2,0,2]]]
A = 2
B = 2
Cin=2
print C[A][B][Cin],S[A][B][Cin]

на С++:

// Табличный одноразрядный (однотритный) троичный симметричный сумматор-вычитатель
// в системе обозначений (-1,0,+1)=(2,0,1) 
#include <iostream>
using namespace std;

void main() {
int S[3][3][3]={0,1,2,1,2,0,2,0,1, 1,2,0,2,0,1,0,1,2, 2,0,1,0,1,2,1,2,0};
int C[3][3][3]={0,0,0,0,1,0,0,0,2, 0,1,0,1,1,0,0,0,0, 0,0,2,0,0,0,2,0,2};
int A = 2;    // (2,0,1)=(-1,0,+1)
int B = 2;    // (2,0,1)=(-1,0,+1)
int Cin=0;    // (2,0,1)=(-1,0,+1)
cout << C[A][B][Cin] << ' ' << S[A][B][Cin];
}

на C:

// Табличный одноразрядный (однотритный) троичный симметричный сумматор-вычитатель
// в системе обозначений (-1,0,+1)=(2,0,1) 
#include <stdio.h>

void main() { 
int S[3][3][3]={0,1,2,1,2,0,2,0,1, 1,2,0,2,0,1,0,1,2, 2,0,1,0,1,2,1,2,0};
int C[3][3][3]={0,0,0,0,1,0,0,0,2, 0,1,0,1,1,0,0,0,0, 0,0,2,0,0,0,2,0,2};
int A = 2;    // (2,0,1)=(-1,0,+1)
int B = 2;    // (2,0,1)=(-1,0,+1)
int Cin=2;    // (2,0,1)=(-1,0,+1)
printf("%i%i", C[A][B][Cin], S[A][B][Cin]);
}

на PHP:

<?php
// Табличный одноразрядный (однотритный) троичный симметричный сумматор-вычитатель
// в системе обозначений (-1,0,+1)=(2,0,1) 
$S=[[[0,1,2],[1,2,0],[2,0,1]],[[1,2,0],[2,0,1],[0,1,2]],[[2,0,1],[0,1,2],[1,2,0]]];
$C=[[[0,0,0],[0,1,0],[0,0,2]],[[0,1,0],[1,1,0],[0,0,0]],[[0,0,2],[0,0,0],[2,0,2]]];
$A = 2;
$B = 2;
$Cin=2;
echo(int)($C[$A][$B][$Cin]);
echo(int)($S[$A][$B][$Cin]);
?>

(Проверить и изменить коды программ на Java, JavaScript, Python, C++, C, PHP и др. можно во многих онлайн компиляторах, например в онлайн компиляторе для 60 языков программирования на сайте ideone.com[34].)

на TB:

' Save this supermain program as file "job.bas"
$include "main%.bas"

if fn main% then print "Job done. No errors."
end
' Save this main program (function main%) as file "main%.bas"
' One trit ternary simmetric adder-subtractor
' in simbol sistem (-1,0,+1)=(2,0,1)
$include "tlib.inc"

def fn main%
dim S%(2,2,2):data 0,1,2,1,2,0,2,0,1, 1,2,0,2,0,1,0,1,2, 2,0,1,0,1,2,1,2,0:_call it3df(S%())
dim C%(2,2,2):data 0,0,0,0,1,0,0,0,2, 0,1,0,1,1,0,0,0,0, 0,0,2,0,0,0,2,0,2:_call it3df(C%())
A% = 2     ' (2,0,1)=(-1,0,+1)
B% = 2     ' (2,0,1)=(-1,0,+1)
Cin%=0     ' (2,0,1)=(-1,0,+1)
print C%(A%,B%,Cin%) ; " " ; S%(A%,B%,Cin%)
fn main% = -1
end def
' Save this sub in file "tlib.inc"
sub it3df (F%(3)) ' InitTernary3DimentionFunction F%()
  local i%,j%,k%
  for i%=0 to 2
    for j%=0 to 2
      for k%=0 to 2
        read F% (i%,j%,k%)
      next k%
    next j%
  next i%
end sub

В троичной симметричной системе счисления со знаками (0,1,2)=(-1,0,+1).

В виде двух кубов размером 3x3x3 (типа кубика Рубика):
Куба младшего разряда суммы, состоящего из трёх слоёв:

     y  z = 0         y  z = 1        y  z = 2
     ^                ^               ^
     |                |               |
  0  1  2          1  2  0         2  0  1
- 2  0  1 -> x   - 0  1  2 -> x  - 1  2  0 -> x
  1  2  0          2  0  1         0  1  2  
     |                |               |
  FT2N15613        FT2N5681        FT2N8229

и куба старшего разряда суммы (переноса), состоящего из трёх слоёв:

     y  z = 0         y  z = 1        y  z = 2
     ^                ^               ^
     |                |               |
  1  1  1          1  1  2         1  2  2
- 0  1  1 -> x   - 1  1  1 -> x  - 1  1  2 -> x
  0  0  1          0  1  1         1  1  1  
     |                |               |
  FT2N9810         FT2N16401       FT2N18832

В виде таблицы истинности:

x0=x 210210210210210210210210210A, 1-е слагаемое
x1=y 222111000222111000222111000B, 2-е слагаемое
x2=z 222222222111111111000000000Cin, перенос из (n − 1)-го разряда
FT3N3 188 195 065 85610 102021210021210102210102021S, МЗР (мл. знач. разр.) суммы
FT3N7 296 225 640 44810 221211111211111110111110100Cout, СЗР суммы, перенос в n+1

ноль в разряде переноса возникает в 4 случаях, единица в разряде переноса возникает в 18 случаях, двойка в разряде переноса возникает в 4 случаях.

В виде двух строк:
строки значений младшего разряда (трита) S суммы:
102021210021210102210102021 или c зада наперёд 120201012201012120012120201
строки значений старшего разряда (трита) Cout суммы (трита переноса):
221211111211111110111110100 или с зада наперёд 001011111011111112111112122

Тринарные троичные функции с тринарным выходом

Всего возможны ≈4.43*1038 простейших тринарных троичных функций с тринарным выходом.

Троичный дешифратор «2 и 2/3 трита в 18 строк»

Можно рассматривать как объединение 18 тринарных (триарных) троичных функций с унарными результатами (выходами).
Результат не изменяется при перемене мест операндов.

x0=x 210210210210210210
x1=y 222111000222111000
x2=z 111111111000000000
0 000000000000000001
1 000000000000000010
2 000000000000000100
3 000000000000001000
4 000000000000010000
5 000000000000100000
6 000000000001000000
7 000000000010000000
8 000000000100000000
9 000000001000000000
10 000000010000000000
11 000000100000000000
12 000001000000000000
13 000010000000000000
14 000100000000000000
15 001000000000000000
16 010000000000000000
17 100000000000000000

Троичный дешифратор «3 трита в 27 строк»

Можно рассматривать как объединение 27 тринарных (триарных) троичных функций с унарными результатами (выходами).

Тетрарные троичные логические функции (операции, элементы) с m-арным результатом

Всего возможно простейших тетрарных троичных функций с m-арным выходом.

Тетрарные троичные логические функции (операции, элементы) с унарным результатом

Всего возможно простейших тетрарных троичных функций с унарным выходом.

Троичный тринарный (трёхвходовой) мультиплексор

Имеет четыре входа:
1. первое троичное число
2. второе троичное число
3. третье троичное число
4. троичный сигнал переключения 3 входов
и один выход:
1. выбранное троичное число

В троичном несимметричном кодировании с обозначениями (−1, 0, +1) = (0, 1, 2):
Таблица истинности:

x0=x xxx1-й аргумент (операнд)
x1=y yyy2-й аргумент (операнд)
x2=z zzz3-й аргумент (операнд)
x3=u 2104-й аргумент (операнд) управляющий
FT4NMUX(x,y,z,u) zyxрезультат действия тетрарной троичной функции MUX(x,y,z,u)

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

FT4NMUX(x, y,z, u) = FT2N21(x, u) FT2N19569 FT2N567(y, u) FT2N19569 FT2N15309(z, u) =
= FT2N21(x, u) FT2Nmax FT2N567(y, u) FT2Nmax FT2N15309(z, u) =
= FT2Nmax(FT2Nmax(FT2N21(x, y),FT2N567(y, x)),FT2N15309(z, u))

Здесь бинарные (двухаргументные) троичные функции FT2N21(x, u), FT2N567(y, u) и FT2N15309(z, u) используются в префиксной записи для выделения первого, второго или третьего операнда, а бинарная (двухоперандная) троичная функция FT2N19569 (FT2Nmax) в первой и второй строке используется в качестве бинарного (двухоперандного) оператора с инфиксной записью в строке, а в третьей строке в качестве бинарной (двухаргументной) троичной функции с префиксной записью в строке для обработки трёх предыдущих результатов, подобно двоичному оператору и функции OR2 (2ИЛИ) в двоичной логике. При этом функции в первой и во второй строке имеют более высший приоритет в строке, то есть выполняются по очереди первыми, а операторы в первой и второй строке имеют более низший приоритет, чем бинарные (двухаргументные) функции, то есть выполняются по очереди вторыми после выполнения функций. Третья строка состоит только из вложенных функций, поэтому функции выполняются по очереди начиная с функции с самым глубоким вложением.

N-арные троичные логические функции

N-арные троичные логические функции

Всего возможно простейших n-арных троичных функций.

К этим функциям относятся n-арные шифраторы и n-арные мультиплексоры.


См. также

Примечания

  1. Троичные триггеры в трёхбитной системе троичных логических элементов 3B BCT (3-Bit BinaryCodedTrinary, «трёхпроводная»)
  2. Троичные триггеры в трёхуровневой системе троичных логических элементов 3L CT (3-Level CodedTrinary, «однопроводная»)
  3. Депман И. Я. Возникновение системы мер и способов измерения величин. Выпуск 1. (1956) Глава VIII. Задача Д. И. Менделеева о наилучшей системе гирь. § Все числа троичной системы могут быть записаны при помощи двух цифр: 0 или 1. С. 113.
  4. Unary Operations. Table 4: Rotate Up https://web.archive.org/web/20080622120236/http://www.trinary.cc/Tutorial/Algebra/Unary.htm
  5. http://jeff.tk:81/wiki/Trinary/Logic Архивная копия от 12 мая 2010 на Wayback Machine A.3.1. Constant Functions. Table A.3. Constant Functions и A.3.2. One-to-one Functions. Table A.4. One-to-one Functions
  6. Unary Operations. Table 7: Shift Down https://web.archive.org/web/20080622120236/http://www.trinary.cc/Tutorial/Algebra/Unary.htm
  7. Unary Operations. Table 5: Rotate Down https://web.archive.org/web/20080622120236/http://www.trinary.cc/Tutorial/Algebra/Unary.htm
  8. Unary Operations. Table 6: Shift Up https://web.archive.org/web/20080622120236/http://www.trinary.cc/Tutorial/Algebra/Unary.htm
  9. http://andserkul.narod2.ru/troichnie_alu/ А. С. Куликов. Троичные АЛУ
  10. https://web.archive.org/web/20080611055612/http://www.trinary.cc/ Веб архив. Сайт Стива Грабба Trinary.cc
  11. Материалы по троичной информатике. Аппаратная реализация. Маслов С. П. Троичная схемотехника
  12. Unary Operations. Invert https://web.archive.org/web/20080622120236/http://www.trinary.cc/Tutorial/Algebra/Unary.htm
  13. Circuits. Logic Families. Ternary. Complement(F210)
  14. Circuits. Logic Families. Ternary. F220
  15. Circuits. Logic Families. Ternary. F211
  16. Circuits. Logic Families. Ternary. F221
  17. http://jeff.tk:81/wiki/Trinary/Logic Архивная копия от 12 мая 2010 на Wayback Machine A.3.2. One-to-one Functions. Table A.4. One-to-one Functions
  18. Троичные трёхбитные триггеры
  19. Circuit. Logic Families. Ternary. CGOR
  20. Binary Function. Table 11: The Mean Function https://web.archive.org/web/20080623205822/http://www.trinary.cc/Tutorial/Algebra/Binary.htm
  21. Binary Functions. Mean https://web.archive.org/web/20080623205822/http://www.trinary.cc/Tutorial/Algebra/Binary.htm
  22. Circuit. Logic Families. Ternary. CGAND
  23. Binary Functions. Table 12: The Magnitude Function https://web.archive.org/web/20080623205822/http://www.trinary.cc/Tutorial/Algebra/Binary.htm
  24. [Binary Operations. Table 8: The Min Function (A↓B) https://web.archive.org/web/20080623205822/http://www.trinary.cc/Tutorial/Algebra/Binary.htm]
  25. [Binary Operations. Min https://web.archive.org/web/20080623205822/http://www.trinary.cc/Tutorial/Algebra/Binary.htm]
  26. [Binary Operations. Table 9: The Max Function (A↑B) https://web.archive.org/web/20080623205822/http://www.trinary.cc/Tutorial/Algebra/Binary.htm]
  27. [Binary Operations. Max https://web.archive.org/web/20080623205822/http://www.trinary.cc/Tutorial/Algebra/Binary.htm]
  28. Анатолий Медынцев. Обратимая троичная операция (недоступная ссылка). Дата обращения: 6 февраля 2012. Архивировано 25 июня 2012 года.
  29. http://www.pcmag.ru/solutions/sub_detail.php?ID=1985&SUB_PAGE=4 Суждение и вычисление: не исключая третье. Александр Рябцев. Импликация Лукасевича
  30. http://society.polbu.ru/tvardovsky_lvovwarsawphilo/ch43_i.html Архивная копия от 15 июля 2014 на Wayback Machine К. Твардовский. Львовско-Варшавская философская школа. Исторические исследования логики Я.Лукасевичем
  31. Three Valued Logic. 4. Сведения по трёхзначной логике
  32. http://www.inp.nsk.su/~kozak/ttl/ttlh01.htm Справочник по стандартным цифровым ТТЛ микросхемам
  33. http://andserkul.narod2.ru/troichnie_summatori/ А. С. Куликов. Троичные сумматоры
  34. Онлайн компилятор для 60 языков программирования

Литература

  • D. C. Rine (ed.), Computer Science and Multiple-Valued Logic. Theory and Applications. Elsevier, 1977, 548p. ISBN 978-0-7204-0406-7
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.