exponenta event banner

Параметры трубопровода

На этой странице документации описаны параметры конфигурации, которые находятся на вкладке Создание кода HDL (HDL Code Generation) > Оптимизация (Optimization) > Конвейерная обработка (Pipelining) диалогового окна Параметры конфигурации (Configuration Parameters). Используя параметры в этом разделе, можно улучшить время проектирования на целевом устройстве..

Иерархическая распределенная конвейерная обработка

Иерархическая распределенная конвейерная обработка расширяет область распределенной конвейерной обработки за счет распределения задержек по иерархиям подсистем. Эта оптимизация перемещает задержки в подсистеме при сохранении иерархии.

Настройки

По умолчанию: Откл.

На

Включить ресинхронизацию по иерархии подсистем. HDL Coder™ применяет ресинхронизацию иерархически из подсистемы верхнего уровня. Чтобы переместить задержки в подсистему, в свойствах блока HDL для этой подсистемы установите значение «Pipelining». on. Иерархическая распределенная конвейерная обработка прекращает распределение задержек, когда она достигает подсистемы, для которой установлено значение Pipelining off.

Прочь

Распределяет трубопроводы в подсистеме, если для параметра Pipelining установлено значение on для этой подсистемы.

Зависимость

Если установлен флажок «Сохранить задержки проектирования», распределенная конвейерная обработка не перемещает задержки проектирования.

Информация командной строки

Свойство: HierarchicalDistPipelining
Текст: символьный вектор
Значение: 'on' | 'off'
По умолчанию: 'off'

Чтобы задать это свойство, используйте hdlset_param или makehdl. Для просмотра значения свойства используйте hdlget_param.

Например, можно включить HierarchicalDistPipelining при создании кода HDL для symmetric_fir подсистема внутри sfir_fixed с использованием любого из этих методов.

  • Передать свойство в качестве аргумента makehdl функция.

    makehdl('sfir_fixed/symmetric_fir', ... 
            'HierarchicalDistPipelining','on')
  • При использовании hdlset_param, можно задать параметр в модели, а затем создать код HDL с помощью makehdl.

    hdlset_param('sfir_fixed','HierarchicalDistPipelining','on')
    makehdl('sfir_fixed/symmetric_fir')

См. также

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

Укажите приоритет алгоритма распределенной конвейерной обработки.

Настройки

По умолчанию: Numerical Integrity

Numerical Integrity

Расставьте приоритеты числовой целостности при распределении регистров конвейера.

Этот параметр использует консервативный алгоритм ресинхронизации, который не перемещает регистры по компоненту, если функциональная эквивалентность исходной конструкции неизвестна.

Performance

Приоритет производительности над числовой целостностью.

Используйте этот параметр, если конструкция требует более высокой тактовой частоты, а поведение Simulink не обязательно должно строго соответствовать сгенерированному поведению кода. Этот параметр использует более агрессивный алгоритм ресинхронизации, который перемещает регистры по компоненту, даже если функциональная эквивалентность модифицированной конструкции исходной неизвестна.

Информация командной строки

Свойство: DistributedPipeliningPriority
Текст: символьный вектор
Значение: 'NumericalIntegrity' | 'Performance'
По умолчанию: 'NumericalIntegrity'

Чтобы задать это свойство, используйте hdlset_param или makehdl. Для просмотра значения свойства используйте hdlget_param.

Например, можно использовать DistributedPipeliningPriority при создании кода HDL для symmetric_fir подсистема внутри sfir_fixed с использованием любого из этих методов.

  • Передать свойство в качестве аргумента makehdl функция.

    makehdl('sfir_fixed/symmetric_fir', ... 
            'DistributedPipeliningPriority','Performance')
  • При использовании hdlset_param, можно задать параметр в модели, а затем создать код HDL с помощью makehdl.

    hdlset_param('sfir_fixed','DistributedPipeliningPriority','Performance')
    makehdl('sfir_fixed/symmetric_fir')

См. также

Конвейеризация тактовой частоты

Если конструкция содержит пути с несколькими циклами, используйте конвейер тактовой частоты для вставки регистров конвейера с тактовой частотой, превышающей скорость передачи данных. Эта оптимизация улучшает тактовую частоту и уменьшает использование области без дополнительной задержки. Конвейеризация тактовой частоты не влияет на существующие в модели задержки проектирования. Это альтернатива использованию ограничений многоцикловой траектории с помощью инструмента синтеза.

Настройки

По умолчанию: Вкл.

На

Вставка регистров трубопроводов с тактовой частотой для многоцикловых путей.

Прочь

Вставка регистров трубопровода на скорости передачи данных для многоцикличных путей.

Зависимость

Если указан коэффициент избыточной дискретизации, превышающий единицу, убедитесь, что установлен флажок Конвейерирование тактовой частоты. Конвейеризация тактовой частоты идентифицирует области в модели, которые работают с той же медленной скоростью передачи данных и ограничены блоками задержки или блоками, которые вводят переход скорости. Генератор кода преобразует эти области в более высокую тактовую частоту путем введения блоков повтора на входе области и блоков перехода скорости на выходе области.

Информация командной строки

Свойство: ClockRatePipelining
Текст: символьный вектор
Значение: 'on' | 'off'
По умолчанию: 'on'

Чтобы задать это свойство, используйте hdlset_param или makehdl. Для просмотра значения свойства используйте hdlget_param.

