This repo is to construct a DL library for learning and testing some classic projects that include:
1, CNN, RNN(LSTM) model in pure Numpy, with all BP gradients calculation included.
2, Some classic model in tensorflow, including ResNet, SqueezeNet and more.
3, Some classic project scripts including Image Captioning, Image Fooling, Deep Dream, style transfer and more.
4, Image Localization, Dectection and Segmentation using Fast(er) R-CNN. (Coming very soon)
5, Multiple GAN(DCGAN, LSGAN, WGAN and more) implementation in Tensorflow.
6, Q-Learning implementation in Numpy and Gym. (Coming very soon)
All files in root directory represent a mini project, introduced in the section below. All files in lib has been covered by these mini projects.
--lib
-- classifiers
"all classifier models in both pure numpy or tensorflow"
-- solvers
"Trainer for both TF and pure numpy model"
-- layers
"layers for pure numpy model"
-- utils
"some assistant files"
-- datasets
"CIFAR-1O, MNIST dataset"
The projects is listed here in a recommended reading sequence:
It uses lib/model/linear_classifier.py to construct a linear classifer model to classify CIFAR-10 images. It's implemented in pure Numpy.
It uses lib/model/fc_net.py to construct a fully connected neural network model to classify CIFAR-10 images. It's implemented in pure Numpy.
It uses lib/model/cnn.py to construct a cnn model to classify CIFAR-10 images. It's implemented in pure Numpy.
It uses lib/model/rnn.py to contruct a vanilla rnn or lstm model to construct image captioning for microsoft coco data, the input feature is not from a CNN but from dataset directly. It's implemented in pure Numpy.
Image Captioning Relevant blog(In Chinese)
It build and test a CNN classifer in tensorflow.
It uses lib/model/squeezeNet.py with well trained parameters to show the saliencymap of images in CIFAR-10.
It uses lib/model/squeezeNet.py with well trained parameters to construct deepdream images based on images in CIFAR-10, for details about deepdream, please refer to the official github repo: https://github.com/google/deepdream
It construct a model that fool well-trained squeezenet to label an image with wrong label.
Please check this blog for details of these 3 prjects above:
Saliency Map/DeepDream/ImageFooling Relevant Blog(In Chinese)
It uses lib/model/squeezeNet.py with well trained parameters to extract features from both content and style image to construct a new content image with style image style.
Style Transfer Relevant Blog(In Chinese)
It implemented DCGAN and WGAN in tensorflow to generate images based on both MNIST and CIFAR-10.
1, Download the repo to local, a star to the repo is appreciated.
2, make sure Python3 is installled in your local env, a virtual env is recommended.
3, pip3 install -r requirements
4, go to lib/datasets, manually run get_datasets.sh and get_3rd_data.sh to download dataset to local.
5, feel free to run any project under root.
I will upload the following extra models and projects in very recent time.
[] DQN
[] RCNN Family
[] ResNet
[] Policy Gradient(Reenforcement learning)
[] VAE(Generative model)
This repo is heavily referenced with the assignment of Stanford cs231n. Special thanks to the great staff who give us such a great online course materials.
Course link: http://cs231n.stanford.edu/
Email: nick_fandingwei@outlook.com
Twitter: https://twitter.com/nick_fandingwei
For Chinese user, zhihu is the fastest way to get response from me: https://www.zhihu.com/people/NickWey
You can also check my tech blog for more: http://nickiwei.github.io/
Consider to follow me on Zhihu, Twitter and Github, thanks!