A software requirement specification (SRS) document is an essential part of the software development life cycle which outlines the requirements that a software program in development must satisfy. This document is often specified by a diverse group of stakeholders and is subject to continual change, making the process of maintaining the document and detecting conflicts between requirements an essential task in software development. Notably, projects that do not address conflicts in the SRS document early on face considerable problems later in the development life cycle. These problems incur substantial costs in terms of time and money, and these costs often become insurmountable barriers that ultimately result in the termination of a software project altogether. As a result, early detection of SRS conflicts is critical to project sustainability. The conflict detection task is approached in numerous ways, many of which require a significant amount of manual intervention from developers, or require access to a large amount of labeled, task-specific training data. In this work, we propose using a prompt-based learning approach to perform few-shot learning for conflict detection. We compare our results to supervised learning approaches that use pretrained language models, such as BERT and its variants. Our results show that prompting with just 32 labeled examples can achieve a similar level of performance in many key metrics to that of supervised learning on training sets that are magnitudes larger in size. In contrast to many other conflict detection approaches, we make no assumptions about the type of underlying requirements, allowing us to analyze pairings of both functional and non-functional requirements. This allows us to omit the potentially expensive task of filtering out non-functional requirements from our dataset.
翻译:软件要求规格(SRS)文件是软件开发生命周期的一个基本部分,它概述了软件开发程序必须满足的要求。该文件往往由不同的利益攸关方群体具体指定,并会不断发生变化,使维护文件和发现需求之间的冲突的过程成为软件开发中的一项基本任务。值得注意的是,在开发生命周期后期面临大量问题时,不解决SRS文件中的冲突的项目在开发生命周期中面临大量问题。这些问题在时间和金钱方面费用巨大,这些费用往往成为无法逾越的障碍,最终导致软件项目完全终止。因此,早期发现SRS冲突对于项目的可持续性至关重要。冲突探测任务以多种方式进行,其中许多需要开发者大量人工干预,或需要获取大量贴标签的、具体任务的培训数据。在这项工作中,我们建议采用基于即时的学习方法,为探测冲突进行几眼熟的学习。我们将我们的结果与采用预先训练的语言模型(如BERT及其变式)来监督学习方法。我们的结果显示,仅仅利用32个标签的不透明的数据要求来评估潜在的项目可持续性至关重要。我们从不具有非筛选要求,因此,从仅通过在测试中进行更大规模的分析方法,我们无法进行类似的分析。