SlideShare une entreprise Scribd logo
1  sur  16
Télécharger pour lire hors ligne
El Proceso
de Desarrollo
 de Software

       Diseño de Software Avanzado
        Departamento de Informática
La Ingeniería del Software
 Ingeniería...
  —   “La profesión en la que el conocimiento de las ciencias naturales y
      matemáticas, ganado con estudio, experiencia y práctica, es aplicado
      con buen juicio para desarrollar formas de utilizar, económicamente, los
      materiales y las fuerzas de la naturaleza para el beneficio del género
      humano” (Acreditation Board for Engineering and Technology, 1996).


 Peculiaridades de la Ingeniería del Software
  —   El “producto” software.
  —   Mucho desarrollo, poca disciplina ingenieril.
  —   Necesidad de describir y documentar lo que se va a producir.
  —   Cambios frecuentes en el producto.




                                                                   Diseño de Software Avanzado
                            El Proceso de Desarrollo de Software    Departamento de Informática   2
La Ingeniería del Software (y II)
 Ingeniería de Sistemas vs. Ingeniería del Software
  —   La Ingeniería de Sistemas está relacionada con todos los aspectos
      asociados al desarrollo de sistemas complejos: hardware, software, etc.
  —   Los sistemas intensivos software son sistemas constituidos
      principalmente por software.


 Informática (Computer Science) vs. Ingeniería del Software
  —   La Informática está relacionada con las teorías y métodos subyacentes a
      los ordenadores y a los sistemas software.




                                                                   Diseño de Software Avanzado
                            El Proceso de Desarrollo de Software    Departamento de Informática   3
Problemas en el Desarrollo de Software
             Problemas                                             Soluciones
El programa no hace lo que se
                                                  Definir bien las especificaciones
supone que debe hacer
                                                  Definir bien el diseño y las
El programa se cuelga
                                                  pruebas
Hace falta un 200% del tiempo
                                                  Planificar bien
planificado para concluir el programa
Si el programador se va de la
empresa... ¡Vaya! Hay que hacer un                Definir bien la documentación
nuevo programa
...                                               ...


                                                                          Diseño de Software Avanzado
                            El Proceso de Desarrollo de Software           Departamento de Informática   4
El Típico Problema de Incomunicación
                                  1. Necesidad: lo que el cliente realmente
                                     quería.
                                  2. Cliente: lo que fue capaz de describir como
                                     una clara necesidad.
                                  3. Proceso de ventas: lo que el fabricante de
                                     software prometió al cliente.
                                  4. Requisitos: los requisitos descritos por el
                                     cliente, tal como finalmente fueron
                                     entendidos.
                                  5. Análisis: la especificación formal de los
                                     requisitos realizada por los analistas.
                                  6. Diseño: la especificación del funcionamiento
                                     del sistema para satisfacer los requisitos
                                     analizados.
                                  7. Codificación: lo que escribió el programador.
                                  8. Instalación: lo que realmente fue instalado al
                                     cliente.
                                  9. Pruebas: lo que los responsables vieron en
                                     el sistema.

                                                              Diseño de Software Avanzado
              El Proceso de Desarrollo de Software             Departamento de Informática   5
El Proceso de Desarrollo Software




Requisitos, necesidades




   ¿Cómo se hace un proyecto software?
                                                                  Sistema software
                                                                  Diseño de Software Avanzado
                           El Proceso de Desarrollo de Software    Departamento de Informática   6
El Proceso de Desarrollo Software (II)
 El SDP define el qué, quién, cuándo y cómo del desarrollo de
 software.

 Cuatro actividades fundamentales que son comunes para todos los
 procesos de desarrollo de software :
  —   Especificación del software
  —   Desarrollo del software
  —   Validación del software
  —   Evolución del software


 Modelo de proceso:
  —   Descripción simplificada (abstracción) de un proceso de desarrollo de
      software real.


                                                                   Diseño de Software Avanzado
                            El Proceso de Desarrollo de Software    Departamento de Informática   7
Ejemplo: Proceso en Cascada

      Necesidad

                                                                          Una sola iteración
 Análisis de requisitos



                          Diseño



                                      Implementación

Es una idealización que no
se da en estado puro
                                                                     Pruebas           Producto final

                                                                                   Diseño de Software Avanzado
                                   El Proceso de Desarrollo de Software             Departamento de Informática   8
