josé m. galarce septiembre 4 de 2010

13
José M. Galarce Septiembre 4 de 2010 Segunda Clase Segunda Clase

Upload: saki

Post on 08-Jan-2016

23 views

Category:

Documents


0 download

DESCRIPTION

Segunda Clase. José M. Galarce Septiembre 4 de 2010. Variables de Usuario. Se desea que el robot sea capaz de tomar decisiones. Tales decisiones son operaciones matemáticas sobre los datos que posee el robot. Los datos que se pueden manipular en el programa son las variables de usuario. - PowerPoint PPT Presentation

TRANSCRIPT

Page 1: José M. Galarce Septiembre 4 de 2010

José M. GalarceSeptiembre 4 de

2010

Segunda ClaseSegunda Clase

Page 2: José M. Galarce Septiembre 4 de 2010

Variables de Usuario

• Se desea que el robot sea capaz de tomar decisiones.• Tales decisiones son operaciones matemáticas sobre los datos que

posee el robot.• Los datos que se pueden manipular en el programa son las variables

de usuario.

• Una variable es una zona de memoria del robot que permite almacenar un número.

• Que pertenezca al usuario significa que es posible modificar el dato almacenado en esa zona a través del programa que se ejecuta en el robot.

• Para declarar una variable de usuario en leguaje NQC se emplea la sentencia:

int variable1;int variable2 = 1;

• De esta manera, es posible referirse al valor numérico almacenado indicando el nombre de la variable.

• Las variables de usuario en NQC sólo pueden ser enteros.• Las variables se pueden definir de manera local o global.

Page 3: José M. Galarce Septiembre 4 de 2010

Operadores Aritméticos

• Dado que las variables son números, es fundamental poder realizar operaciones aritméticas con ellas.

• Las operaciones se realizan análogamente al lenguaje matemático estándar, donde el lado izquierdo de la igualdad es la variable que recibe el resultado de la operación del lado derecho.

• Los operadores aritméticos básicos del lenguaje NQC son:

− Suma (+)a = 2 + 6; → a = 8b = 3 + 8; → b = 11c = a + b; → c = 19

− Diferencia (-)c = a – 5; → c = 3

− Producto (*)b = c * 5; → b = 15

− División (/)a = a / 4; → a = 2a = b / c; → a = 5

− Módulo (%)c = b % c; → c = 0

Page 4: José M. Galarce Septiembre 4 de 2010

Comparadores

• Para poder tomar decisiones respecto a valores numéricos es indispensable poder comparar la magnitud de una variable con un número u otra variable.

• Los comparadores del lenguaje NQC son:[→ a = 3;→ b = 5; → c = 3; ]

– Igual (==) y distinto (!=) :b == 5 → verdaderoa != c → falso

– Menor estricto (<) y Mayor estricto (>) :c < 7 → verdaderoa > b → falso

– Menor igual (<=) o Mayor igual (>=) :b <= 1 → falsoa >= c → verdadero

Page 5: José M. Galarce Septiembre 4 de 2010

Operadores Lógicos

• Es necesario que el robot sea capaz de efectuar operaciones lógicas que le permitan determinar el grado de verdad de una expresión.

• Los sistemas digitales se basan en la lógica booleana, verdadero (1) y falso (0).

• Para el lenguaje NQC, toda variable con valor nulo (0) es considerada falsa, y toda variable distinta de nulo se considera verdadera.

• Los operadores lógicos implementados en el lenguaje NQC son:[→ p = 0;→ q = 1;→ r = 0; → s = 3; ]

─ NOT : Negación (!)!p → verdadero

─ AND : Y (&&)q && s → verdaderop && q → falso

─ OR : O (||)p || r → falsop || q → verdadero

Page 6: José M. Galarce Septiembre 4 de 2010

Números Aleatorios

• Cuando se desea que el robot realice acciones de manera aleatoria, es decir, que no ocurra siempre lo mismo, se dispone de una función capaz de entregar un número distinto cada vez.

• En NQC está implementada la función Random();[ → int i; → int j = 5; ]

• i = Random(9); → Número aleatorio entre 0 y 9 (ambos incluidos).

• j = Random(j); → No aplicable, no se puede ejecutar sobre variables.

• k = 10*Random(4);→ k puede ser {0, 10, 20, 30, 40}

Page 7: José M. Galarce Septiembre 4 de 2010

Condicionalidad

• La función fundamental del programa es la toma de decisiones en base a los datos.

• Las decisiones en NQC se de acuerdo al grado de verdad de una expresión.

• Para esto se emplean los comparadores y operadores lógicos antes vistos.

• En NQC la sentencia condicional básica es if(){} o if(){} else{} [ → int i=5; ]

• if( arg ){ acc1; }if(i){ sí se ejecuta, i se interpreta como

verdadero }

if(i<4){ no se ejecuta porque la comparación

es falsa }

• if( arg ){ acc1; } else{ acc0; }

if(i==3){ no se ejecuta porque la comparación

es falsa }else{sí se ejecuta porque no se ejecutó lo

anterior}

Page 8: José M. Galarce Septiembre 4 de 2010

Diagrama de Flujo

• Standards:– ISO 10628– ANSI Y32.11– SAA AS 1109

• Permite describir abstractamente el desarrollo secuencial del programa.

• Utilizaremos un conjunto de figuras simplificado y adaptado al curso.

• A medida que se incorporen estructuras se hará más complejo el diagrama.

Page 9: José M. Galarce Septiembre 4 de 2010

If

• if( condición ){sentencias si se cumple condición;

}

Page 10: José M. Galarce Septiembre 4 de 2010

If-Else

• if( condición ){

sentencias si se cumple condición;

}

else{

sentencias si no se cumple condición;

}

Page 11: José M. Galarce Septiembre 4 de 2010

Definición de Constantes

• Cuando el programa utiliza repetidas veces un valor o una función, se puede definir este dato como una constante para facilitar su manipulación conjunta, reducir el largo de las sentencias o mejorar la interpretación del programa.

• En leguaje NQC una constante se define como :#define nombre valor

• Se pueden definir como constantes a valores :#define GIRO 125

• Se pueden definir como constantes a expresiones :#define compara a = b + c;

• Se pueden definir constantes para facilitar la escritura del programa :

#define ABC OUT_A+OUT_B+OUT_C

• Todas estas definiciones son reemplazadas en el programa antes de compilar.

• Las definiciones deben ir antes de task main(){• No terminan en ;

Page 12: José M. Galarce Septiembre 4 de 2010

Ruteo de Programas

• Es importante conocer el valor que adquiere cada variable en cada momento a medida que transcurre el programa.

• A esto se le llama “rutear”, porque se describen las rutas que siguen los datos.

• Este proceso se puede realizar de manera mental, pero no es recomendable, ya que el número de variables y operaciones puede ser muy grande.

• Hay un procedimiento para realizarlo de manera ordenada y con menor posibilidad de cometer errores.

variable 1variable 2 … variable m

t0 v0 x0 …

t1 v1 x1

t2 v2 x2

tn vn

Fin del programa.

Page 13: José M. Galarce Septiembre 4 de 2010

José M. GalarceMayo 15 de

2010

Segunda ClaseSegunda Clase