• No se han encontrado resultados

CAPÍTULO 1: Introducción la Ingeniería del Software. Ing. Alejandra Colina V. Enero, 2019

N/A
N/A
Protected

Academic year: 2022

Share "CAPÍTULO 1: Introducción la Ingeniería del Software. Ing. Alejandra Colina V. Enero, 2019"

Copied!
41
0
0

Texto completo

(1)

CAPÍTULO 1:

Introducción la Ingeniería del Software

Ing. Alejandra Colina V.

Enero, 2019

(2)

• Reconocer los elementos que conforman la Ingeniería del Software y sus principales componentes de estudio.

Objetivo del capítulo

(3)

Contenido

Software: definición, características, dominios de aplicación y software

heredados.

Proceso de Ingeniería de software

Ingeniería de software:

definición y capas

Modelos de ingeniería de software

Métodos de ingeniería de software

(4)

En la actualidad, el software tiene un papel dual.

Introducción la Ingeniería del Software

Producto

Vehículo para entregar producto

Transformador de información

Distribuir el producto

El software de computadora sigue siendo la tecnología más importante en la escena mundial.

Se considera una tecnología indispensable para los negocios, ciencias e ingeniería.

Crea nuevas tecnologías

Amplia tecnologías existentes

Cambio radical de tecnologías antiguas

(5)

¿Qué tipo de desarrollador se ve en la ilustración?

(6)

Definición de Software

(7)

Según Pressman (2010) el software es:

1) instrucciones (programas de cómputo) que cuando se ejecutan proporcionan las características, función y desempeño buscados;

2) estructuras de datos que permiten que los programas manipulen en forma adecuada la información, y

3) información descriptiva tanto en papel como en formas virtuales que describen la operación y uso de los programas

Introducción la Ingeniería del Software

(8)

Características del Software

(9)

El software se desarrolla o modifica con intelecto; no se manufactura en el sentido clásico.

El software no se “desgasta”.

Aunque la industria se mueve hacia la construcción basada en

componentes, la mayor parte del software se construye para un uso individualizado.

(10)

Dominios de aplicación del software

(11)

Existen siete grandes categorías de software de computadora como retos continuos a los ingenieros de software

Software de

sistemas(Sistemas operativos.

Compiladores)

Software de aplicación (Bases de datos y sistemas

de gestión de información)

Software de ingeniería y

ciencias

(Aplicaciones en la astronomía, física

cuántica,)

Software incrustado (Tablero de

refrigeradores, de microondas)

Software de línea de productos

(Control de inventario)

Aplicaciones web (Webapps)

Software de

inteligencia artificial (Elaboración de

algoritmos numéricos)

(12)

SOFTWARE HEREDADOS

(13)

Los sistemas de software heredado programas que han sido desarrollados hace varias décadas y modificados de manera continua para que satisfagan los cambios en los requerimientos de los negocios y plataformas de computación (Pressman, 2010).

Se convierten en dolores de cabeza para las organizaciones grandes, son costoso mantenerlos y riesgoso hacerlos evolucionar.

Definición

(14)

¿QUÉ HAGO SI ENCUENTRO UN SISTEMA

HEREDADO DE MALA CALIDAD?

(15)

Un software HEREDADO es de mala calidad cuando:

‒ No son susceptibles de extenderse

‒ Código confuso

‒ Documentación mala o inexistente

‒ Casos de pruebas y resultados nunca se archivaron

‒ Historia de los cambios mal administrada.

Sin embargo, AUN dan apoyo a las “funciones básicas del negocio y son indispensables para éste”.

¿Qué hacer?

(16)

¿QUÉ TIPOS DE CAMBIOS SE HACEN A LOS

SISTEMAS HEREDADOS?

(17)

‒ El software debe adaptarse para que cumpla las necesidades de los nuevos ambientes del cómputo y de la tecnología.

‒ El software debe ser mejorado para implementar nuevos requerimientos del negocio.

