SlideShare uma empresa Scribd logo
Introdução ao
Machine Learning
para Hackers
Quem sou eu?
Gabriel Cypriano
gabrielcs.me
Background em Ciência da Computação e Engenharia de Software
Cursos online recentes:
Machine Learning (Stanford University)
Intro to Recommender Systems (University of Minnesota)
Python for Data Science (DataCamp)
Introdução ao Machine Learning para Hackers
Inteligência Artificial
Machine Learning
Deep Learning
O que é Machine Learning?
Definição anti-hacker:
“It is the field of study that gives computers the
ability to learn without being explicitly
programmed.”
Definição hacker:
“It is all about learning from examples rather than
writing explicit rules — you let the algorithm find
those rules for you.”
OK. Exemplos?
Spam
Recomendações da Netflix
Amazon Echo
Google Photos / Facebook Photo Tags
DeepMind jogando Atari
Prisma
Carros autônomos
Tá, mas eu consigo fazer isso
em casa?
Claro, é só revisar álgebra linear, cálculo multivariável,
inferência estatística e fazer um mestrado + um
doutorado em Deep Learning.
J.K. :)
Nós vamos inverter a abordagem de aprendizado
tradicional e começar utilizando APIs que abstraem a
matemágica.
Leitura recomendada: http://bit.ly/2aSa6SM
Cool! Where do we start?
R foi feita por estatísticos para estatísticos
É a mais natural para computação numérica, mas não
dá pra criar nem um web service, além de limitações
com o volume de dados
Python não é tão natural quanto R para computação
numérica, mas dá pra se fazer web services/apps
Comunidade de ML forte
Scala muito usada com o Spark para computação paralela
Deixa Python na poeira, mas pode ser complexa para
um momento inicial
Cool! Where do we start?
Também existem muitas soluções na nuvem:
Google Cloud Machine Learning
Microsoft Azure Machine Learning
Amazon Machine Learning
IBM Predictive Analytics
Let’s start hacking.
Regressão Linear com Python
Code: http://bit.ly/2aZfa7L
Pausa para teoria:
abordagens de aprendizado
Supervisionado
Quando são fornecidos labels com os exemplos
Por reforço (reinforcement learning)
Dando recompensas, tipo como você treina seu dog.
Não-supervisionado
Quando não são fornecidos labels
Exemplo:
Carros autônomos (input são câmeras e um humano
dirigindo)?
Aprendizagem supervisionada.
Exemplo:
Prisma (input é um estilo de pintura e uma foto)?
Aprendizagem não-supervisionada.
Exemplo:
Jogos de Atari (input são pixels e o score)?
Aprendizagem por reforço.
Back to hacking.
Aprendizagem não-supervisionada: clusterização.
Code: http://bit.ly/2arPMlQ
Deep Learning, babe!
O que é?
Abstração hacker: é machine learning usando tipos de
modelos (Deep Nets) que são capazes de reconhecer
padrões mais complexos nos exemplos.
Cool! Where do we start?
Linguagem Lua; usado
pelo Facebook
Para Python
C++
Criado pelo Google; em
Python
Can we hack that too?
Só precisamos simular os neurônios do nosso cérebro e
aplicar derivadas parciais pra implementar 2 algoritmos:
gradiente descendente e backprop
J.K., vamos usar o TensorFlow.
Code: http://bit.ly/2aYZNv0
Outras vantagens do Deep
Learning
Deep Learning é capaz de fazer aprendizado de features
Nos livramos do feature engineering, tarefa mais
demorada quando se usa outros modelos
Outras vantagens do Deep
Learning
Comunidades que antes usavam técnicas estatísticas
completamente diferentes, agora compartilham muito
em comum
Ex.: reconhecimento de fala e reconhecimento de
objetos em imagens.
Avanços recentes
Reconhecimento de fala sem deep learning
30% de erro
Reconhecimento de fala com deep learning
Menos de 5% de erro
Avanços recentes
Quando a tradução entre
línguas for feita com Deep
Learning, será como capturar o
pensamento de uma língua para
só depois aplicá-lo na outra
língua.
Pausa para teoria:
arquiteturas de deep nets
Redes recorrentes (RNNs)
Têm uma memória de curto prazo, ideal para
reconhecimento de fala e processamento de texto
Redes Convolucionais (ConvNets pros íntimos)
Inspiradas no nosso córtex visual, são muito
utilizadas em imagens
Mais sobre ConvNets
Pausa para teoria:
arquiteturas de deep nets
Redes adversárias
Enquanto uma rede tenta identificar se o input é natural
ou artificial, uma segunda rede tenta criar inputs
artificiais para enganar a outra.
É um tipo de modelo generativo. Provavelmente o que é
utilizado pelo Prisma.
Enquanto as primeiras camadas de uma ConvNet revela
o “estilo”, as últimas revelam o “conteúdo”
Pausa para teoria:
arquiteturas de deep nets
Outros exemplos de modelos generativos:
Beethoven no estilo Bossa Nova
Beethoven no estilo Beatles
Deep Learning: longa história
Redes Neurais Artificiais existem desde os anos 80, mas
depois um tempo ninguém mais deu bola.
Pesquisadores de outras áreas até zombavam.
Fast-forward: lots of data and fast GPUs!
Thank you gamers.
Deep Learning: longa história
Yann Lecun
Facebook, NYU
Geoff Hinton
Google, U. Toronto
Yoshua Bengio
U. Montreal
Tech de ponta:
transfer learning
Similar a se reutilizar o aprendizado de uma língua
ao se aprender uma nova língua.
TensorFlow Inception
Pré-treinado em 2 semanas com 8 GPUs
utilizando o ImageNet
Basicamente, é removida a última camada da rede e
se refaz o treinamento
Tech de ponta:
one-shot learning
Deep Learning atualmente precisa de milhares ou
milhões de exemplos
Como conseguir aprender com um ou poucos
exemplos?
Pesquisa em atividade.
Roadmap ML hacker
(em ordem)
DataCamp: Python for Data Science (opcional)
Udacity: Intro to Machine Learning
Coursera: Machine Learning (Stanford University)
Udacity: Deep Learning (Google)
Deep Learning (Bengio e Goodfellow)
Cheat-sheet de algoritmos
Muitos dados: deep nets
Gracias.
Slides: slideshare.net/GabrielCyprianoSaca
Notícias sobre ML: getpocket.com/@gabrielcs
Blog e mais: gabrielcs.me

