mat lab05

Post on 10-Jul-2015

272 Views

Category:

Documents

1 Downloads

Preview:

Click to see full reader

TRANSCRIPT

MatLab

Instrucción ifif expresión lógica

instrucciones

end

Sí la expresión lógica es verdadera, ejecutamos las instrucciones que están entre la instrucción if y la instrucción end

Si la expresión lógica es falsa, saltamos de inmediato a la instrucción que sigue a end

Instrucción if

Es importante sangrar las instrucciones dentro de la estructura if para que sea más fácil de entender

if g < 50contar = contar + 1;

disp(g);

end

Operadores Relacionales y Lógicos

No igual~=

Igual==

Mayor o igual que>=

Mayor>

Menor o igual que<=

Menor que<

InterpretaciónOperador relacional

Operadores Relacionales y Lógicos Estos operadores comparan dos matrices

de igual tamaño Se usan matrices o expresiones de matrices

en ambos lados de un operador relacional para dar otra matriz del mismo tamaño

Cada entrada de la matriz resultante contiene un 1 si la comparación es verdadera cuando se aplica a los valores de las posiciones correspondientes de las matrices; caso contrario, la matriz resultante contiene un 0

Operadores Relacionales y Lógicos

Operadores Relacionales y Lógicos

Una expresión que contiene un operador relacional es una expresión lógica porque el resultado es una matriz que contiene ceros y unos que pueden interpretarse como valores falsos y verdaderos, respectivamente

La matriz resultante también se denomina matriz 0-1

Operadores Relacionales y Lógicos

También podemos combinar dos expresiones lógicas usando operadores lógicos no (not), y (and) y o (or)

|o

&y

~noSímboloOperador Lógico

Operadores Relacionales y Lógicos

Ejercicio 18

Determine si las siguientes expresiones son verdaderas o falsas

Suponga que las variables tienen los valores indicados:

a = 5.5

b = 1.5

k = -3

Ejercicio 19

1. a < 10.02. a + b >= 6.53. k ~= 04. b – k > a5. ~(a == 3 * b)6. ~k <= k + 67. a < 10 & a > 58. abs(k) > 3 | k < b - a

Instrucciones if anidadas

if g < 50

contar = contar + 1;

disp(g);

if b > g

b = 0;

endend

Cláusula else Permite ejecutar un conjunto de

sentencias si la condición es verdadera y otro conjunto de sentencias si la condición es falsa

if intervalo < 1 x_inc = intervalo / 10; else x_inc = 0.1; end

Cláusula elseif if temperatura > 100 disp(‘Demasiado caliente – Falla de equipo’) elseif temperatura > 90 disp(‘Intervalo operativo normal’) elseif temperatura > 50 disp(‘Temperatura por debajo del intervalo deseado’) else disp(‘Demasiado frío – Apagar equipo’) end

Ejercicio 20

Suponga que las variables son escalares

• Si la diferencia entre volt_1 y volt_2 es mayor que 10.0, exhibir los valores de volt_1 y volt_2

• Si el logaritmo natural de x es mayor que 3, asignar 0 a tiempo e incrementar contar en 1

Ejercicio 20• Si dist es menor que 50.0 y tiempo

es mayor que 10.0, incrementar tiempo en 2; caso contrario incrementar tiempo en 2.5

• Si dist es mayor o igual que 100.0, incrementar tiempo en 2.0. Si dist está entre 50 y 100, incrementar tiempo en 1. En los demás casos, incrementar tiempo en 0.5

Solución de Ecuaciones Lineales

Considere el siguiente sistema de tres ecuaciones con tres incógnitas:

Solución de Ecuaciones Lineales

Podemos reescribir este sistema de ecuaciones utilizando las siguientes matrices:

Solución de Ecuaciones Lineales

Si usamos multiplicación de matrices, el sistema de ecuaciones puede escribirse de esta forma:

A X = B Si modificamos nuestra notación de

modo que las variables se designen como x1, x2, x3, etc., y reescribimos el conjunto inicial de ecuaciones, tenemos:

Solución de Ecuaciones Lineales

Este conjunto de ecuaciones se representa entonces con la ecuación A X = B, donde X es el vector columna [x1 x2 x3]T

Solución de Ecuaciones Lineales

Se usa generalmente la ecuación de matrices A X = B para expresar un sistema de ecuaciones; sin embargo, también podemos expresarlo usando vectores fila para B y X.

