The widespread deployment of multicore systems over the last decade has brought about major changes in the software and hardware landscape. The resulting importance of parallel computing is reflected in the 2013 Curriculum Guidelines developed by the joint ACM/IEEE taskforce. The document recommends increased coverage of parallel computing and describes a new Knowledge Area on this topic. These recommendations have already been adopted by several universities in the form of new parallel programming courses. Implementing the recommendations in a complete curriculum, however, poses many challenges, including deciding on existing material to be removed, complying with administrative and ABET requirements, and maintaining caps on graduation credit hours. This paper describes an alternative approach for adopting the 2013 curricular recommendations on parallel computing. Specifically, we use a module based approach that introduces parallel computing concepts and re-iterates them through a series of short, self-contained modules taught across several lower-division courses. Most of these concepts are then combined into a new senior-level capstone course on parallel programming. Each module covers parallelism aspects in the context of a conventional computer science topic, thus enabling us to include parallel computing without a major overhaul of the curriculum. Evaluations conducted during the first year show encouraging results for this early-and-often approach in terms of learning outcomes, student interest, and confidence gains.
[1]
John R. Graham.
Integrating parallel programming techniques into traditional computer science curricula
,
2007,
SGCS.
[2]
Daniel C. Hyde,et al.
A parallel processing course for undergraduates
,
1989,
SIGCSE '89.
[3]
Dean Sanders,et al.
Teaching a course in parallel processing with limited resources
,
1991,
SIGCSE '91.
[4]
Daniel E. Stevenson,et al.
Concurrent CS: preparing students for a multicore world
,
2008,
ITiCSE.
[5]
Thomas R. Gross,et al.
Teaching the programming of parallel computers
,
1991,
SIGCSE '91.
[6]
William E. Toll.
Decision points in the introduction of parallel processing into the undergraduate curriculum
,
1995,
SIGCSE '95.