Немного деталей под катом.
Первым делом нужны базовые элементы. Вот так выглядит AND gate:
Если толкнуть один из входов («послать единицу»), на выходе получим «ноль»: «единица» на правом входе просто «закроет ключ», единица на левом же раздвоится, и тот сигнал, который ушёл вправо, закроет ключ для левого прежде чем тот дойдёт до него. Если же толкнуть оба входа, правый сигнал, закрыв ключ, не даст левому входу «самоуничтожиться», и на выход уйдёт «единица».
А это — XOR gate.
Здесь, если послать «единицы» на оба входа, домино остановятся посередине, и на выходе будет «ноль».
Из этих двух элементов составляется полусумматор, который принимает на вход два бита и на два выхода выдаёт их сумму: выход «единиц» — это XOR, выход «двоек» — AND.
Зигзаг справа — задержка сигнала, чтобы дать возможность закрыть ключ перед выходом двоек, если необходимо.
Левый выход — x XOR y — единицы, правый — (NOT (x XOR y)) AND y = x AND y — двойки.
Из двух полусумматоров получается уже полноценный сумматор, который помимо входных битов принимает ещё и бит переноса. Соединив три таких сумматора (и полусумматор для начальных битов, где перенос не требуется), команда получила калькулятор, который может сложить два четырёхбитных числа и выдать пятибитный ответ.
Главная проблема таких цепей — утечка сигнала. Неправильно упавшая или улетевшая кость домино может запустить другую цепочку, «сломав» таким образом вывод.
This entry passed through the Full-Text RSS service — if this is your content and you're reading it on someone else's site, please read the FAQ at http://ift.tt/jcXqJW.
Комментариев нет:
Отправить комментарий