Image classifier is a Udacity capstone project.
The project consists of 2 parts:
- GetFiles.ipynb - data collection. Use this file to collect the data in case you want to do it manually. You can also download the dataset from this link.
- ClassifyImages.ipynb - main project.
The project was build on Python 2.7 and Google Cloud Platform using:
- Google VM instance
- Google Datalab
- Google BigQuery
- Google Storage (optional)
To run the analysis please upload the files in your Google Cloud workspace. See "Setting up" section below.
Libraries and modules we used:
- google.datalab
- pandas
- numpy
- logging
- pillow
- os
- random (optional)
- json (optional)
- urllib (optional)
- requests (optional)
- codecs (optional)
- cv2 (optional)
- pytube (optional)
To make the project running in Google Cloud, follow the instruction below.
- set up your account and project in Google Cloud.
- create and connect to a Cloud Datalab instance
- go to /content/ directory by clicking Home icon (see 1). Create a notebook in home directory by clicking Notebook (see 2)
- insert code cell in your new notebook and run
!git clone https://github.com/mzhigarev/Udaticy_MLE_Capstone
to copy GitHub repo to your Google Datalab folder. This command will move the files into home directory ('/content/')
!gsutil mv /content/Udaticy_MLE_Capstone/* /content/
And lastly, remove unnecessary folders
import shutil
shutil.rmtree("/content/Udaticy_MLE_Capstone/")
shutil.rmtree("/content/datalab/")
- Due to GitHub limit for file size, not all files will be copied. You need manually upload files from Google Drive repository into your directory on Google Cloud.
- Finally your directory should contain these files and folders:
ad_test/
excel-word-classifier-tt/
ClassifyImages.ipynb
GetFiles.ipynb
now you can reference the folder with path "/content/", so for example GetFiles.ipynb has a path "/content/GetFiles.ipynb"
We pre-collected files for testing/training. If you want to collect your own set, please run GetFiles.ipynb on local machine.
We used OpenCV and Pytube for data collection and preparation (see GetFiles.ipynb). The libraries are optional, all files you can find here. In case you want to gather your own data, use the libs on your local machine.
Install the labraries:
!pip install pytube
!pip install opencv-python