Function Argument Validation - MATLAB & Simulink (2024)

Function Argument Validation

Function argument validation is a way to declare specific restrictions on function arguments. Using argument validation you can constrain the class, size, and other aspects of arguments without writing code in the body of the function to perform these tests.

Function argument validation is declarative, which enables MATLAB® desktop tools to extract information about a function by inspection of specific code blocks. By declaring requirements for arguments, you can eliminate cumbersome argument-checking code and improve the readability, robustness, and maintainability of your code.

The function argument validation syntax simplifies the process of defining optional, repeating, and name-value arguments. The syntax also enables you to define default values in a consistent way.

Where to Use Argument Validation

The use of function argument validation is optional in function definitions. Argument validation is most useful in functions that can be called by any code and where validity of the arguments must be determined before executing the function code. Functions that are designed for use by others can benefit from the appropriate level of restriction on arguments and the opportunity to return specific error messages based on the argument validation checks.

Where Validation Is Not Needed

In local and private functions, and in private or protected methods, the caller is aware of input requirements, so these types of functions can be called with valid arguments.

Where Validation Is Not Allowed

You cannot use argument validation syntax in nested functions, abstract methods, or handle class destructor methods. For more information on argument validation in methods, see Method Syntax.

arguments Block Syntax

Functions define argument validation in optional code blocks that are delimited by the keywords arguments and end. If used, an arguments block must start before the first executable line of the function.

You can use multiple arguments blocks in a function, but all blocks must occur before any code that is not part of an arguments block.

The highlighted area in the following code shows the syntax for input argument validation.

Function Argument Validation- MATLAB & Simulink (1)

The function argument declaration can include any of these kinds of restrictions:

  • Size — The length of each dimension, enclosed in parentheses

  • Class — The name of a single MATLAB class

  • Functions — A comma-separated list of validation functions, enclosed in braces

You can also define a default value for the input argument in the function validation declaration for that argument. The default value must satisfy the declared restrictions for that argument.

Validate Size and Class

Size

Validation size is the dimensions of the argument, specified with nonnegative integer numbers or colons (:). A colon indicates that any length is allowed in that dimension. You cannot use expressions for dimensions. The value assigned to the argument in the function call must be compatible with the specified size, or MATLAB throws an error.

MATLAB indexed assignment rules apply to size specifications. For example, a 1-by-1 value is compatible with the size specified as (5,3) because MATLAB applies scalar expansion. Also, MATLAB row-column conversion applies so that a size specified as (1,:) can accept a size of 1-by-n and n-by-1.

Here are some examples:

  • (1,1) — The input must be exactly 1-by-1.

  • (3,:) — The first dimension must be 3, and second dimension can be any value.

If you do not specify a size, then any size is allowed unless restricted by validation functions.

Class

Validation class is the name of a single class. The value assigned to the function input must be of the specified class or convertible to the specified class. Use any MATLAB class or externally defined class that is supported by MATLAB, except Java, COM classes, and MATLAB class definitions that do not use the classdef keyword (classes defined before MATLAB software Version 7.6).

Here are some examples:

  • char — Input must be of class char or a value that MATLAB can convert to a char, such as string.

  • double — Input can be a numeric value of any precision.

  • cell — Input must be a cell array.

  • A user-defined class

If you do not specify a class, then any class is allowed unless restricted by validation functions.

Example: Basic Argument Validation

This arguments block specifies the size and class of the three inputs.

function out = myFunction(A, B, C) arguments A (1,1) string  B (1,:) double C (2,2) cell end % Function code ...end

In this function, the variables must meet these validation requirements:

Validation Functions

A validation function is a MATLAB function that throws an error if certain requirements are not satisfied by the argument value. Validation functions do not return values and, unlike class and size, cannot change the value of the arguments they are validating.

During the validation process, MATLAB passes the argument value to each validation function listed for that argument. The value passed to the validation functions is the result of any conversion made by the class and size specifications. MATLAB calls each function from left to right and throws the first error encountered.

For a table of predefined validation functions, see Argument Validation Functions.

