Вы находитесь на странице: 1из 20

Carrera: Ing.

en informática

Materia:

Fundamentos de sistemas de información.

Actividad:

Trabajo de investigación.

Tema:

‘Ingeniería de software’

Chilpancingo de los Bravo, a 20 de marzo del 2018.


Introducción
Conceptos fundamentales
¿Qué se entiende por Software?

“Conjunto de programas, instrucciones y reglas informáticas para ejecutar


ciertas tareas en una computadora.” - RAE [4]

“Es el conjunto de los programas de cómputo, procedimientos, reglas,


documentación y datos asociados que forman parte de las operaciones de un
sistema de computación.” - IEEE 729 [5]

Como vemos en esta definición mucho más exacta, se incluye la


documentación y los datos como parte de lo que se conoce como Software.

Figura 1. El software en una computadora

¿Qué se entiende por Ingeniería del Software?

“Ingeniería del Software es la aplicación práctica del conocimiento científico


en el diseño y construcción de programas de computadora y la documentación
asociada requerida para desarrollar, operar y mantenerlos. Se conoce también
como desarrollo de software o producción de software “- B. Bohem

Y según otra de las definiciones que aporta la IEEE, se introduce el concepto de


cuantificación del proceso:
1) La aplicación de un enfoque sistemático, disciplinado y cuantificable al desarrollo,
operación y mantenimiento del software; es decir, la aplicación de ingeniería al
software. 2) El estudio de enfoques como en (1). - IEEE 610.12 [5]

Como compendio de los conceptos barajados en las definiciones expuestas se


propone la siguiente definición de I. del Software:

“La aplicación práctica, sistemática, disciplinada y cuantificable del


conocimiento científico para realizar el análisis de las necesidades del usuario y
obtener el software y la documentación asociada requerida para su desarrollo,
operación y mantenimiento de manera rentable, fiable, certificada y que opere en
máquinas reales.”

Figura 2. La ingeniería de Software.

Campo de Trabajo

Debido a que toda la información de las empresas fluye a través de computadoras,


se requiere que éstas últimas cuenten con el software adecuado para llevar a cabo
sus actividades. Por esta razón, los Ingenieros de Software tienen un campo de
trabajo ilimitado y muy bien remunerado. Pueden realizar consultoría de forma
independiente o trabajar en organizaciones públicas o privadas tanto nacionales
como internacionales. Pueden trabajar en empresas de desarrollo de software,
administración de proyectos, fábricas de software y similares.
Características del Software

El software se desarrolla, no se fabrica.

El software no se descompone, se echa a perder.

Aunque la industria tiende a ensamblar componentes, la mayoría del software es


hecho a la medida.

Atributos de un buen software

Mantenibilidad. El software debe poder evolucionar para cumplir con las


necesidades de cambio de los clientes.

Confiabilidad. El software debe ser fiable, seguro, no debe causar daños físicos o
económicos en el caso de una falla del sistema.

Eficiencia. El software debe aprovechar al máximo los recursos del sistema.

Usabilidad. El software debe ser fácil de utilizar.

Aplicaciones del Software

Software de sistemas

Software de tiempo real

Software de gestión

Software de ingeniería y científico

Software empotrado

Software de PC’s

Software basado en Web

Software de IA
Desarrollo
La ingeniería de software busca apoyar el desarrollo de software profesional, en
lugar de la programación individual. Incluye técnicas que apoyan la especificación,
el diseño y la evolución del programa, ninguno de los cuales son normalmente
relevantes para el desarrollo de software personal. Con el objetivo de ayudarlo a
obtener una amplia visión de lo que trata la ingeniería de software, en la figura 1.1
se resumen algunas preguntas planteadas con frecuencia.

La ingeniería de software es una disciplina de ingeniería que se interesa por todos


los aspectos de la producción de software, desde las primeras etapas de la
especificación del sistema hasta el mantenimiento del sistema después de que se
pone en operación. En esta definición se presentan dos frases clave:

