El Análisis Estructurado (SA) en ingeniería de software y su técnica aliada, Diseño estructurado (SD), es un conjunto de métodos orientados a analizar y convertir requisitos de negocio en especificaciones y en última instancia, programas informáticos, configuraciones de hardware y procedimientos manuales relacionados.
Las técnicas de análisis y diseño estructurados son herramientas fundamentales de análisis de sistemas desarrolladas a partir de análisis de sistemas clásicos de los años 1960 y 1970.[2]
Objetivos del Análisis Estructurado
El análisis estructurado se hizo popular en las década de 1980 y sigue siendo utilizado por muchos. El análisis consiste en interpretar el concepto del sistema (o situaciones del mundo real) en datos y controlar la terminología representada por el diagrama de flujo de datos. El flujo de datos y el control de la burbuja para el almacén de datos de la burbuja pueden ser muy difíciles de seguir y el número de burbujas puede llegar a ser muy grande. Un enfoque es definir primero los eventos del mundo exterior que requieren que el sistema reaccione, a continuación, asignar una burbuja para ese evento, las burbujas que necesitan interactuar se conectan luego hasta que se defina el sistema. Esto puede ser bastante abrumador y así las burbujas suelen agruparse en burbujas de nivel superior. Se necesitan los Diccionario de datos para describir los flujos de datos y de mando como también se necesita una especificación de proceso para capturar la información de la transacción/transformación.[3]
El análisis estructurado es parte de una serie de métodos estructurados, que "representan una colección de técnicas de análisis, diseño y programación que se desarrollaron en respuesta a los problemas que enfrenta el mundo del software desde 1960 hasta la década de 1980. En este marco de tiempo más programación comercial se hizo en Cobol y Fortran, luego en Lenguaje C y BASIC. Hubo poca orientación sobre las "buenas" técnicas de diseño y programación, y no había técnicas estándar para la documentación de requisitos y diseños. Los sistemas fueron cada vez más grandes y más complejos, y el desarrollo de sistemas de información se hicieron más y más difíciles de hacer ".[4] Como una manera de ayudar a manejar un software grande y complejo, surgieron los siguientes métodos estructurados.
Desde finales de la década de 1960 varios Métodos Estructurados surgieron:[4]
Según Hay (1999) "La ingeniería de la información era una extensión lógica de las técnicas estructuradas que se desarrollaron durante la década de 1970. La programación estructurada condujo al diseño estructurado, que a su vez condujo a sistemas de análisis estructurado. Estas técnicas se caracterizan por su uso de diagramas: diagramas de estructura para el diseño estructurado y diagramas de flujo de datos para el análisis estructurado, tanto para ayudar en la comunicación entre usuarios y desarrolladores, y para mejorar el análisis de la disciplina y del diseñador. Durante la década de 1980, comenzaron a aparecer herramientas para el dibujo de los diagramas automatizados, y llevaron un registro de las cosas dibujadas en un diccionario de datos".[8] Después del ejemplo de diseño asistido por computadora y la fabricación asistida por computadora (CAD / CAM), el uso de estas herramientas fue nombrada la Herramienta CASE.
Temas de análisis estructurado
Sencillo mecanismo de resumen
El análisis estructurado normalmente crea una jerarquía que emplea un único mecanismo de resumen. El método de análisis estructurado puede emplear IDEF (ver figura), es un proceso conducido, y comienza con un propósito y un punto de vista. Este método identifica la función global y de forma iterativa divide funciones en funciones más pequeñas, entradas conservantes, salidas, controles y mecanismos necesarios para optimizar los procesos. También es conocido como un enfoque de descomposición funcional, se centra en la cohesión dentro de las funciones y de acoplamiento entre las funciones que llevan a los datos estructurados.[9]
La descomposición funcional del método estructurado describe el proceso sin delinear el comportamiento del sistema y la estructura del sistema dictados en forma de funciones requeridas. El método identifica las entradas y salidas en relación con las actividades. Una de las razones de la popularidad del análisis estructurado es su capacidad intuitiva para comunicar procesos y conceptos de alto nivel, si los niveles del sistema son sencillos o empresariales. El descubrimiento de cómo los objetos pueden ayudar a las funciones de desarrollo orientado a objetos comercialmente está claro. En contraste con IDEF, el UML está impulsada con múltiples interfaces de mecanismos de resumen útiles para describir las arquitecturas orientadas a servicios (SOAs).[9]
Enfoque
El análisis estructurado considera un sistema desde la perspectiva de los datos que fluyen a través de él. La función del sistema es descrita por procesos que transforman los flujos de datos. El análisis estructurado se aprovecha de la ocultación de información a través del análisis de descomposición sucesiva (o de arriba hacia abajo). Esto permite que la atención se centre en los detalles pertinentes y evita la confusión de mirar los detalles irrelevantes. Como el nivel de detalle aumenta, se reduce la amplitud de la información. El resultado del análisis estructurado es un conjunto relacionado de diagramas, gráficas, descripciones de procesos, y las definiciones de datos. Ellos describen las transformaciones que deben llevarse a cabo y los datos necesarios para cumplir con el Requisito funcional de un sistema.[10]
El enfoque de De Marco[11] consta de los siguientes objetos (véase el gráfico):[10]
Con el diagrama de flujo de datos (DFDs) se dirigen gráficos. Los arcos representan los datos, y los nodos (círculos o burbujas) representan procesos que transforman los datos. Un proceso se puede descomponer además a un DFD más detallado que muestra los subprocesos y los flujos de datos dentro de ella. Los subprocesos pueden a su vez descomponerse aún más con otro conjunto de DFD hasta que sus funciones se pueden entender fácilmente. Las funciones primitivas son procesos que no necesitan ser descompuestas aún más. Estas funciones primitivas se describen por una especificación de proceso (o mini-spec). La especificación del proceso puede consistir en pseudocódigo, diagramas de flujo, o Inglés estructurado. En el modelo de DFD la estructura del sistema es como una red de procesos interconectados compuestos de funciones primitivas. El diccionario de datos es un conjunto de entradas (definiciones) de los flujos de datos, elementos de datos, archivos y bases de datos. Los diccionarios de datos se dividen de una manera de arriba hacia abajo. Estos pueden ser referenciados en otras entradas del diccionario de datos y en los diagramas de flujo de datos.[10]
Diagrama de contexto
Los Diagrama de contexto de sistema son diagramas que representan los usuarios que fuera de un sistema podrían interactuar con él.[13] Este diagrama es la vista de más alto nivel de un sistema, similar al diagrama de bloques, que muestra, posiblemente un sistema de software basado en entradas y salidas además de sus factores externos.
Este tipo de diagrama según Kossiakoff (2003) por lo general "muestra el sistema en el centro, sin detalles de su estructura interior, rodeado de todos sus sistemas de interacción, medio ambiente y actividades. El objetivo de un diagrama de contexto del sistema es centrar la atención en factores y eventos que deben ser considerados en el desarrollo de un conjunto completo de las propuestas del sistema y las limitaciones externas".[13] El diagrama de contexto del sistema está relacionado con el Diagrama de flujo de datos, y muestran las interacciones entre un sistema y otros usuarios con los que el sistema está diseñado para hacer frente. Un diagrama de contexto del sistema puede ser útil para comprender el contexto en el cual el sistema será parte de la ingeniería de software.
Diccionario de datos
Un diccionario de datos o diccionario de base de datos es un archivo que define la organización básica de una base de datos. Un diccionario de la base de datos contiene una lista de todos los archivos de la base de datos, el número de registros en cada archivo, y los nombres y tipos de cada campo de datos. La mayor parte del sistema de gestión de base de datos mantiene el diccionario de datos ocultos a los usuarios para evitar la destrucción accidental de los contenidos. Los diccionarios de datos no contienen los datos reales de la base de datos, sólo la contabilidad de información para su gestión. Sin un diccionario de datos, sin embargo, un sistema de gestión de base de datos no puede acceder a los datos desde la base de datos.
Los usuarios de bases de datos y desarrolladores de Aplicación informática pueden beneficiarse de un documento del diccionario de datos de una autoridad que cataloga la organización, contenidos, y las convenciones de una o más bases de datos.[14] Esto incluye típicamente los nombres y las descripciones de varias tablas y campos en cada base de datos, además de detalles adicionales, como el tipo y la longitud de cada elemento de datos. No hay un estándar universal para el nivel de detalle en un documento de este tipo, pero es sobre todo una destilación de metadatos acerca de la estructura y diseño de la Base de datos, no los datos en sí. Un documento de diccionario de datos también puede incluir información que describe cómo se codifican los elementos de datos. Una de las ventajas del buen diseño de la documentación del diccionario de datos es que ayuda a establecer la coherencia en una base de datos compleja, a través de una gran colección de bases de datos federada.[15]
Es una práctica común dibujar un Diagrama de contexto de sistema que primero muestra la interacción entre el sistema y entidades externas. El DFD está diseñado para mostrar cómo un sistema se divide en porciones más pequeñas y para resaltar el flujo de datos entre las partes. Este diagrama de flujo de datos de nivel de contexto se "explotó" para mostrar más detalles del sistema que se está modelando.
Los diagramas de flujo de datos (DFDs) son una de las tres perspectivas esenciales de Método de análisis y diseño de sistemas estructurados (SSADM). El patrocinador de un proyecto y los usuarios finales tendrán que ser informados y consultados en todas las etapas de la evolución de un sistema. Con un diagrama de flujo de datos, los usuarios son capaces de visualizar cómo funcionará el sistema, lo que el sistema va a lograr, y cómo se implementará el sistema. Los diagramas de flujo de datos del viejo sistema se pueden elaborar y comparar con los diagramas de flujo de datos del nuevo sistema para implementar un sistema más eficiente. Los diagramas de flujo de datos se pueden utilizar para proporcionar al usuario final con una idea física de donde los datos de entrada tienen en última instancia un efecto sobre la estructura de todo el sistema para ordenar una reestructuración. Cómo cualquier sistema es desarrollado puede determinarse a través de un diagrama de flujo de datos.
Diagrama de Estructura
Un diagrama de estructura (SC) es un gráfico que muestra la distribución del sistema de configuración de los niveles más bajos y manejables.[18] Esta tabla se usa en la programación estructurada para organizar los módulos de programa en una estructura de árbol. Cada módulo está representado por una caja que contiene el nombre del módulo. La estructura de árbol visualiza las relaciones entre los módulos.[19]
En análisis estructurado los diagramas de estructura se utilizan para especificar el diseño de alto nivel, o la arquitectura de un programa de computadora. Como una herramienta de diseño, ayudan al programador a dividir y conquistar un problema de software grande, es decir, de forma recursiva romper un problema en partes que son lo suficientemente pequeños para ser entendido por un cerebro humano. El proceso es llamado Top-down y bottom-up, o de descomposición funcional. Los programadores usan un diagrama de estructura para construir un programa de una manera similar a cómo un arquitecto utiliza un plano para construir una casa. En la etapa de diseño, el diagrama se dibuja y se utiliza como una manera para que el cliente y los diferentes diseñadores de software puedan comunicarse. Durante la construcción real del programa (aplicación), al gráfico se le refiere continuamente como el plan maestro.[20]
Diseño Estructurado
El Diseño Estructurado (SD) tiene que ver con el desarrollo de los módulos y la síntesis de estos módulos en una llamada "jerarquía de módulo".[21] Para el diseño de la estructura del módulo óptimo y las interfaces, estos dos principios son cruciales:
La cohesión en Diseño estructurado, que es "interés por la agrupación de procesos relacionados funcionalmente en un módulo en particular",[10] y
Acoplamiento informático, se refiere a "el flujo de información o parámetros que se pasan entre los módulos. El acoplamiento óptimo reduce las interfaces de módulos y la complejidad resultante del software ".[10]
El Diseño Estructurado fue desarrollado por Larry Constantino a finales de 1960, luego refinado y publicado con colaboradores en la década de 1970;[5][6] véase Larry Constantine: Diseño Estructurado para obtener más información Page-Jones (1980) ha propuesto su propio enfoque que consiste en tres principales objetos:
diagramas de estructura
Especificaciones del módulo
diccionario de datos.
El Diagrama de estructura compuesta tiene como objetivo mostrar "la jerarquía del módulo o llamada secuencia de relación de los módulos. Hay un módulo de especificación para cada módulo mostrado en el diagrama de estructura. Los especificaciones del modulo pueden estar compuestas de pseudocódigo o un lenguaje de diseño de programa. El diccionario de datos es como el del análisis estructurado. En esta etapa del Proceso para el desarrollo de software, después de haber realizado el análisis y el diseño, es posible generar automáticamente las declaraciones de tipo de datos ",[22] y de procedimientos o plantillas de subrutinas.[10]
Lenguaje de consulta estructurado
El lenguaje de consulta estructurado (SQL) es un lenguaje estandarizado para la consulta de la información de una base de datos. SQL se introdujo por primera vez como un sistema de bases de datos comerciales en 1979 y desde entonces ha sido el lenguaje de consulta favorita para los sistemas de gestión de base de datos que se ejecutan en sistemas grandes y medianos. Cada vez más, sin embargo, SQL está siendo apoyado por los sistemas de bases de datos de PC, ya que soporta las bases de datos distribuidas (véase la definición de base de datos distribuida). Esto permite que varios usuarios en una red informática puedan acceder a la misma base de datos al mismo tiempo. Aunque hay diferentes dialectos de SQL, sin embargo es lo más parecido a un lenguaje de consulta estándar que existe en la actualidad.
Herramientas de software para el análisis estructurado
Los problemas asociados con los diagramas de flujo de datos (DFD) pueden variar dependiendo del contexto y del enfoque de implementación, pero algunos de los problemas comunes incluyen:[3]
Selección adecuada de burbujas: Elegir correctamente las entidades y procesos representados por las burbujas puede ser complicado y puede llevar a una representación inexacta del sistema.
Particionado de burbujas: Dividir las burbujas en una manera significativa y acordada puede resultar difícil, especialmente en sistemas complejos donde las relaciones entre los componentes no son claras.
Tamaño de la documentación: El nivel de detalle necesario para entender completamente los flujos de datos puede ser excesivo, lo que lleva a una documentación voluminosa y difícil de manejar.
Naturaleza funcional y cambios frecuentes: Los DFDs tienden a ser muy funcionales en la naturaleza, lo que significa que están sujetos a cambios frecuentes a medida que evoluciona el sistema, lo que puede dificultar mantenerlos actualizados.
Énfasis en el flujo de datos sobre el modelado de datos: Aunque se enfatiza el flujo de datos, a menudo hay poca comprensión sobre la estructura de los datos subyacentes, lo que puede llevar a decisiones de diseño inadecuadas.
Dificultad para el cliente y los diseñadores: Tanto para los clientes como para los diseñadores, comprender cómo los conceptos se traducen en los flujos y burbujas de datos puede ser desafiante, lo que dificulta la comunicación efectiva y la implementación exitosa del sistema.
↑Belkhouche, B., and J.E. Urban. (1986). "Direct Implementation of Abstract Data Types from Abstract Specifications". In: IEEE Transactions on Software Engineering pp. 549-661, May, 1986.
Page-Jones, M (1980), The Practical Guide to Structured Systems Design, New York: Yourdon Press.
Derek J. Hatley, Imtiaz A. Pirbhai (1988). Strategies for Real Time System Specification. John Wiley and Sons Ltd. ISBN 0-932633-04-8
Stephen J. Mellor und Paul T. Ward (1986). Structured Development for Real-Time Systems: Implementation Modeling Techniques: 003. Prentice Hall. ISBN 0-13-854803-X