HDL Coder throws error "Minimize algebraic loop occurrences" not supported on atomic subsystem '...' for HDL code generation" when the option is disabled

3 次查看(过去 30 天)
I get the following error from HDL Coder when trying to generate code for a subsystem in a model:
"Minimize algebraic loop occurrences" not supported on atomic subsystem '...' for HDL code generation."
Minimize algebraic loop occurrences does not appear to be enabled for the respective module. The respective model is a resettable subssytem within a "For Each" subssytem. "HDL Code Advisor -> Check for algebraic loops" finds no algebraic loops.
I am struggling with understanding what is causing the error. Perhaps it is linked to the use of a resettable subsystem, which are always atomic, and thus may require some confguration. Is there perhaps an option I have missed?

采纳的回答

Swaraj
Swaraj 2024-1-2
Hi Eirik,
When you generate HDL code for a Subsystem that is not at the top level of the model, the HDL Coder converts the Subsystem to a model reference. A referenced model is treated similar to an Atomic Subsystem.
The "Minimize algebraic loop occurrences" configuration parameter tries to eliminate artificial algebraic loops from a model that involves the current referenced model. Please make sure that you disable the "Minimize algebraic loop occurrences" configuration parameter for all the dependent subsystems since it is not supported for the atomic subsystem. This error signifies that the issue is occurring as this parameter is enabled.
Please share the model here to debug the issue further.
Hope it helps!

更多回答(1 个)

Eirik Nordeng
Eirik Nordeng 2024-1-4
I found the culprit. A submodule further down in the hierarchy had the option "Minimize algebraic loop occurrences" enabled, but it was reported for a module at a higher level in the hierarchy. Once I disabled the option for the respective module, the error disappeared.

产品


版本

R2021b

Community Treasure Hunt

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

Start Hunting!

Translated by