Restructuring Vector Quantization with the Rotation Trick
Christopher Fifty, Ronald G. Junkins, Dennis Duan, Aniketh Iyengar, Jerry W. Liu, Ehsan Amid, Sebastian Thrun, Christopher Ré
TL;DR
This work tackles the non-differentiability of vector quantization in VQ-VAEs by introducing the rotation trick, which propagates gradients through the quantization layer via a rotation and scaling that align encoder outputs with their nearest codebook vectors. By treating the rotation and scaling as constants during backpropagation, the method preserves angular information in gradients, enabling more informative updates within Voronoi regions. Across 11 diverse VQ-based configurations, the rotation trick consistently improves reconstruction metrics and codebook utilization while reducing quantization error, outperforming STE and some gradient-augmentation baselines. The approach is practical for improving lossy compression performance in discrete latent representations and is accompanied by efficient implementation via Householder reflections, with code available for reproducibility.
Abstract
Vector Quantized Variational AutoEncoders (VQ-VAEs) are designed to compress a continuous input to a discrete latent space and reconstruct it with minimal distortion. They operate by maintaining a set of vectors -- often referred to as the codebook -- and quantizing each encoder output to the nearest vector in the codebook. However, as vector quantization is non-differentiable, the gradient to the encoder flows around the vector quantization layer rather than through it in a straight-through approximation. This approximation may be undesirable as all information from the vector quantization operation is lost. In this work, we propose a way to propagate gradients through the vector quantization layer of VQ-VAEs. We smoothly transform each encoder output into its corresponding codebook vector via a rotation and rescaling linear transformation that is treated as a constant during backpropagation. As a result, the relative magnitude and angle between encoder output and codebook vector becomes encoded into the gradient as it propagates through the vector quantization layer and back to the encoder. Across 11 different VQ-VAE training paradigms, we find this restructuring improves reconstruction metrics, codebook utilization, and quantization error. Our code is available at https://github.com/cfifty/rotation_trick.
