{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import torch\n",
    "from dataset import DCDataset, share4v_train_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "stage=0 #MCL stage\n",
    "num_gpus=8  # number of gpus used in inference.py\n",
    "expname='clipmoe' # experiment name, please use the same for the whole MCL process, without stage number\n",
    "savepath='./save_mcl_tmp'   # path to load the output of inference.py and to save the obtained pseudo-labels\n",
    "\n",
    "num_clusters_per_modal=3\n",
    "\n",
    "num_clusters=num_clusters_per_modal*num_clusters_per_modal # number of clusters for each stage in MCL\n",
    "cluster_batch_size=1000000  # batch size for clustering. We use mini-batch Kmeans for clustering\n",
    "cluster_max_iter=500    # max number of iterations for clustering\n",
    "cluster_tol=1e-5    # tolerance for clustering\n",
    "my_dataset = share4v_train_dataset()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "# integrate saved features from all GPUs from inference_DDP_longclip_slurm.py\n",
    "image_feature_list=[]\n",
    "text_feature_list=[]\n",
    "indices_list=[]\n",
    "for rank in range(num_gpus):\n",
    "    saving=torch.load(os.path.join(savepath, '{}_{}_{}_{}.pt'.format(expname, stage, 'features',rank)))\n",
    "    image_feature,text_feature, indices=saving['image_features'],saving['text_features'], saving['indices']\n",
    "    image_feature_list.append(image_feature)\n",
    "    text_feature_list.append(text_feature)\n",
    "    indices_list.append(indices)\n",
    "image_feature_list=torch.cat(image_feature_list, dim=0)\n",
    "text_feature_list=torch.cat(text_feature_list, dim=0)\n",
    "indices_list=torch.cat(indices_list, dim=0)\n",
    "\n",
    "image_features=torch.zeros(len(my_dataset), image_feature_list.size(1), dtype=torch.float16)\n",
    "image_features[indices_list]=image_feature_list\n",
    "image_features=image_features.numpy()\n",
    "\n",
    "text_features=torch.zeros(len(my_dataset), text_feature_list.size(1), dtype=torch.float16)\n",
    "text_features[indices_list]=text_feature_list\n",
    "text_features=text_features.numpy()\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Init 1/1 with method k-means++\n",
      "Inertia for init 1/1: 365251.06288538483\n",
      "Minibatch step 1/500: mean batch inertia: 0.3652535961238412\n",
      "Minibatch step 2/500: mean batch inertia: 0.19841850892257867, ewa inertia: 0.19841850892257867\n",
      "Minibatch step 3/500: mean batch inertia: 0.19714915800895055, ewa inertia: 0.19714915800895055\n",
      "Minibatch step 4/500: mean batch inertia: 0.19656850664992986, ewa inertia: 0.19656850664992986\n",
      "Minibatch step 5/500: mean batch inertia: 0.196282861289549, ewa inertia: 0.196282861289549\n",
      "Minibatch step 6/500: mean batch inertia: 0.19610367445549523, ewa inertia: 0.19610367445549523\n",
      "Minibatch step 7/500: mean batch inertia: 0.19605459548268195, ewa inertia: 0.19605459548268195\n",
      "Minibatch step 8/500: mean batch inertia: 0.19605719948113778, ewa inertia: 0.19605719948113778\n",
      "Minibatch step 9/500: mean batch inertia: 0.19597595770580048, ewa inertia: 0.19597595770580048\n",
      "Minibatch step 10/500: mean batch inertia: 0.19598970210994213, ewa inertia: 0.19598970210994213\n",
      "Minibatch step 11/500: mean batch inertia: 0.19595923350959255, ewa inertia: 0.19595923350959255\n",
      "Minibatch step 12/500: mean batch inertia: 0.19593714838057877, ewa inertia: 0.19593714838057877\n",
      "Minibatch step 13/500: mean batch inertia: 0.19586856386369225, ewa inertia: 0.19586856386369225\n",
      "Minibatch step 14/500: mean batch inertia: 0.19583581129760644, ewa inertia: 0.19583581129760644\n",
      "Minibatch step 15/500: mean batch inertia: 0.19580707485684282, ewa inertia: 0.19580707485684282\n",
      "Minibatch step 16/500: mean batch inertia: 0.19582839497074903, ewa inertia: 0.19582839497074903\n",
      "Minibatch step 17/500: mean batch inertia: 0.19574611021076724, ewa inertia: 0.19574611021076724\n",
      "Minibatch step 18/500: mean batch inertia: 0.1958661171188892, ewa inertia: 0.1958661171188892\n",
      "Minibatch step 19/500: mean batch inertia: 0.19584911163284813, ewa inertia: 0.19584911163284813\n",
      "Minibatch step 20/500: mean batch inertia: 0.1958600115350376, ewa inertia: 0.1958600115350376\n",
      "Minibatch step 21/500: mean batch inertia: 0.19580539293689161, ewa inertia: 0.19580539293689161\n",
      "Minibatch step 22/500: mean batch inertia: 0.19577781760962942, ewa inertia: 0.19577781760962942\n",
      "Minibatch step 23/500: mean batch inertia: 0.19584439483838434, ewa inertia: 0.19584439483838434\n",
      "Minibatch step 24/500: mean batch inertia: 0.19582784344442752, ewa inertia: 0.19582784344442752\n",
      "Minibatch step 25/500: mean batch inertia: 0.1957883103062127, ewa inertia: 0.1957883103062127\n",
      "Minibatch step 26/500: mean batch inertia: 0.19584805703772462, ewa inertia: 0.19584805703772462\n",
      "Minibatch step 27/500: mean batch inertia: 0.19574488914103783, ewa inertia: 0.19574488914103783\n",
      "Minibatch step 28/500: mean batch inertia: 0.1958060969229409, ewa inertia: 0.1958060969229409\n",
      "Minibatch step 29/500: mean batch inertia: 0.1957108599992051, ewa inertia: 0.1957108599992051\n",
      "Minibatch step 30/500: mean batch inertia: 0.19581740815298676, ewa inertia: 0.19581740815298676\n",
      "Minibatch step 31/500: mean batch inertia: 0.19584048473176896, ewa inertia: 0.19584048473176896\n",
      "Minibatch step 32/500: mean batch inertia: 0.19580933151256216, ewa inertia: 0.19580933151256216\n",
      "Minibatch step 33/500: mean batch inertia: 0.19579233495073733, ewa inertia: 0.19579233495073733\n",
      "Minibatch step 34/500: mean batch inertia: 0.19577587330238458, ewa inertia: 0.19577587330238458\n",
      "Minibatch step 35/500: mean batch inertia: 0.19577031947243617, ewa inertia: 0.19577031947243617\n",
      "Minibatch step 36/500: mean batch inertia: 0.19578664094456807, ewa inertia: 0.19578664094456807\n",
      "Minibatch step 37/500: mean batch inertia: 0.19575139007917547, ewa inertia: 0.19575139007917547\n",
      "Minibatch step 38/500: mean batch inertia: 0.19580456450945852, ewa inertia: 0.19580456450945852\n",
      "Minibatch step 39/500: mean batch inertia: 0.19579719250689284, ewa inertia: 0.19579719250689284\n",
      "Converged (lack of improvement in inertia) at step 39/500\n",
      "Init 1/1 with method k-means++\n",
      "Inertia for init 1/1: 445996.85586537246\n",
      "Minibatch step 1/500: mean batch inertia: 0.44601379173109007\n",
      "Minibatch step 2/500: mean batch inertia: 0.25019004649097165, ewa inertia: 0.25019004649097165\n",
      "Minibatch step 3/500: mean batch inertia: 0.24950093159358072, ewa inertia: 0.24950093159358072\n",
      "Minibatch step 4/500: mean batch inertia: 0.24913989773165113, ewa inertia: 0.24913989773165113\n",
      "Minibatch step 5/500: mean batch inertia: 0.24913320132564504, ewa inertia: 0.24913320132564504\n",
      "Minibatch step 6/500: mean batch inertia: 0.24895316198827866, ewa inertia: 0.24895316198827866\n",
      "Minibatch step 7/500: mean batch inertia: 0.24891165449828662, ewa inertia: 0.24891165449828662\n",
      "Minibatch step 8/500: mean batch inertia: 0.24887304833062596, ewa inertia: 0.24887304833062596\n",
      "Minibatch step 9/500: mean batch inertia: 0.2487715202430211, ewa inertia: 0.2487715202430211\n",
      "Minibatch step 10/500: mean batch inertia: 0.2487952726019548, ewa inertia: 0.2487952726019548\n",
      "Minibatch step 11/500: mean batch inertia: 0.24879262167831626, ewa inertia: 0.24879262167831626\n",
      "Minibatch step 12/500: mean batch inertia: 0.24880941125411365, ewa inertia: 0.24880941125411365\n",
      "Minibatch step 13/500: mean batch inertia: 0.2487586044766633, ewa inertia: 0.2487586044766633\n",
      "Minibatch step 14/500: mean batch inertia: 0.2487918907276677, ewa inertia: 0.2487918907276677\n",
      "Minibatch step 15/500: mean batch inertia: 0.2487187323221318, ewa inertia: 0.2487187323221318\n",
      "Minibatch step 16/500: mean batch inertia: 0.24876035035368116, ewa inertia: 0.24876035035368116\n",
      "Minibatch step 17/500: mean batch inertia: 0.2486631765801926, ewa inertia: 0.2486631765801926\n",
      "Minibatch step 18/500: mean batch inertia: 0.24880656517978572, ewa inertia: 0.24880656517978572\n",
      "Minibatch step 19/500: mean batch inertia: 0.2487102254970064, ewa inertia: 0.2487102254970064\n",
      "Minibatch step 20/500: mean batch inertia: 0.24867019152529782, ewa inertia: 0.24867019152529782\n",
      "Minibatch step 21/500: mean batch inertia: 0.24867616570461995, ewa inertia: 0.24867616570461995\n",
      "Minibatch step 22/500: mean batch inertia: 0.24869208691984393, ewa inertia: 0.24869208691984393\n",
      "Minibatch step 23/500: mean batch inertia: 0.24864923511342021, ewa inertia: 0.24864923511342021\n",
      "Minibatch step 24/500: mean batch inertia: 0.24868365289836478, ewa inertia: 0.24868365289836478\n",
      "Minibatch step 25/500: mean batch inertia: 0.2487192471664128, ewa inertia: 0.2487192471664128\n",
      "Minibatch step 26/500: mean batch inertia: 0.24868797077512364, ewa inertia: 0.24868797077512364\n",
      "Minibatch step 27/500: mean batch inertia: 0.24866281961319045, ewa inertia: 0.24866281961319045\n",
      "Minibatch step 28/500: mean batch inertia: 0.24863845943487287, ewa inertia: 0.24863845943487287\n",
      "Minibatch step 29/500: mean batch inertia: 0.24866249893817502, ewa inertia: 0.24866249893817502\n",
      "Minibatch step 30/500: mean batch inertia: 0.24862748454597797, ewa inertia: 0.24862748454597797\n",
      "Minibatch step 31/500: mean batch inertia: 0.2486798664839277, ewa inertia: 0.2486798664839277\n",
      "Minibatch step 32/500: mean batch inertia: 0.24872312623813542, ewa inertia: 0.24872312623813542\n",
      "Minibatch step 33/500: mean batch inertia: 0.24862160924594204, ewa inertia: 0.24862160924594204\n",
      "Minibatch step 34/500: mean batch inertia: 0.2486533885840463, ewa inertia: 0.2486533885840463\n",
      "Minibatch step 35/500: mean batch inertia: 0.24863822972209376, ewa inertia: 0.24863822972209376\n",
      "Minibatch step 36/500: mean batch inertia: 0.24861892833454818, ewa inertia: 0.24861892833454818\n",
      "Minibatch step 37/500: mean batch inertia: 0.2486376436391398, ewa inertia: 0.2486376436391398\n",
      "Minibatch step 38/500: mean batch inertia: 0.24859368173200197, ewa inertia: 0.24859368173200197\n",
      "Minibatch step 39/500: mean batch inertia: 0.2486991448905071, ewa inertia: 0.2486991448905071\n",
      "Minibatch step 40/500: mean batch inertia: 0.2486565377188583, ewa inertia: 0.2486565377188583\n",
      "Minibatch step 41/500: mean batch inertia: 0.24856487979033962, ewa inertia: 0.24856487979033962\n",
      "Minibatch step 42/500: mean batch inertia: 0.2485821336235817, ewa inertia: 0.2485821336235817\n",
      "Minibatch step 43/500: mean batch inertia: 0.24861734170990965, ewa inertia: 0.24861734170990965\n",
      "Minibatch step 44/500: mean batch inertia: 0.24864930024663212, ewa inertia: 0.24864930024663212\n",
      "Minibatch step 45/500: mean batch inertia: 0.24866185723494916, ewa inertia: 0.24866185723494916\n",
      "Minibatch step 46/500: mean batch inertia: 0.24863885945965988, ewa inertia: 0.24863885945965988\n",
      "Minibatch step 47/500: mean batch inertia: 0.24866211306792133, ewa inertia: 0.24866211306792133\n",
      "Minibatch step 48/500: mean batch inertia: 0.24873546928477913, ewa inertia: 0.24873546928477913\n",
      "Minibatch step 49/500: mean batch inertia: 0.24866369868778743, ewa inertia: 0.24866369868778743\n",
      "Minibatch step 50/500: mean batch inertia: 0.24859085847445103, ewa inertia: 0.24859085847445103\n",
      "Minibatch step 51/500: mean batch inertia: 0.24869284260084984, ewa inertia: 0.24869284260084984\n",
      "Converged (lack of improvement in inertia) at step 51/500\n"
     ]
    }
   ],
   "source": [
    "# do mini-batch Kmeans clustering\n",
    "from sklearn.cluster import MiniBatchKMeans\n",
    "kmeans_i = MiniBatchKMeans(\n",
    "    n_clusters=num_clusters_per_modal, \n",
    "    batch_size=cluster_batch_size, \n",
    "    max_iter=cluster_max_iter,\n",
    "    tol=cluster_tol,\n",
    "    verbose=1,\n",
    "    n_init='auto')\n",
    "\n",
    "kmeans_i.fit(image_features)\n",
    "\n",
    "cluster_labels_i = torch.LongTensor(kmeans_i.predict(image_features))\n",
    "\n",
    "\n",
    "kmeans_t = MiniBatchKMeans(\n",
    "    n_clusters=num_clusters_per_modal, \n",
    "    batch_size=cluster_batch_size, \n",
    "    max_iter=cluster_max_iter,\n",
    "    tol=cluster_tol,\n",
    "    verbose=1,\n",
    "    n_init='auto')\n",
    "\n",
    "kmeans_t.fit(text_features)\n",
    "\n",
    "cluster_labels_t = torch.LongTensor(kmeans_t.predict(text_features))\n",
    "\n",
    "cluster_labels=cluster_labels_t*num_clusters_per_modal+cluster_labels_i\n",
    "torch.save(cluster_labels,os.path.join(savepath, '{}_{}_{}.pt'.format(expname, stage, 'cluster_labels')))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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9Gh9++238vb2dsc+AAAAwIECz+gtWrQo1z4eHh4qUaKE7r33XtWpU0fFihUr6GYBAACQiwIHvV69erljHAAAAHCzInm8CgAAAAofQQ8AAMCkCnzqNqcffvhB3377rQ4cOKALFy5IkkqXLq06deqoVatWqlevnrs3CQAAAAfcFvT279+vAQMGKCYmxmmf119/XQ0bNtTcuXNVt25dd20aAAAADrjl1O23336rBg0aKCYmxniMiqenp8qXL6/y5cvL09PT+H3Xrl1q0KCBNm7c6I5NAwAAwIkCB72EhAR16dJFaWlpslgs6tevn3bv3q2UlBSdOXNGZ86cUWpqqmJiYtS/f38VK1ZMaWlp6tKli86fP++OfQAAAIADBQ56M2bMUGJiory8vBQdHa158+YpPDxcnp7//6xwsWLFVL9+fc2dO1fR0dEqXry4EhMTNWPGjIJuHgAAAE4UOOhFR0fLYrFo8ODBatOmTa79W7durSFDhshqtSo6OrqgmwcAAIATBQ56x48flyQ98cQTeV4nq++xY8cKtO0///xTa9eu1dixY/X4448rODhYFotFFotFvXv3zlONxYsXG+vk9lm8eHGu9VJTU/XWW28pPDxcpUuXlr+/v2rWrKnhw4frxIkTed63EydOaPjw4apZs6b8/f1VunRphYeHa+rUqUpNTc1znR07dqhHjx6qXLmyfHx8VKFCBbVp00bLly/Pcw1JWr58uVq3bq0KFSrIx8dHlStXVo8ePbRz58581QEAALdOge+6vXr1qiTJ398/z+tk9U1LSyvQtsuXL1+g9d3tyJEjatu2rX777bdsvx8+fFiHDx/WggULtHTpUrVv395lnTVr1qhHjx5KSkoyfktNTVVsbKxiY2O1YMECRUdHKzQ01GWd8ePHa+LEicrIyDB+++OPP/T111/r66+/1tKlS7Vq1Sr5+Pg4rXHlyhU99dRTWrduXbbff//9dy1dulTLly/X2LFjNW7cOJdjAQAAt16BZ/QqVKggSdq3b1+e18nq686gds8996h169YFqrFhwwbt37/f6adTp05O101OTla7du2MkNe/f39t3LhRO3bs0KRJkxQQEKCkpCR169ZNP/74o9M6+/btU7du3ZSUlKSAgABNmjRJO3bs0MaNG9W/f39JUlxcnNq1a6fk5GSndebOnasJEyYoIyND1apV08KFCxUTE6OoqCi1aNFCUuZp9+eff97lMXn++eeNkNeiRQtFRUUpJiZGCxcuVLVq1ZSRkaHx48dr3rx5LusAAIBbr8Azes2aNdP//vc/TZ48WV27dlVgYKDL/snJyZoyZYosFouaNWtWoG2PHTtW4eHhCg8PV/ny5RUfH6977733puuFhYWpSpUqN7Xu1KlTFRcXJ0l66623NGLECKOtcePGat68uSIiIpSamqphw4Zp8+bNDusMHTpUV65ckaenp77++ms1btzYaHv00UdVvXp1jRw5UnFxcXr77bc1fvx4uxoXLlzQa6+9JikzAO/atUvBwcFGe/v27RUZGak1a9Zo+fLlGjBggJo3b25X57vvvtMnn3wiSerQoYNWr16tYsWKSZLCw8P1xBNPqF69evr999/12muvqUuXLipVqlS+jhsAACg8BZ7RGzhwoKTMa/UeeeQRxcbGOu0bGxuriIgIHT16NNu6N2vChAlq3759kZ/CvX79umbOnClJqlWrloYPH27X5+GHH1bfvn0lSVu2bNGePXvs+sTExOj777+XJPXt2zdbyMsyfPhw1apVS1LmHc/Xr1+367NgwQIlJiZKkqZMmZIt5EmZd0HPmTPHCG1Tp051uF/Tpk2TJHl6embrnyU4OFhTpkyRJF26dEkLFixwWAcAABSNAge9Jk2a6KWXXpLVatX+/fvVsGFD3X///erfv7/eeOMNjRkzRv3799f999+vhg0b6qeffpIkvfTSS2rSpEmBd+DvYNOmTUaw6tWrlzw8HB9W2xtEVq9ebdceFRVlLPfp08dhDQ8PD/Xs2VNSZrjatGmT0zqBgYHq3LmzwzoVK1ZUq1atJEkbN260Ow2cnJxsPNS6VatWqlixosM6nTt3NmZxHe0TAAAoOm55Bdp7770nPz8/vfPOO8rIyNCBAwf0yy+/ZOtjtVolZQaVV199VZMnT3bHpv8Wtm3bZixHREQ47Ve/fn35+fkpNTVV27dvd1rH39/f5TuBbbexffv2bNcmXrt2zXgNXePGjeXl5eWyzoYNG5SWlqbY2Fjj2j1J2rNnj65du5brPnl5ealRo0b6+uuvtWfPHl2/fl3Fixd32h8AANw6bnkFmsVi0VtvvaUff/xRL774oqpXr2688izrU716db344ov68ccfjWv0/m769OmjkJAQeXl5KTg4WI0aNdKYMWN0+vRpl+sdPHjQWK5Zs6bTfp6ensadsocOHbJrz/otNDQ02wOnc7LdRs46cXFxunHjRq5jya1OXvfJtj09Pd3ujmMAAFB03DKjl6VOnTqaPXu2pMyZpYsXL0qSSpUq5XJm6e/C9gaJ8+fP6/z589q9e7fefvttTZ8+3ek1hadOnZKUORNXsmRJl9uoVKmSfv75Z/31119KS0uTt7e3pMzH1CQkJEiS09OkWUqVKiV/f3+lpKTo5MmTDseSlzqVKlUylt1Zp3bt2g77paWlZXukju3jYwAAgPu5NejZ8vLyKvKbJPKqatWq6ty5sxo3bmyElmPHjumzzz7TqlWrdPXqVb3wwguyWCwaMGCA3fpZ17cFBATkui3b5w1evnzZCHq218jltU5KSoouX77scCx5qZNzLIVRx9abb76pCRMmuKwFAADcJ9+nbtevX69//OMf+sc//qFly5bla91ly5YZ63777bf53XShiIyM1JEjRzR16lR17tzZeFxLt27dtGLFCn355ZfGNWevvPKKzp07Z1cj66HReZm1zAp2UubDiHPWyG8d2xr5reNsLO6sY2v06NFKTEw0PjlnEQEAgHvlK+hZrVa98sor+umnn1S2bFk988wz+dpY9+7dFRwcrB9//NHhI0iKQlBQkMvrBdu3b6+xY8dKynw7xcKFC+36ZL1ZIuvmBVdsT136+vra1chvHdsa+a3jbCzurGPL29tbgYGB2T4AAKDw5Cvofffdd4qLi5OHh4fefffdfG/MYrFo+vTpKlasmA4cOKAtW7bku0ZRGDBggBEGHY25RIkSklyftsySkpJiLNueEs2qkd86OU+r5qeOs7G4sw4AACg6+Qp6n332mSTpsccec3rBfW5q166tNm3aSJJWrVp1UzVutXLlyqlMmTKS5PAO3KybFVJSUnTp0iWXtbJOV5YtWzbbKU8fHx9jG7Y3Qjhy8eJFI1zZ3ghhO5a81LE9dVpYdQAAQNHJV9CLiYmRxWJRhw4dCrTR9u3by2q1ateuXQWqcyu5Or1rG3p//fVXp/3S09ONt4Jkvd3CUZ0jR44oPT3daR3bbeSsExYWZrzBwtVYcquT132ybff09FT16tVd9gUAALdOvoLeiRMnJEk1atQo0EbDwsIkSfHx8QWqc6v89ddfxqNPQkJC7NqbNm1qLLs6HR0bG2vMxDl6K0hWnZSUFP3www9O69huI2cdLy8vNWjQQJK0c+dOl9fXZdXx9vZW/fr1s7WFh4cbN2G42qdr164ZgT08PJyHJQMA8DeSr6CX9Zqv0qVLF2ijWevfLs9RmzdvnvFmD0dviWjevLmCgoIkSUuWLDH65rR48WJjOTIy0q69U6dOxvKiRYsc1sjIyNBHH30kSSpZsmS2t1nkrJOUlKTPP//cYZ1Tp04Zdz63bNky2zV5UuY1ei1btpQkffvtt05P337++efG39HRPgEAgKKTr6CXdZdkbteh5SZr/Zzh4laLj4/Xvn37XPZZu3at/vOf/0jKvKPU0Ttovby89PLLL0vKfMPEtGnT7Prs3LnTuGM3IiJC4eHhdn0aNGigZs2aSZIWLlyonTt32vV5++23jbdYDB061OEMWr9+/YzgOWrUKJ0/fz5b+40bN/TSSy8Zb9AYMWKEw31/9dVXJWWech40aJDRP0tCQoJee+01SZmhs1+/fg7rAACAopGvByaXLVtWFy9e1MGDB9W8efOb3mhWUClXrtxN15Ay3w175MgR43vW6VUp8zo32xk0Serdu3e27/Hx8WrRooUaN26sDh066IEHHjDGdOzYMa1atUqrVq0yZuimTZumu+++2+FYRowYoU8//VRxcXEaOXKkjhw5oqefflq+vr7atGmT/u///k/p6eny9fXV9OnTne7TjBkz1KRJE125ckWtW7fW66+/rhYtWujKlSv65JNPNG/ePEmZp7+dPaKmdOnSmjJlil544QWdOHFCDRs21BtvvKG6devqzJkzmj59ujZt2iQp85E3zv6Wjz76qJ5++ml98skn+vLLL/XYY49p2LBhCgkJ0f79+zVp0iT9/vvvkqQpU6aoVKlSTvcLAADcehars/OMDvTq1Usff/yx2rRpo/Xr19/0Rv/5z3/qm2++UY8ePbRkyZKbrtO7d+98rZ9zVzdv3uzw1GdOfn5+evfddx2+FcPWkSNH1LZtW6fvew0MDNTSpUvVvn17l3XWrFmjHj16OD21HRYWpujoaOO9uc6MGzdOEydOdHoquW3btvrss8+yPTMvpytXruipp57SunXrHLZ7eHjo3//+t8aPH+9yLI4kJSUpKChIiYmJbn2mXpVR0W6r5U7xk9vlqR/jLxx5HT8A3A7y+m9ovk7dPv7445Kkr7/+Wtu2bbupgW3dulVff/11tnpFpV69evrf//6nQYMGqWHDhrrnnnvk5+dnvL7t0Ucf1aRJk3T8+PFcQ54khYaGat++fZoyZYrq16+vkiVLys/PTzVq1NArr7yin3/+OdeQJ0kdOnTQzz//rFdeeUVhYWHy8/NTyZIlVb9+fU2ZMkX79u3LNeRJ0oQJE7Rt2zY988wzqlSpkry8vFSuXDk99thjWrZsmaKjo12GPCnzdHV0dLSWLl2qxx57TOXKlZOXl5cqVaqkZ555Rtu2bbupkAcAAApfvmb0rl+/rho1aig+Pl7ly5fX1q1b8/U4jbi4OD3yyCP666+/VKVKFR0+fFienoX2ul38zTGj5xjjLxzM6AEwk0KZ0StevLhxo8Gff/6pevXqacaMGdnejODI5cuXNX36dNWvX19//vmnpMybCgh5AAAAhSffSatz586aMGGCxo0bp5SUFP3rX//Sv//9bzVr1kz16tVTuXLl5O/vr5SUFP3xxx/au3evvv/+e6WkpBjXik2YMCHbo0QAAADgfjc1pfbvf/9bFStW1JAhQ5SamqrLly/rq6++0ldffeWwf1bA8/Pz06xZs+zufgUAAID75evUra0+ffooLi5O//rXvxQcHCyr1er0ExwcrOHDhysuLo6QBwAAcIsU6CK5kJAQTZs2TdOmTdMvv/yin376SefPn1dycrJKlCihMmXK6IEHHtB9993nrvECAAAgj9x2N8R9991HoAMAAPgbuelTtwAAAPh7I+gBAACYFEEPAADApAh6AAAAJkXQAwAAMCmCHgAAgEkR9AAAAEyKoAcAAGBSBD0AAACTIugBAACYFEEPAADApAh6AAAAJkXQAwAAMCmCHgAAgEkR9AAAAEyKoAcAAGBSBD0AAACT8izqAQDA30mVUdFFPQSH4ie3K+ohALgNMaMHAABgUgQ9AAAAkyLoAQAAmBRBDwAAwKQIegAAACZF0AMAADApgh4AAIBJEfQAAABMiqAHAABgUgQ9AAAAkyLoAQAAmBRBDwAAwKQIegAAACZF0AMAADApgh4AAIBJEfQAAABMiqAHAABgUgQ9AAAAkyLoAQAAmBRBDwAAwKQIegAAACZF0AMAADCp2zro/fnnn1q7dq3Gjh2rxx9/XMHBwbJYLLJYLOrdu3e+661fv16RkZGqWLGivL29VbFiRUVGRmr9+vV5rpGenq4PPvhAzZo1U9myZeXr66tq1app4MCB+uWXX/JcJyEhQWPHjtX999+vwMBABQYG6v7779fYsWN1/vz5PNc5cOCABg4cqGrVqsnX11dly5ZVs2bN9MEHHyg9PT3PddxxbAAAwK3lWdQDKIjy5cu7pU5GRoYGDBighQsXZvv99OnTOn36tKKiotSvXz/NnTtXHh7Os3FCQoLatm2rPXv2ZPv92LFjmjdvnpYsWaJZs2apX79+Lseze/duderUSefOncv2+/79+7V//34tWLBAUVFRatCggcs68+fP1+DBg3Xt2jXjt6tXr2rbtm3atm2bFi1apOjoaAUHBzut4a5jAwAAbj3T/Mt8zz33qHXr1je17htvvGEEmYceekjLly9XTEyMli9froceekiStGDBAo0ZM8ZpjRs3bigyMtIIeZ07d9b69eu1e/duzZw5U+XKlVNaWpoGDhzochbs5MmT6tChg86dOydPT0+NHDlSW7du1datWzVy5Eh5enrq7Nmz6tChg06dOuW0zrp16/TCCy/o2rVrKl++vGbOnKndu3dr/fr16ty5syQpJiZGkZGRunHjRqEeGwAAUDQsVqvVWtSDuFnjxo1TeHi4wsPDVb58ecXHx+vee++VJPXq1UuLFy/OtUZcXJzuu+8+paenq379+tq6dat8fX2N9tTUVEVERCg2Nlaenp46dOiQQkND7ep8+OGH6tu3ryTppZde0uzZs7O1HzlyRPXq1VNSUpJCQ0N16NAheXraT6j27NlTH3/8sSRpxYoV6tKlS7b2FStWqFu3bi738fr166pZs6aOHTumwMBA7d27V9WqVcvWZ9CgQZozZ44kadGiRQ5Pdbvr2DiTlJSkoKAgJSYmKjAwMM/r5abKqGi31XKn+Mnt8tSP8ReOO2X8AO4Mef039Lae0ZswYYLat29foFO406dPN65Ve++997IFGUny8/PTe++9Jynz+rt3333XYZ1p06ZJkkqXLq2pU6fatYeGhmr06NGSMkPf6tWr7fqcO3dOS5culSS1adPGLuRJUteuXdWmTRtJ0scff2x3eleSVq9erWPHjkmSRo8ebRfyJGnq1KkqVaqUseyIu44NAAAoGrd10Csoq9WqL774QpJUs2ZNNWrUyGG/Ro0aqUaNGpKkL774QjknQePi4nTo0CFJmUHMz8/PYR3bWTNHQe/LL79URkaGJKlPnz5Ox51VJyMjQ19++aVde1RUlMNt2vLz81PX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z05rtGrVSlLmzQL79u1z2u/DDz902lavXj1jdnDJkiVOZxiTk5O1YsUKSVLt2rV11113Oa3pbrZ3Rbt6TMmCBQvyfAf1ypUrnV7Hl5KS4nRfW7VqZdytO3PmzFxPEQN/BwQ9AHeUY8eOacuWLS77fP3118ay7fV1NWrUUJcuXSRJn3zyid555x2XdY4fP67ly5fb/R4RESEp89ErjtqTk5PVt29fl7UHDhxohM4BAwY4DEFLly7VunXrnNbw9vZWv379JGXeSTtx4kS7PlarVYMHDzYC7+DBg12Oy93Kli1rhNHly5crLS3Nrs+ePXuM59blxblz5zR8+HCHbf/617+Mmy5efPHFbG0lS5Y09n/Hjh165ZVXXJ5+/+OPP4zTzkBR4Ro9AHeU33//XS1atFDt2rUVGRmp+vXr6+6775YknTx5Up9++qkxo/Pggw/aPXbk/fffV2xsrI4dO6bhw4friy++UM+ePXXffffJ29tb58+f108//aSvvvpK3333nSIjI9W9e/dsNXr06KHx48crKSlJffv21ZEjR9SmTRtZLBb98MMPeuedd3Tq1Ck99NBDTmfrHnjgAQ0aNEizZs1SbGys6tevr9dee01169Y1XoE2b9481a9f3+Vp5rFjx+rzzz/XsWPHNH78eO3fv199+vTRXXfdZbwCLeuZhI0bN9aAAQNu9tAbvvrqK8XHx+fa75lnnpGXl5eeffZZzZ49Wz///LOaNm2qf/3rX6pevboSExO1bt06zZkzRwEBAQoJCXF6uttW/fr19f777+v48eN64YUXjFegvf/++9qwYYOkzNO0L7zwgt26//nPf7Rlyxbt3r1bM2bM0ObNm9W/f389+OCD8vf318WLF/XLL7/o22+/1fr161W3bl0jTANFouheygEANycvr0DLy7quPjVr1nT6irOzZ89amzVrlqc6ffr0cVhjxYoV1mLFijlcx9fX17py5UqXr0CzWq3Wa9euWTt37ux02/fee6/16NGjuR6r48ePW2vWrOlyP5o0aeLwlXB5Zfvar7x+Ll68aLVardZLly5ZH3zwQaf9Spcubd2yZYs1IiLCKskaERFht33bv/uGDRusrVu3dvm3P336tNN9SUpKcnncbT8tWrRweSyAwsapWwB3lGbNmmnz5s0aPXq0WrRoodDQUJUoUULFixdX+fLl1bp1a33wwQf68ccfnT4WpUKFCtq6davWrl2rZ599VlWrVpWfn5+KFy+usmXL6uGHH9bw4cO1ZcsWp9fIdenSRTt27FBkZKTKli0rLy8vVapUSb169dKePXtyffOCJBUvXlyfffaZPv74YzVr1kxBQUHy8/NTrVq19Prrr+uHH35Q1apVc61TpUoV/fTTT5o1a5YiIiJUpkwZ43j885//1Mcff6ytW7fe0rttbQUFBWn79u2aOHGi6tatKx8fHwUEBKhWrVp69dVX9dNPP+X6OjtbXl5exkxgo0aNVLJkSfn5+alu3br673//q7179yokJMTp+iVKlNBnn32m77//Xv369VONGjVUokQJeXp6qnTp0goPD9egQYO0bt06ffPNN+44BMBNs1itXE0KAABgRszoAQAAmBRBDwAAwKQIegAAACZF0AMAADApgh4AAIBJEfQAAABMiqAHAABgUgQ9AAAAkyLoAQAAmBRBDwAAwKQIegAAACZF0AMAADApgh4AAIBJEfQAAABM6v8BTvXe9kJZrrUAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 600x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot the distribution of the pseudo labels\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "\n",
    "# 假设L是你的LongTensor\n",
    "L = cluster_labels\n",
    "\n",
    "# 获取唯一值及其计数\n",
    "unique_elements, counts = torch.unique(L, return_counts=True)\n",
    "\n",
    "# 结合unique_elements和counts，然后根据counts排序\n",
    "combined = list(zip(unique_elements.numpy(), counts.numpy()))\n",
    "sorted_combined = sorted(combined, key=lambda x: x[1], reverse=True)  # 根据counts降序排序\n",
    "\n",
    "# 分解回sorted unique elements和sorted counts\n",
    "sorted_unique_elements, sorted_counts = zip(*sorted_combined)\n",
    "\n",
    "# 绘制排序后的结果\n",
    "plt.figure(figsize=(6, 6))\n",
    "plt.bar(range(len(sorted_unique_elements)), sorted_counts, tick_label=sorted_unique_elements)\n",
    "#plt.title('Element Counts Sorted')\n",
    "\n",
    "plt.xticks([])\n",
    "\n",
    "# 设置竖轴的格式为科学记数法\n",
    "#plt.ylim(1e2,1e5)\n",
    "ax = plt.gca()\n",
    "#ax.set_yscale('log')\n",
    "#ax.yaxis.set_major_formatter(LogFormatterSciNotation())\n",
    "ax.set_yscale('linear')  # 改为线性缩放\n",
    "ax.yaxis.set_major_formatter(plt.ScalarFormatter())\n",
    "\n",
    "plt.xlabel('Pseudo Label',fontsize=20)\n",
    "plt.ylabel('Count',fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.savefig('cluster0.pdf', format='pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9\n",
      "81\n",
      "696\n"
     ]
    }
   ],
   "source": [
    "#integrate the clustering labels from the previous stages to get the pseudo labels for the current stage\n",
    "cls=torch.zeros(cluster_labels.shape[0],dtype=torch.long)\n",
    "for s in range(stage+1):\n",
    "    cl=torch.load(os.path.join(savepath, '{}_{}_{}.pt'.format(expname, s, 'cluster_labels')))\n",
    "    cls=cls*num_clusters+cl\n",
    "    unique_elements, counts = torch.unique(cls, return_counts=True)\n",
    "    print(len(counts))\n",
    "torch.save(cls[:1000000],os.path.join(savepath, '{}_{}_{}.pt'.format(expname, stage, 'pseudo_labels')))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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tJfZfv7554qPj1dERIQaNGigiy++WC1btvT6adWqVWUd3qOBAwdKKgwkn376qfV75xvrnW/+d8f58p7zzf9VUScrK0u///57qepEREQUm+EKCAhQo0aNSjWWEydOWCHt3LEAAIDqVykh7e9//7v+/Oc/a9myZTp+/LiMMaX+VLWIiAhr+6effrK2Y2NjrZUBfvzxR681nNuL3tRfxPkJzdLW8fX1VZs2bcpVJy8vT/v27XM7Fuc6e/futV4/4m0snuoAAIDqVeHLne+9955mzJghqXAmZ9CgQbr88svVsGFDj2/NP58OHTpkbTtf1vPz81PXrl21YcMGbdiwQbm5uR5vtl+9erWkwnuz4uLiirV16dJFfn5+ys3N1erVq/XYY4+5rZGbm6vk5GRrn3PfKdezZ89ix+vevbvbOqmpqdYMWI8ePVzae/bsqbVr1yorK0vffvutunXr5vWcPNUBAADVq8IhrWiJoujoaH311Vdq3bp1hQdVmRYvXmxtd+rUqVjboEGDtGHDBmVmZuqjjz7S3/72N5f9f/75Z33xxReSpGuuuabYfV9S4X1g11xzjZKSkvTFF1/o559/dvuOso8++sh6v1h8fLxL+1VXXaV69eopIyNDb7/9tiZMmOCysoNU+E64Iu7qDBo0SFOnTpUkzZ8/321IKygo0DvvvCOp8KEL55fzAgAAe6jwVNcPP/wgh8OhKVOmnNeA9tZbb7ldj9PZyy+/rBUrVkiSWrZsqV69ehVrHzVqlOrVqyep8IW3x48fL9aen5+vsWPHWg9AnLveZpFHHnlEUuGlyPvuu8/lgYljx45p4sSJkgpD0ahRo1xq+Pn56e9//7ukwhUAihZtd7ZhwwbNmzdPUuGyTu7e/9a1a1frPOfNm6cNGza49HnxxRetVQYeeOABrytFAACAamIqKDg42Pj4+JjNmzdXtFSZNG/e3DRs2NCMHj3avP3222bdunXmu+++M2vXrjUzZ840PXr0MJKMJOPn52c+//xzt3VmzZpl9WvdurV58803zaZNm8zSpUtNnz59rLZbbrnF63j+9re/WX379Oljli5dajZt2mTefPNN07p1a6vtjTfe8FgjMzPTxMbGWn3vvvtu89VXX5kNGzaYf//73yYkJMRIMoGBgWbLli0e62zevNkEBgYaSSYkJMT8+9//Nhs2bDBfffWVufvuu636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pzLG4q6Os5ycHGVmZhb7AACAqlVrQ9rLL7+slJQUSYWvw7j88std+pw8edLaDgkJ8VovODjY2j516lSV1imphnOdqhqLs6lTp6pevXrWxzncAQCAqlErQ9rq1av12GOPSZIaN26s119/3W2/M2fOWNt+fn5ea/r7+1vbp0+frtI6JdVwrlNVY3GWkJCgjIwM6+Nt1g0AAFQO3+oeQGXbvn274uPjlZeXp4CAAC1evFiNGzd22zcgIMDazs3N9VrX+SGEc1/TcW4d55/LWic7O7vEsTjXKWkspanhro4zf3//YoEOAABUvVo1k3bgwAH17dtXJ06cUJ06dfT+++/rT3/6k8f+oaGh1ra3y32Sit3kf+5lxMquU1IN5zpVNRYAAFC9ak1IO3z4sK699lodPnxYDodDb775pgYOHOh1H+cb670tsSQVv7H+3HuyylPH4XC43Nhf9HNJNZzrnDuWouWwyjIWd3UAAED1qhUh7dixY7ruuuust+xPnz5dd9xxR4n7dejQwdr+8ccfvfZ1bj/3dR7lqRMdHV3sxn3nOhkZGW5XEihy5MgR6wnLc8cSGhpqBa6KnBMAAKheNT6kZWRkqF+/ftY7xp555hndd999pdq3ZcuWioqKklT8nWrurFmzRlLhTFWLFi2KtfXs2dPa9lYnPT3derN/jx49XNpLW8e5zVudXbt2eQ17JdUBAADVp0aHtOzsbN14443avHmzJOnxxx/XxIkTS72/w+GwLon++OOPSk5OdtsvOTnZmnUaOHCgHA5HsfbY2FhrJmrRokXKzs52W+ett96ytuPj413aBwwYIB+fwn+S+fPnexx3UR0fHx8NGDDApX3QoEFuj+ksOztbixYtklQ4g1e0EgIAALCHGhvScnNzFR8fby1n9MADD+hf//pXmes8+OCD1pJR48aNc3kVxenTpzVu3DhJkq+vrx588EG3dR555BFJ0m+//aYJEya4tO/bt09Tp06VVLjYuruQFhkZqdtuu02StHLlSreLwi9evFgrV66UJA0bNsztygTx8fFq1aqVpMJ3nLlbt/TRRx/ViRMnrG0AAGAvDnPuauE1xM0336yPPvpIknT11VfrlVdecZnhcubn5+dxtighIcFanaBz586aOHGiWrdurX379unZZ5/Vli1brH7//ve/3dbIz89X7969rdB48803a/To0WrQoIFS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0eXPzZs3e7w0t337dv3www8ea1x77bWSCm9s37Jli8d+b775pse2yy+/3JqVe/vttz3O7J08eVKLFi2SJHXo0EFNmzb1WLOyOT996+1VFnPnzi31k7qLFy/2eN9aVlaWx3O99tprradCp02bVuJlVcAOCGkAaoz9+/dr9erVXvt89tln1rbz/WRt27bVkCFDJEnvv/++XnrpJa91Dhw4oAULFrj8vnfv3pIKX8/hrv3kyZMaOXKk19pjxoyxAuPdd9/tNsD85z//0YoVKzzW8Pf316hRoyQVPrH51FNPufQxxuj++++3wur999/vdVyVLSIiwgqSCxYsUE5OjkufTZs2We8lK4309HSNHz/ebdvDDz9sPSBw7733FmurX7++df7ffPONHnroIa+XrH/55RfrUi1QXbgnDUCN8d///ld9+vRRhw4dFB8fr7i4OF100UWSpLS0NC1cuNCaSbnssstcXk3x+uuvKzU1Vfv379f48eO1dOlS3XHHHbrkkkvk7++v48eP6/vvv9enn36qr776SvHx8brllluK1bj99tv1xBNPKDMzUyNHjtTevXvVr18/ORwOffvtt3rppZf0888/q3Pnzh5nyf7whz/ovvvu04wZM5Samqq4uDhNnDhRnTp1spaFmj17tuLi4rxemp08ebI++ugj7d+/X0888YS2bt2qO++8U02bNrWWhSp659wVV1yhu+++u7xfveXTTz/1unh9kVtvvVV+fn667bbb9Nprr+mHH35Qz5499fDDD6tNmzbKyMjQihUrNHPmTIWEhCgqKsrjJWJncXFxev3113XgwAHdc8891rJQr7/+ulauXCmp8NLmPffc47Lv//zP/2j16tXauHGjXn31VX399dcaPXq0LrvsMgUHB+vEiRPavn27vvjiCyUlJalTp05WEAaqRfUtdgDgQlTaBdZL2tfbp127dh6XfTpy5Ijp1atXqerceeedbmssWrTI1KlTx+0+gYGBZvHixSUusJ6bm2sGDx7s8dgtW7Y0+/btq5QF1nv06FFpC6yX9nPixAljjDG///67ueyyyzz2a9iwoVm9erXp3bu3kWR69+7tcvxzF1jv27ev13/7Q4cOeTyXzMxMr9+786dPnz5evwugqnG5E0CN0atXL3399ddKSEhQnz59FBMTo9DQUNWtW1dNmjRR3759NWvWLH333XceX50RGRmpNWvWaPny5brtttvUqlUrBQUFqW7duoqIiNCVV16p8ePHa/Xq1R7vCRsyZIi++eYbxcfHKyIiQn5+foqOjtbw4cO1adOmEt9oL0l169bVhx9+qHfffVe9evVSvXr1FBQUpPbt2+sf//iHvv32W7Vq1arEOi1atND333+vGTNmqHfv3mrUqJH1ffz5z3/Wu+++qzVr1pzXpzqd1atXT+vXr9dTTz2lTp06KSAgQCEhIWrfvr0eeeQRff/99yUu8eXMz8/PmoHr3r276tevr6CgIHXq1En/+te/tHnzZkVFRXncPzQ0VB9++KHWrl2rUaNGqW3btgoNDZWvr68aNmyoLl266L777tOKFSv0+eefV8ZXAJSbwxjungQAALAbZtIAAABsiJAGAABgQ4Q0AAAAGyKkAQAA2BAhDQAAwIYIaQAAADZESAMAALAhQhoAAIANEdIAAABsiJAGAABgQ4Q0AAAAGyKkAQAA2BAhDQAAwIYIaQAAADb0/wBRU2Vs4llCZwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 600x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot the distribution of the pseudo labels\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "\n",
    "# 假设L是你的LongTensor\n",
    "L = cls\n",
    "\n",
    "# 获取唯一值及其计数\n",
    "unique_elements, counts = torch.unique(L, return_counts=True)\n",
    "\n",
    "# 结合unique_elements和counts，然后根据counts排序\n",
    "combined = list(zip(unique_elements.numpy(), counts.numpy()))\n",
    "sorted_combined = sorted(combined, key=lambda x: x[1], reverse=True)  # 根据counts降序排序\n",
    "\n",
    "# 分解回sorted unique elements和sorted counts\n",
    "sorted_unique_elements, sorted_counts = zip(*sorted_combined)\n",
    "\n",
    "# 绘制排序后的结果\n",
    "plt.figure(figsize=(6, 6))\n",
    "plt.bar(range(len(sorted_unique_elements)), sorted_counts, tick_label=sorted_unique_elements)\n",
    "#plt.title('Element Counts Sorted')\n",
    "\n",
    "plt.xticks([])\n",
    "\n",
    "# 设置竖轴的格式为科学记数法\n",
    "#plt.ylim(1e2,1e5)\n",
    "ax = plt.gca()\n",
    "#ax.set_yscale('log')\n",
    "#ax.yaxis.set_major_formatter(LogFormatterSciNotation())\n",
    "ax.set_yscale('linear')  # 改为线性缩放\n",
    "ax.yaxis.set_major_formatter(plt.ScalarFormatter())\n",
    "\n",
    "plt.xlabel('Pseudo Label',fontsize=20)\n",
    "plt.ylabel('Count',fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.savefig('cluster0.pdf', format='pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "llava",
   "language": "python",
   "name": "llava"
  },
  "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.10.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
