GitXplorerGitXplorer
p

moco.tensorflow

public
161 stars
13 forks
0 issues

Commits

List of commits on branch master.
Unverified
e3050d425609f2dd46f9c3405463b89d24674c18

Add KNN eval

pppwwyyxx committed 4 years ago
Verified
e05687a9674e3e1852daa2188478c6124b367529

Update README.md

pppwwyyxx committed 4 years ago
Unverified
b986703a7a7a168e65788175eb11f5d68f9f38d4

update

pppwwyyxx committed 5 years ago
Unverified
efc8fcaebbe7faffc99b8f81f2af96b13ed5cd18

use augmentation from tensorpack

pppwwyyxx committed 5 years ago
Unverified
433f89e65b16ff929ad645c806ad1622a38b2e5d

update docs

pppwwyyxx committed 5 years ago
Unverified
f348e6c963378f36a7c985b8bbe7669d39a1b293

fix missing param

pppwwyyxx committed 5 years ago

README

The README file for this repository.

Implement and reproduce results of the following papers:

Dependencies:

  • TensorFlow 1.14 or 1.15, built with XLA support
  • Tensorpack ≥ 0.10.1
  • Horovod ≥ 0.19 built with Gloo & NCCL support
  • TensorFlow zmq_ops
  • OpenCV
  • the taskset command (from the util-linux package)

Unsupervised Training:

To run MoCo pre-training on a machine with 8 GPUs, use:

horovodrun -np 8 --output-filename moco.log python main_moco.py --data /path/to/imagenet

Add --v2 to train MoCov2, which uses an extra MLP layer, extra augmentations, and cosine LR schedule.

Linear Classification:

To train a linear classifier using the pre-trained features, run:

./main_lincls.py --load /path/to/pretrained/checkpoint --data /path/to/imagenet

KNN Evaluation:

Instead of Linear Classification, a cheap but rough evaluation is to perform a feature-space kNN using the training set:

horovodrun -np 8 ./eval_knn.py --load /path/to/checkpoint --data /path/to/imagenet --top-k 200

Results:

Training was done in a machine with 8 V100s, >200GB RAM and 80 CPUs.

Following results are obtained after 200 epochs of pre-training (~53h) and 100 epochs of linear classifier tuning (~8h). KNN evaluation takes 10min per checkpoint.

linear cls.
accuracy
download
(pretrained only)
tensorboard
MoCo v1 60.9% ⬇️ N/A
MoCo v2 67.7% ⬇️ pretrain; finetune

Notes:

  • Horovod with Gloo is recommended. Horovod with MPI is not tested and may crash due to how we use forking.
  • If using TensorFlow without XLA support, you can modify main_*.py to replace xla.compile by a naive forward.
  • Official PyTorch code is at facebookresearch/moco.