‒ El software debe ampliarse para que sea operable con otros sistemas o bases de datos modernos.

‒ La arquitectura del software debe rediseñarse para hacerla viable dentro de un ambiente de redes.

(18)

1. Muchas aplicaciones modernas cambian con frecuencia, antes de que se presenten al usuario final y después de que la primera versión ha entrado en uso. Sugiera algunos modos de elaborar software para detener el deterioro que produce el cambio.

2. Considere las siete categorías de software. ¿Piensa que puede aplicarse a cada una el mismo enfoque de ingeniería de software?

Explique su respuesta.

Taller

(19)

Ingeniería de Software

(20)

Es el establecimiento y uso de principios fundamentales de la ingeniería con objeto de desarrollar en forma económica software que sea confiable y que trabaje con eficiencia en máquinas reales.

Es la aplicación de un enfoque sistemático, disciplinado y cuantificable al desarrollo, operación y mantenimiento de software; es decir, la aplicación de la ingeniería al software (IEEE).

Definición

(21)

La ingeniería de software es una tecnología multicapa, cualquier enfoque de ingeniería debe apoyarse sobre un compromiso de organización de calidad.

Capas

(22)

Capas

Herramienta Método Proceso

Enfoque de calidad

MÉTODO: cómo se debe construir técnicamente el software. abarcan una gran gama de tareas, que incluyen: Análisis de requisitos. Diseño. Construcción de programas. Pruebas. Mantenimiento.

HERRAMIENTAS: Soporte de ayuda para construir el software, proporciona un enfoque automático o semiautomático para el proceso y para los métodos.

ENFOQUE DE CALIDAD: comprende la gestión para obtener un software de calidad, y hace revisiones para hacer mejoras al producto.

PROCESO: definen las actividades para poder realizar el software.

(23)

¿Cuáles son los elementos de un proceso de

software?

(24)

Proceso

Es un conjunto de actividades, acciones y tareas que se ejecutan cuando va a crearse algún producto del trabajo.

Actividad

Pretende lograr un objetivo amplio y se desarrolla sin importar el dominio de la aplicación, tamaño del proyecto, complejidad del esfuerzo o grado de rigor con el que se usará la ingeniería de software.

Acción

Conjunto de tareas que producen un producto importante del trabajo.

(25)

Tarea

Centra en un objetivo pequeño pero bien que produce un resultado tangible.

En el contexto de la INGENIERÍA DE SOFTWARE un proceso NO es una prescripción rígida de cómo elaborar software de cómputo.

Es un enfoque adaptable que permite que las personas que hacen el trabajo busquen y elijan el conjunto apropiado de acciones y tareas para el trabajo.

Un proceso de software es una serie de actividades relacionadas que conduce a la elaboración de un producto de software .

(26)

Proceso de Ingeniería de software

(27)

Se define proceso del software como una estructura para las actividades, acciones y tareas que se requieren a fin de construir software de alta calidad (Pressman, 2010).

(28)

ESTRUCTURA DE UN PROCESO DEL SOFTWARE

Fuente: Pressman (2010).

(29)

Los procesos de software se clasifican:

• Dirigidos por un plan: son aquellos donde todas las actividades del proceso se planean por anticipado y el avance se mide contra dicho plan

• Procesos ágiles: la planeación es incremental y fácil modificar el proceso para reflejar los requerimientos cambiantes del cliente.

(30)

¿Cuáles son las cinco actividades

estructurales del proceso?

(31)

• Entender los objetivos de los participantes respecto del proyecto, y reunir los requerimientos que ayuden a definir las características y funciones del software.

Comunicación.

• Define el trabajo de ingeniería de software al describir las tareas técnicas por realizar, los riesgos probables, los recursos que se requieren, los productos del trabajo que se obtendrán y una programación de las actividades.

Planeación.

• Un ingeniero de software hace lo mismo al crear modelos a fin de entender mejor los requerimientos del software y el diseño que los satisfará.