Example: Set Specific Restrictions Using Validation Functions

Validation functions can restrict arguments in more specific ways. You can use predefined validation functions for many common kinds of validation, and you can define your own validation function to satisfy specific requirements.

For example, this function specifies the following validations using mustBeNumeric, mustBeReal, mustBeMember, and the local function mustBeEqualSize.

  • Input x must be a real, numeric row vector of any length.

  • Input v must be a real, numeric row vector the same size as x.

  • Input method must be a character vector that is one of the three allowed choices. Because method specifies a default value, this argument is optional.

function myInterp(x,v,method) arguments x (1,:) {mustBeNumeric,mustBeReal} v (1,:) {mustBeNumeric,mustBeReal,mustBeEqualSize(v,x)} method (1,:) char {mustBeMember(method,{'linear','cubic','spline'})} = 'linear' end % Function code ....end% Custom validation functionfunction mustBeEqualSize(a,b) % Test for equal size if ~isequal(size(a),size(b)) eid = 'Size:notEqual'; msg = 'Size of first input must equal size of second input.'; error(eid,msg) endend

Avoid using function argument validation within custom validation functions. For more information about defining validation functions and a list of predefined validation functions, see Argument Validation Functions.

Default Value

An input argument default value can be any constant or expression that satisfies the size, class, and validation function requirements. Specifying a default value in an argument declaration makes the argument optional. MATLAB uses the default value when the argument is not included in the function call. Default value expressions are evaluated each time the default is used.

Note

Because MATLAB validates the default value only when the function is called without a value for the argument, an invalid default value causes an error only when the function is called without that argument.

Optional arguments must be positioned after required arguments in the function signature and in the arguments block. For more information on optional arguments, see Validate Required and Optional Positional Arguments.

Conversion to Declared Class and Size

Both class validation and size validation can change the value of an argument. Here are some examples of conversions that MATLAB can perform.

To satisfy class restrictions:

  • A char value can be converted to a string value.

  • A single value can be converted to a double.

To satisfy size restrictions:

  • Scalar expansion can change input size from scalar to nonscalar.

  • A column vector can be converted to a row vector.

As a result, the validated value in the function body can be different from the value passed when calling the function. For more information on class conversion, see Implicit Class Conversion. To avoid class and size conversions during validation, use argument validation functions instead. For more information, see Use Validation Functions to Avoid Unwanted Class and Size Conversions.

Example: Value Conversion

The following function illustrates how inputs can be converted to match the classes specified in the arguments block. The SpeedEnum class is an enumeration class created to define the values allowed for the third argument.

function forwardSpeed(a,b,c) arguments a double b char c SpeedEnum end % Function code disp(class(a)) disp(class(b)) disp(class(c))end

Here is the enumeration class.

classdef SpeedEnum < int32 enumeration Full (100) Half (50) Stop (0) endend

This call to the function uses input values that MATLAB can convert to the declared types. The actual argument types within the function are displayed as output.

forwardSpeed(int8(4),"A string",'full')
doublecharSpeedEnum

Output Argument Validation

Starting in R2022b, argument validation can be used on output arguments. Similar to input arguments, you can validate the class and size of output arguments and also apply validation functions. However, you cannot specify default values for output arguments or refer to previously declared arguments. Output argument validation is always optional. Adding output argument validation helps improve code readability and also maintains consistent output in code that might change over time.

Separate arguments blocks must be used for validating input and output arguments. Define the type of arguments block (Input) or (Output) after the arguments statement. If both (Input) and (Output) argument blocks are used, the (Output) block must follow the (Input) block. then If no type is specified, then MATLAB assumes the block contains input arguments.

For more information, see arguments.

Example: Validate Output Arguments

Starting in R2022b, argument validation can be used on output arguments.

For example, this function validates the size and class of three input arguments and one output argument using separate arguments blocks. Note that the (Input) block must precede the (Output) block.

function out = myFunction(A, B, C) arguments (Input) A (1,1) string  B (1,:) double C (2,2) cell end arguments (Output) out (1,:) double end % Function code ...end

Kinds of Arguments

