skip to main content
10.1145/3408877.3432442acmconferencesArticle/Chapter ViewAbstractPublication PagessigcseConference Proceedingsconference-collections
research-article
Public Access

Pattern Census: A Characterization of Pattern Usage in Early Programming Courses

Published: 05 March 2021 Publication History

Abstract

Expert programmers rarely think at the syntactic level. Instead, they think at higher levels of abstraction, mentally "chunking" groups of syntactic elements into a single abstraction. Explicitly teaching common "chunks" in early programming courses has been proposed in the research literature using the term "pattern-oriented instruction", but this practice appears not to be emphasized, nor is there a consensus about which patterns to teach or in what order.
In this paper, we explore the set of patterns that students are expected to learn, independent of whether they are taught explicitly or must learn implicitly. Specifically, we studied the instructor solutions to homework and exams from 12 introductory CS courses from nine universities, identifying the presence of 15 patterns throughout the semester. We present results about the relative frequency of the patterns and the order in which the patterns tend to be introduced.

References

[1]
Owen Astrachan and David Reed. 1995. AAA and CS 1: The Applied Apprenticeship Approach to CS 1. In Proceedings of the Twenty-Sixth SIGCSE Technical Symposium on Computer Science Education(Nashville, Tennessee, USA)(SIGCSE '95). Association for Computing Machinery, New York, NY, USA, 1--5. https://doi.org/10.1145/199688.199694
[2]
Owen Astrachan and Eugene Wallingford. 1998. Loop Patterns. https://users.cs.duke.edu/~ola/patterns/plopd/loops.html
[3]
Maria Bannert. 2002. Managing cognitive load?recent trends in cognitive load theory. Learning and Instruction 12, 1 (2002), 139 -- 146. https://doi.org/10.1016/S0959--4752(01)00021--4
[4]
Walter Beck, S. Rebecca Thomas, Janet Drake, J. Philip East, and Eugene Walling-ford. 1996. Pattern Based Programming Instruction. In1996 Annual Conference. ASEE Conferences, Washington, District of Columbia. https://peer.asee.org/6228.
[5]
Mordechai Ben-Ari and Jorma Sajaniemi. 2004. Roles of Variables as Seen by CS Educators. In Proceedings of the 9th Annual SIGCSE Conference on Innovation and Technology in Computer Science Education(Leeds, United Kingdom)(ITiCSE'04). Association for Computing Machinery, New York, NY, USA, 52--56. https://doi.org/10.1145/1007996.1008013
[6]
Joseph Bergin. 1998. Patterns for Selection. http://csis.pace.edu/~bergin/patterns/Patternsv5.html
[7]
Michael J. Clancy and Marcia C. Linn. 1999. Patterns and Pedagogy. In The Proceedings of the Thirtieth SIGCSE Technical Symposium on Computer Science Education(New Orleans, Louisiana, USA)(SIGCSE '99). ACM, New York, NY, USA, 37--42. https://doi.org/10.1145/299649.299673
[8]
Michael de Raadt. 2008.Teaching programming strategies explicitly to novice programmers. Ph. D. Dissertation. University of Southern Queensland.
[9]
Michael de Raadt, Richard Watson, and Mark Toleman. 2009. Teaching and Assessing Programming Strategies Explicitly. In Proceedings of the Eleventh Australasian Conference on Computing Education - Volume 95(Wellington, New Zealand)(ACE'09). Australian Computer Society, Inc., Darlinghurst, Australia, Australia, 45--54. http://dl.acm.org/citation.cfm?id=1862712.1862723
[10]
Max Fowler, Binglin Chen, Sush Azad, Matthew West, and Craig Zilles. 2021.Autograding "Explain in Plain English" questions using NLP. In Proceedings of the SIGCSE Technical Symposium (SIGCSE).
[11]
Erich Gamma, Richard Helm, Ralph Johnson, and John Vlissides. 1993. Design patterns: Abstraction and reuse of object-oriented design. In European Conference on Object-Oriented Programming. Springer, 406--431.
[12]
Erich Gamma, Richard Helm, Ralph Johnson, and John M. Vlissides. 1994. Design Patterns: Elements of Reusable Object-Oriented Software(1 ed.). Addison-Wesley Professional. http://www.amazon.com/Design-Patterns-Elements-Reusable-Object-Oriented/dp/0201633612/ref=ntt_at_ep_dpi_1
[13]
Fernand Gobet, Peter CR Lane, Steve Croker, Peter CH Cheng, Gary Jones, Iain Oliver, and Julian M Pine. 2001. Chunking mechanisms in human learning. Trends in cognitive sciences5, 6 (2001), 236--243.
[14]
Jacqueline Hundley. 2008. A Review of Using Design Patterns in CS1. In Proceedings of the 46th Annual Southeast Regional Conference(Auburn, Alabama)(ACM-SE46). ACM, New York, NY, USA, 30--33. https://doi.org/10.1145/1593105.1593113
[15]
Michelle Ichinco and Caitlin Kelleher. 2017. Towards better code snippets: Exploring how code snippet recall differs with programming experience. In Visual Languages and Human-Centric Computing (VL/HCC), 2017 IEEE Symposium on. IEEE, 37--41.
[16]
Vighnesh Iyer. 2020.An analysis of pattern usage in CS1 courses. M.S. thesis. University of Illinois at Urbana-Champaign, Urbana, Illinois. http://hdl.handle.net/2142/108537
[17]
Marja Kuittinen and Jorma Sajaniemi. 2004. Teaching Roles of Variables in Elementary Programming Courses. In Proceedings of the 9th Annual SIGCSE Conference on Innovation and Technology in Computer Science Education(Leeds,United Kingdom)(ITiCSE '04). ACM, New York, NY, USA, 57--61. https://doi.org/10.1145/1007996.1008014
[18]
Marcia C. Linn and Michael J. Clancy. 1992. The Case for Case Studies of Programming Problems.Commun. ACM35, 3 (March 1992), 121--132. https://doi.org/10.1145/131295.131301
[19]
Torben Lorenzen, Lee Mondshein, Abdul Sattar, and Seikyung Jung. 2012. A Code Snippet Library for CS1. ACM Inroads 3, 1 (March 2012), 41--45. https://doi.org/10.1145/2077808.2077822
[20]
Sandra P Marshall. 1995. Schemas in problem solving. Cambridge University Press.
[21]
Katherine B McKeithen, Judith Spencer Reitman, Henry H Rueter, and Stephen CHirtle. 1981. Knowledge organization and skill differences in computer programmers. Cognitive Psychology13, 3 (1981), 307--325.
[22]
Jeroen J. G. Van Merriënboer. 1990. Strategies for Programming Instruction in High School: Program Completion vs. Program Generation.Journal of Educational Computing Research6, 3 (1990), 265--285. https://doi.org/10.2190/4NK5--17L7-TWQV-1EHL arXiv: https://doi.org/10.2190/4NK5--17L7-TWQV-1EHL
[23]
Orna Muller. 2005. Pattern Oriented Instruction and the Enhancement of Analogical Reasoning. In Proceedings of the First International Workshop on Computing Education Research(Seattle, WA, USA)(ICER '05). ACM, New York, NY, USA, 57--67. https://doi.org/10.1145/1089786.1089792
[24]
Orna Muller, David Ginat, and Bruria Haberman. 2007. Pattern-oriented Instruction and Its Influence on Problem Decomposition and Solution Construction. In Proceedings of the 12th Annual SIGCSE Conference on Innovation and Technology in Computer Science Education(Dundee, Scotland)(ITiCSE '07). ACM, New York, NY, USA, 151--155. https://doi.org/10.1145/1268784.1268830
[25]
Fred Paas, Alexander Renkl, and John Sweller. 2003. Cognitive Load Theory and Instructional Design: Recent Developments. Educational Psychologist 38, 1 (2003), 1--4.
[26]
Nancy Pennington. 1987. Stimulus structures and mental representations inexpert comprehension of computer programs.Cognitive psychology 19, 3 (1987), 295--341.
[27]
Viera K Proulx. 2000. Programming patterns and design patterns in the introductory computer science course. ACM SIGCSE Bulletin32, 1 (2000), 80--84.
[28]
Michael Raadt, Mark Toleman, and Richard Watson. 2007. Incorporating programming strategies explicitly into curricula. In Proceedings of the Seventh Baltic Sea Conference on Computing Education Research (Koli Calling 2007).
[29]
Robert S Rist. 1989. Schema creation in programming. Cognitive Science 13, 3(1989), 389--414.
[30]
Anthony Robins, Janet Rountree, and Nathan Rountree. 2003. Learning and Teaching Programming: A Review and Discussion.Computer Science Education 13, 2 (2003), 137--172. https://doi.org/10.1076/csed.13.2.137.14200arXiv:https://doi.org/10.1076/csed.13.2.137.14200
[31]
Jorma Sajaniemi. 2008. The Roles of Variables Home Page.
[32]
Ben Shneiderman and Richard Mayer. 1979. Syntactic/semantic interactions in programmer behavior: A model and experimental results. International Journal of Computer & Information Sciences 8, 3 (01 Jun 1979), 219--238. https://doi.org/10.1007/BF00977789
[33]
John Sweller. 2011. Cognitive Load Theory. In Psychology of learning and motivation. Vol. 55. Elsevier, 37--76.
[34]
John Sweller, Paul Ayres, and Slava Kalyuga. 2011. Cognitive Load Theory, volume 1 of Explorations in the Learning Sciences, Instructional Systems and Performance Technologies.
[35]
John Sweller, Jeroen JG Van Merrienboer, and Fred GWC Paas. 1998. Cognitive architecture and instructional design. Educational psychology review 10, 3 (1998),251--296.
[36]
Jeroen JG Van Merriënboer and Marcel BM De Croock. 1992. Strategies for computer-based programming instruction: Program completion vs. program generation. Journal of Educational Computing Research 8, 3 (1992), 365--394.
[37]
Jeroen JG Van Merrienboer and Fred GWC Paas. 1990. Automation and schema acquisition in learning elementary computer programming: Implications for the design of practice. Computers in Human Behavior 6, 3 (1990), 273--289.
[38]
Iris Vessey. 1985. Expertise in debugging computer programs: A process analysis. International Journal of Man-Machine Studies 23, 5 (1985), 459 -- 494. https://doi.org/10.1016/S0020--7373(85)80054--7
[39]
Eugene Wallingford. 1996. Toward a First Course Based on Object-oriented Patterns. In Proceedings of the Twenty-seventh SIGCSE Technical Symposium on Computer Science Education(Philadelphia, Pennsylvania, USA)(SIGCSE '96). ACM, New York, NY, USA, 27--31. https://doi.org/10.1145/236452.236485
[40]
Susan Wiedenbeck. 1985. Novice/expert differences in programming skills. International Journal of Man-Machine Studies23, 4 (1985), 383 -- 390. https://doi.org/10.1016/S0020--7373(85)80041--9
[41]
Leon E. Winslow. 1996. Programming Pedagogy-a Psychological Overview. SIGCSE Bull. 28, 3 (Sept. 1996), 17--22. https://doi.org/10.1145/234867.234872
[42]
Benjamin Xie, Dastyni Loksa, Greg L. Nelson, Matthew J. Davidson, Dongsheng Dong, Harrison Kwik, Alex Hui Tan, Leanne Hwa, Min Li, and Andrew J. Ko. 2019. A theory of instruction for introductory programming skills. Computer Science Education 29, 2--3 (2019), 205--253. https://doi.org/10.1080/08993408.2019.1565235arXiv:https://doi.org/10.1080/08993408.2019.1565235

Cited By

View all
  • (2024)Validating, Refining, and Identifying Programming Plans Using Learning Curve Analysis on Code Writing DataProceedings of the 2024 ACM Conference on International Computing Education Research - Volume 110.1145/3632620.3671120(263-279)Online publication date: 12-Aug-2024
  • (2023)Evaluating Beacons, the Role of Variables, Tracing, and Abstract Tracing for Teaching Novices to Understand Program IntentProceedings of the 2023 ACM Conference on International Computing Education Research - Volume 110.1145/3568813.3600140(329-343)Online publication date: 7-Aug-2023
  • (2023)Towards Methods for Identifying High-Quality Domain-Specific Programming PlansProceedings of the 2023 ACM Conference on International Computing Education Research - Volume 210.1145/3568812.3603478(18-19)Online publication date: 7-Aug-2023
  • Show More Cited By

Index Terms

  1. Pattern Census: A Characterization of Pattern Usage in Early Programming Courses

Recommendations

Comments

Information & Contributors

Information

Published In

cover image ACM Conferences
SIGCSE '21: Proceedings of the 52nd ACM Technical Symposium on Computer Science Education
March 2021
1454 pages
ISBN:9781450380621
DOI:10.1145/3408877
Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. Copyrights for components of this work owned by others than the author(s) must be honored. Abstracting with credit is permitted. To copy otherwise, or republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Request permissions from [email protected].

Sponsors

Publisher

Association for Computing Machinery

New York, NY, United States

Publication History

Published: 05 March 2021

Permissions

Request permissions for this article.

Check for updates

Author Tags

  1. CS1
  2. pattern-oriented instruction
  3. patterns
  4. plans
  5. schema

Qualifiers

  • Research-article

Funding Sources

Conference

SIGCSE '21
Sponsor:

Acceptance Rates

Overall Acceptance Rate 1,595 of 4,542 submissions, 35%

Upcoming Conference

SIGCSE TS 2025
The 56th ACM Technical Symposium on Computer Science Education
February 26 - March 1, 2025
Pittsburgh , PA , USA

Contributors

Other Metrics

Bibliometrics & Citations

Bibliometrics

Article Metrics

  • Downloads (Last 12 months)90
  • Downloads (Last 6 weeks)14
Reflects downloads up to 17 Jan 2025

Other Metrics

Citations

Cited By

View all
  • (2024)Validating, Refining, and Identifying Programming Plans Using Learning Curve Analysis on Code Writing DataProceedings of the 2024 ACM Conference on International Computing Education Research - Volume 110.1145/3632620.3671120(263-279)Online publication date: 12-Aug-2024
  • (2023)Evaluating Beacons, the Role of Variables, Tracing, and Abstract Tracing for Teaching Novices to Understand Program IntentProceedings of the 2023 ACM Conference on International Computing Education Research - Volume 110.1145/3568813.3600140(329-343)Online publication date: 7-Aug-2023
  • (2023)Towards Methods for Identifying High-Quality Domain-Specific Programming PlansProceedings of the 2023 ACM Conference on International Computing Education Research - Volume 210.1145/3568812.3603478(18-19)Online publication date: 7-Aug-2023
  • (2023)Using Foundational CS1 Curricula for Middle School & Early High School Computer Programming EducationProceedings of the 54th ACM Technical Symposium on Computer Science Education V. 110.1145/3545945.3569877(827-833)Online publication date: 2-Mar-2023
  • (2022)So many brackets!Proceedings of the 30th IEEE/ACM International Conference on Program Comprehension10.1145/3524610.3529158(122-132)Online publication date: 16-May-2022
  • (2022)Can CS1 Curricula Be Used For Middle School Computer Programming Education?Proceedings of the 53rd ACM Technical Symposium on Computer Science Education V. 210.1145/3478432.3499116(1110-1110)Online publication date: 3-Mar-2022
  • (2021)How should we ‘Explain in plain English’? Voices from the CommunityProceedings of the 17th ACM Conference on International Computing Education Research10.1145/3446871.3469738(69-80)Online publication date: 16-Aug-2021
  • (2021)Autograding "Explain in Plain English" questions using NLPProceedings of the 52nd ACM Technical Symposium on Computer Science Education10.1145/3408877.3432539(1163-1169)Online publication date: 3-Mar-2021
  • (2021)An Inventory of Goals from CS1 Programs Processing a Data Series2021 IEEE Frontiers in Education Conference (FIE)10.1109/FIE49875.2021.9637360(1-8)Online publication date: 13-Oct-2021

View Options

View options

PDF

View or Download as a PDF file.

PDF

eReader

View online with eReader.

eReader

Login options

Media

Figures

Other

Tables

Share

Share

Share this Publication link

Share on social media