# Министерство науки и высшего образования РФ Федеральное государственное автономное образовательное учреждение высшего профессионального образования «СИБИРСКИЙ ФЕДЕРАЛЬНЫЙ УНИВЕРСИТЕТ»

Институт космических и информационных технологий

Кафедра вычислительной техники

# ОТЧЁТ О ПРЕДДИПЛОМНОЙ ПРАКТИКЕ

| Разработка цифрово | го процессора эффектов        | для музыкальн | ных инструментов |
|--------------------|-------------------------------|---------------|------------------|
|                    |                               |               |                  |
|                    |                               |               |                  |
|                    |                               |               |                  |
|                    |                               |               |                  |
|                    |                               |               |                  |
| Руководитель       | подпись, дата                 |               | А.Г. Хантимиров  |
|                    | подинев, дата                 |               | a * 10           |
| Студент            | номер группы, зачетной книжки | подпись, дата | Я.Ф. Кашапов     |

# СОДЕРЖАНИЕ

| Введение                                                          |
|-------------------------------------------------------------------|
| 1 Анализ предметной области                                       |
| 1.1 Обзор существующих решений                                    |
| 1.1.1 Программно-реализуемые эффекты                              |
| 1.1.2 Самостоятельные устройства, реализующие цифровые эффекты 9  |
| 1.1.3 Цифровые эффекты, идущие в составе усилителей звука         |
| 1.1.4 Блоки эффектов                                              |
| 1.2 Обзор элементной базы, используемой в проекте                 |
| 1.2.1 Отладочная плата EBAZ420513                                 |
| 1.2.2 Аналого-цифровой преобразователь РСМ180815                  |
| 1.2.3 Цифро-аналоговый преобразователь РСМ5102а16                 |
| 1.3 Обзор стандарта I2S                                           |
| 1.4 Требования к проектируемому устройству                        |
| 1.5 Вывод                                                         |
| 2 Проектирование и разработка алгоритмов звуковых эффектов 20     |
| 2.1 Эффект «Усиление»                                             |
| 2.2 Эффект «Перегруз»21                                           |
| 2.3 Эффект «Задержка»                                             |
| 2.4 Эффект «Тремоло»                                              |
| 2.5 Эффект «Искажение»                                            |
| 2.6 Вывод                                                         |
| 3 Разработка архитектуры и алгоритмов функционирования процессора |
| эффектов                                                          |
| 3.1 Конфигурация аппаратуры                                       |
| 3.2 Разработка архитектуры процессора эффектов                    |
| 3.3 Разработка алгоритмов функционирования процессора эффектов 37 |
| 3.4 Вывод                                                         |
| 4 Разработка, отлалка и отработка сложно-функциональных блоков    |

| 4.1 Подсистема тактирования в проекте |                                                    |      |  |  |
|---------------------------------------|----------------------------------------------------|------|--|--|
| 4.1.1 Настройк                        | а тактирования ПЛ Xilinx ZYNQ 7010                 | . 40 |  |  |
| 4.1.2 Тактиров                        | ание разрабатываемого процессора эффектов          | . 41 |  |  |
| 4.2 Разработка С                      | Ф-блока «clk_div»                                  | . 43 |  |  |
| 4.3 Разработка С                      | Ф-блока «I2S-передатчик»                           | . 45 |  |  |
| 4.4 Разработка С                      | Ф-блока «I2S-приёмник»                             | . 47 |  |  |
| 4.5 Разработка С                      | Ф-блока «Усиление»                                 | . 49 |  |  |
| 4.6 Разработка С                      | Ф-блока «Эффекты»                                  | . 51 |  |  |
| 4.7 Разработка С                      | Ф-блока «Управление»                               | . 53 |  |  |
| 4.8 Разработка С                      | Ф-блока «Процессор эффектов»                       | . 54 |  |  |
| 4.9 Коммутация с                      | сигналов процессора эффектов на порты ввода-вывода | . 56 |  |  |
| 4.10 Оценка затра                     | аченных ресурсов ПЛИС                              | . 57 |  |  |
| 4.11 Вывод                            |                                                    | . 57 |  |  |
| Заключение                            |                                                    | . 58 |  |  |
| Список сокращений                     | ,<br>1                                             | . 59 |  |  |
| Список использова                     | нных источников                                    | . 60 |  |  |
| ПРИЛОЖЕНИЕ А                          | Реализация эффекта «Усиление». Matlab              | . 62 |  |  |
| приложение Б                          | Реализация эффекта «Перегруз». Matlab              | . 63 |  |  |
| ПРИЛОЖЕНИЕ В                          | Реализация эффекта «Задержка». Matlab              | . 64 |  |  |
| ПРИЛОЖЕНИЕ Г                          | Реализация эффекта «Тремоло». Matlab               | . 65 |  |  |
| приложение д                          | Реализация СФ-блока «clk_div». Verilog             | . 66 |  |  |
| приложение е                          | Тестбенч для СФ-блока «clk_div». Verilog           | . 67 |  |  |
| ПРИЛОЖЕНИЕ Ж                          | Реализация СФ-блока «I2S-передатчик». Verilog      | . 68 |  |  |
| приложение з                          | Тестбенч для СФ-блока «I2S-передатчик». Verilog    | . 69 |  |  |
| приложение и                          | Реализация СФ-блока «I2S-приёмник». Verilog        | . 70 |  |  |
| ПРИЛОЖЕНИЕ К                          | Тестбенч для СФ-блока «I2S-приёмник». Verilog      | . 71 |  |  |
| ПРИЛОЖЕНИЕ Л                          | Реализация СФ-блока «Усиление». Verilog            | . 72 |  |  |
| ПРИЛОЖЕНИЕ М                          | Реализация СФ-блока «Эффекты». Verilog             | . 73 |  |  |
| ПРИЛОЖЕНИЕ Н                          | Реализация СФ-блока «Процессор эффектов». Verilog  | . 74 |  |  |

#### **ВВЕДЕНИЕ**

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

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

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

Цифровыми являются те инструменты, звук в которых генерируется цифровыми электронными схемами. Например, цифровой синтезатор.

В современном «цифровом» мире использование цифровых методов обработки звуков имеет очевидное преимущество — цифровой звук значительно легче и дешевле обрабатывать. На сегодняшний день для этого существует большое количество специализированных микросхем и аудио-процессоров, таких как цифровой сигнальный процессор (ЦСП, или DSP – digital signal processor) и т. п. Появление цифровой обработки сигналов в аудио-приложениях постоянно было обусловлено возможностью разнообразить тональности, экспериментируя усилителями и эффектами.

Обычно DSP-устройства являются сложными и комбинируют в себе как аналоговую, так и цифровую логику. Например, они могу содержать один или несколько аналого-цифровых и цифроаналоговых преобразователей, а также аналоговые и цифровые фильтры частот. Важным критерием качества работы цифровых аудио-процессоров является задержка обработанного сигнала. Чем

меньше эта задержка, тем более пригодным является устройство для использования его в реальном времени, например на музыкальном концерте.

Звуковые эффекты, накладываемые на звук, позволяют разнообразить звучание инструмента, добавив дополнительную музыкальную информацию. Например, большая часть музыкального жанра «Рок», который зародился в 60-х вследствие применения аналоговых схем искажения звукового сигнала, невозможна без таких эффектов как «overdrive» и «distorsion». Данные эффекты выделяют такую музыку, и за счёт них образовался сам жанр, а также появились новые техники игры.

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

На сегодняшний день существует множество коммерческих решений, которые позволяют настраивать звуковые эффекты для любого аналогового звука. Например, решения от компании HeadRush — цифровые процессоры эффектов для электрогитар. Они отличаются высоким качеством, большим количеством настроек и дороговизной. Так же существуют аналоговые «педальки» для электрогитар, которые, как правило, реализуют один конкретный эффект и не являются дорогими. Однако многие музыканты не обходятся только одним эффектом и комбинируют такие устройства, что в итоге ведёт к «удорожанию» звука.

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

Для качественного подхода к реализации такого устройства есть смысл использовать программируемую логическую интегральную схему (ПЛИС), так как именно данный способ позволяет обеспечить наименьшие задержки звукового сигнала при его обработке за счёт особенностей ПЛИС.

В этом проекте демонстрируется альтернативный подход к звуковым эффектам с использованием ПЛИС вместо ядер DSP или аналоговых

компонентов для выполнения цифровой обработки сигналов, предназначенных для изменения аудиосигналов. Звуковая обработка была разработана на отладочной плате с системой на кристалле Xilinx Zynq®-7000, совмещающей в себе ПЛИС, а также два ядра ARM Cortex A9. Различные гитарные эффекты были получены из пользовательских сложно-функциональных блоков (СФблоков), написанных на Verilog. Программируемая логика (ПЛ) управляется поворотными потенциометрами и кнопкам, с которыми взаимодействует пользователь, а индикация базируется на светодиодах.

