{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "33aaec0d-3499-447d-ba03-679e4425329a",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/richard/miniconda3/envs/dl_env/lib/python3.12/site-packages/albumentations/__init__.py:24: UserWarning: A new version of Albumentations is available: 2.0.4 (you have 1.4.23). Upgrade using: pip install -U albumentations. To disable automatic update checks, set the environment variable NO_ALBUMENTATIONS_UPDATE to 1.\n",
      "  check_for_updates()\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "import os\n",
    "SCRIPT_DIR = os.path.dirname(os.path.abspath(\".\"))\n",
    "sys.path.append(SCRIPT_DIR)\n",
    "import helper\n",
    "from utils import data_utils\n",
    "import matplotlib.pyplot as plt\n",
    "from utils import training_utils\n",
    "from utils import data_utils\n",
    "import torch\n",
    "from model import models\n",
    "import json\n",
    "import os\n",
    "from model import lightning_models\n",
    "import math\n",
    "from torchvision import datasets\n",
    "import analysis_utils\n",
    "import numpy as np\n",
    "import random\n",
    "from sklearn.manifold import TSNE\n",
    "from sklearn.preprocessing import MinMaxScaler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "79ffaa5d-4bbf-46b4-902e-227ea0218b58",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_views = 1\n",
    "batch_size = 4\n",
    "model_dir = \"../traning/lr_3.0\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "76c75285-9edc-4d82-bbaa-ca72489a61c8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading default settings...\n",
      "[INFO]does not exist in the config file\n",
      "[DATA]does not exist in the config file\n",
      "[SSL]does not exist in the config file\n",
      "[LC]does not exist in the config file\n",
      "[SemiSL]does not exist in the config file\n",
      "[TL]does not exist in the config file\n",
      "[SemiSL]does not exist in the config file\n",
      "[TL]does not exist in the config file\n",
      "[INFO]\n",
      "num_nodes = 2\n",
      "gpus_per_node = 4\n",
      "cpus_per_gpu = 12\n",
      "prefetch_factor = 2\n",
      "precision = 16-mixed\n",
      "fix_random_seed = True\n",
      "strategy = ddp\n",
      "if_profile = False\n",
      "\n",
      "[DATA]\n",
      "dataset = IMAGENET1K-30percent\n",
      "n_views = 8\n",
      "augmentation_package = albumentations\n",
      "augmentations = ['RandomResizedCrop', 'GaussianBlur', 'RandomGrayscale', 'ColorJitter', 'RandomHorizontalFlip', 'RandomSolarize']\n",
      "crop_size = 224\n",
      "crop_min_scale = 0.08\n",
      "crop_max_scale = 1.0\n",
      "hflip_prob = 0.5\n",
      "blur_kernel_size = 23\n",
      "blur_prob = 0.5\n",
      "grayscale_prob = 0.2\n",
      "jitter_brightness = 0.8\n",
      "jitter_contrast = 0.8\n",
      "jitter_saturation = 0.8\n",
      "jitter_hue = 0.2\n",
      "jitter_prob = 0.8\n",
      "solarize_prob = 0.0\n",
      "imagenet_train_dir = /imagenet/train\n",
      "imagenet_val_dir = /imagenet/val\n",
      "\n",
      "[SSL]\n",
      "backbone = resnet50\n",
      "use_projection_head = True\n",
      "proj_dim = [8192, 8192]\n",
      "proj_out_dim = 512\n",
      "optimizer = LARS\n",
      "lr = 3.0\n",
      "lr_scale = linear\n",
      "lr_scheduler = cosine-warmup\n",
      "grad_accumulation_steps = 1\n",
      "momentum = 0.0\n",
      "weight_decay = 1e-05\n",
      "lars_eta = 0.001\n",
      "loss_function = RepulsiveEllipsoidPackingLossUnitNorm\n",
      "lw0 = 0.0\n",
      "lw1 = 1.0\n",
      "lw2 = 0.0\n",
      "max_mem_size = 0\n",
      "rs = 7.0\n",
      "pot_pow = 2.0\n",
      "max_grad_norm = -1.0\n",
      "warmup_epochs = 10\n",
      "n_epochs = 100\n",
      "batch_size = 800\n",
      "save_every_n_epochs = 10\n",
      "restart_training = False\n",
      "\n",
      "[LC]\n",
      "output_dim = 1000\n",
      "optimizer = SGD\n",
      "use_batch_norm = False\n",
      "lr_sweep = [0.6, 0.1]\n",
      "lr_scale = linear\n",
      "lr_scheduler = cosine\n",
      "weight_decay = 1e-06\n",
      "momentum = 0.9\n",
      "loss_function = CrossEntropyLoss\n",
      "n_epochs = 100\n",
      "batch_size = 1024\n",
      "save_every_n_epochs = 50\n",
      "apply_simple_augmentations = True\n",
      "standardize_to_imagenet = True\n",
      "restart_training = False\n",
      "\n",
      "max_mem_size is dummy for RepulsiveEllipsoidPackingLossUnitNorm\n",
      "lw2 is dummy for RepulsiveEllipsoidPackingLossUnitNorm\n"
     ]
    }
   ],
   "source": [
    "config = helper.Config(model_dir,default_config_file=\"../default_configs/default_config_imagenet.ini\")\n",
    "if \"CIFAR\" in config.DATA[\"dataset\"] or \"MNIST\" in config.DATA[\"dataset\"]:\n",
    "    prune_backbone = True\n",
    "else:\n",
    "    prune_backbone = False\n",
    "ssl_model = lightning_models.CLAP(backbone_name = config.SSL[\"backbone\"],\n",
    "                                  prune = prune_backbone,\n",
    "                                  use_projection_head=config.SSL[\"use_projection_head\"],\n",
    "                                  proj_dim = config.SSL[\"proj_dim\"],\n",
    "                                  proj_out_dim = config.SSL[\"proj_out_dim\"],\n",
    "                                  loss_name= config.SSL[\"loss_function\"],\n",
    "                                  optim_name = config.SSL[\"optimizer\"],\n",
    "                                  lr = 1.0,\n",
    "                                  scheduler_name = config.SSL[\"lr_scheduler\"],\n",
    "                                  momentum = config.SSL[\"momentum\"],\n",
    "                                  weight_decay = config.SSL[\"weight_decay\"],\n",
    "                                  eta = config.SSL[\"lars_eta\"],\n",
    "                                  warmup_epochs = config.SSL[\"warmup_epochs\"],\n",
    "                                  n_epochs = config.SSL[\"n_epochs\"],\n",
    "                                  n_views = config.DATA[\"n_views\"],\n",
    "                                  batch_size = config.SSL[\"batch_size\"],\n",
    "                                  lw0 = config.SSL[\"lw0\"],\n",
    "                                  lw1 = config.SSL[\"lw1\"],\n",
    "                                  lw2 = config.SSL[\"lw2\"],\n",
    "                                  rs = config.SSL[\"rs\"],\n",
    "                                  pot_pow = config.SSL[\"pot_pow\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "baa0e16b-b879-458d-8601-1772c501b2a3",
   "metadata": {},
   "outputs": [],
   "source": [
    "val_dir = \"../datasets/imagenet1k/val/val.lmdb\"\n",
    "aug_ops = [\"ToTensor\",\"Normalize\",\"RandomResizedCrop\"]\n",
    "num_classes= 5\n",
    "mean= [0.485, 0.456, 0.406]\n",
    "std= [0.229, 0.224, 0.225]\n",
    "if val_dir.endswith(\"lmdb\"):\n",
    "    img_type = \"PIL\" \n",
    "    val_dataset = data_utils.ImageFolderLMDB(val_dir,img_type=img_type)\n",
    "else:\n",
    "    val_dataset = datasets.ImageFolder(root=val_dir)\n",
    "classes = random.sample(list(range(1000)),num_classes)\n",
    "sub_indices = [i for i in range(len(val_dataset)) if val_dataset[i][1] in classes]\n",
    "val_dataset = torch.utils.data.Subset(val_dataset, sub_indices)\n",
    "config.DATA[\"mean4norm\"] = mean\n",
    "config.DATA[\"std4norm\"] = std     \n",
    "transform = data_utils.get_transform(aug_ops,aug_params=config.DATA,aug_pkg=\"torchvision\")\n",
    "val_dataset = data_utils.WrappedDataset(val_dataset,transform,n_views = n_views,aug_pkg=\"torchvision\")\n",
    "val_loader = torch.utils.data.DataLoader(val_dataset,batch_size = batch_size,shuffle=True,drop_last=True,\n",
    "                                            num_workers=4,pin_memory=True,persistent_workers=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e103224b-1e7e-4bd4-8570-1b9212524c6f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "dc449c08-5c10-4eb7-bdae-148e19a56832",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found pretrained model at ../traning/lr_3.0/ssl/best_val.ckpt, loading...\n",
      "max_mem_size is dummy for RepulsiveEllipsoidPackingLossUnitNorm\n",
      "lw2 is dummy for RepulsiveEllipsoidPackingLossUnitNorm\n"
     ]
    }
   ],
   "source": [
    "device = torch.device(\"cuda:0\")  # Use GPU 0\n",
    "trained_filename = os.path.join(model_dir,\"ssl\",'best_val.ckpt')\n",
    "if os.path.isfile(trained_filename):\n",
    "    print(f'Found pretrained model at {trained_filename}, loading...')\n",
    "    ssl_model = lightning_models.CLAP.load_from_checkpoint(trained_filename)\n",
    "ssl_model.backbone.remove_projection_head()\n",
    "backbone = ssl_model.backbone.to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "bc70b116-fd5e-4cc9-aefc-1fe3d1cc0d76",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_representations(backbone,test_dataset,count=2400):\n",
    "    test_loader = torch.utils.data.DataLoader(test_dataset,batch_size = batch_size,shuffle=True,drop_last=True,\n",
    "                                              num_workers = 4,pin_memory=True)\n",
    "    rep_vecs = []\n",
    "    all_labels =[]\n",
    "    i = 0\n",
    "    for i,data in enumerate(test_loader):\n",
    "        imgs,labels = data\n",
    "        if i > count - 1:\n",
    "            break\n",
    "        all_labels.append(labels[0].detach().cpu())\n",
    "        imgs = torch.cat(imgs,dim=0).to(device)\n",
    "        with torch.no_grad():\n",
    "            preds = backbone(imgs)\n",
    "            preds = torch.reshape(preds,(batch_size,preds.shape[-1]))\n",
    "            centers = torch.mean(preds,dim=0)\n",
    "            preds -= centers\n",
    "            rep_vecs.append(preds)\n",
    "            \n",
    "    rep_vecs = torch.cat(rep_vecs,dim=0).detach().cpu().numpy()\n",
    "    all_labels = torch.cat(all_labels,dim=-1).detach().cpu().numpy()\n",
    "    return rep_vecs,all_labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "f071e9d9-8530-4f16-b0c2-7907fa28cfb2",
   "metadata": {},
   "outputs": [],
   "source": [
    "x,y = get_representations(backbone,val_dataset,count=3000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "f386423b-a8ba-475a-8cc4-0e365c3a9a70",
   "metadata": {},
   "outputs": [],
   "source": [
    "t_sne = TSNE(\n",
    "    n_components=2,\n",
    "    perplexity=30,\n",
    "    max_iter=600,\n",
    "    random_state=0,\n",
    ")\n",
    "X = t_sne.fit_transform(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "1847b1ef-cbdb-450a-a499-2537ace0a248",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_embedding(x,y,classes, title):\n",
    "    _, ax = plt.subplots()\n",
    "    #X = MinMaxScaler().fit_transform(x)\n",
    "    color = 0\n",
    "    for c in classes:\n",
    "        pos = np.where(y==c)\n",
    "        print(X[pos].shape)\n",
    "        ax.scatter(\n",
    "            X[pos][:,0],X[pos][:,1],\n",
    "            marker=\".\",\n",
    "            s=60,\n",
    "            color=plt.cm.tab10(color),\n",
    "            alpha=1.0,\n",
    "            zorder=2,label = str(c)\n",
    "        )\n",
    "        color += 1\n",
    "    ax.set_title(title)\n",
    "    ax.axis(\"off\")\n",
    "    ax.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "c2e3eb2c-b8e4-41f0-8171-89ad84d3e14b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(50, 2)\n",
      "(50, 2)\n",
      "(50, 2)\n",
      "(50, 2)\n",
      "(48, 2)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_embedding(X,y,classes,\"Imagenet\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "f510ac88-0928-4325-90ea-2a48cab43fcf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading default settings...\n",
      "[INFO]does not exist in the config file\n",
      "[DATA]does not exist in the config file\n",
      "[SSL]does not exist in the config file\n",
      "[LC]does not exist in the config file\n",
      "[SemiSL]does not exist in the config file\n",
      "[TL]does not exist in the config file\n",
      "[SemiSL]does not exist in the config file\n",
      "[TL]does not exist in the config file\n",
      "[INFO]\n",
      "num_nodes = 2\n",
      "gpus_per_node = 4\n",
      "cpus_per_gpu = 12\n",
      "prefetch_factor = 2\n",
      "precision = 16-mixed\n",
      "fix_random_seed = True\n",
      "strategy = ddp\n",
      "if_profile = False\n",
      "\n",
      "[DATA]\n",
      "dataset = IMAGENET1K-30percent\n",
      "n_views = 8\n",
      "augmentation_package = albumentations\n",
      "augmentations = ['RandomResizedCrop', 'GaussianBlur', 'RandomGrayscale', 'ColorJitter', 'RandomHorizontalFlip', 'RandomSolarize']\n",
      "crop_size = 224\n",
      "crop_min_scale = 0.08\n",
      "crop_max_scale = 1.0\n",
      "hflip_prob = 0.5\n",
      "blur_kernel_size = 23\n",
      "blur_prob = 0.5\n",
      "grayscale_prob = 0.2\n",
      "jitter_brightness = 0.8\n",
      "jitter_contrast = 0.8\n",
      "jitter_saturation = 0.8\n",
      "jitter_hue = 0.2\n",
      "jitter_prob = 0.8\n",
      "solarize_prob = 0.0\n",
      "imagenet_train_dir = /imagenet/train\n",
      "imagenet_val_dir = /imagenet/val\n",
      "\n",
      "[SSL]\n",
      "backbone = resnet50\n",
      "use_projection_head = True\n",
      "proj_dim = [8192, 8192]\n",
      "proj_out_dim = 512\n",
      "optimizer = LARS\n",
      "lr = 1.0\n",
      "lr_scale = linear\n",
      "lr_scheduler = cosine-warmup\n",
      "grad_accumulation_steps = 1\n",
      "momentum = 0.0\n",
      "weight_decay = 1e-05\n",
      "lars_eta = 0.001\n",
      "loss_function = RepulsiveEllipsoidPackingLossUnitNorm\n",
      "lw0 = 0.0\n",
      "lw1 = 1.0\n",
      "lw2 = 0.0\n",
      "max_mem_size = 0\n",
      "rs = 7.0\n",
      "pot_pow = 2.0\n",
      "max_grad_norm = -1.0\n",
      "warmup_epochs = 10\n",
      "n_epochs = 100\n",
      "batch_size = 800\n",
      "save_every_n_epochs = 10\n",
      "restart_training = False\n",
      "\n",
      "[LC]\n",
      "output_dim = 1000\n",
      "optimizer = SGD\n",
      "use_batch_norm = False\n",
      "lr_sweep = [0.6, 0.1]\n",
      "lr_scale = linear\n",
      "lr_scheduler = cosine\n",
      "weight_decay = 1e-06\n",
      "momentum = 0.9\n",
      "loss_function = CrossEntropyLoss\n",
      "n_epochs = 100\n",
      "batch_size = 1024\n",
      "save_every_n_epochs = 50\n",
      "apply_simple_augmentations = True\n",
      "standardize_to_imagenet = True\n",
      "restart_training = False\n",
      "\n",
      "max_mem_size is dummy for RepulsiveEllipsoidPackingLossUnitNorm\n",
      "lw2 is dummy for RepulsiveEllipsoidPackingLossUnitNorm\n",
      "Found pretrained model at ../traning/lr_1.0/ssl/best_val.ckpt, loading...\n",
      "max_mem_size is dummy for RepulsiveEllipsoidPackingLossUnitNorm\n",
      "lw2 is dummy for RepulsiveEllipsoidPackingLossUnitNorm\n"
     ]
    }
   ],
   "source": [
    "model_dir = \"../traning/lr_1.0\"\n",
    "config = helper.Config(model_dir,default_config_file=\"../default_configs/default_config_imagenet.ini\")\n",
    "if \"CIFAR\" in config.DATA[\"dataset\"] or \"MNIST\" in config.DATA[\"dataset\"]:\n",
    "    prune_backbone = True\n",
    "else:\n",
    "    prune_backbone = False\n",
    "ssl_model = lightning_models.CLAP(backbone_name = config.SSL[\"backbone\"],\n",
    "                                  prune = prune_backbone,\n",
    "                                  use_projection_head=config.SSL[\"use_projection_head\"],\n",
    "                                  proj_dim = config.SSL[\"proj_dim\"],\n",
    "                                  proj_out_dim = config.SSL[\"proj_out_dim\"],\n",
    "                                  loss_name= config.SSL[\"loss_function\"],\n",
    "                                  optim_name = config.SSL[\"optimizer\"],\n",
    "                                  lr = 1.0,\n",
    "                                  scheduler_name = config.SSL[\"lr_scheduler\"],\n",
    "                                  momentum = config.SSL[\"momentum\"],\n",
    "                                  weight_decay = config.SSL[\"weight_decay\"],\n",
    "                                  eta = config.SSL[\"lars_eta\"],\n",
    "                                  warmup_epochs = config.SSL[\"warmup_epochs\"],\n",
    "                                  n_epochs = config.SSL[\"n_epochs\"],\n",
    "                                  n_views = config.DATA[\"n_views\"],\n",
    "                                  batch_size = config.SSL[\"batch_size\"],\n",
    "                                  lw0 = config.SSL[\"lw0\"],\n",
    "                                  lw1 = config.SSL[\"lw1\"],\n",
    "                                  lw2 = config.SSL[\"lw2\"],\n",
    "                                  rs = config.SSL[\"rs\"],\n",
    "                                  pot_pow = config.SSL[\"pot_pow\"])\n",
    "device = torch.device(\"cuda:0\")  # Use GPU 0\n",
    "trained_filename = os.path.join(model_dir,\"ssl\",'best_val.ckpt')\n",
    "if os.path.isfile(trained_filename):\n",
    "    print(f'Found pretrained model at {trained_filename}, loading...')\n",
    "    ssl_model = lightning_models.CLAP.load_from_checkpoint(trained_filename)\n",
    "ssl_model.backbone.remove_projection_head()\n",
    "backbone = ssl_model.backbone.to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "95ca4f63-eaa4-4373-bf57-78c2cfab589f",
   "metadata": {},
   "outputs": [],
   "source": [
    "x,y = get_representations(backbone,val_dataset,count=3000)\n",
    "t_sne = TSNE(\n",
    "    n_components=2,\n",
    "    perplexity=30,\n",
    "    max_iter=800,\n",
    "    random_state=0,\n",
    ")\n",
    "X = t_sne.fit_transform(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "4476bac1-e93c-4312-9612-5a7dea9dcbcc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(50, 2)\n",
      "(50, 2)\n",
      "(49, 2)\n",
      "(49, 2)\n",
      "(50, 2)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_embedding(X,y,classes,\"Imagenet\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "361e1685-ed6d-4118-be95-f3c59a86e20b",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
