MATLAB Language
Funciones
Buscar..
Ejemplo de base
La siguiente secuencia de comandos de MATLAB muestra cómo definir y llamar a una función básica:
miFun.m :
function [out1] = myFun(arg0, arg1)
out1 = arg0 + arg1;
end
terminal :
>> res = myFun(10, 20)
res =
30
Salidas multiples
La siguiente secuencia de comandos de MATLAB muestra cómo devolver múltiples salidas en una sola función:
miFun.m :
function [out1, out2, out3] = myFun(arg0, arg1)
out1 = arg0 + arg1;
out2 = arg0 * arg1;
out3 = arg0 - arg1;
end
terminal :
>> [res1, res2, res3] = myFun(10, 20)
res1 =
30
res2 =
200
res3 =
-10
Sin embargo, MATLAB devolverá solo el primer valor cuando se asigne a una sola variable
>> res = myFun(10, 20)
res =
30
El siguiente ejemplo muestra cómo obtener una salida específica
>> [~, res] = myFun(10, 20)
res =
200
nargin
En el cuerpo de una función, nargin
y nargout
indican respectivamente el número real de entrada y salida suministrados en la llamada.
Por ejemplo, podemos controlar la ejecución de una función en función del número de entradas proporcionadas.
myVector.m :
function [res] = myVector(a, b, c)
% Roughly emulates the colon operator
switch nargin
case 1
res = [0:a];
case 2
res = [a:b];
case 3
res = [a:b:c];
otherwise
error('Wrong number of params');
end
end
terminal:
>> myVector(10)
ans =
0 1 2 3 4 5 6 7 8 9 10
>> myVector(10, 20)
ans =
10 11 12 13 14 15 16 17 18 19 20
>> myVector(10, 2, 20)
ans =
10 12 14 16 18 20
De manera similar, podemos controlar la ejecución de una función en función del número de parámetros de salida.
myIntegerDivision
function [qt, rm] = myIntegerDivision(a, b)
qt = floor(a / b);
if nargout == 2
rm = rem(a, b);
end
end
terminal :
>> q = myIntegerDivision(10, 7)
q = 1
>> [q, r] = myIntegerDivision(10, 7)
q = 1
r = 3