Solución de Ecuaciones Lineales

Por ejemplo, considere el conjunto de ecuaciones que empleamos en el ejemplo anterior, podemos escribir el conjunto de ecuaciones como XA = B, si X, A y B se definen como:

(Observe que la matriz A es la transpuesta del ejemplo anterior)

División de Matrices

Podemos definir y resolver el sistema de ecuaciones del ejemplo anterior usando la ecuación de matrices A X = B como se muestra en la siguiente diapositiva:

División de Matrices

División de Matrices

También podemos definir y resolver el mismo sistema de ecuaciones usando la ecuación de matrices X A = B, como se muestra a continuación:

División de Matrices

División de Matrices Para poder aplicar estas técnicas, el

sistema debe ser cuadrado. Si un conjunto de ecuaciones es singular,

se exhibe un mensaje de error; el vector de soluciones puede contener valores de NaN, +∞ o -∞, dependiendo de los valores de las matrices A y B

Estos sistemas se denominan Sistemas mal condicionados, MatLab calcula una solución, pero exhibe un mensaje de advertencia para indicar que los resultados podrían ser inexactos

Inversión de Matrices También podemos resolver un sistema de

ecuaciones usando la inversa de la matriz A, siempre y cuando exista dicha inversa.

Por ejemplo, supongamos que A, X y B son las matrices que definimos antes:

Inversión de Matrices

Entonces, A X = B Suponga que multiplicamos ambos

lados de la ecuación por A-1, tenemos entonces:

A-1 A X = A-1 B Dado que A-1 A es igual a la matriz

identidad (I), tenemos:I X = A-1 B

O sea: X = A-1 B

Inversión de Matrices

En MatLab podemos calcular esta solución utilizando el comando:

X = inv(A) * B Este mismo sistema de ecuaciones

puede resolverse también usando la inversa de una matriz si el sistema se expresa en la forma: X A = B

Donde:

Inversión de Matrices

Si multiplicamos ambos lados de la ecuación por A-1, tenemos:

X A A-1 = B A-1

Puesto que A A-1 es la matriz identidad (I), tenemos:

Inversión de Matrices

X I = B A-1

O sea: X = B A-1

En MatLab, podemos calcular esta solución con el comando:

X = B * inv(A)

Ejercicio 21

Resuelva los siguientes sistemas de ecuaciones usando división de matrices y matrices inversas.

Para cada sistema que contenga ecuaciones de dos variables, grafique las ecuaciones para mostrar la intersección o bien para mostrar que el sistema es singular y no tiene solución única

Ejercicio 21

Ejercicio 21

Scripts Un script es una secuencia de instrucciones

de Matlab guardada en un archivo con extensión .m

Se ejecuta escribiendo su nombre:

Funciones (llamada) Las funciones puede recibir varios valores y

devolver varios resultados[m,d]=med_des(x);

Puede haber argumentos opcionalesmit=imread('cameraman.tif','TIFF');mit=imread('cameraman.tif');

No es necesario asignar todos los valores retornados[mit,map]=imread('imageman.gif');mit=imread('imageman.gif');

Funciones (definición) Las funciones se escriben en archivos .m

que deben encontrarse en el directorio actual (o en un directorio definido en el path)

Funciones La variable nargin (local de la función) es el

número de argumentos recibidos. La variable nargout (local de la función) es

el número de argumentos que se recogerán en la llamada. Puede ahorrarnos unos cálculos.

Todos los argumentos llegan por valor, no es posible hacer paso por referencia.

Los scripts comparten las variables del workspace, mientras que las funciones utilizan variables en local

Expresiones lógicas Operadores relacionales: ~= == > <

>= <= Operadores lógicos:

&& Short-circuit AND|| Short-circuit OR& AND| OR

Hay una función xor, pero no es un operador

Control de Flujo: if bloque if

A diferencia de C, en Matlab no es necesario utilizar paréntesis en la expresión lógica

Control de Flujo: for

bucle for

Control de Flujo: while

bucle while

Control de Flujo: switch

switch-case

A diferencia de C, en Matlab no hace falta utilizar break.

Control de Flujo: try

try-catch

Las instrucciones comprendidas entre catch y end sólo se ejecutan si se produce un error en las primeras. Utilizar lasterr para ver el último error.

top related