Treffer: GuardRails: Automated Suggestions for Clarifying Ambiguous Purpose Statements

Title:
GuardRails: Automated Suggestions for Clarifying Ambiguous Purpose Statements
Authors:
Contributors:
Babu, C, Goel, N, Karkare, A
Publisher Information:
Association for Computing Machinery
Publication Year:
2023
Collection:
Indian Institute of Science, Bangalore: ePrints@IIsc
Document Type:
Konferenz conference object
File Description:
application/pdf
Language:
English
Relation:
https://eprints.iisc.ac.in/85309/1/acm_int_con_pro_ser_2023.pdf; Pawagi, M and Kumar, V (2023) GuardRails: Automated Suggestions for Clarifying Ambiguous Purpose Statements. In: 16th Annual Compute Conference, COMPUTE 2023, 9 December 2023 through 11 December 2023, Hyderabad, pp. 55-60.
DOI:
10.1145/3627217.3627234
Accession Number:
edsbas.10E1F7BD
Database:
BASE

Weitere Informationen

Before implementing a function, programmers are encouraged to write a purpose statement i.e., a short, natural-language explanation of what the function computes. A purpose statement may be ambiguous i.e., it may fail to specify the intended behaviour when two or more inequivalent computations are plausible on certain inputs. Our paper makes four contributions. First, we propose a novel heuristic that suggests such inputs using Large Language Models (LLMs). Using these suggestions, the programmer may choose to clarify the purpose statement (e.g., by providing a functional example that specifies the intended behaviour on such an input). Second, to assess the quality of inputs suggested by our heuristic, and to facilitate future research, we create an open dataset of purpose statements with known ambiguities. Third, we compare our heuristic against GitHub Copilot's Chat feature, which can suggest similar inputs when prompted to generate unit tests. Fourth, we provide an open-source implementation of our heuristic as an extension to Visual Studio Code for the Python programming language, where purpose statements and functional examples are specified as docstrings and doctests respectively. We believe that this tool will be particularly helpful to novice programmers and instructors. © 2023 ACM.