Шифратор и дешифратор — различия между версиями

Материал из Викиконспекты
Перейти к: навигация, поиск
Строка 3: Строка 3:
  
 
{{Определение
 
{{Определение
|definition='''Дешифратор''' (англ. ''decoder'') — логический [[Реализация булевой функции схемой из функциональных элементов|схема]], имеющая $n$ входов $s_0$, $s_1$, $\ldots$, $s_{n-1}$ и $2^n$ выходов $z_0$, $z_1$, $\ldots$, $z_{2^n-1}$. На все выходы подаётся $0$, кроме выхода $z_i$, на который подаётся $1$, где $i$ — число, которое закодировано входами $s_0$, $s_1$, $\ldots$, $s_{n-1}$
+
|definition='''Дешифратор''' (англ. ''decoder'') — логический [[Реализация булевой функции схемой из функциональных элементов|схема]], имеющая <tex>n</tex> входов <tex>s_0</tex>, <tex>s_1</tex>, <tex>\ldots</tex>, <tex>s_{n-1}</tex> и <tex>2^n</tex> выходов <tex>z_0</tex>, <tex>z_1</tex>, <tex>\ldots</tex>, <tex>z_{2^n-1}</tex>. На все выходы подаётся <tex>0</tex>, кроме выхода <tex>z_i</tex>, на который подаётся <tex>1</tex>, где <tex>i</tex> — число, которое закодировано входами <tex>s_0</tex>, <tex>s_1</tex>, <tex>\ldots</tex>, <tex>s_{n-1}</tex>
 
}}
 
}}
  
 
==Принцип работы==
 
==Принцип работы==
  
[[Файл:2to4decoder.png|thumb|180px|Дешифратор $2$-to-$4$]]
+
[[Файл:2to4decoder.png|thumb|180px|Дешифратор <tex>2</tex>-to-<tex>4</tex>]]
  
Суть дешифратора заключается в том, что с помощью $n$ входов $s_0$, $s_1$, $\ldots$, $s_{n-1}$ можно задавать выход, на который будет подаваться $1$. Для того, чтобы лучше понять, как работает дешифратор, рассмотрим дешифратор $2$-to-$4$ (это значит, что у этого дешифратора есть два входа $s_0$ и $s_1$ и четыре выхода $z_0$, $z_1$, $z_2$ и $z_3$). Если $s_0 = s_1 = 0$, то на выходе $z_0$ будет значение $1$, на остальных выходах будет $0$. Если же $s_0 = 1$, $s_1 = 0$, то на выходе $z_1$ будет $1$, на остальных выходах будут $0$. Если $s_0 = 0$, $s _1 = 1$, то на выходе $z_2$ будет $1$, а на остальных входах будет $0$. Если же $s_0 = s_1 = 1$, то на выходе $z_3$ будет $1$, а на других — $0$. Для более ясной картины обратимся к таблице истинности.
+
Суть дешифратора заключается в том, что с помощью <tex>n</tex> входов <tex>s_0</tex>, <tex>s_1</tex>, <tex>\ldots</tex>, <tex>s_{n-1}</tex> можно задавать выход, на который будет подаваться <tex>1</tex>. Для того, чтобы лучше понять, как работает дешифратор, рассмотрим дешифратор <tex>2</tex>-to-<tex>4</tex> (это значит, что у этого дешифратора есть два входа <tex>s_0</tex> и <tex>s_1</tex> и четыре выхода <tex>z_0</tex>, <tex>z_1</tex>, <tex>z_2</tex> и <tex>z_3</tex>). Если <tex>s_0 = s_1 = 0</tex>, то на выходе <tex>z_0</tex> будет значение <tex>1</tex>, на остальных выходах будет <tex>0</tex>. Если же <tex>s_0 = 1</tex>, <tex>s_1 = 0</tex>, то на выходе <tex>z_1</tex> будет <tex>1</tex>, на остальных выходах будут <tex>0</tex>. Если <tex>s_0 = 0</tex>, <tex>s _1 = 1</tex>, то на выходе <tex>z_2</tex> будет <tex>1</tex>, а на остальных входах будет <tex>0</tex>. Если же <tex>s_0 = s_1 = 1</tex>, то на выходе <tex>z_3</tex> будет <tex>1</tex>, а на других — <tex>0</tex>. Для более ясной картины обратимся к таблице истинности.
  
 
{| class="wikitable"
 
{| class="wikitable"
 
|-
 
|-
! $S_0$ !! $S_1$ !!  $Z_0$ !! $Z_1$ !! $Z_2$ !! $Z_3$
+
! <tex>S_0</tex> !! <tex>S_1</tex> !!  <tex>Z_0</tex> !! <tex>Z_1</tex> !! <tex>Z_2</tex> !! <tex>Z_3</tex>
 
|-
 
|-
| $\textbf{0}$ || $\textbf{0}$ || $\textbf{1}$ || $0$ || $0$ || $0$
+
| <tex>\textbf{0}</tex> || <tex>\textbf{0}</tex> || <tex>\textbf{1}</tex> || <tex>0</tex> || <tex>0</tex> || <tex>0</tex>
 
|-
 
|-
| $\textbf{1}$ || $\textbf{0}$ || $0$ || $\textbf{1}$ || $0$ || $0$
+
| <tex>\textbf{1}</tex> || <tex>\textbf{0}</tex> || <tex>0</tex> || <tex>\textbf{1}</tex> || <tex>0</tex> || <tex>0</tex>
 
|-
 
|-
| $\textbf{0}$ || $\textbf{1}$ || $0$ || $0$ || $\textbf{1}$ || $0$
+
| <tex>\textbf{0}</tex> || <tex>\textbf{1}</tex> || <tex>0</tex> || <tex>0</tex> || <tex>\textbf{1}</tex> || <tex>0</tex>
 
|-
 
|-
| $\textbf{1}$ || $\textbf{1}$ || $0$ || $0$ || $0$ || $\textbf{1}$
+
| <tex>\textbf{1}</tex> || <tex>\textbf{1}</tex> || <tex>0</tex> || <tex>0</tex> || <tex>0</tex> || <tex>\textbf{1}</tex>
 
|}
 
|}
  
 
==Логическая схема==
 