Например, можно использовать ClockRatePipelining при создании кода HDL для symmetric_fir подсистема внутри sfir_fixed с использованием любого из этих методов.

  • Передать свойство в качестве аргумента makehdl функция.

    makehdl('sfir_fixed/symmetric_fir', ... 
            'ClockRatePipelining','on')
  • При использовании hdlset_param, можно задать параметр в модели, а затем создать код HDL с помощью makehdl.

    hdlset_param('sfir_fixed','ClockRatePipelining','on')
    makehdl('sfir_fixed/symmetric_fir')

См. также

Разрешить конвейеризацию тактовой частоты выходных портов DUT

Для выходных портов DUT вставьте регистры конвейера на тактовой частоте вместо скорости передачи данных.

Настройки

По умолчанию: Откл.

На

На выходных портах DUT вставьте регистры трубопроводов с тактовой частотой.

Прочь

На выходных портах DUT вставьте регистры трубопроводов со скоростью передачи данных.

Зависимость

При указании этого параметра убедитесь, что установлен флажок Clock-rate pipelining.

Информация командной строки

Свойство: ClockRatePipelineOutputPorts
Текст: символьный вектор
Значение: 'on' | 'off'
По умолчанию: 'off'

Чтобы задать это свойство, используйте hdlset_param или makehdl. Для просмотра значения свойства используйте hdlget_param.

Например, можно использовать ClockRatePipelineOutputPorts при создании кода HDL для symmetric_fir подсистема внутри sfir_fixed с использованием любого из этих методов.

  • Передать свойство в качестве аргумента makehdl функция.

    makehdl('sfir_fixed/symmetric_fir', ... 
            'ClockRatePipelineOutputPorts','on')
  • При использовании hdlset_param, можно задать параметр в модели, а затем создать код HDL с помощью makehdl.

    hdlset_param('sfir_fixed','ClockRatePipelineOutputPorts','on')
    makehdl('sfir_fixed/symmetric_fir')

См. также

Адаптивная конвейерная обработка

Этот параметр используется для вставки регистров трубопроводов в блоки в проекте, уменьшения использования области и максимизации достижимой тактовой частоты на целевом устройстве FPGA.

Настройки

По умолчанию: Откл.

На

Вставьте адаптивные регистры трубопроводов в проект. Для вставки адаптивных трубопроводов в кодер HDL необходимо указать инструмент синтеза.

Прочь

Не вставляйте адаптивные регистры трубопроводов.

Зависимость

При указании этого параметра в меню «Создание кода HDL» > «Targetpane» укажите инструмент синтеза. Если в конструкции имеются множители, укажите инструмент синтеза и целевую частоту (МГц) для адаптивной вставки трубопровода.

Информация командной строки

Свойство: AdaptivePipelining
Текст: символьный вектор
Значение: 'on' | 'off'
По умолчанию: 'off'

Чтобы задать это свойство, используйте hdlset_param или makehdl. Для просмотра значения свойства используйте hdlget_param.

Например, можно использовать AdaptivePipelining при создании кода HDL для symmetric_fir подсистема внутри sfir_fixed с использованием любого из этих методов.

  • Передать свойство в качестве аргумента makehdl функция.

    makehdl('sfir_fixed/symmetric_fir', ... 
                        'AdaptivePipelining','on')
  • При использовании hdlset_param, можно задать параметр в модели, а затем создать код HDL с помощью makehdl.

    hdlset_param('sfir_fixed','AdaptivePipelining','on')
    makehdl('sfir_fixed/symmetric_fir')

См. также

Сохранение задержек в проектировании

Настройки

По умолчанию: Откл.

На

Предотвращение задержек в проектировании распределенных трубопроводов.

Прочь

Не следует препятствовать перемещению распределенных трубопроводов из-за задержек проектирования.

Информация командной строки

Свойство: PreserveDesignDelays
Текст: символьный вектор
Значение: 'on' | 'off'
По умолчанию: 'off'

Чтобы задать это свойство, используйте hdlset_param или makehdl. Для просмотра значения свойства используйте hdlget_param.

Например, можно использовать PreserveDesignDelays при создании кода HDL для symmetric_fir подсистема внутри sfir_fixed с использованием любого из этих методов.

  • Передать свойство в качестве аргумента makehdl функция.

    makehdl('sfir_fixed/symmetric_fir', ... 
            'PreserveDesignDelays','on')
  • При использовании hdlset_param, можно задать параметр в модели, а затем создать код HDL с помощью makehdl.

    hdlset_param('sfir_fixed','PreserveDesignDelays','on')
    makehdl('sfir_fixed/symmetric_fir')

См. также

Сопоставить таблицы поиска с оперативной памятью

Этот параметр используется для отображения таблиц поиска в проекте для блокирования ОЗУ и уменьшения использования области на целевом устройстве FPGA.

Настройки

По умолчанию: Вкл.

На

Сопоставьте таблицы поиска в проекте с оперативной памятью.

Прочь

Не сопоставляйте таблицы подстановки в проекте с оперативной памятью.

Информация командной строки

Свойство: LUTMapToRAM
Текст: символьный вектор
Значение: 'on' | 'off'
По умолчанию: 'on'

Чтобы задать это свойство, используйте hdlset_param или makehdl. Для просмотра значения свойства используйте hdlget_param.

Например, можно использовать LUTMapToRAM при создании кода HDL для symmetric_fir подсистема внутри sfir_fixed с помощью одного из следующих методов:

  • Передать свойство в качестве аргумента makehdl функция.

    makehdl('sfir_fixed/symmetric_fir', ... 
            'LUTMapToRAM','on')
  • При использовании hdlset_param, можно задать параметр в модели, а затем создать код HDL с помощью makehdl.

    hdlset_param('sfir_fixed','LUTMapToRAM','on')
    makehdl('sfir_fixed/symmetric_fir')