Student Resources

Attribution Appreciated

While our book is copyrighted, we offer all the example programming code from the book and our teaching material freely without restrictions on reuse nor any promise or warrantee of any kind. We appreciate, but do not require, attribution. An attribution usually includes the title, author, publisher, and ISBN. For example: Structured Parallel Programming by Michael McCool, Arch Robison and James Reinders, copyright 2012, published by Morgan Kaufmann, ISBN 978-0-124-15993-8.

Posted by james on Thursday May 1, 2014 at 11:46:38

Click on the image to download my presentation


Posted by james on Sunday November 17, 2013 at 08:58:54

Piper is an experimental prototype of Intel® Cilk™ Plus that provides library headers and runtime support for pipe-while loops. A pipe-while loop is a new parallel loop construct described in a recent paper on On-the-fly pipeline parallelism, published in July 2013 in collaboration with researchers at MIT. A pipe-while loop is a generalization of an ordinary while loop that allows for pipeline parallelism between iterations.

You can learn more on the Cilk Plus website: .


Posted by james on Sunday November 17, 2013 at 08:58:50

We taught a one day tutorial at Supercomputing 2013 (in Denver) on Sunday November 17, 2013 based on the principles in the book. The presentation material we used is available here.

Full Presentation in PDF (3.1MB)

The latest compilers require some changes to the Cilk Plus examples in the book... we have updated the download of source code to match. You can download the revised/corrected Cilk Plus examples here (0.5MB) or on the download page.

The following details about the tutorial which used this presentation are on the SC13 website:

Structured Parallel Programming with Patterns

SESSION: Structured Parallel Programming with Patterns

Tutorial, 8:30am-5:00pm, Room 302, November 17, 2013 (SC13 - Denver)

Presenters:
Michael D. McCool - Intel Corporation
James R. Reinders - Intel Corporation
Arch Robison - Intel Corporation
Michael Hebenstreit - Intel Corporation

ABSTRACT:
Parallel programming is important for performance, and developers need a comprehensive set of strategies and technologies for tackling it. This tutorial is intended for C++ programmers who want to better grasp how to envision, describe and write efficient parallel algorithms at the single shared-memory node level. This tutorial will present a set of algorithmic patterns for parallel programming. Patterns describe best known methods for solving recurring design problems. Algorithmic patterns in particular are the building blocks of algorithms. Using these patterns to develop parallel algorithms will lead to better structured, more scalable, and more maintainable programs. This course will discuss when and where to use a core set of parallel patterns, how to best implement them, and how to analyze the performance of algorithms built using them. Patterns to be presented include map, reduce, scan, pipeline, fork-joint, stencil, tiling, and recurrence. Each pattern will be demonstrated using working code in one or more of Cilk Plus, Threading Building Blocks, OpenMP, or OpenCL. Attendees also will have the opportunity to test the provided examples themselves on an HPC cluster for the time of the SC13 conference.


Posted by arch on Friday May 11, 2012 at 07:24:05

Arch D. Robison gave a 1/2 day tutorial on June 17th 2012 at the International Supercomputing Conference in Hamburg Germany. The slides are now available:


Posted by arch on Friday May 11, 2012 at 07:18:25

Arch D. Robison gave a talk about Cilk Plus at HP-CAST 18 in Hamburg Germany.


Posted by james on Sunday November 13, 2011 at 08:26:03
Powerpoint presentation as used in the tutorial, with a few errata corrected: