

# Федеральное государственное бюджетное образовательное учреждение высшего образования

### «МИРЭА - Российский технологический университет»

#### РТУ МИРЭА

Институт Информационных Технологий Кафедра Вычислительной Техники (BT)

### ОТЧЁТ ПО ПРАКТИЧЕСКОЙ РАБОТЕ № 4

«Коллоквиум, практическая часть»

по дисциплине

«Схемотехника устройств компьютерных систем»

| Выполнил студент группы<br>ИВБО-01-22 | Воробьев Д.М. |
|---------------------------------------|---------------|
| Принял ассистент кафедры ВТ           | Дуксин Н.А.   |
| Практическая работа выполнена         | «»2024 г.     |
| «Зачтено»                             | « » 2024 г.   |

## СОДЕРЖАНИЕ

| 1 ОСНОВНОЙ РАЗДЕЛ | 3 |
|-------------------|---|
| , ,               |   |
| 1.1 Задание 1     | 3 |

### 1 ОСНОВНОЙ РАЗДЕЛ

### 1.1 Задание 1

Даны таблицы со значениями функций синуса и косинуса для углов, выраженных в ВАМ.

Опишем модуль на языке Verilog, реализующий интерфейс доступа к значениям из приведённых таблиц (Листинг 1.1).

Произведём верификацию работы модуля при помощи симуляции для всех значений углов, определённых в рамках приведённых таблиц (Листинг 1.2).

Листинг 1.1 – Модуль trig\_tables.v на языке Verilog

```
`timescale 1ns / 1ps
module trig_table #(
VALUE WIDTH = 32,
ANGLE WIDTH = 10,
COUNT = 2**ANGLE WIDTH
    input [ANGLE WIDTH-1:0] angle in,
    output signed [VALUE WIDTH-1:0] sin out,
    output signed [VALUE WIDTH-1:0] cos out
);
wire [VALUE WIDTH-1:0] sin table [0:COUNT-1];
`include "sin table a7 d32.vh"
wire [VALUE WIDTH-1:0] cos table [0:COUNT-1];
`include "cos table a7 d32.vh"
wire sin cond = angle in >= 0 && angle in < COUNT/2;
wire cos cond = (angle in \geq 0 && angle in < COUNT/4) || (angle in \geq
3*COUNT/4 && angle in < COUNT);</pre>
assign sin out = sin cond ? sin table[angle in] : -sin table[angle in];
assign cos out = cos cond ? cos table[angle in] : -cos table[angle in];
endmodule
```

### Листинг 1.2 – Тестовый модуль на языке Verilog

```
`timescale 1ns / 1ps
module trig_table_tb;
// Параметры модуля для тестирования
parameter VALUE_WIDTH = 32;
parameter ANGLE_WIDTH = 10;
parameter COUNT = 2**ANGLE_WIDTH;
```

Продолжение листинга 1.2

```
// Входные и выходные сигналы
reg [ANGLE_WIDTH-1:0] angle in;
wire signed [VALUE WIDTH-1:0] sin out, cos out;
reg [5:0] errors = 0;
// Модуль под тестированием
trig table #(
    .VALUE WIDTH (VALUE WIDTH),
    .ANGLE WIDTH (ANGLE WIDTH)
) uut (
    .angle in (angle in),
    .sin out(sin out),
    .cos out(cos out)
 );
 // Таблицы для сравнения
 wire [VALUE WIDTH-1:0] sin table [0:COUNT-1];
 wire [VALUE WIDTH-1:0] cos table [0:COUNT-1];
 `include "sin table a7 d32.vh"
 `include "cos table a7 d32.vh"
 // Процедура тестирования
 initial begin
 // Инициализация тестирования
 angle in = 0;
 // Проход по всем возможным углам
 for (angle in = 0; angle in < COUNT; angle in = angle in + 1) begin
    #10;
    end
 // Окончание симуляции
 $stop;
 end
endmodule
```

Произведём верификацию (Рисунок 1.1).



Рисунок 1.1 – Верификация модуля для приведённых таблиц синуса и косинуса

### ЗАКЛЮЧЕНИЕ

В рамках данной практической работы выполнили практические задания на языке Verilog.

### СПИСОК ИСПОЛЬЗОВАННЫХ ИСТОЧНИКОВ

- 1. Методические указания по ПР № 1 URL: https://online-edu.mirea.ru/mod/resource/view.php?id=405132 (Дата обращения: 23.09.2022).
- 2. Методические указания по ПР № 2 URL: https://online-edu.mirea.ru/mod/resource/view.php?id=409130 (Дата обращения: 23.09.2022).
- 3. Смирнов С.С. Информатика [Электронный ресурс]: Методические указания по выполнению практических и лабораторных работ / С.С. Смирнов М., МИРЭА Российский технологический университет, 2018. 1 электрон. опт. диск (CD-ROM).
- 4. Тарасов И.Е. ПЛИС Xilinx. Языки описания аппаратуры VHDL и Verilog, САПР, приемы проектирования. М.: Горячая линия Телеком, 2021. 538 с.: ил.
- 5. Антик М.И. Дискретная математика [Электронный ресурс]: Учебное пособие / Антик М.И., Казанцева Л.В. М.: МИРЭА Российский технологический университет, 2018 1 электрон. опт. диск (CD-ROM).
- 6. Антик М.И. Математическая логика и программирование в логике [Электронный ресурс]: Учебное пособие / Антик М.И., Бражникова Е.В.— М.: МИРЭА Российский технологический университет, 2018. 1 электрон. опт. диск (CD-ROM).
- 7. Жемчужникова Т.Н. Конспект лекций по дисциплине «Архитектура вычислительных машин и систем» URL: https://drive.google.com/file/d/12OAi2\_axJ6mRr4hCbXs-mYs8Kfp4YEfj/view?us p=sharing (Дата обращения: 23.09.2022).
- 8. Антик М.И. Теория автоматов в проектировании цифровых схем [Электронный ресурс]: Учебное пособие / Антик М.И., Казанцева Л.В. М.: МИРЭА Российский технологический университет, 2020. 1 электрон. опт. диск (CD-ROM).