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

Страницы работы

Уважаемые коллеги! Предлагаем вам разработку программного обеспечения под ключ.

Опытные программисты сделают для вас мобильное приложение, нейронную сеть, систему искусственного интеллекта, SaaS-сервис, производственную систему, внедрят или разработают ERP/CRM, запустят стартап.

Сферы - промышленность, ритейл, производственные компании, стартапы, финансы и другие направления.

Языки программирования: Java, PHP, Ruby, C++, .NET, Python, Go, Kotlin, Swift, React Native, Flutter и многие другие.

Всегда на связи. Соблюдаем сроки. Предложим адекватную конкурентную цену.

Заходите к нам на сайт и пишите, с удовольствием вам во всем поможем.

Содержание работы

ЛАБОРАТОРНАЯ РАБОТА №6

ЛИНЕЙНЕЙНЫЕПЕРЕКЛЮЧАТЕЛЬНЫЕ СХЕМЫ (ЛПС)

ЦЕЛЬ РАБОТЫ: изучение принципов построения и исследование линейных переключательных схем (ЛПС) в устройствах умножения и деления многочленов.

КРАТКИЕ СВЕДЕНИЯ ИЗ ТЕОРИИ

ЛПС называется любая схема , содержащая конечное число сумматоров, устройств памяти и устройств умножения на константу, соединённых любым доступным способом. Умножение на 0 или 1 означает соответственно разрыв или наличие соединения обратной связи. Поэтому ЛПС, позволяющие умножать или делить двоичные многочлены, состоят только из ячеек памяти и сумматоров и представляют собой регистры сдвига с логическими обратными связями.

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

1.  Умножение многочленов

На рис. 6.1 изображена одна из схем, используемая для умножения произвольного двоичного многочлена:

а (х) = а n-1 х  n-1  + а n-2  х n-2 +…+ а 1 х  + а 0,   i € {0, 1})

на фиксированный многочлен без нулевых членов:

h (х) =  х r + х r-1  +… + х 2 + х + 1,  (h i = 1).

Вход и выход схемы предполагаются последовательными.

На вход схемы поступают коэффициенты многочлена а (х) , начиная с коэффициентов старших разрядов, после чего следует r нулей. Произведение, равное:

а (х) h (х) = а n-1 х n + r -1 + (а n - 2  + а n - 1) x n + r - 2 + … + (a 0 + a 1) x + a 0

формируется на выходе схемы за (n + r) тактов.

Для примера разобрано построение схемы (рис. 6.2) , осуществляющей умножение любого многочлена на входе на фиксированный многочлен h (x) = x 3 + x  2 + 1. Цепь тактовых импульсов на схеме не показана.

Построение схемы отвечает следующему правилу:

- число ячеек памяти равно степени многочлена h (x);

- число сумматоров на 1 меньше числа нулевых членов многочлена;

- сумматоры устанавливаются перед ячейками регистра, соответствующими ненулевыми членами многочлена тех же степеней. Ячейка старшей степени отсутствует и сумматор на выходе схемы стоит перед отсутствующей ячейкой;

- сумматор, соответствующий младшему члену многочлена, отбрасывается, т.е. сумматор на входе ячейки П1 отсутствует;

- множимое подаётся одновременно на вход П1 и на все сумматоры.

Если коэффициент при  хравен 0, то число сумматоров равно числу ненулевых членов h (x) и множимое подаётся на сумматоры.

Процесс умножения многочлена а (х) = x 2 + x  (двоичное представление 110) на многочлен h (x) = х 3 + х 2 + 1 представлен в табл. 6.1. Произведение а (х) * h (x) = x 5 + x 3+ x 2+ x (101110) формируется на выходе за h + r = 6 тактов. Первоначально в ячейках памяти содержатся нули.

Таблица 6.1.

Номер такта

Множимое

(вход)

Состояние ячейки памяти

Произведение

(выход)

П1

П2

П3

0

-

0

0

0

-

1

1

1

0

1

1

2

1

1

1

1

0

3

0

0

1

1

1

4

0

0

0

1

1

5

0

0

0

0

1

6

0

0

0

0

0

   

2.  Деление многочленов

Структурная схема регистра сдвига с логическими обратными связями , осуществляющая деление на двоичный фиксированный многочлен степени r  без нулевых членов,  представлен на рис.6.3. Ячейки памяти в исходном состоянии должны содержать нули. Для первых r тактов работы схемы, пока первый входной сигнал не достигнет конца регистра, выходные символы равны нулю. На  (r + 1) такте появляется первый ненулевой выходной символ, который равен первому коэффициенту частного, а в регистре будет находиться остаток от деления (остаток может быть и нулевым).

На рис. 6.4. изображена схема, предназначенная для деления на многочлен g (x) = x 3 + x + 1. Поступление тактовых импульсов на схеме не показано.

Построение регистров подобной структуры отвечает следующему правилу:

- число ячеек регистра равно степени многочлена, на который производится деление;

- число сумматоров на 1 меньше числа ненулевых членов многочлена g (x);

- сумматоры ставятся перед ячейками регистра, соответствующими ненулевыми членами многочлена g(x) тех же степеней;

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

Последовательность операций в схеме при делении многочлена а(х)= х 6+ х 5 представлена в табл. 6.2. Деление осуществляется за 7 тактов. Первоначальное состояние всех ячеек регистра – ненулевое.

Таблица 6.2.

Номер такта

Делимое

(вход)

Состояние ячеек памяти

Частное

(выход)

П1

П2

П3

0

-

0

0

0

-

1

1

1

0

0

0

2

1

1

1

0

0

3

0

0

1

1

0

4

0

1

1

1

1

5

0

1

0

1

1

6

0

1

0

0

1

7

0

0

1

0

0

В 1 такте единица старшего разряда делимого записывается в ячейку П1. При поступлении 2 тактового импульса(такт 2) эта единица считывается с ячейки П1 и записывается в ячейку П2. Одновременно в ячейку П1 поступает второй разряд делимого. На третьем такте все ячейки памяти будут заполнены и в цепи обратной связи (ОС) с выхода ячейки П3 появится сигнал 1. В четвёртом такте единица ОС складывается с нулевым сигналом на входе схемы и ячейка П1 переходит в состояние 1.

Одновременно единица ОС складывается во втором сумматоре с нулевым сигналом, считываемым с ячейки П1, в результате чего ячейка П2 также перейдёт в состояние 1 и т.д. На 7 такте в ячейках памяти появится остаток от деления.

Похожие материалы

Информация о работе

Уважаемые коллеги! Предлагаем вам разработку программного обеспечения под ключ.

Опытные программисты сделают для вас мобильное приложение, нейронную сеть, систему искусственного интеллекта, SaaS-сервис, производственную систему, внедрят или разработают ERP/CRM, запустят стартап.

Сферы - промышленность, ритейл, производственные компании, стартапы, финансы и другие направления.

Языки программирования: Java, PHP, Ruby, C++, .NET, Python, Go, Kotlin, Swift, React Native, Flutter и многие другие.

Всегда на связи. Соблюдаем сроки. Предложим адекватную конкурентную цену.

Заходите к нам на сайт и пишите, с удовольствием вам во всем поможем.