Mais conteúdo relacionado

PDF
Machine learning java ce conference 2012 - fortaleza ce
PDF
Como ingressar no mercado de Machine Learning
PDF
Python e Aprendizagem de Máquina (Inteligência Artificial)
PDF
Criação de robôs em PHP para raspagem de dados
PDF
Introdução a Machine Learning e TensorFlow
PDF
Hackeando o Facebook com Python
PPTX
Dismistificando deep learning v2.1
PPTX
Dismistificando deep learning
Machine learning java ce conference 2012 - fortaleza ce
Como ingressar no mercado de Machine Learning
Python e Aprendizagem de Máquina (Inteligência Artificial)
Criação de robôs em PHP para raspagem de dados
Introdução a Machine Learning e TensorFlow
Hackeando o Facebook com Python
Dismistificando deep learning v2.1
Dismistificando deep learning

Mais procurados (13)

PDF
Introdução ao pensamento computacional e aos algoritmos
PDF
De algoritmos à programas de computador
PDF
Hackeando o Facebook com Python
PDF
Dicas para programador web
PDF
Introducão à Deep Learning e suas aplicações em neuroimagem
PDF
Python para iniciantes
PDF
Administradores e suas gambiarras
PDF
Hackeando o Facebook e o Twitter com Python TI no Vale
PDF
Computação Visual com Python
PDF
Oficina Python: Hackeando a Web com Python 3
PDF
Quando robôs encontram ursos polares
PDF
Máquinas Podem Pensar
PDF
Desbravando a web com python - Matheus Lima
Introdução ao pensamento computacional e aos algoritmos
De algoritmos à programas de computador
Hackeando o Facebook com Python
Dicas para programador web
Introducão à Deep Learning e suas aplicações em neuroimagem
Python para iniciantes
Administradores e suas gambiarras
Hackeando o Facebook e o Twitter com Python TI no Vale
Computação Visual com Python
Oficina Python: Hackeando a Web com Python 3
Quando robôs encontram ursos polares
Máquinas Podem Pensar
Desbravando a web com python - Matheus Lima

