Разработка, производство и продажа радиоэлектронной аппаратуры
|
Карта сайта
|
Пишите нам
|
В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; 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 изображения:
если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
если прибавить четыре к четырём будет:
Перейти к списку ответов
|
Конференция
|
Раздел "Электроника"
|
Главная страница
|
Карта сайта
Web
telesys.ru