La semaine dernière, lorsque j’ai présenté Google Deep Dream, il a fallu que je prenne une décision éditoriale afin de garder le billet dans une taille raisonnable. Configurer Docker et mettre en place le nécessaire pour « rêver » sur sa première image était déjà une bouchée raisonnable à mastiquer, à mon avis.
Alors, une fois que vous avez Deep Dream, que pouvez-vous faire de plus? DE LA SCIENCE!
Le code source
La plateforme utilisée par Deep Dream pour exécuter le code source permettant de faire fonctionner la machine à rêver est IPython. IPython permet, notamment, d’exécuter de façon interactive du code source Python à même votre navigateur web.
En particulier, avec l’exemple de Deep Dream, des explications sont fournies pour chaque extrait de code source que vous serez invité à exécuter. Parlant de code source, j’ai extrait le code de la page interactive de Deep Dream afin que vous puissiez voir une idée de ce que cela représente.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
Je ne crois pas que vous devez être vraiment familier avec Python pour comprendre le fonctionnement sommaire de ce code. La principale chose à savoir avec Python est que l’indentation va servir à identifier un bloc d’exécution. Alors, pas d’accolades comme en C# avec Python.
Des jeux de données supplémentaires
Lorsque vous exécutez Deep Dream dans la machine virtuelle Docker de mon billet précédent, un jeu de données nommé bvlc_googlenet est utilisé. Ce jeu de modèle, mis en place par Google, est reconnu pour sa capacité à reconnaître et classer des images.
Si vous êtes du genre à pousser l’expérience un peu plus loin, vous pouvez télécharger ces modèles de données et les exécuter sur votre instance Deep Dream. Par exemple, bvlc_googlenet et bvlc_alexnet servent des buts différents et donnent des résultants qui sont, en conséquent, différents.
Pascal – bvlc_alexnet
Pascal – bvlc_googlenet
Voici les étapes pour y arriver:
Cloner le repository git https://github.com/BVLC/caffe.git
Copier le contenu du dossier /Models/ dans /deepdream (le répertoire où vous avez mappé le répertoire /src dans la commande de démarrage du conteneur Docker dans les instructions du précédent billet)
Pour chaque jeu de données, se référer aux instructions pour télécharger le fichier à l’extension .caffemodel et le déposer à la racine du dossier du jeu de données que vous désirez utiliser.
Pour modifier le code précédemment cité, afin de faire fonctionner des jeux de données différents, vous devez ajuster les bouts de code suivants:
La variable model_path: afin d’y spécifier le répertoire de votre jeu de données (portez attention à l’emplacement débutant par /src
La variable param_fn: spécifiez-y le nom de votre fichier .caffemodel
La fonction make_step: modifiez le contenu du paramètre end pour un des layers de votre jeu de données. Pour trouver le nom d’un layer, consultez le fichier deploy.prototxt de votre jeu de données. Il s’agit d’un fichier JSON qui contient la définition des layers à votre disposition
Ce gist est vraiment impressionnant: https://gist.github.com/JamesNK/56b1c3b90b2a8d21c73d. Il s’agit d’un échange entre développeurs sur la meilleure façon d’écrire un nuspec pour Newtonsoft.Json pour que la librairie supporte le maximum de plateformes .NET.
Connaissez-vous Google Deep Dream? Il s’agit du nom donné à une technologie fascinante qui a donné lieu à des avancées remarquées dernièrement. En particulier pour l’identification d’images et de reconnaissance de la voix.
Vous l’avez lu. Deep Dream est basé sur une technologie inspirée du fonctionnement humain. Pour faire simple, il s’agit d’un algorithme qui apprend et classifie selon les différents intrants qui sont mis à sa disposition grâce à des calculs statistiques. C’est par là que s’en va le futur!
Deep Dream, grâce à ses images psychédéliques, a donné un peu de popularité au concept de réseau de neurones artificiel. Cependant, il ne s’agit pas d’un concept nouveau. Ces algorithmes sont déjà utilisés dans divers champs d’application comme à la bourse ou même en météorologie.
L’autre facteur qui a donné de la visibilité à Deep Dream est la possibilité d’exécuter le code sur sa propre machine. La plateforme est basée sur un framework de Deep Learning nommée Caffe. Vous vous doutez surement que je n’ai pas résisté à la tentation de l’exécuter sur ma propre machine, n’est-ce pas?
Installation de Deep Dream
Le plus simple pour exécuter Deep Dream à partir de votre propre ordinateur est d’avoir recours à une machine virtuelle Linux qui exécutera Docker pour héberger le nécessaire.
Dans le cas où vous ne connaissez pas Docker, il s’agit d’une plateforme de virtualisation d’applications qui fonctionne sous le concept de conteneurs partageant les ressources du système hôte. Vous trouverez plus d’informations au sujet de Docker ici.
Le principal avantage que j’ai trouvé à avoir recours à Docker est d’avoir accès à des conteneurs préparés par la communauté que vous pouvez utiliser pour vos besoins.
Alors donc, dans l’ordre, pour exécuter Deep Dream sur votre machine vous devez:
Installer une distribution de Linux sur une machine virtuelle (si vous avez déjà Linux, évidemment, sautez cette étape). Pour ma part, j’ai installé Ubuntu 14.04.3 LTS.
À partir de cet instant, vous avez Docker sur votre machine virtuelle Linux. Cependant, ce n’est qu’un début, car vous devez maintenant mettre en place un conteneur Docker avec tout ce qu’il faut pour Deep Dream.
S’assurer que Docker est en fonction : sudo service docker start
Exécuter la commande docker pull ryankennedyio/deepdream
Attendre
Attendre
Attendre
Démarrer le conteneur avec la commande: docker run -d -p 443:8888 -e « PASSWORD=password » -v /docker:/src ryankennedyio/deepdream
Voilà! Vous avez maintenant accès à Deep Dream à partir de votre machine virtuelle Linux. C’est bien beau Docker mais comment y accéder? Il y a quelques détails que vous devez savoir à partir de cet instant.
Notes sur la commande docker run
Afin de vous sauver quelques recherches sur la signification des arguments envoyés à la commande docker run, voici un résumé de ce que vous devez savoir.
L’argument -p 443:8888 redirige les requêtes faites au port 443 (HTTPS) vers le port 8888
Le mot de passe pour accéder à votre conteneur est « password »
À partir de votre conteneur, le dossier « /src » sera mappé au dossier « /docker » de l’hôte. Ceci veut dire que c’est dans ce dernier que vous devrez déposer vos propres images.
Récupérer l’adresse IP locale de votre conteur Docker
Lorsque vous démarrer un conteneur Docker, un identifiant unique lui est associé. Prenez-le en note et exécuter la commande sudo docker inspect <CID> | grep IPAddress | cut -d ‘ »‘ -f 4 où <CID> est l’identifiant unique.
Dans le cas où vous n’avez pas noté cet identifiant, vous pouvez le récupérer avec la commande sudo docker ps vous aurez maintenant dans la colonne « NAMES » l’identifiant unique en question.
Une fois que vous aurez trouvé votre adresse IP accédez-y en tapant l’URL suivante: https://IP:8888/tree. Félicitations! Vous pouvez maintenant exécuter Deep Dream en cliquant sur dream.ipynb.
Quelques rêves
J’ai fait quelques Deep Dream depuis que j’ai procédé à ma propre installation de docker. Je vous laisse contempler le résultat. Pour vous donner une idée, ces images sont toutes basées sur mon image de profil Twitter.