Informações sobre o curso
4.5
2,385 classificações
414 avaliações
Programa de cursos integrados
100% online

100% online

Comece imediatamente e aprenda em seu próprio cronograma.
Prazos flexíveis

Prazos flexíveis

Redefinir os prazos de acordo com sua programação.
Nível intermediário

Nível intermediário

Horas para completar

Aprox. 13 horas para completar

Sugerido: 5 hours/week...
Idiomas disponíveis

Inglês

Legendas: Inglês

Habilidades que você terá

StreamsFunctional DesignReactive ProgrammingFunctional Programming
Programa de cursos integrados
100% online

100% online

Comece imediatamente e aprenda em seu próprio cronograma.
Prazos flexíveis

Prazos flexíveis

Redefinir os prazos de acordo com sua programação.
Nível intermediário

Nível intermediário

Horas para completar

Aprox. 13 horas para completar

Sugerido: 5 hours/week...
Idiomas disponíveis

Inglês

Legendas: Inglês

Programa - O que você aprenderá com este curso

Semana
1
Horas para completar
8 horas para concluir

For Expressions and Monads

We'll start by revisiting some concepts that we have learned from Principles of Functional Programming in Scala; collections, pattern matching, and functions. We'll then touch on for-comprehensions, a powerful way in Scala to traverse a list, process it, and return a new list. We'll see how to do queries with for-comprehensions as well as how the for-comprehension is "desugared" into calls to higher-order functions by the Scala compiler. Finally, we'll discuss what monads are, and how to verify that the monad laws are satisfied for a number of examples....
Reading
10 vídeos (total de (Total 164 mín.) min), 11 leituras, 1 teste
Video10 videos
Tools Setup for Mac OS X21min
Tools for Setup for Windows18min
Tutorial: Working on the Programming Assignments8min
Recap: Functions and Pattern Matching19min
Recap: Collections12min
Lecture 1.1 - Queries with For7min
Lecture 1.2 - Translation of For11min
Lecture 1.3 - Functional Random Generators19min
Lecture 1.4 - Monads20min
Reading11 leituras
Troubleshooting10min
Grading Policy10min
Tools Setup10min
Sbt Tutorial10min
Eclipse Tutorial10min
Intellij IDEA Tutorial10min
Scala Tutorial10min
Cheat Sheet10min
Reactive Cheat Sheet10min
Scala Style Guide10min
Learning Resources10min
Semana
2
Horas para completar
7 horas para concluir

Lazy Evaluation

This week we'll revisit performance issues caused by combinatorial search, and we'll discover an important concept in functional programming that can these issues: laziness. We'll also learn a little bit about proofs on trees; in particular, we'll see how to extend structural induction to trees....
Reading
5 vídeos (total de (Total 80 mín.) min), 2 testes
Video5 videos
Lecture 2.2 - Streams12min
Lecture 2.3 - Lazy Evaluation11min
Lecture 2.4 - Computing with Infinite Sequences9min
Lecture 2.5 - Case Study: the Water Pouring Problem31min
Semana
3
Horas para completar
7 horas para concluir

Functions and State

This week, we'll learn about state and side-effects. Through a rich example, we'll learn programming patterns for managing state in larger programs. We'll also learn about for-loops and while-loops in Scala....
Reading
6 vídeos (total de (Total 72 mín.) min), 2 testes
Video6 videos
Lecture 3.2 - Identity and Change8min
Lecture 3.3 - Loops8min
Lecture 3.4 - Extended Example: Discrete Event Simulation10min
Lecture 3.5 - Discrete Event Simulation: API and Usage10min
Lecture 3.6 - Discrete Event Simulation: Implementation and Test18min
Semana
4
Horas para completar
8 horas para concluir

Timely Effects

This week we'll learn a number of important programming patterns via examples, starting with the observer pattern, and then going on to functional reactive programming. We'll learn how latency can be modeled as an effect, and how latency can be handled with Scala's monadic futures. We'll learn the important combinators on futures as well as how they can be composed to build up rich and responsive services....
Reading
11 vídeos (total de (Total 109 mín.) min), 2 testes
Video11 videos
Lecture 4.2 - Functional Reactive Programming20min
Lecture 4.3 - A Simple FRP Implementation19min
Lecture 4.4 - Latency as an Effect 17min
Lecture 4.5 - Latency as an Effect 212min
Lecture 4.6 - Combinators on Futures 19min
Lecture 4.7 - Combinators on Futures 27min
Lecture 4.8 - Composing Futures 14min
Lecture 4.9 - Implementation of flatMap on Future3min
Lecture 4.10 - Composing Futures 28min
Conclusion4min
4.5
414 avaliaçõesChevron Right
Direcionamento de carreira

41%

comecei uma nova carreira após concluir estes cursos
Benefício de carreira

30%

consegui um benefício significativo de carreira com este curso

Melhores avaliações

por RPSep 15th 2016

This is a university degree course which takes enormous effort to complete. But still its beond the programming course range giving you whats not possible to google or learn practical way. Thanks!

por ESMar 18th 2018

Thank you for this exciting course! I did the FP in Scala course a few years ago and decided to do the full certification now. I am looking forward to the next courses in the specialisation.

Instrutores

Avatar

Martin Odersky

Professor
Computer Science

Sobre École Polytechnique Fédérale de Lausanne

Sobre o Programa de cursos integrados 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

Perguntas Frequentes – FAQ

  • Ao se inscrever para um Certificado, você terá acesso a todos os vídeos, testes e tarefas de programação (se aplicável). Tarefas avaliadas pelos colegas apenas podem ser enviadas e avaliadas após o início da sessão. Caso escolha explorar o curso sem adquiri-lo, talvez você não consiga acessar certas tarefas.

  • Quando você se inscreve no curso, tem acesso a todos os cursos na Especialização e pode obter um certificado quando concluir o trabalho. Seu Certificado eletrônico será adicionado à sua página de Participações e você poderá imprimi-lo ou adicioná-lo ao seu perfil no LinkedIn. Se quiser apenas ler e assistir o conteúdo do curso, você poderá frequentá-lo como ouvinte sem custo.

Mais dúvidas? Visite o Central de Ajuda ao Aprendiz.