You are on page 1of 19

REPORTE

INTRODUCCION TEORICA

ESTRUCTURAS

En la paleta de funciones la primera opción es la de las estructuras. Éstas controlan el flujo del programa, bien
sea mediante la secuenciación de acciones, ejecución de bucles, etc.

Las estructuras se comportan como cualquier otro nodo en el diagrama de bloques, ejecutando automáticamente
lo que está programado en su interior una vez tiene disponibles los datos de entrada, y una vez ejecutadas las
instrucciones requeridas, suministran los correspondientes valores a los cables unidos a sus salidas. Sin embargo,
cada estructura ejecuta su subdiagrama de acuerdo con las reglas específicas que rigen su comportamiento, y
que se especifican a continuación.

Un subdiagrama es una colección de nodos, cables y terminales situados en el interior del rectángulo que
constituye la estructura. El For Loop y el While Loop únicamente tienen un subdiagrama. El Case Structure y el
Sequence Structure, sin embargo, pueden tener múltiples subdiagramas, superpuestos como si se tratara de cartas
en una baraja, por lo que en el diagrama de bloques únicamente será posible visualizar al tiempo uno de ellos.
Los subdiagramas se construyes del mismo modo que el resto del programa

Las siguientes estructuras se hallan disponibles en el lenguaje G.

1. ESTRUCTURA CASE

Al igual que otras estructuras posee varios subdiagramas, que se superponen como si de una baraja de cartas se
tratara. En la parte superior del subdiagrama aparece el identificador del que se está representando en pantalla. A
ambos lados de este identificador aparecen unas flechas que permiten pasar de un subdiagrama a otro.

En este caso el identificador es un valor que selecciona el subdiagrama que se debe ejecutar en cada momento.
La estructura Case tiene al menos dos subdiagramas (True y False). Únicamente se ejecutará el contenido de
uno de ellos, dependiendo del valor de lo que se conecte al selector.

2. ESTRUCTURA SEQUENCE

De nuevo, este tipo de estructuras presenta varios subdiagramas, superpuestos como en una baraja de cartas, de
modo que únicamente se puede visualizar una en pantalla. También poseen un identificador del subdiagrama
mostrado en su parte superior, con posibilidad de avanzar o retroceder a otros subdiagramas gracias a las flechas
situadas a ambos lados del mismo.

Esta estructura secuencia la ejecución del programa. Primero ejecutará el subdiagrama de la hoja (frame) Nº 0,
después el del Nº 1, y así sucesivamente.

Para pasar datos de una hoja a otra se pulsará el botón derecho del ratón sobre el borde de la estructura,
seleccionando la opción Add sequence local.

3. BUCLE For
Equivalente al bucle for de los demás lenguajes de programación. Ejecuta el código dispuesto en su interior un
número determinado de veces.

Para pasar valores de una iteración a otra se emplean los llamador shift registers. Para crear uno, se pulsará el
botón derecho del ratón mientras éste se halla situado sobre el borde del bucle, seleccionando la opción Add Shift
Register. El shift register consta de dos terminales, situados en los bordes laterales del bloque. El terminal
izquierdo almacena el valor obtenido en la iteración anterior. El terminal derecho guardará el dato
correspondiente a la iteración en ejecución. Dicho dato aparecerá, por tanto, en el terminal izquierdo durante la
iteración posterior.

Se puede configurar un shift register para memorizar valores de varias iteraciones previas. Para ello, con el ratón
situado sobre el terminal izquierdo del shift register se pulsará el botón derecho, seleccionando a continuación la
opción Add Element.
4. BUCLE While

Es el equivalente al bucle while empleado en los lenguajes convencionales de programación. Su funcionamiento


es similar al del bucle for.

El programa comprueba el valor de lo que se halle conectado al terminal condicional al finalizar el bucle. Por lo
tanto, el bucle siempre se ejecuta al menos una vez.

Con esta estructura también se pueden emplear los shift registers para tener disponibles los datos obtenidos en
iteraciones anteriores (es decir, para memorizar valores obtenidos). Su empleo es análogo al de los bucles for,
por lo que omitirá su explicación.

5. NODOS CON FORMULAS

La estructura denominada Formula Node se emplea para introducir en el diagrama de bloques fórmulas de un
modo directo. Resulta de gran utilidad cuando la ecuación tiene muchas variables o es relativamente compleja.
Por ejemplo, se desea implementar la ecuación:

2
y=x +x+1

Empleando bloques pertenecientes al lenguaje G quedaría:


Si se utiliza la formula node, se obtiene:

Para definir una fórmula mediante esta estructura, se actuará del siguiente modo:

- En primer lugar, se deben definir las variables de entrada y las de salida. Para ello, se pulsa con el botón
derecho del ratón sobre el borde de la formula node. A continuación se seleccionará Add Input o Add
Output, según se trate de una entrada o una salida, respectivamente. Aparecerá un rectángulo, en el que se
debe escribir el nombre de la variable (se distingue entre mayúsculas y minúsculas). Todas las variables que
se empleen deben estar declaradas como entradas o salidas. Las que se empleen como variables intermedias
se declararán como salidas, aunque posteriormente no se unan a ningún bloque posterior.
- Una vez definidas las variables a emplear, se escribirán la o las fórmulas en el interior del recuadro (para
ello se emplea la labeling tool). Cada fórmula debe finalizar con un “;”.
- Los operadores y funciones que se pueden emplear se explican en la ayuda de LabVIEW, y son los que se
muestran a continuación:

La sintaxis de una expresión incondicional es la siguiente:

Si el valor lógico de la expresión condicional es true se ejecutará texpresión. Si, por el contrario, fuese false, lo
que se aplicará será fexpresión.

Como ejemplo considérese el siguiente fragmento de código:

Se puede implementar este fragmento de código empleando un formula node, tal y como se muestra en la
siguiente figura:

DESARROLLO:
Todas las partes se desarrollaron de acuerdo a lo que se especifica en la práctica, siguiendo los pasos indicados.
Parte 1. Autoajuste
Este programa genera números aleatorios hasta que el numero generado cumpla la especificación del
número deseado que se ha especificado. El terminal de conteo del bucle registrara el número de
iteraciones antes que el número se alcance.

 Abrir un nuevo panel frontal


 Construir el siguiente esquema en el panel frontal . Number to match (funtions—numeric –
numeric control ). Current number y #of iterations (funtions --- numeric – numeric
indicador ), para colocar las indicaciones de uso hacer uso de Tool palette — edit text .
El control Number to Match específica el número al cual se desea alcanzar. El indicador
Current Number indica en valor actual del número aleatorio. El indicador # of iterations
visualiza el numero de iteraciones antes de alcanzar al numero deseado.
 Para configurar las restricciones , de un click derecho en el control Number to match y del
menú seleccionar Data Range . La caja de dialogo Data Range aparecera .
 Configurar la caja de dialogo de data range con los siguiente valores

 Después dar clic en OK


 Dar un clic derecho en el indicador current number y del menú seleccionar Format &
Presicion , aparecerá la caja de dialogo de Format &Presicion .En Precisión of type
seleccionar Digits of precision y en digits colocar 0
.
 Dar u clic en OK
 Repetir los dos pasos anteriores para # of iterations
 Construir el siguiente diagrama de bloques

 Funtions ---numeric--- add , multiply , Round to nearest , increment, Random


number(0-1)
 Funtions ---comparison --- not equal ?
 Dar click derecho sobre Multiply ---create ---constant
 Y en el valor de la constante poner el numero 10000

 Ubicar el bucle while en Funtions – structures


 Guarde el VI como Auto Match.vi.
 Para probar el programa en Number to match poner un valor cualquiera y ejecutar el
VI
 Si se desea visualizar como el VI actualiza el indicador Current number presionar el
botón Highlight Execution que esta en el diagrama de bloques

Parte 2. Ejemplo de uso de Registros de Desplazamiento VI


 Construir el siguiente esquema en el panel frontal

X(i) visualizara el valor actual ,X(i-1 )el valor anterior y asi sucesivamente , al final tendremos lo tres
valores anteriores al valor final
 Construir el siguiente diagrama de bloques
 Colocar los registros de despalamiento , para crear un registro de desplazamiento de un click
derecho al lado izquierdo o derecho de los bordes de los bucles y seleccionando Add Shift
Register

 El bucle for se encuentra en Funtions ---Structutes

 Guarde el archivo como Shift Register.vi


Parte 3. Raíz Cuadrada VI
 Construir el siguiente diagrama de bloques
 Construir el siguiente diagrama de bloques

 La estructura case se encuentra ubicada en Funtions---Structures


 Square root esta ubicada en Funtons ---numeric
 Greater of equal to 0? Esta ubicada en Funtions ----- comparison
 One button dialog esta ubicada en funtions –Dialog&user interface ; este boton hara visualizar el
siguiente mensaje cuando la raíz no sea un valor positivo Error...Negative Number , en el terminal
de mensaje de one button dialog dar clic derecho sobre mensaje y crear una constante y topear el
mensaje anterior
 Guarde el VI como Square Root.vi
 Cuando se cumpla el caso TRUE la raiz cuadrada se visualizara en el indicador Square root value
.

Cuando se cumpla el caso false se visualizara en pantalla lo siguiente , al hacer click en OK en Squre
root value aparece el valor de -99999, constante que se pueso en el caso false al indicador
Parte 4. Tiempo de Emparejamiento en un VI
Este VI calcula el tiempo que tome en generar un numero aleatorio que sea igual al numero
especificado.
 Abrir el VI auto match.vi.
 Modificar el Panel de control como se muestra en la figura

 Cambiar el number to match , current number of iterations a una reoresentacion I32 , para
