Diagrama de Flujo de Datos
Diagrama de Flujo de Datos
Diagrama de Flujo de Datos
Definición:
El diagrama de flujo de datos es un modelo que describe los flujos de datos o tuberías, los procesos que
cambian o transforman los datos en un sistema, las entidades externas que son fuente o destino de los datos (y
en consecuencia los límites del sistema) y los almacenamientos o depósitos de datos a los cuales tiene acceso
el sistema, permitiendo así describir el movimiento de los datos a través del sistema.
•ð los lugares de origen y destino de los datos (los límites del sistema),
•ð las transformaciones a las que son sometidos los datos (los procesos internos),
•ð los lugares en los que se almacenan los datos dentro del sistema, y
•ð los canales por donde circulan los datos.
Características:
•ð Relevante: Ya que posibilitar comunicar diferentes modelos para así facilitar el entendimiento
entre el usuario y el analista de sistemas.
•ð Lógico: Ya que no identifica soporte físico.
•ð Descendente: Se construye en forma descendente, de lo general a lo particular.
Simbología:
Entidad Externa:
Son generalmente clases lógicas de cosas o de personas, las cuales representan una fuente o destino de
transacciones, como por ejemplo clientes, empleados, proveedores, etc., con las que el sistema se comunica.
También pueden ser una fuente o destino específico, como por ejemplo Departamento Contable.
1
Como el sistema que esta bajo análisis acepta datos de otro sistema o bien se los provee, este otro sistema es
una Entidad Externa.
Mediante la designación de alguna cosa o de algún sistema como Entidad Externa estamos estableciendo
implícitamente que se encuentra fuera de los límites del sistema que estamos considerando por lo cual no nos
interesa la transformación o proceso que se realiza dentro de ellos, es decir que están fuera del control del
sistema que se está modelando. Son sólo proveedores o requeridores de datos del sistema bajo consideración.
Por todo ello, ni el analista ni el diseñador pueden cambiar ni los contenidos ni la forma de trabajo de un
terminador.
Proceso:
Indican aquellos lugares dentro del sistema en donde la información (flujos de datos) que ingresan se procesan
o transforman. Es decir, son las funciones o procesos que transforman entradas de datos en salidas de
información.
Su nombre deberá ponerse mediante una frase imperativa, que consistirá idealmente de un verbo activo
seguido por una claúsula objeto, cuanto mas simple mejor. Al analista le servirá pensar que la descripción de
la función es "una orden a un empleado sin conocimiento del tema". Estas frases imperativas no tienen sujeto;
tan pronto como se introduce un sujeto se habrá indicado como deberá realizarse físicamente la función ("El
operador ingresará los datos del alumno").
Un proceso puede ser físicamente una oficina repleta de empleados, un procedimiento, o una combinación de
actividades manuales y automatizadas.
Flujo de datos:
Representa un transporte de paquetes de datos desde su origen hasta su destino, es decir que representa una
estructura de datos en movimiento de una parte del sistema a otro.
Puede imaginarse como una tubería por donde se envían paquetes de datos, pero deberá tener una descripción
de su contenido la cual deberá elegirse de forma que sea lo más útil posible a los usuarios que revisen el DFD.
Puede estar contenido físicamente en una nota, una factura, una llamada telefónica, de programa a programa,
etc. Es decir, en cualquier medio por el cual los datos pasan de una entidad o proceso a otra.
Almacén o archivo:
Representa un archivo lógico en donde se agregan o de donde se extraen datos. Es una estructura de datos,
2
pero estática.
Puede ser físicamente un archivo de tarjetas, una microficha, un archivo, o un archivo en cinta o diskette.
Deberá elegirse el nombre que sea más descriptivo para el usuario, que identifique los paquetes de datos que
contiene.
• 1. Primero se deberán identificar las entidades externas ya que ello implica definir los límites del
sistema.
• 2. Se deberán elegir nombres con significado tanto para procesos como también para flujos de datos,
almacenes y entidades externas. Si es posible a partir del vocabulario del usuario evitando terminologías
técnicas.
• 4. Numerar los procesos, mediante un esquema de numeración consistente que implique, para los lectores
del DFD, una cierta secuencia de ejecución.
• 5. Se deberán, en la medida de lo posible, evitar los DFD excesivamente complejos. Deberán ser
comprensibles, digeribles y agradables a la vista sin demasiados elementos.
3
• 7. Procesos: Se relacionarán con:
•ð Almacenes
•ð Entidades externas
•ð Otros procesos
•ð Deberán tener al menos una Entrada y una Salida, no son manantiales de datos.
• 10. En todos los niveles del Diagrama de Flujo de Datos deberá haber igual cantidad de Entradas y de
Salidas.
• 12. Cada proceso en el DFD de alto nivel de un sistema puede ser "explotado" para convertirse en un DFD
en si mismo.
• 13. Cada proceso en el nivel inferior deberá estar relacionado, inversamente, con el proceso del nivel
superior. Es decir que, cada proceso padre que se detalla en el DFD, ha de estar balanceado. La regla del
balanceo consiste en que cada proceso debe tener exactamente los mismos datos de entrada/salida netos que
el DFD hijo.
• 14. Los flujos de datos pueden descomponerse en la explosión del proceso en un DFD hijo.
4
• 15. No se deberá prestar atención a las condiciones de tiempo, excepto a las naturales precedencias lógicas
y a los almacenamientos de datos necesarios desde el punto de vista lógico. Se deberá dibujar un sistema
que nunca comience ni pare.
• 16. Para evitar el cruzamiento de las líneas de flujo de datos, la misma entidad (o el mismo almacén) se
podrá dibujar mas de una vez en el mismo diagrama; las dos (o mas) casillas por entidad pueden
identificarse con dos líneas inclinadas en el ángulo superior izquierdo de las mismas.
Proceso
• Círculo.
• Muestra una parte del sistema que transforma entradas en salidas.
• Se nombra con una frase u oración sencilla (preferentemente frase verbo−objeto).
Flujo de datos
1.3. Almacén
5
• Modeliza una colección de paquetes en reposo.
• Puede ser requerimiento fundamental o aspecto conveniente de la realización del sistema.
• Ejemplos de aspectos convenientes de interponer un almacén entre dos procesos:
• Ambos procesos se ejecutan en la misma computadora pero no hay memoria suficiente (o algún otro
recurso de hardware)
• Se espera que cualquiera de los procesos se ejecute en hardware poco confiable
• Se espera que diferentes programadores implementen los dos procesos
• El analista o diseñador pensaron que algún día el usuario necesitaría acceder
• Un flujo que viene de un sistema se interpreta como una lectura o un acceso a la información del
almacén (no destructiva)
• Un flujo hacia un almacén se describe como una escritura, una actualización o una eliminación
1.4. Terminador
• Rectángulo.
• Representan entidades externas con las cuales el sistema se comunica.
• Persona, Organización externa, Organismo gubernamental, grupo o departamento dentro de la
organización.
Usar un verbo y un objeto. Evitar verbos ambiguos: hacer, manejar, procesar, etc.
• Técnicamente correcto
• Aceptable para el usuario
• Estar lo suficientemente bien dibujado para mostrarlo a la dirección de la organización
6
Para mejorarlo estéticamente:
Organizar el DFD global en una serie de niveles de modo que cada uno proporcione más detalle sobre una
porción del nivel anterior.
El primer nivel consta de una sola burbuja que representa la totalidad del sistema (diagrama de contexto). El
DFD que sigue se conoce como nivel 0 y representa la vista de más alto nivel de las principales funciones del
sistema.
Los números de las burbujas sirven para relacionar una burbuja con el nivel siguiente del DFD.
• ¿Cuántos niveles?
• ¿Deben partirse todas las partes del sistema al mismo nivel de detalle?
7
No, pero cuidado con los extremos.
De forma descendente.
• ¿Cómo asegurar que los distintos niveles sean consistentes entre sí?
Los flujos de datos que entran y salen de una burbuja en el nivel i deben corresponder con los que entran y
salen de toda la figura correspondiente del nivel i+1 que la describe.
Un almacén que aparece en un nivel i se puede repetir en los niveles sucesivos de refinamiento i+1, i+2, etc.
Pero un almacén local al nivel i no aparecía en los niveles anteriores i−1, i−2, etc.
Un enfoque que tiene más éxito es identificar los acontecimientos externos a los cuales debe responder el
sistema y utilizarlos para crear un primer borrador del DFD. De ahí puede partirse hacia arriba (para crear
DFD de mayor nivel de abstracción) y hacia abajo.
a) ¿Que es Dfd?
Dfd es un software diseñado para construir y analizar algoritmos . Usted puede crear diagramas de flujo de
datos para la representación de algoritmos de programación estructurada a partir de las herramientas de
edición que para éste propósito suministra el programa. Después de haber ingresado el algoritmo representado
por el diagrama, podrá ejecutarlo, analizarlo y depurarlo en un entorno interactivo diseñado para éste fin. La
interfaz gráfica de Dfd, facilita en gran medida el trabajo con diagramas ya que simula la representación
estándar de diagramas de flujo en hojas de papel.
b) Algoritmo
8
un diagrama de flujo de datos se comienza por el INICIO y se siguen las flechas de figura a figura,
ejecutándose las acciones indicadas por cada figura; el tipo de figura indica el tipo de paso que representa.
Los diagramas de flujo son frecuentemente usados debido a que pueden suprimir detalles innecesarios y tener
un significado preciso, si son usados correctamente.
d) Tipos de Datos
Real: Valores numéricos que van desde −1*10 ^ 2000 hasta 1*10 ^ 2000 . Los valores más cercanos a 0 que
se pueden manejar son 1*10 ^ −2000 y −1*10 ^ −2000.
Lógico: La letra V ó F encerrada entre puntos, para indicar verdadero ó falso respectivamente.
e) Campos de Datos
Variables: Es posible modificar su valor. El nombre de una variable debe comenzar por una letra seguida de
letras, números o el caracter ( _ ).
No se tiene en cuenta la diferencia entre mayúsculas y minúsculas para el nombre de una variable; es decir,
CASA equivale a casa. Cuando una variable recibe un valor por primera vez, el tipo de dato de ésta será igual
al tipo de dato del valor.
f) Arreglos
Dfd soporta arreglos n−dimensionales de cualquier tipo de dato. El nombre de un arreglo debe comenzar por
una letra seguida de letras, números o el carácter ( _ ).
No se tiene en cuenta la diferencia entre mayúsculas y minúsculas para el nombre de un vector; es decir,
VECTOR(2) equivale a vector(2).
g) Interfaz de Usuario
Dfd posee una ventana principal que proporciona el ambiente de trabajo en donde se pueden construir y
analizar algoritmos. Los componentes básicos de la ventana principal son: La barra de menú, barras de
herramientas, barras de desplazamiento y el área de trabajo.
9
h) Acción Actual
Edición
Ejecución
Depuración
La barra de estado ubicada ubicada en la parte inferior de la ventana de Dfd muestra la acción actual.
i) Subprograma Actual
En Dfd, solo un subprograma (incluyendo el principal) puede ser visualizado a la vez, considerándose éste el
Subprograma Actual.
j) Errores de Sintaxis
Estos errores son detectados en tiempo de revisión cuando se intenta ejecutar un algoritmo que contiene
expresiones incorrectas. El mensaje de error correspondiente será mostrado y se indicara el objeto en el que se
produjo el error.
2. SISTEMA DE MENÚS
a) Menú Archivo
Archivo | Nuevo
Barra de herramientas:
Teclado: CTRL + N
Dfd da como nombre temporal al nuevo diagrama Sin nombre.dfd, hasta que éste sea guardado con un nombre
de archivo único. Al ejecutar este comando quedará seleccionada la opción Angulos en Grados del menú
Opciones.
Archivo | Abrir
Inicia la sesión de trabajo con un diagrama ya existente, con este comando puede abrir un archivo de Dfd y
comenzar a trabajar sobre él.
Barra de Herramientas
10
Teclado CTRL + A
Al abrir un archivo de Dfd, las opciones del menú Opciones, tomarán el estado que tenían en el momento en
que fue guardado el archivo.
Archivo | Guardar
Guarda en disco el diagrama que se está editando(principal y subprogramas) y el estado del menú Opciones,
como un archivo de extensión dfd.
A medida que Usted trabaja va haciendo cambios en el diagrama original, por lo cual es conveniente guardar
con frecuencia el diagrama.
Barra de herramientas
Teclado CTRL + G
El comando Guardar Como guarda en disco permite colocar un nombre al diagrama en edición. Se despliega
un cuadro de diálogo donde se selecciona el nombre y la ubicación (unidad y directorio) del archivo en cual se
va a guardar el diagrama.
Teclado ALT + A , C
Archivo | Imprimir
Este comando despliega el cuadro de diálogo de impresión del sistema, el tamaño del diagrama a imprimir
será proporcional al tamaño del diagrama que se visualiza en pantalla.
Barra de herramientas
Teclado CTRL + P
Archivo | Salir
Teclado ALT + A , S
Si el diagrama en edición no ha sido guardado desde la última modificación, Dfd le preguntará si desea
guardar antes de salir.
b) Menú Edición
11
Edición | Cortar
Este comando se usa para eliminar un objeto seleccionado de un diagrama y colocarlo en el portapapeles de
Dfd . El comando Cortar estará disponible cuando un objeto eliminable se encuentre seleccionado y la acción
actual sea Edición.
Barra de herramientas
Teclado CTRL + X
Cuando se cortan objetos, estos reemplazan el contenido del portapapeles de Dfd . Los objetos que conforman
estructuras de control serán cortados junto con su cuerpo.
Edición | Copiar
Este comando se usa para obtener una copia del objeto seleccionado en el portapapeles de Dfd. El objeto
seleccionado queda intacto; es decir, no se remueve del diagrama. El comando Copiar estará disponible
cuando exista un objeto eliminable seleccionado y la acción actual sea Edición.
Barra de herramientas
Teclado CTRL + C
Cuando se copian objetos, estos reemplazan el contenido del portapapeles de Dfd. Los objetos que conforman
estructuras de control serán copiados juntos con su cuerpo.
Edición | Pegar
Use este comando para insertar una copia del contenido del portapapeles de Dfd a continuación del objeto
seleccionado. El comando Pegar estará disponible cuando el portapapeles de Dfd no esté vacío, exista un
objeto seleccionado y la acción actual sea Edición.
Barra de herramientas
Teclado CTRL + V
Después de haber sido pegado, el objeto permanece en el portapapeles de Dfd, de manera que puede pegarlo
las veces que desee.
Edición | Eliminar
Este comando elimina el objeto seleccionado del diagrama sin colocarlo en el portapapeles de Dfd . Se
encontrará disponible cuando un objeto eliminable se encuentre seleccionado y la acción actual sea Edición.
12
Barra de herramientas
Teclado SUPR
Los objetos que conforman estructuras de control serán eliminados junto con su cuerpo. En caso de que el
objeto seleccionado sea de tipo subprograma, entonces se ejecutará el comando Eliminar Subprograma.
Este comando se usa para eliminar todos los objetos que conforman un subprograma. El comando estará
disponible cuando esté visualizado un subprograma (no el principal) y la acción actual sea Edición.
Barra de herramientas
Teclado ALT + E, S
Este comando se utiliza para insertar a continuación del objeto seleccionado un objeto del tipo que indique el
ítem seleccionado en el menú Objeto; es decir, el último objeto seleccionado en la barra de herramientas.
El comando estará disponible cuando exista un objeto seleccionado, el ítem seleccionado en el menú Objeto
sea diferente de Cursor y la acción actual sea Edición.
Teclado INS
Este comando se utiliza para editar el contenido de un objeto seleccionado. Estará disponible cuando se
encuentre seleccionado un objeto editable y la acción actual sea Edición.
Teclado ENTER
c) Menú Objeto
Objeto | Cursor
Este comando selecciona el cursor normal del Mouse, el cual se puede usar para:
13
Otras formas de acceder al comando:
Barra de herramientas
Teclado ALT + O, C
Cuando la acción actual es diferente de Ejecución, el cursor normal puede cambiar dependiendo de la posición
del apuntador del Mouse.
Es la flecha de cursor que se presenta cuando el apuntador del Mouse no está sobre ningún objeto. La forma
de este puntero depende de las propiedades del Mouse que maneja el sistema.
El cursor en forma de mano señalando se presenta cuando el apuntador del Mouse se sitúa sobre un objeto que
se puede seleccionar, éste indica que se puede seleccionar, quitar la selección de otro objeto ó editar el objeto
Hacer clic con el botón izquierdo del Mouse dentro de un objeto selecciona el objeto y quita la selección a
cualquier otro que se encuentre seleccionado en el subprograma actual. Hacer clic con el botón izquierdo del
Mouse sobre un área vacía del diagrama quita la selección del objeto. Hacer doble clic con el botón izquierdo
del Mouse sobre un objeto editable invoca al correspondiente cuadro de diálogo para la edición.
Objeto | Asignación
Este comando se utiliza para indicar que el siguiente objeto a ser insertado en el diagrama es de tipo
Asignación.
Barra de herramientas
Teclado ALT + O, A
14