==Логическая схема==
[[Файл:LogicSircuit1to2decoder.png|thumb|180px|Логическая схема дешифратора $1$-to-$2$]]
+
[[Файл:LogicSircuit1to2decoder.png|thumb|180px|Логическая схема дешифратора <tex>1</tex>-to-<tex>2</tex>]]
  
[[Файл:LogicSircuit2to4decoder.png|thumb|180px|Логическая схема дешифратора $2$-to-$4$]]
+
[[Файл:LogicSircuit2to4decoder.png|thumb|180px|Логическая схема дешифратора <tex>2</tex>-to-<tex>4</tex>]]
  
Давайте построим логическую схему дешифратора рекурсивным способом: допустим, что мы построили схему для $n-1$ элемента, теперь попробуем слить $n$-ый выход с предыдущими $n-1$ выходами. Для $n=1$ схема выглядит тривиальным образом: от входа $s_0$ отходят два провода, один напрямую соединён с выходом $z_0$, другой соединён с гейтом $NOT$, а гейт $NOT$ соединён с выходом $z_1$. Теперь допустим, что мы можем построить схему для $n-1$ входов. Тогда $n$-ый вход соединим с дешифратором $1$-to-$2$, а первые $n-1$ выходы соединим с дешифратором $(n-1)$-to-$(2^{n-1})$ и потом соединим каждый выход дешифратора $(n-1)$-to-$(2^{n-1})$ с каждым выходом дешифратора $1$-to-$2$ с помощью гейтов $AND$, потом соединим соответствующие гейты с выходами $z_i$ таким образом, чтобы значение на входе $z_i$ было равно $1$ только в том случае, если число $i$ кодируется входами $s_0$, $s_1$, $\ldots$, $s_{n-1}$. Очевидно, что мы таким образом перебрали всевозможные комбинации значений на входах $s_0$, $s_1$, $\ldots$, $s_{n-1}$, поэтому наша схема будет работать верно.
+
Давайте построим логическую схему дешифратора рекурсивным способом: допустим, что мы построили схему для <tex>n-1</tex> элемента, теперь попробуем слить <tex>n</tex>-ый выход с предыдущими <tex>n-1</tex> выходами. Для <tex>n=1</tex> схема выглядит тривиальным образом: от входа <tex>s_0</tex> отходят два провода, один напрямую соединён с выходом <tex>z_0</tex>, другой соединён с гейтом <tex>NOT</tex>, а гейт <tex>NOT</tex> соединён с выходом <tex>z_1</tex>. Теперь допустим, что мы можем построить схему для <tex>n-1</tex> входов. Тогда <tex>n</tex>-ый вход соединим с дешифратором <tex>1</tex>-to-<tex>2</tex>, а первые <tex>n-1</tex> выходы соединим с дешифратором <tex>(n-1)</tex>-to-<tex>(2^{n-1})</tex> и потом соединим каждый выход дешифратора <tex>(n-1)</tex>-to-<tex>(2^{n-1})</tex> с каждым выходом дешифратора <tex>1</tex>-to-<tex>2</tex> с помощью гейтов <tex>AND</tex>, потом соединим соответствующие гейты с выходами <tex>z_i</tex> таким образом, чтобы значение на входе <tex>z_i</tex> было равно <tex>1</tex> только в том случае, если число <tex>i</tex> кодируется входами <tex>s_0</tex>, <tex>s_1</tex>, <tex>\ldots</tex>, <tex>s_{n-1}</tex>. Очевидно, что мы таким образом перебрали всевозможные комбинации значений на входах <tex>s_0</tex>, <tex>s_1</tex>, <tex>\ldots</tex>, <tex>s_{n-1}</tex>, поэтому наша схема будет работать верно.
  
 
==См. также==
 
