# МІНІСТЕРСТВО ОСВІТИ І НАУКИ УКРАЇНИ НАЦІОНАЛЬНИЙ ТЕХНІЧНИЙ УНІВЕРСИТЕТ УКРАЇНИ «КИЇВСЬКИЙ ПОЛІТЕХНІЧНИЙ ІНСТИТУТ ІМЕНІ ІГОРЯ СІКОРСЬКОГО» КАФЕДРА КОНСТРУЮВАННЯ ЕЛЕКТРОННО-ОБЧИСЛЮВАЛЬНОЇ АПАРАТУРИ

# Лабораторна робота №3

3 курсу: «Пристрої зі змінною архітектурою»

Тема: «Моделювання проекту в середовищі Quartus II»

Виконав студент IV курсу гр.

Перевірив

ДК-91 Тисяк E. B.

Антонюк О.І.

Більшість перевірки я виконував не за допомогою Quartus II, а з використанням ModelSim. Я так зробив з наступних причин:

- Я звик працювати в ModelSim
- Я не зміг розібратись з тим, як переглядати в Quartus II значення регістрів й інших структур, що не є вхідними/вихідними сигналами
- ModelSim дозволяє використовувати debag режим

Результат виконання ЛР, а саме файли мого проекту я розмістив за наступним посиланням: <a href="https://github.com/LAMPA23/ModelSim/tree/semestr-7/Lab-3/">https://github.com/LAMPA23/ModelSim/tree/semestr-7/Lab-3/</a>

Значних змін зазнали файли rom.v , rom\_init.dat , uart\_sender.v , uart\_receiver.v uart\_mem.v .

# РЕЗУЛЬТАТ МОДЕЛЮВАННЯ В QUARTUS II:

Створений мною проект коректно компілюється:



Створений мною проект коректно проходить етам аналізу і синтезу:



Для поверхневої перевірки я добавив 2 сигнали.

# Перший:

```
main_core.v

module main_core(

i_clk,
 i_uart_rst,
 uart_out,
 alu_out

input i_clk, i_uart_rst;
 output [7:0] uart_out;
 output [31:0] alu_out;
```

```
≡ main_core.v

49

50 assign alu_out = wire_32_3;
```

```
107
108
          alu alu inst(
              .i op1(wire 32 7),
109
              .i op2(wire 32 0),
110
              .i control(wire 6 0),
111
             .o result(wire 32_3),
112
              .o zf(zero)
113
114
          );
115
```

В результаті даний сигнал повністю відповідає очікуванням. Сигнал по послідовності значень збігається з моделлю в ModelSim, але має зовсім інші значення в часі.

#### Симуляція в Quartus II:



### Симуляція в ModelSim:



# Другий:

В результаті даний сигнал повністю НЕ відповідає очікуванням. Натомість в ModelSim він є коректним і все працює так як задумано.

### Симуляція в Quartus II:



# Симуляція в ModelSim:





# А ось як буде передаватись вся синусоїда:



# РЕЗУЛЬТАТ МОДЕЛЮВАННЯ В ModelSim:

Для перевірки одночасно з передачею по uart запустив сортування чисел в регістрах \$4, \$5, \$6. Після сортування число в \$6 зміняється одиничкою. Все працює коректно:



#### висновок:

Загалом етам моделювання можна вважати пройденим. Швидша за все, що і частину з uart, можна просимулювати в Quartus II, просто для цього слід відслідкувати де і коли, все починає йти «не за планом». Можливо ця проблема буде вирішена в інших ЛР.