Ejemplo:
Al momento de diseñar un sistema se debe conversar con el cliente para que el exponga sus ideas, con respecto a lo que desea que haga su sistema, estas deben ser lo mas claras y precisas de hecho el diseñador esta atento para ayudar a expresar lo que se debe hacer, se transcriben para llevar un control.
Esta información no es más que los requerimientos del sistema a realizar.
Es el proceso de recopilar, analizar y verificar las necesidades del cliente o usuario para un sistema. Tiene la finalidad de entregar una especificación de requisitos de software correcta y completa.
Este permite definir todas las actividades involucradas en el descubrimiento, documentación y mantenimiento de los requerimientos para un producto de software determinado, aquí se debe tomar en cuenta la viabilidad de llevar a cabo el software (si es factible llevarlo a cabo o no), luego realizar un subproceso de obtención y análisis de requerimientos, su especificación formal, para finalizar la validación donde se verifica que los requerimientos realmente definen el sistema que quiere el cliente.
La ingeniería de requerimientos es de gran importancia al momento de realizar un software ya que:
*Permite gestionar las necesidades del proyecto en forma estructurada ya que cada actividades una serie de pasaos bien definidos y organizados.
*Mejora la capacidad de predecir cronogramas de proyectos, así como sus resultados: proporciona un punto de partida para controles subsecuentes y actividades de mantenimiento, la estimación de costos, tiempo y recursos necesarios.
· Disminuye los costos y retrasos del proyecto: el hecho de tener claro lo que se desea evita un gran margen de error por lo tanto se ahorra tiempo al momentos de corregirlos y económicamente es mucho más factible.
· Mejora la calidad del software: se mejora la calidad ya que permite cumplir con los requerimientos ya expuestos tales como la funcionalidad, factibilidad de uso, entre otros.
· Mejora la comunicación entre equipos: La especificación de requerimientos representa una forma de consenso entre clientes y desarrolladores. Si este consenso no ocurre, el proyecto no será exitoso.
· Evita rechazos de usuarios finales: La ingeniería de requerimientos obliga al cliente a considerar sus requerimientos cuidadosamente y revisarlos dentro del marco del problema, por lo que se le involucra durante todo el desarrollo del proyecto.
Para completar el proceso de ingeniería de requerimiento se requiere llevar a cabo diversas actividades:
En esta fase los analistas de requerimientos deben trabajar junto al cliente para descubrir el problema que el sistema debe resolver, los diferentes servicios que debe prestar, las restricciones que se pueden presentar y otros. Es importante, es de gran importancia que esta sea efectiva, ya que la aceptación del sistema dependerá de cuán bien éste satisfaga las necesidades del cliente.
v Análisis (Evaluación y negociación de los requerimientos)
Basándose en la información que se tiene de la fase de la extracción realizada previamente, se enfoca el análisis para captar los problemas del sistema identificados hasta el momento. Usualmente se hace un análisis luego de haber producido un bosquejo inicial del documento de requerimientos; se leen detenidamente los requerimientos, se conceptúan, se investigan, se intercambian ideas con el resto del equipo, se resaltan los problemas, se buscan alternativas y soluciones, y luego se van fijando reuniones con el cliente para discutir los requerimien
Por medio de esta fase se documentan detalladamente los requerimientos acordados con el cliente. Se trata de transcribir el análisis anteriormente realizado utilizando técnicas y/o estándares de documentación, como la notación UML .
Es la etapa final de la IR. Su objetivo es, ratificar los requerimientos, en otras palabras, verificar todos los requerimientos que aparecen en el documento especificado para asegurarse que representan una descripción, Esto implica verificar que los requerimientos sean consistentes y que estén completos.
Los requerimientos son una manera de comprender mejor el desarrollo de las necesidades de los usuarios y cómo los objetivos de la organización pueden cambiar, por lo tanto, es esencial planear posibles cambios a los requerimientos cuando el sistema sea desarrollado y utilizado. La actividad de evolución es un proceso externo que ocurre a lo largo del ciclo de vida del proyecto.
Los requerimientos cambian por diferentes razones. Las más frecuentes son:
· Porque al analizar el problema, no se hacen las preguntas correctas a las personas correctas.
· Porque cambió el problema que se estaba resolviendo.
· Porque los usuarios cambiaron su forma de pensar o sus percepciones.
· Porque cambió el ambiente de negocios.
· Porque cambió el mercado en el cual se desenvuelve el negocio.
Cambios a los requisitos involucra modificar el tiempo en el que se va a implementar una característica en particular
Ejemplo:
Como ya se menciono anteriormente para poder tener claro los requerimientos se deben realizar las siguientes actividades.
ü Extracción (Análisis del problema)
Se realiza en primera estancia entrevista al cliente el cual suministra la información de que desea que realice el sistema incluyendo sus restricciones estas son transcripta para ser utilizado como apoyo para el desarrollador.
ü Análisis (Evaluación y negociación de los requerimientos)
EL desarrollador la información ya recopilada analiza dicha información buscando verificar su factibilidad, las posibles nuevas opciones y hasta los errores que puede arrojar.
ü Especificación
Los resultados del análisis se discuten con el cliente llegando a un acuerdo, se trascribe toda la información de manera organizada utilizando técnicas y estándar con algún tipo de lenguaje adecuado
ü Validación
La información ya organizada se verifica par ratificar que cumpla con los requerimientos solicitado y no falte nada, de ser así se agregan o eliminan procesos dependiendo de cual sea la necesidad.
ü Evolución de los requerimientos
En esta fase se desarrolla el sistema, es recomendable en esta actividad guardar todo lo referente a los códigos de programación e interfases graficas, ya que a medida del desarrollo surgen diversas modificaciones dados, por el cliente, por errores arrojados por el sistema o por las necesidades del mismo.
Las entrevistas y cuestionarios es una técnica que se utiliza para reunir información proveniente de personas o de grupos. Durante la entrevista, el analista conversa con el encuestado; el cuestionario consiste en una serie de preguntas relacionadas con varios aspectos de un sistema
Esta técnica consiste en analizar distintos sistemas ya desarrollados que estén relacionados con el sistema a ser construido.
Este es un modelo que se usa para generar ideas. Las reglas básicas a seguir son:
· Los participantes deben pertenecer a distintas disciplinas y, preferentemente, deben tener mucha experiencia. Esto trae aparejado la obtención de una cantidad mayor de ideas creativas.
· Conviene suspender el juicio crítico y se debe permitir la evolución de cada una de las ideas, porque sino se crea un ambiente hostil que no alienta la generación de ideas.
· Por más locas o salvajes que parezcan algunas ideas, no se las debe descartar, porque luego de maduradas probablemente se tornen en un requerimiento sumamente útil.
· A veces ocurre que una idea resulta en otra idea, y otras veces podemos relacionar varias ideas para generar una nueva.
· Escribir las ideas sin censura.
Para validar los requerimientos hallados, se construyen prototipos. Los prototipos son simulaciones del posible producto, que luego son utilizados por el usuario final, permitiéndonos conseguir una importante retroalimentación en cuanto a si el sistema diseñado con base a los requerimientos recolectados le permite al usuario realizar su trabajo de manera eficiente y efectiva. El desarrollo del prototipo comienza con la captura de requerimientos. Desarrolladores y clientes se reúnen y definen los objetivos globales del software, identifican todos los requerimientos que son conocidos, y señalan áreas en las que será necesaria la profundización en las definiciones. Luego de esto, tiene lugar un “diseño rápido”. El diseño rápido se centra en una representación de aquellos aspectos del software que serán visibles al usuario (por ejemplo, entradas y formatos de las salidas).
Un caso de uso es una secuencia de transacciones que son desarrolladas por un sistema en respuesta a un evento que inicia un actor sobre el propio sistema. Los diagramas de casos de uso sirven para especificar la funcionalidad y el comportamiento de un sistema mediante su interacción con los usuarios y/o otros sistemas.
Ejemplo:
ü Las entrevistas se utiliza con gran prioridad en un principio es de gran importancia ya que por medio de ella se obtienen los requerimientos del sistema
Su gran ventaja es que nos permite recolectar toda la información indispensable para es sistema.
Su desventaja radica que al momento de hacerse se debe realizar de una manera concisa para que no se preste a confusiones mas adelante.
ü Los sistemas existentes pueden ser utilizados luego de tener la información sobre el sistema para ubicar uno parecido y poder utilizarse como guía, como los que son permitidos observar en las hemerotecas.
Su ventaja radica en que ya estos existen y pueden ser de gran ayuda para guiarse.
Su desventaja es que se debe estar claro en que los requerimientos lo mas seguro es que sean parecido, y es para ser utilizado como guía mas no como copia exacta lo cual nos puede traer contratiempo.
ü Lluvia de ideas esta técnica se utiliza en conjunto de entrevistas a una muestra de la población que utilizara el sistema ya que las ideas son diversas,
Su ventaja es que la cantidad de ideas es bastante grande por lo tanto salen a resaltar ideas que tal ves no habían salido a relucir y fuesen de gran importancia.
Su desventaja es que se utiliza un poco mas de tiempo para la recolección de ideas y luego deben ser analizada para desechar las que no sean de interés.
Prototipos los realizamos antes del desarrollo del sistema para que el usuario tenga una idea del sistema.
Su ventaja es que por medio de este prototipo el cliente observa si lo que se esta realizando