{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "2403f5a8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "================================================================================\n",
      "RANKINGS BY DATASET\n",
      "================================================================================\n",
      "\n",
      "Aircraft:\n",
      "  1. PVTv2-B2     (84.14%)\n",
      "  2. Swin-T       (81.90%)\n",
      "  3. ViT-B        (78.39%)\n",
      "  4. PVT-M        (76.70%)\n",
      "  5. MoCov3-S     (76.04%)\n",
      "  6. PVT-S        (75.20%)\n",
      "  7. ViT-S        (73.12%)\n",
      "  8. DINO-S       (72.18%)\n",
      "  9. ViT-T        (71.26%)\n",
      "  10. PVT-T        (69.76%)\n",
      "\n",
      "Caltech:\n",
      "  1. PVT-M        (93.75%)\n",
      "  2. ViT-B        (93.47%)\n",
      "  3. PVTv2-B2     (93.13%)\n",
      "  4. PVT-S        (93.02%)\n",
      "  5. ViT-S        (92.70%)\n",
      "  6. Swin-T       (91.90%)\n",
      "  7. PVT-T        (90.04%)\n",
      "  8. MoCov3-S     (89.84%)\n",
      "  9. ViT-T        (89.39%)\n",
      "  10. DINO-S       (86.76%)\n",
      "\n",
      "Cars:\n",
      "  1. PVTv2-B2     (90.60%)\n",
      "  2. ViT-B        (89.26%)\n",
      "  3. Swin-T       (88.93%)\n",
      "  4. PVT-M        (87.66%)\n",
      "  5. PVT-S        (87.61%)\n",
      "  6. ViT-S        (86.72%)\n",
      "  7. PVT-T        (84.10%)\n",
      "  8. MoCov3-S     (82.18%)\n",
      "  9. ViT-T        (82.09%)\n",
      "  10. DINO-S       (79.81%)\n",
      "\n",
      "CF-10:\n",
      "  1. ViT-B        (98.56%)\n",
      "  2. PVTv2-B2     (97.96%)\n",
      "  3. DINO-S       (97.96%)\n",
      "  4. PVT-M        (97.93%)\n",
      "  5. MoCov3-S     (97.92%)\n",
      "  6. ViT-S        (97.69%)\n",
      "  7. PVT-S        (97.34%)\n",
      "  8. Swin-T       (97.34%)\n",
      "  9. ViT-T        (96.52%)\n",
      "  10. PVT-T        (94.87%)\n",
      "\n",
      "CF-100:\n",
      "  1. ViT-B        (89.96%)\n",
      "  2. PVTv2-B2     (88.24%)\n",
      "  3. PVT-M        (87.36%)\n",
      "  4. ViT-S        (86.62%)\n",
      "  5. PVT-S        (86.20%)\n",
      "  6. Swin-T       (85.97%)\n",
      "  7. MoCov3-S     (85.84%)\n",
      "  8. DINO-S       (85.66%)\n",
      "  9. ViT-T        (81.58%)\n",
      "  10. PVT-T        (75.26%)\n",
      "\n",
      "DTD:\n",
      "  1. ViT-B        (77.66%)\n",
      "  2. PVTv2-B2     (77.16%)\n",
      "  3. PVT-M        (77.10%)\n",
      "  4. Swin-T       (77.04%)\n",
      "  5. DINO-S       (75.96%)\n",
      "  6. PVT-S        (75.77%)\n",
      "  7. ViT-S        (75.08%)\n",
      "  8. PVT-T        (72.92%)\n",
      "  9. MoCov3-S     (71.88%)\n",
      "  10. ViT-T        (71.86%)\n",
      "\n",
      "Flowers:\n",
      "  1. ViT-B        (97.98%)\n",
      "  2. PVTv2-B2     (97.89%)\n",
      "  3. Swin-T       (97.40%)\n",
      "  4. PVT-M        (97.36%)\n",
      "  5. PVT-S        (97.32%)\n",
      "  6. ViT-S        (96.79%)\n",
      "  7. DINO-S       (95.96%)\n",
      "  8. PVT-T        (95.80%)\n",
      "  9. ViT-T        (95.50%)\n",
      "  10. MoCov3-S     (93.89%)\n",
      "\n",
      "Food:\n",
      "  1. ViT-B        (88.96%)\n",
      "  2. PVTv2-B2     (88.67%)\n",
      "  3. PVT-S        (86.98%)\n",
      "  4. Swin-T       (86.67%)\n",
      "  5. ViT-S        (86.26%)\n",
      "  6. DINO-S       (85.69%)\n",
      "  7. PVT-M        (85.56%)\n",
      "  8. PVT-T        (83.78%)\n",
      "  9. MoCov3-S     (82.84%)\n",
      "  10. ViT-T        (81.96%)\n",
      "\n",
      "Pets:\n",
      "  1. ViT-B        (94.61%)\n",
      "  2. Swin-T       (94.50%)\n",
      "  3. PVT-M        (94.48%)\n",
      "  4. PVT-S        (94.13%)\n",
      "  5. ViT-S        (94.02%)\n",
      "  6. PVTv2-B2     (93.86%)\n",
      "  7. DINO-S       (92.59%)\n",
      "  8. PVT-T        (91.48%)\n",
      "  9. ViT-T        (91.44%)\n",
      "  10. MoCov3-S     (90.44%)\n",
      "\n",
      "SUN:\n",
      "  1. ViT-B        (68.62%)\n",
      "  2. PVT-M        (67.22%)\n",
      "  3. PVTv2-B2     (66.44%)\n",
      "  4. PVT-S        (65.78%)\n",
      "  5. Swin-T       (65.51%)\n",
      "  6. ViT-S        (64.76%)\n",
      "  7. DINO-S       (64.14%)\n",
      "  8. PVT-T        (61.86%)\n",
      "  9. MoCov3-S     (60.60%)\n",
      "  10. ViT-T        (58.40%)\n",
      "\n",
      "VOC:\n",
      "  1. ViT-B        (87.88%)\n",
      "  2. Swin-T       (87.54%)\n",
      "  3. PVT-M        (87.36%)\n",
      "  4. ViT-S        (86.62%)\n",
      "  5. PVT-S        (86.62%)\n",
      "  6. PVTv2-B2     (86.44%)\n",
      "  7. DINO-S       (84.80%)\n",
      "  8. PVT-T        (84.60%)\n",
      "  9. ViT-T        (83.10%)\n",
      "  10. MoCov3-S     (81.84%)\n",
      "\n",
      "================================================================================\n",
      "RANK FREQUENCY SUMMARY\n",
      "================================================================================\n",
      "\n",
      "Rank Frequency Table:\n",
      "Model        Rank- 1  Rank- 2  Rank- 3  Rank- 4  Rank- 5  Rank- 6  Rank- 7  Rank- 8  Rank- 9  Rank-10   Avg_Rank\n",
      "--------------------------------------------------------------------------------\n",
      "ViT-B             8       2       1       0       0       0       0       0       0       0      1.36\n",
      "PVTv2-B2          2       5       2       0       0       2       0       0       0       0      2.73\n",
      "PVT-M             1       1       4       4       0       0       1       0       0       0      3.45\n",
      "Swin-T            0       3       2       2       1       2       0       1       0       0      4.09\n",
      "PVT-S             0       0       1       3       4       2       1       0       0       0      4.91\n",
      "ViT-S             0       0       0       2       3       4       2       0       0       0      5.55\n",
      "DINO-S            0       0       1       0       1       1       4       2       0       2      7.09\n",
      "MoCov3-S          0       0       0       0       2       0       1       2       3       3      8.18\n",
      "PVT-T             0       0       0       0       0       0       2       6       0       3      8.36\n",
      "ViT-T             0       0       0       0       0       0       0       0       8       3      9.27\n",
      "\n",
      "================================================================================\n",
      "DETAILED ANALYSIS FOR ViT-B\n",
      "================================================================================\n",
      "ViT-B Performance Summary:\n",
      "Total datasets: 11\n",
      "\n",
      "Rank 1:  8 times ( 72.7%)\n",
      "Rank 2:  2 times ( 18.2%)\n",
      "Rank 3:  1 times (  9.1%)\n",
      "Rank 4:  0 times (  0.0%)\n",
      "Rank 5:  0 times (  0.0%)\n",
      "Rank 6:  0 times (  0.0%)\n",
      "Rank 7:  0 times (  0.0%)\n",
      "Rank 8:  0 times (  0.0%)\n",
      "Rank 9:  0 times (  0.0%)\n",
      "Rank 10:  0 times (  0.0%)\n",
      "\n",
      "ViT-B Average Rank: 1.36\n",
      "\n",
      "Datasets where ViT-B ranked 1st:\n",
      "  • CF-10: 98.56%\n",
      "  • CF-100: 89.96%\n",
      "  • DTD: 77.66%\n",
      "  • Flowers: 97.98%\n",
      "  • Food: 88.96%\n",
      "  • Pets: 94.61%\n",
      "  • SUN: 68.62%\n",
      "  • VOC: 87.88%\n",
      "\n",
      "================================================================================\n",
      "OVERALL RANKING STATISTICS\n",
      "================================================================================\n",
      "Most 1st place finishes:\n",
      "  1. ViT-B       :  8 wins ( 72.7%)\n",
      "  2. PVTv2-B2    :  2 wins ( 18.2%)\n",
      "  3. PVT-M       :  1 wins (  9.1%)\n",
      "  4. Swin-T      :  0 wins (  0.0%)\n",
      "  5. MoCov3-S    :  0 wins (  0.0%)\n",
      "\n",
      "Best average rank:\n",
      "  1. ViT-B       : 1.36\n",
      "  2. PVTv2-B2    : 2.73\n",
      "  3. PVT-M       : 3.45\n",
      "  4. Swin-T      : 4.09\n",
      "  5. PVT-S       : 4.91\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "# Load the CSV data\n",
    "df = pd.read_csv('emms.csv')\n",
    "\n",
    "# Function to get rankings for each dataset\n",
    "def get_model_rankings(df):\n",
    "    \"\"\"Get the rank of each model on each dataset\"\"\"\n",
    "    rankings = {}\n",
    "    \n",
    "    # For each dataset (column), rank models from best (1) to worst\n",
    "    for col in df.columns[1:]:  # Skip 'Model' column\n",
    "        # Sort by accuracy descending and get ranks (1 = best)\n",
    "        dataset_ranks = df[['Model', col]].sort_values(col, ascending=False).reset_index(drop=True)\n",
    "        dataset_ranks['Rank'] = range(1, len(dataset_ranks) + 1)\n",
    "        \n",
    "        rankings[col] = dict(zip(dataset_ranks['Model'], dataset_ranks['Rank']))\n",
    "    \n",
    "    return rankings\n",
    "\n",
    "# Function to count rank frequencies for each model\n",
    "def count_rank_frequencies(rankings_dict):\n",
    "    \"\"\"Count how many times each model gets each rank\"\"\"\n",
    "    \n",
    "    models = list(rankings_dict[list(rankings_dict.keys())[0]].keys())\n",
    "    datasets = list(rankings_dict.keys())\n",
    "    \n",
    "    rank_counts = {}\n",
    "    \n",
    "    for model in models:\n",
    "        rank_counts[model] = {}\n",
    "        for rank in range(1, len(models) + 1):\n",
    "            rank_counts[model][rank] = 0\n",
    "        \n",
    "        # Count ranks across all datasets\n",
    "        for dataset in datasets:\n",
    "            model_rank = rankings_dict[dataset][model]\n",
    "            rank_counts[model][model_rank] += 1\n",
    "    \n",
    "    return rank_counts\n",
    "\n",
    "# Get rankings and count frequencies\n",
    "rankings = get_model_rankings(df)\n",
    "rank_frequencies = count_rank_frequencies(rankings)\n",
    "\n",
    "# Display detailed rankings for each dataset\n",
    "print(\"=\"*80)\n",
    "print(\"RANKINGS BY DATASET\")\n",
    "print(\"=\"*80)\n",
    "\n",
    "for dataset in df.columns[1:]:\n",
    "    print(f\"\\n{dataset}:\")\n",
    "    dataset_ranking = [(model, rank) for model, rank in rankings[dataset].items()]\n",
    "    dataset_ranking.sort(key=lambda x: x[1])  # Sort by rank\n",
    "    \n",
    "    for i, (model, rank) in enumerate(dataset_ranking):\n",
    "        accuracy = df[df['Model'] == model][dataset].iloc[0]\n",
    "        print(f\"  {rank}. {model:<12} ({accuracy:.2f}%)\")\n",
    "\n",
    "# Create summary table\n",
    "print(\"\\n\" + \"=\"*80)\n",
    "print(\"RANK FREQUENCY SUMMARY\")\n",
    "print(\"=\"*80)\n",
    "\n",
    "# Convert to DataFrame for better display\n",
    "rank_df = pd.DataFrame(rank_frequencies).T\n",
    "rank_df = rank_df.fillna(0).astype(int)\n",
    "\n",
    "# Sort by average rank (lower is better)\n",
    "rank_df['Avg_Rank'] = sum(rank_df[col] * col for col in rank_df.columns) / rank_df.sum(axis=1)\n",
    "rank_df = rank_df.sort_values('Avg_Rank')\n",
    "\n",
    "print(\"\\nRank Frequency Table:\")\n",
    "print(\"Model        \", end=\"\")\n",
    "for rank in range(1, len(df) + 1):\n",
    "    print(f\"Rank-{rank:2d}\", end=\"  \")\n",
    "print(\" Avg_Rank\")\n",
    "print(\"-\" * 80)\n",
    "\n",
    "for model in rank_df.index:\n",
    "    print(f\"{model:<12}\", end=\" \")\n",
    "    for rank in range(1, len(df) + 1):\n",
    "        count = rank_df.loc[model, rank] if rank in rank_df.columns else 0\n",
    "        print(f\"{count:6d}\", end=\"  \")\n",
    "    print(f\"{rank_df.loc[model, 'Avg_Rank']:8.2f}\")\n",
    "\n",
    "# Specific analysis for ViT-B\n",
    "print(\"\\n\" + \"=\"*80)\n",
    "print(\"DETAILED ANALYSIS FOR ViT-B\")\n",
    "print(\"=\"*80)\n",
    "\n",
    "vit_b_ranks = rank_frequencies['ViT-B']\n",
    "total_datasets = len(df.columns) - 1\n",
    "\n",
    "print(f\"ViT-B Performance Summary:\")\n",
    "print(f\"Total datasets: {total_datasets}\")\n",
    "print()\n",
    "\n",
    "for rank in sorted(vit_b_ranks.keys()):\n",
    "    count = vit_b_ranks[rank]\n",
    "    percentage = (count / total_datasets) * 100\n",
    "    print(f\"Rank {rank}: {count:2d} times ({percentage:5.1f}%)\")\n",
    "\n",
    "print(f\"\\nViT-B Average Rank: {rank_df.loc['ViT-B', 'Avg_Rank']:.2f}\")\n",
    "\n",
    "# Show which datasets ViT-B ranked 1st on\n",
    "print(f\"\\nDatasets where ViT-B ranked 1st:\")\n",
    "first_rank_datasets = [dataset for dataset, ranks in rankings.items() if ranks['ViT-B'] == 1]\n",
    "if first_rank_datasets:\n",
    "    for dataset in first_rank_datasets:\n",
    "        accuracy = df[df['Model'] == 'ViT-B'][dataset].iloc[0]\n",
    "        print(f\"  • {dataset}: {accuracy:.2f}%\")\n",
    "else:\n",
    "    print(\"  None\")\n",
    "\n",
    "# Overall ranking statistics\n",
    "print(\"\\n\" + \"=\"*80)\n",
    "print(\"OVERALL RANKING STATISTICS\")\n",
    "print(\"=\"*80)\n",
    "\n",
    "print(\"Most 1st place finishes:\")\n",
    "first_place_counts = {model: counts[1] for model, counts in rank_frequencies.items()}\n",
    "sorted_first_places = sorted(first_place_counts.items(), key=lambda x: x[1], reverse=True)\n",
    "\n",
    "for i, (model, count) in enumerate(sorted_first_places[:5]):\n",
    "    percentage = (count / total_datasets) * 100\n",
    "    print(f\"  {i+1}. {model:<12}: {count:2d} wins ({percentage:5.1f}%)\")\n",
    "\n",
    "print(f\"\\nBest average rank:\")\n",
    "best_avg_ranks = rank_df['Avg_Rank'].sort_values()\n",
    "for i, (model, avg_rank) in enumerate(best_avg_ranks.head(5).items()):\n",
    "    print(f\"  {i+1}. {model:<12}: {avg_rank:.2f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acd3d929",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "newmol",
   "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.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
