Requirements volatility is a major issue in software development, causing problems such as higher defect density, project delays, and cost overruns. Software architecture that guides the overall vision of software product is one of the areas that is greatly affected by requirements volatility. Since critical architecture decisions are made based on the requirements at hand, changes in requirements can result significant changes in architecture. With the wide adoption of agile software development, software architectures are designed to accommodate possible future changes. However, the changes has to be carefully managed as unnecessary and excessive changes can bring negative consequences. An exploratory case study was conducted to study the impact of requirements volatility on software architecture. Fifteen semistructured, thematic interviews were conducted in a European software company. The research revealed poor communication, information distortion, and external dependencies as the main factors that cause requirement volatility and inadequate architecture documentation, inability to trace design rationale, and increased complexity as the main implications of requirements volatility on software architecture. Insights from software teams' awareness of the requirement volatility, factors contribute to it, and possible ways to mitigate its implications will be utilized to improve the management of requirement volatility during software architecting process. KEYWORDS requirements management, requirements volatility, software architecture, software teams
INTRODUCTIONRequirements are added, deleted, and modified throughout the software development life cycle. Despite being seen as a natural characteristic of software projects, improper management of requirement changes can have adverse consequences on project cost, schedule, and quality of the resulting product. 1 Therefore, uncertain requirements are identified as one of the main factors that contribute to project failures. 2 While it is widely accepted that requirements changes are inevitable, significance of the potential consequences demands software teams to be aware of its existence, factors, and impacts. 3 Multiple terms including requirements change, requirements uncertainty, requirements instability, and requirements volatility are commonly associated with or related to the same phenomenon. 1,4 Requirements volatility is selected as the preferred term to be used in this study, as it not only indicates the change of requirements but also highlights their fragile nature and the potential to be changed.Software architecture that guides the overall vision of the software product is one of the areas that is greatly affected by requirements volatility. 5,6 Software architecture plays a prominent role in software development and acts as the foundation of the software systems that shapes the final outcome. Making suboptimal architecture decisions can decrease system quality and cause problems later on. 7 Since critical architecture decisions are primarily made base...