{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "e7e4abc7",
   "metadata": {},
   "source": [
    "# Show the effective dim of different VQ models"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "429f5b44",
   "metadata": {},
   "source": [
    "## Download VQ models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "6155aab3",
   "metadata": {},
   "outputs": [],
   "source": [
    "## VQ GAN models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "90d8e9f1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--2025-04-30 15:51:36--  https://heibox.uni-heidelberg.de/f/140747ba53464f49b476/?dl=1\n",
      "Resolving heibox.uni-heidelberg.de (heibox.uni-heidelberg.de)... 129.206.7.113\n",
      "Connecting to heibox.uni-heidelberg.de (heibox.uni-heidelberg.de)|129.206.7.113|:443... connected.\n",
      "HTTP request sent, awaiting response... 302 Found\n",
      "Location: https://heibox.uni-heidelberg.de/seafhttp/files/198dc622-bc81-45ac-8e93-d88fb8bd594c/last.ckpt [following]\n",
      "--2025-04-30 15:51:37--  https://heibox.uni-heidelberg.de/seafhttp/files/198dc622-bc81-45ac-8e93-d88fb8bd594c/last.ckpt\n",
      "Reusing existing connection to heibox.uni-heidelberg.de:443.\n",
      "HTTP request sent, awaiting response... 200 OK\n",
      "Length: 957954257 (914M) [application/octet-stream]\n",
      "Saving to: ‘logs/vqgan_imagenet_f16_1024/checkpoints/last.ckpt’\n",
      "\n",
      "logs/vqgan_imagenet 100%[===================>] 913.58M  7.32MB/s    in 98s     \n",
      "\n",
      "2025-04-30 15:53:15 (9.36 MB/s) - ‘logs/vqgan_imagenet_f16_1024/checkpoints/last.ckpt’ saved [957954257/957954257]\n",
      "\n"
     ]
    }
   ],
   "source": [
    "!mkdir -p logs/vqgan_imagenet_f16_1024/checkpoints\n",
    "!wget 'https://heibox.uni-heidelberg.de/f/140747ba53464f49b476/?dl=1' -O 'logs/vqgan_imagenet_f16_1024/checkpoints/last.ckpt' "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "17700bb0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--2025-04-30 15:53:15--  https://heibox.uni-heidelberg.de/f/867b05fc8c4841768640/?dl=1\n",
      "Resolving heibox.uni-heidelberg.de (heibox.uni-heidelberg.de)... 129.206.7.113\n",
      "Connecting to heibox.uni-heidelberg.de (heibox.uni-heidelberg.de)|129.206.7.113|:443... connected.\n",
      "HTTP request sent, awaiting response... 302 Found\n",
      "Location: https://heibox.uni-heidelberg.de/seafhttp/files/d3058941-3ac6-4648-8a8f-2d9da83e820a/last.ckpt [following]\n",
      "--2025-04-30 15:53:16--  https://heibox.uni-heidelberg.de/seafhttp/files/d3058941-3ac6-4648-8a8f-2d9da83e820a/last.ckpt\n",
      "Reusing existing connection to heibox.uni-heidelberg.de:443.\n",
      "HTTP request sent, awaiting response... 200 OK\n",
      "Length: 980092370 (935M) [application/octet-stream]\n",
      "Saving to: ‘logs/vqgan_imagenet_f16_16384/checkpoints/last.ckpt’\n",
      "\n",
      "logs/vqgan_imagenet 100%[===================>] 934.69M  11.6MB/s    in 91s     \n",
      "\n",
      "2025-04-30 15:54:48 (10.2 MB/s) - ‘logs/vqgan_imagenet_f16_16384/checkpoints/last.ckpt’ saved [980092370/980092370]\n",
      "\n"
     ]
    }
   ],
   "source": [
    "!mkdir -p logs/vqgan_imagenet_f16_16384/checkpoints\n",
    "!wget 'https://heibox.uni-heidelberg.de/f/867b05fc8c4841768640/?dl=1' -O 'logs/vqgan_imagenet_f16_16384/checkpoints/last.ckpt' "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "63a7ab8d",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/authorname/miniconda3/envs/rotation_trick/lib/python3.8/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "\n",
    "def load_vqgan_codebook(ckpt_path):\n",
    "    # Load the VQGAN model\n",
    "    ckpt = torch.load(ckpt_path, map_location=\"cuda:0\")\n",
    "    return ckpt['state_dict']['quantize.embedding.weight']\n",
    "\n",
    "vqgan_imagenet_f16_1024 = load_vqgan_codebook(\"logs/vqgan_imagenet_f16_1024/checkpoints/last.ckpt\")\n",
    "vqgan_imagenet_f16_16384 = load_vqgan_codebook(\"logs/vqgan_imagenet_f16_16384/checkpoints/last.ckpt\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "9d612e43",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([1024, 256]), torch.Size([16384, 256]))"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "vqgan_imagenet_f16_1024.shape, vqgan_imagenet_f16_16384.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "94dc9c1b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# save to disk\n",
    "!mkdir -p codebooks\n",
    "torch.save(vqgan_imagenet_f16_1024, \"codebooks/vqgan_imagenet_f16_1024.pt\")\n",
    "torch.save(vqgan_imagenet_f16_16384, \"codebooks/vqgan_imagenet_f16_16384.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "b38152ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Residual VQ models\n",
    "# download from https://twg.kakaocdn.net/brainrepo/models/RQVAE/7518a004fe39120fcffbba76005dc6c3/imagenet_480M.tar.gz\n",
    "!mkdir -p logs/rqvae_imagenet_480M/checkpoints\n",
    "!cp ../../ckpt/imagenet_480M/stage1/model.pt logs/rqvae_imagenet_480M/checkpoints/model.ckpt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "491540a5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([16385, 256])"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def load_rqvae_codebook(ckpt_path):\n",
    "    # Load the VQGAN model\n",
    "    ckpt = torch.load(ckpt_path, map_location=\"cuda:0\")\n",
    "    return ckpt['state_dict']['quantizer.codebooks.0.weight']\n",
    "\n",
    "rqvae_imagenet_480M = load_rqvae_codebook(\"logs/rqvae_imagenet_480M/checkpoints/model.ckpt\")\n",
    "rqvae_imagenet_480M.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "ab73f7d1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# save to disk\n",
    "torch.save(rqvae_imagenet_480M, \"codebooks/rqvae_imagenet_480M.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9d1505da",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--2025-04-30 16:24:30--  https://huggingface.co/thuanz123/vitvqgan-imagenet-small/resolve/main/imagenet_vitvq_small.ckpt\n",
      "Resolving huggingface.co (huggingface.co)... 18.161.69.100, 18.161.69.98, 18.161.69.97, ...\n",
      "Connecting to huggingface.co (huggingface.co)|18.161.69.100|:443... connected.\n",
      "HTTP request sent, awaiting response... 302 Found\n",
      "Location: https://cdn-lfs-us-1.hf.co/repos/0f/69/0f690ef14674b2d061e78e219922e5fccca5a769c2e43abf986f013bfac45333/7ff4d8b9e1998a5f8f4b7b610685406513f2660ee9cb7078ea4e9efc6d340e82?response-content-disposition=inline%3B+filename*%3DUTF-8%27%27imagenet_vitvq_small.ckpt%3B+filename%3D%22imagenet_vitvq_small.ckpt%22%3B&Expires=1746019470&Policy=eyJTdGF0ZW1lbnQiOlt7IkNvbmRpdGlvbiI6eyJEYXRlTGVzc1RoYW4iOnsiQVdTOkVwb2NoVGltZSI6MTc0NjAxOTQ3MH19LCJSZXNvdXJjZSI6Imh0dHBzOi8vY2RuLWxmcy11cy0xLmhmLmNvL3JlcG9zLzBmLzY5LzBmNjkwZWYxNDY3NGIyZDA2MWU3OGUyMTk5MjJlNWZjY2NhNWE3NjljMmU0M2FiZjk4NmYwMTNiZmFjNDUzMzMvN2ZmNGQ4YjllMTk5OGE1ZjhmNGI3YjYxMDY4NTQwNjUxM2YyNjYwZWU5Y2I3MDc4ZWE0ZTllZmM2ZDM0MGU4Mj9yZXNwb25zZS1jb250ZW50LWRpc3Bvc2l0aW9uPSoifV19&Signature=Abili%7Esp-HND6%7EzN%7EBpa0-OA1be28Wmy19YrWSrRVHwF-Qw%7EDrMrORSvt7rFET3xQ4hFbN13siqupO2KD8EA--j%7EQX8owSz92uLKKLlODlePo1VQRvIDRV%7EjidhZIB4smi1tI5EF3w8bZcn0zvd8-Ofqi8xfvxtgzLRTGwE4YzUAw1CEEf1jJFhylKdj0tG7vud6ZWOI-%7EeCloG3fnKD%7E8lXiYvqxDMjrTrnKT-YRAX8XpqODDVrFKYJfk8m5tACXiHlSB-BgVp8c6oq7Mt3r-ISv5AMla0oArego5HoT0svS54T73n3KDJmP0nDcsdBLg5tS3J5g5xETyq1XXuPmg__&Key-Pair-Id=K24J24Z295AEI9 [following]\n",
      "--2025-04-30 16:24:30--  https://cdn-lfs-us-1.hf.co/repos/0f/69/0f690ef14674b2d061e78e219922e5fccca5a769c2e43abf986f013bfac45333/7ff4d8b9e1998a5f8f4b7b610685406513f2660ee9cb7078ea4e9efc6d340e82?response-content-disposition=inline%3B+filename*%3DUTF-8%27%27imagenet_vitvq_small.ckpt%3B+filename%3D%22imagenet_vitvq_small.ckpt%22%3B&Expires=1746019470&Policy=eyJTdGF0ZW1lbnQiOlt7IkNvbmRpdGlvbiI6eyJEYXRlTGVzc1RoYW4iOnsiQVdTOkVwb2NoVGltZSI6MTc0NjAxOTQ3MH19LCJSZXNvdXJjZSI6Imh0dHBzOi8vY2RuLWxmcy11cy0xLmhmLmNvL3JlcG9zLzBmLzY5LzBmNjkwZWYxNDY3NGIyZDA2MWU3OGUyMTk5MjJlNWZjY2NhNWE3NjljMmU0M2FiZjk4NmYwMTNiZmFjNDUzMzMvN2ZmNGQ4YjllMTk5OGE1ZjhmNGI3YjYxMDY4NTQwNjUxM2YyNjYwZWU5Y2I3MDc4ZWE0ZTllZmM2ZDM0MGU4Mj9yZXNwb25zZS1jb250ZW50LWRpc3Bvc2l0aW9uPSoifV19&Signature=Abili%7Esp-HND6%7EzN%7EBpa0-OA1be28Wmy19YrWSrRVHwF-Qw%7EDrMrORSvt7rFET3xQ4hFbN13siqupO2KD8EA--j%7EQX8owSz92uLKKLlODlePo1VQRvIDRV%7EjidhZIB4smi1tI5EF3w8bZcn0zvd8-Ofqi8xfvxtgzLRTGwE4YzUAw1CEEf1jJFhylKdj0tG7vud6ZWOI-%7EeCloG3fnKD%7E8lXiYvqxDMjrTrnKT-YRAX8XpqODDVrFKYJfk8m5tACXiHlSB-BgVp8c6oq7Mt3r-ISv5AMla0oArego5HoT0svS54T73n3KDJmP0nDcsdBLg5tS3J5g5xETyq1XXuPmg__&Key-Pair-Id=K24J24Z295AEI9\n",
      "Resolving cdn-lfs-us-1.hf.co (cdn-lfs-us-1.hf.co)... 108.139.60.75, 108.139.60.9, 108.139.60.119, ...\n",
      "Connecting to cdn-lfs-us-1.hf.co (cdn-lfs-us-1.hf.co)|108.139.60.75|:443... connected.\n",
      "HTTP request sent, awaiting response... 200 OK\n",
      "Length: 1020596002 (973M) [binary/octet-stream]\n",
      "Saving to: ‘logs/vitvqgan_imagenet/vitvqgan_imagenet_small.ckpt’\n",
      "\n",
      "logs/vitvqgan_image 100%[===================>] 973.32M  26.5MB/s    in 38s     \n",
      "\n",
      "2025-04-30 16:25:08 (25.7 MB/s) - ‘logs/vitvqgan_imagenet/vitvqgan_imagenet_small.ckpt’ saved [1020596002/1020596002]\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Download third-party implemented ViT-VQGAN\n",
    "!mkdir -p logs/vitvqgan_imagenet\n",
    "!wget https://huggingface.co/thuanz123/vitvqgan-imagenet-small/resolve/main/imagenet_vitvq_small.ckpt -O logs/vitvqgan_imagenet/imagenet_vitvq_small.ckpt\n",
    "!wget https://huggingface.co/thuanz123/vitvqgan-imagenet-base/resolve/main/imagenet_vitvq_base.ckpt -O logs/vitvqgan_imagenet/imagenet_vitvq_base.ckpt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "f55e7805",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "def load_vitvqgan_codebook(ckpt_path):\n",
    "    # Load the VQGAN model\n",
    "    ckpt = torch.load(ckpt_path, map_location=\"cuda:0\")\n",
    "    return ckpt['state_dict']['quantizer.embedding.weight']\n",
    "\n",
    "vitvqgan_imagenet_small = load_vitvqgan_codebook(\"logs/vitvqgan_imagenet/imagenet_vitvq_small.ckpt\")\n",
    "vitvqgan_imagenet_base = load_vitvqgan_codebook(\"logs/vitvqgan_imagenet/imagenet_vitvq_base.ckpt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "2c751cc9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([8192, 32]), torch.Size([8192, 32]))"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# save to disk\n",
    "torch.save(vqgan_imagenet_f16_1024, \"codebooks/vitvqgan_imagenet_small.pt\")\n",
    "torch.save(vqgan_imagenet_f16_16384, \"codebooks/vitvqgan_imagenet_base.pt\")\n",
    "vitvqgan_imagenet_small.shape, vitvqgan_imagenet_base.shape\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "58cf56ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Download MaskGIT\n",
    "!mkdir -p logs/maskgit\n",
    "!curl -L -o logs/maskgit/maskgit_256x256 https://storage.googleapis.com/maskgit-public/checkpoints/tokenizer_imagenet256_checkpoint\n",
    "!curl -L -o logs/maskgit/maskgit_512x512 https://storage.googleapis.com/maskgit-public/checkpoints/tokenizer_imagenet512_checkpoint"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b371af48",
   "metadata": {},
   "outputs": [],
   "source": [
    "# use jax to load the checkpoint\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "from flax.serialization import from_bytes\n",
    "\n",
    "def load_maskgit_codebook(ckpt_path):\n",
    "    # Load the MaskGIT model\n",
    "    with open(ckpt_path, \"rb\") as f:\n",
    "        ckpt = from_bytes(jnp.zeros((1, 1)), f.read())\n",
    "    return ckpt['params']['quantizer']['codebook']\n",
    "maskgit_256x256 = load_maskgit_codebook(\"logs/maskgit/maskgit_256x256\")\n",
    "maskgit_512x512 = load_maskgit_codebook(\"logs/maskgit/maskgit_512x512\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "27a252aa",
   "metadata": {},
   "outputs": [],
   "source": [
    "# save to disk\n",
    "\n",
    "# import numpy as np\n",
    "# np.save(\"codebooks/maskgit_256x256.npy\", maskgit_256x256)\n",
    "# np.save(\"codebooks/maskgit_512x512.npy\", maskgit_512x512)\n",
    "\n",
    "# import torch\n",
    "# import numpy as np\n",
    "# torch.save(np.load(\"codebooks/maskgit_256x256.npy\"), \"codebooks/maskgit_256x256.pt\")\n",
    "# torch.save(np.load(\"codebooks/maskgit_512x512.npy\"), \"codebooks/maskgit_512x512.pt\")\n",
    "\n",
    "torch.save(torch.from_numpy(maskgit_256x256), \"codebooks/maskgit_256x256.pt\")\n",
    "torch.save(torch.from_numpy(maskgit_512x512), \"codebooks/maskgit_512x512.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "d8231974",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "torch.save(torch.from_numpy(np.load(\"codebooks/maskgit_256x256.npy\")), \"codebooks/maskgit_256x256.pt\")\n",
    "torch.save(torch.from_numpy(np.load(\"codebooks/maskgit_512x512.npy\")), \"codebooks/maskgit_512x512.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3c38adac",
   "metadata": {},
   "outputs": [],
   "source": [
    "# video - VideoGPT\n",
    "\n",
    "# Create the cache directory if it doesn't exist\n",
    "# !mkdir -p logs/videogpt\n",
    "\n",
    "# Download all VQ-VAE models\n",
    "# !gdown --id 1iIAYJ2Qqrx5Q94s5eIXQYJgAydzvT_8L -O logs/videogpt/bair_stride4x2x2\n",
    "# !gdown --id 1uuB_8WzHP_bbBmfuaIV7PK_Itl3DyHY5 -O logs/videogpt/ucf101_stride4x4x4\n",
    "# !gdown --id 1DOvOZnFAIQmux6hG7pN_HkyJZy3lXbCB -O logs/videogpt/kinetics_stride4x4x4\n",
    "# !gdown --id 1jvtjjtrtE4cy6pl7DK_zWFEPY3RZt2pB -O logs/videogpt/kinetics_stride2x4x4\n",
    "\n",
    "# All failed\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1a7b2cac",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--2025-04-30 17:42:05--  https://huggingface.co/hpcai-tech/vqvae/resolve/main/model.safetensors\n",
      "Resolving huggingface.co (huggingface.co)... 18.161.69.98, 18.161.69.119, 18.161.69.100, ...\n",
      "Connecting to huggingface.co (huggingface.co)|18.161.69.98|:443... connected.\n",
      "HTTP request sent, awaiting response... 302 Found\n",
      "Location: https://cdn-lfs-us-1.hf.co/repos/0e/58/0e58ba2025664b6bb8224839737d751ba9757ed5f00949ef5aab79a9b8dbbe92/b9fda02bdef17ca1378a9392adc5b1d9692fa194ccaabff3b8352ce7548af0de?response-content-disposition=inline%3B+filename*%3DUTF-8%27%27model.safetensors%3B+filename%3D%22model.safetensors%22%3B&Expires=1746024126&Policy=eyJTdGF0ZW1lbnQiOlt7IkNvbmRpdGlvbiI6eyJEYXRlTGVzc1RoYW4iOnsiQVdTOkVwb2NoVGltZSI6MTc0NjAyNDEyNn19LCJSZXNvdXJjZSI6Imh0dHBzOi8vY2RuLWxmcy11cy0xLmhmLmNvL3JlcG9zLzBlLzU4LzBlNThiYTIwMjU2NjRiNmJiODIyNDgzOTczN2Q3NTFiYTk3NTdlZDVmMDA5NDllZjVhYWI3OWE5YjhkYmJlOTIvYjlmZGEwMmJkZWYxN2NhMTM3OGE5MzkyYWRjNWIxZDk2OTJmYTE5NGNjYWFiZmYzYjgzNTJjZTc1NDhhZjBkZT9yZXNwb25zZS1jb250ZW50LWRpc3Bvc2l0aW9uPSoifV19&Signature=g4wud-fbLjAwTmZumq%7EL0ZGS8BnTvwfn1TUkdDfBdIwaxok5qOJImEHzE2fQrXzfGi6LK7LdOZtpm1B%7E1B1MOWC2V0KK5%7EjTdYiozMLT7G0HHhB92i3kciEQV1DLdYtbzXezphNOvsg4UHl7JEmkaplxX1b90jre3RQdlf%7EMyImfUtNvPrA-a-tOvv2VfwlARwvkFozzYen9rlMP4tVbhTelHRpbhmwGmE4cNuX4pTDfAlT9XLfOGK0O6HVsFou%7Eq%7ELiaC40A4JGt0LCIvwVcTHfcBXeiZhH6kFZH2hb%7EHe96qkVCv5vhggA1gCt-gP4O90UxbHC%7EARq5HsNlQqzpg__&Key-Pair-Id=K24J24Z295AEI9 [following]\n",
      "--2025-04-30 17:42:06--  https://cdn-lfs-us-1.hf.co/repos/0e/58/0e58ba2025664b6bb8224839737d751ba9757ed5f00949ef5aab79a9b8dbbe92/b9fda02bdef17ca1378a9392adc5b1d9692fa194ccaabff3b8352ce7548af0de?response-content-disposition=inline%3B+filename*%3DUTF-8%27%27model.safetensors%3B+filename%3D%22model.safetensors%22%3B&Expires=1746024126&Policy=eyJTdGF0ZW1lbnQiOlt7IkNvbmRpdGlvbiI6eyJEYXRlTGVzc1RoYW4iOnsiQVdTOkVwb2NoVGltZSI6MTc0NjAyNDEyNn19LCJSZXNvdXJjZSI6Imh0dHBzOi8vY2RuLWxmcy11cy0xLmhmLmNvL3JlcG9zLzBlLzU4LzBlNThiYTIwMjU2NjRiNmJiODIyNDgzOTczN2Q3NTFiYTk3NTdlZDVmMDA5NDllZjVhYWI3OWE5YjhkYmJlOTIvYjlmZGEwMmJkZWYxN2NhMTM3OGE5MzkyYWRjNWIxZDk2OTJmYTE5NGNjYWFiZmYzYjgzNTJjZTc1NDhhZjBkZT9yZXNwb25zZS1jb250ZW50LWRpc3Bvc2l0aW9uPSoifV19&Signature=g4wud-fbLjAwTmZumq%7EL0ZGS8BnTvwfn1TUkdDfBdIwaxok5qOJImEHzE2fQrXzfGi6LK7LdOZtpm1B%7E1B1MOWC2V0KK5%7EjTdYiozMLT7G0HHhB92i3kciEQV1DLdYtbzXezphNOvsg4UHl7JEmkaplxX1b90jre3RQdlf%7EMyImfUtNvPrA-a-tOvv2VfwlARwvkFozzYen9rlMP4tVbhTelHRpbhmwGmE4cNuX4pTDfAlT9XLfOGK0O6HVsFou%7Eq%7ELiaC40A4JGt0LCIvwVcTHfcBXeiZhH6kFZH2hb%7EHe96qkVCv5vhggA1gCt-gP4O90UxbHC%7EARq5HsNlQqzpg__&Key-Pair-Id=K24J24Z295AEI9\n",
      "Resolving cdn-lfs-us-1.hf.co (cdn-lfs-us-1.hf.co)... 108.139.79.3, 108.139.79.98, 108.139.79.64, ...\n",
      "Connecting to cdn-lfs-us-1.hf.co (cdn-lfs-us-1.hf.co)|108.139.79.3|:443... connected.\n",
      "HTTP request sent, awaiting response... 200 OK\n",
      "Length: 88842260 (85M) [binary/octet-stream]\n",
      "Saving to: ‘logs/videogpt/model.safetensors’\n",
      "\n",
      "logs/videogpt/model 100%[===================>]  84.73M  24.4MB/s    in 3.5s    \n",
      "\n",
      "2025-04-30 17:42:10 (24.4 MB/s) - ‘logs/videogpt/model.safetensors’ saved [88842260/88842260]\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# downlaod hpcai-tech/vqvae from huggingface\n",
    "!mkdir -p logs/videogpt/\n",
    "!wget https://huggingface.co/hpcai-tech/vqvae/resolve/main/model.safetensors -O logs/videogpt/model.safetensors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8ea97f9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([2048, 256])"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from safetensors import safe_open\n",
    "import torch\n",
    "\n",
    "def load_videogpt_codebook(ckpt_path):\n",
    "    with safe_open(ckpt_path, framework=\"pt\") as f:\n",
    "        return f.get_tensor(\"codebook.embeddings\")\n",
    "videogpt = load_videogpt_codebook(\"logs/videogpt/model.safetensors\")\n",
    "videogpt.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "cc087333",
   "metadata": {},
   "outputs": [],
   "source": [
    "# save to disk\n",
    "torch.save(videogpt, \"codebooks/videogpt.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "54a67b5f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "env: CUDA_VISIBLE_DEVICES=1\n",
      "env: TOKENIZERS_PARALLELISM=false\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "import os\n",
    "\n",
    "%set_env CUDA_VISIBLE_DEVICES=1\n",
    "%set_env TOKENIZERS_PARALLELISM=false\n",
    "# huggingface/tokenizers: The current process just got forked, after parallelism has already been used. Disabling parallelism to avoid deadlocks...\n",
    "# To disable this warning, you can either:\n",
    "# \t- Avoid using `tokenizers` before the fork if possible\n",
    "# \t- Explicitly set the environment variable TOKENIZERS_PARALLELISM=(true | false)\n",
    "\n",
    "sys.path.append('/path-to-home/esm3/')\n",
    "\n",
    "import torch\n",
    "from esm.models.esm3 import ESM3\n",
    "\n",
    "def load_model(device=\"cpu\"):\n",
    "    model = ESM3.from_pretrained(\"esm3_sm_open_v1\", device=device)\n",
    "    structure_token_encoder = model.get_structure_token_encoder()\n",
    "    structure_tokenizer = model.tokenizers.structure\n",
    "    structure_decoder = model.get_structure_token_decoder()\n",
    "    del model\n",
    "    return (structure_token_encoder, structure_tokenizer, structure_decoder)\n",
    "\n",
    "(structure_token_encoder, structure_tokenizer, structure_decoder) = load_model(device=torch.device(\"cpu\"))\n",
    "codebook = structure_token_encoder.codebook.embeddings\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6856cd5f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# save to disk\n",
    "torch.save(codebook, \"codebooks/esm3.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e6efdd49",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import pickle\n",
    "# you need to download the codebook from https://colab.research.google.com/drive/15bBbfa7WigruoME089cSfE242K1MvRGz\n",
    "ckpt = \"/path-to-home/protoken/ProToken_Code_Book.pkl\"\n",
    "codebook = pickle.load(open(ckpt, \"rb\"))\n",
    "codebook = torch.tensor(codebook)\n",
    "# save to disk\n",
    "torch.save(codebook, \"codebooks/protoken.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0fbcac5c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import pickle\n",
    "# download data from https://zenodo.org/records/13901445\n",
    "# FT4 should mean foldtoken4\n",
    "# we can load embed_32, embed_256, or embed_4096\n",
    "ckpt = \"/path-to-home/esm3/foldtoken-effective-dim/model_zoom/FT4/embed_4096.pt\"\n",
    "codebook = torch.load(ckpt, map_location=\"cpu\")\n",
    "codebook\n",
    "# save to disk\n",
    "torch.save(codebook, \"codebooks/FT4_embed_4096.pt\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7f8372bf",
   "metadata": {},
   "source": [
    "## Get eff dim"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "a1761dcb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "@torch.amp.autocast(device_type=\"cuda\", enabled=False)\n",
    "def get_cum_var(data, eps=1e-4):\n",
    "    # data: [num_samples, num_features]\n",
    "    data = data.float()\n",
    "    N, D = data.shape\n",
    "    device = data.device\n",
    "    assert N >= D, f\"Number of samples must be greater than number of features. Got {N} samples and {D} features.\"\n",
    "    data = data - data.mean(dim=0, keepdim=True)\n",
    "    cov = data.T @ data / (N - 1)\n",
    "    eigvals, eigvecs = torch.linalg.eig(cov)\n",
    "    eigvals, eigvecs = eigvals.real, eigvecs.real\n",
    "\n",
    "    # sanity check\n",
    "    # if not torch.allclose(eigvecs @ eigvecs.T, torch.eye(D, device=device), atol=eps):\n",
    "    #     print(\n",
    "    #         f\"Warning: eigenvectors are not orthogonal: \"\n",
    "    #         f\"{torch.linalg.norm(eigvecs @ eigvecs.T - torch.eye(D, device=device))}\"\n",
    "    #     )\n",
    "\n",
    "    # The returned eigenvalues are not guaranteed to be in any specific order.\n",
    "    # Sort eigenvalues and eigenvectors\n",
    "    sorted_indices = torch.argsort(eigvals, descending=True)\n",
    "    eigvals = eigvals[sorted_indices]\n",
    "    eigvecs = eigvecs[:, sorted_indices]\n",
    "    # Compute explained variance\n",
    "    explained_var = eigvals / eigvals.sum()\n",
    "    cum_explained_var = explained_var.cumsum(dim=0)  # [D]\n",
    "    cum_explained_var = torch.cat([torch.tensor([0], device=device), cum_explained_var])  # [D+1]\n",
    "    return cum_explained_var\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "def get_effective_dim(data, thresh=0.99):\n",
    "    try:\n",
    "        cum_var = get_cum_var(data)\n",
    "        # get the first index where cum_var > thresh\n",
    "        eff_dim = torch.argmax((cum_var > thresh).long())\n",
    "        return float(eff_dim)\n",
    "    except Exception as e:\n",
    "        print(f\"Error: {e}\")\n",
    "        return float(\"nan\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "50a9e7e0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Effective dim for vqgan_imagenet_f16_1024: 4.0. Original shape: torch.Size([1024, 256]).\n",
      "Effective dim for vqgan_imagenet_f16_16384: 4.0. Original shape: torch.Size([16384, 256]).\n",
      "Effective dim for rqvae_imagenet_480M: 38.0. Original shape: torch.Size([16385, 256]).\n",
      "Effective dim for vitvqgan_imagenet_small: 4.0. Original shape: torch.Size([1024, 256]).\n",
      "Effective dim for vitvqgan_imagenet_base: 4.0. Original shape: torch.Size([16384, 256]).\n",
      "Effective dim for maskgit_256x256: 14.0. Original shape: torch.Size([1024, 256]).\n",
      "Effective dim for maskgit_512x512: 10.0. Original shape: torch.Size([1024, 256]).\n",
      "Effective dim for videogpt: 4.0. Original shape: torch.Size([2048, 256]).\n",
      "Effective dim for esm3: 26.0. Original shape: torch.Size([4096, 128]).\n",
      "Effective dim for protoken: 17.0. Original shape: torch.Size([512, 32]).\n",
      "Effective dim for FT4_embed_4096: 5.0. Original shape: torch.Size([4096, 32]).\n"
     ]
    }
   ],
   "source": [
    "for codebook in [\n",
    "    \"vqgan_imagenet_f16_1024\",\n",
    "    \"vqgan_imagenet_f16_16384\",\n",
    "    \"rqvae_imagenet_480M\",\n",
    "    \"vitvqgan_imagenet_small\",\n",
    "    \"vitvqgan_imagenet_base\",\n",
    "    \"maskgit_256x256\",\n",
    "    \"maskgit_512x512\",\n",
    "    \"videogpt\",\n",
    "    \"esm3\",\n",
    "    \"protoken\",\n",
    "    \"FT4_embed_4096\",\n",
    "]:\n",
    "    codebook_tensor = torch.load(f\"codebooks/{codebook}.pt\")\n",
    "    codebook_tensor = codebook_tensor.float()\n",
    "    print(f\"Effective dim for {codebook}: {get_effective_dim(codebook_tensor)}. Original shape: {codebook_tensor.shape}.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "df488092",
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "sns.set_context(\"paper\", font_scale=1.2)\n",
    "sns.set_style(\"whitegrid\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "968ea117",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fca97096730>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot curve\n",
    "for codebook in [\n",
    "    \"vqgan_imagenet_f16_1024\",\n",
    "    \"vqgan_imagenet_f16_16384\",\n",
    "    # \"rqvae_imagenet_480M\",\n",
    "    \"vitvqgan_imagenet_small\",\n",
    "    \"vitvqgan_imagenet_base\",\n",
    "    \"maskgit_256x256\",\n",
    "    \"maskgit_512x512\",\n",
    "    \"videogpt\",\n",
    "    \"esm3\",\n",
    "    \"protoken\",\n",
    "    \"FT4_embed_4096\",\n",
    "]:\n",
    "    codebook_tensor = torch.load(f\"codebooks/{codebook}.pt\")\n",
    "    codebook_tensor = codebook_tensor.float()\n",
    "    cum_var = get_cum_var(codebook_tensor)\n",
    "    plt.plot(np.arange(1, len(cum_var) + 1), cum_var.cpu().numpy(), label=codebook)\n",
    "plt.xlabel(\"Dimension\")\n",
    "plt.ylabel(\"Cumulative explained variance\")\n",
    "plt.title(\"Cumulative explained variance for different codebooks\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "6c12c59a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 350x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "# Load codebook\n",
    "codebook_name = \"vqgan_imagenet_f16_16384\"\n",
    "codebook_tensor = torch.load(f\"codebooks/{codebook_name}.pt\").float()\n",
    "\n",
    "# Compute cumulative explained variance\n",
    "cum_var = get_cum_var(codebook_tensor)  # This should return a 1D torch.Tensor\n",
    "\n",
    "plt.figure(figsize=(3.5, 3))  # Small size for inset-style placement\n",
    "sns.lineplot(x=np.arange(1, len(cum_var) + 1), y=cum_var.cpu().numpy(), marker=\"o\", linewidth=1.5, markeredgecolor=\"none\", markersize=3)\n",
    "eff_dim = int(get_effective_dim(codebook_tensor))\n",
    "# plt.text(eff_dim + 5, 0.93, \"Effective dimension ≈ 4 (99% variance)\", fontsize=9, color=\"grey\")\n",
    "# Add annotation with arrow\n",
    "plt.annotate(\n",
    "    \"Effective dim ≈ 4\\n(explains 99% of variance)\",\n",
    "    xy=(eff_dim, cum_var[eff_dim]),\n",
    "    xytext=(eff_dim + 20, cum_var[eff_dim] - 0.5),\n",
    "    textcoords=\"data\",\n",
    "    fontsize=11,\n",
    "    color=\"gray\",\n",
    "    arrowprops=dict(arrowstyle=\"->\", color=\"gray\", lw=1)\n",
    ")\n",
    "\n",
    "plt.xlabel(\"Principal Components\", fontsize=12)\n",
    "plt.ylabel(\"Cumulative Variance\", fontsize=12)\n",
    "plt.title(\"Explained Variance (VQGAN)\", fontsize=12)\n",
    "plt.xticks(fontsize=10)\n",
    "plt.yticks(fontsize=10)\n",
    "plt.tight_layout()\n",
    "plt.grid(True)\n",
    "plt.savefig(\"cumvar_vqgan16384.pdf\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "1f8523d1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# background dim vs effective dim\n",
    "import pandas as pd\n",
    "\n",
    "df = []\n",
    "for codebook in [\n",
    "    \"vqgan_imagenet_f16_1024\",\n",
    "    \"vqgan_imagenet_f16_16384\",\n",
    "    \"rqvae_imagenet_480M\",\n",
    "    \"vitvqgan_imagenet_small\",\n",
    "    \"vitvqgan_imagenet_base\",\n",
    "    \"maskgit_256x256\",\n",
    "    \"maskgit_512x512\",\n",
    "    \"videogpt\",\n",
    "    \"esm3\",\n",
    "    \"protoken\",\n",
    "    \"FT4_embed_4096\",\n",
    "]:\n",
    "    codebook_tensor = torch.load(f\"codebooks/{codebook}.pt\")\n",
    "    codebook_tensor = codebook_tensor.float()\n",
    "    eff_dim = int(get_effective_dim(codebook_tensor))\n",
    "    df.append({\n",
    "        \"codebook\": codebook,\n",
    "        \"effective_dim\": eff_dim,\n",
    "        \"background_dim\": codebook_tensor.shape[1],\n",
    "    })\n",
    "df = pd.DataFrame(df)\n",
    "\n",
    "# rename codebook\n",
    "rename = {\n",
    "    \"vqgan_imagenet_f16_1024\": \"VQGAN-1024\",\n",
    "    \"vqgan_imagenet_f16_16384\": \"VQGAN-16384\",\n",
    "    \"rqvae_imagenet_480M\": \"RQVAE\",\n",
    "    \"vitvqgan_imagenet_small\": \"ViT-VQGAN-Small\",\n",
    "    \"vitvqgan_imagenet_base\": \"ViT-VQGAN-Base\",\n",
    "    \"maskgit_256x256\": \"MaskGIT-256\",\n",
    "    \"maskgit_512x512\": \"MaskGIT-512\",\n",
    "    \"videogpt\": \"VideoGPT\",\n",
    "    \"esm3\": \"ESM3\",\n",
    "    \"protoken\": \"ProToken\",\n",
    "    \"FT4_embed_4096\": \"FoldToken\"\n",
    "}\n",
    "\n",
    "df[\"codebook\"] = df[\"codebook\"].replace(rename)\n",
    "# add my own model\n",
    "df = pd.concat([\n",
    "    df,\n",
    "    pd.DataFrame({\n",
    "        \"codebook\": [\"DCVQ (32d)\", \"DCVQ (64d)\", \"DCVQ (128d)\", \"DCVQ (256d)\"],\n",
    "        \"effective_dim\": [18, 28, 48, 80],\n",
    "        \"background_dim\": [32, 64, 128, 256],\n",
    "    })\n",
    "], ignore_index=True)\n",
    "df[\"Type\"] = df[\"codebook\"].apply(lambda x: \"DCVQ (Ours)\" if \"DCVQ\" in x else \"Vanilla VQVAE\")\n",
    "# for RQVAE, type set to RQVAE\n",
    "df.loc[df[\"codebook\"] == \"RQVAE\", \"Type\"] = \"RQVAE\"\n",
    "df[\"Modality\"] = (\n",
    "    [\"Image\"] * 7 + [\"Video\"] + [\"Protein\"] * 3 + [\"Image\"] * 4\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "3b04f9e8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>codebook</th>\n",
       "      <th>effective_dim</th>\n",
       "      <th>background_dim</th>\n",
       "      <th>Type</th>\n",
       "      <th>Modality</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>VQGAN-1024</td>\n",
       "      <td>4</td>\n",
       "      <td>256</td>\n",
       "      <td>Vanilla VQVAE</td>\n",
       "      <td>Image</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>VQGAN-16384</td>\n",
       "      <td>4</td>\n",
       "      <td>256</td>\n",
       "      <td>Vanilla VQVAE</td>\n",
       "      <td>Image</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>RQVAE</td>\n",
       "      <td>38</td>\n",
       "      <td>256</td>\n",
       "      <td>RQVAE</td>\n",
       "      <td>Image</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>ViT-VQGAN-Small</td>\n",
       "      <td>4</td>\n",
       "      <td>256</td>\n",
       "      <td>Vanilla VQVAE</td>\n",
       "      <td>Image</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>ViT-VQGAN-Base</td>\n",
       "      <td>4</td>\n",
       "      <td>256</td>\n",
       "      <td>Vanilla VQVAE</td>\n",
       "      <td>Image</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>MaskGIT-256</td>\n",
       "      <td>14</td>\n",
       "      <td>256</td>\n",
       "      <td>Vanilla VQVAE</td>\n",
       "      <td>Image</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>MaskGIT-512</td>\n",
       "      <td>10</td>\n",
       "      <td>256</td>\n",
       "      <td>Vanilla VQVAE</td>\n",
       "      <td>Image</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>VideoGPT</td>\n",
       "      <td>4</td>\n",
       "      <td>256</td>\n",
       "      <td>Vanilla VQVAE</td>\n",
       "      <td>Video</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>ESM3</td>\n",
       "      <td>26</td>\n",
       "      <td>128</td>\n",
       "      <td>Vanilla VQVAE</td>\n",
       "      <td>Protein</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>ProToken</td>\n",
       "      <td>17</td>\n",
       "      <td>32</td>\n",
       "      <td>Vanilla VQVAE</td>\n",
       "      <td>Protein</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>FoldToken</td>\n",
       "      <td>5</td>\n",
       "      <td>32</td>\n",
       "      <td>Vanilla VQVAE</td>\n",
       "      <td>Protein</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>DCVQ (32d)</td>\n",
       "      <td>18</td>\n",
       "      <td>32</td>\n",
       "      <td>DCVQ (Ours)</td>\n",
       "      <td>Image</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>DCVQ (64d)</td>\n",
       "      <td>28</td>\n",
       "      <td>64</td>\n",
       "      <td>DCVQ (Ours)</td>\n",
       "      <td>Image</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>DCVQ (128d)</td>\n",
       "      <td>48</td>\n",
       "      <td>128</td>\n",
       "      <td>DCVQ (Ours)</td>\n",
       "      <td>Image</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>DCVQ (256d)</td>\n",
       "      <td>80</td>\n",
       "      <td>256</td>\n",
       "      <td>DCVQ (Ours)</td>\n",
       "      <td>Image</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "           codebook  effective_dim  background_dim           Type Modality\n",
       "0        VQGAN-1024              4             256  Vanilla VQVAE    Image\n",
       "1       VQGAN-16384              4             256  Vanilla VQVAE    Image\n",
       "2             RQVAE             38             256          RQVAE    Image\n",
       "3   ViT-VQGAN-Small              4             256  Vanilla VQVAE    Image\n",
       "4    ViT-VQGAN-Base              4             256  Vanilla VQVAE    Image\n",
       "5       MaskGIT-256             14             256  Vanilla VQVAE    Image\n",
       "6       MaskGIT-512             10             256  Vanilla VQVAE    Image\n",
       "7          VideoGPT              4             256  Vanilla VQVAE    Video\n",
       "8              ESM3             26             128  Vanilla VQVAE  Protein\n",
       "9          ProToken             17              32  Vanilla VQVAE  Protein\n",
       "10        FoldToken              5              32  Vanilla VQVAE  Protein\n",
       "11       DCVQ (32d)             18              32    DCVQ (Ours)    Image\n",
       "12       DCVQ (64d)             28              64    DCVQ (Ours)    Image\n",
       "13      DCVQ (128d)             48             128    DCVQ (Ours)    Image\n",
       "14      DCVQ (256d)             80             256    DCVQ (Ours)    Image"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "bc78ec6c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 450x450 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from adjustText import adjust_text\n",
    "\n",
    "df_jittered = df.copy()\n",
    "df_jittered[\"background_dim\"] = df_jittered[\"background_dim\"].astype(float)\n",
    "df_jittered[\"effective_dim\"] = df_jittered[\"effective_dim\"].astype(float)\n",
    "jitter_mask = (df_jittered[\"background_dim\"] == 256) & (df_jittered[\"effective_dim\"] == 4)\n",
    "n_jitter = jitter_mask.sum()\n",
    "jitter_strength = 4  # Adjust as needed\n",
    "# Apply jitter only to the specified points\n",
    "list_of_noise = np.linspace(-jitter_strength, jitter_strength, n_jitter)\n",
    "# add noise to background_dim and effective_dim\n",
    "df_jittered.loc[jitter_mask, \"background_dim\"] += list_of_noise\n",
    "\n",
    "\n",
    "sns.set_context(\"paper\", font_scale=1.2)\n",
    "sns.set_style(\"whitegrid\")\n",
    "\n",
    "plt.figure(figsize=(4.5, 4.5))  # Small size for inset-style placement\n",
    "ax = plt.gca()\n",
    "\n",
    "# Use only 'codebook' for hue, no different marker styles\n",
    "sns.scatterplot(\n",
    "    data=df_jittered,\n",
    "    x=\"background_dim\",\n",
    "    y=\"effective_dim\",\n",
    "    hue=\"Type\",\n",
    "    style=\"Modality\",\n",
    "    s=30,\n",
    "    palette=\"Set2\",\n",
    "    edgecolor=\"black\",\n",
    "    ax=ax,\n",
    ")\n",
    "\n",
    "palette = sns.color_palette(\"Set2\")\n",
    "ours_color = palette[2]  # Assuming 'Ours' is the first color in the palette\n",
    "sns.lineplot(\n",
    "    data=df_jittered[df_jittered[\"Type\"] == \"DCVQ (Ours)\"],\n",
    "    x=\"background_dim\",\n",
    "    y=\"effective_dim\",\n",
    "    linewidth=1.5,\n",
    "    linestyle=\"-\",\n",
    "    ax=ax,\n",
    "    color=ours_color\n",
    ")\n",
    "\n",
    "# Add codebook names to the points\n",
    "texts = []\n",
    "for i, row in df_jittered.iterrows():\n",
    "    text = plt.text(\n",
    "        row[\"background_dim\"] + 5,\n",
    "        row[\"effective_dim\"] - 0.5,\n",
    "        row[\"codebook\"],\n",
    "        fontsize=8,\n",
    "        color=\"black\",\n",
    "        ha=\"left\",\n",
    "        va=\"top\"\n",
    "    )\n",
    "    texts.append(text)\n",
    "adjust_text(texts, arrowprops=dict(arrowstyle=\"-\", color='gray', lw=0.5), ax=ax)\n",
    "ax.legend(loc=\"upper left\", fontsize=10, title_fontsize=12, ncol=2)\n",
    "\n",
    "plt.xlabel(\"Background Dim\", fontsize=14)\n",
    "plt.ylabel(\"Effective Dim\", fontsize=14)\n",
    "plt.grid(True)\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"background_dim_vs_effective_dim.pdf\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4ff646b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8287d73c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d8aea558",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b0e907b0",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "rotation_trick",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
