TY - JOUR
T1 - Cognition in Software Engineering: A Taxonomy and Survey of a Half-Century of Research
AU - Fagerholm, Fabian
AU - Felderer, Michael
AU - Fucci, Davide
AU - Unterkalmsteiner, Michael
AU - Marculescu, Bogdan
AU - Martini, Markus
AU - Wallgren Tengberg, Lars Göran
AU - Feldt, Robert
AU - Lehtelä, Bettina
AU - Nagyvaradi, Balazs
AU - Khattak, Jehan
PY - 2022/9/9
Y1 - 2022/9/9
N2 - Cognition plays a fundamental role in most software engineering activities. This article provides a taxonomy of cognitive concepts and a survey of the literature since the beginning of the Software Engineering discipline. The taxonomy comprises the top-level concepts of perception, attention, memory, cognitive load, reasoning, cognitive biases, knowledge, social cognition, cognitive control, and errors, and procedures to assess them both qualitatively and quantitatively. The taxonomy provides a useful tool to filter existing studies, classify new studies, and support researchers in getting familiar with a (sub) area. In the literature survey, we systematically collected and analysed 311 scientific papers spanning five decades and classified them using the cognitive concepts from the taxonomy. Our analysis shows that the most developed areas of research correspond to the four life-cycle stages, software requirements, design, construction, and maintenance. Most research is quantitative and focuses on knowledge, cognitive load, memory, and reasoning. Overall, the state of the art appears fragmented when viewed from the perspective of cognition. There is a lack of use of cognitive concepts that would represent a coherent picture of the cognitive processes active in specific tasks. Accordingly, we discuss the research gap in each cognitive concept and provide recommendations for future research.
AB - Cognition plays a fundamental role in most software engineering activities. This article provides a taxonomy of cognitive concepts and a survey of the literature since the beginning of the Software Engineering discipline. The taxonomy comprises the top-level concepts of perception, attention, memory, cognitive load, reasoning, cognitive biases, knowledge, social cognition, cognitive control, and errors, and procedures to assess them both qualitatively and quantitatively. The taxonomy provides a useful tool to filter existing studies, classify new studies, and support researchers in getting familiar with a (sub) area. In the literature survey, we systematically collected and analysed 311 scientific papers spanning five decades and classified them using the cognitive concepts from the taxonomy. Our analysis shows that the most developed areas of research correspond to the four life-cycle stages, software requirements, design, construction, and maintenance. Most research is quantitative and focuses on knowledge, cognitive load, memory, and reasoning. Overall, the state of the art appears fragmented when viewed from the perspective of cognition. There is a lack of use of cognitive concepts that would represent a coherent picture of the cognitive processes active in specific tasks. Accordingly, we discuss the research gap in each cognitive concept and provide recommendations for future research.
KW - cognition
KW - cognitive concepts
KW - psychology of programming
KW - human factors
KW - measurement
KW - taxonomy
U2 - 10.1145/3508359
DO - 10.1145/3508359
M3 - Article
VL - 54
SP - 1
EP - 36
JO - ACM COMPUTING SURVEYS
JF - ACM COMPUTING SURVEYS
SN - 0360-0300
IS - 11
M1 - 226
ER -