### 1 Анализ предметной области

#### 1.1 Обзор существующих решений

Многие устройства, реализующие цифровые звуковые эффекты, сегодня являются очень сложными и больше напоминают компьютеры. Они состоят из высококоплиментарных DSP-ядер, специально предназначенных для обработки звука, за счёт чего и возможно создание линейных и нелинейных эффектов.

В общем виде можно выделить несколько типов цифровых эффектов с точки зрения их реализации:

- программно-реализуемые эффекты;
- самостоятельные устройства, реализующие цифровые эффекты;
- эффекты, которые идут в составе усилителей звука.

Отдельно стоит выделить классические способы обработки звука — различные блоки эффектов (педали эффектов).

Рассмотрим данные решения более подробно.

# 1.1.1 Программно-реализуемые эффекты

Для получения таких эффектов достаточно использовать персональный компьютер (ПК). Например, программное обеспечение «Guitar Rig» (Рисунок 1) позволяет подключить сотни разных эффектов к любому источнику звука в ПК.



Рисунок 1 – Интерфейс программы GuitarRig 5

Также популярны программные средства, называемые звуковыми плагинами, которые можно активировать в программах мастеринга звука. Один плагин может реализовывать один или несколько эффектов. Например, плагин «Emissary Ignite» (Рисунок 2). Он содержит в себе два режима звучания («Clean» и «Lead») и отдельные эквалайзеры для каждого из них. Плагины можно комбинировать, выстраивая необходимую цепочку эффектов для получения желаемого звучания.



Рисунок 2 – Звуковой плагин «Emissary Ignite» в режиме Lead Fat

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

Таким образом, плюсы данного подхода:

- много реализованных эффектов;
- нужен только компьютер и звуковая карта.

#### Минусы:

- заметные задержки при обработке звука;
- неудобно использовать на концертах;
- для обеспечения высокого качества звука необходима дорогостоящая звуковая карта.

# 1.1.2 Самостоятельные устройства, реализующие цифровые эффекты

Как правило, такие устройства содержат DSP-ядро, аналого-цифровые преобразователи (АЦП), цифро-аналоговые преобразователи (ЦАП) и интерфейс пользователя (кнопки, дисплей и т.п.). По способу ввода и вывода звука могут сильно отличаться. Например, на входе и выходе может быть аналоговый сигнал. Или на входе аналоговый, а на выходе — цифровой, передающийся по шине I2S или USB. Представителем такого типа устройств является HeadRush Pedalboard (Рисунок 3) [1]. Задержка обработанного сигнала сравнительно низкая.



Рисунок 3 — Моделирующий гитарный процессор эффектов HeadRush Pelalboard

Другим примером является ZOOM G1X Four (Рисунок 4). Такой процессор эффектов построен на основе 32-разрядного DSP ZOOM ZFX-3, в составе которого содержится 24-битный АЦП и ЦАП с частотой дискретизации 96 кГц.



Рисунок 4 – Гитарный процессор эффектов ZOOM G1X Four

Плюсы подобных устройств:

- много реализованных эффектов;
- устройство готово для использования на концерте;
- низкие задержки обработанного сигнала.

#### Минусы:

- высокая стоимость.

## 1.1.3 Цифровые эффекты, идущие в составе усилителей звука

Некоторые модели комбо-усилителей звука содержат в себе встроенный блок процессора эффектов. Например, Yamaha THR (Рисунок 5). Такие устройства обладают меньшими возможностями по настройке эффектов по сравнению полноценными процессорами эффектов. Входной сигнал аналоговый, передающийся через инструментальный разъём. Задержка обработанного сигнала сравнительно низкая, так как данный вид устройств предназначен для использования в реальном времени.



Рисунок 5 – Гитарный комбоуслитель Yamaha THR с моделирующим блоком настройки эффектов

#### Плюсы:

- устройство «два в одном»;
- устройство готово для использования на концерте;

– низкие задержки обработанного сигнала;

#### Минусы:

- высокая стоимость;
- малое количество эффектов.

## 1.1.4 Блоки эффектов

Блоки эффектов являются классическим вариантом наложения эффектов на звук. Как правило, они реализуют один эффект или несколько одного типа. Чаще всего эти устройства являются аналоговыми. Имеют инструментальные вход и выход.



Рисунок 6 – Комбирированный блок эффектов «Overdrive/Distortion» BOSS OS-

2

#### Плюсы:

- малые габариты;
- устройство готово для использования на концерте;
- низкие задержки обработанного сигнала;

#### Минусы:

- могут быть дорогими;
- реализуют один эффект;
- цепочка блоков эффектов обладает большими габаритами.

# 1.2 Обзор элементной базы, используемой в проекте

#### 1.2.1 Отладочная плата ЕВАZ4205

Отладочная плата EBAZ4205 (Рисунок 7) построена на основе системы на кристалле (СНК) Xilinx ZYNQ 7010. Дополнительные возможности платы [2]:

- − 256 M6 DDR3 RAM;
- − 128 M6 NAND Flash;
- розетка RJ-45 и Ethernet-контроллер IP101GA;
- 52 GPIO, выведенных на разъёмы DATA1, DATA2, DATA3;
- слот для SD-карт;
- JTAG-разъём для отладки ПЛИС.



Рисунок 7 – Отладочная плата EBAZ4205

Как уже было отмечено, в основе отладочной платы лежит Xilinx ZYNQ 7010. Это система на кристалле, которая помимо программируемой логики (ПЛ) содержит ещё процессорную систему (ПС) с двумя ядрами ARM Cortex A9. Общая структурная схема ZYNQ 7010 (Рисунок 8) [3] включает множество дополнительных СФ-блоков и соединений типа «процессорная система – программируемая логика». Основные характеристики ПЛ:

- 28 тыс. программируемых логических ячеек;
- 17,6 тыс. таблиц преобразования;
- 2,1 Мб ОЗУ.



Рисунок 8 – Общая структурная схема ZYNQ 7010

В данном проекте процессорная часть использоваться будет только лишь для отладки и загрузки результата синтеза Verilog-конфигурации в ПЛИС. Так как на процессорной части ZYNQ 7010 запущено Linux-ядро, то через devfs доступно устройство /dev/xdevbit, в которое можно загружать синтезированные проекты (bitstream).

## 1.2.2 Аналого-цифровой преобразователь РСМ1808

АЦП РСМ1808 (Рисунок 9) специально спроектирован для обработки звукового сигнала. Типовые примеры применения данного преобразователя [4]:

- Цифровой TV;
- DVD-рекордер.



Рисунок 9 – Отладочная плата Chipdip PCM1808

### Основные характеристики АЦП:

- разрядность 24 бит;
- настраиваемая частота дискретизации аналогового сигнала до 96 кГц.
- оцифрованный сигнал в формате I2S или Left-justified;
- возможность работы в разных режимах: «master» или «slave».

# 1.2.3 Цифро-аналоговый преобразователь РСМ5102а

ЦАП РСМ5102a (Рисунок 10) по своему классу не отличается от АЦП РСМ1808. Они могут применяться в одних и тех же проектах. Основные характеристики ЦАП [5]:

- настраиваемая разрядность 16, 24 или 32 бит;
- настраиваемая частота дискретизации аналогового сигнала до 384 кГц.
- оцифрованный сигнал в формате I2S или Left-justified;
- возможность работы в разных режимах: «master» или «slave».



Рисунок 10 – Отладочная плата Chipdip PCM5102a

## 1.3 Обзор стандарта I2S

Показанные выше АЦП и ЦАП передают и принимают оцифрованный звук в формате I2S. Это специализированный стандарт передачи аудио между цифровыми устройствами [6].

Шина I2S состоит из трёх проводников (Рисунок 11):

- continuous serial clock (SCK, в этом проекте BCK);
- word select (WS, в этом проекте LRCK);
- serial data (SD, в этом проекте DOUT).

Сигнал ВСК предназначен для синхронизации передачи данных между устройствами. WS определяет, для какого аудиоканала (левого или правого) передаются данные по последовательной шине SD. Если WS равен логической единице, то данные на SD соответствуют правому каналу, иначе – левому.



Рисунок 11 – Типовые схемы соединения устройств и передачи данных I2S

Как можно видеть, от того, в каком режиме работает устройство, зависит кто генерирует тактовые сигналы передачи данных. В данном проекте между I2S-передатчиком и I2S-приёмником находится ПЛИС.

# 1.4 Требования к проектируемому устройству

Проектируемый процессор эффектов должен реализовывать следующие эффекты:

- задержка;
- перегрузка;
- искажения;
- тремоло.

Для выбора эффектов следует организовать интерфейс пользователя на основе кнопок, светодиодных индикаторов, потенциометров и энкодеров.

Verilog-проект должен быть разделён на модули. Взаимодействие с АЦП, ЦАП и эффекты, а также обработку ввода пользователем следует реализовать в виде СФ-блоков.

