Об этом курсе
4.8
Оценки: 5,645
Рецензии: 1,144
Специализация
100% онлайн

100% онлайн

Начните сейчас и учитесь по собственному графику.
Гибкие сроки

Гибкие сроки

Назначьте сроки сдачи в соответствии со своим графиком.
Промежуточный уровень

Промежуточный уровень

At least one year of programming (in any language)

Часов на завершение

Прибл. 23 часа на выполнение

Предполагаемая нагрузка: 5 hours / week...
Доступные языки

Английский

Субтитры: Английский, Корейский, Сербский, Французский

Чему вы научитесь

  • 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

Приобретаемые навыки

RecursionScala ProgrammingArray ProgrammingFunctional Programming
Специализация
100% онлайн

100% онлайн

Начните сейчас и учитесь по собственному графику.
Гибкие сроки

Гибкие сроки

Назначьте сроки сдачи в соответствии со своим графиком.
Промежуточный уровень

Промежуточный уровень

At least one year of programming (in any language)

Часов на завершение

Прибл. 23 часа на выполнение

Предполагаемая нагрузка: 5 hours / week...
Доступные языки

Английский

Субтитры: Английский, Корейский, Сербский, Французский

Программа курса: что вы изучите

Неделя
1
Часов на завершение
13 ч. на завершение

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...
Reading
11 videos (Total 139 min), 8 материалов для самостоятельного изучения, 4 тестов
Video11 видео
Tools Setup for Linux22мин
Tools Setup for Mac OS X21мин
Tools Setup for Windows18мин
Lecture 1.1 - Programming Paradigms14мин
Lecture 1.2 - Elements of Programming14мин
Lecture 1.3 - Evaluation Strategies and Termination4мин
Lecture 1.4 - Conditionals and Value Definitions8мин
Lecture 1.5 - Example: square roots with Newton's method11мин
Lecture 1.6 - Blocks and Lexical Scope8мин
Lecture 1.7 - Tail Recursion12мин
Reading8 материала для самостоятельного изучения
Tools Setup (Please read)10мин
Cheat Sheet10мин
IntelliJ IDEA Tutorial10мин
Eclipse Tutorial10мин
SBT tutorial and Submission of Assignments (Please read)10мин
Learning Resources10мин
Scala Tutorial10мин
Scala Style Guide10мин
Quiz1 практическое упражнение
Learning check-in2мин
Неделя
2
Часов на завершение
7 ч. на завершение

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....
Reading
7 videos (Total 84 min), 2 тестов
Video7 видео
Lecture 2.2 - Currying14мин
Lecture 2.3 - Example: Finding Fixed Points10мин
Lecture 2.4 - Scala Syntax Summary4мин
Lecture 2.5 - Functions and Data11мин
Lecture 2.6 - More Fun With Rationals15мин
Lecture 2.7 - Evaluation and Operators16мин
Неделя
3
Часов на завершение
7 ч. на завершение

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....
Reading
3 videos (Total 66 min), 2 тестов
Video3 видео
Lecture 3.2 - How Classes Are Organized20мин
Lecture 3.3 - Polymorphism21мин
Неделя
4
Часов на завершение
8 ч. на завершение

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....
Reading
7 videos (Total 117 min), 2 тестов
Video7 видео
Lecture 4.2 - Functions as Objects8мин
Lecture 4.3 - Subtyping and Generics15мин
Lecture 4.4 - Variance (Optional)21мин
Lecture 4.5 - Decomposition16мин
Lecture 4.6 - Pattern Matching19мин
Lecture 4.7 - Lists16мин
4.8
Рецензии: 1,144Chevron Right
Формирование карьерного пути

27%

начал новую карьеру, пройдя эти курсы
Карьерные преимущества

83%

получил значимые преимущества в карьере благодаря этому курсу
Продвижение по карьерной лестнице

11%

стал больше зарабатывать или получил повышение

Лучшие рецензии

автор: 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.

автор: VPSep 14th 2018

It took me much longer than expected to finish the course and sometimes it made me feel stupid and helpless. Diving into functional programming was a mind bending experience, totally worth time spent!

Преподаватель

Avatar

Martin Odersky

Professor
Computer Science

О École Polytechnique Fédérale de Lausanne

О специализации ''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

Часто задаваемые вопросы

  • Зарегистрировавшись на сертификацию, вы получите доступ ко всем видео, тестам и заданиям по программированию (если они предусмотрены). Задания по взаимной оценке сокурсниками можно сдавать и проверять только после начала сессии. Если вы проходите курс без оплаты, некоторые задания могут быть недоступны.

  • Записавшись на курс, вы получите доступ ко всем курсам в специализации, а также возможность получить сертификат о его прохождении. После успешного прохождения курса на странице ваших достижений появится электронный сертификат. Оттуда его можно распечатать или прикрепить к профилю LinkedIn. Просто ознакомиться с содержанием курса можно бесплатно.

Остались вопросы? Посетите Центр поддержки учащихся.