esto haga click derecho en cada uno de ellos aparecera un menu selecionar Representation
----I32 .
 Cambiar a time to match a una representation DBL
 Modificar el diagrama de bloques como sigue :
 Cambiar el bucle while por una estructura Squence
 La estructura Squence esta ubicada en Funtions --- Structures
 Dar un clic derecho en el borde de la estructura squence y seleccionar del menú emergente
Add frame after así podremos visualizar la secuencia en la que se encuentra la estructura
 Tick count se encuentra ubicada en Funtions – timing . Esta función lee el valor actual del reloj
del sistema operativo y retorna el valor en milisegundos.
 Guardar el archivo como Time to Match.vi.

Por lo tanto Tick count que esta fuera de la estructura squence tomara el valor cuando empieze la secuencia , y
el tick count que esta dentro (secuencia 1)tomara el valor en la ultima secuencia , entonces el valor del tick count
fuera de la estructura y el tick count dentro de la estructura (secuencia 1) se restan y al dividirlo entre 1000
obtendremos el tiempo en segundos

RESULTADOS

AUTOAJUSTE
REGISTROS DE DESPLAZAMIENTO VI:

RAIZ CUADRADA

TIEMPO DE EMPAREJAMIENTO EN UN VI
PREGUNTAS

1. Cuales son las diferencias entre un bucle For y un bucle While?

Un Bucle While es una estructura que repite una sección de código hasta que se cumpla una condición
determinada.
• En cambio , un Bucle For ejecuta una sección de código un determinado número de veces.

2. Como los datos son transferidos entre las iteraciones de los bucles?

Para el bucle for:

El terminal izquierdo almacena el valor obtenido en la iteración anterior. El Terminal derecho guardará el
dato correspondiente a la iteración en ejecución. Dicho dato aparecerá, por tanto, en el Terminal izquierdo
durante la iteración posterior.

Se puede configurar un shift register para memorizar valores de varias iteraciones previas. Para ello, con el
ratón situado sobre el terminal izquierdo del shift registe,r se pulsará el botón derecho, seleccionando a
continuación la opción Add Element.
Para el bucle while:

Con esta estructura también se pueden emplear los shift registers para tener disponibles los datos obtenidos
en iteraciones anteriores (es decir, para memorizar valores obtenidos). Su empleo es análogo al de los bucles
for, por lo que omitirá su explicación.

3. Como se ejecuta una estructura Case?

Una estructura Case, son dos o mas subdiagramas de manera que solo uno de ellos se ejecuta (el que cumpla
la condición) cuando la estructura se ejecuta. Esto depende del valor que cableemos al selector representado
con el simbolo [?]. la estructura se ejecuta solamente un caso a la vez. Un valor de entrada determina cual
subdiagrama se ejecutara.

El titulo del selector se encuentra en la parte superior de la estructura, contiene el nombre del valor del
selector que corresponde en cada caso y puede ser decrementada o incrementada a través de las flechas de
cada lado.

Conecta un valor de entrada, o selector, al terminal del selector para determinar cual caso se ejecutara. Se
debe de conectar datos del tipo entero, Booleano, cadenas, o tipos enumerados para el terminal del selector.

Se puede colocar el terminal de selección en cualquier lugar del borde izquierdo de la estructura. Si el tipo de
selector es Booleano, la estructura poseerá solo 2 casos el TRUE y el FALSE. Si el terminal de selección es
un entero, cadena, o del tipo enumerado, la estructura podrá tener muchos casos de ejecución.

4. Como se ejecuta una estructura Sequence?

La estructura Secuencia, que se ilustra como diapositivas o negativos de una película, ejecuta los diagramas
de bloques de forma secuencial. En lenguajes de programación convencionales el código se ejecuta en el
orden en que va apareciendo, G utiliza esta estructura para controlar el orden en que los nodos se van
ejecutando.

5. Cuando se utiliza un nodo de formulas, que ocurre si el nombre de la entrada es el mismo que el de
la salida?

El nodo Fórmula se utiliza para ejecutar fórmulas matemáticas directamente. Es muy práctico cuando una
ecuación es de muchas variables y de otra forma sería muy complicado. Cuando una entrada y salida tienen
el mismo nombre el programa no genera error , pero nunca 2 entradas o 2 salidas pueden tener el mismo
nombre porque se genera error en el programa , pero una salida puede tener el mismo nombre de una entrada
CONCLUSIONES

 Los bucles simplifican los algoritmos de programación

 La estructura case tiene dos o mas subdiagramas si trabaja con datos de tipo booleano y es visible
uno a la vez por lo tanto el subdiagrama que se ejecuta depende de la condicion que esta fuera de la
estructura .

 Los nodos de formulas son utiles para ejecutar ecuaciones matematicas , además no hay problema
cuando una entrada tiene el nombre de la salida, y si cuando dos entradas o dos salidas tienen el
mismo nombre.

You might also like