## **1.5** Вывод

Были рассмотрены различные варианты устройств, реализующих цифровые звуковые эффекты. Каждый из вариантов имеет свои плюсы и минусы. Однако самым главным критерием для устройства, реализующего эффекты, является задержка обработанного сигнала. Поэтому, для качественного подхода к реализации такого устройства есть смысл использовать ПЛИС, так как именно данный способ позволяет обеспечить наименьшие задержки звукового сигнала при его обработке за счёт возможности параллельной обработки данных.

Также рассмотрена элементная база проектируемого устройства. Высокоточные АЦП и ЦАП позволят преобразовать звуковой сигнал с наименьшими потерями.

Таким образом, задача сводится к реализации набора СФ-блоков, реализующих звуковые эффекты и взаимодействующих с ЦАП, АЦП и т.д.

### 2 Проектирование и разработка алгоритмов звуковых эффектов

#### 2.1 Эффект «Усиление»

Эффект усиления функционирует за счёт увеличения амплитуды входного сигнала.

$$f(x) = x * G \tag{2.1}$$

Ниже представлена общая блок-диаграмма, описывающая эффект усиления входного звукового сигнала (Рисунок 12).



Рисунок 12 – Блок-диаграмма эффекта усиления

Входные параметры, необходимые для работы эффекта:

- входной сигнал;
- коэффициент усиления.

Встроенные функции Matlab, где была построена модель данного эффекта, позволяют считывать музыкальные файлы в формате Waveform Audio File

(WAV), а также проигрывать считанную и обработанную музыку. Для примера был взят отрывок ритм-гитарной партии музыкальной композиции «*Metallica* – *Sad But True*», и к нему был применён эффект усиления с коэффициентом равным пяти (Рисунок 13). Частота дискретизации составила 44100 Гц.



Рисунок 13 – Применение эффекта «Усиление» к музыкальной композиции

# 2.2 Эффект «Перегруз»

Эффект перегрузки (Overdrive) появился в 60-х вместе с популяризацией электрических гитар. Функционально данный эффект искажает входной сигнал путём ограничения его по амплитуде. Существуют два основных способа ограничения: жесткое (hard-clipping) и мягкое (soft-clipping). Рисунок 14 показывает сравнение этих методов.



Рисунок 14 – Способы реализации эффекта «Перегруз»

Как можно видеть при «мягком» ограничении входного сигнала, функция сглаживает его значения у порога отсекания. Это усложняет реализацию, но позволяет сделать перегруженный звук более естественным по сравнению с «жестким» ограничением. Ниже представлена общая блок-диаграмма, описывающая эффект перегрузки (Рисунок 15).



Рисунок 15 – Блок-диаграмма эффекта перегрузки

Для функционирования эффекта необходимы следующие входные параметры:

- входной сигнал;
- значение коэффициента усиления звука (Gain);
- значение порога срабатывания отсекания (Threshold).

После подачи входного аудиосигнала, он умножается на коэффициент усиления, а затем блок-компаратор сравнивает получившийся усиленный сигнал и пороговое допустимое значение. В случае превышения порога, выходом компаратора будет само пороговое значение, иначе — усиленный сигнал. Математически метод «жесткого» ограничения это можно записать следующим образом [7]:

$$f(x) = \begin{cases} threshold, & x > threshold \\ x, & x \le threshold \end{cases}$$
 (2.2)

где threshold – порог отсекания сигнала.

Метод «мягкого» ограничения описывается [7]:

$$f(x) = \begin{cases} 2x, & 0 \le x < \frac{1}{3} \\ \frac{3 - (2 - 3x)^2}{3}, & \frac{1}{3} \le x < \frac{2}{3} \\ 1, & \frac{2}{3} \le x \le 1 \end{cases}$$
 (2.3)

На основании формул 2.2 и 2.3 была построена модель в Matlab с двумя режимами: hard-clipping или soft-clipping. Для наглядности результат работы модели показан на синусоидальном входном сигнале (Рисунок 16 и Рисунок 17).



Рисунок 16 – Применение функции «Перегруз» к входному сигналу в Matlab в режиме «жесткого» отсекания



Рисунок 17 — Применение функции «Перегруз» к входному сигналу в Matlab в режиме «мягкого» отсекания

Полученная модель позволяет:

- выбрать режим (soft- или hard-clipping);
- усилить входной сигнал;
- выбрать уровень отсекания сигнала (threshold).

Результат моделирования эффекта в Matlab показан ниже (Рисунок 18).



Рисунок 18 – Применение эффекта «Overdrive» к музыкальной композиции

## 2.3 Эффект «Задержка»

Данный эффект основан на том, что к входному сигналу добавляется его точная копию, но с задержкой на какое-то определённое время. Существует два основных типа реализации повторения сигнала: *infinite impulse response* (IIR) и *finite impulse response* (FIR).

IIR – свойство, которое позволяет системе повторять сигнал бесконечное количество раз. FIR – свойство, которое позволяет системе повторять сигнал конечное количество раз (2.4). В данном проекте реализуется именно этот вариант, а количество повторений равно одному.

$$y[n] = \begin{cases} x[n] + G * x[n - M], FIR \\ x[n] + G * y[n - M], IIR \end{cases}$$
 (2.4)

где G – коэффициент усиления повторяющегося сигнала;

M – задержка, измеряемая в отсчётах.

Блок-диаграмма, описывающая эффект задержки показана ниже (Рисунок 19).



Рисунок 19 – Блок-диаграмма эффекта задержки

Цифровой эффект «Задержка» является зависимым от частоты дискретизации (частоты семплирования) звука. Данный параметр описывает, сколько замеров значений сигнала выполнено в секунду. Стандартное значение для студийной музыкальной записи — 44100 отсчётов в секунду. Расчёт количества отсчётов за определённый промежуток времени в миллисекундах вычисляется следующим образом:

$$delay_{samples} = \left| \frac{delay_{ms} * F_s}{1000} \right| \tag{2.5}$$

где  $delay_{ms}$  – задержка в миллисекундах;

 $F_s$  – частота дискретизации сигнала в Гц;

Построенная модель в Matlab (Рисунок 20) показывает поведение системы при применении данного эффекта к синусоидальному сигналу с задержкой, равной 200 мс.



Рисунок 20 – Применение эффекта «Задержка» к синусоидальному сигналу

Видно, что дополнительный сигнал смещён вперёд во времени, иными словами, отстаёт относительно входного сигнала и при этом повторяет его.

# 2.4 Эффект «Тремоло»

Эффект «Тремоло» основан на амплитудной модуляции сигналов. Модуляцией называется процесс изменения одного или нескольких параметров

высокочастотного несущего колебания по закону низкочастотного информационного сигнала [11]. Схема модуляции сигнала показана ниже (Рисунок 21).



Рисунок 21 – Принцип формирования модулированного сигнала

В случае эффекта «Тремоло» модулирующим сигналом выступает звуковой сигнал, а несущим — сигнал какой-то формы с частотой в диапазоне, как правило, от 0 до 20 Гц. Модулированным сигналом будет выступать сигнал с эффектом. Функция амплитудной модуляции для звукового сигнала:

$$f(t) = input * (1 + depth * sin(2\pi \frac{F_c}{F_s}t))$$
 (2.6)

$$f(t) = input * (1 + depth * cos(2\pi \frac{F_c}{F_s}t))$$

$$(2.7)$$

где *input* – модулирующий сигнал;

depth – глубина затухания модулированного сигнала;

 $F_c$  – частота несущего сигнала;

 $F_s$  – частота дискретизации моделирующего сигнала.

Однако, при реализации эффекта «Тремоло» в ПЛИС гораздо эффективнее использовать более простую функцию несущего сигнала. Такой функцией может выступать меандр, так как сигнал такой формы легко реализовать в цифровых устройствах и на его реализацию будет потрачено меньше вычислительных

ресурсов. Также несущим сигналом может являться треугольный сигнал. В таком случае моделирующая функция принимает следующий вид:

$$f(t) = input * (1 + depth * triangle(2\pi \frac{F_c}{F_s}t))$$
 (2.8)

где triangle() – функция генерации треугольной несущей.

Данный эффект был смоделирован в Matlab в разных режимах:

- функция несущего сигнала синусоидальная (depth=1) (Рисунок 22);
- функция несущего сигнала треугольная (depth=0.8) (Рисунок 23);
- функция несущего сигнала пилообразная (depth=0.8) (Рисунок 24).



Рисунок 22 – Применение эффекта «Тремоло» с синусоидальной несущей



Рисунок 23 – Применение эффекта «Тремоло» с треугольной несущей



Рисунок 24 – Применение эффекта «Тремоло» с треугольной несущей

Модель с треугольной формой несущего сигнала была применена к звуковой записи (Рисунок 25).