Function argument validation can declare four kinds of arguments. Functions can define any of these kinds of arguments, but the arguments must be defined in the following order:

Argument TypeAdditional Information

1. Required positional arguments

Validate Required and Optional Positional Arguments

2. Optional positional arguments

3. Repeating positional arguments

Validate Repeating Arguments

4. Optional name-value arguments

Validate Name-Value Arguments

Order of Argument Validation

When a function is called, MATLAB validates the arguments in the order they are declared in the arguments block, from top to bottom. Each argument is fully validated before the next argument is validated. Therefore, any reference to a previously declared argument uses values that have been validated. Functions throw an error as a result of the first validation failure.

Validated values can be different from the original values passed as inputs when the function is called. For example, this function declares the inputs as class uint32 values. The third input declaration assigns a default value equal to the product of the first two inputs.

function c = f(a, b,c) arguments a uint32 b uint32 c uint32 = a.* b end % Function code ...end

Calling the function with inputs that are a different numeric class (for example, double) results in a conversion to uint32.

c = f(1.8,1.5)

Because the optional argument c is not specified in the function call, MATLAB evaluates the default value and assigns it to c after converting a and b to uint32 values. In this case, the conversion results in a value of 2 for both inputs. Therefore, the product of a times b is four.

c = uint32 4

If you specify a value for the third input, then the function assigns a value to c and does not evaluate the default value expression.

c = f(1.8,1.5,25)
c = uint32 25

Restrictions on Variable and Function Access

arguments blocks exist in the function's workspace. Any packages, classes, or functions added to the scope of the function using the import command are added to the scope of the arguments block.

The only variables visible to validator functions and default value expressions are the input variables already declared. In this function, the default value of c is derived from a and b.

function c = f(a,b,c) arguments a uint32 b uint32 c uint32 = a * b end % Function code ...end

However, you cannot refer to input variables not yet declared in an arguments block. For example, using this declaration for argument a in the previous function is not valid because b and c have not been declared yet.

arguments a uint32 = b * c b uint32 c uint32end

Argument validation expressions can reference only previously declared, and therefore validated, arguments. Validation functions and default values for name-value arguments cannot access other name-value arguments.

Limitations on Functions in arguments Block

Any references to previously declared arguments must be visible in the text of validation functions and default values. To ensure code transparency, do not use functions that interact with the function workspace. Specifically, do not use nested functions or any of the functions listed in the following table in the arguments block.

assigninbuiltinclear
dbstackevalevalc
evalinexistfeval
inputinputnameload
narginnarginchknargoutchk
savewhoswho

These restrictions apply only within the arguments block and do not apply to variables or functions in the body of the function.

Debugging Arguments Blocks

While debugging inside of an arguments block the workspace is read only. This means that it is possible to inspect the workspace and view the values assigned to variables. However, it is not possible to create new variables or change the values assigned to existing variables while the workspace is read only. Once the debugger is outside of the arguments block it will once again be possible to create or edit variables.

See Also

namedargs2cell | arguments

Related Topics

  • Argument Definitions
  • Validate Required and Optional Positional Arguments
  • Validate Repeating Arguments
  • Validate Name-Value Arguments
  • Argument Validation Functions
  • Validate Property Values

MATLAB Command

You clicked a link that corresponds to this MATLAB command:

 

Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.

Function Argument Validation- MATLAB & Simulink (2)

Select a Web Site

Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .

You can also select a web site from the following list:

Americas

  • América Latina (Español)
  • Canada (English)
  • United States (English)

Europe

  • Belgium (English)
  • Denmark (English)
  • Deutschland (Deutsch)
  • España (Español)
  • Finland (English)
  • France (Français)
  • Ireland (English)
  • Italia (Italiano)
  • Luxembourg (English)
  • Netherlands (English)
  • Norway (English)
  • Österreich (Deutsch)
  • Portugal (English)
  • Sweden (English)
  • Switzerland
    • Deutsch
    • English
    • Français
  • United Kingdom (English)

Asia Pacific

  • Australia (English)
  • India (English)
  • New Zealand (English)
  • 中国
  • 日本 (日本語)
  • 한국 (한국어)