1. Disciplina de ingeniería. Los ingenieros hacen que las cosas funcionen. Aplican
teorías, métodos y herramientas donde es adecuado. Sin embargo, los usan de
manera selectiva y siempre tratan de encontrar soluciones a problemas, incluso
cuando no hay teorías ni métodos aplicables. Los ingenieros también reconocen
que deben trabajar ante restricciones organizacionales y financieras, de modo que
buscan soluciones dentro de tales limitaciones.

2. Todos los aspectos de la producción del software. La ingeniería de software no


sólo se interesa por los procesos técnicos del desarrollo de software, sino también
incluye actividades como la administración del proyecto de software y el desarrollo
de herramientas, así como métodos y teorías para apoyar la producción de software.

Características del producto (Software)


Mantenimiento El software debe escribirse de tal forma que pueda evolucionar para satisfacer las
necesidades cambiantes de los clientes. Éste es un atributo crítico porque el cambio del
software es un requerimiento inevitable de un entorno empresarial variable.
Confiabilidad y seguridad La confiabilidad del software incluye un rango de características que abarcan fiabilidad,
seguridad y protección. El software confiable no tiene que causar daño físico ni económico,
en caso de falla del sistema. Los usuarios malintencionados no deben tener posibilidad de
acceder al sistema o dañarlo.
Eficiencia El software no tiene que desperdiciar los recursos del sistema, como la memoria y los ciclos
del procesador. Por lo tanto, la eficiencia incluye capacidad de respuesta, tiempo de
procesamiento, utilización de memoria, etcétera.
Aceptabilidad El software debe ser aceptable al tipo de usuarios para quienes se diseña. Esto significa que
necesita ser comprensible, utilizable y compatible con otros sistemas que ellos usan.

Tabla 1. Atributos esenciales del buen software.


Esta disciplina trasciende la actividad de programación, que es el pilar
fundamental a la hora de crear una aplicación. El ingeniero de software se encarga
de toda la gestión del proyecto para que éste se pueda desarrollar en un plazo
determinado y con el presupuesto previsto.

La ingeniería de software, por lo tanto, incluye el análisis previo de la situación, el


diseño del proyecto, el desarrollo del software, las pruebas necesarias para
confirmar su correcto funcionamiento y la implementación del sistema.
Cabe destacar que el proceso de desarrollo de software implica lo que se conoce
como ciclo de vida del software, que está formado por cuatro etapas: concepción,
elaboración, construcción y transición.

Figura 3. Actividad de programación del Software.

La concepción fija el alcance del proyecto y desarrolla el modelo de negocio; la


elaboración define el plan del proyecto, detalla las características y fundamenta la
arquitectura; la construcción es el desarrollo del producto; y la transición es la
transferencia del producto terminado a los usuarios.
Una vez que se completa este ciclo, entra en juego el mantenimiento del software.
Se trata de una fase de esta ingeniería donde se solucionan los errores
descubiertos (muchas veces advertidos por los propios usuarios) y se incorporan
actualizaciones para hacer frente a los nuevos requisitos. El proceso de
mantenimiento incorpora además nuevos desarrollos, para permitir que el software
pueda cumplir con una mayor cantidad de tareas.
El enfoque de ingeniería del software cuenta con un compromiso organizacional con
la calidad porque no es posible incorporar la ingeniería del software en una
organización que no está centrada en conseguir calidad.

La ingeniería del software es una tecnología multicapa.

Se puede ver como un conjunto de componentes estratificados, que reposan sobre


ese enfoque de calidad.

Estos componentes que forman parte de la ingeniería del software son:

Figura 4. Capas de la ingeniería de Software.

Calidad: indispensable para cualquier disciplina de ingeniería. Idea reforzada por la


tendencia actual de fomento de la cultura de mejora continua de procesos.

Procesos: definen un marco de trabajo para el conjunto de áreas clave base del
control de la gestión de proyectos y establecen el contexto de aplicación de los
métodos técnicos y otras cuestiones como el aseguramiento de la calidad y gestión
del cambio.

Métodos: especifican cómo construir técnicamente el Software, abarcando desde