Рисунок 25 – Применение эффекта «Тремоло» к музыкальной композиции

# 2.5 Эффект «Искажение»

Данный эффект по своей функциональности похож на «Перегруз», однако искажает сигнал в большей степени. Существует множество вариаций реализации данного эффекта [7] (2.9, 2.10, 2.11), однако все они являются сложнореализуемыми в ПЛИС.

$$y = \frac{x}{1+|x|} \tag{2.9}$$

$$y = \begin{cases} -\frac{2}{3}, & x \le -1\\ x + \frac{x^3}{3}, & -1 < x < 1\\ \frac{2}{3}, & x \ge 1 \end{cases}$$
 (2.10)

$$y = \arctan(x) \tag{2.11}$$

Наиболее оптимальный способ создания цифрового эффекта «искажения» с точки зрения реализации в ПЛИС является метод повторного квантования сигнала. Суть его заключается в том, чтобы уменьшить точность квантования оцифрованного звука.

#### 2.6 Вывод

В этой главе были рассмотрены реализации эффектов разрабатываемого процессора эффектов. Они также были смоделированы в Matlab, что позволило понять то, как они работают. При реализации в ПЛИС стоить учитывать следующие ограничения:

- следует отказаться от вычислений чисел с плавающей точкой;
- следует отказаться от деления чисел.

# 3 Разработка архитектуры и алгоритмов функционирования процессора эффектов

#### 3.1 Конфигурация аппаратуры

АЦП РСМ1808 и ЦАП РСМ5102а являются конфигурируемыми: они могут работать в разных режимах [4][5]. Модули Chipdip, которые используются в проекте, заранее определяют эти режимы в своей электрической схеме:

- PCM1808 настроен в режиме ведущего (master mode 384  $\rm f_s$ ), а PCM5102a ведомого;
  - протокол обмена оцифрованного звука I2S;

Для настройки PCM1808 в режим ведущего необходимо подать на вход определённую комбинацию согласно документации (Рисунок 26). В режиме «ведомый» PCM5102a управляется внешним устройством. Это означает, что ЦАП не генерирует тактовые импульсы LRCK, BCK и SCKI. Их должно генерировать устройство «ведущий». В случае этого проекта, этим устройством является Xilinx ZYNQ 7010. Для PCM1808 предоставляется внешний тактовый импульс SCKI.

| MD1 (PIN 11) | MD0 (PIN 10) | INTERFACE MODE                                                                          |
|--------------|--------------|-----------------------------------------------------------------------------------------|
| Low          | Low          | Slave mode (256 f <sub>S</sub> , 384 f <sub>S</sub> , 512 f <sub>S</sub> autodetection) |
| Low          | High         | Master mode (512 f <sub>S</sub> )                                                       |
| High         | Low          | Master mode (384 f <sub>S</sub> )                                                       |
| High         | High         | Master mode (256 f <sub>S</sub> )                                                       |

Рисунок 26 – Входные комбинации для выбора режима работы РСМ1808

# 3.2 Разработка архитектуры процессора эффектов

Рисунок 27 отражает общую архитектуру разрабатываемого процессора эффектов.



Рисунок 27 – Функциональная схема работы процессора эффектов

Процессор эффектов принимает на вход звуковой сигнал в аналоговом виде и выдаёт на выход также аналоговый сигнал через инструментальный разъём. Все необходимые преобразования форм сигнала производятся внутри разрабатываемого устройства. Более подробная схема (Рисунок 28) описывает эти преобразования.



Рисунок 28 – Компонентная схема разрабатываемого устройства

Показанная выше схема описывает, как компоненты процессора эффектов взаимодействуют между собой. Аналогово-цифровой преобразователь PCM1808 принимает входной звуковой аналоговый сигнал, преобразует его в цифровой вид и передаёт по шине I2S на ПЛИС Xilinx ZYNQ 7010, которая реализует

цифровые звуковые эффекты. Полученный обработанный сигнал поступает по I2S шине в цифро-аналоговый преобразователь PCM5102a, который преобразует сигнал в конечный аналоговый формат. Компонентная электрическая схема (Рисунок 29) описывает какими сигналами соединены составляющие процессора эффектов.

На этой схеме система Xilinx ZYNQ 7010 разделена на две части: процессорная система (ПС) Xilinx ZYNQ 7010 генерирует тактовые импульсы для программируемой логики (СLK0). АЦП, ПЛ и ЦАП соединяются рядом линий тактовых импульсов:

- LRCK линия выбора канала звукового сигнала (левый/правый);
- SCKI линия системных тактовых сигналов для PCM1808 и PCM5102a;
- ВСК линия тактовых сигналов передачи данных для РСМ1808 и РСМ5102а.

На линиях «I2S DATA» выставляются цифровые аудиоданные, а по шине «Моde» передаётся код текущего режима работы процессора эффектов.



Рисунок 29 – Компонентная электрическая схема процессора эффектов

Далее архитектуру проекта стоит рассмотреть с точки зрения её устройства в виде СФ-блоков.

## 3.3 Разработка алгоритмов функционирования процессора эффектов

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

Например, СФ-блок (Рисунок 30), которое реализует эффект «Тремоло», можно использовать в других проектах. Достаточно подать на вход оцифрованный сигнал в формате I2S.



Рисунок 30 — СФ-блок, который применяет эффект «Тремоло» к входному звуковому сигналу

СФ-блоки можно комбинировать в проекте, выстраивая цепочки СФ-блоков. Схема (Рисунок 31) описывает устройство ПЛИС-проекта на уровне СФ-блоков. Таблица 1 описывает назначение каждого СФ-блока.



Рисунок 31 — Схема ПЛИС-проекта на уровне СФ-блоков

Таблица 1 – Назначение СФ-блоков ПЛИС-проекта

| Название        | Назначение                                           |
|-----------------|------------------------------------------------------|
| I2S_receiver    | Реализует интерфейс работы с модулем АЦП PCM1808     |
| I2S_transceiver | Реализует интерфейс работы с модулем<br>ЦАП PCM5102a |
| tremolo         | Реализует звуковой эффект «тремоло»                  |
| delay           | Реализует звуковой эффект «задержка»                 |
| distortion      | Реализует звуковой эффект «искажение»                |
| overdrive       | Реализует звуковой эффект «перегрузка»               |
| gain            | Реализует звуковой эффект «усиление»                 |
| fx              | Содержит эффекты и управляет их включением           |
| fx_control      | Реализует обработку взаимодействия с пользователем   |

| ZYNQ PS      | Предоставляет источник тактовых импульсов для ПЛ                    |
|--------------|---------------------------------------------------------------------|
| clock_wizard | Предоставляет источник тактовых импульсов 30МГц для модуля ЦАП      |
| clk_div      | Реализует делитель частот на основе счётчика                        |
| fx_processor | Содержит все модули, необходимые для реализации процессора эффектов |

Из показанного выше списка СФ-блоков реализовывать «ZYNQ PS» и «clock\_wizard» нет необходимости, так как они содержатся в стандартном наборе СФ-блоков Vivado.

ПЛИС-проект представляет из себя цепочку СФ-блоков. Блоки, реализующие эффекты могут быть соединены последовательно, таким образом процессор эффектов позволяет накладывать несколько эффектов одновременно. Диаграмма ниже (Рисунок 32) показывает, как устроена последовательность включения эффектов.



Рисунок 32 – Последовательность включения эффектов

## 3.4 Вывод

Была спроектирована архитектура проектируемого устройства. Определены режимы, в которых работают модули АЦП и ЦАП. Также определён набор реализуемых сложно-функциональных блоков.

## 4 Разработка, отладка и отработка сложно-функциональных блоков

## 4.1 Подсистема тактирования в проекте

## 4.1.1 Настройка тактирования ПЛ Xilinx ZYNQ 7010

Поскольку на отладочной плате EBAZ4205 отсутствует кварцевый резонатор для тактирования программируемой логики, то источником тактовых импульсов может выступать процессорная система ZYNQ [12]. Для этого необходимо сконфигурировать проект Xilinx Vivado, добавив туда СФ-блок «ZYNQ7 Processing System» с активированным выходом FCLK\_CLK0 (Рисунок 33) и созданным портом CLK0 (Рисунок 34), который будет тактировать ПЛ от процессорной части с частотой 50 МГц.



Рисунок 33 — Активация источника тактовых импульсов от процессорной части Xilinx ZYNQ 7010



Рисунок 34 — Добавленная в проект процессорная часть Xilinx ZYNQ 7010 с выходом тактовых импульсов

После добавления показанного выше СФ-блока, необходимо создать HDL-обёртку в Xilinx Vivado, а далее модуль можно импортировать в рабочие проекты, где необходим источник тактовых импульсов. Например, можно создать переменную Verilog с типом wire, которая будет инициализировать модуль (Рисунок 35).

