Троичная систeма счисления
Троичная систeма счисления — позиционная система счисления с основанием 3.
Существует в двух вариантах: несимметричная и симметричная.
В цифровой электронике, независимо от варианта троичной системы счисления, одному троичному разряду в троичной системе счисления соответствует один троичный триггер как минимум на трёх инверторах с логикой на входе или два двоичных триггера как минимум на четырёх инверторах.
Несимметричная троичная система счисления
Примером представления чисел в несимметричной троичной системе счисления может служить запись в этой системе целых положительных чисел:
Десятичное число | 0 | 1 | 2 | 3 |
4 | 5 | 6 | 7 | 8 | 9 | 10 |
Троичное число | 0 | 1 | 2 | 10 | 11 | 12 | 20 | 21 | 22 |
100 | 101 |
Если в десятичной системе счисления имеется 10 цифр и веса соседних разрядов различаются в 10 раз (разряд единиц, разряд десятков, разряд сотен), то в троичной системе используются только три цифры и веса соседних разрядов различаются в три раза (разряд единиц, разряд троек, разряд девяток, …). Цифра 1, написанная первой левее запятой, обозначает единицу; эта же цифра, написанная второй левее запятой, обозначает тройку и т.д.
В сдвоенных (спаренных, комбинированных) показательных позиционных троичных системах счисления используются две системы счисления:
- внутриразрядная система счисления с основанием a, числа которой используются для записи цифр и
- приписная межразрядная система счисления с основанием b.
Целое число в сдвоенной показательной позиционной системе счисления представляется в виде суммы произведений значений в разрядах (цифр) -
ak на k-тые степени числа b:
где:
- k - число от 0 до n-1, номер числового разряда,
- n - число разрядов,
- a - число, основание основной внутриразрядной системы счисления,
- ak — целые числа из множества a, называемые цифрами,
- b - число, основание межразрядной показательной весовой функции,
- bk - числа межразрядной функции, весовые коэффициенты разрядов.
Каждое произведение akbk в такой записи называется (a,b)-ичным разрядом.
При b=a образуются (a,a)-ичные системы счисления с произведением - akak и суммой -
, которые при a=3 превращаются в обычную (3,3)-ичную (троичную) систему счисления. При записи первый индекс часто опускается, иногда, когда есть упоминание в тексте, опускается и второй индекс.
Весовой коэффициент разряда - bk - приписной и, в общем случае, может быть необязательно показательной функцией от номера разряда - k, и необязательно степенью числа 3. Множество значений ak более ограниченно и более связано с аппаратной частью - числом устойчивых состояний триггеров или числом состояний группы триггеров в одном разряде регистра. В общем случае, ak могут быть тоже необязательно из троичного множества a={0,1,2}, но, чтобы спаренной системе быть троичной и называться троичной, как минимум, одна из двух систем должна быть троичной. Так как ak-тые ближе к аппаратной части и по ak-тым из множества a={0,1,2} или из множества a={-1,0,+1}, а не по bk мы определяем и относим число x(a,b) к троичным системам кодирования, то есть бо?льшие основания считать a основным основанием системы счисления, b в таком случае называется основанием вспомогательной системы счисления. Но и это весьма относительно, так как запись числа может быть в одной системе кодирования, а само число может быть в другой системе счисления. Пример: двоично-десятичное кодирование (BCD), в котором числа записываются в двоичном коде, а система счисления - десятичная.
Целое число x в сдвоенной (спаренной) позиционной троичной системе записывают в виде последовательности его цифр (строки цифр), перечисляемых слева направо по убыванию старшинства разрядов:
В показательных системах счисления значениям разрядов приписываются весовые коэффициенты bk, в записи они опускаются, но подразумевается, что k-тый разряд справа налево имеет весовой коэффициент равный bk.
Из комбинаторики известно, что число записываемых кодов не зависит от основания показательной функции - b, которое определяет диапазон представляемых числами x3,b величин, и равно числу размещений с повторениями:
где:
a=3 - 3-х элементное множество a={0,1,2} из которого берутся цифры ak, n - число элементов (цифр) в числе x3,b.
Дробное число записывается и представляется в виде:
где m - число разрядов дробной части сдвоенного (спаренного) позиционного числа справа от запятой,
при m=0 дробная часть отсутствует, число - целое,
при ak из троичного множества a={0,1,2} и b=1 образуется непозиционная троичная система счисления с одинаковыми весовыми коэффициентами всех разрядов равными 1k=1,
при ak из двоичного множества a={0,1} и b=3 в сумме будут только целые степени - 3k,
при ak из троичного множества a={0,1,2} и b=3 в сумме будут целые и удвоенные степени 3, система счисления становится обычной несимметричной троичной системой счисления, ak удовлетворяют неравенству 0<=ak<=(b-1)<b, т.е. 0<=ak<=2<3,
при ak из десятичного множества a={0,1,2,3,4,5,6,7,8,9} и b=3 в сумме будут целые степени 3 умноженные на 1, 2, 3, 4, 5, 6, 7, 8 и 9.
В некоторых случаях этого может оказаться недостаточно, в таких случаях можно применить строенные (комтринированные), счетверённые и другие системы счисления.
В строенных (комтринированных) показательных позиционных троичных системах счисления используются три системы счисления. В вес разряда вводится дополнительный член в третьей системе счисления. Например, сомножитель (b/с):
В общем случае c<>3.
При ak из a={0,1,2}, b=3 и c=3 образуется обычная несимметричная троичная система счисления.
При a=2, b=3 и c=2 образуется (2,3,2)-ичная система счисления с дополнительным нецелочисленным весовым коэффициентом в произведении равным (3/c)=(3/2)=1,5.
При других значениях a, b и c образуются другие строенные показательные позиционные системы счисления с дополнительным сомножителем (b/c), число которых бесконечно.
Возможны бесконечные множества и других составных систем систем счисления.
Одна троичная цифра может кодироваться разными способами.
1. Трёхуровневое однопроводное кодирование:
2 - (+1) ;
1 - (0) ;
0 - (-1) .
2. Двухуровневое двухразрядное двухпроводное кодирование 1:
2 - (1,0);
1 - (0,1);
0 - (0,0).
3. Двухуровневое двухразрядное двухпроводное кодирование 2:
2 - (1,1);
1 - (0,1);
0 - (0,0).
3. Трёхразрядное одноединичное трёхпроводное кодирование 1:
2 - (1,0,0);
1 - (0,1,0);
0 - (0,0,1).
4. Трёхразрядное однонулевое трёхпроводное кодирование 2:
2 - (0,1,1);
1 - (1,0,1);
0 - (1,1,0).
5. Трёхразрядное единичное (унарное) трёхпроводное кодирование 3:
2 - (1,1,1);
1 - (0,1,1);
0 - (0,0,1).
6. Двухуровневое нулевое трёхпроводное кодирование 4:
2 - (0,0,0);
1 - (1,0,0);
0 - (1,1,0).
и др.
При поразрядном сравнении троичная система счисления оказывается более ёмкой, чем двоичная система счисления.
При девяти разрядах двоичный код имеет ёмкость 29 = 512 чисел, а троичный код имеет ёмкость 39 = 19683 числа, т.е. в 39 / 29 = 38,4 раза больше.
При двадцати семи разрядах двоичный код имеет ёмкость 227 = 134217728 чисел, а троичный код имеет ёмкость 327 = 7625597484987 чисел, т.е. в 327 / 227 = 56815,13 раз больше.
При восьмидесяти одном разряде двоичный код имеет ёмкость 281 = 2417851693229258349412352 числа, а троичный код имеет ёмкость
381 = 4,434e + 38 чисел, т.е. в 381 / 281 = 183396897083556,95 раз больше.
Троичная позиционная показательная несимметричная троичная система счисления по затратам числа знаков (в трёхразрядном десятичном числе 3*10=30 знаков) наиболее экономична из позиционных показательных несимметричных систем счисления. А. Кушнеров приписывает эту теорему Джону фон Нейману.
Для перевода целое десятичное число делят нацело с остатком (целочисленное деление) на 3 до тех пор, пока частное больше нуля. Остатки, записанные слева направо от последнего к первому являются целым несимметричным троичным эквивалентом целого десятичного числа.
Пример: десятичное целое число 4810,10 переведём в несимметричное троичное целое число:
число = 4810,10 делим на 3, частное = 16, остаток a0 = 0
частное = 1610,10 делим на 3, частное = 5, остаток a1 = 1
частное = 510,10 делим на 3, частное = 1, остаток a2 = 2
частное = 110,10 делим на 3, частное = 0, остаток a3 = 1
Частное не больше нуля, деление закончено.
Теперь, записав все остатки от последнего к первому слева напрво, получим результат 4810,10 = (a3a2a1a0)3,3 = 12103,3.
Позиционная целочисленная симметричная троичная система счисления была предложена итальянским математиком Фибоначчи (Леонардо Пизанский) (1170 — 1250) для решения «задачи о гирях». Частный случай этой задачи был опубликован в книге Баше де Мезириака в XVII веке, позже этой задачей интересовался Д. И. Менделеев.
Симметричность при взвешивании на рычажных весах использовали с древнейших времён, добавляя гирю на чашу с товаром. Элементы троичной системы счисления были в системе счисления древних шумеров, в системах мер, весов и денег, в которых были единицы равные 3. Но только в симметричной троичной системе счисления Фибоначчи объединены оба этих свойства.
Симметричная троичная система использовалась в советской ЭВМ Сетунь. По затратам числа знаков на представление чисел она равна троичной несимметричной системе.
Возможно шесть соответствий троичной симметричной системы счисления и троичной несимметричной системы счисления:
| 1. | 2. | 3. | 4. | 5. | 6. |
| | | | | | |
1 | 2 | 1 | 0 | 0 | 2 | 1 |
0 | 1 | 0 | 2 | 1 | 0 | 2 |
1 | 0 | 2 | 1 | 2 | 1 | 0 |
В соответствии 2. сохраняются числовые значения 0 и 1.
Десятичная система | -3 | -2 | -1 | 0 |
1 | 2 | 3 | 4 | 5 | 6 |
7 | 8 | 9 |
Троичная несимметричная | -10 | -2 | -1 | 0 | 1 | 2 | 10 | 11 |
12 | 20 | 21 | 22 | 100 |
Троичная симметричная | 10 | 11 | 1 | 0 | 1 | 11 | 10 | 11 | 111 |
110 | 111 | 101 | 100 |
В троичной симметричной системе счисления знак 1 можно заменить знаком (не числом) i или 2 и, во втором случае, использовать для троичной симметричной системы счисления {-1,0,+1} знаки троичной несимметричной системы {2,0,1}.
Благодаря тому что основание 3 нечётно, в троичной системе возможно симметричное относительно нуля расположение цифр: -1, 0, 1, с которым связано четыре ценных свойства:
- Естественность представления отрицательных чисел;
- Отсутствие проблемы округления.
- Таблица умножения в этой системе, как отметил О. Л. Коши, примерно в четыре раза короче.
- Для изменения знака у представляемого числа нужно изменять знаки у всех его цифр. Это свойство увеличивает число операций при перемене знака (в несимметричных системах изменяется только один знаковый разряд), но повышает надёжность при сбоях в одном или более разрядах.
Наличие положительной и отрицательной цифр позволяет непосредственно представлять как положительные, так и отрицательные числа. При этом нет необходимости в специальном разряде знака и не надо вводить дополнительный (или обратный) код для выполнения арифметических операций с отрицательными числами. Все действия над числами, представленными в троичной системе счисления с цифрами 0, 1, -1, выполняются естественно с учётом знаков чисел. Знак числа определяется знаком старшей значащей цифры числа: если она положительна, то и число положительно, если отрицательна, то и число отрицательно. Для изменения знака числа надо изменить знаки всех его цифр (т.е. инвертировать его код инверсией Лукасевича). Например:
Другим полезным следствием симметричного расположения значений цифр является отсутствие проблемы округления чисел: абсолютная величина части числа, представленной отбрасываемыми младшими цифрами, никогда не превосходит половины абсолютной величины части числа, соответствующей младшей значащей цифре младшего из сохраняемых разрядов. Следовательно, в результате отбрасывания младших цифр числа получается наилучшее при данном количестве оставшихся цифр приближение этого числа, и округление не требуется.
Всякое число, записанное в троичной системе счисления с цифрами 0, 1, -1, можно представить в виде суммы целых степеней числа 3, причём если в данном разряде троичного изображения числа стоит цифра 1, то соответствующая этому разряду степень числа 3 входит в сумму со знаком «+», если же цифра -1, то со знаком «-», а если цифра 0, то вовсе не входит. Это можно представить формулой:
где
— целая часть числа,
— дробная часть числа,
причём коэффициенты K могут принимать значения { 1, 0, -1 }.
Для того чтобы число, представленное в троичной системе, перевести в десятичную систему, надо цифру каждого разряда данного числа умножить на соответствующую этому разряду степень числа 3 (в десятичном представлении) и полученные произведения сложить.
Представление команд троичным кодом при программировании и при вводе в машину неудобно и неэкономно, поэтому вне машины применяется девятиричная форма представления команд. Девятиричные цифры сопоставляются парам троичных цифр:
При выводе из машины отрицательные девятиричные цифры обозначают буквами: