École Polytechnique Fédérale de Lausanne
Functional Programming in Scala Specialization
École Polytechnique Fédérale de Lausanne

Functional Programming in Scala Specialization

Program on a Higher Level. Write elegant functional code to analyze data that's big or small

Martin Odersky
Prof. Heather Miller
Prof. Viktor Kuncak

Instructors: Martin Odersky

Access provided by The National Institute of Engineering

75,874 already enrolled

Get in-depth knowledge of a subject
4.6

(6,930 reviews)

Intermediate level

Recommended experience

5 months to complete
at 10 hours a week
Flexible schedule
Learn at your own pace
Get in-depth knowledge of a subject
4.6

(6,930 reviews)

Intermediate level

Recommended experience

5 months to complete
at 10 hours a week
Flexible schedule
Learn at your own pace

What you'll learn

  • Write purely functional programs using recursion, pattern matching, and higher-order functions

  • Design immutable data structures

  • Write programs that effectively use parallel collections to achieve performance

  • Manipulate data with Spark and Scala

Details to know

Shareable certificate

Add to your LinkedIn profile

Taught in English

See how employees at top companies are mastering in-demand skills

 logos of Petrobras, TATA, Danone, Capgemini, P&G and L'Oreal

Advance your subject-matter expertise

  • Learn in-demand skills from university and industry experts
  • Master a subject or tool with hands-on projects
  • Develop a deep understanding of key concepts
  • Earn a career certificate from École Polytechnique Fédérale de Lausanne

Specialization - 5 course series

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

Category: Scala Programming
Category: Programming Principles
Category: Functional Design
Category: Object Oriented Programming (OOP)
Category: Algorithms
Category: Data Structures
Category: Integrated Development Environments
Category: Computer Programming
Category: Software Design Patterns
Category: Computational Thinking
Category: Javascript

What you'll learn

  • Recognize and apply design principles of functional programs

  • Design functional libraries and their APIs

  • Write simple functional reactive applications

  • Understand reasoning techniques for programs that combine functions and state

Skills you'll gain

Category: Scala Programming
Category: Functional Design
Category: Data Structures
Category: Software Design
Category: Java
Category: Software Design Patterns
Category: Performance Tuning
Category: Programming Principles
Category: Algorithms
Parallel programming

Parallel programming

Course 332 hours

What you'll learn

Skills you'll gain

Category: Scala Programming
Category: Algorithms
Category: Data Structures
Category: Other Programming Languages
Category: Functional Design
Category: Performance Tuning
Category: Scalability
Category: Java
Category: Distributed Computing

What you'll learn

Skills you'll gain

Category: Apache Spark
Category: Scala Programming
Category: Distributed Computing
Category: Big Data
Category: Data Analysis
Category: Data Processing
Category: Data Manipulation
Category: SQL
Category: Data Transformation
Category: Apache Hadoop
Category: Performance Tuning

What you'll learn

Skills you'll gain

Category: Scala Programming
Category: Data Transformation
Category: Spatial Data Analysis
Category: Heat Maps
Category: Web Applications
Category: User Interface (UI)
Category: Data Manipulation
Category: Geospatial Mapping
Category: Big Data
Category: Interactive Data Visualization
Category: Apache Spark
Category: Data Visualization Software
Category: Real Time Data

Earn a career certificate

Add this credential to your LinkedIn profile, resume, or CV. Share it on social media and in your performance review.

Instructors

Martin Odersky
École Polytechnique Fédérale de Lausanne
6 Courses235,353 learners
Prof. Heather Miller
École Polytechnique Fédérale de Lausanne
2 Courses104,141 learners

Why people choose Coursera for their career

Felipe M.
Learner since 2018
"To be able to take courses at my own pace and rhythm has been an amazing experience. I can learn whenever it fits my schedule and mood."
Jennifer J.
Learner since 2020
"I directly applied the concepts and skills I learned from my courses to an exciting new project at work."
Larry W.
Learner since 2021
"When I need courses on topics that my university doesn't offer, Coursera is one of the best places to go."
Chaitanya A.
"Learning isn't just about being better at your job: it's so much more than that. Coursera allows me to learn without limits."