State Flow C Action Language Bitwise Operators
5 次查看(过去 30 天)
显示 更早的评论
I am trying to use bitwise operators to AND as well as OR an uint value with an int value in stateflow with C action language. I need to use 32 bit values but the results appear to be incorrect with 32 bit values, while 8-, 16-, and 64- bit values all seem to give correct results. Image below shows the stateflow chart and correct results using 16 bit values vs incorrect results with 32 bit values. Am I missing something? Or is this a known issue?
采纳的回答
Yash
2024-5-6
编辑:Yash
2024-5-7
Hi Tyler,
The incorrect results in 32 bit are obtained due to saturation on integer overflow. Upon executing the model, you should notice two warnings in the Diagnostic Viewer, which are as follows:
- "Chart containing object '...' has both C-bit operations and saturation on integer overflow enabled. To avoid unexpected results when bitwise operations produce an overflow, disable saturation on integer overflows. For more information, click here."
- "Saturate on overflow detected."
Both warnings highlight the same concern regarding saturation on integer overflow. To resolve this, kindly proceed with the following steps:
- Open the stateflow chart.
- Right-click on the blank area within the chart and choose "Properties...".
- Uncheck the "Saturate on integer overflow" option.
- Run the model again, you should get the correct output now.
Hope this helps.
0 个评论
更多回答(0 个)
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!