Professional Documents
Culture Documents
ACRIMOS
DAG Grafo acclico dirigido
FSM Medida funcional del tamao
INCOSE Consejo Internacional sobre Ingeniera
de Sistemas
SADT Anlisis estructurado y tcnicas de
diseo
UML Unified Modeling Language
ITRODUCCI
1
ms que una nica actividad discreta realizada al principio de un proyecto de desarrollo
de software.
El rea de conocimiento de los requisitos del software se relaciona de cerca con las
reas de diseo del software, pruebas, mantenimiento del software, gestin de la
configuracin del software, gestin de la ingeniera de software, proceso de la ingeniera
de software, y calidad de software.
Fig. 1 Descomposicin de los temas del rea de conocimiento de los requisitos del
software.
Bsicamente, un requisito del software es una caracterstica que se debe exhibir para
solucionar un cierto problema en el del mundo real. La Gua se refiere a requisitos de
software porque se refiere a los problemas que tratar el software. Por lo tanto, un
requisito del software es una caracterstica que debe exhibir el software desarrollado o
adaptado para solucionar un problema particular. El problema puede ser automatizar
parte de una tarea de alguien que utilizar el software, sustentar los procesos del
negocio de la organizacin que ha encargado el software, corregir defectos del software
existente, controlar un dispositivo, y muchos ms. El funcionamiento de los usuarios,
los procesos del negocio y los dispositivos es generalmente complejo. Por extensin,
2
por lo tanto, los requisitos de un software particular son, por lo general, una compleja
combinacin de requisitos de distintas personas en diversos niveles de una organizacin
y del ambiente en el cual el software funcionar.
Una caracterstica esencial de todos los requisitos del software es que sean
comprobables. Puede ser difcil o costoso verificar ciertos requisitos del software. Por
ejemplo, verificar un requisito de la capacidad de procesamiento sobre un call-center
puede hacer necesario el desarrollo de software de simulacin. Tanto los requisitos del
software como el personal de calidad del software deben asegurar que los requisitos se
puedan verificar dentro de las restricciones de recursos disponibles.
Los requisitos tienen otros atributos adems de las propiedades de comportamiento que
expresan; como, por ejemplo, una tasa de prioridad para permitir negociaciones frente a
recursos finitos y un valor del estado para permitir supervisar el progreso del proyecto.
Generalmente, los requisitos del software se identifican de forma nica, de modo tal
que puedan estar sujetos a control de la configuracin del software y gestionados a lo
largo de todo el ciclo vital del software. [Kot00; Pfl01; Som05; Tha97]
Se puede establecer una distincin entre los parmetros del producto y los del proceso.
Los parmetros del producto son requisitos del software a ser desarrollado (por ejemplo,
el software verificar que un estudiante cumpla todos los requisitos previos antes de
que se inscriba en un curso.).
Algunos requisitos del software generan requisitos del proceso implcitos. La eleccin
de la tcnica de la verificacin es un ejemplo. Otro puede ser el uso de tcnicas
rigurosas particulares de anlisis (tales como mtodos de especificacin formales) para
reducir fallas que pueden llevar a una inadecuada confiabilidad.
Los requisitos del proceso tambin pueden ser impuestos directamente por la
organizacin desarrolladora, su cliente, o una tercera parte tal como un regulador de
seguridad [Kot00; Som97].
Los requisitos funcionales describen las funciones que el software debe ejecutar; por
ejemplo, ajustarse a un formato de texto o modular una seal. Se conocen tambin como
capacidades.
Los requisitos no funcionales son los que actan para restringir la solucin. Los
requisitos no funcionales se conocen a veces como restricciones o requisitos de la
calidad. Pueden ser clasificados ms a fondo segn sean requisitos de performance,
requisitos de mantenimiento, requisitos de seguridad, requisitos de confiabilidad o uno
de muchos otros tipos de requisitos del software [Kot00; Som97]
3
1.4. Propiedades emergentes
Algunos requisitos representan propiedades emergentes del software- esto es, requisitos
que no pueden ser satisfechos por un solo componente, sino que su satisfaccin depende
de cmo interoperen todos los componentes del software. El requisito de capacidad de
procesamiento de un centro de llamadas, por ejemplo, depende de cmo interacten el
sistema telefnico, el sistema de informacin y los operadores, bajo las condiciones de
operacin reales. Las propiedades emergentes dependen de forma crucial de la
arquitectura del sistema. [Som05]
Los requisitos del software se deben indicar tan clara e inequvocamente como sea
posible, y cuantitativamente, en los casos apropiados. Es importante evitar requisitos
vagos e inverificables, cuya interpretacin dependa del juicio subjetivo (el software
ser confiable; el software ser de uso fcil). Esto es particularmente importante para
los requisitos no funcionales. Dos ejemplos de requisitos cuantificados son los
siguientes: el software para un centro de llamadas debe aumentar la capacidad de
procesamiento del centro en un 20%; y un sistema tendr una probabilidad de generar
un error fatal durante una hora cualquiera de operacin de menos de 1 * 108. El
requisito de capacidad de procesamiento est a un alto nivel y necesitar ser utilizado
para derivar varios requisitos detallados. El requisito de confiabilidad restringir
firmemente la arquitectura del sistema. [Dav93; Som05]
En este contexto, sistema significa una combinacin de elementos que interactan para
lograr un objetivo definido. Estos incluyen el hardware, software, firmware, gente,
informacin, tcnicas, instalaciones, servicios y otros elementos de apoyo, segn lo
definido por el Consejo Internacional sobre la Ingeniera de Sistemas (INCOSE00).
Los requisitos del sistema son los requisitos del sistema en su totalidad. En un sistema
que contiene componentes de software, los requisitos del software se derivan de los
requisitos del sistema.
La literatura sobre requisitos llama a veces a los requisitos del sistema requisitos del
usuario. La Gua define requisitos el usuario de una manera restringida, como
requisitos de los clientes o de los usuarios finales del sistema. Los requisitos del
sistema, por el contrario, abarcan a los requisitos del usuario, requisitos de otras partes
interesadas (por ejemplo autoridades reguladoras) y requisitos sin un origen humano
identificable.
Esta seccin introduce el proceso de los requisitos del software, orientando las cinco
subzonas restantes y demostrando cmo el proceso de los requisitos encaja con el
proceso de ingeniera del software. [Dav93; Som05]
4
El objetivo de este asunto es proporcionar una comprensin de que el proceso de los
requisitos
No es una actividad anticipada discreta del ciclo vital del software, sino un proceso
iniciado en principio de un proyecto y a continuacin refinado a travs del ciclo
vital.
Identifica los requisitos del software como elementos de configuracin, y los maneja
usando las mismas prcticas de gerencia de la configuracin del software como
otros productos de los procesos del ciclo vital del software.
Este asunto introduce los papeles de la gente que participa en el proceso de los
requisitos. Este proceso es fundamental interdisciplinario, y el especialista de los
requisitos necesita mediar entre el dominio del tenedor de apuestas y el de la tecnologa
de dotacin lgica. Hay mucha gente implicada adems del especialista de los
requisitos, cada uno de ellos tiene una funcin en el software. Los tenedores de apuestas
variarn segn los proyectos, pero incluyen siempre usuarios/operadores y clientes
(quines no necesitan ser iguales). [Gog93]
Los ejemplos tpicos de los tenedores de apuestas del software incluyen (pero no
restringen)
Usuarios: Este grupo abarca a los que utilizan el software. Es a menudo un grupo
heterogneo que abarca a gente con diversos papeles y requisitos.
Clientes: Este grupo abarca a los que han comisionado el software o quin
representa el blanco de mercado del software.
Analistas de mercado: Un producto del mass-market no tendr un cliente que
comisiona, de modo que la gente de comercializacin a menudo necesita establecer
lo que el mercado necesita y actuar como clientes.
Reguladores: Muchos dominios de aplicacin como por ejemplo el transporte
pblico o la banca son regulados. El software en estos dominios debe conformarse
con los requisitos de las autoridades reguladoras.
Ingenieros de software: Estas personas tienen un inters legtimo en beneficiarse del
desarrollo del software, por ejemplo, reutilizando componentes en otros productos.
Si, en este escenario, un cliente de un producto particular tiene requisitos especficos
que comprometen el potencial para la reutilizacin de componentes, los ingenieros
de software deben pesar cuidadosamente sus propios intereses contra los del cliente.
5
los stakeholder principales y dentro de presupuestario, tcnico, regulador, y otros
apremios. Un requisito previo para esto es que identifiquen a todos los stakeholders, la
naturaleza de su inters analizada, y sus requisitos sacados.
[Dav93; Kot00; Rob99; Som97; You01]
La captura de los requisitos se refiere a de donde vienen los requisitos del software y
cmo el ingeniero de software puede recogerlos. Es la primera etapa en la construccin
de una comprensin del problema que el software requiere solucionar. Es fundamental
una actividad humana, y es donde identifican a los stakeholders y las relaciones se
establecen entre el equipo del desarrollo y el cliente. Tambin se conoce como
descubrimiento de los requisitos, y adquisicin de los requisitos.
6
Los requisitos tienen muchas fuentes en software tpico, y es esencial que todas las
fuentes potenciales estn identificadas y evaluadas para su impacto en l. Este asunto se
disea para promover el conocimiento de las varias fuentes de los requisitos del
software y de los armazones para manejarlos. Los puntos principales cubiertos son
Una vez que se hayan identificado las fuentes de los requisitos, ingenieros de software
pueden comenzar a sacar requisitos de ellos. Este asunto se concentra en las tcnicas
para conseguir que los stakeholders articulen sus requisitos. Es un rea muy difcil y
ingenieros de software necesitan sensibilizarse al hecho que (por ejemplo) los usuarios
pueden tener dificultad para describir sus tareas, puede dejar la informacin importante
sin especificar, o pueden estar poco dispuestos o cooperar. Es particularmente
importante entender que la captura no es una actividad pasiva, y que, ingenieros de
software tienen que trabajar difcilmente para sacar la informacin adecuada. Existe un
nmero de tcnicas para hacer esto, las principales son [Gog93]
7
Entrevistas, medios tradicionales de sacar requisitos. Es importante entender las
ventajas y limitaciones de las entrevistas y cmo deben ser conducidas.
Escenarios, valiosos medios para proporcionar contexto a las exigencias del
consumidor. Proporcionan un marco para preguntas sobre tareas del usuario
permitiendo preguntas y si y cmo se hace esto. El tipo ms comn de escenario
es el caso del uso.
Prototipos, una herramienta valiosa para clarificar requisitos confusos. Pueden actuar
de una manera similar a los escenarios, proveyendo a los usuarios un contexto dentro
del cul pueden entender mejor qu informacin necesitan proporcionar. Hay una
amplia gama de tcnicas de prototipado, maquetas de versiones de pruebas beta de los
diseos de la pantalla del software, y un traslado fuerte de su uso para captura de los
requisitos y el uso de prototipos para la validacin de los requisitos (vase el asunto 6.2
Prototipado).
Reuniones. El propsito de stas es intentar alcanzar un efecto aditivo por el que un
grupo de gente puede obtener ms penetracin en los requisitos del software que
trabajando individualmente. Ellos pueden inspirarse y refinar las ideas que pueden ser
difciles de traer a la superficie usando entrevistas. Otra ventaja es que dejan a los
stakeholders reconocer donde hay requisitos en conflicto. Cuando se aplica bien, esta
tcnica puede resultar en un rico y constante sistema de requisitos que difcilmente sera
realizable de otro modo. Sin embargo, las reuniones necesitan ser dirigidas
cuidadosamente (por lo tanto es necesario un facilitador) para evitar que una situacin
ocurra donde las capacidades crticas del equipo son erosionadas por lealtad del grupo, o
los requisitos que reflejan las preocupaciones de algunos favorecen la gente abierta (y
quizs mayor) en detrimento de otros.
Observacin. La importancia del contexto del software dentro del ambiente de
organizacin ha conducido a la adaptacin de las tcnicas de observacin para captura
de los requisitos. Los ingenieros de software aprenden sobre las tareas del usuario
sumergindose en la observacin de cmo los usuarios obran recprocamente con su
software. Estas tcnicas son relativamente costosas, pero son instructivas porque
ilustran que muchas tareas del usuario y procesos del negocio son demasiado sutiles y
complejos para que sus agentes los describan fcilmente.
4. Anlisis de requisitos
[Som05]
La vista tradicional del anlisis de requisitos ha sido que est reducida a modelado
conceptual utilizando uno de varios mtodos de anlisis tales como Anlisis
Estructurados y Tcnicas de Diseo (SADT). Mientras que el modelado conceptual es
importante, nosotros incluimos la clasificacin de requisitos para ayudar a informar a
compensaciones entre los requisitos (clasificacin de los requisitos) y el proceso de
establecer estas compensaciones (negociacin de los requisitos). [Dav93]
El cuidado se debe tomar para describir requisitos con exactitud, suficientemente como
para permitir que los requisitos sean validados, su implementacin sea verificada, y sus
costes estimados.
8
4.1 Clasificacin de los requisitos
[Dav93; Kot00; Som05]
Hay un desfase fuerte entre la clasificacin de los requisitos y las cualidades de los
requisitos (vase las cualidades de los requisitos del punto 7.3).
9
entidades del dominio del problema, configurados para reflejar sus relaciones y
dependencias con el mundo real.
Varias clases de modelos pueden ser desarrollados. stos incluyen datos y controlan
flujos, modelos de estado, rastros de evento, interacciones de usuario, modelos de
objeto, modelos de datos y muchos otros. Los factores que influencian la opcin del
modelo incluyen
La naturaleza del problema. Algunos tipos de software exigen que ciertos aspectos
estn analizados rigurosamente. Por ejemplo, controlar el flujo y los modelos de estado
son probablemente ms importantes para el software en tiempo real que para el software
de gerencia de informacin, mientras que es generalmente lo contrario para los modelos
de datos.
La maestra del ingeniero del software. Es a menudo ms productivo adoptar una
notacin que modele o mtodo con el cual el ingeniero del software tiene una
experiencia.
Los requisitos de proceso del cliente. Los clientes pueden imponer su notacin o
mtodo favorecido, o prohibir cualquiera que le sea desconocido. Este factor puede estar
en conflicto con el factor anterior.
La disponibilidad de mtodos y de herramientas. Notaciones o mtodos que son mal
apoyados por el entrenamiento y las herramientas pueden no alcanzar la aceptacin
esperada aunque se satisfagan tipos particulares de problemas.
Observar que, en casi todos los casos, es til comenzar construyendo un modelo del
contexto del software. El contexto del software proporciona una conexin entre el
software previsto y su ambiente externo. Esto es crucial para entender el contexto del
software en su ambiente operacional e identificar sus interfaces con el ambiente.
La aplicacin de modelar se junta firmemente con la de los mtodos. Para los propsitos
prcticos, un mtodo es una notacin (o sistema de notaciones) apoyado por un proceso
que dirige el uso de las notaciones. Hay escasa evidencia emprica para apoyar las
demandas de superioridad de una notacin sobre otra. Sin embargo, la extensa
aceptacin de un mtodo o de una notacin particular puede conducir a nivel industrial
al beneficio de habilidades y de conocimiento. sta es actualmente la situacin con el
UML (Lenguaje de Modelado Unificado). (UML04)
Este asunto no busca ensear un estilo o una notacin de modelado particular sino
proporcionar algo a la direccin con el propsito de modelar.
Dos estndares proporcionan las notaciones que pueden ser tiles en desarrollo
conceptual realizando modelado-IEEE conceptual Std 1320.1, IDEF0 para modelado
funcional; e IEEE Std 1320.2, IDEF1X97 (IDEFObject) para modelado de la
informacin.
10
[Dav93; Som05]
11
problemas emergen como resultado el anlisis. Sin embargo, un caso fuerte se puede
tambin hacer para considerar los requisitos como asunto de la validacin.
5. Especificacin de requisitos
12
La especificacin de requisitos del software establece la base para el acuerdo entre los
clientes y los contratistas o los proveedores (en proyectos del mercado, estos papeles se
pueden desempear por las divisiones de comercializacin y desarrollo) en los que hay
que hacer el producto de software, as como lo que no se espera que haga. Para los
lectores no tcnicos, el documento de la especificacin de los requisitos es acompaado
a menudo por un documento de la definicin de los requisitos del software.
IEEE tiene un estndar, IEEE Std 830 [IEEE830-98], para produccin y contenido de la
especificacin de los requisitos del software. Tambin, IEEE 1465 (similar a ISO/IEC
12119) es un estndar que trata requisitos de calidad en paquetes de software.
(IEEE1465-98)
13
estndares, y ste es comprensible, constante, y finito. Las notaciones formales ofrecen
la ventaja importante de permitir que las dos caractersticas pasadas sean probadas (en
un sentido estricto, por lo menos). Diversos stakeholders, incluyendo los representantes
del cliente y del revelador, deben tambin repasar los documentos. Los documentos de
los requisitos son conformes a las mismas prcticas de gerencia de la configuracin del
software como los otros puntos relevantes de los procesos del ciclo de vida del software.
(Bry94, Ros98)
Las revisiones se pueden constituir en el final del documento de definicin del sistema,
el documento de la especificacin de sistema, el documento de la especificacin de
requisitos del software, especificacin de la lnea de fondo para un nuevo lanzamiento,
o en cualquier otro paso en el proceso. IEEE Std 1028 proporciona la direccin para
conducir tales revisiones. (IEEE1028-97) Las revisiones son tambin cubiertas en KA
de la calidad del software, punto 2.3 Revisiones e intervenciones.
6.2. Prototipado
[Dav93; Kot00; Som05; Tha97]
14
6.3. Validacin modelo
[Dav93; Kot00; Tha97]
Una caracterstica esencial de un requisito del software es que debe ser posible validar
que el producto final lo satisface. Los requisitos que no pueden ser validados son
deseos realmente justos. Una tarea importante es por lo tanto planear cmo verificar
cada requisito. En la mayora de los casos, el diseo de pruebas de aceptacin hace esto.
Identificar y disear pruebas de aceptacin pueden ser difcil para los requisitos no
funcionales (vase el asunto los requisitos funcionales y no funcionales de 1.3). Para ser
validados, deben primero ser analizados al punto donde pueden ser expresados
cuantitativamente. La informacin adicional se puede encontrar en el software KA de
prueba, conformidad de la prueba en el punto 2.2.4.
7. Consideraciones prcticas
El primer nivel de la descomposicin de los puntos presentados en este KA puede
parecer que describe una secuencia lineal de actividades. sta es una vista simplificada
del proceso. [Dav93]
Los requisitos procesan palmos de todo el ciclo de vida del software. Cambiar la
gerencia y el mantenimiento de los requisitos en un estado que refleja exactamente el
software que se construir, o se ha construido, es clave para el xito del proceso
ingeniera del software [Kot00; Lou95]
Hay presin general en la industria del software para ciclos de desarrollo ms cortos, y
esto est particularmente pronunciado en sectores del mercado altamente competitivos.
15
Por otra parte, la mayora de los proyectos son obligados de cierta manera por su
ambiente, y muchas son mejoras, o revisiones, del software existente donde est la
arquitectura dada. En la prctica, por lo tanto, es casi siempre imprctico poner el
proceso de los requisitos en ejecucin como proceso lineal, determinista en el cual los
requisitos del software se saquen de los stakeholders, asignado, y entregado al equipo de
desarrollo del software. Es ciertamente un mito que los requisitos para los proyectos
grandes del software siempre estn entendidos perfectamente o especificados
perfectamente. [Som97]
16
34 requisitos del software se desarrollan en un cierto.
35
36 7.2. Cambiar a gestin
37 [Kot00]
38
39 La gestin del cambio es central en el anlisis de
40 requisitos. Este asunto describe el papel de la gestin
41 del cambio, los procedimientos que necesitan estar
42 preparados, y el anlisis que se debe aplicar a los
43 cambios propuestos. Tiene acoplamientos fuertes a la
44 configuracin del software KA de la gestin.
45
46 7.3. Cualidades de los requisitos
47 [Kot00]
48
49 Los requisitos deben consistir no slo una
50 especificacin de qu se requiere, sino tambin de la
51 informacin ancilar que las ayudas manejan e
52 interpretan los requisitos. Esto debe incluir varias
53 dimensiones de la clasificacin del requisito (vase
54 la clasificacin de los requisitos del asunto 4.1) y el
55 mtodo de la verificacin o el plan de prueba de
56 aceptacin. Puede tambin incluir la informacin
57 adicional tal como un resumen-anlisis razonado para
58 cada requisito, la fuente de cada requisito, y una
59 historia del cambio. Los requisitos ms importantes
60 atribuyen, sin embargo, un identificador que permite
61 requisitos identificados inequvocamente.
62
63 7.4 El remontar de los requisitos
64 [Kot00]
65
66 El remontar de los requisitos se refiere a la fuente
67 recuperacin de requisitos y de predecir los efectos
68 de esos requisitos. El trazado es fundamental para el
69 anlisis de la ejecucin del impacto cuando los
70 requisitos cambian. Un requisito debe ser detectable
71 al revs a requisitos y los stakeholders que lo
72 motivaron (de un requisito del software de nuevo a
73 los requisitos del sistema que ayudan a satisfacer, por
74 ejemplo). Inversamente, un requisito debe ser
75 detectable entidades del diseo que lo satisfacen (por
76 ejemplo, de un requisito del sistema en el software
77 requisitos que se han elaborado a partir de l, y
78 encendido en los mdulos del cdigo que lo ponen en
79 ejecucin).
80
81 Los requisitos que remontan para un proyecto tpico
82 formarn un grfico acclico dirigido complejo
83 (DAG) de requisitos.
17
84
85 7.5 Requisitos que miden
86 Como cuestin prctica, es tpicamente til tener
87 cierto concepto del volumen de los requisitos para
88 un producto de software particular. Este punto es til
89 evaluando el tamao de un cambio en requisitos, en
90 estimar el coste de una tarea del desarrollo o del
91 mantenimiento, o simplemente para el uso como el
92 denominador en otra medida. La medida funcional
93 del tamao (FSM) es una tcnica para evaluar el
94 tamao de un cuerpo de requisitos funcionales. IEEE
95 Std 14143.1 define el concepto de FSM.
96 [IEEE14143.1-00] Estndares de ISO/IEC y otras
97 fuentes describen mtodos particulares del FSM.
98
99 Informacin adicional sobre la medida del tamao y
100 los estandares se encuentran en el proceso de la
101 ingenieria del software.
18
32 [You01] R.R. You, Effective Requirements Practices,
33 Addison-Wesley, 2001.
1
2 APDICE A. LISTA DE LECTURAS
3 COMPLEMETARIAS
4
5 (Ale02) I. Alexander and R. Stevens, Writing Better
6 Requirements, Addison-Wesley, 2002.
7 (Ard97) M. Ardis, Formal Methods for
8 Telecommunication System Requirements: A Survey of
9 Standardized Languages, Annals of Software
10 Engineering, vol. 3, 1997.
11 (Ber97) V. Berzins et al., A Requirements Evolution
12 Model for Computer Aided Prototyping, presented at
13 Ninth IEEE International Conference on Software
14 Engineering and Knowledge Engineering, Knowledge
15 Systems Institute, 1997.
16 (Bey95) H. Beyer and K. Holtzblatt, Apprenticing with
17 the Customer, Communications of the ACM, vol. 38,
18 iss. 5, May 1995, pp. 45-52.
19 (Bru95) G. Bruno and R. Agarwal, Validating Software
20 Requirements Using Operational Models, presented at
21 Second Symposium on Software Quality Techniques
22 and Acquisition Criteria, 1995.
23 (Bry94) E. Bryne, IEEE Standard 830: Recommended
24 Practice for Software Requirements Specification,
25 presented at IEEE International Conference on
26 Requirements Engineering, 1994.
27 (Buc94) G. Bucci et al., An Object-Oriented Dual
28 Language for Specifying Reactive Systems, presented
29 at IEEE International Conference on Requirements
30 Engineering, 1994.
31 (Bus95) D. Bustard and P. Lundy, Enhancing Soft
32 Systems Analysis with Formal Modeling, presented at
33 Second International Symposium on Requirements
34 Engineering, 1995.
35 (Che94) M. Chechik and J. Gannon, Automated
36 Verification of Requirements Implementation,
37 presented at Proceedings of the International
38 Symposium on Software Testing and Analysis, special
39 issue, 1994.
40 (Chu95) L. Chung and B. Nixon, Dealing with Non-
41 Functional Requirements: Three Experimental Studies
42 of a Process-Oriented Approach, presented at
43 Seventeenth IEEE International Conference on Software
44 Engineering, 1995.
45 (Cia97) P. Ciancarini et al., Engineering Formal
46 Requirements: An Analysis and Testing Method for Z
47 Documents, Annals of Software Engineering, vol. 3,
48 1997.
19
49 (Cre94) R. Crespo, We Need to Identify the
50 Requirements of the Statements of Non-Functional
51 Requirements, presented at International Workshop on
52 Requirements Engineering: Foundations of Software
53 Quality, 1994.
54 (Cur94) P. Curran et al., BORIS-R Specification of the
55 Requirements of a Large-Scale Software Intensive
56 System, presented at Requirements Elicitation for
57 Software-Based Systems, 1994.
58 (Dar97) R. Darimont and J. Souquieres, Reusing
59 Operational Requirements: A Process-Oriented
60 Approach, presented at IEEE International Symposium
61 on Requirements Engineering, 1997.
62
63
64 (Dav94) A. Davis and P. Hsia, Giving Voice to
65 Requirements Engineering: Guest Editors
66 Introduction, IEEE Software, vol. 11, iss. 2, March
67 1994, pp. 12-16.
68 (Def94) J. DeFoe, Requirements Engineering
69 Technology in Industrial Education, presented at IEEE
70 International Conference on Requirements
71 Engineering,1994.
72 (Dem97) E. Demirors, A Blackboard Framework for
73 Supporting Teams in Software Development, presented
74 at Ninth IEEE International Conference on Software
75 Engineering and Knowledge Engineering, Knowledge
76 Systems Institute, 1997.
77 (Die95) M. Diepstraten, Command and Control System
78 Requirements Analysis and System Requirements
79 Specification for a Tactical System, presented at First
80 IEEE International Conference on Engineering of
81 complex Computer Systems, 1995.
82 (Dob94) J. Dobson and R. Strens, Organizational
83 Requirements Definition for Information Technology,
84 presented at IEEE International Conference on
85 Requirements Engineering, 1994.
86 (Duf95) D. Duffy et al., A Framework for
87 Requirements Analysis Using Automated Reasoning,
88 presented at Seventh International Conference on
89 Advanced Information Systems Engineering, 1995.
90 (Eas95) S. Easterbrook and B. Nuseibeh, Managing
91 Inconsistencies in an Evolving Specification, presented
92 at Second International Symposium on Requirements
93 Engineering, 1995.
94 (Edw95) M. Edwards et al., RECAP: A Requirements
95 Elicitation, Capture, and Analysis Process Prototype
96 Tool for Large Complex Systems, presented at First
97 IEEE International Conference on Engineering of
98 Complex Computer Systems, 1995.
20
99 (ElE95) K. El-Emam and N. Madhavji, Requirements
100 Engineering Practices in Information Systems
101 Development: A Multiple Case Study, presented at
102 Second International Symposium on Requirements
103 Engineering, 1995.
104 (Fai97) R. Fairley and R. Thayer, The Concept of
105 Operations: The Bridge from Operational Requirements
106 to Technical Specifications, Annals of Software
107 Engineering, vol. 3, 1997.
108 (Fic95) S. Fickas and M. Feather, Requirements
109 Monitoring in Dynamic Environments, presented at
110 Second International Symposium on Requirements
111 Engineering, 1995.
112 (Fie95) R. Fields et al., A Task-Centered Approach to
113 Analyzing Human Error Tolerance Requirements,
114 resented at Second International Symposium on
115 Requirements Engineering, 1995.
116 (Gha94) J. Ghajar-Dowlatshahi and A. Varnekar,
117 Rapid Prototyping in Requirements Specification Phase
118 of Software Systems, presented at Fourth International
119 Symposium on Systems Engineering, National Council
120 on Systems Engineering, 1994.
121 (Gib95) M. Gibson, Domain Knowledge Reuse During
122
123
124
125 Requirements Engineering, presented at Seventh
126 International Conference on Advanced Information
127 Systems Engineering (CAiSE 95), 1995.
(Gol94) L. 1 Goldin and D. Berry, AbstFinder: A
2 Prototype Abstraction Finder for Natural Language Text
3 for Use in Requirements Elicitation: Design,
4 Methodology and Evaluation, presented at IEEE
5 International Conference on Requirements Engineering,
6 1994.
7 (Got97) O. Gotel and A. Finkelstein, Extending
8 Requirements Traceability: Lessons Learned from an
9 Industrial Case Study, presented at IEEE International
10 Symposium on Requirements Engineering, 1997.
11 (Hei96) M. Heimdahl, Errors Introduced during the
12 TACS II Requirements Specification Effort: A
13 Retrospective Case Study, presented at Eighteenth
14 IEEE International Conference on Software
15 Engineering, 1996.
16 (Hei96a) C. Heitmeyer et al., Automated Consistency
17 Checking Requirements Specifications, ACM
18 Transactions on Software Engineering and
19 Methodology, vol. 5, iss. 3, July 1996, pp. 231-261.
20 (Hol95) K. Holtzblatt and H. Beyer, Requirements
21 Gathering: The Human Factor, Communications of the
21
22 ACM, vol. 38, iss. 5, May 1995, pp. 31-32.
23 (Hud96) E. Hudlicka, Requirements Elicitation with
24 Indirect Knowledge Elicitation Techniques: Comparison
25 of Three Methods, presented at Second IEEE
26 International Conference on Requirements Engineering,
27 1996.
28 (Hug94) K. Hughes et al., A Taxonomy for
29 Requirements Analysis Techniques, presented at IEEE
30 International Conference on Requirements Engineering,
31 1994.
32 (Hug95) J. Hughes et al., Presenting Ethnography in
33 the Requirements Process, presented at Second IEEE
34 International Symposium on Requirements Engineering,
35 1995.
36 (Hut94) A.T.F. Hutt, ed., Object Analysis and Design -
37 Comparison of Methods. Object Analysis and Design -
38 Description of Methods, John Wiley & Sons,
39 1994.(INCOSE00) INCOSE, How To: Guide for all
40 Engineers, Version 2, International Council on Systems
41 Engineering, 2000.
42 (Jac95) M. Jackson, Software Requirements and
43 Specifications, Addison-Wesley, 1995.
44 (Jac97) M. Jackson, The Meaning of Requirements,
45 Annals of Software Engineering, vol. 3, 1997.
46 (Jon96) S. Jones and C. Britton, Early Elicitation and
47 Definition of Requirements for an Interactive
48 Multimedia Information System, presented at Second
49 IEEE International Conference on Requirements
50 Engineering, 1996.
51 (Kir96) T. Kirner and A. Davis, Nonfunctional
52 Requirements for Real-Time Systems, Advances in
53 Computers, 1996.
54 (Kle97) M. Klein, Handling Exceptions in
55 Collaborative Requirements Acquisition, presented at
56 IEEE International Symposium on Requirements
57 Engineering,
58 1997.
59 (Kos97) R. Kosman, A Two-Step Methodology to
60 Reduce Requirements Defects, Annals of Software
61 Engineering, vol. 3, 1997.
62 (Kro95) J. Krogstie et al., Towards a Deeper
63 Understanding of Quality in Requirements
64 Engineering, presented at Seventh International
65 Conference on Advanced Information Systems
66 Engineering (CAiSE 95), 1995.
67 (Lal95) V. Lalioti and B. Theodoulidis, Visual
68 Scenarios for Validation of Requirements
69 Specification, presented at Seventh International
70 Conference on Software Engineering and Knowledge
71 Engineering, Knowledge Systems Institute, 1995.
22
72 (Lam95) A. v. Lamsweerde et al., Goal-Directed
73 Elaboration of Requirements for a Meeting Scheduler:
74 Problems and Lessons Learnt, presented at Second
75 International Symposium on Requirements Engineering,
76 1995.
77 (Lei97) J. Leite et al., Enhancing a Requirements
78 Baseline with Scenarios, presented at IEEE
79 International Symposium on Requirements Engineering,
80 1997.
81 (Ler97) F. Lerch et al.., Using Simulation-Based
82 Experiments for Software Requirements Engineering,
83 Annals of Software Engineering, vol. 3, 1997.
84 (Lev94) N. Leveson et al., Requirements Specification
85 or Process-Control Systems, IEEE Transactions on
86 Software Engineering, vol. 20, iss. 9, September 1994,
87 pp. 684-707.
88 (Lut96a) R. Lutz and R. Woodhouse, Contributions of
89 SFMEA to Requirements Analysis, presented at
90 Second IEEE International Conference on Requirements
91 Engineering, 1996.
92 (Lut97) R. Lutz and R. Woodhouse, Requirements
93 Analysis Using Forward and Backward Search, Annals
94 of Software Engineering, vol. 3, 1997.
95 (Mac96) L. Macaulay, Requirements Engineering,
96 Springer-Verlag, 1996.
97 (Mai95) N. Maiden et al., Computational Mechanisms
98 for Distributed Requirements Engineering, presented at
99 Seventh International Conference on Software
100 Engineering and Knowledge Engineering, Knowledge
101 Systems Institute, 1995.
102 (Mar94) B. Mar, Requirements for Development of
103 Software Requirements, presented at Fourth
104 International Symposium on Systems Engineering,
105 1994.
106 (Mas97) P. Massonet and A. v. Lamsweerde,
107 Analogical Reuse of Requirements Frameworks,
108 presented at IEEE International Symposium on
109 Requirements Engineering, 1997.
110 (McF95) I. McFarland and I. Reilly, Requirements
111 Traceability in an Integrated Development
112 Environment, presented at Second International
113 Symposium on Requirements Engineering, 1995.
114 (Mea94) N. Mead, The Role of Software Architecture
115 in Requirements Engineering, presented at IEEE
116 International Conference on Requirements Engineering,
117 1994.
118 (Mos95) D. Mostert and S. v. Solms, A Technique to
119 Include Computer Security, Safety, and Resilience
120 Requirements as Part of the Requirements
121 Specification, Journal of Systems and Software, vol.
23
122 31, iss. 1, October 1995, pp. 45-53.
123 (Myl95) J. Mylopoulos et al., Multiple Viewpoints
124 Analysis of Software Specification Process, IEEE
125 Transactions on Software Engineering, 1995.
126 (Nis92) K. Nishimura and S. Honiden, Representing
127 and Using Non-Functional Requirements: A ProcessOriented
Approach, 1 IEEE Transactions on Software
2 Engineering, December 1992.
3 (Nis97) H. Nissen et al., View-Directed Requirements
4 Engineering: A Framework and Metamodel, presented
5 at Ninth IEEE International Conference on Software
6 Engineering and Knowledge Engineering, Knowledge
7 Systems Institute, 1997.
8 (OBr96) L. OBrien, From Use Case to Database:
9 Implementing a Requirements Tracking System,
10 Software Development, vol. 4, iss. 2, February 1996, pp.
11 43-47.
12 (UML04) Object Management Group, Unified Modeling
13 Language, www.uml.org, 2004. (Opd94) A. Opdahl,
14 Requirements Engineering for Software Performance,
15 presented at International Workshop on Requirements
16 Engineering: Foundations of Software Quality, 1994.
17 (Pin96) F. Pinheiro and J. Goguen, An Object-Oriented
18 Tool for Tracing Requirements, IEEE Software, vol.
19 13, iss. 2, March 1996, pp. 52-64.
20 (Pla96) G. Playle and C. Schroeder, Software
21 Requirements Elicitation: Problems, Tools, and
22 Techniques, Crosstalk: The Journal of Defense
23 Software Engineering, vol. 9, iss. 12, December 1996,
24 pp. 19-24.
25 (Poh94) K. Pohl et al., Applying AI Techniques to
26 Requirements Engineering: The NATURE Prototype,
27 presented at IEEE Workshop on Research Issues in the
28 Intersection Between Software Engineering and
29 Artificial Intelligence, 1994.
30 (Por95) A. Porter et al., Comparing Detection Methods
31 for Software Requirements Inspections: A Replicated
32 Experiment, IEEE Transactions on Software
33 Engineering, vol. 21, iss. 6, June 1995, pp. 563-575.
34 (Pot95) C. Potts et al., An Evaluation of Inquiry-Based
35 Requirements Analysis for an Internet Server,
36 presented at Second International Symposium on
37 Requirements Engineering, 1995.
38 (Pot97) C. Potts and I. Hsi, Abstraction and Context in
39 Requirements Engineering: Toward a Synthesis,
40 Annals of Software Engineering, vol. 3, 1997.
41 (Pot97a) C. Potts and W. Newstetter, Naturalistic
42 Inquiry and Requirements Engineering: Reconciling
43 Their Theoretical Foundations, presented at IEEE
44 International Symposium on Requirements Engineering,
24
45 1997.
46 (Ram95) B. Ramesh et al., Implementing Requirements
47 Traceability: A Case Study, presented at Second
48 International Symposium on Requirements Engineering,
49 1995.
50 (Reg95) B. Regnell et al., Improving the Use Case
51 Driven Approach to Requirements Engineering,
52 presented at Second IEEE International Symposium on
53 Requirements Engineering, 1995.
54 (Reu94) H. Reubenstein, The Role of Software
55 Architecture in Software Requirements Engineering,
56 presented at IEEE International Conference on
57 Requirements Engineering, 1994.
58 (Rob94) J. Robertson and S. Robertson, Complete
59 Systems Analysis, Vol. 1 and 2, Prentice Hall, 1994.
60 (Rob94a) W. Robinson and S. Fickas, Supporting
61 Multi- Perspective Requirements Engineering,
62 presented at IEEE International Conference on
63 Requirements Engineering, 1994.
64 (Ros98) L. Rosenberg, T.F. Hammer, and L.L.
65 Huffman, Requirements, testing and metrics,
66 presented at 15th Annual Pacific Northwest Software
67 Quality Conference, 1998.
68 (Sch94) W. Schoening, The Next Big Step in Systems
69 Engineering Tools: Integrating Automated
70 Requirements Tools with Computer Simulated Synthesis
71 and Test, presented at Fourth International Symposium
72 on Systems Engineering, 1994.
73 (She94) M. Shekaran, The Role of Software
74 Architecture in Requirements Engineering, presented at
75 IEEE International Conference on Requirements
76 Engineering, 1994.
77 (Sid97) J. Siddiqi et al., Towards Quality Requirements
78 Via Animated Formal Specifications, Annals of
79 Software Engineering, vol. 3, 1997.
80 (Span97) G. Spanoudakis and A. Finkelstein,
81 Reconciling Requirements: A Method for Managing
82 Interference, Inconsistency, and Conflict, Annals of
83 Software Engineering, vol. 3, 1997.
84 (Ste94) R. Stevens, Structured Requirements,
85 presented at Fourth International Symposium on
86 Systems Engineering, 1994.
87 (Vin90) W.G. Vincenti, What Engineers Know and How
88 They Know It - Analytical Studies form Aeronautical
89 History, John Hopkins University Press, 1990.
90 (Wei03) K. Weigers, Software Requirements, second
91 ed., Microsoft Press, 2003.
92 (Whi95) S. White and M. Edwards, A Requirements
93 Taxonomy for Specifying Complex Systems, presented
94 at First IEEE International Conference on Engineering
25
95 of Complex Computer Systems, 1995.
96 (Wil99) B. Wiley, Essential System Requirements: A
97 Practical Guide to Event-Driven Methods, Addison-
98 Wesley, 1999.
99 (Wyd96) T. Wyder, Capturing Requirements With Use
100 Cases, Software Development, vol. 4, iss. 2, February
101 1996, pp. 36-40.
102 (Yen97) J. Yen and W. Tiao, A Systematic Tradeoff
103 Analysis for Conflicting Imprecise Requirements,
104 presented at IEEE International Symposium on
105 Requirements Engineering, 1997.
106 (Yu97) E. Yu, Towards Modeling and Reasoning
107 Support for Early-Phase Requirements Engineering,
108 presented at IEEE International Symposium on
109 Requirements Engineering, 1997.
110 (Zav96) P. Zave and M. Jackson, Where Do Operations
111 Come From? A Multiparadigm Specification
112 Technique, IEEE Transactions on Software
113 Engineering,, vol. 22, iss. 7, July 1996, pp. 508-528.
APDICE 1 B. LISTA DE ESTADARS
2
3 (IEEE830-98) IEEE Std 830-1998, IEEE Recommended
4 Practice for Software Requirements Specifications,
5 IEEE, 1998.
6 (IEEE1028-97) IEEE Std 1028-1997 (R2002), IEEE
7 Standard for Software Reviews, IEEE, 1997.
8 (IEEE1233-98) IEEE Std 1233-1998, IEEE Guide for
9 Developing System Requirements Specifications, 1998.
10 (IEEE1320.1-98) IEEE Std 1320.1-1998, IEEE
11 Standard for Functional Modeling Language-Syntax
12 and Semantics for IDEF0, IEEE, 1998.
13 (IEEE1320.2-98) IEEE Std 1320.2-1998, IEEE
14 Standard for Conceptual Modeling Language-Syntax
15 and Semantics for IDEFIX97 (IDEFObjetct), IEEE,
16 1998.
17 (IEEE1362-98) IEEE Std 1362-1998, IEEE Guide for
18 Information Technology-System Definition-Concept of
19 Operations (ConOps) Document, IEEE, 1998.
20
21
22 (IEEE1465-98) IEEE Std 1465-1998//ISO/
23 IEC12119:1994, IEEE Standard Adoption of
24 International Standard ISO/IEC12119:1994(E),
25 Information Technology-Software Packages-Quality
26 requirements and testing, IEEE, 1998.
27 (IEEEP1471-00) IEEE Std 1471-2000, IEEE
28 Recommended Practice for Architectural Descriptionos
29 Software Intensive Systems, Architecture Working
30 Group of the Software Engineering Standards
31 Committee, 2000.
26
32 (IEEE12207.0-96) IEEE/EIA 12207.0-1996//ISO/
33 IEC12207:1995, Industry Implementation of Int. Std.
34 ISO/IEC 12207:95, Standard for Information
35 Technology- Software Life Cycle Processes, IEEE,
36 1996.
37 (IEEE14143.1-00) IEEE Std 14143.1-2000//ISO/
38 IEC14143-1:1998, Information Technology-Software
39 Measurement-Functional Size Measurement-Part 1:
40 Definitions of Concepts, IEEE, 2000.
27