Validación de argumentos en Matlab

Publicado el 21 septiembre 2022 por Daniel Rodríguez @analyticslane

Hasta hace poco no existía en Matlab una forma automatizada para comprobar que los parámetros de una función son los correctos. La única manera de hacer esto era mediante la inclusión de código con comprobaciones específicas para ello, como puede ser el tipo de dato, las dimensiones de la matriz o los valores. Tampoco existía una manera de definir un valor por defecto para los parámetros. Esto cambió con la versión 2019b donde se introdujo el entorno arguments para configurar estas tareas. Dentro de este entorno se puede saber cuáles son los tipos de datos válidos, el tamaño de las matrices, validar los valores y asignar un valor por defecto. Todo esto facilita la validación de argumentos en Matlab, permitiendo esto se puede hacer definiendo los tipos de datos como en otros lenguajes.

Uso de arguments en una función de Matlab

A partir de la versión 2019b en el cuerpo de las funciones de Matlab se puede incluir un nuevo bloque usando la palabra reservada arguments. Al igual que el resto de los bloques, este finalizará al encontrarse con el primer end.

La sintaxis del bloque arguments es algo diferente a los utilizados habitualmente. En este bloque se debe incluir en cada línea el nombre de los parámetros de la función seguido del tipo de dato. Además, opcionalmente se puede incluir las dimensiones permitidas para la entrada (antes de la definición del tipo), un conjunto de validadores (entre corchetes depuesto del tipo de dato) y el valor por defecto al final de la línea. Siendo la sintaxis básica la siguiente.

arguments
    par1 (dimensions) dataType {validators} = defaultValue
    ...
    parN
end

Ejemplo de validación de argumentos en Matlab

Posiblemente la mejor forma para comprender cómo es la validación de argumentos en Matlab con arguments sea estudiando un ejemplo. Uno como la siguiente función.

function [out, par3] = testFunction(par1, par2, par3)

arguments
    par1 (1, 1) double {mustBeNonnegative}
    par2 (1, 2) double
    par3 string = 'No value'
end

out = par1 .* par2;

fprintf('La clase de %i es %s\n', par1, class(par1));
fprintf('La clase de (%d, %d) es %s\n', par2, class(par2));
fprintf('La clase de "%s" es %s\n', par3, class(par3));

end

En este código se ha definido una función testFunction() que únicamente multiplica los dos primeros parámetros. El primero, 'par1' es necesariamente un escalar real positivo, mientras que el segundo es un vector de 1 por 2 también real. Adicionalmente la función también puede recibir un tercer parámetro que solamente puede ser una cadena de texto y tiene como valor por defecto 'No value'.

Ahora si los valores son correctos, la función trabaja correctamente tal cómo se muestra a continuación.

>> [out, par3] = testFunction(3, [1, 2])
La clase de 3 es double
La clase de (1, 2) es double
La clase de "No value" es string

out =

     3     6


par3 = 

    "No value"

En donde se puede ver que el segundo parámetro devuelve la cadena por defecto.

Pero, en el caso de que no sean correctos se producirá se producirá un fallo al llamarla. Por ejemplo, si el primer parámetro es negativo.

>> [out, par3] = testFunction(-3, [1, 2])
Error using testFunction
Invalid argument at position 1. Value must be nonnegative.

Este error se produce porque mediante la opción {mustBeNonnegative} obliga a que este parámetro sea solamente positivo. Lo que no sucede en el ejemplo anterior. Existen diferentes tipos de validadores que se pueden ver en la documentación

Otra posible causa de fallo sería pasar como segundo parámetro vector que no sea de 1 por 2.

>> [out, par3] = testFunction(3, [1, 2, 3])
Error using testFunction
Invalid argument at position 2. Value must be a vector with 2 elements.

Conclusiones

La validación de los argumentos en las funciones de Matlab era algo bastante tedioso debido a que no existía una opción para su configuración. Afortunadamente con la introducción de arguments en la versión 2019b esto se ha vuelto mucho más fácil debido a que ahora es simplemente una opción, como sucede en otros lenguajes.