las tareas de especificación de requisitos y el diseño hasta la construcción, pruebas
y mantenimiento.

Herramientas: son aquellas que darán un soporte más o menos automático a


procesos y métodos.
El proceso del software
Un proceso es un conjunto de actividades, acciones y tareas que se ejecutan
cuando va a crearse algún producto del trabajo. Una actividad busca lograr un
objetivo amplio (por ejemplo, comunicación con los participantes) 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.

Una acción (diseño de la arquitectura) es un conjunto de tareas que producen un


producto importante del trabajo (por ejemplo, un modelo del diseño de la
arquitectura). Una tarea se centra en un objetivo pequeño, pero bien definido (por
ejemplo, realizar una prueba unitaria) que produce un resultado tangible.

Modelos de proceso
También conocidos como paradigmas, son abstracciones que, si bien no describen
detalladamente el proceso a seguir para el desarrollo software, representan
diferentes estrategias o enfoques para abordar este problema:

“Una descripción simplificada de un proceso del software que presenta


una visión de ese proceso. Estos modelos pueden incluir actividades que son parte
de los procesos y productos de software y las personas involucradas en la ingeniería
del software.” - Sommerville [2]

A continuación, se describen los principales modelos de proceso:


• Lineal secuencial
• Basado en prototipos
• Evolutivo
o Incremental
o En espiral
• Basado en componentes

1. Lineal secuencial
También llamado ciclo de vida básico, utiliza un enfoque sistemático y secuencial
de las actividades fundamentales que se mencionaron con anterioridad:

Figura 5. Modelo lineal secuencial.


En esta figura, propuesta por Pressman, se contempla el concepto de ingeniería de
Sistemas / Información, que ofrece una visión que pone de manifiesto que el
software suele formar parte de una solución mayor, y que su cometido es dar
respuesta a un subconjunto de los requisitos a cubrir.

El modelo secuencial más conocido es el modelo en cascada, propuesto por Royce


en 1970 [8].

Figura 6. Modelo en cascada.

El uso de este modelo es frecuente en proyectos de tamaño considerable en el que


se conocen bien los requisitos a los que se debe dar respuesta.

Son desventajas de este modelo:

▪ La necesidad de conocer los requisitos con exactitud desde el comienzo del


proyecto, cuestión que no es habitual.
▪ El producto a obtener no se hace visible hasta el final, algo que provoca que
los errores cometidos en la fase de análisis se propaguen por el resto de
fases.

2. Basado en prototipos

Este modelo facilita la definición de los requisitos, mediante un diseño rápido


centrado en la representación de los aspectos del software que serán visibles por el
usuario mediante la construcción de un prototipo.
Una vez realizada la primera versión del prototipo, se irá refinando y validando hasta
lograr la definición completa del sistema.

Figura 7. Modelo basado en prototipos.

La principal desventaja de este modelo es la percepción de “producto terminado”


que puede dar el prototipo. La clave para evitarla es dejar claro desde el primer
momento cuál es la función del prototipo y sus limitaciones.

3. Evolutivo
Surge para dar respuesta a una realidad: la necesidad de dar respuesta a la
necesidad de rápida evolución del Software. La experiencia confirma que, con
frecuencia, los requisitos cambian durante el desarrollo, cuestión que se ve
reforzada por la presión sobre tiempos de entrega que dificultan la finalización de
un producto completo y obligan a introducir versiones parciales, cada vez más
completas, que den cierto grado de solución en un plazo menor.

3.1 Incremental

Combina elementos del modelo lineal aplicados repetidas veces con la filosofía de
construcción de prototipos.

Figura 8. Modelo incremental.


A diferencia de la construcción de prototipos, el modelo incremental se centra en la
entrega de un producto operativo en cada incremento, siendo los primeros
incrementos versiones, si bien incompletas, que proporcionan la funcionalidad
precisada además de una plataforma para la evaluación.

Este modelo también es útil cuando no se dispone de todos los recursos para
realizar una implementación completa en una fecha establecida, limitándose la
entrega a un primer incremento ajustado a la capacidad disponible.

