**Работа 4. Мультиплексоры и АЛУ.**

**§ 4.1.** **Мультиплексор**

Мультиплексор – это цифровой переключатель, который подключает к выходу один из информационных входов в соответствии с адресом, поданным на адресный вход. Мультиплексор имеет *m* адресных входов, 2*m*информационных входов и один выход.

Мультиплексор 2 в 1 является простейшим, он имеет два входных сигнала: «x», и «y», и передает на выход «q» один из них, в зависимости от значения адреса «a». Функционирование мультиплексора поясняют схема коммутатора 2 в 1, условное обозначение, логическая функция, таблица истинности, принципиальная схема (рис. 4.1), а также теоретические временные диаграммы (рис. 4.2.).

По логической функции несложно составить описание на Verilog, однако более универсальным является поведенческое описание *v41\_mux*. Алгоритм работы мультиплексора описывает строка 5, в которой содержится оператор условного присваивания с ключевым словом «assign». Строка 5 имеет смысл: если a = 1, то q = x, иначе q = y.

|  |  |  |  |
| --- | --- | --- | --- |
| a | x | y | q |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |

a

x

y

q

0

1

Рис. 4.1. Мультиплексор 2 в 1

![](data:image/x-wmf;base64,183GmgAAAAAAAAAJYAIACQAAAABxVQEACQAAAxcBAAADABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCYAIACRIAAAAmBg8AGgD/////AAAQAAAAwP///7H////ACAAAEQIAAAsAAAAmBg8ADABNYXRoVHlwZQAAUAAIAAAA+gIAABAAAAAAAAAABAAAAC0BAAAFAAAAFAJXAPAHBQAAABMCVwCnCBwAAAD7AoD+AAAAAAAAkAEBAAAABAIAEFRpbWVzIE5ldyBSb21hbgAU8RIAqknXdkCR2nbLAmZdBAAAAC0BAQAIAAAAMgrAAecHAQAAAGF5CAAAADIKwAFxBgEAAAB5eQgAAAAyCsABFQQBAAAAYXkIAAAAMgrAAaMCAQAAAHh5CAAAADIKwAE7AAEAAABxeRwAAAD7AoD+AAAAAAAAkAEAAAACBAIAEFN5bWJvbAB2SwMKeTgyMQAU8RIAqknXdkCR2nbLAmZdBAAAAC0BAgAEAAAA8AEBAAgAAAAyCsABWQcBAAAA13kIAAAAMgrAASAFAQAAANp5CAAAADIKwAGHAwEAAADXeQgAAAAyCsABXAEBAAAAPXkKAAAAJgYPAAoA/////wEAAAAAABwAAAD7AhQACQAAAAAAvAIAAADMAQICIlN5c3RlbQBdywJmXQAACgArAIoDAAAAAAEAAAAw8xIABAAAAC0BAQAEAAAA8AECAAMAAAAAAA==)

&

x

a

y

dd1

dd2

dd3

q

dd4

&

1

MUX

0  
1

q

a

x

y

Входные тестовые сигналы необходимо создать таким образом, чтобы, было несложно предсказать выходные сигналы и однозначно определить правильность функционирования устройства. Для мультиплексора сигналы на входах «x» и «y» должны быть различными, а переключающий сигнал на адресном входе «a» дожжен иметь частоту ниже, чем частота входных сигналов «x» и «y».

a=0; q=y

y

x![](data:image/x-emf;base64,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)

a

q

t

t

t

t

a=1; q=x

Рис. 4.2 Теоретические временные  
диаграммы мультиплексора

// Поведенческое описание

// мультиплексора 2 в 1

*module v41\_mux (x ,y, a, q); //2*

*input x ,y, a; //3*

*output q; //4*

*assign q = a ? x : y ; //5*

*endmodule //6*

**Задание 4.1. Проект мультиплексора 2 в 1.**

Разработайте иерархический проект мультиплексора 2 в 1 содержащий два модуля, модуль, созданный по схеме s41\_mux, и модуль по описанию v41\_mux. разработайте различные варианты тестовых сигналов, выполните моделирование, опишите работу устройства.

**§ 4.2. Мультиплексор для коммутации шин**

Шина представляет собой совокупность проводников, по которым одновременно (параллельным кодом) передаются сигналы. Для n – разрядного мультиплексора 2 в 1 необходимо использовать n одноразрядных мультиплексоров, на которые подается общий управляющий сигнал. Каждый проводник шины должен коммутироватьcя отдельным одноразрядным мультиплексором. Мультиплексор, переключающий шины, подключает к выходным проводникам *q* проводники входной шины *x*, или шины *y*, в зависимости от адреса на входе *a* (Рис. 4.3). Теоретические временные диаграммы составьте подобно заданию 3.1.

Рис. 4.3. Схема мультиплексора для коммутации шин

//Мультиплексор для шин

*module v42\_mux(x, y, a, q);//2*

*input [3:0] x, y; //3*

*input a ; //4*

*output [3:0] q; //5*

*assign q = a ? x : y ; //6*

*endmodule //7*

MUX

0  
1

q

a

x

y

a

x

y

q

MUX

0  
1

q3

a

x3

y3

MUX

0  
1

q2

a

x2

y2

MUX

0  
1

q1

a

x1

y1

MUX

0  
1

q0

a

x0

y0

Разработайте иерархический проект. При вводе схемы первого модуля *s32\_mux* используйте символ, полученный в предыдущем проекте (*s41\_mux*). Для ввода описания второго модуля скорректируйте копию (полученную командой Save As) предыдущего описания.

**Задание 4.2. Проект мультиплексора для коммутации шин.**

Разработайте иерархический проект мультиплексора 2 в 1 для коммутации 4-разрядных шин, содержащий два модуля, модуль, созданный по схеме s42\_mux, и модуль по описанию v42\_mux. разработайте различные варианты тестовых сигналов, выполните моделирование, опишите работу устройства.

Рис. .4.4. Символ  
4-разрядного АЛУ  
на 4 операции

4

a  
  
b  
  
k

q  
  
c  
  
z

ALU

4

2

4

**§ 4.3. АЛУ комбинационного типа**

Ядром любого процессора является арифметико – логическое устройство (АЛУ), выполняющее математиченскую обработку данных. Входами АЛУ являются операнды (a, b) и код операции (k), а выходом – код результата (q) (Рис. 4.4). Входные и выходные данные – это параллельные коды, разрядность которых (напримар, 4) задана. Разраядность кода операции k определяется по заданному количеству операций. Если задано количество операций4, то k = 2

По результату операции в АЛУ должны формироваться признаки результата, для этого используются комбинационные схемы: Признак нуля (z = 1, если q = 0), признак переноса (с = 1, если появился перенос при суммировании a и b, или при сдвиге) признак отрицательного числа (n = 1, если q < 0). Существует два метода синтеза АЛУ.

Синтез АЛУ можно выполнить классическим методом, в основе которого составление таблицы истинности и логических функцийй. Классичечкий синтез используется при проектитровании сложных универсальных процессоров, обеспечивает уменьшение аппаратных затрат и повышение быстродействия устройства. Классический синтез выполняется с использованием спецмализированных САПР ввиду высокой трудоемкости процесса. Так, напримкр, аблица истинности заданного АЛУ с учетом суммарного количества поводников на входах (4 + 4 + 2) бкдет иметь 210 = 1024 строк.

Рис. 4.5. Структура 4-разрядного АЛУ

00  
01  
10  
11

MUX

k

q

4

![](data:image/x-wmf;base64,183GmgAAAAAAAGADwAECCQAAAACzXAEACQAAA9EAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCwAFgAxIAAAAmBg8AGgD/////AAAQAAAAwP///8b///8gAwAAhgEAAAsAAAAmBg8ADABNYXRoVHlwZQAAMAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4A2J/zd+Gf83cgIPV3KwtmGgQAAAAtAQAACAAAADIKYAFSAgEAAABieQgAAAAyCmABOgABAAAAYXkcAAAA+wKA/gAAAAAAAJABAAAAAgACABBTeW1ib2wAAPkJCmdA8RIA2J/zd+Gf83cgIPV3KwtmGgQAAAAtAQEABAAAAPABAAAIAAAAMgpgAUMBAQAAACt5CgAAACYGDwAKAP////8BAAAAAAAcAAAA+wIQAAcAAAAAALwCAAAAzAECAiJTeXN0ZW0AGisLZhoAAAoAIQCKAQAAAAAAAAAAXPMSAAQAAAAtAQAABAAAAPABAQADAAAAAAA=)

![](data:image/x-wmf;base64,183GmgAAAAAAAMACwAEECQAAAAAVXQEACQAAA9EAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCwAHAAhIAAAAmBg8AGgD/////AAAQAAAAwP///8X///+AAgAAhQEAAAsAAAAmBg8ADABNYXRoVHlwZQAAMAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4AwPASAJyNCnZAkQ120gJmIgQAAAAtAQAACAAAADIKYAG8AQEAAABieQgAAAAyCmABNwABAAAAYXkcAAAA+wKA/gAAAAAAAJABAAAAAgQCABBTeW1ib2wAdlcJCq241CwAwPASAJyNCnZAkQ120gJmIgQAAAAtAQEABAAAAPABAAAIAAAAMgpgATMBAQAAANd5CgAAACYGDwAKAP////8BAAAAAAAcAAAA+wIUAAkAAAAAALwCAAAAzAECAiJTeXN0ZW0AItICZiIAAAoALgCKAwAAAAAAAAAA2PISAAQAAAAtAQAABAAAAPABAQADAAAAAAA=)

![](data:image/x-wmf;base64,183GmgAAAAAAAGADwAECCQAAAACzXAEACQAAA9EAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCwAFgAxIAAAAmBg8AGgD/////AAAQAAAAwP///8X///8gAwAAhQEAAAsAAAAmBg8ADABNYXRoVHlwZQAAMAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4AGPESAJyNCnZAkQ12bQBmMQQAAAAtAQAACAAAADIKYAFkAgEAAABieQgAAAAyCmABNgABAAAAYXkcAAAA+wKA/gAAAAAAAJABAAAAAgQCABBTeW1ib2wAdowICq646zQAGPESAJyNCnZAkQ12bQBmMQQAAAAtAQEABAAAAPABAAAIAAAAMgpgAUEBAQAAANp5CgAAACYGDwAKAP////8BAAAAAAAcAAAA+wIUAAkAAAAAALwCAAAAzAECAiJTeXN0ZW0AMW0AZjEAAAoALgCKAwAAAAAAAAAAMPMSAAQAAAAtAQAABAAAAPABAQADAAAAAAA=)

![](data:image/x-wmf;base64,183GmgAAAAAAAKADwAEDCQAAAAByXAEACQAAA9EAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCwAGgAxIAAAAmBg8AGgD/////AAAQAAAAwP///8X///9gAwAAhQEAAAsAAAAmBg8ADABNYXRoVHlwZQAAMAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4AGPESAJyNCnZAkQ12gwhmRQQAAAAtAQAACAAAADIKYAGeAgEAAABieQgAAAAyCmABNgABAAAAYXkcAAAA+wKA/gAAAAAAAJABAAAAAgQCABBTeW1ib2wAdncICqQY7DQAGPESAJyNCnZAkQ12gwhmRQQAAAAtAQEABAAAAPABAAAIAAAAMgpgATwBAQAAAMV5CgAAACYGDwAKAP////8BAAAAAAAcAAAA+wIUAAkAAAAAALwCAAAAzAECAiJTeXN0ZW0ARYMIZkUAAAoALgCKAwAAAAAAAAAAMPMSAAQAAAAtAQAABAAAAPABAQADAAAAAAA=)

a

4

b

4

k

с

z

КС

n

2

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

Задано проектирование 4 - разрядного АЛУ комбинационного типа на 4 операции, имеющего входы данных а, b и вход кода операции k. Сигнал на выходе q определяется следующим образом: ![](data:image/x-wmf;base64,183GmgAAAAAAAMAFAAIBCQAAAADQWQEACQAAA+EAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCAALABRIAAAAmBg8AGgD/////AAAQAAAAwP///8X///+ABQAAxQEAAAsAAAAmBg8ADABNYXRoVHlwZQAAUAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4AFPESAHlId3VAkXp1RwBmZwQAAAAtAQAACAAAADIKYAG0BAEAAABieQgAAAAyCmABhQIBAAAAYXkIAAAAMgpgATsAAQAAAHF5HAAAAPsCgP4AAAAAAACQAQAAAAIEAgAQU3ltYm9sAHU9AQoiaLssABTxEgB5SHd1QJF6dUcAZmcEAAAALQEBAAQAAADwAQAACAAAADIKYAGaAwEAAAAreQgAAAAyCmABWAEBAAAAPXkKAAAAJgYPAAoA/////wEAAAAAABwAAAD7AhQACQAAAAAAvAIAAADMAQICIlN5c3RlbQBnRwBmZwAACgCBAIoDAAAAAAAAAAAw8xIABAAAAC0BAAAEAAAA8AEBAAMAAAAAAA==) при k=00; ![](data:image/x-wmf;base64,183GmgAAAAAAACAFAAIBCQAAAAAwWQEACQAAA+EAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCAAIgBRIAAAAmBg8AGgD/////AAAQAAAAwP///8X////gBAAAxQEAAAsAAAAmBg8ADABNYXRoVHlwZQAAUAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4AvPASAHlId3VAkXp1xQhmzAQAAAAtAQAACAAAADIKYAEWBAEAAABieQgAAAAyCmABhQIBAAAAYXkIAAAAMgpgATsAAQAAAHF5HAAAAPsCgP4AAAAAAACQAQAAAAIEAgAQU3ltYm9sAHXTCQpzqLosALzwEgB5SHd1QJF6dcUIZswEAAAALQEBAAQAAADwAQAACAAAADIKYAGHAwEAAADXeQgAAAAyCmABWAEBAAAAPXkKAAAAJgYPAAoA/////wEAAAAAABwAAAD7AhQACQAAAAAAvAIAAADMAQICIlN5c3RlbQDMxQhmzAAACgCBAIoDAAAAAAAAAADY8hIABAAAAC0BAAAEAAAA8AEBAAMAAAAAAA==) при k=01; ![](data:image/x-wmf;base64,183GmgAAAAAAAMAFAAIBCQAAAADQWQEACQAAA+EAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCAALABRIAAAAmBg8AGgD/////AAAQAAAAwP///8X///+ABQAAxQEAAAsAAAAmBg8ADABNYXRoVHlwZQAAUAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4AFPESAHlId3VAkXp1aglmqQQAAAAtAQAACAAAADIKYAG/BAEAAABieQgAAAAyCmABhQIBAAAAYXkIAAAAMgpgATsAAQAAAHF5HAAAAPsCgP4AAAAAAACQAQAAAAIEAgAQU3ltYm9sAHVVAApEaLssABTxEgB5SHd1QJF6dWoJZqkEAAAALQEBAAQAAADwAQAACAAAADIKYAGWAwEAAADaeQgAAAAyCmABWAEBAAAAPXkKAAAAJgYPAAoA/////wEAAAAAABwAAAD7AhQACQAAAAAAvAIAAADMAQICIlN5c3RlbQCpaglmqQAACgCBAIoDAAAAAAAAAAAw8xIABAAAAC0BAAAEAAAA8AEBAAMAAAAAAA==) при k=10; ![](data:image/x-wmf;base64,183GmgAAAAAAAAAGAAIBCQAAAAAQWgEACQAAA+EAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCAAIABhIAAAAmBg8AGgD/////AAAQAAAAwP///8X////ABQAAxQEAAAsAAAAmBg8ADABNYXRoVHlwZQAAUAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4AFPESAHlId3VAkXp1JglmIQQAAAAtAQAACAAAADIKYAH4BAEAAABieQgAAAAyCmABhQIBAAAAYXkIAAAAMgpgATsAAQAAAHF5HAAAAPsCgP4AAAAAAACQAQAAAAIEAgAQU3ltYm9sAHVCAAr3aLssABTxEgB5SHd1QJF6dSYJZiEEAAAALQEBAAQAAADwAQAACAAAADIKYAGRAwEAAADFeQgAAAAyCmABWAEBAAAAPXkKAAAAJgYPAAoA/////wEAAAAAABwAAAD7AhQACQAAAAAAvAIAAADMAQICIlN5c3RlbQAhJglmIQAACgCBAIoDAAAAAAAAAAAw8xIABAAAAC0BAAAEAAAA8AEBAAMAAAAAAA==) при k=11. Заданию соответствует структурная схема АЛУ (рис. 4.5). Схема АЛУ может быть построена из ранее разработанных модулей 4-разрядных схем сумматора, комбинационных схем, мультиплексора для коммутации шин.

Перспективным методом проектирования АЛУ комбинационного типа является его поведенческое описание на языке Verilog по алгоритму функционирования. Составим описание 4-разрядного АЛУ на 4 операции, структура которого приведено на рис. 4.5. Устройство должно иметь 4-разрядные входы (a,b) и выход (q), а также двухразрядный код операции (k). Заданы коды операций: 0 – суммирование, 1 – поразрядная логическая операция «И», 2 – поразрядная логическая операция «ИЛИ»., 3 – поразрядная логическая операция «сумма пр модулю 2». Устройство должно формировать признаки переноса (с), отрицательного числа n и нуля (z).

//Описание АЛУ 1

module v43\_alu (a,b,k,q, с,z);//2

input [3:0] a, b; //3

input [1:0] k ; //4

output [3:0] q;t с,z ; //6

assign {с,q} = (k == 0) ? (a +b):

(k==1)?( a&b):

(k==2) ? (a | b):(a ^ b); //7

endmodule //8

![](data:image/x-wmf;base64,183GmgAAAAAAAGACoAEACQAAAADRXQEACQAAA8kAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCoAFgAhIAAAAmBg8AGgD/////AAAQAAAAwP///yUAAAAgAgAAxQEAAAsAAAAmBg8ADABNYXRoVHlwZQAAUAAcAAAA+wKA/gAAAAAAAJABAAAAAgQCABBTeW1ib2wAdn4IClLY6zQAwPASAJyNCnZAkQ12rQhmwQQAAAAtAQAACAAAADIKAAFWAQEAAAA9eRwAAAD7AoD+AAAAAAAAkAEBAAAABAIAEFRpbWVzIE5ldyBSb21hbgDA8BIAnI0KdkCRDXatCGbBBAAAAC0BAQAEAAAA8AEAAAgAAAAyCgABOwABAAAAcXkKAAAAJgYPAAoA/////wEAAAAAABwAAAD7AhQACQAAAAAAvAIAAADMAQICIlN5c3RlbQDBrQhmwQAACgAuAIoDAAAAAAAAAADY8hIABAAAAC0BAAAEAAAA8AEBAAMAAAAAAA==)

![](data:image/x-wmf;base64,183GmgAAAAAAAGADwAECCQAAAACzXAEACQAAA9EAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCwAFgAxIAAAAmBg8AGgD/////AAAQAAAAwP///8b///8gAwAAhgEAAAsAAAAmBg8ADABNYXRoVHlwZQAAMAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4A2J/zd+Gf83cgIPV3KwtmGgQAAAAtAQAACAAAADIKYAFSAgEAAABieQgAAAAyCmABOgABAAAAYXkcAAAA+wKA/gAAAAAAAJABAAAAAgACABBTeW1ib2wAAPkJCmdA8RIA2J/zd+Gf83cgIPV3KwtmGgQAAAAtAQEABAAAAPABAAAIAAAAMgpgAUMBAQAAACt5CgAAACYGDwAKAP////8BAAAAAAAcAAAA+wIQAAcAAAAAALwCAAAAzAECAiJTeXN0ZW0AGisLZhoAAAoAIQCKAQAAAAAAAAAAXPMSAAQAAAAtAQAABAAAAPABAQADAAAAAAA=)

k=0?

0

1

1

0

![](data:image/x-wmf;base64,183GmgAAAAAAAMACwAEECQAAAAAVXQEACQAAA9EAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCwAHAAhIAAAAmBg8AGgD/////AAAQAAAAwP///8X///+AAgAAhQEAAAsAAAAmBg8ADABNYXRoVHlwZQAAMAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4AwPASAJyNCnZAkQ120gJmIgQAAAAtAQAACAAAADIKYAG8AQEAAABieQgAAAAyCmABNwABAAAAYXkcAAAA+wKA/gAAAAAAAJABAAAAAgQCABBTeW1ib2wAdlcJCq241CwAwPASAJyNCnZAkQ120gJmIgQAAAAtAQEABAAAAPABAAAIAAAAMgpgATMBAQAAANd5CgAAACYGDwAKAP////8BAAAAAAAcAAAA+wIUAAkAAAAAALwCAAAAzAECAiJTeXN0ZW0AItICZiIAAAoALgCKAwAAAAAAAAAA2PISAAQAAAAtAQAABAAAAPABAQADAAAAAAA=)

k=1?

k=2?

![](data:image/x-wmf;base64,183GmgAAAAAAAGADwAECCQAAAACzXAEACQAAA9EAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCwAFgAxIAAAAmBg8AGgD/////AAAQAAAAwP///8X///8gAwAAhQEAAAsAAAAmBg8ADABNYXRoVHlwZQAAMAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4AGPESAJyNCnZAkQ12bQBmMQQAAAAtAQAACAAAADIKYAFkAgEAAABieQgAAAAyCmABNgABAAAAYXkcAAAA+wKA/gAAAAAAAJABAAAAAgQCABBTeW1ib2wAdowICq646zQAGPESAJyNCnZAkQ12bQBmMQQAAAAtAQEABAAAAPABAAAIAAAAMgpgAUEBAQAAANp5CgAAACYGDwAKAP////8BAAAAAAAcAAAA+wIUAAkAAAAAALwCAAAAzAECAiJTeXN0ZW0AMW0AZjEAAAoALgCKAwAAAAAAAAAAMPMSAAQAAAAtAQAABAAAAPABAQADAAAAAAA=)

![](data:image/x-wmf;base64,183GmgAAAAAAAKADwAEDCQAAAAByXAEACQAAA9EAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCwAGgAxIAAAAmBg8AGgD/////AAAQAAAAwP///8X///9gAwAAhQEAAAsAAAAmBg8ADABNYXRoVHlwZQAAMAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4AGPESAJyNCnZAkQ12gwhmRQQAAAAtAQAACAAAADIKYAGeAgEAAABieQgAAAAyCmABNgABAAAAYXkcAAAA+wKA/gAAAAAAAJABAAAAAgQCABBTeW1ib2wAdncICqQY7DQAGPESAJyNCnZAkQ12gwhmRQQAAAAtAQEABAAAAPABAAAIAAAAMgpgATwBAQAAAMV5CgAAACYGDwAKAP////8BAAAAAAAcAAAA+wIUAAkAAAAAALwCAAAAzAECAiJTeXN0ZW0ARYMIZkUAAAoALgCKAwAAAAAAAAAAMPMSAAQAAAAtAQAABAAAAPABAQADAAAAAAA=)

1

0

Рис. 4.8. Алгоритм выбора операции и описание АЛУ

В описании АЛУ строка 2 – заголовок, содержит имя описания и перечисление всех входов и выходов. В строке 3 описаны 4-разрядные входные векторы a,b, в строке 4 описан 2-разрядный вектор кода операции (k), а в строке 5 – выходной вектор (q) В строке 6 указаны признаки переноса и нуля (с,z), для которых описание диапазона отсутствует, следовательно, эти сигналы – одноразрядный.

Описание типов сигналов, используемых в качестве входов и выходов, в данном примере отсутствует, все сигналы по умолчанию имеют тип «wire», с которыми используют параллельный оператор с ключевым словом «assign», а также арифметические, логические операторы и оператор условного присваивания.

В строке 7 записан оператор условного присваивания, содержащий вложенные условные операторы, который в зависимости от кода операции выполняет определенные действия в соответствии с алгоритмом, представленном на рис. 4.8. Для улучшения восприятия оператор разделен символами перевода строки, что не влияет на компиляцию.

Рис. 4.9. Теоретические временные диаграммы

0000

0001

0010

0011

0100

0101

0110

0111

00

01

10

11

0101

0110

0111

1000

1001

1010

1011

1100

0101

0111

0010

0000

1101

1111

1101

1011

t

t

t

t

Сигнал, формируемый оператором присваивания (строка 7), записан как объединение сигналов переноса «с» и выходного вектора «q», они записаны через запятую в фигурных скобках. Результат - 5-разрядный вектор суммы или разности, старший бит которого равен 1, если возникает перенос.

Теоретические временные диаграммы, предназначенные для проверки работоспособности, лриведены на рис. 4.9.

**Задание 4.3. Проект АЛУ комбинационного типа**

Разработайте проект **АЛУ комбинационного типа** по описанию v43\_ alu . разработайте различные варианты тестовых сигналов, выполните моделирование, опишите работу устройства.

**Задание 4.4. Проект АЛУ комбинационного типа по схеме.** Заданы операции.

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Вариант | 1 | 2 | 3 | 4 | 5 | 6 |
| операции | and, nor | and, nxor | or, nxor | nand, or | nand, xor | nor, xor |

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Вариант | 7 | 8 | 9 | 10 | 11 | 12 |
| операции | nand, nor | nand, nxor | nor, nxor | and, nor | and, xor | or, xor |

Разработайте проект 4-разрядного АЛУ по схеме на 4 операции в соответствии с таблицей, содержащий модули, разработанные в предыдущих работах. Разработайте тестовые сигналы, выполните моделирование, опишите работу устройства.

**Контрольные вопросы**

|  |  |
| --- | --- |
| 1.  2.  3.  4.  5.  6.  7.  8.  9.10. | Сформулируйте функциональное назначение мультиплексора.  Укажите входные и выходные сигналы мультиплексора.  Как составляется таблица истинности мультиплексора.  Составьте описание мультиплексора по логическим функциям.  Как составить теоретические временные диаграммы для мультиплексора?  Синтаксис и применение оператора условного присваивания.  Особенности структурного и поведенческого описания.  Поясните методы проектирования АЛУ и способы его описания на Vtrilog..  Определите количество входов мультиплексора для переключения n входов. |