## ГУАП

## КАФЕДРА № 44

| ОТЧЕТ<br>ЗАЩИЩЕН С ОЦЕНКОЙ                                  |                    |                                   |
|-------------------------------------------------------------|--------------------|-----------------------------------|
| ПРЕПОДАВАТЕЛЬ                                               |                    |                                   |
| Доц., канд. техн. наук, доц. должность, уч. степень, звание | подпись, дата      | О.О. Жаринов<br>инициалы, фамилия |
| ОТЧЕТ О Л                                                   | ІАБОРАТОРНОЙ РАБО  | TE №2                             |
| Разработка преобразователей комбинационной логики           |                    |                                   |
| по ку                                                       | урсу: СХЕМОТЕХНИКА |                                   |
|                                                             |                    |                                   |
| РАБОТУ ВЫПОЛНИЛ                                             |                    | V.C. Hovmagon                     |
| СТУДЕНТ ГР. № 4142                                          | подпись, дата      | К.С. Некрасов инициалы, фамилия   |

Санкт-Петербург 2024

# Цель работы

Изучить принципы работы типовых функциональных узлов комбинационной логики: шифраторов, дешифраторов, мультиплексоров. Разработать проект преобразователя кодов на их основе, с использованием языков описания аппаратуры. Основной целью работы является формирование навыков использования модулей на языке описания аппаратуры.

# Индивидуальное задание. Вариант 3

| Состояния |    |    |  |    |    |
|-----------|----|----|--|----|----|
| входных   |    |    |  | 3  |    |
| сигналов  |    |    |  |    |    |
| x2        | x1 | x0 |  | y1 | y0 |
| 0         | 0  | 0  |  | 1  | 1  |
| 0         | 0  | 1  |  | 0  | 0  |
| 0         | 1  | 0  |  | 1  | 1  |
| 0         | 1  | 1  |  | 0  | 1  |
| 1         | 0  | 0  |  | 0  | 1  |
| 1         | 0  | 1  |  | 1  | 0  |
| 1         | 1  | 0  |  | 1  | 0  |
| 1         | 1  | 1  |  | 0  | 1  |

## Решение

## Мультиплексор

Для разработки мультиплексора была использована конструкция switch, которая в зависимости от входов на x[2..0] выдают разный сигнал на выходы y[1..0]

#### Листинг кода

```
module second(
  input wire [2:0] x,
  output reg [1:0] y
);
  always @* begin
  case(x)
    3'b000: y = 2'b11;
    3'b001: y = 2'b00;
    3'b010: y = 2'b11;
    3'b011: y = 2'b01;
    3'b100: y = 2'b01;
    3'b101: y = 2'b10;
```

```
3'b110: y = 2'b10;
3'b111: y = 2'b01;
default: y = 2'b00;
endcase
end
endmodule
```

### Временная диаграмма



Рисунок 1 – Временная диаграмма





Рисунок 2 - Схема подключения ПЛИС

# Шифратор Дешифратор

#### Дешифратор:

Входной вектор х преобразуется в выходной вектор decoder, используя оператор case. Каждое значение входного вектора соответствует определенному значению выходного вектора.

#### Шифратор:

Значения выходного вектора decoder используются для определения значений выходного вектора encoder, который является результатом логических операций над битами decoder.

#### Дешифрация:

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

#### Листинг кода

```
module second1(
 input wire [2:0] x,
output reg [1:0] y
);
 reg [7:0] decoder;
wire [3:0] encoder;
 always ∂*
 begin
  case(x)
   3'd0: decoder = 8'b00000001;
   3'd1: decoder = 8'b00000010;
   3'd2: decoder = 8'b00000100;
   3'd3: decoder = 8'b00001000;
   3'd4: decoder = 8'b00010000;
   3'd5: decoder = 8'b00100000;
   3'd6: decoder = 8'b01000000;
   3'd7: decoder = 8'b10000000;
  endcase
 end
 assign encoder[0] = decoder[1];
 assign encoder[1] = decoder[3] | decoder[4] | decoder[7];
 assign encoder[2] = decoder[6] | decoder[5];
 assign encoder[3] = decoder[0] | decoder[2];
 always @(decoder)
 begin
  case (encoder)
   4'b0001: y = 2'b00;
   4'b0010: y = 2'b01;
   4'b0100: y = 2'b10;
   4'b1000: y = 2'b11;
  endcase
 end
endmodule
```

#### Временная диаграмма



Рисунок 3 – Временная диаграмма

#### Схема подключения ПЛИС

# Top View MAX II - EPM570ZM256C7



Рисунок 4 – Схема подключения ПЛИС

# Вывод

Изучены принципы работы типовых функциональных узлов комбинационной логики: шифраторов, дешифраторов, мультиплексоров. Разработан проект преобразователя кодов на их основе, с использованием языков описания аппаратуры. Получены навыки использования модулей на языке описания аппаратуры Verilog.