El Proceso de Desarrollo Software (y III)
 Es un problema complejo para proyectos medios o grandes:
  —   Dividir un proyecto en mini-proyectos, más fáciles de manejar y
      completar.
  —   Cada mini-proyecto es una iteración.
  —   Cada iteración contiene todos los elementos de un proyecto normal:
       •   planificación
       •   análisis y diseño
       •   construcción
       •   integración y pruebas
       •   versión del producto (interna o externa)
  —   Cada iteración genera una línea base (baseline) que comprende una
      versión parcialmente completa del sistema final, y toda la documentación
      asociada.
  —   Las sucesivas iteraciones se construyen unas sobre otras hasta que se
      alcanza el sistema final terminado.
  —   La diferencia entre dos líneas base se conoce como incremento.

                                                                       Diseño de Software Avanzado
                                El Proceso de Desarrollo de Software    Departamento de Informática   9
Ejemplo: Proceso en Espiral




             Espiral de Boehm (©IEEE, 1988)

                                                       Diseño de Software Avanzado
                El Proceso de Desarrollo de Software    Departamento de Informática   10
Ejemplo: Proceso Iterativo e Incremental
 Posibilita la evolución en paralelo de los distintos flujos de trabajo, y
 por tanto el trabajo en paralelo de distintos equipos de personas.
 Las distintas versiones de los documentos producidas en cada
 iteración no necesariamente son compatibles entre sí: organizar bien
 la documentación.

       Iteración 1                 Iteración 2                     Iteración 3

         Análisis                     Análisis                       Análisis
       (versión 1)                  (versión 2)                    (versión 3)
                                      Diseño                         Diseño
                                    (versión 1)                    (versión 2)
                                                                 Implementación
                                                                   (versión 1)



                                                                       Diseño de Software Avanzado
                          El Proceso de Desarrollo de Software          Departamento de Informática   11
El Proceso Unificado
de Desarrollo de Software
 Ligado en su origen histórico a los trabajos de Ivar Jacobson en
 Ericsson (1967), Objectory (1987) y Rational (1997).
 Principios del USDP/UP.
  —   Dirigido por casos de uso y riesgos
       • Capturar requisitos.
       • Analizar riesgos y enfrentarse a ellos.
  —   Centrado en la arquitectura
       • La arquitectura de un sistema describe la estrategia de división del sistema en
         componentes, cómo estos componentes interaccionan, y cómo son
         desplegados en el hardware.
       • Una arquitectura de calidad garantiza un sistema de calidad, no una mera
         colección de piezas mal conectadas.
  —   Iterativo e incremental
       • Proceso dividido en sucesivas iteraciones.
       • La diferencia entre dos iteraciones es un incremento.


                                                                       Diseño de Software Avanzado
                               El Proceso de Desarrollo de Software     Departamento de Informática   12
USDP: Flujos de Trabajo
 En cada iteración existen cinco flujos de trabajo (workflows):
  —   Requisitos: capturar lo que el sistema debe hacer.
  —   Análisis: refinar y estructurar los requisitos.
  —   Diseño: realizar los requisitos en la arquitectura del sistema.
  —   Implementación: construir el software.
  —   Pruebas: verificar que la implementación funciona como se desea.


 Pueden existir otros (no cubiertos por USDP):
  —   Planificación
  —   Evaluación
  —   Específicos del proyecto


 Distinto peso relativo en cada iteración.

                                                                   Diseño de Software Avanzado
                            El Proceso de Desarrollo de Software    Departamento de Informática   13
USDP: Fases
 El ciclo de vida del proyecto se divide en cuatro fases, cada una de
 las cuales termina con un hito (milestone):
  —   Inicio: objetivos del proyecto.
  —   Elaboración: arquitectura del sistema.
  —   Construcción: capacidad operativa inicial.
  —   Transición: entrega del producto.


 En cada fase puede haber una o más iteraciones.

 En cada iteración se ejecutan los cinco flujos de trabajo principales
 y los otros que sean necesarios.




                                                                   Diseño de Software Avanzado
                            El Proceso de Desarrollo de Software    Departamento de Informática   14
