{
  "metadata": {
    "forum_id": "rJehVyrKwH",
    "review_id": "ryegpfeaYS",
    "rebuttal_id": "SJlzQjkXjB",
    "title": "And the Bit Goes Down: Revisiting the Quantization of Neural Networks",
    "reviewer": "AnonReviewer2",
    "rating": 8,
    "conference": "ICLR2020",
    "permalink": "https://openreview.net/forum?id=rJehVyrKwH&noteId=SJlzQjkXjB",
    "annotator": "anno10"
  },
  "review_sentences": [
    {
      "review_id": "ryegpfeaYS",
      "sentence_index": 0,
      "text": "This paper suggests a quantization approach for neural networks, based on the Product Quantization (PQ) algorithm which has been successful in quantization for similarity search.",
      "suffix": "",
      "review_action": "arg_structuring",
      "fine_review_action": "arg-structuring_heading",
      "aspect": "none",
      "polarity": "none"
    },
    {
      "review_id": "ryegpfeaYS",
      "sentence_index": 1,
      "text": "The basic idea is to quantize the weights of a neuron/single layer with a variant of PQ, which is modified to optimize the quantization error of inner products of sample inputs with the weights, rather than the weights themselves.",
      "suffix": "",
      "review_action": "arg_structuring",
      "fine_review_action": "arg-structuring_heading",
      "aspect": "none",
      "polarity": "none"
    },
    {
      "review_id": "ryegpfeaYS",
      "sentence_index": 2,
      "text": "This is cast as a weighted variant of k-means.",
      "suffix": "",
      "review_action": "arg_structuring",
      "fine_review_action": "arg-structuring_heading",
      "aspect": "none",
      "polarity": "none"
    },
    {
      "review_id": "ryegpfeaYS",
      "sentence_index": 3,
      "text": "The inner product is more directly related to the network output (though still does not account for non-linear neuron activations) and thus is expected to yield better downstream performance, and only requires introducing unlabeled input samples into the quantization process.",
      "suffix": "",
      "review_action": "arg_structuring",
      "fine_review_action": "arg-structuring_heading",
      "aspect": "none",
      "polarity": "none"
    },
    {
      "review_id": "ryegpfeaYS",
      "sentence_index": 4,
      "text": "This approach is built into a pipeline that gradually quantizes the entire network.",
      "suffix": "\n\n",
      "review_action": "arg_structuring",
      "fine_review_action": "arg-structuring_heading",
      "aspect": "none",
      "polarity": "none"
    },
    {
      "review_id": "ryegpfeaYS",
      "sentence_index": 5,
      "text": "Overall, I support the paper and recommend acceptance.",
      "suffix": "",
      "review_action": "arg_evaluative",
      "fine_review_action": "none",
      "aspect": "asp_motivation-impact",
      "polarity": "pol_positive"
    },
    {
      "review_id": "ryegpfeaYS",
      "sentence_index": 6,
      "text": "PQ is known to be successful for quantization in other contexts, and the specialization suggested here for neural networks is natural and well-motivated.",
      "suffix": "",
      "review_action": "arg_evaluative",
      "fine_review_action": "none",
      "aspect": "asp_motivation-impact",
      "polarity": "pol_positive"
    },
    {
      "review_id": "ryegpfeaYS",
      "sentence_index": 7,
      "text": "The method can be expected to perform well empirically, which the experiments verify, and to have potential impact.",
      "suffix": "\n\n",
      "review_action": "arg_evaluative",
      "fine_review_action": "none",
      "aspect": "asp_substance",
      "polarity": "pol_positive"
    },
    {
      "review_id": "ryegpfeaYS",
      "sentence_index": 8,
      "text": "Questions:",
      "suffix": "\n",
      "review_action": "arg_structuring",
      "fine_review_action": "arg-structuring_heading",
      "aspect": "none",
      "polarity": "none"
    },
    {
      "review_id": "ryegpfeaYS",
      "sentence_index": 9,
      "text": "1. Can you comment on the quantization time of the suggested method? Repeatedly solving the EM steps can add up to quite an overhead.",
      "suffix": "",
      "review_action": "arg_request",
      "fine_review_action": "arg-request_explanation",
      "aspect": "asp_substance",
      "polarity": "pol_negative"
    },
    {
      "review_id": "ryegpfeaYS",
      "sentence_index": 10,
      "text": "Does it pose a difficulty? How does it compare to other methods?",
      "suffix": "\n",
      "review_action": "arg_request",
      "fine_review_action": "arg-request_explanation",
      "aspect": "asp_substance",
      "polarity": "none"
    },
    {
      "review_id": "ryegpfeaYS",
      "sentence_index": 11,
      "text": "2. Can you elaborate on the issue of non-linearity? It is mentioned only briefly in the conclusion. What is the difficulty in incorporating it? Is it in solving equation (4)? And perhaps, how do you expect it to effect the results?",
      "suffix": "",
      "review_action": "arg_request",
      "fine_review_action": "arg-request_explanation",
      "aspect": "asp_substance",
      "polarity": "none"
    }
  ],
  "rebuttal_sentences": [
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 0,
      "text": "We thank Reviewer 2 for their support and questions.",
      "suffix": "",
      "rebuttal_stance": "nonarg",
      "rebuttal_action": "rebuttal_social",
      "alignment": [
        "context_global",
        null
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 1,
      "text": "We answer them below.",
      "suffix": "\n\n",
      "rebuttal_stance": "nonarg",
      "rebuttal_action": "rebuttal_structuring",
      "alignment": [
        "context_in-rebuttal",
        null
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 2,
      "text": "Quantization time",
      "suffix": "\n",
      "rebuttal_stance": "nonarg",
      "rebuttal_action": "rebuttal_structuring",
      "alignment": [
        "context_in-rebuttal",
        null
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 3,
      "text": "As we state in our paper, quantizing a ResNet-50 (quantization + finetuning steps) takes about one day on one Volta V100 GPU.",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          9
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 4,
      "text": "The time of quantization is around 1 to 2 hours, the rest being dedicated to finetuning.",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          9
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 5,
      "text": "Thus, the time dedicated to quantization is relatively short, especially compared with the fine-tuning and even more with the initial network training.",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          9
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 6,
      "text": "This is because we optimized our EM implementation in at least two ways as detailed below.",
      "suffix": "\n",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          9,
          10
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 7,
      "text": "-\tThe E-step is performed on the GPU (see file src/quantization/distance.py, lines 61-75) with automatic chunking.",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          9,
          10
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 8,
      "text": "This means that the code chunks the centroids and the weight matrices into blocks, performs the distance computation on those blocks and aggregates the results.",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          9,
          10
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 9,
      "text": "This falls within the map/reduce paradigm.",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          9,
          10
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 10,
      "text": "Note that the blocks are automatically calculated to be the largest that fit into the GPU, such that the utilization of the GPU is maximized, so as to minimize the compute time.",
      "suffix": "\n",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          9,
          10
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 11,
      "text": "-\tThe M-step involves calculating a solution of a least squares problem (see footnote 2 in our paper).",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          9,
          10
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 12,
      "text": "The bottleneck for this is to calculate the pseudo-inverse of the activations x. However, we fix x when iterating our EM algorithm, therefore we can factor the computation of the pseudo inverse of x before alternating between the E and the M steps (see file src/quantization/solver.py and in particular the docstring).",
      "suffix": "\n\n",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          9,
          10
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 13,
      "text": "We provided pointers to the files in the code anonymously shared on OpenReview.",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          9,
          10
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 14,
      "text": "To our knowledge, these implementation strategies are novel in this context and were key in the development of our method to be able to iterate rapidly.",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          9,
          10
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 15,
      "text": "Both strategies are documented in the code so that they can benefit to the community.",
      "suffix": "\n\n",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          9,
          10
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 16,
      "text": "Incorporating the non-linearity",
      "suffix": "\n",
      "rebuttal_stance": "nonarg",
      "rebuttal_action": "rebuttal_structuring",
      "alignment": [
        "context_in-rebuttal",
        null
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 17,
      "text": "As the Reviewer rightfully stated, optimally we should take the non-linearity in Equation (4) into account.",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          11
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 18,
      "text": "One could hope for a higher compression ratio.",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          11
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 19,
      "text": "Indeed, the approximation constraint on the positive outputs would stay the same (they have to be close to the original outputs).",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          11
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 20,
      "text": "On the other hand, the only constraint lying on the negative outputs is that they should remain negative (with a possible margin), but not necessarily close to the original negative outputs.",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          11
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 21,
      "text": "However, our early experiments with this method resulted in a rather unstable EM algorithm.",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          11
        ]
      ],
      "details": {}
    },
    {
      "review_id": "ryegpfeaYS",
      "rebuttal_id": "SJlzQjkXjB",
      "sentence_index": 22,
      "text": "This direction may deserve further investigation.",
      "suffix": "",
      "rebuttal_stance": "concur",
      "rebuttal_action": "rebuttal_answer",
      "alignment": [
        "context_sentences",
        [
          11
        ]
      ],
      "details": {}
    }
  ]
}