```
wire clk;
ps_to_pl_clock_wrapper this (
    .CLK0(clk)
);
```

Рисунок 35 – Импорт источника тактовых импульсов в проект топ-уровня

# 4.1.2 Тактирование разрабатываемого процессора эффектов

Отдельно стоит рассмотреть схему тактирования процессора эффектов и тактирование его внутренних составляющих. Модули АЦП РСМ1808 и ЦАП РСМ5102а синхронно принимают и отдают аудиоданные определённым образом

[4][5]. При различных значениях на системном тактовом входе ЦАП и АЦП, можно получить разные частоты дискретизации звука (Рисунок 36).

| Sampling  | System Clock Frequency (f <sub>SCK</sub> ) (MHz) |                        |                       |                    |                    |                    |                    |                     |                     |                     |                     |                     |
|-----------|--------------------------------------------------|------------------------|-----------------------|--------------------|--------------------|--------------------|--------------------|---------------------|---------------------|---------------------|---------------------|---------------------|
| Frequency | 64 f <sub>S</sub>                                | 128 f <sub>S</sub>     | 192 f <sub>S</sub>    | 256 f <sub>S</sub> | 384 f <sub>S</sub> | 512 f <sub>S</sub> | 768 f <sub>S</sub> | 1024 f <sub>S</sub> | 1152 f <sub>S</sub> | 1536 f <sub>S</sub> | 2048 f <sub>S</sub> | 3072 f <sub>S</sub> |
| 8 kHz     | _(1)                                             | 1.0240(2)              | 1.5360 <sup>(2)</sup> | 2.0480             | 3.0720             | 4.0960             | 6.1440             | 8.1920              | 9.2160              | 12.2880             | 16.3840             | 24.5760             |
| 16 kHz    | _ <sup>(1)</sup>                                 | 2.0480(2)              | 3.0720 <sup>(2)</sup> | 4.0960             | 6.1440             | 8.1920             | 12.2880            | 16.3840             | 18.4320             | 24.5760             | 36.8640             | 49.1520             |
| 32 kHz    | _(1)                                             | 4.0960(2)              | 6.1440 <sup>(2)</sup> | 8.1920             | 12.2880            | 16.3840            | 24.5760            | 32.7680             | 36.8640             | 49.1520             | _(1)                | _(1)                |
| 44.1 kHz  | <b>-</b> <sup>(1)</sup>                          | 5.6488 <sup>(2)</sup>  | 8.4672 <sup>(2)</sup> | 11.2896            | 16.9344            | 22.5792            | 33.8688            | 45.1584             | _(1)                | _(1)                | _(1)                | _ <sup>(1)</sup>    |
| 48 kHz    | _(1)                                             | 6.1440 <sup>(2)</sup>  | 9.2160(2)             | 12.2880            | 18.4320            | 24.5760            | 36.8640            | 49.1520             | _(1)                | _(1)                | _(1)                | _(1)                |
| 88.2 kHz  | _(1)                                             | 11.2896 <sup>(2)</sup> | 16.9344               | 22.5792            | 33.8688            | 45.1584            | _(1)               | _(1)                | _(1)                | _(1)                | _(1)                | _(1)                |
| 96 kHz    | _(1)                                             | 12.2880 <sup>(2)</sup> | 18.4320               | 24.5760            | 36.8640            | 49.1520            | _(1)               | _(1)                | _(1)                | _(1)                | _(1)                | _(1)                |
| 176.4 kHz | _(1)                                             | 22.5792                | 33.8688               | 45.1584            | _(1)               | _(1)               | _(1)               | _(1)                | _(1)                | _(1)                | _(1)                | _(1)                |
| 192 kHz   | _(1)                                             | 24.5760                | 36.8640               | 49.1520            | _(1)               | _(1)               | _(1)               | _(1)                | _(1)                | _(1)                | _(1)                | _(1)                |
| 384 kHz   | 24.5760                                          | 49.1520                | _(1)                  | _(1)               | _(1)               | _(1)               | _(1)               | _(1)                | _(1)                | _(1)                | _(1)                | _(1)                |

Рисунок 36 – Соответствие режимов и частот функционирования РСМ5102а

Например, при подаче 16.9344 МГц (SCKI) на этот вход в режиме 384f<sub>s</sub> частота передачи данных (BCK) составит 2.8224 МГц, а результирующая частота дискретизации составит 44100 Гц (LRCK). Это стандартное студийное значение для звука на компакт-дисках. Однако, существует проблема с тем, чтобы точно сгенерировать такое значение SCKI. Поэтому было принято решение подать на системный вход тактовых импульсов 30 МГц. В режиме 384f<sub>s</sub> итоговая частота дискретизации звука будет равна 78125 Гц, а ВСК – 5 МГц. Данные расчёты одинаково актуальны как для PCM1808, так и для PCM5102a. Рисунок 37 показывает, как генерируются тактовые импульсы различной частоты в данном проекте.



Рисунок 37 — Схема взаимодействия СФ-блоков и модулей АЦП и ЦАП относительно тактовых импульсов

Процессорная часть ZYNQ 7010 генерирует тактовый импульс с частотой 50 МГц, который проходит через СФ-блок из стандартной библиотеки «clock\_wizard». На выходе этого блока системная частота АЦП SCKI со значением 30 МГц. При подаче такого сигнала на PCM1808, если это устройство находится в режиме ведущего, встроенные блоки тактирования начнут генерировать два сигнала: ВСК (5 МГц) и LRCK (78125 Гц). Эти сигналы поступают на входы СФ-блока «I2S-приёмник».

Для взаимодействия с ЦАП достаточно подать сигналы ВСК и LRCK. SCKI не требуется, когда PCM5102a настроен в режиме ведомого. При правильно настроенных ВСК и LRCK, внутренний PLL-блок модуля автоматически сгенерирует SCKI [5].

## 4.2 Разработка СФ-блока «clk\_div»

Данный сложный функциональный блок выполняет функцию цифрового делителя частот на основе счётчика. На графическом представлении (Рисунок

38) можно видеть входные и выходные сигналы СФ-блока. Таблица 2 описывает их назначение.



Рисунок 38 – Графическое обозначение СФ-блока «clk\_div»

Таблица 2 – Назначение сигналов СФ-блока «clk div»

| Сигнал  | Описание                          |
|---------|-----------------------------------|
| reset_n | Входной сигнал сброса делителя по |
|         | низкому уровню                    |
| clk     | Входной опорный сигнал тактовых   |
|         | импульсов                         |
| clk_out | Выходной сигнал тактовых          |
|         | импульсов                         |

У СФ-блока «clk\_div» есть два входных параметра:

- **Presc**. Определяет значение предделителя частоты;
- Width. Определяет разрядность счётчика.

Для тестирования сложнофункционального блока был написан тест-бенч на Verlog. Результаты тестирования (Рисунок 39) при входных параметрах Presc=8, Width=32 показывают, что входной тактовый сигнал с частотой 50 МГц был поделен на 8, т.е. итоговая частота составила 6.25МГц.



Рисунок 39 – Результат тестирования СФ-блока «clk\_div»

## 4.3 Разработка СФ-блока «I2S-передатчик»

Сложно-функциональный блок i2s\_transceiver выполняет функцию отправителя I2S-закодированного аудио согласно документации на ЦАП РСМ5102a [5]. Разработанный Verilog-модуль принимает входные массивы аудиоданных для каждого канала и выполняет их сериализацию. Под сериализацией подразумевается преобразование параллельных данных в последовательное представление. На графическом представлении СФ-блока (Рисунок 40) можно видеть входные и выходные сигналы. Таблица 3 описывает их назначение.



Рисунок 40 – Графическое обозначение СФ-блока «I2S\_transceiver»

Таблица 3 – Назначение сигналов СФ-блока «I2S-передатчик»

| Сигнал        | Описание                            |
|---------------|-------------------------------------|
| reset_n       | Входной сигнал сброса по низкому    |
|               | уровню                              |
| bck           | Входной сигнал тактовых импульсов   |
|               | передачи данных                     |
| lrck          | Выходной сигнал смены канала        |
|               | отправления                         |
| sdata         | Выходной сигнал последовательных    |
|               | данных I2S                          |
| left_channel  | Входная 32-хразрядная шина,         |
|               | передающая значение I2S для левого  |
|               | канала                              |
| right_channel | Входная 32-хразрядная шина,         |
|               | передающая значение I2S для правого |
|               | канала                              |

У СФ-блока «I2S-передатчик» есть один входной параметр:

- Width. Определяет разрядность аудиоданных для одного канала.
- Presc. Определяет значение предделителя частоты для генерации сигнала LRCK.

Для тестирования сложнофункционального блока был написан тест-бенч на Verilog. Результаты тестирования показаны ниже (Рисунок 41).



Рисунок 41 — Результат тестирования СФ-блока «I2S-передатчик»

