Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Программируемые логические схемы и их применение»

Ответ: Конечно можно ++

Отправлено Шурила 27 ноября 2008 г. 21:38
В ответ на: Подскажите, пожалуйста, можно ли в проект, написанный на AlteraHDL встроить мегафункции Altera? отправлено Bars 26 ноября 2008 г. 13:24

как пример, использование lpm_add_sub:
INCLUDE "lpm_add_sub.inc";
PARAMETERS (
width = 10);
SUBDESIGN s_diff_wave
(
Din[(width-1)..0] : INPUT;
F : INPUT; -- Входная частота
R : INPUT; -- Разрешение работы (=0 обнуление регистров)
Dout[(width-1)..0] : OUTPUT;
)
VARIABLE
RG[(width-1)..0] : DFF; -- Регистр сдвига
RG1r : DFF;
Dout[(width-1)..0] : DFF;
adder : lpm_add_sub WITH (LPM_WIDTH = (width + 1),
-- LPM_PIPELINE = 1,
LPM_DIRECTION = "sub",
LPM_REPRESENTATION = "signed");
Begin

RG[].clk = F;
RG[].clrn = R;
RG1r.clk = F;
RG1r.clrn = R;
Dout[].clk = F;

-- Разница входного и задержанного отсчета
RG[] = Din[];
adder.dataa[width] = gnd;
adder.datab[width] = gnd;
adder.dataa[width-1..0] = Din[];
adder.datab[width-1..0] = RG[];
-- Обработка и вывод результата
RG1r = adder.result[width]; -- запоминание знака
if (adder.result[width] and (not RG1r)) then
Dout[] = RG[]; -- если знак изменился с "+" на "-"
else
Dout[] = gnd;
end if;
End;


Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
если прибавить четыре к четырём будет:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru