Matlab

Validación de argumentos en Matlab

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.

Imagen de ThePixelman en Pixabay

¿Te ha parecido de utilidad el contenido?

Daniel Rodríguez

Share
Published by
Daniel Rodríguez

Recent Posts

Data Lake y Data Warehouse: diferencias, usos y cómo se complementan en la era del dato

En la era del dato, las organizaciones se enfrentan al reto de gestionar volúmenes masivos…

2 días ago

Documentar tu API de Express con TypeScript usando OpenAPI (Swagger)

En la serie Creación de una API REST con Express y TypeScript construimos una API…

4 días ago

Curiosidad: El sesgo de supervivencia, o por qué prestar atención sólo a los que “llegaron” puede engañarte

Durante la Segunda Guerra Mundial, la Fuerza Aérea de Estados Unidos quería reforzar sus aviones…

1 semana ago

Cómo abrir una ventana de Chrome con tamaño y posición específicos desde la línea de comandos en Windows

En muchas situaciones —ya sea para grabar un tutorial, tomar capturas de pantalla profesionales, probar…

2 semanas ago

La Paradoja del Cumpleaños, o por qué no es tan raro compartir fecha de nacimiento

Imagínate en una sala con un grupo de personas, por ejemplo, en una oficina, un…

2 semanas ago

Programador de tareas de Windows: Guía definitiva para automatizar tu trabajo (BAT, PowerShell y Python)

En el trabajo diario con ordenadores, es común encontrarse con tareas repetitivas: realizar copias de…

3 semanas ago

This website uses cookies.