Functional programming is becoming increasingly widespread in industry. This trend is driven by the adoption of Scala as the main programming language for many applications. Scala fuses functional and object-oriented programming in a practical package. It interoperates seamlessly with both Java and Javascript. Scala is the implementation language of many important frameworks, including Apache Spark, Kafka, and Akka. It provides the core infrastructure for sites such as Twitter, Netflix, Zalando, and also Coursera.



Functional Programming Principles in Scala
This course is part of Functional Programming in Scala Specialization

Instructor: Martin Odersky
Access provided by The National Institute of Engineering
219,494 already enrolled
(8,259 reviews)
Recommended experience
What you'll learn
- Understand the principles of functional programming 
- Write purely functional programs, using recursion, pattern matching, and higher-order functions 
- Design immutable data structures 
- Combine functional programming with objects and classes 
Skills you'll gain
Details to know

Add to your LinkedIn profile
31 assignments
See how employees at top companies are mastering in-demand skills

Build your subject-matter expertise
- Learn new concepts from industry experts
- Gain a foundational understanding of a subject or tool
- Develop job-relevant skills with hands-on projects
- Earn a shareable career certificate

There are 6 modules in this course
Get up and running with Scala on your computer. Complete an example assignment to familiarize yourself with our unique way of submitting assignments. In this week, we'll learn the difference between functional imperative programming. We step through the basics of Scala; covering expressions, evaluation, conditionals, functions, and recursion
What's included
8 videos7 readings7 assignments3 programming assignments
This week, we'll learn about functions as first-class values, and higher order functions. We'll also learn about Scala's syntax and how it's formally defined. Finally, we'll learn about methods, classes, and data abstraction through the design of a data structure for rational numbers.
What's included
8 videos5 assignments2 programming assignments
This week, we'll cover traits, and we'll learn how to organize classes into hierarchies. We'll cover the hierarchy of standard Scala types, and see how to organize classes and traits into packages. Finally, we'll touch upon the different sorts of polymorphism in Scala.
What's included
6 videos4 assignments2 programming assignments
This week we'll learn about the relationship between functions and objects in Scala; functions *are* objects! We'll zoom in on Scala's type system, covering subtyping and generics, and moving on to more advanced aspects of Scala's type system like variance. Finally, we'll cover Scala's most widely used data structure, Lists, and one of Scala's most powerful tools, pattern matching.
What's included
7 videos6 assignments2 programming assignments
This week we dive into Lists, the most commonly-used data structure in Scala.
What's included
6 videos5 assignments
After a deep-dive into Lists, this week we'll explore other data structures; vectors, maps, ranges, arrays, and more. We'll dive into Scala's powerful and flexible for-comprehensions for querying data.
What's included
7 videos4 assignments2 programming assignments
Earn a career certificate
Add this credential to your LinkedIn profile, resume, or CV. Share it on social media and in your performance review.
Instructor

Offered by
Why people choose Coursera for their career




Learner reviews
8,259 reviews
- 5 stars83.55% 
- 4 stars13.50% 
- 3 stars1.70% 
- 2 stars0.66% 
- 1 star0.56% 
Showing 3 of 8259
Reviewed on Jun 4, 2019
It was a good introduction to Scala for me. The video are precise and concise. The assignment are made for you to apply the concepts seen in the videos, but they remain challenging and fun to do!
Reviewed on Sep 23, 2019
As expected Martin is awesome in explaining principle of functional programming. I have started reading the book as well to make sure I keep up with the knowledge which I have gained from this course.
Reviewed on Jan 14, 2017
Content and the lecturing is super. All the assignments makes you think about the subjects. If you want to learn about functional programming and something about scala this is the course for you.
Explore more from Computer Science
 - École Polytechnique Fédérale de Lausanne 
 - École Polytechnique Fédérale de Lausanne 
 - École Polytechnique Fédérale de Lausanne 
 - École Polytechnique Fédérale de Lausanne 