USDP: Fases, Iteraciones
y Flujos de Trabajo
                                                                                Fases del ciclo de vida
 Flujos de trabajo    Inicio           Elaboración               Construcción               Transición

   Requisitos
                                                                     Una iteración en la
                                                                     fase de Elaboración
    Análisis



    Diseño



 Implementación



   Pruebas


                      Iteración(es)    Iter.     Iter.       Iter.      Iter.   Iter.      Iter.      Iter.
                     preliminar(es)     #1        #2          #n        #n+1    #n+2        #m       #m+1

                                                         Iteraciones
                                                                                          Diseño de Software Avanzado
                                 El Proceso de Desarrollo de Software                      Departamento de Informática   15
Otros Enfoques y Nomenclaturas

                    Terminología USDP                        Terminología clásica

                          Requisitos
                                                              Análisis de requisitos
                           Análisis

                            Diseño                                          Diseño

                                                                  Implementación
                       Implementación
                                                                     Integración

                           Pruebas                                      Pruebas



Eric Braude, Software Engineering. An Object-Oriented Perspective, John Wiley & Sons, 2001, p. 30.


                                                                                       Diseño de Software Avanzado
                                     El Proceso de Desarrollo de Software               Departamento de Informática   16

Contenu connexe

Tendances

Tema 3 proseso de desarrollo del software
Tema 3 proseso de desarrollo del softwareTema 3 proseso de desarrollo del software
Tema 3 proseso de desarrollo del software
Luis Garcia
 
Intoduccion A La Ingenieria Del Software
Intoduccion A La Ingenieria Del SoftwareIntoduccion A La Ingenieria Del Software
Intoduccion A La Ingenieria Del Software
guest9ad165
 
SELECCIÓN DE TECNICAS DE INGENIERIA DE SOFTWARE.
SELECCIÓN DE TECNICAS DE INGENIERIA DE SOFTWARE. SELECCIÓN DE TECNICAS DE INGENIERIA DE SOFTWARE.
SELECCIÓN DE TECNICAS DE INGENIERIA DE SOFTWARE.
Cristhian Martinez
 
Ingeniería de software es la aplicación de un enfoque sistemático
Ingeniería de software es la aplicación de un enfoque sistemáticoIngeniería de software es la aplicación de un enfoque sistemático
Ingeniería de software es la aplicación de un enfoque sistemático
Santiago Moha
 
Elproceso de desarrollo de software
Elproceso de desarrollo de softwareElproceso de desarrollo de software
Elproceso de desarrollo de software
celestevictoria
 
Elproceso de desarrollo de software
Elproceso de desarrollo de softwareElproceso de desarrollo de software
Elproceso de desarrollo de software
ayymba
 
Ingeniería de software
Ingeniería de softwareIngeniería de software
Ingeniería de software
mat3matik
 
Ingeniería%20de%20 software[1], maryy
Ingeniería%20de%20 software[1], maryyIngeniería%20de%20 software[1], maryy
Ingeniería%20de%20 software[1], maryy
nelly
 
Ingenier%c3%ada de software
Ingenier%c3%ada de softwareIngenier%c3%ada de software
Ingenier%c3%ada de software
Marilupe
 
Ingen de software
Ingen de softwareIngen de software
Ingen de software
erikapoh
 

Tendances (16)

La importancia del_modelado_en_la_producción_de_sw_vf
La importancia del_modelado_en_la_producción_de_sw_vfLa importancia del_modelado_en_la_producción_de_sw_vf
La importancia del_modelado_en_la_producción_de_sw_vf
 
Tema 3 proseso de desarrollo del software
Tema 3 proseso de desarrollo del softwareTema 3 proseso de desarrollo del software
Tema 3 proseso de desarrollo del software
 
Intoduccion A La Ingenieria Del Software
Intoduccion A La Ingenieria Del SoftwareIntoduccion A La Ingenieria Del Software
Intoduccion A La Ingenieria Del Software
 
SELECCIÓN DE TECNICAS DE INGENIERIA DE SOFTWARE.
SELECCIÓN DE TECNICAS DE INGENIERIA DE SOFTWARE. SELECCIÓN DE TECNICAS DE INGENIERIA DE SOFTWARE.
SELECCIÓN DE TECNICAS DE INGENIERIA DE SOFTWARE.
 
Modelo en cascada
Modelo en cascadaModelo en cascada
Modelo en cascada
 
Diapositivas De Ingenieria De Software
Diapositivas De Ingenieria De SoftwareDiapositivas De Ingenieria De Software
Diapositivas De Ingenieria De Software
 
chuy
chuy chuy
chuy
 
