реклама на сайте
подробности

 
 
> Как можно оптимизировать код?
keeka
сообщение Oct 13 2011, 19:45
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 15
Регистрация: 15-12-10
Из: Москва
Пользователь №: 61 640



Добрый день, народ.

Закончил свою первую работу - модулятор ЧМ2.
Код написан на VHDL.
Подскажите, пожалуйста, что можно было сделать лучше, оптимальней, чтобы лучше работало. Чувствую, что сделал все очень корявоsm.gif
на вход clk подается clock, на вход reset - информационные биты. Все в формате boolean. Ну и выход в формате integer.

Прикрепленный файл  fsk_modulator.vhd ( 1.21 килобайт ) Кол-во скачиваний: 237
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
syoma
сообщение Oct 19 2011, 12:57
Сообщение #2


Профессионал
*****

Группа: Свой
Сообщений: 1 817
Регистрация: 14-02-07
Из: наших, которые работают за бугром
Пользователь №: 25 368



Конечно, Матлаб не универсальная штука и все промоделировать в нем нельзя. Пока можно сказать, что он хорошо подходит для моделирования алгоритмов DSP, не более. Автоматы состояний мы делаем в Xilinx StateCAD, а затем подключаем к модели через blackbox.
Процессоры там тоже особо не промоделируешь.
Но, кстати, это особо и не нужно.
Например, ессно наш алгоритм DSP получает сигналы не напрямую с аналогового сигнала. В реальности там стоит АЦП, а АЦП надо еще тактировать и управлять. То есть целый драйвер нужен. Но в МАТЛАБЕ от этого можно абстрагироваться, просто подав Simulinkовский сигнал на преобразователь в фиксированную точку и все. Таким образом сигнал становится как-бы внутренним Плисовским сигналом.
А драйвер АЦП давно отлажен и сделан как BSP в виде симулинковского блока в библиотеке. В итоге отлаженный алгоритм подключается к драйверу и генерится битстрим.
Цитата
Каким образом Вы проверяете работоспособность на функциональном уровне? Только по симулинку? Тестбенчи вообще не пишете? Каким образом проверяется работоспособность с учетом всех задержек

К сожалению(или к счастью) с тестбенчами опыта не имел по вышеозначенным причинам, поэтому не совсем понимаю, зачем они нужны.
В случае с System Generator все сводится к следующему. Все клоки Маталаб распределяет сам и дизайн полностью синхронный. Таким образом сигнал от одного регистра до следующего должен дойти за период клока. При моделировании в Симулинке регистровые задержки учитываются и по диаграмме можно увидеть, что данный сигнал задержан на столько то периодов.
Далее есть такая функция - анализатор таймингов, которая комплирует полностью дизайн, пытается впихать его в ПЛИС и если вышеуказанное условие не выполняется - в Симулинке показывается цепь, которая содержит слишком длинную комбинаторную цепочку. В этом случае разработчик должен внести в нее регистры, увеличив задержки. При этом он продолжает моделирование и если надо корректирует дизайн, чтобы сохранялась исходная функция. Если тайминг проходит, то можно прошивать ПЛИС - гарантируется, что в этом случае функциональность ПЛИС будет идентична модели.

ПС Кстати в следуюшем проекте мы начинаем использовать SERDES. Посмотрю, как их можно к Матлабу прикрутить
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- keeka   Как можно оптимизировать код?   Oct 13 2011, 19:45
- - eugen_pcad_ru   Код не видел пока. Вопрос: фаза формируемого сигна...   Oct 14 2011, 04:44
- - andrew_b   Что это такое? Код process(clk) begin -...   Oct 14 2011, 04:51
- - keeka   ЦитатаКод не видел пока. Вопрос: фаза формируемого...   Oct 14 2011, 08:06
- - DuHast   а "rising_edge(clk)" где у Вас? В моде...   Oct 14 2011, 08:14
- - keeka   Там по rising_edge ранее запускалась команда счит...   Oct 14 2011, 08:44
|- - DuHast   У Вас сигнал clk стоит в списке чуствительности пр...   Oct 16 2011, 10:04
|- - keeka   Цитата(DuHast @ Oct 16 2011, 14:04) У Вас...   Oct 16 2011, 19:34
|- - VladimirB   Цитата(keeka @ Oct 16 2011, 23:34) Поясни...   Oct 16 2011, 20:21
|- - keeka   Цитата(VladimirB @ Oct 17 2011, 00:21) Са...   Oct 17 2011, 04:49
|- - DuHast   Цитата(keeka @ Oct 17 2011, 08:49) Хотя б...   Oct 17 2011, 11:18
|- - yes   Цитата(keeka @ Oct 17 2011, 08:49) Хотя б...   Oct 17 2011, 15:23
|- - VladimirB   Цитата(yes @ Oct 17 2011, 19:23) опасаюсь...   Oct 17 2011, 18:30
- - Koluchiy   Цитатана вход clk подается clock, на вход reset - ...   Oct 16 2011, 16:06
- - keeka   Мне на самом деле очень интересна тема автоматичес...   Oct 18 2011, 12:23
|- - bogaev_roman   Цитата(keeka @ Oct 18 2011, 16:23) Как сч...   Oct 18 2011, 13:40
|- - VladimirB   Цитата(keeka @ Oct 18 2011, 16:23) Мне на...   Oct 18 2011, 19:17
|- - des00   Цитата(VladimirB @ Oct 18 2011, 14:17) Но...   Oct 19 2011, 03:11
|- - sazh   Цитата(des00 @ Oct 19 2011, 06:11) я сдел...   Oct 19 2011, 06:50
|- - des00   Цитата(sazh @ Oct 19 2011, 01:50) Вопр...   Oct 19 2011, 17:17
- - syoma   ЦитатаХотя есть одно НО - сгенеренный код не оптим...   Oct 19 2011, 07:41
|- - bogaev_roman   Цитата(syoma @ Oct 19 2011, 11:41) 1. Раз...   Oct 19 2011, 12:25
|- - bogaev_roman   Согласен, для ЦОС матлаб подходит очень хорошо, но...   Oct 19 2011, 13:11
- - keeka   А как вы относитесь к связке LabVIEW + PXI? Писать...   Oct 19 2011, 13:04
- - syoma   ЦитатаЧто сделать, если внести регистры не удается...   Oct 19 2011, 13:22
|- - bogaev_roman   Цитата(syoma @ Oct 19 2011, 17:22) В Матл...   Oct 19 2011, 13:44
- - syoma   Ваша логика ясна, все понятно. Но так же и понятно...   Oct 19 2011, 14:14
|- - bogaev_roman   Цитата(syoma @ Oct 19 2011, 18:14) Ваша л...   Oct 19 2011, 14:44
- - tAmega   Немного запоздал с линком, вот только что нарыл. Э...   Oct 22 2011, 05:32
|- - ys05   Цитата(tAmega @ Oct 22 2011, 09:32) Кому ...   Oct 22 2011, 07:51
- - keeka   ЦитатаНу а пока первый линк для топик стартера. С...   Oct 22 2011, 07:25
- - tAmega   Завтра выложу на рапиду и дам сюда линк.   Oct 22 2011, 09:58
- - tAmega   Вот, линк на полный конспект из трех частей со все...   Oct 23 2011, 07:48
- - keeka   Спасибо Как раз, что мне нужно)   Oct 23 2011, 10:29


Reply to this topicStart new topic
2 чел. читают эту тему (гостей: 2, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 23rd July 2025 - 09:25
Рейтинг@Mail.ru


Страница сгенерированна за 0.01413 секунд с 7
ELECTRONIX ©2004-2016