Matlab 1
Matlab 1
Matlab 1
Indice general
1. Primera sesion 3
1.1. Operaciones basicas . . . . . . . . . . . . . . . . . . . . . . . 3
1.2. Las matrices en MATLAB . . . . . . . . . . . . . . . . . . . . 6
1.3. Ejercicios . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
2. Segunda sesion 15
2.1. Gracas sencillas en MATLAB . . . . . . . . . . . . . . . . . 15
2.2. Programacion en MATLAB: Scripts . . . . . . . . . . . . . . 21
2.3. Ejercicios . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
3. Tercera sesion 27
3.1. Programacion en MATLAB: las functions . . . . . . . . . . . 27
3.2. Ejercicios . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
4. Cuarta sesion 34
4.1. Bucles for... end . . . . . . . . . . . . . . . . . . . . . . . . . 34
4.2. Bucles if... end y while... end . . . . . . . . . . . . . . . . . . 37
4.3. Ejercicios . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
A. Soluciones a los ejercicios 40
A.1. Primera sesion . . . . . . . . . . . . . . . . . . . . . . . . . . 40
A.2. Segunda sesion . . . . . . . . . . . . . . . . . . . . . . . . . . 42
A.3. Tercera sesion . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
A.4. Cuarta sesion . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
1
Prologo
Presentamos aqu un guion detallado de las practicas de MATLAB que
han formado parte, desde su puesta en marcha en el curso 2003/2004, de
la asignatura Fundamentos Matematicos de la Ingeniera de primer curso
de Ingeniera Tecnica en Obras P ublicas, esp. Construcciones Civiles, de la
Universidad de A Coru na.
Las practicas se han venido estructurando en cuatro sesiones de 100
minutos. La mitad de ese tiempo, al menos, se dedica a la resolucion de
ejercicios relacionados con los aspectos de MATLAB que hayan sido trata-
dos en cada sesion. Se incluyen, ademas de las explicaciones teoricas, los
enunciados de los ejercicios, y en un apendice las soluciones a todos ellos.
Es importante tener en cuenta que este material ha sido elaborado a
partir de la realizacion de las mencionadas practicas, y no al reves. En
particular no hemos incluido mas contenidos que los que ha dado tiempo
a explicar y ejercitar razonablemente en el escaso tiempo disponible. Por
supuesto, existe un gran n umero de fuentes que el lector puede consultar
para continuar su aprendizaje o resolver una duda concreta, empezando por
la propia ayuda de MATLAB.
Por otra parte, el caracter informal de estas notas y la introduccion
gradual y detallada de los contenidos pueden resultar convenientes para
alguien que nunca ha usado el programa y quiere aprender, por su cuenta y
rapidamente, sus caractersticas basicas.
2
Captulo 1
Primera sesion
1.1. Operaciones basicas
MATLAB es una utilidad matematica, originalmente concebida para rea-
lizar calculos numericos con vectores y matrices (de ah el nombre, MATrix
LABoratory), aunque en las sucesivas versiones ha ido incorporando multi-
tud de aplicaciones nuevas. En estas sesiones solo podremos ver unas cuan-
tas, pero se trata sobre todo de familiarizarse con el entorno del programa
y ponerse en situacion de ir aprendiendo cosas nuevas conforme se vayan
necesitando.
Al abrir el programa nos encontramos una especie de sub-escritorio, es
decir, una ventana en la que viven varias ventanas mas peque nas. Por ahora
vamos a jarnos en la ventana mas a la derecha en la conguracion estandar,
que es la ventana de comandos. En ella introduciremos los comandos en
modo directo, es decir, las instrucciones para las que queramos una respuesta
inmediata.
Los dos angulos que aparecen en la ventana de comandos
>>
se conocen como el prompt de MATLAB y nos indican que el programa
esta esperando nuestras instrucciones.
Para empezar, MATLAB se puede utilizar, por supuesto, como una cal-
culadora. Si escribs lo siguiente
>> 234*485
y pulsais Entrar, el programa os devuelve
ans =
113490
Ahora jaos en que en la ventana de Workspace (espacio de trabajo)
aparece la variable ans (de answer). MATLAB va guardando el resultado de
3
la ultima operacion en esta variable. Si haceis doble click sobre el icono que
aparece al lado del nombre, aparece una ventana con el valor de la variable
ans. Esta ventana es un editor, as que el valor se puede modicar.
Vemos que el asterisco * se utiliza para multiplicar. Si queremos calcular
una potencia, por ejemplo 5
7
, lo haremos con el acento circunejo ^:
>> 5^7
ans =
78125
Si repets la operacion de editar la variable ans, vereis que aparece almace-
nado este otro valor. El resultado de la ultima operacion lo hemos perdido,
o al menos ya no esta almacenado en ninguna variable, aunque se podra
recuperar copiando y pegando dentro de la propia ventana de comandos.
En las expresiones compuestas de varias operaciones, hay que tener en
cuenta las reglas de prioridad, que nos indican que operaciones se efect uan
antes y cuales despues. Son las habituales: lo que primero se ejecuta es lo
que hemos puesto entre parentesis, en su caso, y en caso de tener varios
parentesis anidados, se van evaluando de dentro hacia fuera. Dentro de cada
parentesis (si es que los hay), lo primero que se eval ua son las potencias,
despues las multiplicaciones y divisiones, y nalmente las sumas y restas. Si
hay varias operaciones del mismo nivel seguidas, se efect uan de izquierda a
derecha. Por ejemplo, para obtener el valor de la expresion
2
12
+
1
7
0
25 3(1
3)
podramos teclear
>> (2^12+1/7)/(0.25-3*(1-3^0.5))
ans =
1.6745e+003
Al igual que ocurre con las calculadoras cientcas, la notacion 1.6745e+003
signica 1
6745 10
3
, es decir, 1674
5.
MATLAB admite aritmetica compleja. Por ejemplo si tecleais
>> (3-2i)*(4+5i)
el resultado es
ans =
22.0000 + 7.0000i
Por supuesto podemos guardar el resultado de una operacion en una
variable nueva:
4
>> x=tan(pi/3)
x =
1.7321
En una lnea hemos hecho dos cosas: pedirle a MATLAB que eval ue esa
expresion y guardar el resultado en la variable x, que aparece en el Workspace
junto a ans.
Fijaos en que pi es una constante interna de MATLAB, es decir, tiene
un valor asignado.
Aunque los resultados que vamos obteniendo aparezcan solo con cuatro
cifras decimales, MATLAB opera realmente con una precision mucho mayor.
Para que los resultados aparezcan con mas cifras signicativas basta teclear
>> format long
Si volvemos a pedirle el valor de x
>> x
nos devuelve ahora
x =
1.73205080756888
MATLAB opera siempre con doble precision, independientemente de como
nos de los resultados. Es importante tener en cuenta que la instruccion
format no cambia la precision de la maquina sino solo el formato de salida
de resultados.
Cuando MATLAB hace un calculo, o simplemente se da por enterado de
que hemos asignado un valor a una variable, nos responde con ese resultado
en pantalla, como hemos podido ver hasta ahora. Para pedirle que no lo
haga, escribimos punto y coma al nal de la expresion y antes de pulsar
enter
>> y=exp(i*pi);
(exp es la exponencial de base e.) MATLAB ha hecho este calculo y ha
guardado el resultado en la variable y, pero no nos contesta con el resultado.
Sin embargo la variable y aparece en el Workspace, y podemos recuperar su
valor editandola desde all o bien simplemente tecleando
>> y
y =
-1.00000000000000 + 0.00000000000000i
Como veis a veces el formato largo es un poco incomodo. Para recuperar el
formato por defecto escribimos
5
>> format short
>> y
y =
-1.0000 + 0.0000i
Hemos visto que, como es habitual en las ventanas de edicion de texto, una
vez se ha llenado la Command Window con nuestros comandos y las res-
puestas del programa, las lneas van desapareciendo por la parte superior de
la ventana, desplazadas por las nuevas lneas de la parte inferior. Las lneas
de la sesion actual que van quedando ocultas se pueden mostrar utilizando
la barra movil vertical a la derecha de la ventana. Si lo que queremos hacer
es borrar todas las lneas de la Command Window, el comando que debemos
utilizar es
>> clc
Vamos a jarnos ahora en la ventana que aparece abajo a la izquierda,
llamada Command History (Historia de comandos). Como su nombre indi-
ca, recoge todos los comandos que hemos ido introduciendo en la presente
sesion (y en las ultimas sesiones). El comando clc no tiene efecto sobre la
Command History. Desde esta ventana se puede directamente arrastrar con
el raton una lnea completa hasta la ventana de comandos y ejecutarla o
modicarla una vez all; tambien, si hacemos click con el boton derecho del
raton sobre un comando de la Command History, se abre un men u local que
nos permite copiarla, ejecutarla, borrarla y otras opciones. Otra forma de
recuperar comandos anteriores y en general, moverse por la historia reciente
de comandos, es utilizar las teclas de cursor desde la Command Window.
1.2. Las matrices en MATLAB
Como antes comentabamos, una de las caractersticas de MATLAB es
que esta especialmente dise nado para trabajar con variables vectoriales y
matriciales. Podemos hacer esta asignacion
>> a=[2 3 0 1];
sin haberle indicado previamente al programa que a no es una variable es-
calar (es decir, una variable en la que almacenamos un solo n umero) sino
una variable vectorial. De hecho en MATLAB no hay propiamente varia-
bles numericas escalares ni vectoriales, sino matriciales (arrays): si mirais
el Workspace en cualquier sesion de trabajo vereis que los n umeros se van
almacenando como matrices 11. Analogamente, nuestra variable a es para
MATLAB una matriz 1 4.
Las matrices se introducen entre corchetes, separando las las por ; y los
elementos de cada la por comas o simplemente espacios.
6
>> A=[0 -1 3 2; 2 1 7 2; 3 0 6 3; 5 0 10 6]
A =
0 -1 3 2
2 1 7 2
3 0 6 3
5 0 10 6
Como no hemos puesto ; al nal de la introduccion de datos, MATLAB nos
contesta con el valor de la variable. Tanto en la ventana de comandos como
en la de variables, ya aparece colocada en forma matricial.
Las variables a y A no se intereren (las podeis ver conviviendo en el
Workspace) porque MATLAB distingue may usculas de min usculas. Las va-
riables pueden estar formadas por varios caracteres (como ya hemos visto
con los ejemplos de ans y pi), pero el primero de ellos siempre ha de ser
una letra.
Vamos a crear dos variables matriciales mas (jaos en que todas van
apareciendo en la ventana del Workspace):
>> D=[2 -1 3 0 ; 0 0 1 5]
D =
2 -1 3 0
0 0 1 5
>> E=rand(4,4)
E =
0.9501 0.8913 0.8214 0.9218
0.2311 0.7621 0.4447 0.7382
0.6068 0.4565 0.6154 0.1763
0.4860 0.0185 0.7919 0.4057
(El comando rand crea una matriz del tama no especicado, en este caso
4 4, formada por n umeros aleatorios entre 0 y 1.)
Las operaciones de suma de matrices y producto de un escalar por una
matriz se realizan directamente, sin necesidad de ir componente a compo-
nente:
>> A+E
ans =
0.9501 -0.1087 3.8214 2.9218
2.2311 1.7621 7.4447 2.7382
3.6068 0.4565 6.6154 3.1763
5.4860 0.0185 10.7919 6.4057
7
>> 3.5*E
ans =
3.3255 3.1195 2.8749 3.2263
0.8090 2.6673 1.5565 2.5837
2.1239 1.5976 2.1540 0.6169
1.7009 0.0648 2.7718 1.4200
Por supuesto, si intentamos sumar dos matrices de tama nos distintos obten-
dremos un mensaje de error
>> A+D
??? Error using ==> +
Matrix dimensions must agree.
Igual de facil resulta multiplicar matrices
>> D*E
ans =
3.4896 2.3899 3.0444 1.6342
3.0368 0.5490 4.5751 2.2048
D*E es el producto ordinario de las matrices D y E. Para que tenga sentido,
como sabeis, el n umero de columnas del primer factor tiene que coincidir
con el n umero de las del segundo
>> E*D
??? Error using ==> *
Inner matrix dimensions must agree.
Tiene sentido denir otro producto de matrices, el que se hace componente
a componente, como la suma. Para multiplicar en este sentido dos matrices es
necesario que tengan el mismo tama no: cada elemento de la matriz resultado
se obtiene multiplicando los elementos que ocupan esa misma posicion en
las dos matrices. Vamos a crear por ejemplo la matriz
>> F=10*rand(2,4)
F =
9.3547 4.1027 0.5789 8.1317
9.1690 8.9365 3.5287 0.0986
y multiplicar elemento a elemento las matrices D y F, que tienen las mismas
dimensiones. Las operaciones elemento a elemento se indican anteponien-
do un punto al smbolo correspondiente. Por ejemplo
>> D.*F
ans =
18.7094 -4.1027 1.7367 0
0 0 3.5287 0.4931
8
La potencia nsima de una matriz cuadrada es el producto matricial de la
matriz por s misma n veces:
>> A^4
ans =
2419 -204 5342 3030
5343 -452 11838 6702
5457 -465 12093 6852
9870 -840 21870 12391
Tambien se puede plantear la potencia n-sima elemento a elemento:
>> F.^4
ans =
1.0e+003 *
7.6581 0.2833 0.0001 4.3724
7.0680 6.3778 0.1550 0.0000
o elevar una matriz a otra, elemento a elemento
>> F.^D
ans =
87.5104 0.2437 0.1940 1.0000
1.0000 1.0000 3.5287 0.0000
o la division
>> F./D
Warning: Divide by zero.
ans =
4.6773 -4.1027 0.1930 Inf
Inf Inf 3.5287 0.0197
Aqu veis que cuando dividimos por cero MATLAB no da error sino que
devuelve Inf (innito).
Las funciones elementales (trigonometricas, exponencial, logaritmo, etc.)
se pueden aplicar a las matrices, componente a componente, sin necesidad
de anteponer un punto:
>> sin(F)
ans =
0.0700 -0.8198 0.5471 0.9617
0.2530 0.4691 -0.3775 0.0985
>> exp(D)
ans =
7.3891 0.3679 20.0855 1.0000
1.0000 1.0000 2.7183 148.4132
9
Las operaciones elemento a elemento resultan utiles en muchas ocasiones
en las que queremos hacer el mismo calculo simultaneamente sobre diversos
valores numericos. Por ejemplo, para evaluar la funcion f(x) = tan
2
(ln x)
en los valores x = 1, 1
5, 2, 3, 5 basta hacer
>> x=[1 1.5 2 3 5];
>> y=tan(log(x)).^2
y =
0 0.1843 0.6900 3.8339 669.0486
Tanto los cinco valores de la x como las cinco evaluaciones de la funcion los
hemos almacenado en sendas variables vectoriales.
Para trasponer matrices utilizamos el apostrofe. Por ejemplo:
>> B=A
B =
0 2 3 5
-1 1 0 0
3 7 6 10
2 2 3 6
Hay que hacer una observacion aqu: Si la matriz con la que trabajamos es
de n umeros complejos, por ejemplo la matriz 4 1 siguiente
>> C= [ 1-i ; -i; 0; 4-i];
al teclear C no nos da exactamente la traspuesta
>> C
ans =
1.0000 + 1.0000i 0 + 1.0000i 0 4.0000 + 1.0000i
sino la traspuesta conjugada: se traspone la matriz y se calculan los con-
jugados de todos sus elementos. Esto es debido a que cuando se trabaja
con matrices complejas, la operacion combinada trasposicion-conjugacion
es muy com un. Si queremos, en el caso complejo, simplemente trasponer,
tenemos que escribir
>> C.
ans =
1.0000 - 1.0000i 0 - 1.0000i 0 4.0000 - 1.0000i
Se puede extraer un elemento de una matriz. Por ejemplo, el elemento de
la la 2 y columna 4 de A lo recuperamos tecleando
>> A(2,4)
ans =
2
10
Un rango de las, o de columnas, se indica utilizando los dos puntos :
Por ejemplo, los elementos de la matriz A que estan dentro de la la 2, entre
las columnas 1 y 3 inclusive, se extraen as de la matriz:
>> A(2,1:3)
ans =
2 1 7
Fijaos en que ans es una variable 13. Los elementos de A que estan dentro
de la columna 3, entre las las 2 y 4 inclusive se extraen as:
>> A(2:4,3)
ans =
7
6
10
y ahora el resultado es 3 1 (logico...). Si queremos sacar de A una la o
columna entera podemos poner delimitadores 1:4 (porque la matriz es 44)
o no poner ninguno:
>> A(:,4)
ans =
2
2
3
6
Tambien podemos sacar de una matriz elementos no adyacentes. El segundo
y cuarto elementos de la la 3 de A:
>> A(3,[2 4])
ans =
0 3
Si denimos delimitadores antes y despues de la coma, lo que obtenemos son
submatrices. Por ejemplo, la submatriz 3 3 de A obtenida al intersecar las
las {2, 3} con las columnas {2, 3, 4} sera
>> A(2:3,2:4)
ans =
1 7 2
0 6 3
Las submatrices pueden estar formadas por elementos no adyacentes. La
submatriz de los elementos de A que estan en las las 1 o 4 y en las columnas
2 o 4 sera
11
>> A([1 4],[2 4])
ans =
-1 2
0 6
Se le puede a nadir una la a una matriz
>> u=[3 4 1 5];
>> G=[A;u]
G =
0 -1 3 2
2 1 7 2
3 0 6 3
5 0 10 6
3 4 1 5
o bien una columna, de esta otra forma:
>> v=[1; 0; 2; -1];
>> H=[A v]
H =
0 -1 3 2 1
2 1 7 2 0
3 0 6 3 2
5 0 10 6 -1
Existe una cosa un poco extra na en MATLAB que es la matriz vaca [].
Para quitarle a H la la 3, por ejemplo, la igualo a la matriz vaca:
>> H(3,:)=[]
H =
0 -1 3 2 1
2 1 7 2 0
5 0 10 6 -1
Para quitarle al resultado las columnas 3 y 5, escribo
>> H(:,[3 5])=[]
H =
0 -1 2
2 1 2
5 0 6
MATLAB tiene comandos para crear matrices predeterminadas. Por ejem-
plo, la matriz identidad nn se genera con eye(n)
12
>> eye(5)
ans =
1 0 0 0 0
0 1 0 0 0
0 0 1 0 0
0 0 0 1 0
0 0 0 0 1
Una matriz toda de unos se genera con ones(m,n); por ejemplo
>> ones(4,3)
ans =
1 1 1
1 1 1
1 1 1
1 1 1
y una matriz toda de ceros, con zeros(m,n); por ejemplo
>> zeros(1,7)
ans =
0 0 0 0 0 0
1.3. Ejercicios
1. Calcular modulo y argumento del n umero complejo
(3i 1)
5
5 + i
Nota: el comando abs da el valor absoluto de un n umero real, o bien
el modulo de un n umero complejo. El comando angle da el argumento
en radianes de un n umero complejo. Como siempre, se pueden aplicar
a matrices.
2. Comprobar que
lm
n
_
1 +
1
n
_
n
= e
de la siguiente forma: Crear una variable vectorial n que contenga los
elementos
1 10 100 500 1000 2000 4000 8000
Seguidamente crear un nuevo vector y cuyas componentes sean los
valores correlativos de la sucesion en los ndices de n. Comparar los
valores de las componentes de y con el autentico valor de e.
13
3. Denir las siguientes matrices:
A =
_
2 6
3 9
_
, B =
_
1 2
3 4
_
, C =
_
5 5
5 3
_
Crear la siguiente matriz (que tiene sobre la diagonal las matrices A,
B, C) sin introducir elemento a elemento:
G =
_
_
_
_
_
_
_
_
2 6 0 0 0 0
3 9 0 0 0 0
0 0 1 2 0 0
0 0 3 4 0 0
0 0 0 0 5 5
0 0 0 0 5 3
_
_
_
_
_
_
_
_
Realizar sobre G las siguientes operaciones, guardando todos los resul-
tados en variables distintas:
(a) Borrar la ultima la y la ultima columna de G.
(b) Extraer la primera submatriz 4 4 de G.
(c) Extraer la submatriz {1, 3, 6} {2, 5} de G.
(d) Reemplazar G(5, 5) por 4.
4. (Resolucion de sistemas de ecuaciones lineales.) El comando inv cal-
cula la matriz inversa de una matriz regular. Por lo tanto, el sistema
de ecuaciones lineales Ax =b puede resolverse simplemente mediante
>> inv(A)*b
Sin embargo, hay una forma de hacer que MATLAB calcule la solu-
cion de Ax =b utilizando el metodo de Gauss (reduccion del sistema
mediante operaciones elementales de la). Este metodo es preferible
al anterior ya que el calculo de la inversa involucra mas operaciones
y es mas sensible a errores numericos. Se utiliza la llamada division
matricial izquierda \
>> A\b
Probar los dos metodos con el sistema siguiente:
_
_
_
2x y + 3z = 4
x + 4y + z = 2
6x + 10y + 3z = 0
14
Captulo 2
Segunda sesion
En esta sesion vamos a aprender a producir algunas gracas con MAT-
LAB y tambien empezaremos a escribir y ejecutar programas.
2.1. Gracas sencillas en MATLAB
La forma mas artesanal de generar gracas 2D en MATLAB es usando
el comando plot. Vamos a representar, por ejemplo, la funcion f(x) =
senxcos
2
x en el intervalo [5, 5]. Primero tenemos que crear dos variables
vectoriales: una, que llamaremos por ejemplo x, y que almacenara los valores
de x [5, 5] en los que evaluaremos la funcion f, y otra, que podemos
llamar y, en el que se almacenaran las evaluaciones de f en esos puntos. En
denitiva, se trata simplemente de crear una tabla de valores.
Habitualmente los valores de x se escogen equiespaciados entre los dos
extremos del intervalo. Hay dos formas de hacer esto: indicando el n umero de
puntos o indicando la distancia entre dos puntos consecutivos. Por ejemplo,
tecleando
>> x=linspace(-5,5,20);
almacenamos en la variable x 20 valores distribuidos regularmente entre 5
y 5. (Comprobadlo editando la variable en el Workspace.) Si hacemos en
cambio
>> x=-5:0.5:5;
la variable x almacenara valores entre 5 y 5, cada uno a una distancia
0
5, en lugar
de x=-5:1:5; podramos poner simplemente x=-5:5; de forma similar a
cuando determinabamos un rango de las o columnas en una matriz.)
Nos quedamos por ejemplo con este ultimo valor de x, y evaluamos la
funcion en esos puntos:
15
>> x=-5:0.5:5;
>> y=sin(x)-cos(x).^2;
Notar que cos(x) es una matriz la y queremos elevarla al cuadrado en el
unico sentido posible, es decir, elemento a elemento; de ah que antepon-
gamos un punto al caracter ^. Ahora solo queda pedirle al programa que
represente los puntos (x,y) en un sistema de ejes coordenados. Esto se hace
simplemente escribiendo
>> plot(x,y)
Se abre una ventana graca con la representacion de la funcion.
-5 -4 -3 -2 -1 0 1 2 3 4 5
-1.5
-1
-0.5
0
0.5
1
Observamos que la graca no es muy satisfactoria: es una lnea poligonal.
Lo que hace el comando plot es pintar los puntos (x,y) que hemos creado
y unirlos con segmentos de lnea recta. Para que la graca aparezca mas
suave, por lo tanto, hay que tomar los puntos de x mas cercanos unos de
otros. Por ejemplo
>> x=-5:0.1:5;
crea un array con puntos desde 5 hasta 5 espaciados 0
1 (jaos en el Works-
pace). Evaluando de nuevo la funcion en los puntos de x
>> y=sin(x)-cos(x).^2;
>> plot(x,y)
se crea una graca mas suave.
16
-5 -4 -3 -2 -1 0 1 2 3 4 5
-1.5
-1
-0.5
0
0.5
1
Esta nueva curva sustituye a la anterior en la ventana graca. Si queremos
conservarla, podemos guardarla de la forma habitual, desde la propia ven-
tana graca (File>>Save o Save as...), o haciendo click sobre el icono del
diskette). Como en otras aplicaciones, hay una carpeta donde el programa
guardara por defecto todos los archivos a menos que le indiquemos otra cosa.
Esa carpeta se llama Current Directory y su contenido es accesible des-
de la vista normal del escritorio de MATLAB, haciendo click en la pesta na
correspondiente. Al iniciar el programa el Current Directory se sit ua en una
carpeta llamada work, que cuelga de la carpeta donde esta instalado MAT-
LAB, pero se puede cambiar utilizando los botones de la parte superior de
la ventana. Las gracas generadas por MATLAB se guardan como archivos
.g, un formato propio del programa, aunque tambien se pueden convertir
a .jpg, a .eps y otros (File>>Export...).
Se pueden pintar varias gracas superpuestas. Por ejemplo, denimos los
valores de la funcion coseno sobre la malla de puntos x ya creada:
>> z=cos(x);
y pintamos las dos gracas a la vez (ver graca en pagina siguiente), sim-
plemente escribiendo
>> plot(x,y,x,z)
Puede ser que queramos pintar solo una serie de puntos. Por ejemplo, si
nos interesa representar gracamente los elementos de la sucesion 1/n desde
n = 1 hasta 10, la secuencia de comandos
17
-5 -4 -3 -2 -1 0 1 2 3 4 5
-1.5
-1
-0.5
0
0.5
1
>> n=1:10;
>> m=1./n;
>> plot(n,m)
produce una graca continua que seguramente no nos viene bien. En este
caso basta a nadirle la opcion . como un argumento mas del comando
plot:
>> plot(n,m,.)
(ver graca en pagina siguiente). Hay multitud de opciones que controlan la
apariencia de la graca. Por ejemplo,
>> plot(n,m,o)
sustituye los puntos por peque nos crculos. Si tecleais
>> help plot
os aparecera en pantalla una lista de opciones disponibles para este comando.
help se puede usar para obtener informacion sobre cualquier comando.
Tambien podeis mejorar o modicar la graca desde la propia venta-
na graca, sin introducir comandos desde la Command Window. Desde los
men us Edit e Insert, y haciendo click sobre los elementos de la graca que
nos interesen, se puede modicar el color de la lnea, su grosor, el aspecto
de los ejes, ponerle etiquetas a los ejes X e Y , darle un ttulo a la graca,
insertar lneas, echas, texto...
18
1 2 3 4 5 6 7 8 9 10
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
Por supuesto, todas estas operaciones se pueden hacer desde la Command
Window, pero esto es mas complicado porque necesitamos acordarnos del
comando que hace cada cosa. Por ejemplo los siguientes comandos
>> x=-2*pi:.1:2*pi;
>> y=sin(x)-cos(sqrt(2)*x);
>> plot(x,y,r,linewidth,2)
>> axis tight
>> grid on
>> xlabel(eje x)
>> ylabel(eje y)
>> title(Grafica de y=sin(x)-cos(sqrt(2)*x),FontSize,14)
dan lugar a la graca reproducida en la pagina siguiente.
La ventaja de aprender a editar una graca con comandos en vez de
desde la ventana graca es que los comandos se pueden programar. (Veremos
enseguida como hacerlo.) La edicion de una graca a golpe de raton es mucho
mas intuitiva pero en muchos casos resulta comodo almacenar el proceso de
edicion en una secuencia de comandos, para no tener que guardar la graca,
o si tenemos que producir varias gracas parecidas.
19
-6 -4 -2 0 2 4 6
-1.5
-1
-0.5
0
0.5
1
1.5
eje x
e
j
e
y
Grafica de y=sin(x)-cos(sqrt(2)*x)
La instruccion plot es muy versatil, pero si queremos producir una gra-
ca estandar que represente una sola curva sin complicarnos generando una
tabla de valores, disponemos del comando ezplot, que traza la curva corres-
pondiente a una expresion funcional que se introduce como una cadena de
caracteres. Por ejemplo: para dibujar la funcion f(x) = exp(sen(x)) 1 en
el intervalo [0, 10] basta teclear
>> ezplot(exp(sin(x))-1,[0,10])
0 1 2 3 4 5 6 7 8 9 10
-0.5
0
0.5
1
1.5
x
exp(sin(x))-1
20
exp(sin(x))-1 es una cadena de caracteres que MATLAB ha de inter-
pretar como la expresion analtica de una funcion. Las cadenas de caracteres
(strings) han de introducirse entre apostrofes. Una de las ventajas de ezplot
es que tambien puede utilizarse para dibujar gracas de curvas denidas im-
plcitamente (curvas en el plano). Por ejemplo, representamos la conica de
ecuacion x
2
+ 2xy 3x + 1 = 0 (el conjunto de puntos (x, y) del plano que
satisfacen esa ecuacion):
>> ezplot(x^2+2*x*y-3*x+1,[-4 4 -4 4])
-4 -3 -2 -1 0 1 2 3 4
-4
-3
-2
-1
0
1
2
3
4
x
y
x
2
+2 x y-3 x+1 = 0
donde los cuatro n umeros indican el recuadro del plano donde esta el trozo
de graca que nos interesa, en este caso 4 x 4, 4 y 4.
2.2. Programacion en MATLAB: Scripts
Un script no es mas que un conjunto de comandos concatenados que
podemos ejecutar siempre que nos apetezca, sin teclearlos cada vez.
Vamos a introducir en un script la secuencia de comandos que produca
la graca de la funcion senx cos(
_
2 + sen x (10 x 5)
e
x
(5 < x < 2)
ln(x
2
+ 1) (2 x 10)
Investigar el uso de los comandos de edicion directa en la ventana
graca para intentar darle un mejor aspecto al resultado.
3. Preparar un script solucion.m que resuelva el siguiente sistema de ecua-
ciones:
_
_
_
5x + 2ry + rz = 2
3x + 6y + (2r 1)z = 3
2x + (r 1)y + 3rz = 5
para un valor arbitrario del parametro r que introduciremos antes de
ejecutar el programa, de esta forma:
>> r=10;
>> solucion
25
4. (Un bucle for.) Es posible (y recomendable) hacer el calculo de la suma
de, pongamos, 10000 terminos de la sucesion (1)
n1
/n sin necesidad
de crear variables vectoriales de 10000 componentes. La forma habitual
de hacerlo es mediante un bucle for.
Un bucle for es un conjunto de lneas de programa comprendidas entre
dos lneas parecidas a estas:
for k=1:10
.
.
.
end
Las lneas de programa comprendidas entre estas dos se ejecutaran
sucesivamente 10 veces seguidas, y en cada una de ellas la variable k
tomara el valor correspondiente, desde 1 hasta 10, en este caso.
Para entender como funciona, crear y ejecutar un script con las
siguientes lneas
for a=1:5
a^2
end
y razonar la respuesta que se obtiene.
Desde la Command Window ejecutar el comando
>> clear
que borrara las variables del Workspace.
A continuacion crear el siguiente script
% Calcula la suma de 10000 terminos de la serie de ln(2)
suma=0;
for k=1:10000
suma=suma+(-1)^(k-1)/k;
end
suma
vreal=log(2)
difa=abs(suma-vreal)
Guardarlo por ejemplo como sumaln2 y ejecutarlo. Intentar razo-
nar, lnea a lnea, como funciona el programa. Comprobar que
en el Workspace no aparece ahora ninguna variable vectorial.
Adaptar el script como antes, para un n umero arbitrario n de
sumandos.
26
Captulo 3
Tercera sesion
3.1. Programacion en MATLAB: las functions
En la sesion anterior aprendimos a almacenar una secuencia de comandos
en un script para ejecutarlos sucesivamente siempre que lo necesitaramos,
sin necesidad de teclearlos todos cada vez. Ejecutar un script es totalmente
equivalente a ejecutar desde la Command Window cada una de sus lneas de
comando. En particular, todas las variables que se creen dentro del script se
incorporaran al Workspace y permaneceran almacenadas por si necesitamos
usarlas mas adelante.
Las variables que aparecen en el Workspace se denominan variables glo-
bales o variables del espacio de trabajo base. Hasta ahora son las unicas va-
riables que nos hemos encontrado. Si trabajamos siempre desde la Command
Window, o mediante scripts, MATLAB no puede averiguar que variables nos
conviene conservar y cuales usamos simplemente como variables auxiliares.
Sin embargo, la mayor parte de las tareas que vayamos a programar se
podran describir como el procesamiento de unos datos de entrada para ob-
tener datos de salida, y no nos importara prescindir de los datos intermedios
que genere el proceso. Si distinguimos entre estos tres tipos de variables, y si
ademas conseguimos que se limpien automaticamente del Workspace las
variables que no nos interese conservar, programaremos de forma mas sis-
tematica, ahorraremos memoria y evitaremos la acumulacion de informacion
in util.
Para ello disponemos de un tipo de programa diferente a los scripts, que
se denomina function. Las functions se caracterizan por admitir argumentos
de entrada y salida y por disponer de su propio espacio de trabajo.
Vamos a generar un script y convertirlo en una function para entender
mejor estas nuevas posibilidades. Programaremos una operacion elemental
de la sobre una matriz; por ejemplo, la operacion H
31(2)
consistente en
sumarle a la la 3 de una matriz la la 1 multiplicada por 2.
Creamos y guardamos el siguiente script con el nombre de msumf:
27
% suma a la fila 3 de la matriz A, la fila 1
% multiplicada por -2
A(3,:)=A(3,:)-2*A(1,:);
A
Vamos a probar este programa sobre la matriz
A =
_
_
1 0 1 1 1
1 1 1 2 0
2 0 2 2 1
_
_
Para ello tecleamos desde la Command Window lo siguiente:
>> A=[1 0 -1 1 1 ; 1 1 1 2 0 ; 2 0 -2 2 1];
>> copia=A;
>> msumf
A =
1 0 -1 1 1
1 1 1 2 0
0 0 0 0 -1
Vamos a analizar un poco lo que hace el programa msumf, y como lo hemos
usado. La lnea
A(3,:)=A(3,:)-2*A(1,:);
que es la que realiza la operacion, act ua de la siguiente forma: como siempre,
el valor situado a la derecha del signo = se le asigna a la variable situada a la
izquierda. A(3,:) es la tercera la de la matriz A y A(1,:) la primera; por
lo tanto A(3,:)-2*A(1,:) es la nueva la resultado de la operacion, la que
resulta de restarle a la tercera el doble de la primera. Estos nuevos valores
pasan a ocupar la la 3 de la matriz A, sustituyendo a los anteriores, ya que
los almacenamos en A(3,:). La lnea de programa siguiente se limita a sacar
en pantalla la nueva matriz A, ya con la operacion incorporada.
Desde la Command Window, despues de denir la matriz A y antes de
ejecutar el programa, hemos creado una copia (llamada copia) de A
>> copia=A;
ya que, una vez ejecutado msumf, la variable A almacenara la matriz transfor-
mada, sobreescribiendo a la de partida, que se perdera si no la guardaramos
en alg un sitio. Si examinais el Workspace vereis que la variable que almacena
la matriz inicial es ahora copia.
Por supuesto, tal como esta el programa es poco util; deberamos poder
adaptarlo para que realizara cualquier operacion del tipo H
ij()
, para las i
y j y n umeros arbitrarios. Para ello basta modicarlo as:
28
% suma a la fila i de la matriz A, la fila j
% multiplicada por lambda
A(i,:)=A(i,:)+lambda*A(j,:);
A
y ahora, cada vez que lo queramos ejecutar, debemos indicar los valores de
i, j y lambda. Por ejemplo, en la matriz A (que ya ha sufrido la primera
transformacion), vamos a sumarle a la segunda la la primera multiplicada
por 1.
>>i=2;j=1;lambda=-1;
>> msumf
A =
1 0 -1 1 1
0 1 2 1 -1
0 0 0 0 -1
(Nota: Como vemos, se pueden introducir varios comandos en la misma
lnea de la Command Window o en una lnea de programa, separados por
puntos y comas si queremos que no salgan los resultados por pantalla, o
por comas si queremos que salgan.) En el Workspace vemos aparecer las
variables i, j, lambda, ademas de A y copia.
Si convertimos este script en una function podremos controlar que va-
riables permanecen en el Workspace, y ademas no necesitaremos acordarnos
cada vez que ejecutamos el programa de que la matriz que queremos trans-
formar ha de llamarse A. Lo primero que tenemos que hacer es determinar
cuales son las variables de entrada (los datos sobre los que va a trabajar el
programa) y cuales las variables de salida (el resultado de ejecutar el progra-
ma). En este caso, las variables de entrada son claramente la matriz A a la
que queremos aplicar la operacion, y las las i y j y el n umero lambda que
intervienen en la misma, y la variable de salida es la matriz transformada,
que vamos a llamar de otra forma (B) para evitar confusiones.
La primera lnea de una function tiene siempre la misma estructura,
que tenemos que respetar: primero la palabra function, despues un espacio
en blanco, despues las variables de salida, despues un signo =, despues el
nombre del programa (que ha de ser necesariamente el mismo nombre con el
que lo guardemos), y nalmente, entre parentesis y separadas por comas, las
variables de entrada. Vamos ya a editar nuestro archivo msumf y convertirlo
en una function:
function B=msumf(A,i,j,lambda)
% suma a la fila i de la matriz A, la fila j
% multiplicada por lambda
B=A;
B(i,:)=B(i,:)+lambda*B(j,:);
29
En este caso realizamos la operacion sobre una matriz B
B(i,:)=B(i,:)+lambda*B(j,:);
que previamente hemos inicializado como una copia de A,
B=A;
y que designamos como variable de salida, ya que al nalizar la ejecucion
del programa almacena la matriz transformada.
Si las variables de salida son mas de una (es decir, si los resultados del
programa salen almacenados en varias variables, cosa que sucede frecuente-
mente), han de ir entre corchetes y separados por comas.
Vamos a ejecutar este programa, pero antes, para empezar otra vez desde
el principio, borraremos todas las variables del Workspace. Eso se hace con
el comando
>> clear
La llamada a una function incluye necesariamente la asignacion de valores
a las variables de entrada. Si intentamos ejecutar msumf tecleando sin mas
el nombre del programa, como cuando era un script,
>> msumf
obtendremos como respuesta un mensaje de error, parecido al que recibimos
al ejecutar el comando
>> cos
sin indicar de que angulo es el coseno que queremos calcular: en ambos
casos hace falta indicar el o los argumentos. Al llamar una function hay que
introducir los valores de las variables en el mismo orden en que aparecen
en la primera lnea del programa: en nuestro caso, primero la matriz que
queremos modicar, despues las dos las que intervienen en la operacion
(en el orden adecuado), y despues el n umero:
>>>> msumf([1 0 -1 1 1 ; 1 1 1 2 0 ; 2 0 -2 2 1],3,1,-2)
ans =
1 0 -1 1 1
1 1 1 2 0
0 0 0 0 -1
Si ahora miramos el Workspace veremos que la unica variable que se ha
creado es ans. Todas las variables que aparecen en una function, tanto las
de entrada, como las de salida, como las que en su caso utilice internamente el
programa, son variables locales, es decir, pertenecen al espacio de trabajo de
este, se borran al acabar la ejecucion del mismo y por lo tanto no apareceran
en el Workspace.
Tambien podramos haber llamado a nuestra function asignandole de
paso un nombre al resultado
30
>> matriz=msumf([1 0 -1 1 1 ; 1 1 1 2 0 ; 2 0 -2 2 1],3,1,-2)
Al entrar esta lnea en la Command Window, MATLAB sigue los siguientes
pasos: busca y localiza la funcion msumf; como la primera lnea de esta es
function B=msumf(A,i,j,lambda), introduce respectivamente
en las variables locales de entrada A, i, j, lambda
los valores
_
_
1 0 1 1 1
1 1 1 2 0
2 0 2 2 1
_
_
, 3, 1 y 2,
ejecuta el programa con esos datos, obteniendo
_
_
1 0 1 1 1
1 1 1 2 0
0 0 0 0 1
_
_
co-
mo resultado de esa ejecucion, guardado en la variable local de salida B; a
continuacion, asigna ese resultado a la nueva variable del Workspace matriz
(o a ans si no hubieramos especicado nosotros una), borra cualquier otro
resto de la ejecucion del programa y como la lnea que hemos introducido
para llamar al programa no acaba en ; nos devuelve el resultado por pantalla
matriz =
1 0 -1 1 1
1 1 1 2 0
0 0 0 0 -1
En vez de introducir los valores numericos concretos de los argumentos al
llamar a una function, podemos asignar todos o parte de ellos a traves de
variables del Workspace, por ejemplo
>> C=[1 -1; 3 -2 ; 4 6; 1 1];
>> resultado=msumf(C,2,1,-3)
resultado =
1 -1
0 1
4 6
1 1
Otro ejemplo:
>> i=[1 2 ; 3 4]; numero=-3;
>> j=msumf(i,2,1,numero)
j =
1 2
0 -2
31
Las variables globales i y j, que ahora preferimos utilizar para almacenar
las matrices, no intereren con las variables i y j de la function, ya que per-
tenecen a espacios de trabajo distintos. Ahora mismo, para nosotros, msumf
es una caja negra que realiza determinado calculo, sin importarnos como:
solo nos importa el resultado que obtendremos con determinados datos de
entrada, exactamente igual que con la funcion sin o cos. Preferimos en ge-
neral las functions a los scripts porque no queremos que el programa nos
devuelva informacion que no nos interesa, ni tampoco preocuparnos porque
dentro de las tripas de ese programa haya variables que puedan interferir
con las que tengamos denidas en el momento de ejecutarlo. Las functions
permiten programar en varios modulos o etapas, descomponiendo una tarea
que puede ser muy complicada en diversos subprogramas que se escriben,
corrigen o comprueban de una forma sencilla.
3.2. Ejercicios
1. Preparar una function solucion.m que resuelva el siguiente sistema de
ecuaciones
_
_
_
5x + 2ry + rz = 2
3x + 6y + (2r 1)z = 3
2x + (r 1)y + 3rz = 5
para un valor arbitrario del parametro r. (La variable de entrada sera el
parametro r; la de salida, el vector solucion del sistema. Recordar que
A\b proporciona la solucion del sistema de ecuaciones con matriz de
coecientes A y vector de terminos independientes b.)
2. Preparar tres functions que efect uen cada una de las tres operaciones
elementales de la sobre una matriz dada. Las functions tendran los
siguientes encabezamientos (la segunda de ellas ya la tenemos):
function B=mprodf(A,i,lambda)
% multiplica la fila i de la matriz A por lambda
function B=msumf(A,i,j,lambda)
% suma a la fila i de la matriz A, la fila j
% multiplicada por lambda
32
function B=minterf(A,i,j)
% intercambia las filas i y j de la matriz A
Teclear format rat para obtener los resultados numericos que siguen
en forma de fracciones.
Utilizando las functions recien programadas, calcular la forma escalo-
nada por las y la forma escalonada reducida por las de la matriz
A =
_
_
_
_
1 1 1 1 2 1
4 5 7 2 4 6
2 5 8 4 3 1
3 3 4 1 3 4
_
_
_
_
Comprobar que el segundo resultado es el mismo que el obtenido eje-
cutando el comando
>> rref(A)
3. Teclear format long para obtener los resultados numericos que siguen
en el formato de muchas cifras decimales.
Se considera la funcion f(x) = xe
x
1. Preparar una function
function y=valores(a,b)
que calcule los valores de f en once puntos equiespaciados entre a y
b (incluidos estos dos); dicho de otra forma, que eval ue f sobre los
puntos que marcan la division de [a, b] en diez subintervalos iguales
(estos puntos se obtienen mediante linspace(a,b,11)). La salida de
la function sera una matriz 2 11, llamada y, cuya primera la alma-
cenara los once puntos de la particion del intervalo, y la segunda los
once valores correspondientes de la funcion.
Utilizar sucesivamente la funcion valores para aproximar hasta la
quinta cifra decimal el unico cero de la funcion f en el intervalo [0, 1].
(Al ejecutar valores sobre el intervalo [0, 1] observamos que la funcion
cambia de signo en el subintervalo [0
5, 0
5)/2.)
2. Crear una function que, introducida por el usuario una matriz arbitra-
ria, devuelva una matriz del mismo tama no en la que se ha sumado 1 a
los elementos de la primera la de la matriz original, 2 a los elementos
de la segunda, 3 a los de la tercera, y as sucesivamente. La function
tendra un unico argumento de entrada (la matriz inicial) y un unico
argumento de salida (la matriz resultado). size(A,1) da el n umero de
las, y size(A,2) el de columnas, de la matriz A.
3. Crear un script en el que, mediante el uso de bucles y de condicionales,
se genere una matriz 5 8 con los siguientes elementos:
si el elemento esta en una columna par o bien en una la par, la
raz cuadrada de la suma de los dos ndices (de la y de columna).
en otro caso, la suma de los dos ndices elevados al cuadrado.
Nota: El resto de la division de x entre y se puede calcular en MATLAB
mediante rem(x,y). El o logico se escribe con una barra vertical, |.
De esta forma, la condicion i es par o j es par se podra escribir as:
(rem(i,2)==0)|(rem(j,2)==0)
39
Apendice A
Soluciones a los ejercicios
A.1. Primera sesion
1. >> w=(3i-1)^5/(5+i)
w =
-61.2308 + 9.8462i
>>abs(w)
ans =
62.0174
>> angle(w)
ans =
2.9822
2. >> n=[1 10 100 500 1000 2000 4000 8000];
>> y=(1+1./n).^n
y =
Columns 1 through 6
2.0000 2.5937 2.7048 2.7156 2.7169 2.7176
Columns 7 through 8
2.7179 2.7181
>> exp(1)
ans =
2.7183
3. >> A=[2 6; 3 9]; B=[1 2; 3 4]; C=[-5 5; 5 3];
Pueden ir varios comandos en la misma lnea, separados por , o bien
por ; . Si utilizamos comas MATLAB nos devuelve el resultado en
pantalla.
Primero inicializo la matriz a ceros
>> G=zeros(6,6);
40
despues meto las tres matrices como submatrices de G
>> G(1:2,1:2)=A; G(3:4,3:4)=B; G(5:6,5:6)=C
G =
2 6 0 0 0 0
3 9 0 0 0 0
0 0 1 2 0 0
0 0 3 4 0 0
0 0 0 0 -5 5
0 0 0 0 5 3
Eliminar la ultima la y la ultima columna: Como quiero conservar
la matriz G, primero le asigno el mismo valor a una nueva variable F
sobre la que hare los cambios:
>> F=G;
y ahora hago la eliminacion sobre F
>> F(6,:)=[]
F =
2 6 0 0 0 0
3 9 0 0 0 0
0 0 1 2 0 0
0 0 3 4 0 0
0 0 0 0 -5 5
>> F(:,6)=[]
F =
2 6 0 0 0
3 9 0 0 0
0 0 1 2 0
0 0 3 4 0
0 0 0 0 -5
Extraer la submatriz 4 4 de la esquina superior izquierda de G:
>> H=G(1:4,1:4)
H =
2 6 0 0
3 9 0 0
0 0 1 2
0 0 3 4
Extraer la submatriz {1, 3, 6} {2, 5} de G:
41
>> K=G([1 3 6],[2 5])
K =
6 0
0 0
0 5
Para cambiar el valor de un elemento basta con asignarle el nuevo:
Como quiero conservar la matriz G, los cambios los hare sobre J
>> J=G;
>> J(5,5)=4
J =
2 6 0 0 0 0
3 9 0 0 0 0
0 0 1 2 0 0
0 0 3 4 0 0
0 0 0 0 4 5
0 0 0 0 5 3
Nota: La mayor parte de estos manejos (eliminacion de las, cambio de
valor de elementos, etc.) se pueden hacer desde la ventana del Works-
pace, editando la variable. Pero necesitamos saber hacerlo tambien con
comandos.
4. >> A=[2 -1 3; 1 4 1; 6 10 3]; b=[4;2;0];
>> inv(A)*b
ans =
-1.8049
0.2927
2.6341
>> A\b
ans =
-1.8049
0.2927
2.6341
La solucion es x = 1
8049, y = 0
2927, z = 2
6341.
A.2. Segunda sesion
2. >> x=-10:.1:-5;
>> y=2+sin(x);
>> z=-5:.1:2;
>> t=exp(z);
42
>> u=2:.1:10;
>> v=log(u.^2+1);
>> plot(x,y,z,t,u,v)
>> grid on
>> xlabel(x), ylabel(f(x))
>> title(Representacion grafica de una funcion definida a trozos)
-10 -8 -6 -4 -2 0 2 4 6 8 10
0
1
2
3
4
5
6
7
8
x
f
(
x
)
Representacion grafica de una funcion definida a trozos
Notar que hemos generado tres tablas de valores: (x,y), (z,t), (u,v).
3. El programa podra ser
% Resuelve un sistema de ecuaciones en funcion de un parametro
A=[5, 2, r; 3, 6, 2*r-1; 2, r-1, 3*r];
b=[2; 3 ; 5];
s=A\b
Lo guardamos como solucion y probamos si funciona
>> r=10;
>> solucion
s=
-0.0220
-0.4286
0.2967
>> r=5;
43
>> solucion
s=
0.0833
-0.0417
0.3333
4. suma es la variable en la que se van almacenando las sumas parciales.
El programa inicializa su valor a cero; despues entra en el bucle. En la
primera ejecucion del bucle k vale 1. La lnea
suma=suma+(-1)^(k-1)/k;
como cualquier igualdad dentro de un programa o una secuencia de
comandos, es en realidad una asignacion: se asigna el valor a la derecha
del signo = a la variable indicada a la izquierda. En este caso, el valor
suma+(-1)^(k-1)/k= 0 + (1)
11
/1 se le asigna a la variable suma,
sustituyendo el valor anterior, que era 0. suma pasa a almacenar, por lo
tanto, el primer sumando. Acaba el bucle en end y vuelve a ejecutarse
para k igual a 2 y ese nuevo valor de suma. Luego en esta ejecucion la
lnea
suma=suma+(-1)^(k-1)/k;
asigna el valor suma+(-1)^(k-1)/k= (1)
11
/1 + (1)
21
/2 a la va-
riable suma, sustituyendo el valor anterior. suma pasa a almacenar la
suma de los dos primeros terminos de la sucesion. El bucle se ejecuta
de nuevo para k=3, y al acabar esa ejecucion suma almacenara la suma
de los tres primeros terminos, y as sucesivamente hasta k=10000.
Al terminar las 10000 ejecuciones del bucle el programa sale del mismo
y ejecuta las lneas de comando
suma
vreal=log(2)
difa=abs(suma-vreal)
Ninguna de las tres lneas acaba en ; as que las tres produciran una
salida por pantalla, la de cada una de las tres variables suma (que a
estas alturas almacena la suma de los 10000 sumandos), vreal que
es el valor autentico de ln 2 y difa que es el error cometido en la
aproximacion.
44
A.3. Tercera sesion
1. El programa podra ser
function s=solucion(r)
% Resuelve un sistema de ecuaciones en funcion de un parametro
A=[5, 2, r; 3, 6, 2*r-1; 2, r-1, 3*r];
b=[2; 3 ; 5];
s=A\b;
La llamada al programa incluira la asignacion de un valor al parametro
>> solucion(5)
ans =
0.0833
-0.0417
0.3333
>> solucion(100)
ans =
0.1437
0.0093
0.0126
2. Las functions pedidas podran ser
function B=mprodf(A,i,lambda)
% multiplica la fila i de la matriz A por lambda
B=A;
B(i,:)=lambda*B(i,:);
..............................................
function B=msumf(A,i,j,lambda)
% suma a la fila i de la matriz A,
% la fila j multiplicada por lambda
B=A;
B(i,:)=B(i,:)+lambda*B(j,:);
...............................................
function B=minterf(A,i,j)
% intercambia las filas i y j de la matriz A
B=A;
B([j i],:)=B([i j],:);
45
Vamos a explicar un poco mas la lnea B([i j],:)=B([j i],:). Lee-
mos de derecha a izquierda: asignarle el valor B([j i],:) a B([i j],:).
Es decir: la submatriz de B formada por las las j e i (en ese orden)
la metemos en B como submatriz B([i j],:), sustituyendo el antiguo
valor de esa submatriz.
Una vez guardadas las functions, ya las podemos usar como comandos.
Partimos de
>> A=[1 1 -1 1 -2 -1 ; 4 -5 7 -2 -4 -6; ...
2 5 -8 4 -3 1; 3 -3 4 -1 -3 -4]
A =
1 1 -1 1 -2 -1
4 -5 7 -2 -4 -6
2 5 -8 4 -3 1
3 -3 4 -1 -3 -4
Vamos a llamarle p. ej. X a la matriz que almacenara todos los resul-
tados parciales, hasta la forma reducida nal.
>> X=msumf(A,2,1,-4)
X =
1 1 -1 1 -2 -1
0 -9 11 -6 4 -2
2 5 -8 4 -3 1
3 -3 4 -1 -3 -4
La siguiente operacion elemental la hare sobre el resultado X de haber
aplicado la primera. La matriz resultante la vuelvo a almacenar en X
porque no me interesa guardar estos resultados intermedios.
>> X=msumf(X,3,1,-2); X=msumf(X,4,1,-3)
X =
1 1 -1 1 -2 -1
0 -9 11 -6 4 -2
0 3 -6 2 1 3
0 -6 7 -4 3 -1
>> X=minterf(X,2,3)
X =
1 1 -1 1 -2 -1
0 3 -6 2 1 3
0 -9 11 -6 4 -2
0 -6 7 -4 3 -1
46
>> X=msumf(X,3,2,3); X=msumf(X,4,2,2)
X =
1 1 -1 1 -2 -1
0 3 -6 2 1 3
0 0 -7 0 7 7
0 0 -5 0 5 5
>> X=msumf(X,4,3,-5/7)
X =
1 1 -1 1 -2 -1
0 3 -6 2 1 3
0 0 -7 0 7 7
0 0 0 0 0 0
Ya tengo una forma escalonada por las. Guardo este resultado en una
nueva variable F1
>> F1=X
F1 =
1 1 -1 1 -2 -1
0 3 -6 2 1 3
0 0 -7 0 7 7
0 0 0 0 0 0
y sigo haciendo operaciones elementales hasta llegar a la reducida
>> X=mprodf(X,2,1/3); X=mprodf(X,3,-1/7)
X =
Columns 1 through 5
1.0000 1.0000 -1.0000 1.0000 -2.0000
0 1.0000 -2.0000 0.6667 0.3333
0 0 1.0000 0 -1.0000
0 0 0 0 0
Column 6
-1.0000
1.0000
-1.0000
0
Si quiero puedo hacer que los resultados salgan en forma fraccionaria,
tecleando
>> format rat
47
Sigo con las operaciones elementales de la
>> X=msumf(X,1,2,-1)
X =
Columns 1 through 4
1 0 1 1/3
0 1 -2 2/3
0 0 1 0
0 0 0 0
Columns 5 through 6
-7/3 -2
1/3 1
-1 -1
0 0
>> X=msumf(X,1,3,-1); X=msumf(X,2,3,2)
X =
Columns 1 through 4
1 0 0 1/3
0 1 0 2/3
0 0 1 0
0 0 0 0
Columns 5 through 6
-4/3 -1
-5/3 -1
-1 -1
0 0
Esta ultima ya es la forma escalonada reducida por las. Tecleando
rref(A) compruebo que da el mismo resultado.
Salgo del formato racional p. ej. al formato con muchos decimales, para
hacer el siguiente ejercicio:
>> format long
3. function y=valores(a,b)
% ejercicio 3, tercera sesion de
% MATLAB curso 2006/07
y=zeros(2,11);
y(1,:)=linspace(a,b,11);
y(2,:)=y(1,:).*exp(y(1,:))-1;
La lnea y=zeros(2,11) inicializa la matriz y a ceros, reservando el
espacio necesario en memoria. La lnea y(1,:)=linspace(a,b,11);
48
coloca en la primera la y(1,:) de la matriz y once valores entre a
y b a distancias iguales. La lnea y(2,:)=y(1,:).*exp(y(1,:))-1;
eval ua la funcion f(x) = xe
x
1 en cada uno de esos once valores y
coloca los once resultados en la segunda la y(2,:) de la matriz y.
Ejecutamos el programa en el intervalo [0, 1]
>> valores(0,1)
ans =
Columns 1 through 3
0 0.10000000000000 0.20000000000000
-1.00000000000000 -0.88948290819244 -0.75571944836797
Columns 4 through 6
0.30000000000000 0.40000000000000 0.50000000000000
-0.59504235772720 -0.40327012094349 -0.17563936464994
Columns 7 through 9
0.60000000000000 0.70000000000000 0.80000000000000
0.09327128023431 0.40962689522933 0.78043274279397
Columns 10 through 11
0.90000000000000 1.00000000000000
1.21364280004126 1.71828182845905
Debajo de cada valor de la x encontramos la evaluacion de la funcion
en ese punto. Vemos que el signo de la funcion cambia entre 0
5 y 0
6,
luego la raz esta en el intervalo [0
5, 0
6].
>> valores(0.5,0.6)
ans =
Columns 1 through 3
0.50000000000000 0.51000000000000 0.52000000000000
-0.17563936464994 -0.15070149057760 -0.12534562215658
Columns 4 through 6
0.53000000000000 0.54000000000000 0.55000000000000
-0.09956587643217 -0.07335629442018 -0.04671084017293
Columns 7 through 9
0.56000000000000 0.57000000000000 0.58000000000000
-0.01962339983418 0.00791221931723 0.03590228983504
Columns 10 through 11
0.59000000000000 0.60000000000000
0.06435316508474 0.09327128023431
La raz esta en el intervalo [0
56, 0