Показанную выше диаграмму можно сравнить с диаграммой из документации на принимающее устройство ЦАП РСМ5102а (Рисунок 42). При использовании формата данных I2S во всех режимах, данные для выбранного канала на шине DATA действительны только по истечении такта после переключения шины LRCK.



I<sup>2</sup>S Data Format; L-channel = LOW, R-channel = HIGH

Рисунок 42 – Формат приёма данных РСМ5102а

Исходя из результатов тестирования СФ-блока, полученный формат данных полностью соответствует правильному формату, который предусмотрен устройством приёма.

Функционально работа СФ-блока сводится к тому, чтобы по падающему фронту ВСК выставлять данные правого и левого аудиоканалов на последовательную шину DOUT и каждые 32 такта ВСК переключать сигнал LRCK.

## 4.4 Разработка СФ-блока «I2S-приёмник»

Сложно-функциональный блок i2s\_receiver выполняет функцию считывателя I2S-закодированного аудио, занимая промежуточное место между блоками обработки звука и устройством, этот звук предоставляющим в формате I2S (АЦП). На графическом представлении (Рисунок 43) можно видеть входные и выходные сигналы СФ-блока. Таблица 4 описывает их назначение.



Рисунок 43 – Графическое обозначение СФ-блока «I2S-приёмник»

Таблица 4 — Назначение сигналов СФ-блока «I2S-приёмник»

| Сигнал        | Описание                          |
|---------------|-----------------------------------|
| reset_n       | Входной сигнал сброса по низкому  |
|               | уровню                            |
| BCK           | Входной сигнал тактовых импульсов |
|               | передачи данных                   |
| LRCK          | Входной сигнал смены канала       |
|               | считывания                        |
| i2s_data_in   | Входной сигнал последовательных   |
|               | данных I2S                        |
| left_channel  | Выходная 32-хразрядная шина,      |
|               | передающая считанное значение     |
|               | аудио для левого канала           |
| right_channel | Выходная 32-хразрядная шина,      |
|               | передающая считанное значение     |
|               | аудио для правого канала          |

У СФ-блока «I2S-приёмник» есть один входной параметр:

— **Width.** Определяет разрядность аудиоданных для одного канала.

Тестирование данного модуля удобнее всего производить в паре с использованием СФ-блока «I2S-передатчик». Блок-диаграмма проекта для тестирования показана ниже (Рисунок 44).



Рисунок 44 – Блок-диаграмма проекта-тестбенча

Так как работа передатчика полностью соответствует формату I2S, то в случае верной работы приёмника, значения в регистрах left\_channel\_in, left\_channel\_out, right\_channel\_in и right\_channel\_out должны совпадать. Далее для тестирования был написан тестбенч. Частота ВСК составила 5 МГц, а LRCK -78,125 кГц.



Рисунок 45 — Результат тестирования СФ-блока «I2S-приёмник»

Как можно заметить выше, данные на входе передатчика и выходе приёмника совпали, а каналы не были перепутаны. Это означает, что СФ-блок «I2S-приёмник» работает корректно.

# 4.5 Разработка СФ-блока «Усиление»

Данный СФ-блок реализует эффект «Усиление». Суть эффекта сводится к умножению каждого аудиоканала на константное значение. На графическом представлении СФ-блока (Рисунок 46) можно видеть входные и выходные сигналы. Таблица 5 описывает их назначение.



Рисунок 46 – Графическое обозначение СФ-блока «Усиление»

Таблица 5 – Назначение сигналов СФ-блока «Усиление»

| Сигнал            | Описание                          |
|-------------------|-----------------------------------|
| clk               | Входной сигнал тактовых импульсов |
| reset_n           | Входной сигнал сброса по низкому  |
|                   | уровню                            |
| enable            | Входной сигнал активации эффекта  |
| gain_value        | Входное значение усиления звука   |
| left_channel_in   | Входная 32-хразрядная шина,       |
|                   | передающая значение аудио для     |
|                   | левого канала                     |
| right_channel_in  | Входная 32-хразрядная шина,       |
|                   | передающая значение аудио для     |
|                   | правого канала                    |
| left_channel_out  | Выходная 32-хразрядная шина,      |
|                   | передающая значение обработанного |
|                   | аудио для левого канала           |
| right_channel_out | Выходная 32-хразрядная шина,      |
|                   | передающая значение обработанного |
|                   | аудио для правого канала          |

У СФ-блока «Усиление» есть один входной параметр:

- Width. Определяет разрядность аудиоданных для одного канала.

## 4.6 Разработка СФ-блока «Эффекты»

Данный СФ-блок содержит в себе все реализованные эффекты. Этот модуль выполняет управление эффектами, включая или выключая их в зависимости от входных параметров. На графическом представлении СФ-блока (Рисунок 47) можно видеть входные и выходные сигналы. Таблица 6 описывает их назначение.



Рисунок 47 – Графическое обозначение СФ-блока «Эффекты»

Таблица 6 – Назначение сигналов СФ-блока «Эффекты»

| Сигнал           | Описание                           |
|------------------|------------------------------------|
| enable           | Входной сигнал активации цепочки   |
|                  | эффектов                           |
| clk              | Входной сигнал тактовых импульсов  |
| reset_n          | Входной сигнал сброса по низкому   |
|                  | уровню                             |
| left_channel_in  | Входная 32-хразрядная шина,        |
|                  | передающая значение аудио для      |
|                  | левого канала                      |
| right_channel_in | Входная 32-хразрядная шина,        |
|                  | передающая значение аудио для      |
|                  | правого канала                     |
| fx_num           | Входная 4-хразрядная шина, которая |
|                  | содержит номера эффектов для       |
|                  | активации                          |

| param1            | Входная 32-хразрядная шина,       |
|-------------------|-----------------------------------|
|                   | передающая первое значение        |
|                   | параметра для эффекта             |
| param2            | Входная 32-хразрядная шина,       |
|                   | передающая второе значение        |
|                   | параметра для эффекта             |
| left_channel_out  | Выходная 32-хразрядная шина,      |
|                   | передающая значение обработанного |
|                   | аудио для левого канала           |
| right_channel_out | Выходная 32-хразрядная шина,      |
|                   | передающая значение обработанного |
|                   | аудио для правого канала          |

У СФ-блока «Эффекты» есть один входной параметр:

– **Width.** Определяет разрядность аудиоданных для одного канала.

Как уже было замечено, модуль «Эффекты» содержит в себе все реализованные эффекты и управляет ими. Рисунок 48 показывает, как устроен СФ-блок.



Рисунок 48 – Диаграмма-дизайн СФ-блока «Эффекты»

СФ-блоки, реализующие эффекты, соединяются последовательно, что в итоге позволяет добиться наложения всех эффектов на звук.

## 4.7 Разработка СФ-блока «Управление»

Данный модуль выполняет обработку взаимодействия с пользователем и интерпретирует его, выдавая на выход ряд значений. На графическом представлении СФ-блока (Рисунок 49) можно видеть входные и выходные сигналы. Таблица 7 описывает их назначение.



Рисунок 49 – Графическое обозначение СФ-блока «Управление»

Таблица 7 – Назначение сигналов СФ-блока «Управление»

| Сигнал      | Описание                          |
|-------------|-----------------------------------|
| clk         | Входной сигнал тактовых импульсов |
| reset_n     | Входной сигнал сброса по низкому  |
|             | уровню                            |
| en          | Входной сигнал активации эффектов |
| fx_switch   | Входной сигнал, который управляет |
|             | переключением эффекта для         |
|             | активации                         |
| fx_activate | Входной сигнал, который управляет |
|             | активацией эффекта                |
| param1      | Выходная 32-хразрядная шина,      |
|             | передающая первое значение        |
|             | параметра для эффекта             |
| param2      | Выходная 32-хразрядная шина,      |
|             | передающая второе значение        |
|             | параметра для эффекта             |
| fx_num      | Выходная 4-хразрядная шина,       |
|             | которая содержит номера эффектов  |
|             | для активации                     |

| enable_fx | Выходной сигнал активации |
|-----------|---------------------------|
|           | эффектов                  |

У СФ-блока «Управление» есть один входной параметр:

– **Width.** Определяет разрядность аудиоданных для одного канала.

## 4.8 Разработка СФ-блока «Процессор эффектов»

«Процессор эффектов» — это модуль топ-уровня, содержащий в себе все вышеперечисленные СФ-блоки. Все входные и выходные сигналы модуля являются аппаратными, то есть коммутируются микросхемой ПЛИС на порты ввода-вывода. На графическом представлении СФ-блока (Рисунок 50) можно видеть входные и выходные сигналы. Таблица 7 описывает их назначение.



Рисунок 50 – Графическое обозначение СФ-блока «Процессор эффектов»

Таблица 8 – Назначение сигналов СФ-блока «Процессор эффектов»

