1. Intro
About this course
Introduction to machine learning
The goal of the module is to explore different applications of ML/AI/DL with a focus on design and art.
We will first learn how neural networks work with simple code examples. From there we will experiment with different techniques of Deep Learning for Computer Vision (image classification, objects detection, pose estimation...) and Generative Deep Learning (DeepDream, style transfer, Pix2Pix / CycleGAN...).
data:image/s3,"s3://crabby-images/54d29/54d293a26c3092ac3fdf58250280980b1a8a0e1f" alt="G."
About Me
UX, UI, CODE
Designer and coder. Background in code, worked mostly in design...
Principles
Peer learning
"Peer learning is an educational practice in which students interact with other students to attain educational goals."
Evaluation Criteria
- Grading Collaboration, Research, Exploration
- Deliverable Presentation + project + documentation
- Date Week 51 / 52
data:image/s3,"s3://crabby-images/01baf/01bafe5744840c25c5e8194dfce66ebb2c9aa762" alt="diagram"
1.0 Students intro
1.1 AI/ML/DL
AI
Artificial intelligence (AI) is an area of computer science that emphasizes the creation of intelligent machines that work and react like humans.
data:image/s3,"s3://crabby-images/b2a0f/b2a0fa430a0f6bb11764a12ea5e7d423bac06804" alt="diagram"
ML
Machine Learning at its most basic is the practice of using algorithms to parse data, learn from it, and then make a determination or prediction about something in the world.
--
So rather than hand-coding software routines with a specific set of instructions to accomplish a particular task, the machine is “trained” using large amounts of data and algorithms that give it the ability to learn how to perform the task.
data:image/s3,"s3://crabby-images/27256/2725685b315db2fcea0b4fb603bfd409c40bb198" alt="diagram"
data:image/s3,"s3://crabby-images/4ae22/4ae2220195b4a420d0e57d7e821b1b48174769d5" alt="diagram"
1.2 History
data:image/s3,"s3://crabby-images/c570c/c570c4b2357f5644ae04409eb3e60e303a9b3047" alt="diagram"
Analytical Engine
“ The Analytical Engine has no pretensions whatever to originate anything. It can do whatever we know how to order it to perform… Its province is to assist us in making available what we are already acquainted with ”
Ada Lovelace (1843)
1.3 The steps of ML
data:image/s3,"s3://crabby-images/72359/7235954819fa4792090854e19533cb047c5ecabc" alt="diagram"
1.4 Different kinds of ML
Supervised Learning
data:image/s3,"s3://crabby-images/02df9/02df936edc34db093e5ed5cd1941d3ecf08da4fe" alt="diagram"
Learning to map input data to known targets (also called annotations),
given a set of examples (often annotated by humans)
Unsupervised Learning
data:image/s3,"s3://crabby-images/0216f/0216fa552d84dcc194d456534cb5f62a5f8cb36c" alt="diagram"
Finding interesting transformations of the input data without the help of any targets
Reinforcement Learning
data:image/s3,"s3://crabby-images/ed720/ed72016d470598784274211287fa9c8090adbc15" alt="diagram"
In reinforcement learning, an "agent" receives information about its environment and learns to pick actions that will maximize some reward.
1.5 What is a neural network?
data:image/s3,"s3://crabby-images/1762a/1762ac5ceb84ef89b1287070eba94ed3a089d21b" alt="diagram"
data:image/s3,"s3://crabby-images/df0b4/df0b4ffddfbcaddf86f3f3692e396b9817acfefa" alt="diagram"
1.6 What is Deep Learning
DL
Deep learning is a specific subfield of machine learning, a new take on learning representations from data which puts an emphasis on learning successive "layers" of increasingly meaningful representations.
The 'Deep' in Deep Learning
data:image/s3,"s3://crabby-images/7d0f2/7d0f291cf81afe073e10de331e3036b0608969df" alt="diagram"
data:image/s3,"s3://crabby-images/ce966/ce96660e2a9fc1dcdf5ab95cbe3bf18b35c2a9c8" alt="diagram"
Understanding how deep learning works in three figures
data:image/s3,"s3://crabby-images/86ff1/86ff12004f85ea60e005031ba54f10ccc99e505a" alt="diagram"
data:image/s3,"s3://crabby-images/fd780/fd78053bd5f0b70f5cf3b7121e13f4b1f2450f05" alt="diagram"
data:image/s3,"s3://crabby-images/7700b/7700b9967958fc2d50c22d642c5e69f5979c6636" alt="diagram"
1.7 Learning steps
Application of DL
-
Self driving vehicles
-
Face tracking / recognition
-
Medical image interpretation
-
Speech processing
1.8 Why Now?
2. Maths
3. Machine Learning
3.1 Tasks
Image classification
data:image/s3,"s3://crabby-images/2d5c9/2d5c9b54ec4cd79d1d5cd0aa31dcdc20f69bf284" alt="diagram"
Image regression
data:image/s3,"s3://crabby-images/305a8/305a83e12b78ef50606db8bf387ce68890a47e89" alt="diagram"
Text classification
data:image/s3,"s3://crabby-images/f1d69/f1d6937cb59988496f590ad6a54f40d6731d8700" alt="diagram"
Sound classification (text to speech)
data:image/s3,"s3://crabby-images/cd508/cd5087dafc73c9d9225341f920c98bf919e8ad58" alt="diagram"
Object Detection
data:image/s3,"s3://crabby-images/50111/5011130e3b90248c50e8c793976fd926f46e50d8" alt="diagram"
Pose Detection
data:image/s3,"s3://crabby-images/e5e19/e5e193c20dbddb578373ed9a503d3978f56ae0a5" alt="diagram"
Image Segmentation
data:image/s3,"s3://crabby-images/03700/037004389897ae8a4f9eef3e8ca19ea481920d97" alt="diagram"
3.2 Models Architectures
CNN - Convolutional Neural Networks
data:image/s3,"s3://crabby-images/73f69/73f690d5ce42b0b6d9315ed8eafcabfc694532cc" alt=""
RNN - Reccurent Neural Networks
LSTM - Long Short Term Memory
GAN - Generative Adversorial Networks
4. Examples
4.1 Personal
4.2 Others
X Degrees of Separation
The hidden paths through culture
data:image/s3,"s3://crabby-images/0cdfb/0cdfb98e0d49d9abd725aaf7ea28c9c90665cc77" alt="Text 2 Image"
Text 2 Image
Text 2 Image translation
- url: t2i.cvalenzuelab.com
- based on: AttnGan
- built by: @c_valenzuelab
data:image/s3,"s3://crabby-images/feff1/feff18aece3b32fe18dd8de2b6b81c58a75216eb" alt="fpt"
Fast photo style
Given a content photo and a style photo, the code can transfer the style of the style photo to the content photo.
data:image/s3,"s3://crabby-images/221bf/221bf195f798f2d00dee187a84075bae9cb734ac" alt="Text 2 Image"
Everybody Dance Now
Simple method for "do as I do" motion transfer: given a source video of a person dancing the model can transfer that performance to a novel (amateur) target after only a few minutes of the target subject performing standard moves
data:image/s3,"s3://crabby-images/7f3c5/7f3c52ffe1bdae57b5d94171b1d58300595bfe94" alt="vid2vid"
vid2vid
photorealistic video-to-video translation. It can be used for turning semantic label maps into photo-realistic videos, synthesizing people talking from edge maps, or generating human motions from poses.
- url: https://github.com/NVIDIA/vid2vid
- project: https://tcwang0509.github.io/vid2vid/
- built by: https://github.com/NVIDIA
data:image/s3,"s3://crabby-images/f8527/f8527d515987bb38dec9cfe4d86ce7313767bb12" alt="example-sentencespace"
Voyage in Sentence Space
Imagine a sentence. “I went looking for adventure.” Imagine another one. “I never returned.” Now imagine a sentence gradient between them
data:image/s3,"s3://crabby-images/d6e87/d6e870c5591aa2c5f268df9560a9fdcaa2fd035d" alt="machinewriting"
Writing with the machine
...If I had to offer an extravagant analogy (and I do) I’d say it’s like writing with a deranged but very well-read parrot on your shoulder. Anytime you feel brave enough to ask for a suggestion, you press tab, and...
I should say clearly: I am absolutely 100% not talking about an editor that “writes for you,” whatever that means. The world doesn’t need any more dead-eyed robo-text.
The animating ideas here are augmentation; partnership; call and response.
The goal is not to make writing “easier”; it’s to make it harder.
The goal is not to make the resulting text “better”; it’s to make it different — weirder, with effects maybe not available by other means.
Robin Sloan
OpenAI Five
OpenAI team of five neural networks, OpenAI Five, has started to defeat amateur human teams at Dota 2.
- url: https://blog.openai.com/openai-five/
- built by: OpenAI
BeatBox
AI Can Help Anyone Become a Beatbox Champion
- url: https://codepen.io/naotokui/pen/NBzJMW
- built by: @naotokui
Imaginary Soundscape
Take a walk in soundscapes "imagined" by AI
- url: http://naotokui.net/projects/imaginary-soundscape/
- built by: @naotokui
AI DJ PROJECT
A dialog between human and AI through music
- url: http://aidj.qosmo.jp
- built by: @naotokui
- blog post: Medium article
The Neural Drum Machine
Uses the "Drums RNN" model from @TensorFlow Magenta to generate drum patterns. And @deeplearnjs + Tone.
5. Integration
data:image/s3,"s3://crabby-images/72359/7235954819fa4792090854e19533cb047c5ecabc" alt="diagram"
data:image/s3,"s3://crabby-images/2fbee/2fbeec4782a58634a59b2a537aba1a908bcb02f4" alt="diagram"
data:image/s3,"s3://crabby-images/d5a2f/d5a2fb33a8db765d61af5a6cd063364e47db6614" alt="diagram"
data:image/s3,"s3://crabby-images/781cb/781cbc112e77f04df28f15904493b7f9041c9db6" alt="diagram"
data:image/s3,"s3://crabby-images/72359/7235954819fa4792090854e19533cb047c5ecabc" alt="diagram"
data:image/s3,"s3://crabby-images/3222d/3222d79f66210a3d25f527fbaad5b8b6e1841526" alt="diagram"
data:image/s3,"s3://crabby-images/1d0e2/1d0e2a024ae09274b9ac89cc52368223ef13c514" alt="diagram"
data:image/s3,"s3://crabby-images/72359/7235954819fa4792090854e19533cb047c5ecabc" alt="diagram"
data:image/s3,"s3://crabby-images/1429a/1429a5817781521c5c3523e7345a0ee20ac6018c" alt="diagram"
data:image/s3,"s3://crabby-images/3f00b/3f00b69f12436f7a759ec3340cc02544a0234f0e" alt="diagram"
6. Tools
7. Ethics
8. Efficiency
data:image/s3,"s3://crabby-images/d0c39/d0c3937b3fd09acf9021278b6ebc8a995f1ea207" alt="diagram"
Credits
- Photos unsplash.com
- Diagrams mostly Deep Learning With Python by François Chollet