3.1.2 En espiral
Combina igualmente la naturaleza iterativa de la construcción de prototipos con los
aspectos sistemáticos del modelo lineal. Este modelo es propuesto por Boehm en
1988 [9] e incorpora los conceptos de análisis de riesgos y planificación como parte
del proceso.

Figura 9. Modelo en espiral.

La espiral representa el avance del proyecto y ésta pasa por un conjunto de regiones
que se corresponden con actividades del marco de trabajo.
El número de regiones propuestas por Boehm originalmente es de 4, aunque en la
bibliografía revisada se distinguen hasta 6.

Una variante de este modelo, el modelo espiral Win-Win, también propuesto por
Boehm en 1998 [10], interesante por introducir el concepto ganar-ganar como parte
del proceso iterativo. El fundamento de esta variante se basa a que, con frecuencia,
es difícil obtener del cliente los detalles necesarios para continuar el proceso, lo que
se deriva en un proceso de negociación: la funcionalidad, rendimiento, y otros
productos o características del sistema se sopesan frente al coste y al tiempo.

2.4 Basado en componentes

Modelo evolutivo por naturaleza y que presenta características comunes con el


modelo en espiral. También conocido como “Desarrollo basado en la reutilización”,
se apoya precisamente en el ese concepto: enfatizar la creación de clases y
componentes que encapsulan datos y procedimientos para tratarlos de modo que
se facilite su reutilización en distintos proyectos.

Figura 10. Modelo basado en componentes.

Este modelo introduce el concepto de “biblioteca de componentes” es un repositorio


de elementos potencialmente reutilizables (clases y componentes). A comienzo de
la etapa de construcción, se distinguen las necesidades únicas del proyecto de las
comunes entre distintos proyectos.
Para darle respuesta a estas últimas se identifican los “componentes candidatos”
de formar parte de la biblioteca. Si existen los componentes candidatos existen en
la biblioteca, se reutilizarán, y en otro caso, se construirán de tal modo que puedan
ser incorporados posteriormente a la biblioteca.

De esta forma, se compone la primera iteración de la aplicación a construirse,


mediante los componentes de la biblioteca y aquellos componentes únicos del
proyecto (a priori, no reutilizables)

Metodologías tradicionales

Son aquellas caracterizadas por una fuerte planificación durante todo el proceso de
desarrollo y por realizar una intensa etapa de análisis y diseño antes de la construcción del
sistema, cuestión por las que también se conocen con el nombre de “Metodologías
Pesadas”.

Figura 11. Metodologías tradicionales.

Cabe realizar la siguiente clasificación en función del tipo de enfoque que utilizan para
realizar las etapas análisis y diseño:

▪ Estructuradas

Los datos se consideran separadamente de los procesos que los transforman y el


comportamiento del sistema, tiende a desempeñar un papel secundario en la etapa de
análisis, haciéndose un fuerte uso de la descomposición funcional. MÉTRICA, MERISE o
SSADM son ejemplos de metodologías estructuradas.

▪ Orientadas a objetos.

Se considera el dominio del problema como un conjunto de objetos que interactúan entre
sí. OOAD (Booch), OOSE (Jacobson), OMT (Rumbaugh), MÉTRICA son ejemplos de
metodologías con enfoque orientado a objetos.

Por ejemplo, MÉTRICA v3, dispone de actividades que dan cobertura a ambos enfoques
[11]:
Figura 12. Métrica V3, diagrama de actividades ASI.

Es característico de las metodologías tradicionales, en general:

▪ Prestar especial atención al modelado y mantenimiento de los modelos.


▪ El énfasis en el control del proceso de desarrollo, metodología, el rigor de las
actividades involucradas, las herramientas y la notación utilizada.
▪ El énfasis en la especificación detallada de procesos y un elevado número y
especialización de roles.
▪ Limitar la participación del cliente a reuniones de control, reduciendo de manera
significativa sus aportes.
▪ Asumir que no se van a presentar cambios una vez comenzado el proyecto y
esperar que la arquitectura se defina tempranamente.
▪ Documentar de manera rigurosa toda actividad desarrollada en el proyecto.
▪ El aumento de los tiempos de espera por parte del usuario para ver los resultados.

