movie-posters-convnet
movie-posters-convnet copied to clipboard
Unsupervised clustering of movie posters with features extracted from Convolutional Neural Network
Demo
Overview
Unsupervised clustering of movie posters with features extracted from Convolutional Neural Network. Visualization using flask as a backend and d3js for the frontend.
This project is divided into 3 main scripts:
- get_posters.py
- retrieve the posters from impawards.com.
- create a thumbnail for each posters for the visualization.
- get_features_from_cnn.py
- get_data_visu.py
- dimension reduction for data-visualization with umap.
- compute the cosine similarity and extract the 6 ``closest'' images for each posters.
To get parameters descriptions:
- python src/get_XXX.py --help
Requirements
OS
- Linux/Unix/OSX (requirement for wget)
- Python 3.3+
- ImageMagick
- Postgresql
Packages Python
- BeautifulSoup 4.4
- Tensorflow
- Keras
- Pandas
- requests
- sklearn
- numpy
- PIL
- flask
Warnings
The extraction of the features from ConvNet is long if you do not owned a GPU. The computation of the similarity between each posters required O(n^2) in memory which required around 32Go of RAM.
Installation
Clone the depot:
$ git clone https://github.com/adrz/movie-posters-convnet.git
$ cd movie-posters-convnet/
$ virtualenv -p python3 env
$ source env/bin/activate
$ pip install -r requirements-gpu.txt
Create postgresql database (supposed you already install postgresql):
$ psql -U postgres -c "createuser movieposters;"
$ psql -U postgres -c "createdb movieposters;"
$ psql -U postgres -c "alter user movieposters with encrypted password 'yourpassword';"
$ psql -U postgres -c "grant all privileges on database movieposters to movieposters ;"
Usage
Computation
After cloning you can just launch the bash script that will:
- download posters from 1920 to 2016
- compute features
- compute the datavisualization features
$ python src/get_posters.py -c config/development.conf
$ python src/get_get_features_from_cnn.py -c config/development.conf
$ python src/get_data_visu.py -c config/development.conf
Then grab a coffee...
Visualization
$ source env/bin/activate
$ configapi=./config/development.conf
$ python app.py
Then launch index.html into your favorite browser:
$ chromium 127.0.0.1:5000/index.html
or
$ chromium 127.0.0.1:5000/index_complete.html
Results
Cherry-piking from the top-200 closest couple of posters (relative to cosine distance):
data:image/s3,"s3://crabby-images/0748c/0748c2692545cc27dc0fe6a3aa8ab564d6bcca84" alt=""
data:image/s3,"s3://crabby-images/2a161/2a161c829f26f6967e10aec66d6dd98c0e71e606" alt=""
data:image/s3,"s3://crabby-images/087f4/087f435ec7fd3cb97b60e668eb31d2409dacca15" alt=""
data:image/s3,"s3://crabby-images/ac65b/ac65b843790ba57aeaab5fa4d5114be2d21363ec" alt=""
data:image/s3,"s3://crabby-images/12c06/12c0653db9d8bd05f56873ab304bb640fc4b606c" alt=""
data:image/s3,"s3://crabby-images/17a43/17a438c7040cbe26212f3bbe1683491d62197f3f" alt=""
data:image/s3,"s3://crabby-images/dffb7/dffb7af9e63888aef90721a607264f5a14825704" alt=""
data:image/s3,"s3://crabby-images/f1bee/f1bee748bb6f9642c64c390d98788f07420d2a48" alt=""
data:image/s3,"s3://crabby-images/bfce1/bfce1817d4c7fae597c8a6aebd88fd16f9d819f6" alt=""
data:image/s3,"s3://crabby-images/a7288/a728867b4a0c35f73ae9611745d8f53b6036d1eb" alt=""
data:image/s3,"s3://crabby-images/6b694/6b69499deb7530936e64b9366932198206da603f" alt=""
data:image/s3,"s3://crabby-images/7b04b/7b04b6194d3e50b5ac550ae672cdb70b2b9d1c63" alt=""
data:image/s3,"s3://crabby-images/74730/74730c476935c4694b3316ad981eda2240fd04d8" alt=""
data:image/s3,"s3://crabby-images/93f92/93f92c192083b4cb133cc60b132cce5236742145" alt=""
data:image/s3,"s3://crabby-images/3b38a/3b38afbab1c5ee0a054bf5adbaabf733a55b9276" alt=""
data:image/s3,"s3://crabby-images/b9231/b923176a9adaaf9248d13e64a91ad4e3f01f6fe0" alt=""
data:image/s3,"s3://crabby-images/b80ee/b80eed9b050c057c03be8e0fbacddb6875fcb7a1" alt=""
data:image/s3,"s3://crabby-images/28772/287723746423494175e5ce739d8f83e01f934578" alt=""
data:image/s3,"s3://crabby-images/d4f03/d4f037de51e654f7876bad507d067bfcaf8a94c4" alt=""
data:image/s3,"s3://crabby-images/5e415/5e415d98bf19fec156b198849803171881bc131f" alt=""
data:image/s3,"s3://crabby-images/4359f/4359f4a2cfb564d741d9743c9f9744d0f1368115" alt=""
data:image/s3,"s3://crabby-images/c227d/c227dc9efe66a310d7ea604155730c86bfe128bc" alt=""
data:image/s3,"s3://crabby-images/ec942/ec94297ba1f9f515159f2a5ddf633d88e90b4c82" alt=""
data:image/s3,"s3://crabby-images/6faa5/6faa5a4531e9721f698e86145f755a6e64c70049" alt=""
License
This project is licensed under the MIT License - see the LICENSE.md file for details
Acknowledgments
- posters: IMP Awards