The Tensorflow Object Detection API supports distributed training on Google Cloud ML Engine. This section documents instructions on how to train and evaluate your model using Cloud ML. The reader should complete the following prerequistes:
- The reader has created and configured a project on Google Cloud Platform. See the Cloud ML quick start guide.
- The reader has installed the Tensorflow Object Detection API as documented in the installation instructions.
- The reader has a valid data set and stored it in a Google Cloud Storage bucket. See this page for instructions on how to generate a dataset for the PASCAL VOC challenge or the Oxford-IIIT Pet dataset.
- The reader has configured a valid Object Detection pipeline, and stored it in a Google Cloud Storage bucket. See this page for details on how to write a pipeline configuration.
Additionally, it is recommended users test their job by running training and evaluation jobs for a few iterations locally on their own machines.
In order to run the Tensorflow Object Detection API on Cloud ML, it must be packaged (along with it's TF-Slim dependency). The required packages can be created with the following command
# From tensorflow/models/
python setup.py sdist
(cd slim && python setup.py sdist)
This will create python packages in dist/object_detection-0.1.tar.gz and slim/dist/slim-0.1.tar.gz.
Google Cloud ML requires a YAML configuration file for a multiworker training job using GPUs. A sample YAML file is given below:
trainingInput:
runtimeVersion: "1.0"
scaleTier: CUSTOM
masterType: standard_gpu
workerCount: 9
workerType: standard_gpu
parameterServerCount: 3
parameterServerType: standard
Please keep the following guidelines in mind when writing the YAML configuration:
- A job with n workers will have n + 1 training machines (n workers + 1 master).
- The number of parameters servers used should be an odd number to prevent a parameter server from storing only weight variables or only bias variables (due to round robin parameter scheduling).
- The learning rate in the training config should be decreased when using a larger number of workers. Some experimentation is required to find the optimal learning rate.
The YAML file should be saved on the local machine (not on GCP). Once it has been written, a user can start a training job on Cloud ML Engine using the following command:
# From tensorflow/models/
gcloud ml-engine jobs submit training object_detection_`date +%s` \
--job-dir=gs://${TRAIN_DIR} \
--packages dist/object_detection-0.1.tar.gz,slim/dist/slim-0.1.tar.gz \
--module-name object_detection.train \
--region us-central1 \
--config ${PATH_TO_LOCAL_YAML_FILE} \
-- \
--train_dir=gs://${TRAIN_DIR} \
--pipeline_config_path=gs://${PIPELINE_CONFIG_PATH}
Where ${PATH_TO_LOCAL_YAML_FILE}
is the local path to the YAML configuration,
gs://${TRAIN_DIR}
specifies the directory on Google Cloud Storage where the
training checkpoints and events will be written to and
gs://${PIPELINE_CONFIG_PATH}
points to the pipeline configuration stored on
Google Cloud Storage.
Users can monitor the progress of their training job on the ML Engine Dashboard.
Evaluation jobs run on a single machine, so it is not necessary to write a YAML configuration for evaluation. Run the following command to start the evaluation job:
gcloud ml-engine jobs submit training object_detection_eval_`date +%s` \
--job-dir=gs://${TRAIN_DIR} \
--packages dist/object_detection-0.1.tar.gz,slim/dist/slim-0.1.tar.gz \
--module-name object_detection.eval \
--region us-central1 \
--scale-tier BASIC_GPU \
-- \
--checkpoint_dir=gs://${TRAIN_DIR} \
--eval_dir=gs://${EVAL_DIR} \
--pipeline_config_path=gs://${PIPELINE_CONFIG_PATH}
Where gs://${TRAIN_DIR}
points to the directory on Google Cloud Storage where
training checkpoints are saved (same as the training job), gs://${EVAL_DIR}
points to where evaluation events will be saved on Google Cloud Storage and
gs://${PIPELINE_CONFIG_PATH}
points to where the pipeline configuration is
stored on Google Cloud Storage.
You can run Tensorboard locally on your own machine to view progress of your training and eval jobs on Google Cloud ML. Run the following command to start Tensorboard:
tensorboard --logdir=gs://${YOUR_CLOUD_BUCKET}
Note it may Tensorboard a few minutes to populate with results.