Metodologías Ágiles

Los métodos ágiles surgen como respuesta a la dificultad de la aplicación práctica


y efectiva de las metodologías tradicionales, para determinados proyectos. Esto es,
porque asumen el cumplimiento de una serie de condiciones y restricciones durante
la ejecución del proyecto que, en la práctica, casi nunca llegan a producirse y la
rigidez normativa y la dependencia de planificaciones detalladas previas al
desarrollo surgen como un escollo para obtener resultados satisfactorios. Además,
el progresivo aumento en el nivel de exigencia y expectativas de los usuarios y la
necesidad de resultados más rápidos, sin detrimento de la calidad, dan pie a estos
nuevos métodos.

En cualquier caso, la conveniencia o no de estos nuevos métodos es una cuestión


de estudio para cada proyecto en particular.

Figura 13. Metodologías agiles.

Según las referencias consultadas las metodologías ágiles, en términos generales,


ofrecen mayores probabilidades de éxito en proyectos que cumplan ciertas
condiciones, siendo ejemplo típico de éstas:

▪ No involucrar a más de 15 o 20 desarrolladores


▪ No requerir más de cinco o seis meses de trabajo
▪ Un entorno de desarrollo apropiado para la comunicación entre los miembros del
equipo
▪ Que el cliente o usuario esté dispuesto y disponible para el trabajo conjunto con el
equipo de desarrollo.
▪ Que los requerimientos puedan ser formulados según va avanzando el proyecto.

Las diferencias más significativas entre las metodologías ágiles y


tradicionales son las siguientes:
Tabla 2. Metodologías tradicionales frente a Metodologías Ágiles.

A continuación, se exponen conceptos de un conjunto de metodologías ágiles que


se han considerado relevantes para este estudio:

1. XP – Programación Extrema Llamada Programación Extrema (eXtreme


Programming) toma su nombre por teorizar un conjunto de principios y prácticas
puramente de sentido común y llevarlos al extremo. XP está especialmente indicado
para dar respuesta a proyectos cuyos requisitos no están definidos y son
cambiantes, y donde el riesgo técnico es elevado.

Los valores que inspiran XP son los siguientes:

Figura 14. Valores que inspiran la programación extrema (XP).


Comunicación: frecuente y fluida, alineando la visión del sistema de los
programadores con la del cliente y favoreciendo la simplicidad.

Simplicidad: comenzar con la solución más simple.

Retroalimentación: a varios niveles, del resultado de las pruebas, del resultado de


la ejecución de las tareas respecto a las estimaciones iniciales, etc.

Coraje: también a varios niveles, trabajar para las necesidades presentes y no las
futuras, alentando la mejora del código sin efectos externos (refactorización),
persistencia frente a los problemas, etc.

2. SCRUM
Scrum es marco de trabajo iterativo e incremental para el desarrollo de proyectos,
productos y aplicaciones. Tiene su origen en el artículo “The new new product
development” de Nonaka y Takeuchi en 1986 en el que se examinan las pautas de
trabajo comunes de varias empresas en productos de éxito.

En éstas, el trabajo no recorría fases a través de distintos equipos especializados,


sino que un equipo altamente cualificado y multidisciplinar trabajaba conjuntamente
desde el principio hasta el final. Estos autores utilizan por primera vez el término
SCRUM (melé), como comparación de esta forma de trabajar con el término que se
utiliza en rugby para designar la jugada en que el equipo forma un bloque compacto
para seguir todos a una un fin común. Formalmente, no es hasta 1995 en la
“OOPSLA Business Object Design and Implementation Workshop” la presentación
y definición del marco de trabajo de SCRUM, en el estudio "Scrum Development
Process", por Ken Schwaber y Jeff Sutherland.

Figura 15. Esquemático del ciclo de vida de SCRUM.