Modelado.

(32)

• Esta actividad combina la generación de código y las

pruebas que se requieren para descubrir errores en éste.

Construcción.

• El software se entrega al consumidor que lo evalúa y que le da retroalimentación, misma que se basa en dicha

evaluación.

Despliegue.

(33)

• Un flujo de proceso lineal ejecuta cada una de las cinco actividades estructurales en secuencia, comenzando por la comunicación y terminando con el despliegue.

• Un flujo de proceso iterativo repite una o más de las actividades antes de pasar a la siguiente.

(34)

• Un flujo de proceso evolutivo realiza las actividades en forma

“circular”. A través de las cinco actividades, cada circuito lleva a una versión más completa del software.

(35)

• Un flujo de proceso paralelo ejecuta una o más actividades en paralelo con otras

(36)

¿Qué acciones son apropiadas para una actividad estructural, dados la naturaleza del problema por resolver, las características de las personas que hacen el trabajo y los participantes que patrocinan el proyecto?

▪ Para un proyecto de software pequeño solicitado.

▪ Para proyecto de software grande.

Diferentes proyectos demandan diferentes conjuntos de tareas.

El equipo de software elige el conjunto de tareas con base en las características del problema y el proyecto.

(37)

Evaluación y Mejora del Proceso

(38)

¿De qué técnicas formales se

dispone para evaluar el proceso del

software?

(39)

• Proporciona un modelo de cinco fases para evaluar el proceso:

inicio, diagnóstico, establecimiento, actuación y aprendizaje.

Método de evaluación del estándar CMMI para el proceso de mejora (SCAMPI, por sus siglas en inglés):

• Proporciona una técnica de diagnóstico para evaluar la madurez relativa de una organización de software; usa el SEI CMM como la base de la evaluación.

Evaluación basada en CMM para la mejora del proceso interno (CBA IPI, por sus siglas en

inglés):

(40)

• Define un conjunto de requerimientos para la evaluación del proceso del software. Cuyo objetivo es ayudar a las organizaciones a desarrollar una evaluación objetiva de cualquier proceso del software definido.

SPICE (ISO/IEC 15504):

• Estándar genérico que se aplica a cualquier organización que desee mejorar la calidad general de los productos, sistemas o servicios que proporciona.

ISO9001:2000 para software:

(41)

BIBLIOGRAFÍA

Ian Sommerville, Software Engineering. 9th edition, 2011, Addison- Wesley

Roger Pressman, Ingeniería de Software: Un Enfoque Práctico.

Séptima Edición, 2010, McGraw-Hill

.

Referencias

Documento similar

– Esta norma esta orientada a los procesos de ciclo de vida del desarrollo de software de la organización ISO. – Establece un proceso de ciclo de vida para el desarrollo software

Cuando las características y las métricas asociadas se puedan usar no sólo para evaluar el producto software, sino también para definir requisitos de calidad y otros usos, la

Los objetivos del presente trabajo fin de grado es ofrecer una introducción general sobre el software EMSO, un simulador de procesos orientado a ecuaciones, dando a conocer el

La Normativa de evaluación del rendimiento académico de los estudiantes y de revisión de calificaciones de la Universidad de Santiago de Compostela, aprobada por el Pleno or-

• Consiste en una estructuración de los factores en una jerarquía multinivel, con un conjunto de factores de más alto nivel, unos criterios que descomponen dichos factores,

A pesar de que han sido propuestos lineamientos para la conducción de RS en la IS, éstos presentan debilidades y carencias, motivado por la fuerte influencia que han recibido

IV. Está relacionada con la ingeniería de sistemas, dado que al construir software en general estamos construyendo a la vez un sistema compuesto al menos por software, hardware

n En cada iteración se identifican y especifican los casos de uso relevantes, se crea un diseño basado en la arquitectura seleccionada, se implementa el diseño mediante componentes