RU2045770C1 - Устройство для формирования остатка по модулю три - Google Patents
Устройство для формирования остатка по модулю три Download PDFInfo
- Publication number
- RU2045770C1 RU2045770C1 SU5038171A RU2045770C1 RU 2045770 C1 RU2045770 C1 RU 2045770C1 SU 5038171 A SU5038171 A SU 5038171A RU 2045770 C1 RU2045770 C1 RU 2045770C1
- Authority
- RU
- Russia
- Prior art keywords
- input
- output
- boolean functions
- modulo
- bit
- Prior art date
Links
Images
Landscapes
- Error Detection And Correction (AREA)
Abstract
Изобретение относится к вычислительной технике и микроэлектронике и может быть использовано для построения средств аппаратурного контроля и цифровых устройств, работающих в системе остаточных классов. Устройство содержит два блока вычисления фундаментальных симметрических булевых функций, четыре элемента ИЛИ, сумматор по модулю три, n-входов и два выхода. Устройство для формирования остатка по модулю три работает следующим образом. На входы устройства поступают соответственно разряды x1....xn входного двоичного слова X=xn,xn-1...x1, причем x1 младший разряд. На выходах формируется двухразрядный двоичный код результата R= 2r1+r2 свертки по модулю три входного слова X R= Xmod3, ri∈{0,1}, i=1,2 и R∈ {0,1,2}. Достоинством устройства является высокое бистродействие. 1 ил. 3 табл.
Description
Изобретение относится к вычислительной технике и микроэлектронике и может быть использовано для построения средств аппаратурного контроля и цифровых устройств, работающих в системе остаточных классов.
На чертеже представлена схема устройства для формирования остатка по модулю три при разрядности входного двоичного слова, равной n 19.
Устройство содержит два блока вычисления фундаментальных симметрических булевых функций 1 и 2, четыре элемента ИЛИ 3, 4, 5 и 6, сумматор по модулю три 7, n 19 входов 81.819 и два выхода 91 и 92.
В общем случае устройство для формирования остатка по модулю три содержит сумматор по модулю три, четыре элемента ИЛИ и два блока вычисления фундаментальных симметрических булевых функций. При этом i-й и (i 1, 2) выход сумматора по модулю три является i-м выходом устройства, а j-й вход (j n разрядность входного двоичного слова) первого блока вычисления фундаментальных булевых функций является входом 2j-го разряда (начиная с младших разрядов) входного слова устройства, (2k-1)-й разряд входного слова устройства (k ) является k-м входом второго блока вычисления фундаментальных симметрических булевых функций. В устройстве p-й вход (p , v [n/2] /3[) первого элемента ИЛИ соединен с выходом функции с порогом 3p-2 первого блока вычисления фундаментальных симметрических булевых функций, r-й вход (r u([n/2-1]/3[) второго элемента ИЛИ соединен с выходом функции с порогом 3r-1 первого блока вычисления фундаментальных симметрических булевых функций, s-й вход (s wn/2[/3[) третьего элемента ИЛИ соединен с выходом функции с порогом 3s-2 второго блока вычисления фундаментальных симметрических булевых функций, t-й вход (t z(]n/2[-1)/3[) четвертого элемента ИЛИ соединен с выходом функции с порогом 3t-1 второго блока вычисления фундаментальных симметрических булевых функций. Выход первого элемента ИЛИ соединен с входом старшего разряда первого слагаемого сумматора по модулю три, вход старшего разряда второго слагаемого которого соединен с выходом четвертого элемента ИЛИ. Выход второго элемента ИЛИ соединен с входом младшего разряда первого cлагаемого сумматора по модулю три, вход младшего разряда второго слагаемого которого соединен с выходом третьего элемента ИЛИ.
Устройство для формирования остатка по модулю три при n 19 работает следующим образом.
На входы 81.819 устройства поступают соответственно разряды х1.х19 входного двоичного слова Х х19 х18 х17 х1, причем х1 младший разряд. На выходах 91 и 92 формируется двухразрядный двоичный код результата R 2r1 + r2 свертки по модулю три входного слова Х, ri(-{0,1} i 1, 2, и R(-{0,1,2} Причем на выходе 91 реализуется старший разряд r1, а на выходе 92 младший разряд r2 результата Р.
Поясним принцип работы устройства для формирования остатка по модулю три.
Пусть Х xn xn-1 xn-2 x1 разрядное двоичное слово и х1 младший разряд. Тогда результат свертки по модулю три входного слова можно представить в виде:
R 2r1 + r2 Xmod 3 (A + B) mod 3 (Amod 3 + Bmod 3) mod 3, где AX2k-1, BX2j
Обозначим: A mod 3 2a1 + a2 и Bmod 3 2b1 + b2. Следовательно,
(2(a1 + b1) + a2 + b2), (1) При этом
a1= Ф (2)
a2= Ф (3)
b1= F (4)
b2= F (5) где qn/2[, q [n/2] v[n/2]/3[, u([n/2]-1/3[, wn/2[/3[, z(]n/2[-1)/3[ и фундаментальные симметрические булевы функции Фq c и Fg d определяются следующим образом:
Ф
F
Здесь с d
Фундаментальные симметрические булевы функции Fg d и Фq c вычисляются соответственно первым и вторым блоками вычисления фундаментальных симметрических булевых функций (табл. 1 и 2). На выходах элементов ИЛИ реализуются функции a1, a2, b1 и b2 согласно выражениям (2)-(5). Результат свертки по модулю три входного слова формируется в соответствии с (1) на выходе сумматора по модулю три (табл. 3).
R 2r1 + r2 Xmod 3 (A + B) mod 3 (Amod 3 + Bmod 3) mod 3, где AX2k-1, BX2j
Обозначим: A mod 3 2a1 + a2 и Bmod 3 2b1 + b2. Следовательно,
(2(a1 + b1) + a2 + b2), (1) При этом
a1= Ф (2)
a2= Ф (3)
b1= F (4)
b2= F (5) где qn/2[, q [n/2] v[n/2]/3[, u([n/2]-1/3[, wn/2[/3[, z(]n/2[-1)/3[ и фундаментальные симметрические булевы функции Фq c и Fg d определяются следующим образом:
Ф
F
Здесь с d
Фундаментальные симметрические булевы функции Fg d и Фq c вычисляются соответственно первым и вторым блоками вычисления фундаментальных симметрических булевых функций (табл. 1 и 2). На выходах элементов ИЛИ реализуются функции a1, a2, b1 и b2 согласно выражениям (2)-(5). Результат свертки по модулю три входного слова формируется в соответствии с (1) на выходе сумматора по модулю три (табл. 3).
Так, при n 19 на входы 82, 84, 818 первого блока вычисления фундаментальных симметрических булевых функций 1 поступают переменные х2, х4, х18; на входы 81, 83, 819 второго блока вычисления фундаментальных симметрических булевых функций 2 поступают переменные х1, х3, х19. На выходах первого 3, второго 4, третьего 5 и четвертого 6 элементов ИЛИ реализуются соответственно функции a1, a2, b1и b2:
a1= Ф 0∨ Ф 0∨ Ф 0 (6)
a2= Ф 0∨ Ф 0∨ Ф 0∨ Ф (7)
b1= F ∨ F ∨ F (8)
b2= F ∨ F ∨ F (9)
На выходах 91 и 92 сумматора по модулю три формируется результат свертки по модулю три девятнадцатиразрядного входного слова.
a1= Ф
a2= Ф
b1= F
b2= F
На выходах 91 и 92 сумматора по модулю три формируется результат свертки по модулю три девятнадцатиразрядного входного слова.
Рассмотрим работу устройства на примере формирования остатка по модулю три для входного слова Х 1010010111101100110 (n 19).
Очевидно, на входы первого блока вычисления фундаментальных симметрических булевых функций 1 поступает вектор двоичных переменных Х1= х2, х4, х18 101011100, на входы второго блока вычисления фундаментальных симметрических булевых функций 2 -вектор двоичных переменных Х2 х1, х3, х19 0101110011.
Тогда A 6, B 5, и F9 5 1 (остальные фундаментальные симметрические булевы функции, формируемые на выходах блоков 1 и 2, равны нулю). Следовательно, с учетом (6)-(9) имеем
a1 a2 b1 0; b2 1.
a1 a2 b1 0; b2 1.
Сумматор по модулю три 7 выполняет сложение входных операндов согласно (1). Откуда R (2(0+0)+0+1)mod 3 1. На выходах 91 и 92сумматора 7 соответственно имеем: r1 0 и r2 1.
Таким образом, Хmod 31010010111101100110 mod 3 01.
Достоинством устройства для формирования остатка по модулю является высокое быстродействие, определяемое малой глубиной схемы.
Быстродействие устройства может быть рассчитано по формуле
T tFSM + tИЛИ + tSM, где tFSM, tИЛИ, tSM соответственно быстродействие блока вычисления фундаментальных симметрических булевых функций, элемента ИЛИ и сумматора по модулю три.
T tFSM + tИЛИ + tSM, где tFSM, tИЛИ, tSM соответственно быстродействие блока вычисления фундаментальных симметрических булевых функций, элемента ИЛИ и сумматора по модулю три.
Claims (1)
- УСТРОЙСТВО ДЛЯ ФОРМИРОВАНИЯ ОСТАТКА ПО МОДУЛЮ ТРИ, содержащее сумматор по модулю три, i-й; (i 1,2) выход которого является i-м выходом устройства, отличающееся тем, что оно содержит четыре элемента ИЛИ и два блока вычисления фундаментальных симметрических булевых функций, j-й вход n разрядность входного двоичного слова) первого из которых является входом 2j-го разряда (начиная с младших разрядов) входного слова устройства, вход (2k-1)-го разряда входного устройства (k 1, n/2[) соединен с k м входом второго блока вычисления фундаментальных симметрических булевых функций, p-й вход первого элемента ИЛИ соединен с выходом функции с порогом 3p-2 первого блока вычисления фундаментальных симметрических булевых функций, r-й вход второго элемента ИЛИ соединен с выходом функции с порогом 3r-1 первого блока вычисления фундаментальных симметрических булевых функций, s-й вход третьего элемента ИЛИ соединен с выходом функции с порогом 3s-2 второго блока вычисления фундаментальных симметрических булевых функций, t-й вход четвертого элемента ИЛИ соединен с выходом функции с порогом 3t-1 второго блока вычисления фундаментальных симметрических булевых функций, выход первого элемента ИЛИ соединен с входом старшего разряда первого слагаемого сумматора по модулю три, вход старшего разряда второго слагаемого которого соединен с выходом четвертого элемента ИЛИ, выход второго элемента ИЛИ соединен с входом младшего разряда второго слагаемого сумматора по модулю три, вход младшего разряда второго слагаемого которого соединен с выходом третьего элемента ИЛИ.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
SU5038171 RU2045770C1 (ru) | 1992-04-20 | 1992-04-20 | Устройство для формирования остатка по модулю три |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
SU5038171 RU2045770C1 (ru) | 1992-04-20 | 1992-04-20 | Устройство для формирования остатка по модулю три |
Publications (1)
Publication Number | Publication Date |
---|---|
RU2045770C1 true RU2045770C1 (ru) | 1995-10-10 |
Family
ID=21602284
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
SU5038171 RU2045770C1 (ru) | 1992-04-20 | 1992-04-20 | Устройство для формирования остатка по модулю три |
Country Status (1)
Country | Link |
---|---|
RU (1) | RU2045770C1 (ru) |
-
1992
- 1992-04-20 RU SU5038171 patent/RU2045770C1/ru active
Non-Patent Citations (2)
Title |
---|
Авторское свидетельство СССР N 1180899, кл. G 06F 11/00, 1983. * |
Авторское свидетельство СССР N 1211733, кл. G 06F 11/10, 1984. * |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
Kawahito et al. | A 32* 32-bit multiplier using multiple-valued MOS current-mode circuits | |
US5070471A (en) | High speed multiplier which divides multiplying factor into parts and adds partial end products | |
US5122982A (en) | Carry generation method and apparatus | |
US4730266A (en) | Logic full adder circuit | |
US4122527A (en) | Emitter coupled multiplier array | |
KR870009595A (ko) | 직렬-비트 2의 보수 디지탈 신호 처리 장치 | |
RU2045770C1 (ru) | Устройство для формирования остатка по модулю три | |
US5095455A (en) | Binary multiplier circuit with improved inputs | |
RU2045771C1 (ru) | Устройство для формирования остатка по модулю пять | |
JPH02501246A (ja) | 高速乗算器回路 | |
US3428903A (en) | Multipurpose logic circuit for performing 254 out of 256 discrete logical combinations of three variables | |
EP0326414B1 (en) | High speed multiplier | |
RU2018927C1 (ru) | Сумматор по модулю три | |
SU1667059A2 (ru) | Устройство дл умножени двух чисел | |
RU2021630C1 (ru) | Устройство для сложения по модулю три | |
RU2054709C1 (ru) | Устройство для умножения чисел в позиционном коде | |
US5239499A (en) | Logical circuit that performs multiple logical operations in each stage processing unit | |
RU2018928C1 (ru) | Устройство для сложения n чисел по модулю пять | |
KR970005175A (ko) | 파이프라인 구조에 근거한 곱셈/나눗셈 공유 처리기 구조 | |
RU2018929C1 (ru) | УСТРОЙСТВО ДЛЯ СЛОЖЕНИЯ ТРЕХ ЧИСЕЛ ПО МОДУЛЮ 2n+1 | |
SU1580347A1 (ru) | Устройство дл сравнени чисел | |
EP0213854A2 (en) | Fixed-Coefficient serial multiplication and digital circuits therefor | |
SU1647561A1 (ru) | Устройство дл умножени по модулю семь | |
SU1626385A1 (ru) | Устройство дл преобразовани двоичного кода в код системы счислени остаточных классов | |
SU1300462A1 (ru) | Устройство дл сложени |