{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "# Data\n",
    "relora_delta = [5693, 5723, 6050, 4942]\n",
    "full_models_delta = [1173, 1203, 2641, 0]\n",
    "projections = ['Q Projections', 'K Projections', 'V Projections', 'Down Projections']\n",
    "\n",
    "# Custom color palette\n",
    "colors = ['#E69F00', '#56B4E9', '#F0E442', '#009E73']\n",
    "\n",
    "# Create the bar plot\n",
    "fig, ax = plt.subplots(figsize=(6, 4))\n",
    "bar_width = 0.35\n",
    "index = np.arange(len(projections))\n",
    "\n",
    "relora = ax.bar(index, relora_delta, bar_width, label='ReLoRA', color=colors[0])\n",
    "full_models = ax.bar(index + bar_width, full_models_delta, bar_width, label='Full Models', color=colors[1])\n",
    "\n",
    "# Add labels and titles\n",
    "ax.set_xlabel('Projections')\n",
    "ax.set_ylabel('Delta')\n",
    "ax.set_title('Delta Comparison between ReLoRA and Full Models')\n",
    "ax.set_xticks(index + bar_width / 2)\n",
    "ax.set_xticklabels(projections)\n",
    "ax.legend()\n",
    "\n",
    "# Adjust spacing\n",
    "plt.tight_layout()\n",
    "\n",
    "# Save or display the plot\n",
    "plt.savefig('bar_plot.png', dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Data for the bar plot\n",
    "labels = ['ReLoRA', 'Full-Rank', 'LoRA']\n",
    "q_projections = [5693, 1173, 7680]\n",
    "k_projections = [5723, 1203, 7680]\n",
    "v_projections = [6050, 2641, 7681]\n",
    "down_projections = [4942, 0, 7680]\n",
    "\n",
    "# Custom color palette\n",
    "colors = ['#FF5C5C', '#FFB157', '#2EC4B6']\n",
    "\n",
    "# Plotting the bar plot\n",
    "fig, ax = plt.subplots(figsize=(8, 4))\n",
    "width = 0.2\n",
    "\n",
    "ax.bar(labels, q_projections, width, label='Q Projections', color=colors[0])\n",
    "ax.bar(labels, k_projections, width, label='K Projections', color=colors[1], bottom=q_projections)\n",
    "ax.bar(labels, v_projections, width, label='V Projections', color=colors[2], bottom=[q + k for q, k in zip(q_projections, k_projections)])\n",
    "ax.bar(labels, down_projections, width, label='Down Projections', color=colors[0], alpha=0.5, hatch='/')\n",
    "\n",
    "# Adding labels and title\n",
    "ax.set_ylabel('Number of Singular Values < 0.1')\n",
    "ax.set_title('Singular Values Comparison')\n",
    "ax.legend()\n",
    "\n",
    "# Adjusting layout and saving the plot\n",
    "plt.tight_layout()\n",
    "plt.savefig('singular_values_plot.png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "# Data\n",
    "methods = ['ReLoRA', 'Full-rank Training', 'LoRA']\n",
    "projections = ['$W_Q$', '$W_K$', '$W_V$', '$W_{up}$', '$W_{down}$']\n",
    "counts = [5693, 1173, 7680, 5723, 1203, 7680, 6050, 2641, 7681, 4884, 0, 7680, 4942, 0, 7680]\n",
    "\n",
    "# Custom color palette\n",
    "# colors = ['#E64B35', '#4DBBD5', '#00A087', '#3C5488', '#F39B7F']\n",
    "\n",
    "# Plotting\n",
    "fig, ax = plt.subplots(figsize=(5, 3))\n",
    "\n",
    "width = 0.2\n",
    "x = np.arange(len(projections))\n",
    "\n",
    "for i, method in enumerate(methods):\n",
    "    bars = ax.bar(x + i * width, counts[i::3], width, label=method, alpha=0.7)\n",
    "\n",
    "# Customize the plot\n",
    "ax.set_xticks(x + width)\n",
    "ax.set_xticklabels(projections)\n",
    "ax.set_ylabel('#Singular Values < 0.1')\n",
    "# ax.set_xlabel('Projections')\n",
    "ax.legend()\n",
    "\n",
    "# Adjust layout\n",
    "plt.tight_layout()\n",
    "\n",
    "# Save or display the plot\n",
    "plt.savefig('bar_plot.png', dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "# Data\n",
    "methods = ['Full-rank\\nTraining', 'ReLoRA', 'LoRA']\n",
    "projections = ['$W_Q$', '$W_K$', '$W_V$', '$W_{up}$', '$W_{down}$']\n",
    "counts = [1173, 5693, 7680, 1203, 5723, 7680, 2641, 6050, 7681, 0, 4884, 7680, 0, 4942, 7680]\n",
    "# divide by 12\n",
    "counts = [c // 12 for c in counts]\n",
    "\n",
    "# font 15\n",
    "plt.rc('font', size=13)\n",
    "\n",
    "# Custom color palette\n",
    "# colors = ['#E64B35', '#4DBBD5', '#00A087', '#3C5488', '#F39B7F']\n",
    "\n",
    "# Plotting\n",
    "fig, ax = plt.subplots(figsize=(8, 2.5), dpi=300)\n",
    "\n",
    "width = 0.2\n",
    "x = np.arange(len(projections))\n",
    "\n",
    "for i, method in enumerate(methods):\n",
    "    alpha = {\"ReLoRA\": 0.9, \"Full-rank\\nTraining\": 0.5, \"LoRA\": 0.5}\n",
    "    bars = ax.bar(x + i * width, counts[i::3], width, label=method, alpha=alpha[method])\n",
    "\n",
    "# Customize the plot\n",
    "ax.set_xticks(x + width)\n",
    "ax.set_xticklabels(projections)\n",
    "# ax.set_ylabel('# Singular Values < 0.1', fontsize=15)\n",
    "# ax.set_xlabel('Projections')\n",
    "# move legend to the right\n",
    "ax.legend(loc='center right', bbox_to_anchor=(1.3, 0.5))\n",
    "\n",
    "# ax.spines['top'].set_visible(False)\n",
    "# ax.spines['bottom'].set_visible(False)\n",
    "# ax.spines['left'].set_visible(False)\n",
    "# ax.spines['right'].set_visible(False)\n",
    "# ax.grid(axis='y', linestyle='--')\n",
    "\n",
    "# plt.subplots_adjust(left=0.15, right=10)  # Adjust the left and right spacing here\n",
    "\n",
    "# Adjust layout\n",
    "plt.tight_layout()\n",
    "\n",
    "# Save or display the plot\n",
    "plt.savefig(\"zero_signuar_values.pdf\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "# Data\n",
    "methods = ['Full-rank\\nTraining', 'ReLoRA', 'LoRA']\n",
    "projections = ['$W_Q$', '$W_K$', '$W_V$', '$W_{up}$', '$W_{down}$']\n",
    "counts = [1173, 5693, 7680, 1203, 5723, 7680, 2641, 6050, 7681, 0, 4884, 7680, 0, 4942, 7680]\n",
    "# divide by 12\n",
    "counts = [c // 12 for c in counts]\n",
    "\n",
    "# font 15\n",
    "plt.rc('font', size=13)\n",
    "\n",
    "# Custom color palette\n",
    "# colors = ['#E64B35', '#4DBBD5', '#00A087', '#3C5488', '#F39B7F']\n",
    "\n",
    "# Plotting\n",
    "fig, ax = plt.subplots(figsize=(8, 2.5), dpi=300)\n",
    "\n",
    "width = 0.2\n",
    "x = np.arange(len(projections))\n",
    "\n",
    "for i, method in enumerate(methods):\n",
    "    alpha = {\"ReLoRA\": 0.9, \"Full-rank\\nTraining\": 0.5, \"LoRA\": 0.5}\n",
    "    bars = ax.bar(x + i * width, counts[i::3], width, label=method, alpha=alpha[method])\n",
    "\n",
    "# Customize the plot\n",
    "ax.set_xticks(x + width)\n",
    "ax.set_xticklabels(projections)\n",
    "\n",
    "# Remove the zero tick from the y axis (only zero)\n",
    "# ax.set_yticks(ax.get_yticks()[1:])\n",
    "\n",
    "# ax.set_ylabel('# Singular Values < 0.1', fontsize=15)\n",
    "# ax.set_xlabel('Projections')\n",
    "# move legend to the right\n",
    "ax.legend(loc='center right', bbox_to_anchor=(1.3, 0.5))\n",
    "\n",
    "# add seaborn-like grid\n",
    "ax.grid(axis='y', linestyle='--')\n",
    "\n",
    "# plt.subplots_adjust(left=0.15, right=10)  # Adjust the left and right spacing here\n",
    "\n",
    "# Adjust layout\n",
    "plt.tight_layout()\n",
    "\n",
    "# Save or display the plot\n",
    "plt.savefig(\"zero_signuar_values.pdf\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "methods = ['ReLoRA', 'Full-rank Training', 'LoRA']\n",
    "projections = ['Q', 'K', 'V', 'Up', 'Down']\n",
    "\n",
    "counts = [\n",
    "    5693, 1173, 7680,  # Q Projections\n",
    "    5723, 1203, 7680,  # K Projections\n",
    "    6050, 2641, 7681,  # V Projections\n",
    "    4884, 0, 7680,     # Up Projections\n",
    "    4942, 0, 7680      # Down Projections\n",
    "]\n",
    "\n",
    "alpha = {'ReLoRA': 0.9, 'Full-rank Training': 0.5, 'LoRA': 0.5}\n",
    "\n",
    "width = 0.2  # the width of the bars\n",
    "x = np.arange(len(projections))  # the label locations\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "for i, method in enumerate(methods):\n",
    "    ax.bar(x + i * width, counts[i::3], width, label=method, alpha=alpha[method])\n",
    "\n",
    "# Add some text for labels, title and custom x-axis tick labels, etc.\n",
    "ax.set_xlabel('Projections')\n",
    "ax.set_ylabel('Number of singular values < 0.1')\n",
    "ax.set_title('Comparison of different methods for various projections')\n",
    "ax.set_xticks(x)\n",
    "ax.set_xticklabels(projections)\n",
    "ax.legend()\n",
    "\n",
    "fig.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.10.9"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