Ingeniería de software es la aplicación de un enfoque sistemático
Ingeniería de software es la aplicación de un enfoque sistemáticoIngeniería de software es la aplicación de un enfoque sistemático
Ingeniería de software es la aplicación de un enfoque sistemático
 
Elproceso de desarrollo de software
Elproceso de desarrollo de softwareElproceso de desarrollo de software
Elproceso de desarrollo de software
 
Elproceso de desarrollo de software
Elproceso de desarrollo de softwareElproceso de desarrollo de software
Elproceso de desarrollo de software
 
Ingeniería de software
Ingeniería de softwareIngeniería de software
Ingeniería de software
 
Ingeniería%20de%20 software[1], maryy
Ingeniería%20de%20 software[1], maryyIngeniería%20de%20 software[1], maryy
Ingeniería%20de%20 software[1], maryy
 
Ingenier%c3%ada de software
Ingenier%c3%ada de softwareIngenier%c3%ada de software
Ingenier%c3%ada de software
 
Ingen de software
Ingen de softwareIngen de software
Ingen de software
 
Ingenieria De Software
Ingenieria De SoftwareIngenieria De Software
Ingenieria De Software
 
Conceptos I Sw
Conceptos I SwConceptos I Sw
Conceptos I Sw
 

En vedette

Aprendé Scrum en 5 minutos
Aprendé Scrum en 5 minutosAprendé Scrum en 5 minutos
Aprendé Scrum en 5 minutos
Rebeka Sanabria
 
Metodologías de desarrollo de software ucp
Metodologías de desarrollo de software   ucpMetodologías de desarrollo de software   ucp
Metodologías de desarrollo de software ucp
Alonso Toro Lazo
 
1 ingeniería de software
1 ingeniería de software1 ingeniería de software
1 ingeniería de software
UVM
 
Unidad 1.2 B Metodos Agiles 1
Unidad 1.2 B Metodos Agiles  1Unidad 1.2 B Metodos Agiles  1
Unidad 1.2 B Metodos Agiles 1
Sergio Sanchez
 
4 Clase Metodologia De Desarrolo De Software
4 Clase Metodologia De Desarrolo De Software4 Clase Metodologia De Desarrolo De Software
4 Clase Metodologia De Desarrolo De Software
Julio Pari
 
Metodologias de desarrollo
Metodologias de desarrolloMetodologias de desarrollo
Metodologias de desarrollo
Hermes Romero
 

En vedette (20)

Generalidades - Marketing
 Generalidades - Marketing  Generalidades - Marketing
Generalidades - Marketing
 
Metodologías ágiles
Metodologías ágilesMetodologías ágiles
Metodologías ágiles
 
Aprendé Scrum en 5 minutos
Aprendé Scrum en 5 minutosAprendé Scrum en 5 minutos
Aprendé Scrum en 5 minutos
 
Metodologías de desarrollo de software ucp
Metodologías de desarrollo de software   ucpMetodologías de desarrollo de software   ucp
Metodologías de desarrollo de software ucp
 
Introducción a las Metodologías Ágiles
Introducción a las Metodologías ÁgilesIntroducción a las Metodologías Ágiles
Introducción a las Metodologías Ágiles
 
1 ingeniería de software
1 ingeniería de software1 ingeniería de software
1 ingeniería de software
 
Introducción a la metodologías ágiles y scrum
Introducción a la metodologías ágiles y scrumIntroducción a la metodologías ágiles y scrum
Introducción a la metodologías ágiles y scrum
 
Fundamentos de las metodologías ágiles
Fundamentos de las metodologías ágilesFundamentos de las metodologías ágiles
Fundamentos de las metodologías ágiles
 
CORETIC - SCRUM
CORETIC - SCRUMCORETIC - SCRUM
CORETIC - SCRUM
 
Unidad 1.2 B Metodos Agiles 1
Unidad 1.2 B Metodos Agiles  1Unidad 1.2 B Metodos Agiles  1
Unidad 1.2 B Metodos Agiles 1
 
Scrum en 15 minutos
Scrum en 15 minutosScrum en 15 minutos
Scrum en 15 minutos
 
Desarrollo Agil
Desarrollo AgilDesarrollo Agil
Desarrollo Agil
 
Presentacion Atmosferia 2011
Presentacion Atmosferia 2011Presentacion Atmosferia 2011
Presentacion Atmosferia 2011
 
