HDL Code Generation Error

54 次查看(过去 30 天)
How to solve this error?
Signals of type 'Double' will not generate synthesizable HDL. Consider enabling Native Floating-Point mode and retyping all 'Double' typed signals to 'Single' to generate synthesizable code

采纳的回答

Kiran Kintali
Kiran Kintali 2020-10-6
编辑:Stefanie Schwarz 2021-10-21

更多回答(1 个)

stozaki
stozaki 2020-10-6
Hello kameshwar,
Which MATLAB version are you using?
The block type that supports code generation of double floating point data types depends on the MATLAB version. It looks like your model contains blocks that don't support HDL code generation for "double" data types.
Please see the release notes and support block table for details.
stozaki
  6 个评论
stozaki
stozaki 2020-10-7
编辑:stozaki 2020-10-7
Hi
Your model has some problems.
1. The Chart block cannot generate code from the model root level. Wrap in the subsystem.
2. The model configuration parameters are not settings for HDL code generation. Check the hdlsetup command for details.
3. The output of the Signal Generator is "double". Since the input data type of the Chart block is "Inherit: Same as Simulink",code cannot be generated because it is a double type. Use the Data Type Conversion block to set the Signal Generator output to boolean. In Chart's action language, immediate values (eg 1 and 0) are considered double type.
your model
modified model
I have attached the modified model. In this model, if the subsystem is the target of code generation, code generation can be performed without error.
makehdl('Pattern_Detector_modified_19a/Subsystem');
stozaki

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 Code Generation 的更多信息

标签

产品


版本

R2019a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by