==См. также==

Версия 11:21, 4 декабря 2018

Эта статья находится в разработке!


Определение:
Дешифратор (англ. decoder) — логический схема, имеющая [math]n[/math] входов [math]s_0[/math], [math]s_1[/math], [math]\ldots[/math], [math]s_{n-1}[/math] и [math]2^n[/math] выходов [math]z_0[/math], [math]z_1[/math], [math]\ldots[/math], [math]z_{2^n-1}[/math]. На все выходы подаётся [math]0[/math], кроме выхода [math]z_i[/math], на который подаётся [math]1[/math], где [math]i[/math] — число, которое закодировано входами [math]s_0[/math], [math]s_1[/math], [math]\ldots[/math], [math]s_{n-1}[/math]


Принцип работы

Дешифратор [math]2[/math]-to-[math]4[/math]

Суть дешифратора заключается в том, что с помощью [math]n[/math] входов [math]s_0[/math], [math]s_1[/math], [math]\ldots[/math], [math]s_{n-1}[/math] можно задавать выход, на который будет подаваться [math]1[/math]. Для того, чтобы лучше понять, как работает дешифратор, рассмотрим дешифратор [math]2[/math]-to-[math]4[/math] (это значит, что у этого дешифратора есть два входа [math]s_0[/math] и [math]s_1[/math] и четыре выхода [math]z_0[/math], [math]z_1[/math], [math]z_2[/math] и [math]z_3[/math]). Если [math]s_0 = s_1 = 0[/math], то на выходе [math]z_0[/math] будет значение [math]1[/math], на остальных выходах будет [math]0[/math]. Если же [math]s_0 = 1[/math], [math]s_1 = 0[/math], то на выходе [math]z_1[/math] будет [math]1[/math], на остальных выходах будут [math]0[/math]. Если [math]s_0 = 0[/math], [math]s _1 = 1[/math], то на выходе [math]z_2[/math] будет [math]1[/math], а на остальных входах будет [math]0[/math]. Если же [math]s_0 = s_1 = 1[/math], то на выходе [math]z_3[/math] будет [math]1[/math], а на других — [math]0[/math]. Для более ясной картины обратимся к таблице истинности.

[math]S_0[/math] [math]S_1[/math] [math]Z_0[/math] [math]Z_1[/math] [math]Z_2[/math] [math]Z_3[/math]
[math]\textbf{0}[/math] [math]\textbf{0}[/math] [math]\textbf{1}[/math] [math]0[/math] [math]0[/math] [math]0[/math]
[math]\textbf{1}[/math] [math]\textbf{0}[/math] [math]0[/math] [math]\textbf{1}[/math] [math]0[/math] [math]0[/math]
[math]\textbf{0}[/math] [math]\textbf{1}[/math] [math]0[/math] [math]0[/math] [math]\textbf{1}[/math] [math]0[/math]
[math]\textbf{1}[/math] [math]\textbf{1}[/math] [math]0[/math] [math]0[/math] [math]0[/math] [math]\textbf{1}[/math]

Логическая схема

Логическая схема дешифратора [math]1[/math]-to-[math]2[/math]
Логическая схема дешифратора [math]2[/math]-to-[math]4[/math]

Давайте построим логическую схему дешифратора рекурсивным способом: допустим, что мы построили схему для [math]n-1[/math] элемента, теперь попробуем слить [math]n[/math]-ый выход с предыдущими [math]n-1[/math] выходами. Для [math]n=1[/math] схема выглядит тривиальным образом: от входа [math]s_0[/math] отходят два провода, один напрямую соединён с выходом [math]z_0[/math], другой соединён с гейтом [math]NOT[/math], а гейт [math]NOT[/math] соединён с выходом [math]z_1[/math]. Теперь допустим, что мы можем построить схему для [math]n-1[/math] входов. Тогда [math]n[/math]-ый вход соединим с дешифратором [math]1[/math]-to-[math]2[/math], а первые [math]n-1[/math] выходы соединим с дешифратором [math](n-1)[/math]-to-[math](2^{n-1})[/math] и потом соединим каждый выход дешифратора [math](n-1)[/math]-to-[math](2^{n-1})[/math] с каждым выходом дешифратора [math]1[/math]-to-[math]2[/math] с помощью гейтов [math]AND[/math], потом соединим соответствующие гейты с выходами [math]z_i[/math] таким образом, чтобы значение на входе [math]z_i[/math] было равно [math]1[/math] только в том случае, если число [math]i[/math] кодируется входами [math]s_0[/math], [math]s_1[/math], [math]\ldots[/math], [math]s_{n-1}[/math]. Очевидно, что мы таким образом перебрали всевозможные комбинации значений на входах [math]s_0[/math], [math]s_1[/math], [math]\ldots[/math], [math]s_{n-1}[/math], поэтому наша схема будет работать верно.

См. также

Источники информации