[an error occurred while processing this directive]
Понятно, что удобно, например Log2 можно реализовать в функции(+)
(«Телесистемы»: Конференция «Языки описания аппаратуры (VHDL и др.))

миниатюрный аудио-видеорекордер mAVR

Отправлено cdg 25 января 2005 г. 14:18
В ответ на: Ответ: отправлено xdan 24 января 2005 г. 20:15


module One_Counters (BD , O);

parameter CODE_LENGTH = 3;

function integer F_BUS_LENGTH;
input [31:0] F_CODE_LENGTH;

//здесь может быть все, что угодно
//(в пределах) синтаксиса

F_BUS_LENGTH = 2**F_CODE_LENGTH;
endfunction

`define BUS_LENGTH F_BUS_LENGTH(CODE_LENGTH)
`define BusType [`BUS_LENGTH-1:0]
`define CodeType [CODE_LENGTH :0]

input `BusType BD;
output `CodeType O;

function `CodeType one_amount;
input `BusType T;
reg `CodeType C;
integer i;
begin
C=0;
for (i=0; i <= (`BUS_LENGTH-1); i = i+1) if (T[i]==1) C=C + 1;
one_amount=C;
end
endfunction // one_amountassign O=one_amount(BD);

assign O=one_amount(BD);

endmodule // One_Counters


Составить ответ  |||  Конференция  |||  Архив

Ответы


Отправка ответа

Имя (обязательно): 
Пароль: 
E-mail: 

Тема (обязательно):
Сообщение:

Ссылка на URL: 
Название ссылки: 

URL изображения: 


Перейти к списку ответов  |||  Конференция  |||  Архив  |||  Главная страница  |||  Содержание  |||  Без кадра

E-mail: info@telesys.ru