RUP (Rational Unified Process).
Se define como un proceso de Ingeniería de Software cuyo objetivo es la producción
de software de calidad que satisface los requisitos del usuario final, en un plazo y
coste predecibles.

El proceso de desarrollo de software propuesto por RUP tiene tres características


esenciales: está dirigido por los Casos de Uso, está centrado en la arquitectura, y
es iterativo e incremental.

Dirigido por Casos de Uso

Los casos de uso se utilizan para la toma de requisitos, representando aquellas


funcionalidades del sistema que proporcionarán al usuario un valor añadido. Sirven
de guía para el diseño del sistema, su implementación y las pruebas, constituyendo
una guía de trabajo y un elemento integrador que permitirá la trazabilidad entre los
artefactos que son generados en las diferentes actividades del proceso de
desarrollo.

Figura 16. R.U.P. Los casos de uso, elemento integrador


Ética en la ingeniería de software
Como otras disciplinas de ingeniería, la ingeniería de software se realiza dentro de
un marco social y legal que limita la libertad de la gente que trabaja en dicha área.

Figura 4. El código de ética en la ingeniería de software.

Como ingeniero de software, usted debe aceptar que su labor implica


responsabilidades mayores que la simple aplicación de habilidades técnicas.
También debe comportarse de forma ética y moralmente responsable para ser
respetado como un ingeniero profesional. No sobra decir que debe mantener
estándares normales de honestidad e integridad.

No debe usar sus habilidades y experiencia para comportarse de forma


deshonesta o de un modo que desacredite la profesión de ingeniería de software.
Sin embargo, existen áreas donde los estándares de comportamiento aceptable
no están acotados por la legislación, sino por la noción más difusa de
responsabilidad profesional.

➢ Algunas de ellas son:

1. Confidencialidad. Por lo general, debe respetar la confidencialidad de sus


empleadores o clientes sin importar si se firmó o no un acuerdo formal sobre la
misma.

2. Competencia. No debe desvirtuar su nivel de competencia. Es decir, no hay


que aceptar de manera intencional trabajo que esté fuera de su competencia.

3. Derechos de propiedad intelectual. Tiene que conocer las leyes locales que
rigen el uso de la propiedad intelectual, como las patentes y el copyright. Debe ser
cuidadoso para garantizar que se protege la propiedad intelectual de empleadores
y clientes.
4. Mal uso de computadoras. No debe emplear sus habilidades técnicas para
usar incorrectamente las computadoras de otros individuos. El mal uso de
computadoras varía desde lo relativamente trivial (esto es, distraerse con los
juegos de la PC del compañero) hasta lo extremadamente serio (diseminación de
virus u otro malware).

Conclusiones

En este trabajo de investigación principalmente vimos algunos conceptos como


que es el software y lo que es ingeniería de software para entender mejor el tema.

Vimos los procesos y las metodologías que se aplican dentro de la ingeniería de


software, para poder desarrollar un proyecto de forma correcta y cuáles son las
características que este debe tener.

Y también conocimos la ética o valores que se deben aplicar dentro de esta


ingeniería como profesional.

Ya conocimos mas como es esta ingeniería, y cuales también serian algunos


campos de trabajo si tomamos esta carrera más a fondo.

Fuentes:
http://bibing.us.es/proyectos/abreproy/70201/fichero/02+-
+Ingenieria+del+Software.pdf / libro.
http://zeus.inf.ucv.cl/~bcrawford/AULA_ICI_3242/Ingenieria%20del%20Software%
207ma.%20Ed.%20-%20Ian%20Sommerville.pdf / libro.
ftp://april.frm.utn.edu.ar/METODOLOGIA%20DE%20SISTEMAS%20-
%20TSP/LIBROS/Ingenieria%20de%20Software-Somerville.pdf / libro.
http://sosagas.blogspot.mx/2011/09/capas-de-la-ingenieria-de-software.html
https://umad.edu.mx/ingenieria-de-software/
http://yaqui.mxl.uabc.mx/~molguin/as/IngSoft%201-4.pdf

Вам также может понравиться