You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

69 lines
2.9 KiB

6 years ago
  1. # Dockerfile for the TPU and TensorFlow Lite Object Detection tutorial
  2. This Docker image automates the setup involved with training
  3. object detection models on Google Cloud and building the Android TensorFlow Lite
  4. demo app. We recommend using this container if you decide to work through our
  5. tutorial on ["Training and serving a real-time mobile object detector in
  6. 30 minutes with Cloud TPUs"](https://medium.com/tensorflow/training-and-serving-a-realtime-mobile-object-detector-in-30-minutes-with-cloud-tpus-b78971cf1193), though of course it may be useful even if you would
  7. like to use the Object Detection API outside the context of the tutorial.
  8. A couple words of warning:
  9. 1. Docker containers do not have persistent storage. This means that any changes
  10. you make to files inside the container will not persist if you restart
  11. the container. When running through the tutorial,
  12. **do not close the container**.
  13. 2. To be able to deploy the [Android app](
  14. https://github.com/tensorflow/tensorflow/tree/master/tensorflow/lite/examples/android/app)
  15. (which you will build at the end of the tutorial),
  16. you will need to kill any instances of `adb` running on the host machine. You
  17. can accomplish this by closing all instances of Android Studio, and then
  18. running `adb kill-server`.
  19. You can install Docker by following the [instructions here](
  20. https://docs.docker.com/install/).
  21. ## Running The Container
  22. From this directory, build the Dockerfile as follows (this takes a while):
  23. ```
  24. docker build --tag detect-tf .
  25. ```
  26. Run the container:
  27. ```
  28. docker run --rm -it --privileged -p 6006:6006 detect-tf
  29. ```
  30. When running the container, you will find yourself inside the `/tensorflow`
  31. directory, which is the path to the TensorFlow [source
  32. tree](https://github.com/tensorflow/tensorflow).
  33. ## Text Editing
  34. The tutorial also
  35. requires you to occasionally edit files inside the source tree.
  36. This Docker images comes with `vim`, `nano`, and `emacs` preinstalled for your
  37. convenience.
  38. ## What's In This Container
  39. This container is derived from the nightly build of TensorFlow, and contains the
  40. sources for TensorFlow at `/tensorflow`, as well as the
  41. [TensorFlow Models](https://github.com/tensorflow/models) which are available at
  42. `/tensorflow/models` (and contain the Object Detection API as a subdirectory
  43. at `/tensorflow/models/research/object_detection`).
  44. The Oxford-IIIT Pets dataset, the COCO pre-trained SSD + MobileNet (v1)
  45. checkpoint, and example
  46. trained model are all available in `/tmp` in their respective folders.
  47. This container also has the `gsutil` and `gcloud` utilities, the `bazel` build
  48. tool, and all dependencies necessary to use the Object Detection API, and
  49. compile and install the TensorFlow Lite Android demo app.
  50. At various points throughout the tutorial, you may see references to the
  51. *research directory*. This refers to the `research` folder within the
  52. models repository, located at
  53. `/tensorflow/models/resesarch`.