Contact your local office

Function Argument Validation
- MATLAB & Simulink (2024)

FAQs

Function Argument Validation - MATLAB & Simulink? ›

Function argument validation is a way to declare specific restrictions on function arguments. Using argument validation you can constrain the class, size, and other aspects of arguments without writing code in the body of the function to perform these tests.

What is an example of a function argument in MATLAB? ›

For example, if you create a function named myplot with repeating arguments X , Y , and style , the function accepts multiple sets of these three arguments, such as myplot(x1,y1,style1,x2,y2,style2) . MATLAB creates a cell array that contains all the values passed in for that argument.

What is the difference between MATLAB function and Simulink function? ›

You find it easier to model custom functionality by using a MATLAB function than by using a Simulink block diagram. The custom functionality that you want to model does not include continuous or discrete dynamic states. To model dynamic states, use S-functions. See Author Blocks Using MATLAB S-Functions.

Can you pass a function as an argument in MATLAB? ›

You can use function handles as input arguments to other functions, which are called function functions. These functions evaluate mathematical expressions over a range of values. Typical function functions include integral , quad2d , fzero , and fminbnd .

How do you make a function argument optional in MATLAB? ›

MATLAB lets you ignore arguments by passing a tilde character ( ~ ) in place of the argument. You can define a function that ignores unused positional arguments by adding a tilde character ( ~ ) in the arguments block corresponding to the position of the argument in the function signature.

What are the three types of function arguments? ›

Types of Function Arguments in Python
  • Default Arguments.
  • Keyword Arguments.
  • Arbitrary Arguments.
  • Required Arguments.
Apr 19, 2024

What is meant by function argument? ›

In mathematics, an argument of a function is a value provided to obtain the function's result. It is also called an independent variable. For example, the binary function has two arguments, and , in an ordered pair . The hypergeometric function is an example of a four-argument function.

Why use Simulink instead of MATLAB? ›

Another factor to consider when choosing between Simulink blocks and MATLAB code is the speed and efficiency of your system. Simulink blocks can be faster and more efficient for some tasks, such as prototyping, testing, and debugging.

What is the purpose of Simulink in MATLAB? ›

Simulate. Deploy. Simulink is a block diagram environment used to design systems with multidomain models, simulate before moving to hardware, and deploy without writing code.

What can be passed as function arguments? ›

Information can be passed into functions as arguments. Arguments are specified after the function name, inside the parentheses. You can add as many arguments as you want, just separate them with a comma.

How do you declare a function passing argument? ›

Passing arguments by value

When an argument is passed by value, the C function receives a copy of the actual value of the argument. To specify that the argument should always be passed by value, use the keyword ByVal preceding the parameter declaration for that argument in the Declare statement for the C function.

Should you pass a function as an argument? ›

Functions are data, and therefore can be passed around just like other values. This means a function can be passed to another function as an argument. This allows the function being called to use the function argument to carry out its action. This turns out to be extremely useful.

What are function arguments in MATLAB? ›

An input argument default value can be any constant or expression that satisfies the size, class, and validation function requirements. Specifying a default value in an argument declaration makes the argument optional. MATLAB uses the default value when the argument is not included in the function call.

How do you overload a function in MATLAB? ›

To overload a MATLAB function: Define a method with the same name as the function you want to overload. Ensure that the method argument list accepts an object of the class, which MATLAB uses to determine which version to call. Perform the necessary steps in the method to implement the function.

Does MATLAB have null? ›

Different machines and releases of MATLAB® can produce different singular vectors that are still numerically accurate, so values calculated using null may differ. The rational basis for the null space null(A,"rational") is obtained from the reduced row echelon form of A , as calculated by rref .

What is a function handle as an argument in MATLAB? ›

A function handle is a MATLAB® data type that represents a function. A typical use of function handles is to pass a function to another function. For example, you can use function handles as input arguments to functions that evaluate mathematical expressions over a range of values.

What is a variable argument in MATLAB function? ›

