Unnecessary copying in Matlab Coder generated C code

1 次查看(过去 30 天)
Hi! I generated C code with Matlab Coder can I realize that there are a lot of such unnecessary copying. What can I do to avoid that?
for (i0 = 0; i0 < 153; i0++) {
dv42[i0] = dv74[i0];
dv43[i0] = dv75[i0];
}
...
for (i0 = 0; i0 < 153; i0++) {
dv74[i0] = dv42[i0];
dv75[i0] = dv43[i0];
}
...
for (i0 = 0; i0 < 153; i0++) {
dv42[i0] = dv74[i0];
dv43[i0] = dv75[i0];
}
  1 个评论
Ryan Livingston
Ryan Livingston 2013-8-1
编辑:Ryan Livingston 2013-8-1
If you post a small example of MATLAB code which produces this, we may be able to give some suggestions.

请先登录,再进行评论。

回答(1 个)

Jane Jean
Jane Jean 2013-8-1
I have a structure in Matlab similar to what is below and right before the subfunction is called, the generated C code is doing the unnecessary copying instead of taking 'a' directly as an input of the subfunction.
function output = main_function(a)
...
a = [1;2;3];
...
output_sub = subfunction(a)
  2 个评论
Walter Roberson
Walter Roberson 2013-8-1
The copying would be appropriate if the subfunction modifies its input, which we cannot determine from what you show.
Why are you passing "a" into main_function and also assigning a value to it?
Jane Jean
Jane Jean 2013-8-1
'a' is first used somewhere before it is reassigned with another value. But right before it is fed into 'subfunction', 'a' is copied to another temporary variable, e.g. 'dv74' then the latter is copied to 'dv42' and 'dv42' is copied back to 'dv74' and 'dv74' is again copied to 'dv42' and finally subfunction takes 'dv42' as input. What can I do to avoid this unnecessary copying?

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 MATLAB Coder 的更多信息

产品

Community Treasure Hunt

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

Start Hunting!

Translated by