| Сигнал | Описание                          |
|--------|-----------------------------------|
| FX_EN  | Входной сигнал активации эффектов |
| FX_SW  | Входной сигнал переключения       |
|        | эффектов для активации            |
| FX_ACT | Входной сигнал, который управляет |
|        | активацией выбранного эффекта     |

| ВСК      | Входной тактовый сигнал ВСК с модуля АЦП РСМ1808                       |
|----------|------------------------------------------------------------------------|
| LRCK_in  | Входной тактовый сигнал LRCK с модуля АЦП PCM1808                      |
| DATA_in  | Входной сигнал последовательной шины I2S DATA с модуля АЦП PCM1808     |
| reset_n  | Входной сигнал сброса по низкому уровню                                |
| SCKI     | Выходной тактовый сигнал SCKI, запускающий модуль АЦП PCM1808          |
| LRCK_out | Выходной тактовый сигнал LRCK для модуля ЦАП PCM5102a                  |
| DATA_out | Выходной сигнал последовательной шины I2S DATA для модуля ЦАП PCM5102a |

«Процессор эффектов» содержит все СФ-блоки проекта, соединяя их различными сигналами и шинами. Рисунок 51 показывает, как взаимодействуют другие модули между собой.



Рисунок 51 – Диаграмма-дизайн СФ-блока «Процессор эффектов»

Оцифрованное аудио приходит из АЦП с помощью модуля «I2S-приёмник». Далее они попадают в СФ-блок «Эффекты», где производится их преобразование, или данные остаются неизменными. Это зависит от входных параметров модуля «Управление». С выхода СФ-блока «Эффекты» аудиоданные

попадают в «I2S-передатчик», где преобразуются согласно формату приёма данных ЦАП.

# 4.9 Коммутация сигналов процессора эффектов на порты вводавывода

Все входные и выходные сигналы процессора эффектов скоммутированы на порты ввода-вывода ПЛИС. Отражает соответствие сигналов физическим портам микросхемы ZYNQ 7010.

| Сигнал   | Порт ввода-вывода |
|----------|-------------------|
| FX_EN    | T19               |
| FX_SW    | P19               |
| FX_ACT   | U19               |
| BCK      | J18               |
| LRCK_in  | K18               |
| DATA_in  | M17               |
| reset_n  | U20               |
| SCKI     | L16               |
| LRCK_out | N20               |
| DATA_out | P18               |

Важно заметить, что порты J18, K18, L16 являются SRCC (Single Region Clock Compatible). Из-за свойства «Clock compatible» через эти порты можно корректно передавать внешние сигналы тактовых импульсов, например BCK.

## 4.10 Оценка затраченных ресурсов ПЛИС

В результате имплементации ПЛИС-проекта в среде Vivado, ресурсы ПЛИС были утилизированы так, как это показывает Рисунок 52.

| Resource | Utilization | Available | Utilization % |       |
|----------|-------------|-----------|---------------|-------|
| LUT      | 34          | 17600     |               | 0.19  |
| FF       | 200         | 35200     |               | 0.57  |
| Ю        | 7           | 100       |               | 7.00  |
| BUFG     | 4           | 32        |               | 12.50 |
| MMCM     | 1           | 2         |               | 50.00 |

Рисунок 52 – Утилизация ресурсов ПЛИС

## 4.11 Вывод

Была определена подсистема тактирования всех аппаратных составляющих проекта. Это важно, так как от того, какие значения частот подавать на входы ЦАП и АЦП зависит режим их работы и частота дискретизации звука.

Были разработаны и протестированы СФ-блоки процессора эффектов. Проект процессора эффектов является модульным, состоит из нескольких подмодулей, некоторые из которых также являются модульными. Процессор эффектов включает в себя:

- 7 входных сигналов
- 3 выходных сигнала
- 11 СФ-блоков.

Было утилизировано небольшое количество ресурсов ПЛИС. Существенным является использование одного ММСМ-блока для генерации частоты SCKI с помощью СФ-блока «clock\_wizard».

# ЗАКЛЮЧЕНИЕ

# СПИСОК СОКРАЩЕНИЙ

АПЦ – аналого-цифровой преобразователь;

ПЛ – программируемая логика;

ПЛИС – программируемая логическая схема;

СФ-блок – сложно-функциональный блок;

ЦАП – цифро-аналоговый преобразователь;

ЦСП – цифровой сигнальный процессор.

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

- 1 HeadRush Pedalboard: официальный сайт. URL: https://www.headrushfx.com/products/pedalboard (дата обращения: 15.12.2022)
- 2 EBAZ4205. Xjtuecho [Электронный ресурс] / URL: https://github.com/xjtuecho/EBAZ4205 (дата обращения: 21.12.2022)
- 3 Zynq-7000 All Programmable SoC Data Sheet: Overview. Xilinx [Электронный ресурс] / URL: https://www.farnell.com/datasheets/2553940.pdf (дата обращения: 21.12.2022)
- 4 PCM1808 Reference Manual. Analog Devices [Электронный ресурс] / URL: https://static.chipdip.ru/lib/170/DOC001170929.pdf (дата обращения: 21.12.2022)
- 5 PCM5102a Reference Manual. Analog Devices [Электронный ресурс] / URL: https://static.chipdip.ru/lib/145/DOC004145096.pdf (дата обращения: 21.12.2022)
- 6 I2S Bus Specification. Philips Semiconductors [Электронный ресурс] / URL: https://www.sparkfun.com/datasheets/BreakoutBoards/I2SBUS.pdf (дата обращения: 22.12.2022)
- 7 Design of DSP Guitar Effects with FPGA Implementation [Электронный ресурс] / URL: https://scholarworks.rit.edu/cgi/viewcontent.cgi?article=11514&context=theses (дата обращения: 28.03.2023)
- 8 Гитарные эффекты: алгоритмы, первый опыт аппаратной реализации [Электронный ресурс] / URL: https://habr.com/ru/post/369391/ (дата обращения: 22.12.2022)
- 9 Adding sound effects to your music. Rhea [Электронный ресурс] / URL: https://www.projectrhea.org/rhea/index.php/Adding\_sound\_effects\_to\_your\_music (дата обращения: 01.04.2023)

- 10 Digital Audio Effects. Cardiff University [Электронный ресурс] / URL: https://users.cs.cf.ac.uk/Dave.Marshall/CM0268/PDF/10\_CM0268\_Audio\_FX.pdf (дата обращения: 01.04.2023)
- 11 Физический уровень Модуляции. ИТМО вики-конспекты [Электронный ресурс] / URL: https://neerc.ifmo.ru/wiki/index.php? title=Физический уровень Модуляции (дата обращения: 05.04.2023)
- 12 ZYNQ uses PS to light up PL (detailed version). ProgrammerSought [Электронный ресурс] / URL: https://www.programmersought.com/article/69677090787/ (дата обращения: 07.04.2023)

# приложение а

# Реализация эффекта «Усиление». Matlab

```
function output = gain(input, gain_value)
  output = input(:,1);
  for n = 1:length(input)
      output(n) = input(n)*gain_value;
  end
end
```

#### ПРИЛОЖЕНИЕ Б

## Реализация эффекта «Перегруз». Matlab

```
function output = overdrive(input, gain_value, clip_value, mode)
    input = gain(input, gain_value);
    output = input(:,1);
    if(strcmp(mode, 'SOFT'))
        for n = 1:length(input)
            switch true
                 case input(n) \leftarrow -(2/3)*clip value
                     output(n) = -clip value;
                 case input(n) <= -(1/3)*clip_value
                     output(n) = clip_value*(-3+(2+3*input(n)/clip_value)^2)/3;
                 case abs(input(n)) <= (1/3)*clip_value</pre>
                     output(n) = 2*input(n);
                 case input(n) <= (2/3)*clip value
                     output(n) = clip value*\overline{(3-(2-3*input(n)/clip value)^2)/3};
                 otherwise
                     output(n) = clip_value;
            end
        end
    else
        for n = 1:length(input)
            if (input(n) > clip_value)
                 output(n) = clip_value;
            elseif (input(n) < -clip value)
                 output(n) = -clip value;
            else
                 output(n) = input(n);
            end
        end
    end
end
```

## приложение в

# Реализация эффекта «Задержка». Matlab

```
function output = delay(input, fs, delay_value, gain)
    delay_samples = floor(delay_value*fs/1000); %ms
    output = input(:,1);
    n = delay_samples+1:length(input);
    output(n) = input(n) + gain*input(n-delay_samples); %FIR implementation
end
```

# приложение г

# Реализация эффекта «Тремоло». Matlab

```
function output = tremolo(input,fs)
  index = 1:length(input);
  fc = 4;
  alpha = 0.8;
  tremolo_carrier=(1+ alpha*sawtooth(2*pi*index*(fc/fs),1/2))';
  output = tremolo_carrier.*input;
end
```

# приложение д

