{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "79cb4b9b",
   "metadata": {},
   "source": [
    "# Class Distribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf808229",
   "metadata": {},
   "outputs": [],
   "source": [
    "from datasets import load_dataset, concatenate_datasets\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import numpy as np\n",
    "\n",
    "sns.set_theme(style=\"whitegrid\")\n",
    "\n",
    "HF_REPO = \"hamzamooraj99/AgriPath-LF16-30k\"\n",
    "NUM_CLASSES = 65"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d76189a4",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = load_dataset(HF_REPO)\n",
    "dataset = concatenate_datasets([\n",
    "    dataset[\"train\"],\n",
    "    dataset[\"validation\"],\n",
    "    dataset[\"test\"]\n",
    "])\n",
    "\n",
    "print(f\"Columns: {dataset.column_names}\")\n",
    "# print(f\"Columns: {large_dataset.column_names}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb64490d",
   "metadata": {},
   "outputs": [],
   "source": [
    "keep_cols = [\"numeric_label\", \"source\"]\n",
    "drop_cols = [c for c in dataset.column_names if c not in keep_cols]\n",
    "dataset_small = dataset.remove_columns(drop_cols)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c2c70114",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = dataset_small.to_pandas()\n",
    "df[\"numeric_label\"] = df[\"numeric_label\"].astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "da5b7ede",
   "metadata": {},
   "outputs": [],
   "source": [
    "counts = (\n",
    "    df.groupby([\"numeric_label\", \"source\"])\n",
    "      .size()\n",
    "      .unstack(fill_value=0)\n",
    "      .reindex(range(NUM_CLASSES), fill_value=0)\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a966e792",
   "metadata": {},
   "outputs": [],
   "source": [
    "lab_counts   = counts.get(\"lab\", pd.Series([0]*NUM_CLASSES, index=range(NUM_CLASSES))).to_numpy()\n",
    "field_counts = counts.get(\"field\", pd.Series([0]*NUM_CLASSES, index=range(NUM_CLASSES))).to_numpy()\n",
    "x = np.arange(NUM_CLASSES)\n",
    "\n",
    "COLOR_LAB = \"#4C72B0\"    # blue\n",
    "COLOR_FIELD = \"#DD8452\"  # orange\n",
    "\n",
    "plt.figure(figsize=(18, 5))\n",
    "plt.bar(x, lab_counts, label=\"lab\", color=COLOR_LAB)\n",
    "plt.bar(x, field_counts, bottom=lab_counts, label=\"field\", color=COLOR_FIELD)\n",
    "\n",
    "plt.xticks(x, [str(i) for i in x], rotation=0, fontsize=13)  # show 0–64 explicitly\n",
    "plt.ylim(0, 550)\n",
    "plt.xlabel(\"Numeric label (0–64)\")\n",
    "plt.ylabel(\"Count\")\n",
    "# plt.title(\"Class distribution (lab vs field)\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "unsloth_env",
   "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.11.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