Metodologías agiles de desarrollo de software
Metodologías agiles de desarrollo de softwareMetodologías agiles de desarrollo de software
Metodologías agiles de desarrollo de software
 
Metodología scrum
Metodología scrumMetodología scrum
Metodología scrum
 
Sensibilización en Metodologías Ágiles
Sensibilización en Metodologías ÁgilesSensibilización en Metodologías Ágiles
Sensibilización en Metodologías Ágiles
 
Metodología de desarrollo de software
Metodología de desarrollo de softwareMetodología de desarrollo de software
Metodología de desarrollo de software
 
4 Clase Metodologia De Desarrolo De Software
4 Clase Metodologia De Desarrolo De Software4 Clase Metodologia De Desarrolo De Software
4 Clase Metodologia De Desarrolo De Software
 
Metodologias de desarrollo
Metodologias de desarrolloMetodologias de desarrollo
Metodologias de desarrollo
 
Proceso para el desarrollo de software Ponencia M.C.Ivet Espinosa Conde
Proceso para el desarrollo de software Ponencia M.C.Ivet Espinosa CondeProceso para el desarrollo de software Ponencia M.C.Ivet Espinosa Conde
Proceso para el desarrollo de software Ponencia M.C.Ivet Espinosa Conde
 

Similaire à 01 el proceso-de_desarrollo_de_software

Tm01 el modelado en el desarrollo de software
Tm01 el modelado en el desarrollo de softwareTm01 el modelado en el desarrollo de software
Tm01 el modelado en el desarrollo de software
Julio Pari
 
Trabajo diapositiva modulo 3 de josue
Trabajo diapositiva modulo 3 de josueTrabajo diapositiva modulo 3 de josue
Trabajo diapositiva modulo 3 de josue
Josue Zelaya
 
Kevin guia
Kevin guiaKevin guia
Kevin guia
keninmnk
 

Similaire à 01 el proceso-de_desarrollo_de_software (20)

Tm01 el modelado en el desarrollo de software
Tm01 el modelado en el desarrollo de softwareTm01 el modelado en el desarrollo de software
Tm01 el modelado en el desarrollo de software
 
introducción ingeniería de software
introducción  ingeniería de  softwareintroducción  ingeniería de  software
introducción ingeniería de software
 
Proceso desarrollo software
Proceso desarrollo softwareProceso desarrollo software
Proceso desarrollo software
 
Trabajo diapositiva modulo 3 de josue
Trabajo diapositiva modulo 3 de josueTrabajo diapositiva modulo 3 de josue
Trabajo diapositiva modulo 3 de josue
 
Trabajo diapositiva Software por Jhonatan Ruiz
Trabajo diapositiva  Software por Jhonatan RuizTrabajo diapositiva  Software por Jhonatan Ruiz
Trabajo diapositiva Software por Jhonatan Ruiz
 
Trabajo diapositiva modulo 3 de jhonatan
Trabajo diapositiva modulo 3 de jhonatanTrabajo diapositiva modulo 3 de jhonatan
Trabajo diapositiva modulo 3 de jhonatan
 
El_software_y_la_Ingenieria_de_Software.pdf
El_software_y_la_Ingenieria_de_Software.pdfEl_software_y_la_Ingenieria_de_Software.pdf
El_software_y_la_Ingenieria_de_Software.pdf
 
Inf 162
Inf 162Inf 162
Inf 162
 
El Proceso De Desarrollo De Software
El Proceso De Desarrollo De SoftwareEl Proceso De Desarrollo De Software
El Proceso De Desarrollo De Software
 
Paula guia
Paula guiaPaula guia
Paula guia
 
Proceso de diseño
Proceso de diseñoProceso de diseño
Proceso de diseño
 
Software
SoftwareSoftware
Software
 
Introducción a la Ingeniria del Software
Introducción a la Ingeniria del SoftwareIntroducción a la Ingeniria del Software
Introducción a la Ingeniria del Software
 
procesos de desarrollo de sw
procesos de desarrollo de swprocesos de desarrollo de sw
procesos de desarrollo de sw
 
Kevin guia
Kevin guiaKevin guia
Kevin guia
 
Ingenieria de software
Ingenieria de softwareIngenieria de software
Ingenieria de software
 
Ingeniería de software
Ingeniería de software Ingeniería de software
Ingeniería de software
 