The varargin argument is a cell array that contains the function inputs, where each input is in its own cell. Create a function in a file named plotWithTitle. m that accepts a variable number of paired (x,y) inputs for the plot function and an optional title.

How to write a function in MATLAB example? ›

Syntax for Function Definition
  1. function myOutput = myFunction(x) If your function returns more than one output, enclose the output names in square brackets.
  2. function [one,two,three] = myFunction(x) If there is no output, you can omit it.
  3. function myFunction(x) Or you can use empty square brackets.

What is the argument of a function in MATLAB quizlet? ›

What are the "arguments" of a function? They are the input values passed to the function so that it can perform its computation. These values appear in parentheses after the function name. In MATLAB several functions default to along the first non-singleton dimension, if you do not provide a dimension argument.

Top Articles
Federal aid addresses discrimination for thousands of farmers after years of delay - Investigate Midwest
New leads revealed in cold case of missing Tennessee mom and daughter
What Is Single Sign-on (SSO)? Meaning and How It Works? | Fortinet
3 Tick Granite Osrs
Exclusive: Baby Alien Fan Bus Leaked - Get the Inside Scoop! - Nick Lachey
Evita Role Wsj Crossword Clue
Horned Stone Skull Cozy Grove
Boat Jumping Female Otezla Commercial Actress
Garrick Joker'' Hastings Sentenced
Craigslist Dog Kennels For Sale
What to do if your rotary tiller won't start – Oleomac
Scholarships | New Mexico State University
2015 Honda Fit EX-L for sale - Seattle, WA - craigslist
Connect U Of M Dearborn
Samantha Lyne Wikipedia
Dr Adj Redist Cadv Prin Amex Charge
Khiara Keating: Manchester City and England goalkeeper convinced WSL silverware is on the horizon
Jalapeno Grill Ponca City Menu
The best firm mattress 2024, approved by sleep experts
Morristown Daily Record Obituary
Self-Service ATMs: Accessibility, Limits, & Features
Tu Pulga Online Utah
Japanese Mushrooms: 10 Popular Varieties and Simple Recipes - Japan Travel Guide MATCHA
Jcp Meevo Com
Sofia the baddie dog
Wonder Film Wiki
Summoners War Update Notes
Experity Installer
Sam's Club Gas Price Hilliard
Account Now Login In
La Qua Brothers Funeral Home
After Transmigrating, The Fat Wife Made A Comeback! Chapter 2209 – Chapter 2209: Love at First Sight - Novel Cool
Miss America Voy Board
Human Unitec International Inc (HMNU) Stock Price History Chart & Technical Analysis Graph - TipRanks.com
Academic important dates - University of Victoria
Is The Nun Based On a True Story?
Skip The Games Grand Rapids Mi
The All-New MyUMobile App - Support | U Mobile
Author's Purpose And Viewpoint In The Dark Game Part 3
888-822-3743
Chase Bank Zip Code
Lady Nagant Funko Pop
Citymd West 146Th Urgent Care - Nyc Photos
Aloha Kitchen Florence Menu
New Starfield Deep-Dive Reveals How Shattered Space DLC Will Finally Fix The Game's Biggest Combat Flaw
Dolce Luna Italian Restaurant & Pizzeria
Appsanywhere Mst
BYU Football: Instant Observations From Blowout Win At Wyoming
Psalm 46 New International Version
Law Students
Haunted Mansion Showtimes Near The Grand 14 - Ambassador
Latest Posts
Article information

Author: Maia Crooks Jr

Last Updated:

Views: 6308

Rating: 4.2 / 5 (43 voted)

Reviews: 82% of readers found this page helpful

Author information

Name: Maia Crooks Jr

Birthday: 1997-09-21

Address: 93119 Joseph Street, Peggyfurt, NC 11582

Phone: +2983088926881

Job: Principal Design Liaison

Hobby: Web surfing, Skiing, role-playing games, Sketching, Polo, Sewing, Genealogy

Introduction: My name is Maia Crooks Jr, I am a homely, joyous, shiny, successful, hilarious, thoughtful, joyous person who loves writing and wants to share my knowledge and understanding with you.