Destaque (20)

PDF
Machine Learning - Introdução e Aplicações
PPTX
Aplicações Práticas de Machine Learning
PDF
Deep Learning
PPTX
Webinar: Amazon Machine Learning
PDF
Machine Learning com Python e Scikit-learn
PPT
Introdução ao Deep Learning com o TensorFlow
PPTX
First Big Data Week
PDF
Deep Learning e Bots em Geral
PPTX
Azure Machine Learning
PDF
Mini-curso JavaFX Aula3 UFPB
PPTX
Redes neurais
PDF
Mini-curso JavaFX Aula2
PDF
JavaFX: Desktop para desenvolvedores WEB
PDF
Introdução ao JavaFX
PDF
Aplicações desktop (GUI) e aplicações ricas para internet (RIA)
PPTX
Aprendizado de Máquinas com Azure Machine Learning e R
PDF
Deep Belief Networks (D2L1 Deep Learning for Speech and Language UPC 2017)
PPT
Social Machines - 2017 Update (University of Iowa)
PDF
EL MODELO DE NEGOCIO DE YOUTUBE
PPTX
Criando aplicações java fx em minutos
Machine Learning - Introdução e Aplicações
Aplicações Práticas de Machine Learning
Deep Learning
Webinar: Amazon Machine Learning
Machine Learning com Python e Scikit-learn
Introdução ao Deep Learning com o TensorFlow
First Big Data Week
Deep Learning e Bots em Geral
Azure Machine Learning
Mini-curso JavaFX Aula3 UFPB
Redes neurais
Mini-curso JavaFX Aula2
JavaFX: Desktop para desenvolvedores WEB
Introdução ao JavaFX
Aplicações desktop (GUI) e aplicações ricas para internet (RIA)
Aprendizado de Máquinas com Azure Machine Learning e R
Deep Belief Networks (D2L1 Deep Learning for Speech and Language UPC 2017)
Social Machines - 2017 Update (University of Iowa)
EL MODELO DE NEGOCIO DE YOUTUBE
Criando aplicações java fx em minutos

Semelhante a Introdução ao Machine Learning para Hackers (20)

PPTX
[Jose Ahirton Lopes] Inteligencia Artificial - Uma Abordagem Visual
PPTX
[Jose Ahirton Lopes] Inteligencia Artificial - Uma Abordagem Visual
PPTX
Introdução a Machine learning (Aprendizado de Máquina)
PDF
PyBr21: Explorando características faciais para inferir informações demográficas
PDF
Minicurso do Terminal ao Python
PPTX
[Jose Ahirton Lopes] Deep Learning - Uma Abordagem Visual
PPTX
Data Science & Machine Learning - Python Conference ES 2017
DOCX
Fórum respostas
PDF
Inteligencia artificial 1
PPTX
Uma breve introdução ao Big Data e Inteligência Artificial.pptx
PDF
Ia01 introducao (1)
PDF
Minicurso_AprenziagemDeMaquina_scikit_learn_aula0.pdf
PPTX
Desmistificando machine learning
PDF
Python Training #1 - ed5
PDF
Data Science e Inteligência de dados - Inteligencia artificial e machine lear...
PDF
Aprendizado de Máquina em Microcontroladores com TensorFlow Lite e Edge Impul...
PDF
Inteligência Artificial : desafios na sociedade do conhecimento
PDF
Python: A Arma Secreta do Cientista de Dados
PPTX
[Jose Ahirton Lopes] Deep Learning - Uma Abordagem Visual
ODP
G.O. - Grafos Online
[Jose Ahirton Lopes] Inteligencia Artificial - Uma Abordagem Visual
[Jose Ahirton Lopes] Inteligencia Artificial - Uma Abordagem Visual
Introdução a Machine learning (Aprendizado de Máquina)
PyBr21: Explorando características faciais para inferir informações demográficas
Minicurso do Terminal ao Python
[Jose Ahirton Lopes] Deep Learning - Uma Abordagem Visual
Data Science & Machine Learning - Python Conference ES 2017
Fórum respostas
Inteligencia artificial 1
Uma breve introdução ao Big Data e Inteligência Artificial.pptx
Ia01 introducao (1)
Minicurso_AprenziagemDeMaquina_scikit_learn_aula0.pdf
Desmistificando machine learning
Python Training #1 - ed5
Data Science e Inteligência de dados - Inteligencia artificial e machine lear...
Aprendizado de Máquina em Microcontroladores com TensorFlow Lite e Edge Impul...
Inteligência Artificial : desafios na sociedade do conhecimento
Python: A Arma Secreta do Cientista de Dados
[Jose Ahirton Lopes] Deep Learning - Uma Abordagem Visual
G.O. - Grafos Online

