RoomNet
RoomNet copied to clipboard
A lightweight ConvNet (~700 KB) to classify pictures of different rooms of a house/apartment with 88.9 % accuracy
data:image/s3,"s3://crabby-images/c4d0a/c4d0a00d77e8a67ca68e7a17324801f20cb93ca3" alt="drawing"
A Convolutional Neural Net to classify pictures of different rooms of a house/apartment with 88.9 % validation accuracy over 1839 images.
Full presentation at - https://github.com/ironhide23586/RoomNet/raw/master/documentation/RoomNet%20Presentation.pptx
This is a custom neural net I designed to classify an input image in to one of the following 6 classes (in order of their class IDs) -
- Backyard
- Bathroom
- Bedroom
- Frontyard
- Kitchen
- LivingRoom
Architecture -
Building Blocks -
Full Network Architecture -
data:image/s3,"s3://crabby-images/4f876/4f87632bf5b345add2263f4016b1adf738fc9f36" alt="drawing"
Out-of-box Inference -
Optimized inference code in infer.py. Refer to the short code in the main method calling the classify_im_dir method.
Training -
- Input image size = 224 x 224 (tried 300 x 300, 600 x 600)
- Softmax Cross Entropy Loss used with L2 Weight normalization
- Dropout varied from 0 (initially) to 0.3 (intermittently near the end of training). Dropout layers placed after every block.
- Batch Normalization moving means & vars were frozen when being trained with dropout
- Adam Optimizer used with exponential learning rate decay.
- Initially trained with in-batch computation of BatchNorm moving means/vars. Followed this by training net, by disabling this computation and using frozen means/vars during training. Resulted in 10% immediate jump in validation accuracy.
- Batch Size varied from 8 (in the beginning) to 45 (towards training end) as – 8 -> 32 -> 40 -> 45
- Asynchronous Data Reader designed with a Queue based architecture which allows for quick data I/O during training even with large batch sizes.
Conversion to Inference Optimized Version -
- Discarded all back propagation/training related compute node from the Tensorflow Graph.
- Model size reduced from ~2 MB to ~800 KB.
- network.py contains class defining the model called “RoomNet”
- Output is an excel file mapping each image path to its label. There is also provision to split an input directory to directories corresponding to the class names and automatically fill the relevant image in its respective directory.
Training Environment -
- Training done using Tensorlfow + CUDA 10.0 + cuDNN on NVIDIA GTX 1070 laptop grade GPU with 8GB of GPU memory
- Compute system used is an Alienware m17 r4.
- CPU used is an Intel Core i7 – 6700HQ with 8 logical cores at 2.6 GHz of base speed (turbo boost to ~3.3 GHz)
- Number of training steps from scratch to reach best model is 157,700.
- Time spent on training - ~48 hours
Previous Approaches tried -
- Tried training the final dense NASnet mobile but accuracy never crosses 60%.
- Tried the same with InceptionV3 but convergence takes too damn long.
Performance Plots -
Validation Accuracy
data:image/s3,"s3://crabby-images/a3ee2/a3ee2e9da2287812ff3d2c03596b1d14368075d4" alt="drawing"
Validation Class-wise F-Score
data:image/s3,"s3://crabby-images/518c8/518c899399a534611ba777499b0279403639d3aa" alt="drawing"
Validation Class-wise Precision
data:image/s3,"s3://crabby-images/5c2eb/5c2eb16c2cb5060aee4c2380997f2cd29810e3f6" alt="drawing"
Validation Class-wise Recall
data:image/s3,"s3://crabby-images/d9727/d9727298b27579c8bbb123690b2857ec8b081495" alt="drawing"