Computer Science
Manipulating big data distributed over a cluster using functional concepts is rampant in industry, and is arguably one of the first widespread industrial uses of functional ideas.

Course Details

Language English
Duration 4 week
Effort 6 hour/week
Description

Manipulating big data distributed over a cluster using functional concepts is rampant in industry, and is arguably one of the first widespread industrial uses of functional ideas. This is evidenced by the popularity of MapReduce and Hadoop, and most recently Apache Spark, a fast, in-memory distributed collections framework written in Scala. In this course, we'll see how the data parallel paradigm can be extended to the distributed case, using Spark throughout. We'll cover Spark's programming model in detail, being careful to understand how and when it differs from familiar programming models, like shared-memory parallel collections or sequential Scala collections. Through hands-on examples in Spark and Scala, we'll learn when important issues related to distribution like latency and network communication should be considered and how they can be addressed effectively for improved performance.

What you will learn

Learning Outcomes. By the end of this course you will be able to:


  • read data from persistent storage and load it into Apache Spark,

  • manipulate data with Spark and Scala,

  • express algorithms for data analysis in a functional style,

  • recognize how to avoid shuffles and recomputation in Spark,

Prerequisites

You should have at least one year programming experience. Proficiency with Java or C# is ideal, but experience with other languages such as C/C++, Python, Javascript or Ruby is also sufficient. You should have some familiarity using the command line. This course is intended to be taken after Parallel Programming

Course instructors

Prof. Heather Miller

Heather Miller is an assistant professor in Carnegie Mellon University's School of Computer Science. Previously, she was a research scientist at EPFL, and the co-founder and executive director of the Scala Center.

École polytechnique fédérale de Lausanne

Free online courses from École polytechnique fédérale de Lausanne

EPFL is the Swiss Federal Institute of Technology in Lausanne. The past decade has seen EPFL ascend to the very top of European institutions of science and technology: it is ranked #1 in E…

95 instructors