Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Verilog_posobie.docx
Скачиваний:
24
Добавлен:
11.06.2015
Размер:
86.73 Кб
Скачать

3.4.36. Задание векторов входных сигналов для моделирования (Verilog Input Vectors )

Для задания входных векторов для моделирования системы требуется весьма ограниченное подмножество языка Verilog. Рассмотрим простой пример

 

        initial

        begin

           clk = 1'b0;

           globalReset = 1'b1;

           in = 1'b1;

        end

 

Выражение 1'b0 предсавляет собой двоичное представление 0.

Существуют две основных части :

 

        initial

        begin

             -----

        end

 

        always

        begin

             -----

        end

Блок initial начинает выполняться с началом моделирования (simulation), поэтому в нем инициализируются сигналы и определяется последовательность их изменений

Тактовый сигнал существует в течении всего времени моделирования. Задержка между моментами смены сигналов (событиями, events) определяется с помощюь знака  # . Например

 

           #160 globalReset = 0;

           #160 in = 0;

           #160 in = 1;

           #320 in = 0;

В приведенном примере после 160 единиц времени ожидания сигнал globalReset устанавливается в 0, затем 160 единиц ожидания и установка сигнала in в 0 и т.д.

Наиболее часто конструкция always используется для задания тактового сигнала. Например:

 

        always

        begin

           #10 clk = ~clk;

        end

Здесь сигнал clk должен быть проинвертирован каждые 10 единиц измерения времени, что по сути означает, что период тактового сигнала - 20 единиц измерения времени (time units).

Кроме того, в процессе моделирования неплохо использовать цикл repeat для задания заданного числа повторений

 

        repeat(10)

        begin

            #40 in = 0;

            #20 in = 1;

        end

 

Для генерации случайных чисел в диапазоне  [0, n-1] используется следующая команда

 

        {$random} % n

 

Комбинируя эти команды создадим генератор пачек из 14 случайных чисел каждые 20 единиц времени (time units)

 

        repeat(14)

        begin

            #20 in = {$random} / 16  % 2;

        end

 

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]