Specify Input Types at the Command Line
Define Input Properties by Example at the Command Line
Specifying Properties of Primary Inputs by Example at the Command Line
Specifying Properties of Primary Fixed-Point Inputs by Example at the Command Line
Command-Line Option -args
The codegen
function provides a
command-line option -args for specifying the properties of
primary (entry-point) function inputs as a cell array of example values or types.
The cell array can be a variable or literal array of constant values. Using this
option, you specify the properties of inputs at the same time as you generate code
for the MATLAB® function with codegen.
You can pass the output type from one entry-point function as the input to another. See Pass an Entry-Point Function Output as an Input. For information about specifying cell array inputs, see Specify Cell Array Inputs at the Command Line.
If you have a test function or script that calls the
entry-point MATLAB function with the required types, you can use coder.getArgTypes to determine the
types of the function inputs. coder.getArgTypes returns a cell
array of coder.Type objects that you can pass to
codegen using the -args option. See
Specifying General Properties of Primary Inputs for codegen.
You can also create coder.Type objects interactively by using the
Coder Type Editor. See Create and Edit Input Types by Using the Coder Type Editor.
Rules for Using the -args Option
When using the -args command-line option to define properties
by example, follow these rules:
The order of elements in the cell array must correspond to the order in which inputs appear in the primary function signature. For example, the first element in the cell array defines the properties of the first primary function input.
To generate fewer arguments than those arguments that occur in the MATLAB function, specify properties for only the number of arguments that you want in the generated function.
If the MATLAB function has input arguments, to generate a function that has no input arguments, pass an empty cell array to
-args.For each primary function input whose class is fixed point (
fi), specify the inputnumerictypeandfimathproperties.For each primary function input whose class is
struct, specify the properties of each of its fields in the order that they appear in the structure definition.
Specifying Properties of Primary Inputs by Example at the Command Line
Consider a MATLAB function that adds its two inputs:
function y = mcf(u,v) %#codegen y = u + v;
The following examples show how to specify different properties of the primary
inputs u and v by example at the command line:
Use a literal cell array of constants to specify that both inputs are real scalar doubles:
codegen mcf -args {0,0}Use a literal cell array of constants to specify that input
uis an unsigned 16-bit, 1-by-4 vector and inputvis a scalar double:codegen mcf -args {zeros(1,4,'uint16'),0}Assign sample values to a cell array variable to specify that both inputs are real, unsigned 8-bit integer vectors:
a = uint8([1;2;3;4]) b = uint8([5;6;7;8]) ex = {a,b} codegen mcf -args ex
Specifying Properties of Primary Fixed-Point Inputs by Example at the Command Line
To generate a MEX function or C/C++ code for fixed-point MATLAB code, you must install Fixed-Point Designer™ software.
Consider a MATLAB function that calculates the square root of a fixed-point number:
%#codegen function y = sqrtfi(x) y = sqrt(x);
To specify the properties of the primary fixed-point input x by
example, follow these steps:
Define the
numerictypeproperties forx, for example:T = numerictype('WordLength',32,... 'FractionLength',23,... 'Signed',true);Define the
fimathproperties forx, for example:F = fimath('SumMode','SpecifyPrecision',... 'SumWordLength',32,... 'SumFractionLength',23,... 'ProductMode','SpecifyPrecision',... 'ProductWordLength',32,... 'ProductFractionLength',23);Create a fixed-point variable with the
numerictypeandfimathproperties that you defined, for example:myeg = { fi(4.0,T,F) };Compile the function
sqrtfiusing thecodegencommand, passing the variablemyegas the argument to the-argsoption, for example:codegen sqrtfi -args myeg;
Specify Constant Inputs at the Command Line
If you know that your primary inputs do not change at run time, you can reduce overhead in the generated code by specifying that the primary inputs are constant values. Constant inputs are commonly used for flags that control how an algorithm executes and values that specify the sizes or types of data.
To specify that inputs are constants, use the -args command-line
option with a coder.Constant object. To specify that an input is a
constant with the size, class, complexity, and value of
constant_input, use the following
syntax:
-args {coder.Constant(constant_input)}Calling Functions with Constant Inputs
The code generator compiles constant function inputs into the generated code. In the generated C or C++ code, function signatures do not contain the constant inputs. By default, MEX function signatures contain the constant inputs. When you call a MEX function, you must provide values that match the compile-time values. You can control whether a MEX function signature includes constant inputs and whether the MEX function checks the values that you provide for constant inputs. See Constant Input Checking in MEX Functions.
Specifying a Structure as a Constant Input
Suppose that you define a structure tmp in the MATLAB workspace to specify the dimensions of a
matrix:
tmp = struct('rows', 2, 'cols', 3);The following MATLAB function rowcol accepts a structure input
p to define matrix y:
function y = rowcol(u,p) %#codegen y = zeros(p.rows,p.cols) + u;
The following example shows how to specify that primary input u
is a double scalar variable and primary input p is a constant
structure:
codegen rowcol -args {0,coder.Constant(tmp)}Specify Variable-Size Inputs at the Command Line
Variable-size data is data whose size might change at run time. MATLAB supports bounded and unbounded variable-size data for code generation.
Bounded variable-size data has fixed upper bounds. This data
can be allocated statically on the stack or dynamically on the heap.
Unbounded variable-size data does not have fixed upper
bounds. This data must be allocated on the heap. You can define inputs to have one or
more variable-size dimensions — and specify their upper bounds — using the
-args option and coder.typeof
function:
-args {coder.typeof(example_value, size_vector, variable_dims)}Same class and complexity as
example_valueSame size and upper bounds as
size_vectorVariable dimensions specified by
variable_dims
When you enable dynamic memory allocation, you can specify Inf in
the size vector for dimensions with unknown upper bounds at compile time.
When variable_dims is a scalar, it is applied to
all the dimensions, with the following exceptions:
If the dimension is 1 or 0, which are fixed.
If the dimension is unbounded, which is always variable size.
For more information, see coder.typeof and Generate Code for Variable-Size Arrays.
Specifying a Variable-Size Vector Input
Write a function that computes the average of every
nelements of a vectorAand stores them in a vectorB:function B = nway(A,n) %#codegen % Compute average of every N elements of A and put them in B. coder.extrinsic('error'); if ((mod(numel(A),n) == 0) && (n>=1 && n<=numel(A))) B = ones(1,numel(A)/n); k = 1; for i = 1 : numel(A)/n B(i) = mean(A(k + (0:n-1))); k = k + n; end else B = zeros(1,0); error('n <= 0 or does not divide number of elements evenly'); endSpecify the first input
Aas a vector of double values. Its first dimension stays fixed in size and its second dimension can grow to an upper bound of 100. Specify the second inputnas a double scalar.codegen -report nway -args {coder.typeof(0,[1 100],1),1}As an alternative, assign the
coder.typeofexpression to a MATLAB variable, then pass the variable as an argument to-args:vareg = coder.typeof(0,[1 100],1) codegen -report nway -args {vareg, 0}