Modelo en cascada
Modelo en cascadaModelo en cascada
Modelo en cascada
 
Modelo en cascada
Modelo en cascadaModelo en cascada
Modelo en cascada
 
UNIDAD_I.ppt
UNIDAD_I.pptUNIDAD_I.ppt
UNIDAD_I.ppt
 

Dernier

redes informaticas en una oficina administrativa
redes informaticas en una oficina administrativaredes informaticas en una oficina administrativa
redes informaticas en una oficina administrativa
nicho110
 

Dernier (12)

Avances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvanaAvances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvana
 
redes informaticas en una oficina administrativa
redes informaticas en una oficina administrativaredes informaticas en una oficina administrativa
redes informaticas en una oficina administrativa
 
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
 
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptx
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptxEVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptx
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptx
 
pruebas unitarias unitarias en java con JUNIT
pruebas unitarias unitarias en java con JUNITpruebas unitarias unitarias en java con JUNIT
pruebas unitarias unitarias en java con JUNIT
 
Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21
 
How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.
 
Buenos_Aires_Meetup_Redis_20240430_.pptx
Buenos_Aires_Meetup_Redis_20240430_.pptxBuenos_Aires_Meetup_Redis_20240430_.pptx
Buenos_Aires_Meetup_Redis_20240430_.pptx
 
investigación de los Avances tecnológicos del siglo XXI
investigación de los Avances tecnológicos del siglo XXIinvestigación de los Avances tecnológicos del siglo XXI
investigación de los Avances tecnológicos del siglo XXI
 
Avances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estosAvances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estos
 
EL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptx
EL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptxEL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptx
EL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptx
 
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptxPROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
 

