Informações sobre o curso
4.4
1,521 classificações
234 avaliações

100% online

Comece imediatamente e aprenda em seu próprio cronograma.

Prazos flexíveis

Redefinir os prazos de acordo com sua programação.

Nível intermediário

Aprox. 16 horas para completar

Sugerido: 6 hours/week...

Inglês

Legendas: Inglês

Habilidades que você terá

Data StructureParallel ComputingData ParallelismParallel Algorithm

100% online

Comece imediatamente e aprenda em seu próprio cronograma.

Prazos flexíveis

Redefinir os prazos de acordo com sua programação.

Nível intermediário

Aprox. 16 horas para completar

Sugerido: 6 hours/week...

Inglês

Legendas: Inglês

Programa - O que você aprenderá com este curso

Semana
1
12 horas para concluir

Parallel Programming

We motivate parallel programming and introduce the basic constructs for building parallel programs on JVM and Scala. Examples such as array norm and Monte Carlo computations illustrate these concepts. We show how to estimate work and depth of parallel programs as well as how to benchmark the implementations....
9 vídeos (total de (Total 106 mín.) min), 5 leituras, 3 testes
9 videos
Introduction to Parallel Computing15min
Parallelism on the JVM I13min
Parallelism on the JVM II8min
Running Computations in Parallel13min
Monte Carlo Method to Estimate Pi4min
First-Class Tasks7min
How Fast are Parallel Programs?24min
Benchmarking Parallel Programs17min
5 leituras
Tools Setup10min
Eclipse Tutorial10min
IntelliJ IDEA Tutorial10min
Sbt Tutorial10min
Submitting Solutions10min
Semana
2
8 horas para concluir

Basic Task Parallel Algorithms

We continue with examples of parallel algorithms by presenting a parallel merge sort. We then explain how operations such as map, reduce, and scan can be computed in parallel. We present associativity as the key condition enabling parallel implementation of reduce and scan....
6 vídeos (total de (Total 100 mín.) min), 2 testes
6 videos
Data Operations and Parallel Mapping18min
Parallel Fold (Reduce) Operation18min
Associativity I14min
Associativity II17min
Parallel Scan (Prefix Sum) Operation24min
Semana
3
7 horas para concluir

Data-Parallelism

We show how data parallel operations enable the development of elegant data-parallel code in Scala. We give an overview of the parallel collections hierarchy, including the traits of splitters and combiners that complement iterators and builders from the sequential case....
5 vídeos (total de (Total 51 mín.) min), 2 testes
5 videos
Data-Parallel Operations I6min
Data-Parallel Operations II8min
Scala Parallel Collections15min
Splitters and Combiners7min
Semana
4
7 horas para concluir

Data Structures for Parallel Computing

We give a glimpse of the internals of data structures for parallel computing, which helps us understand what is happening under the hood of parallel collections....
5 vídeos (total de (Total 57 mín.) min), 2 testes
5 videos
Parallel Two-phase Construction14min
Conc-tree Data Structure14min
Amortized, Constant-time Append Operation11min
Conc-Tree Combiners4min
4.4
234 avaliaçõesChevron Right

23%

comecei uma nova carreira após concluir estes cursos

20%

consegui um benefício significativo de carreira com este curso

Melhores avaliações

por ALApr 24th 2018

The course is fairly advanced and you would need to review the materials many times to understand the concept. The assignments are definitely fun and not as straightforward as other courses.

por RCAug 25th 2017

Superb study material. Learnt a lot during this course. I am not much into mathematical stuff, but got a hang of how to break problems and improve efficiency through parallelism.

Instrutores

Avatar

Prof. Viktor Kuncak

Associate Professor
School of Computer and Communication Sciences
Avatar

Dr. Aleksandar Prokopec

Principal Researcher
Oracle Labs

Sobre Escola Politécnica Federal de Lausana

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.