# Реализация СФ-блока «clk\_div». Verilog

```
`timescale 1ns / 1ps
module clk_div
\#(parameter\ WIDTH = 32,\ PRESC = 8) (
    input reset n,
    input clk,
    output reg clk out
    reg [WIDTH-1:0] bit_cnt = 1'b1;
    always @(posedge clk or negedge reset_n)
      if (!reset n)
      bit_cnt <= 1;
else if (bit_cnt >= PRESC)
             bit_cnt <= 1;
      else
             bit_cnt <= bit_cnt + 1;</pre>
    always @(posedge clk or negedge reset n)
      if (!reset n)
         clk_out <= 1'b0;
      else i\bar{f} (bit_cnt == PRESC)
             clk_out <= ~clk_out;</pre>
endmodule
```

#### приложение е

# Тестбенч для СФ-блока «clk\_div». Verilog

```
`timescale 1ns / 1ps
module clk_div_tb();
    reg clk, reset_n;
    wire clk_div_out;
    initial begin
        clk = 0;
        reset_n = 1;
    end
    initial begin
        #20 reset_n = 0;
        \#5 \text{ reset}_n = 1;
    end
    always
        #10 clk=~clk;
    design_1_wrapper clk_div_inst (
        .clk(clk),
        .clk_out(clk_div_out),
        .reset_n(reset_n)
    );
endmodule
```

#### приложение ж

## Реализация СФ-блока «I2S-передатчик». Verilog

```
`timescale 1ns / 1ps
module i2s_transceiver #(
      parameter WIDHT = 32, PRESC = 32
) (
      input bck,
    input reset_n,
      output reg lrck,
      output reg sdata,
      // Parallel datastreams
      input [WIDHT-1:0] left_channel,
      input [WIDHT-1:0] right_channel
);
reg [WIDHT-1:0]
                  bit cnt;
reg [WIDHT-1:0]
                  right;
reg [WIDHT-1:0]
                  left;
always @(negedge bck or negedge reset n)
      if (!reset n) begin
            bit cnt <= 1;
            sdata <= 0;
            left <= 0;
            right <= 0;
    end
      else if (bit_cnt >= PRESC)
            bit cnt <= 1;
      else
            bit_cnt <= bit_cnt + 1;</pre>
// Sample channels on the transfer of the last bit of the right channel
always @(negedge bck)
      if (bit cnt == PRESC && lrck) begin
        right <= right channel;
        left <= left channel;</pre>
      end
// left/right "clock" generation - 0 = left, 1 = right
always @(negedge bck or negedge reset n)
      if (!reset_n)
            lrck <= 1;
      else if (bit_cnt == PRESC)
            lrck <= ~lrck;</pre>
always @(negedge bck)
      sdata <= lrck ? right[WIDHT - bit_cnt] : left[WIDHT - bit_cnt];</pre>
endmodule
```

#### приложение 3

## Тестбенч для СФ-блока «I2S-передатчик». Verilog

```
`timescale 1ns / 1ps
module i2s_transceiver_tb();
    reg bc\overline{k}, reset n;
    reg [31:0] left channel, right channel;
    wire lrck, dout;
    initial begin
         left_channel = 32'hFFFFFFF;
         right channel = 32'h0F000000;
         bck = 0;
         reset n = 1;
    end
    initial begin
         #20 reset_n = 0;
         \#5 \text{ reset}_n = 1;
    end
    always begin
         #200 bck=~bck;
    design_1_wrapper i2s_tx_inst(
         .reset n(reset n),
         .BCK(bck),
         .left_channel(left_channel),
.right_channel(right_channel),
.LRCK(lrck),
         .DOUT(dout)
    );
endmodule
```

#### ПРИЛОЖЕНИЕ И

## Реализация СФ-блока «I2S-приёмник». Verilog

```
`timescale 1ns / 1ps
module i2s_receiver #(
      parameter WIDTH = 32
) (
    input reset n,
      input BCK,
      input LRCK,
      input i2s_data_in,
      // Parallel datastreams
      output reg [WIDTH-1:0] left channel,
      output reg [WIDTH-1:0] right channel
);
reg [WIDTH-1:0]
                  left;
reg [WIDTH-1:0]
                  right;
      lrclk_r;
wire lrclk nedge;
assign lrclk nedge = !LRCK & lrclk_r;
always @(posedge BCK)
      lrclk_r <= LRCK;</pre>
// sdata msb is valid one clock cycle after lrclk switches
always @(posedge BCK)
      if (lrclk r)
            right <= {right[WIDTH-2:0], i2s data in};
      else
            left <= {left[WIDTH-2:0], i2s_data_in};</pre>
always @(posedge BCK or negedge reset n)
      if (!reset n) begin
            left channel <= 0;</pre>
            right channel <= 0;
      else if (lrclk nedge) begin
            left channel <= left;</pre>
            right channel <= {right[WIDTH-2:0], i2s_data_in};</pre>
      end
endmodule
```

#### ПРИЛОЖЕНИЕ К

## Тестбенч для СФ-блока «I2S-приёмник». Verilog

```
`timescale 1ns / 1ps
module i2s receiver tb();
    reg bck, reset n;
    reg [31:0] left channel in, right channel in;
    wire [31:0] left channel out, right channel out;
    wire lrck, i2s_data;
    initial begin
        left channel in = 32'hFFFFFFF;
        right channel in = 32'h0F000000;
        bck = 0;
        reset_n = 1;
    end
    initial begin
        #20 reset n = 0;
        #5 reset n = 1;
    end
    always begin
        #200 bck=~bck;
    design 1 wrapper i2s rx tx (
        .BCK(bck),
        .LRCK(lrck),
        .i2s_data(i2s_data),
        .reset_n(reset_n),
        .left channel in(left channel in),
        .right_channel_in(right_channel_in),
        .left channel out(left channel out),
        .right channel out(right channel out)
    );
endmodule
```

#### приложение л

## Реализация СФ-блока «Усиление». Verilog

```
`timescale 1ns / 1ps
module gain #(parameter WIDTH=32) (
    input clk,
    input reset n,
    input enable,
    input [WIDTH-1:0] gain value, left channel in, right channel in,
    output reg [WIDTH-1:0] left channel out, right channel out
    );
    always @(posedge clk or negedge reset_n)
         if (!reset n) begin
             left_channel_out <= 0;
right_channel_out <= 0;</pre>
         end
         else if (enable) begin
             left_channel_out <= left_channel_in * gain_value;</pre>
             right_channel_out <= right_channel_in * gain_value;</pre>
         end
         else begin
             left channel out <= left channel in;</pre>
             right_channel_out <= left_channel_in;</pre>
         end
endmodule
```

#### приложение м

## Реализация СФ-блока «Эффекты». Verilog

```
`timescale 1ns / 1ps
module fx #(parameter WIDTH=32) (
    input enable,
    input clk,
    input reset n,
    input [WIDTH-1:0] left channel in, right channel in,
    output reg [WIDTH-1:0] left channel out, right channel out,
    input [3:0] fx num,
    input [WIDTH-1:0] param1,
    input [WIDTH-1:0] param2
    );
    parameter
    GAIN = 4'b0000,
    OVERDRIVE = 4'b0001;
    reg en_gain, en_overdrive;
    design 1 wrapper effects (
        .clk(clk),
        .reset n(reset n),
        .left channel in(left channel in),
        .right channel in(left channel in),
        .left channel out(left channel out),
        .right channel out(right channel out),
        .param1(param1),
        .param2(param2),
        .en gain(en gain),
        .en overdrive(en overdrive)
    );
    always @(posedge clk or negedge reset n)
        if (!reset n) begin
            en gain \leftarrow 0;
            en overdrive <= 0;
        end
        else if (!enable) begin
            case (fx num)
                GAIN: en gain <= 1;
                OVERDRIVE: en overdrive <= 1;
                default: begin
                     en_gain <= 0;
                     en overdrive <= 0;
                end
            endcase
        end
        else begin
            left channel out = left channel in;
            right channel out = left channel in;
        end
```

endmodule

#### приложение н

## Реализация СФ-блока «Процессор эффектов». Verilog

```
`timescale 1ns / 1ps
module fx_processor(
    input FX EN,
    input FX_SW,
    input FX ACT,
    input BCK,
    output SCKI,
    input LRCK_in,
    output LRCK_out,
    input DATA_in,
    output DATA out,
    input reset n
    );
    design_1_wrapper fx_processor_inst(
         .FX_EN(FX_EN),
         .FX_SW(FX_SW),
         .FX^{-}ACT(FX^{-}ACT),
         .BC\overline{K}(BCK),
         .SCKI(SCKI),
         .LRCK_in(LRCK_in),
         .LRCK_out(LRCK_out),
         .DATA_in(DATA_in),
         .DATA out(DATA out),
         .reset_n(reset_n)
    );
endmodule
```