Último (7)

DOC
COMO AUTOMATIZR JOGOS SUPER NINTENDO ATRAVES DA PROGRAMAÇÃO
DOC
CODIGO PARA AUTOMATIZAR A JOGABILIDADE SUPER MARIO
PDF
Evolução em código: algoritmos genéticos com PHP
PDF
apresentacao introducao computacao ead.pdf
PDF
Dos requisitos ao código: como criar código rastreável em PHP
PPTX
Mapeamento de Objeto para Tabela Relacional
PPTX
Curso de Windows 11 resumido na prática.pptx
COMO AUTOMATIZR JOGOS SUPER NINTENDO ATRAVES DA PROGRAMAÇÃO
CODIGO PARA AUTOMATIZAR A JOGABILIDADE SUPER MARIO
Evolução em código: algoritmos genéticos com PHP
apresentacao introducao computacao ead.pdf
Dos requisitos ao código: como criar código rastreável em PHP
Mapeamento de Objeto para Tabela Relacional
Curso de Windows 11 resumido na prática.pptx

Introdução ao Machine Learning para Hackers

  • 2. Quem sou eu? Gabriel Cypriano gabrielcs.me Background em Ciência da Computação e Engenharia de Software Cursos online recentes: Machine Learning (Stanford University) Intro to Recommender Systems (University of Minnesota) Python for Data Science (DataCamp)
  • 5. O que é Machine Learning? Definição anti-hacker: “It is the field of study that gives computers the ability to learn without being explicitly programmed.” Definição hacker: “It is all about learning from examples rather than writing explicit rules — you let the algorithm find those rules for you.”
  • 6. OK. Exemplos? Spam Recomendações da Netflix Amazon Echo Google Photos / Facebook Photo Tags DeepMind jogando Atari Prisma Carros autônomos
  • 7. Tá, mas eu consigo fazer isso em casa? Claro, é só revisar álgebra linear, cálculo multivariável, inferência estatística e fazer um mestrado + um doutorado em Deep Learning. J.K. :) Nós vamos inverter a abordagem de aprendizado tradicional e começar utilizando APIs que abstraem a matemágica. Leitura recomendada: http://bit.ly/2aSa6SM
  • 8. Cool! Where do we start? R foi feita por estatísticos para estatísticos É a mais natural para computação numérica, mas não dá pra criar nem um web service, além de limitações com o volume de dados Python não é tão natural quanto R para computação numérica, mas dá pra se fazer web services/apps Comunidade de ML forte Scala muito usada com o Spark para computação paralela Deixa Python na poeira, mas pode ser complexa para um momento inicial
  • 9. Cool! Where do we start? Também existem muitas soluções na nuvem: Google Cloud Machine Learning Microsoft Azure Machine Learning Amazon Machine Learning IBM Predictive Analytics
  • 10. Let’s start hacking. Regressão Linear com Python Code: http://bit.ly/2aZfa7L
  • 11. Pausa para teoria: abordagens de aprendizado Supervisionado Quando são fornecidos labels com os exemplos Por reforço (reinforcement learning) Dando recompensas, tipo como você treina seu dog. Não-supervisionado Quando não são fornecidos labels
  • 12. Exemplo: Carros autônomos (input são câmeras e um humano dirigindo)? Aprendizagem supervisionada.
  • 13. Exemplo: Prisma (input é um estilo de pintura e uma foto)? Aprendizagem não-supervisionada.
  • 14. Exemplo: Jogos de Atari (input são pixels e o score)? Aprendizagem por reforço.
  • 15. Back to hacking. Aprendizagem não-supervisionada: clusterização. Code: http://bit.ly/2arPMlQ
  • 16. Deep Learning, babe! O que é? Abstração hacker: é machine learning usando tipos de modelos (Deep Nets) que são capazes de reconhecer padrões mais complexos nos exemplos.
  • 17. Cool! Where do we start? Linguagem Lua; usado pelo Facebook Para Python C++ Criado pelo Google; em Python
  • 18. Can we hack that too? Só precisamos simular os neurônios do nosso cérebro e aplicar derivadas parciais pra implementar 2 algoritmos: gradiente descendente e backprop J.K., vamos usar o TensorFlow. Code: http://bit.ly/2aYZNv0
  • 19. Outras vantagens do Deep Learning Deep Learning é capaz de fazer aprendizado de features Nos livramos do feature engineering, tarefa mais demorada quando se usa outros modelos
  • 20. Outras vantagens do Deep Learning Comunidades que antes usavam técnicas estatísticas completamente diferentes, agora compartilham muito em comum Ex.: reconhecimento de fala e reconhecimento de objetos em imagens.
  • 21. Avanços recentes Reconhecimento de fala sem deep learning 30% de erro Reconhecimento de fala com deep learning Menos de 5% de erro
  • 22. Avanços recentes Quando a tradução entre línguas for feita com Deep Learning, será como capturar o pensamento de uma língua para só depois aplicá-lo na outra língua.
  • 23. Pausa para teoria: arquiteturas de deep nets Redes recorrentes (RNNs) Têm uma memória de curto prazo, ideal para reconhecimento de fala e processamento de texto Redes Convolucionais (ConvNets pros íntimos) Inspiradas no nosso córtex visual, são muito utilizadas em imagens
  • 25. Pausa para teoria: arquiteturas de deep nets Redes adversárias Enquanto uma rede tenta identificar se o input é natural ou artificial, uma segunda rede tenta criar inputs artificiais para enganar a outra. É um tipo de modelo generativo. Provavelmente o que é utilizado pelo Prisma. Enquanto as primeiras camadas de uma ConvNet revela o “estilo”, as últimas revelam o “conteúdo”
  • 26. Pausa para teoria: arquiteturas de deep nets Outros exemplos de modelos generativos: Beethoven no estilo Bossa Nova Beethoven no estilo Beatles
  • 27. Deep Learning: longa história Redes Neurais Artificiais existem desde os anos 80, mas depois um tempo ninguém mais deu bola. Pesquisadores de outras áreas até zombavam. Fast-forward: lots of data and fast GPUs! Thank you gamers.
  • 28. Deep Learning: longa história Yann Lecun Facebook, NYU Geoff Hinton Google, U. Toronto Yoshua Bengio U. Montreal
  • 29. Tech de ponta: transfer learning Similar a se reutilizar o aprendizado de uma língua ao se aprender uma nova língua. TensorFlow Inception Pré-treinado em 2 semanas com 8 GPUs utilizando o ImageNet Basicamente, é removida a última camada da rede e se refaz o treinamento
  • 30. Tech de ponta: one-shot learning Deep Learning atualmente precisa de milhares ou milhões de exemplos Como conseguir aprender com um ou poucos exemplos? Pesquisa em atividade.
  • 31. Roadmap ML hacker (em ordem) DataCamp: Python for Data Science (opcional) Udacity: Intro to Machine Learning Coursera: Machine Learning (Stanford University) Udacity: Deep Learning (Google) Deep Learning (Bengio e Goodfellow)
  • 33. Gracias. Slides: slideshare.net/GabrielCyprianoSaca Notícias sobre ML: getpocket.com/@gabrielcs Blog e mais: gabrielcs.me