Clear Filters
Clear Filters

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

2 views (last 30 days)
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?
  1 Comment
Shivang
Shivang on 27 Dec 2023
Hi Eirik,
Is "Minimize algebraic loop occurrences" disabled for the 'For Each' subsystem?
Also it would be great if you could share the model.

Sign in to comment.

Accepted Answer

Swaraj
Swaraj on 2 Jan 2024
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!

More Answers (1)

Eirik Nordeng
Eirik Nordeng on 4 Jan 2024
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.

Products


Release

R2021b

Community Treasure Hunt

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

Start Hunting!