Academia.eduAcademia.edu

Mental models of recursion

2003

Abstract

Recursion is a fundamental concept in Computer Science. A student's knowledge of recursion can be termed their mental model of recursion. A student's mental model is viable if it allows them to accurately and consistently represent the mechanics of recursion. Non-viable mental models are constructed if students have misconceptions about the mechanisms of recursion or have misconceptions about concepts fundamental to recursion. This paper presents a study of the mental models of recursion that first year students at the University of the Witwatersrand have constructed in 2000, 2001 and 2002. It was found that while the majority of students constructed the viable copies model, many non-viable models such as the looping, active, step, magic, return-value and various odd models were also constructed. Identifying the models that students have can allow lecturers to target individual students' specific problems and analysis of the models can provide insight into learning.

Key takeaways

  • This research is concerned with studying those traces and identifying the mental model of recursion that Wits students in 2000, 2001 and 2002 have constructed.
  • Each student's trace of the given recursive program was coded into categories derived from the definition of recursion.
  • The initial categories were derived from conceptual models of recursion [8,5] and as analysis progressed, more categories were added according to features found in the traces.
  • Kahney's viable copies (C) model was identified and the following models were all thought to be non-viable models: Looping model (L): With this model the recursive procedure is viewed as a single object rather than a series of instantiations and thus recursion is seen as a form of iteration.
  • Students with a return-value model could not construct a viable model of recursion because they did not have a viable model of parameter passing and return value evaluation, which are required before students can understand how a recursive program executes.