coder.varsize
Resolve size incompatibility errors and declare upper bounds
Syntax
Description
coder.varsize( instructs
        the code generator to allow the dimensions of variables
          varName1,...,varNameN)varName1,...,varNameN to change size at run time. The code generator
        attempts to determine the upper bound for each dimension of each variable. Dimensions with
        size 1, also known as singleton dimensions, remain
        fixed size. To instruct the code generator to allow singleton dimensions to vary in size,
        you must specify variable-size upper bounds by using the upperBounds and
          variableSize arguments. For more information about defining
        variable-size data in MATLAB® code for code generation, see Define Variable-Size Data for Code Generation.
coder.varsize(
        specifies an upper bound for each dimension of the variables
          varName1,...,varNameN,upperBounds)varName1,...,varNameN. Singleton dimensions remain fixed size.
coder.varsize(
        specifies, for each upper bound specified in varName1,...,varNameN,upperBounds,variableSize)upperBounds, whether that
        upper bound is fixed size or variable size. To instruct the code generator to allow a
        singleton dimension to vary in size, explicitly specify an variable-size upper bound.
Examples
Input Arguments
Limitations
- Code generation does not support using - coder.varsizewith global variables, MATLAB classes, and MATLAB class properties.
- Code generation does not support using - coder.varsizewith strings. See Resolve Error: coder.varsize Not Supported for Strings (MATLAB Coder).
- The - coder.varsizedirective instructs the code generator to allow the size of a variable to change. It does not change the size of the variable. Consider this code snippet:- ... x = 7; coder.varsize("x", [1 5]); disp(size(x)); ... - After the - coder.varsizedirective,- xis still a 1-by-1 array. You cannot assign a value to an element beyond the current size of- x. For example, this code produces a run-time error because the index 3 exceeds the dimensions of- x.- ... x = 7; coder.varsize("x", [1,5]); x(3) = 1; ... 
- You cannot call - coder.varsizeon function input arguments. Instead:- If the function is an entry-point function, specify that an input argument has a variable size by using - coder.typeofat the command line. Alternatively, specify that an entry-point function input argument has a variable size by using the Define Input Types step of the MATLAB Coder™ app.
- If the function is not an entry-point function, use - coder.varsizein the calling function with the variable that is the input to the called function.
 
- For sparse matrices, - coder.varsizetreats variable-size dimensions as unbounded.
- To use - coder.varsizewith a cell array, the cell array must be homogeneous. See Cell Array Limitations for Code Generation.
Tips
- In many cases, the code generator can determine that the size of a variable can change at run time. In such cases, you do not need to use the - coder.varsizedirective. Use- coder.varizeonly if the code generator produces a size overflow error or if you want to specify upper bounds.
- To declare variable-size output variables in MATLAB Function blocks, use the Symbols pane and the Property Inspector. If you provide upper bounds in a - coder.varsizedeclaration, the upper bounds must match the upper bounds in the Property Inspector. See Declare Variable-Size MATLAB Function Block Variables.
- If you do not specify upper bounds in the - coder.varsizedeclaration and the code generator is unable to infer upper bounds, the generated code uses dynamic memory allocation. Dynamic memory allocation can reduce the speed of the generated code. In some cases, you can avoid dynamic memory allocation by specifying upper bounds by using the- upperBoundsargument.
- If you use - coder.varsizeto specify that the upper bound of a dimension is 1, the dimension has a fixed size of 1 by default. To specify that the dimension can be 0 or 1, set the corresponding element of the- variableSizevector to- true. For example, this directive specifies that the first dimension of- xhas a fixed size of 1 and the other dimensions have a variable size of- 5.- coder.varsize('x',[1 5 5])- In contrast, this code specifies that the first dimension of - xis variable size with an upper bound of 1.- coder.varsize("x",[1 5 5],[true true true])
- When you use the output of an extrinsic function, the code generator is unable to determine the size of this output at code generation time. Use - coder.varsizeto instruct the code generator to treat the variable you use to store this output as variable size. See Use Variable-Size Output of Extrinsic Function at Run Time.
- Under certain circumstances, you can force a cell array to be homogeneous by using - coder.varsize. See Control Whether a Cell Array Is Variable-Size.
Version History
Introduced in R2011a