# Базовые логические элементы

### Базовые логические элементы

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

- Вентиль «И» конъюнктор.
   Реализует конъюнкцию.
- Вентиль «ИЛИ» дизъюнктор.
   Реализует дизъюнкцию.
- Вентиль «НЕ» инвертор.
   Реализует инверсию

#### Составные элементы

 Любая логическая операция может быть представлена через конъюнкцию, дизъюнкцию и инверсию

 Любой сколь угодно сложный элемент компьютера может быть сконструирован из элементарных вентилей

## Сигналы-аргументы и сигналы-функции

Вентили оперируют с электрическими импульсами:

- Импульс имеется логический смысл сигнала «1»
- Импульса нет логический смысл сигнала «0»

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

## Логическая схема типа «И» (конъюнктор)



## Логическая схема типа «ИЛИ» (дизъюнктор)



## Логическая схема типа «НЕ» (инвертор)

Электрическая цепь с одним автоматическим выключателем



## Конъюнктор

На входы конъюнктора
 подаются сигналы 0 или 1

На выходе конъюнктора появляются сигналы 0 или 1 в соответствии с таблицей истинности



## Дизъюнктор

На входы дизъюнктора
 подаются сигналы 0 или 1

На выходе дизъюнктора появляются сигналы 0 или 1 в соответствии с таблицей истинности







## Инвертор

На входы инвертора
 подаются сигналы 0 или 1

 На выходе инвертора появляются сигналы 1 или 0 в соответствии с таблицей истинности





### Сумматор двоичных чисел

- Любое математическое сколь угодно сложное выражение может быть представлено в виде последовательности элементарных математических операций
- Все математические действия в компьютере сводятся к сложению двоичных чисел
- Основу микропроцессора составляют сумматоры двоичных чисел

## Полусумматор. Арифметическое сложение двоичных чисел

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

|   | Без переноса |      |  |  |  |
|---|--------------|------|--|--|--|
| + | 0000         | 0001 |  |  |  |
|   | 0000         | 0010 |  |  |  |
|   | 0000         | 0011 |  |  |  |



## Обозначим слагаемые через A и B, перенос – через P, а сумму – через S

Таблица сложения одноразрядных двоичных чисел:

| Слага | емые | Перенос | Сумма |
|-------|------|---------|-------|
| Α     | В    | Р       | S     |
| 0     | 0    | 0       | 0     |
| 0     | 1    | 0       | 1     |
| 1     | 0    | 0       | 1     |
| 1     | 1    | 1       | 0     |

Очевидно, что  $P = A \wedge B$ 

### Получаем формулу для вычисления S

#### Если сравнить AVB с S:

| Α | В | AV |
|---|---|----|
|   |   | В  |
| 0 | 0 | 0  |
| 0 | 1 | 1  |
| 1 | 0 | 1  |
| 1 | 1 | 1  |

| Α | В | S |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

<del>to очевидно, что они п</del>рактически идентичны.

Чтобы равенство оказалось полным нужно выражение **A** ∨ **B** умножить на ¬**P** 

### Получаем формулу для вычисления S

$$S = (A \lor B) \land \neg P \Rightarrow (A \lor B) \land \neg (A \land B)$$

| Α | В | AVB | ΑΛ | ¬(A ∧      | (A ∨ B) ∧ ¬(A ∧ |
|---|---|-----|----|------------|-----------------|
|   |   | 0   | ₿  | <b>B</b> ) | ₽)              |
| 0 | 0 | 1   | 0  | 1          | 1               |
| 0 | 1 | 1   | 0  | 1          | 1               |
| 1 | 0 | 1   | 1  | 0          | 0               |
| 1 | 1 |     |    |            |                 |

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

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

#### двоичного полусумматора

Полусумматор называется так, потому, что здесь не учитывается перенос единицы из младшего разряда



### Полный одноразрядный сумматор

Должен иметь три входа (A, B и  $P_0$ ) и два выхода (S и P)

| Слага | емые | Пере           | Сумма |   |
|-------|------|----------------|-------|---|
| Α     | В    | P <sub>0</sub> | Р     | S |
| 0     | 0    | 0              | 0     | 0 |
| 0     | 1    | 0              | 0     | 1 |
| 1     | 0    | 0              | 0     | 1 |
| 1     | 1    | 0              | 1     | 0 |
| 0     | 0    | 1              | 0     | 1 |
| 0     | 1    | 1              | 1     | 0 |
| 1     | 0    | 1              | 1     | 0 |
| 1     | 1    | 1              | 1     | 1 |

### Формула полного

#### одноразрядного сумматора

Р принимает значение 1 когда хотя бы две из трех переменных равны 1:

$$P = (A \land B) \lor (A \land P_0) \lor (B \land P_0)$$

Сумма равна произведению логического сложения (A, B и P<sub>0</sub>) на инвертированный перенос ¬Р:

$$S = (A \lor B \lor P_0) \land \neg P$$

 Это выражение справедливо во всех случаях, кроме одного, когда А, В и Р<sub>0</sub> равны 1:

## Формула полного одноразрядного сумматора

Правильное значение суммы – **1**. Для ее получения необходимо полученное выражение сложить с произведением этих же переменных:

$$S = (A \lor B \lor P_0) \land \neg P \lor (A \land B \land P_0)$$

## Многоразрядный сумматор

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

## Триггер

- Важнейшая структурная единица оперативной памяти и регистров процессора
- Состоит из двух логических элементов «ИЛИ» и двух логических элементов «НЕ»

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



## Работа триггера

- В обычном состоянии на входы триггера S
  и R подан сигнал «0» и триггер хранит «0».
- При подаче сигнала «1» на вход S триггер принимает значение на выходе Q значение «1»
- При подаче сигнала «1» на вход R триггер возвращается в свое исходное состояние
  - хранит «**0**»