01 el proceso-de_desarrollo_de_software

  • 1. El Proceso de Desarrollo de Software Diseño de Software Avanzado Departamento de Informática
  • 2. La Ingeniería del Software Ingeniería... — “La profesión en la que el conocimiento de las ciencias naturales y matemáticas, ganado con estudio, experiencia y práctica, es aplicado con buen juicio para desarrollar formas de utilizar, económicamente, los materiales y las fuerzas de la naturaleza para el beneficio del género humano” (Acreditation Board for Engineering and Technology, 1996). Peculiaridades de la Ingeniería del Software — El “producto” software. — Mucho desarrollo, poca disciplina ingenieril. — Necesidad de describir y documentar lo que se va a producir. — Cambios frecuentes en el producto. Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 2
  • 3. La Ingeniería del Software (y II) Ingeniería de Sistemas vs. Ingeniería del Software — La Ingeniería de Sistemas está relacionada con todos los aspectos asociados al desarrollo de sistemas complejos: hardware, software, etc. — Los sistemas intensivos software son sistemas constituidos principalmente por software. Informática (Computer Science) vs. Ingeniería del Software — La Informática está relacionada con las teorías y métodos subyacentes a los ordenadores y a los sistemas software. Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 3
  • 4. Problemas en el Desarrollo de Software Problemas Soluciones El programa no hace lo que se Definir bien las especificaciones supone que debe hacer Definir bien el diseño y las El programa se cuelga pruebas Hace falta un 200% del tiempo Planificar bien planificado para concluir el programa Si el programador se va de la empresa... ¡Vaya! Hay que hacer un Definir bien la documentación nuevo programa ... ... Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 4
  • 5. El Típico Problema de Incomunicación 1. Necesidad: lo que el cliente realmente quería. 2. Cliente: lo que fue capaz de describir como una clara necesidad. 3. Proceso de ventas: lo que el fabricante de software prometió al cliente. 4. Requisitos: los requisitos descritos por el cliente, tal como finalmente fueron entendidos. 5. Análisis: la especificación formal de los requisitos realizada por los analistas. 6. Diseño: la especificación del funcionamiento del sistema para satisfacer los requisitos analizados. 7. Codificación: lo que escribió el programador. 8. Instalación: lo que realmente fue instalado al cliente. 9. Pruebas: lo que los responsables vieron en el sistema. Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 5
  • 6. El Proceso de Desarrollo Software Requisitos, necesidades ¿Cómo se hace un proyecto software? Sistema software Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 6
  • 7. El Proceso de Desarrollo Software (II) El SDP define el qué, quién, cuándo y cómo del desarrollo de software. Cuatro actividades fundamentales que son comunes para todos los procesos de desarrollo de software : — Especificación del software — Desarrollo del software — Validación del software — Evolución del software Modelo de proceso: — Descripción simplificada (abstracción) de un proceso de desarrollo de software real. Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 7
  • 8. Ejemplo: Proceso en Cascada Necesidad Una sola iteración Análisis de requisitos Diseño Implementación Es una idealización que no se da en estado puro Pruebas Producto final Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 8
  • 9. El Proceso de Desarrollo Software (y III) Es un problema complejo para proyectos medios o grandes: — Dividir un proyecto en mini-proyectos, más fáciles de manejar y completar. — Cada mini-proyecto es una iteración. — Cada iteración contiene todos los elementos de un proyecto normal: • planificación • análisis y diseño • construcción • integración y pruebas • versión del producto (interna o externa) — Cada iteración genera una línea base (baseline) que comprende una versión parcialmente completa del sistema final, y toda la documentación asociada. — Las sucesivas iteraciones se construyen unas sobre otras hasta que se alcanza el sistema final terminado. — La diferencia entre dos líneas base se conoce como incremento. Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 9
  • 10. Ejemplo: Proceso en Espiral Espiral de Boehm (©IEEE, 1988) Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 10
  • 11. Ejemplo: Proceso Iterativo e Incremental Posibilita la evolución en paralelo de los distintos flujos de trabajo, y por tanto el trabajo en paralelo de distintos equipos de personas. Las distintas versiones de los documentos producidas en cada iteración no necesariamente son compatibles entre sí: organizar bien la documentación. Iteración 1 Iteración 2 Iteración 3 Análisis Análisis Análisis (versión 1) (versión 2) (versión 3) Diseño Diseño (versión 1) (versión 2) Implementación (versión 1) Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 11
  • 12. El Proceso Unificado de Desarrollo de Software Ligado en su origen histórico a los trabajos de Ivar Jacobson en Ericsson (1967), Objectory (1987) y Rational (1997). Principios del USDP/UP. — Dirigido por casos de uso y riesgos • Capturar requisitos. • Analizar riesgos y enfrentarse a ellos. — Centrado en la arquitectura • La arquitectura de un sistema describe la estrategia de división del sistema en componentes, cómo estos componentes interaccionan, y cómo son desplegados en el hardware. • Una arquitectura de calidad garantiza un sistema de calidad, no una mera colección de piezas mal conectadas. — Iterativo e incremental • Proceso dividido en sucesivas iteraciones. • La diferencia entre dos iteraciones es un incremento. Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 12
  • 13. USDP: Flujos de Trabajo En cada iteración existen cinco flujos de trabajo (workflows): — Requisitos: capturar lo que el sistema debe hacer. — Análisis: refinar y estructurar los requisitos. — Diseño: realizar los requisitos en la arquitectura del sistema. — Implementación: construir el software. — Pruebas: verificar que la implementación funciona como se desea. Pueden existir otros (no cubiertos por USDP): — Planificación — Evaluación — Específicos del proyecto Distinto peso relativo en cada iteración. Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 13
  • 14. USDP: Fases El ciclo de vida del proyecto se divide en cuatro fases, cada una de las cuales termina con un hito (milestone): — Inicio: objetivos del proyecto. — Elaboración: arquitectura del sistema. — Construcción: capacidad operativa inicial. — Transición: entrega del producto. En cada fase puede haber una o más iteraciones. En cada iteración se ejecutan los cinco flujos de trabajo principales y los otros que sean necesarios. Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 14
  • 15. USDP: Fases, Iteraciones y Flujos de Trabajo Fases del ciclo de vida Flujos de trabajo Inicio Elaboración Construcción Transición Requisitos Una iteración en la fase de Elaboración Análisis Diseño Implementación Pruebas Iteración(es) Iter. Iter. Iter. Iter. Iter. Iter. Iter. preliminar(es) #1 #2 #n #n+1 #n+2 #m #m+1 Iteraciones Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 15
  • 16. Otros Enfoques y Nomenclaturas Terminología USDP Terminología clásica Requisitos Análisis de requisitos Análisis Diseño Diseño Implementación Implementación Integración Pruebas Pruebas Eric Braude, Software Engineering. An Object-Oriented Perspective, John Wiley & Sons, 2001, p. 30. Diseño de Software Avanzado El Proceso de Desarrollo de Software Departamento de Informática 16