Über diesen Kurs
201,951 recent views

100 % online

Beginnen Sie sofort und lernen Sie in Ihrem eigenen Tempo.

Flexible Fristen

Setzen Sie Fristen gemäß Ihrem Zeitplan zurück.

Stufe „Mittel“

At least one year of programming (in any language)

Ca. 23 Stunden zum Abschließen

Empfohlen: 5 hours / week...

Englisch

Untertitel: Englisch, Koreanisch, Serbisch, Französisch

Was Sie lernen werden

  • Check

    Understand the principles of functional programming

  • Check

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

  • Check

    Design immutable data structures

  • Check

    Combine functional programming with objects and classes

Kompetenzen, die Sie erwerben

RecursionScala ProgrammingArray ProgrammingFunctional Programming

100 % online

Beginnen Sie sofort und lernen Sie in Ihrem eigenen Tempo.

Flexible Fristen

Setzen Sie Fristen gemäß Ihrem Zeitplan zurück.

Stufe „Mittel“

At least one year of programming (in any language)

Ca. 23 Stunden zum Abschließen

Empfohlen: 5 hours / week...

Englisch

Untertitel: Englisch, Koreanisch, Serbisch, Französisch

Lehrplan - Was Sie in diesem Kurs lernen werden

Woche
1
13 Stunden zum Abschließen

Getting Started + Functions & Evaluation

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...
11 Videos (Gesamt 139 min), 8 Lektüren, 4 Quiz
11 Videos
Tools Setup for Linux22m
Tools Setup for Mac OS X21m
Tools Setup for Windows18m
Lecture 1.1 - Programming Paradigms14m
Lecture 1.2 - Elements of Programming14m
Lecture 1.3 - Evaluation Strategies and Termination4m
Lecture 1.4 - Conditionals and Value Definitions8m
Lecture 1.5 - Example: square roots with Newton's method11m
Lecture 1.6 - Blocks and Lexical Scope8m
Lecture 1.7 - Tail Recursion12m
8 Lektüren
Tools Setup (Please read)10m
Cheat Sheet10m
IntelliJ IDEA Tutorial10m
Eclipse Tutorial10m
SBT tutorial and Submission of Assignments (Please read)10m
Learning Resources10m
Scala Tutorial10m
Scala Style Guide10m
1 praktische Übung
Learning check-in2m
Woche
2
7 Stunden zum Abschließen

Higher Order Functions

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....
7 Videos (Gesamt 84 min), 2 Quiz
7 Videos
Lecture 2.2 - Currying14m
Lecture 2.3 - Example: Finding Fixed Points10m
Lecture 2.4 - Scala Syntax Summary4m
Lecture 2.5 - Functions and Data11m
Lecture 2.6 - More Fun With Rationals15m
Lecture 2.7 - Evaluation and Operators16m
Woche
3
7 Stunden zum Abschließen

Data and Abstraction

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....
3 Videos (Gesamt 66 min), 2 Quiz
3 Videos
Lecture 3.2 - How Classes Are Organized20m
Lecture 3.3 - Polymorphism21m
Woche
4
8 Stunden zum Abschließen

Types and Pattern Matching

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....
7 Videos (Gesamt 117 min), 2 Quiz
7 Videos
Lecture 4.2 - Functions as Objects8m
Lecture 4.3 - Subtyping and Generics15m
Lecture 4.4 - Variance (Optional)21m
Lecture 4.5 - Decomposition16m
Lecture 4.6 - Pattern Matching19m
Lecture 4.7 - Lists16m
Woche
5
1 Stunde zum Abschließen

Lists

This week we dive into Lists, the most commonly-used data structure in Scala....
7 Videos (Gesamt 88 min)
7 Videos
Lecture 5.2 - Pairs and Tuples10m
Lecture 5.3 - Implicit Parameters11m
Lecture 5.4 - Higher-Order List Functions14m
Lecture 5.5 - Reduction of Lists15m
Lecture 5.6 - Reasoning About Concat13m
Lecture 5.7 - A Larger Equational Proof on Lists9m
Woche
6
8 Stunden zum Abschließen

Collections

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....
6 Videos (Gesamt 99 min), 2 Quiz
6 Videos
Lecture 6.2 - Combinatorial Search and For-Expressions13m
Lecture 6.3 - Combinatorial Search Example16m
Lecture 6.4 - Maps22m
Lecture 6.5 - Putting the Pieces Together20m
Conclusion4m
4.8
1,241 BewertungenChevron Right

30%

nahm einen neuen Beruf nach Abschluss dieser Kurse auf

26%

ziehen Sie für Ihren Beruf greifbaren Nutzen aus diesem Kurs

10%

erhalten Sie eine Gehaltserhöhung oder Beförderung

Top-Bewertungen

von RSOct 9th 2016

Really good explanation by the instructor. Good assignments. The assignments gave a good insights into functional programming. I loved the way the problems were decomposed into neat smaller functions.

von GBAug 13th 2017

An excellent introduction to the concepts of functional programming that had the "side-effect" of getting me hooked on the language! (Even though the hipster in me really wanted to prefer Clojure.)

Dozent

Avatar

Martin Odersky

Professor
Computer Science

Über École Polytechnique Fédérale de Lausanne

Über die Spezialisierung Functional Programming in Scala

Discover how to write elegant code that works the first time it is run. This Specialization provides a hands-on introduction to functional programming using the widespread programming language, Scala. It begins from the basic building blocks of the functional paradigm, first showing how to use these blocks to solve small problems, before building up to combining these concepts to architect larger functional programs. You'll see how the functional paradigm facilitates parallel and distributed programming, and through a series of hands on examples and programming assignments, you'll learn how to analyze data sets small to large; from parallel programming on multicore architectures, to distributed programming on a cluster using Apache Spark. A final capstone project will allow you to apply the skills you learned by building a large data-intensive application using real-world data....
Functional Programming in Scala

Häufig gestellte Fragen

  • Sobald Sie sich für ein Zertifikat angemeldet haben, haben Sie Zugriff auf alle Videos, Quizspiele und Programmieraufgaben (falls zutreffend). Aufgaben, die von anderen Kursteilnehmern bewertet werden, können erst dann eingereicht und überprüft werden, wenn Ihr Unterricht begonnen hat. Wenn Sie sich den Kurs anschauen möchten, ohne ihn zu kaufen, können Sie womöglich auf bestimmte Aufgaben nicht zugreifen.

  • Wenn Sie sich für den Kurs anmelden, erhalten Sie Zugriff auf alle Kurse der Spezialisierung und Sie erhalten nach Abschluss aller Arbeiten ein Zertifikat. Ihr elektronisches Zertifikat wird zu Ihrer Seite „Errungenschaften“ hinzugefügt – von dort können Sie Ihr Zertifikat ausdrucken oder es zu Ihrem LinkedIn Profil hinzufügen. Wenn Sie nur lesen und den Inhalt des Kurses anzeigen möchten, können Sie kostenlos als Gast an dem Kurs teilnehmen.

Haben Sie weitere Fragen? Besuchen Sie das Hilfe-Center für Teiln..