{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "e763e9e3-3a25-4c8f-918e-31be7e00d4de",
   "metadata": {},
   "source": [
    "<hr>\n",
    "\n",
    "***Version: 1001.1792024.qut.cs.tnl***\n",
    "\n",
    "***Sk Tanzir Mehedi, PhD Student, QUT***\n",
    "\n",
    "***Supervisory Team: Prof. Raja Jurdak & Dr Chadni Islam***\n",
    "<hr>"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8c753dce-50dc-4930-8a0f-82ff92ebe176",
   "metadata": {},
   "source": [
    "**----Start of Step 4 Analysis----**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "773732cc-ef27-4649-9ce8-3dbfa76703fb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy for Sequence Matcher: 81.06%\n",
      "Accuracy for Cosine Similarity: 5.30%\n",
      "Accuracy for Jaccard Similarity: 58.31%\n",
      "Accuracy for Levenshtein Distance: 73.06%\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "from difflib import SequenceMatcher\n",
    "\n",
    "df_combined = pd.read_excel('D:/Final Version/Step 4 SimilarityAlgorithms/SimilarityAlgorithmsOutput.xlsx')\n",
    "\n",
    "def calculate_similarity(str1, str2):\n",
    "    str1 = str(str1)\n",
    "    str2 = str(str2)\n",
    "    return SequenceMatcher(None, str1, str2).ratio()\n",
    "\n",
    "similarity_threshold = 0.7\n",
    "\n",
    "total_entries = len(df_combined)\n",
    "accuracies = {\n",
    "    'Sequence Matcher': 0,\n",
    "    'Cosine Similarity': 0,\n",
    "    'Jaccard Similarity': 0,\n",
    "    'Levenshtein Distance': 0,\n",
    "}\n",
    "\n",
    "for index, row in df_combined.iterrows():\n",
    "    malicious_name = str(row['Malicious Package Name'])\n",
    "\n",
    "    # Compare with Sequence Matcher\n",
    "    sequence_name = str(row['Benign Package Name SM'])\n",
    "    if calculate_similarity(malicious_name, sequence_name) >= similarity_threshold:\n",
    "        accuracies['Sequence Matcher'] += 1\n",
    "\n",
    "    # Compare with Cosine Similarity\n",
    "    cosine_name = str(row['Benign Package Name CS'])\n",
    "    if calculate_similarity(malicious_name, cosine_name) >= similarity_threshold:\n",
    "        accuracies['Cosine Similarity'] += 1\n",
    "\n",
    "    # Compare with Jaccard Similarity\n",
    "    jaccard_name = str(row['Benign Package Name JS'])\n",
    "    if calculate_similarity(malicious_name, jaccard_name) >= similarity_threshold:\n",
    "        accuracies['Jaccard Similarity'] += 1\n",
    "\n",
    "    # Compare with Levenshtein Distance\n",
    "    levenshtein_name = str(row['Benign Package Name LS'])\n",
    "    if calculate_similarity(malicious_name, levenshtein_name) >= similarity_threshold:\n",
    "        accuracies['Levenshtein Distance'] += 1\n",
    "\n",
    "for method in accuracies:\n",
    "    accuracy_percentage = (accuracies[method] / total_entries) * 100\n",
    "    print(f\"Accuracy for {method}: {accuracy_percentage:.2f}%\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0ad86f52-6dff-46cb-92a0-41df96a281d0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Dh06aOrUqdq0aZNq1Khh73Pu3DnVqVNHe/bsUffu3VW1alX99ddfWrJkiY4eParChQsrNTVVjz32mGJiYtS+fXv1799fZ8+e1cqVK7Vr1y6FhYVlu7bLly8rMjJStWvX1htvvKH8+fNL+vcw4n/++Ue9e/eWn5+ffv75Z02ePFlHjx7VwoUL7c/fuXOn6tSpo3z58qlnz54qXry49u/fr6VLl+rVV19VvXr1VLRoUUVHR6tly5bplktYWJjCw8MzrS8+Pl4PPvig/vnnH/Xr109+fn6aM2eOHn/8cX3++edq2bKl6tatq7lz56pz5872Q8ZvRbFixfTQQw9p1apVSkpKkre3d7o+w4YNU+nSpTV9+nS98sorCg0NVVhYmFq0aKGPP/5YixYt0tSpU+Xp6amKFStK+vfial26dFFkZKQmTJigf/75R1OnTlXt2rW1bds2h8OWM3tfevXqpdmzZ6tbt27q16+fDh48qClTpmjbtm366aefHA793bdvn5544gn16NFDXbp00cyZM9W1a1dVq1ZN5cuXV926ddWvXz+9++67eumll1S2bFlJsv83IyEhIYqJidHRo0d177333tTybdeuncqWLavx48frm2++0dixY+Xr66sPPvhAjzzyiCZMmKDo6GgNGjRINWrUUN26dbM1/tSpU1W+fHk9/vjjcnFx0dKlS/W///1PaWlp6tOnj0PfvXv3qkOHDurVq5eefvrpDEPy9ZZT586d9fHHH2vFihV67LHH7M85ceKEfvjhhywd0XLs2DGtWrXKHoA7dOigt99+W1OmTMnwjxvXzmvfvn1Vp04dPffcczp06JBatGihQoUKObw/Fy5cUL169bRv3z717dtXoaGhWrhwobp27aqEhAT179/fYdxZs2bp4sWL6tmzp9zc3OTr66u0tDSHPr169dKxY8e0cuVKzZ07N8P65s+fr7Nnz6pXr16y2WyaOHGiWrVqpQMHDjh8VlNTU9W4cWPVrVtXEydOVHR0tPr27asCBQpo2LBh6tixo1q1aqVp06YpKipK4eHhCg0NlfTvH3PGjRunp556SjVr1lRSUpI2b96srVu3qmHDhjdc/gBgKQMAsNzmzZuNJLNy5UpjjDFpaWnm3nvvNf3793foN2LECCPJfPnll+nGSEtLM8YYM3PmTCPJvPXWW5n2WbVqlZFkVq1a5TD94MGDRpKZNWuWva1Lly5GknnxxRfTjffPP/+kaxs3bpyx2Wzm8OHD9ra6desaLy8vh7ar6zHGmKFDhxo3NzeTkJBgbzt58qRxcXExI0eOTPc6VxswYICRZNauXWtvO3v2rAkNDTXFixc3qamp9nZJpk+fPtcdL6t9+/fvbySZHTt2GGMyXn6zZs0yksymTZscnjty5EgjyZw6dcqh5oIFC5qnn37aoe+JEyeMj4+PQ3tm78vatWuNJBMdHe3Qvnz58nTtISEhRpJZs2aNve3kyZPGzc3NPP/88/a2hQsXZvh5ycxHH31kJBlXV1fz8MMPm+HDh5u1a9c6vA9XSHJ4f68sl549e9rbLl++bO69915js9nM+PHj7e1///238fDwMF26dLG3ZfQeXBnzahl9diMjI02JEiUc2q4so+XLl6frHxIS4vDamS2n1NRUc++995p27do5tL/11lvGZrOZAwcOpBv7Wm+88Ybx8PAwSUlJxhhjfv/9dyPJLFq0yKHftet2cnKy8fPzMzVq1DApKSn2frNnzzaSzEMPPWRvmzRpkpFk5s2bZ2+7dOmSCQ8PN56envbXvrKMvb29zcmTJx1eP6Pl36dPn3TL/+q+fn5+5syZM/b2r776ykgyS5cutbdd+by/9tpr9rYr77/NZjMLFiywt//222/pPleVKlUyTZs2TVcDANwJOLwcAG6D6OhoBQQE6OGHH5b072GY7dq104IFC5Sammrv98UXX6hSpUrp9gZfec6VPoULF9azzz6baZ+b0bt373RtHh4e9v8/f/68/vrrLz344IMyxmjbtm2SpFOnTmnNmjXq3r27ihUrlmk9UVFRSk5O1ueff25v+/TTT3X58uV051Rf69tvv1XNmjVVu3Zte5unp6d69uypQ4cOZflK49nl6ekpSTp79myOjLdy5UolJCSoQ4cO+uuvv+z/nJ2dVatWLa1atSrdc659XxYuXCgfHx81bNjQYYxq1arJ09Mz3RjlypVTnTp17I/9/f1VunRpHThw4Kbno3v37lq+fLnq1aunH3/8UWPGjFGdOnVUsmRJrVu3LktjPPXUU/b/d3Z2VvXq1WWMUY8ePeztBQsWvOlar/7sJiYm6q+//tJDDz2kAwcOKDEx0aFvaGioIiMjs/0aVzg5Oaljx45asmSJw2clOjpaDz74oH1v7PVER0eradOm8vLykiSV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3aG7X79+WrJkib777jslJycrJCREY8eO1eDBg29rHQCQEZvJqSupAACQBZcvX1ZwcLCaNWumjz76KLfLAXLUV199pRYtWmjNmjUOt2q73dLS0uTv769WrVppxowZuVYHAIBzugEAt9nixYt16tQph4uzAXeLGTNmqESJEg73lLfaxYsX010/4eOPP9aZM2dUr16921YHACBjHF4OALgtNm7cqJ07d2rMmDGqUqXKTV+0CbgTLViwQDt37tQ333yjd95557Ze0XvDhg167rnn1KZNG/n5+Wnr1q366KOPdP/996tNmza3rQ4AQMY4vBwAcFt07dpV8+bNU+XKlTV79uwsn1sO5AU2m02enp5q166dpk2bdlvPaz906JD69eunn3/+WWfOnJGvr6+aNGmi8ePHZ3pePgDg9snV0L1mzRq9/vrr2rJli44fP65FixapRYsW9unGGI0cOVIzZsxQQkKCIiIiNHXqVJUsWdLe58yZM3r22We1dOlSOTk5qXXr1nrnnXfk6emZC3MEAAAAAMD/ydVzus+fP69KlSrpvffey3D6xIkT9e6772ratGnauHGjChQooMjISF28eNHep2PHjvr111+1cuVKff3111qzZo169ux5u2YBAAAAAIBM3TGHl9tsNoc93cYYBQcH6/nnn9egQYMkSYmJiQoICNDs2bPVvn177dmzR+XKldOmTZtUvXp1SdLy5cvVpEkTHT16VMHBwbk1OwAAAAAA3LkXUjt48KBOnDihBg0a2Nt8fHxUq1YtrV+/Xu3bt9f69etVsGBBe+CWpAYNGsjJyUkbN25Uy5YtMxw7OTlZycnJ9sdpaWk6c+aM/Pz8buuFTwAAAAAAeZMxRmfPnlVwcLCcnDI/iPyODd0nTpyQJAUEBDi0BwQE2KedOHEi3QVCXFxc5Ovra++TkXHjxmn06NE5XDEAAAAA4L/myJEjuvfeezOdfseGbisNHTpUAwcOtD9OTExUsWLFdOTIEXl7e+diZQAAAACAvCApKUlFixaVl5fXdfvdsaE7MDBQkhQfH6+goCB7e3x8vCpXrmzvc/LkSYfnXb58WWfOnLE/PyNubm5yc3NL1+7t7U3oBgAAAABk2Y1OUc7Vq5dfT2hoqAIDAxUTE2NvS0pK0saNGxUeHi5JCg8PV0JCgrZs2WLv88MPPygtLU21atW67TUDAAAAAHC1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tWrV0uzZs1W6dGkdP35co0ePVp06dbRr1y55eXnps88+U7t27eTn5ycXFxflz59fixYt0n333XfdcX/55ReFh4fr4sWL8vT01KJFi1SuXLks19W9e3ft3LlT5cqVU+HChfXZZ5/p77//1ogRIxQbG6uXX35ZCxYsUFhYmGbOnKl77rnnVhcFAPwn3PF7uv/880916tRJfn5+8vDwUIUKFRzOJzLGaMSIEQoKCpKHh4caNGigP/74IxcrBgAAyFzjxo3Vpk0bVaxYUZGRkfr222+VkJCgzz77TJI0fPhwJSQk6Pvvv9fmzZs1cOBAtW3bVr/88st1xy1durS2b9+ujRs3qnfv3urSpYt2796d5bry5cun9957TwcPHtSmTZtUu3ZtPf/88+rXr5+2bdumxYsXa8eOHXrggQfUr1+/W1oGAPBfckeH7r///lsRERHKly+fli1bpt27d+vNN99UoUKF7H0mTpyod999V9OmTdPGjRtVoEABRUZG6uLFi7lYOQAAQNYULFhQpUqV0r59+7R//35NmTJFM2fOVP369VWpUiWNHDlS1atX13vvvXfdcVxdXXXfffepWrVqGjdunCpVqqR33nnnputatWqVfv31V/Xt21exsbFq0qSJChQooLZt22Z6XjgAIL07+vDyCRMmqGjRopo1a5a9LTQ01P7/xhhNmjRJL7/8spo3by5J+vjjjxUQEKDFixerffv2t71mAACA7Dh37pz279+vzp07659//pEkOTk57hdxdnZWWlpatsZNS0tTcnLyTdV08eJF9enTR9HR0XJ2dlZqaqqMMZKklJQUpaam3tS4APBfdEfv6V6yZImqV6+uNm3aqEiRIqpSpYpmzJhhn37w4EGdOHFCDRo0sLf5+PioVq1aWr9+fabjJicnKykpyeEfAADA7TBo0CCtXr1ahw4d0rp169SyZUs5OzurQ4cOKlOmjO677z716tVLP//8s/bv368333xTK1euVIsWLexj1K9fX1OmTLE/Hjp0qNasWaNDhw7pl19+0dChQxUbG6uOHTva+5w4cULbt2/Xvn37JP17Dvj27dt15syZdDWOGTNGTZo0sV8tPSIiQl9++aV27typKVOmKCIiwqKlAwB3nzt6T/eBAwc0depUDRw4UC+99JI2bdqkfv36ydXVVV26dNGJEyckSQEBAQ7PCwgIsE/LyLhx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mTNnGmP+bzvzxRdfmHr16hkPDw9TsWJFs27dOmOMyfSzZkzWf4dekZVt6bWu/txf7Z9//jGlS5c2ERERmb4XCxcuNPfff79xd3c3vr6+pn79+ubcuXNm5MiR6ebpSt3X+02a1XlITU01EyZMMGFhYcbV1dUULVrUjB071j49Li7OtGnTxvj4+JhChQqZxx9/3Bw8eDDTZfBfwuHlkCR5enrK09NTixcvVnJycqb92rRpo5MnT2rZsmXasmWLqlatqvr169v38H722WcaNWqUXnvtNW3evFlBQUF6//33s11P3759tX79ei1YsEA7d+5UmzZt1KhRI/3xxx/2Pv/884/eeOMNzZ07V2vWrFFcXJwGDRpknz516lT16dNHPXv21C+//KIlS5bovvvuy/K8ZKZatWoqXry4vvjiC0lSXFyc1qxZo86dO6fr6+XlpdmzZ2v37t165513NGPGDL399tuS/j006fnnn1f58uV1/PhxHT9+XO3atVNaWpoaN26sn376SfPmzdPu3bs1fvx4OTs7Z3neo6OjNWLECL366qvas2ePXnvtNQ0fPlxz5sxxqO/FF19U//79tWfPHkVGRmblrYFFzpw5o+XLl6tPnz4qUKBAuulXDn9LS0tT8+bNdebMGa1evVorV67UgQMH1K5dO3vfjh076t5779WmTZu0ZcsWvfjii9c9imH//v1avHixvv76a3399ddavXq1xo8fb58+btw4ffzxx5o2bZp+/fVXPffcc+rUqZNWr16d4Xj+/v5ycnLS559/rtTU1Gwth1GjRmnKlClat26djhw5orZt22rSpEmaP3++vvnmG3333XeaPHlylsdzcnLSu+++q19//VVz5szRDz/8oCFDhjj0+eeffzRhwgR9+OGH+vXXX1WkSBGH6e+8847Cw8P19NNP29fVYsWKqXv37po1a5ZD31mzZqlu3boO3zW4M50/f14DBw7U5s2bFRMTIycnJ7Vs2VJpaWmSpHPnzumhhx7Sn3/+qSVLlmjHjh0aMmSIffo333yjli1bqkmTJtq2bZtiYmJUs2ZN+/gpKSkaM2aMduzYocWLF+vQoUPq2rVrujpefPFFjR8/Xnv27FHFihU1ePBgrV69Wl999ZW+++47xcbGauvWrdedl8DAQP3www86depUtpbB22+/rYiICG3btk1NmzZV586dFRUVpU6d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ijp69Kh+//336+7tzkxAQICCg4N14MAB+3lTuPP5+voqMjJS7733nvr165fuR2lCQoIKFiyosmXL6siRIzpy5Ih9b/fu3buVkJCgcuXK2fuXKlVKpUqV0nPPPacOHTpo1qxZmYbu6ylXrpzc3NwUFxdn31N3M2w2m8qUKZPhXgirbNmyRWlpaXrzzTfte1Y+++yzmxoro3VVkpo0aaICBQpo6tSpWr58udasWXNLNeP2OH36tPbu3asZM2bYtzM//vijQ5+KFSvqww8/1JkzZzLc212xYkXFxMRkeD7xb7/9ptOnT2v8+PH29XTz5s03rCssLEz58uXTxo0bVaxYMUnS33//rd9//z3b69+V74Pz589n63m34qefftL777+vJk2aSJKOHDmiv/76K9vjZLa+ubi4qEuXLpo1a5ZcXV3Vvn17y+/GgIxVrVpVX3zxhYoXL57pFffd3d3VqlUrRUdHa9++fSpdurSqVq3qMMbevXtv+RoY/v7+6tKli7p06aI6depo8ODBDqH7ejL6rOXE79BbceHCBU2fPl1169bNNKzabDZFREQoIiJCI0aMUEhIiBYtWqSBAwdmOE9Z+U16IyVLlpSHh4diYmIyPIqmatWq+vTTT1WkSBF5e3tna+z/AkI3JP37A6RNmzbq3r27KlasKC8vL23evFkTJ05U8+bNJUkNGjRQeHi4WrRooYkTJ6pUqVI6duyY/WIy1atXV//+/dW1a1dVr15dERERio6O1q+//upweOgjjzyigQMH6ptvvlFYWJjeeust+22EpH/DQseOHRUVFaU333xTVapU0alTpxQTE6OKFSuqadOmWZqnUaNG6ZlnnlGRIkXse6J/+uknPfvss1malxtp1KiRTp06lekXS8mSJRUXF6cFCxaoRo0a+uabb7Ro0SKHPsWLF9fBgwfth5RfOQSxbt26at26td566y3dd999+u2332Sz2dSoUaMszfvo0aPVr18/+fj4qFGjRkpOTrbfPmbgwIFZGgO333vvvaeIiAjVrFlTr7zyiipWrKjLly9r5cqVmjp1qvbs2aMGDRqoQoUK6tixoyZNmqTLly/rf//7nx566CFVr15dFy5c0ODBg/XEE08oNDRUR48e1aZNm9S6deubqsnLy0uDBg3Sc889p7S0NNWuXVuJiYn66aef5O3trS5duqR7zvbt2zVy5Eh1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",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "methods = list(accuracies.keys())\n",
    "accuracy_percentages = [(accuracies[method] / total_entries) * 100 for method in methods]\n",
    "\n",
    "plt.figure(figsize=(10, 6))\n",
    "plt.bar(methods, accuracy_percentages, color='blue')\n",
    "plt.xlabel('Similarity Algorithm')\n",
    "plt.ylabel('Accuracy (%)')\n",
    "plt.title('Accuracy of Different Similarity Algorithms')\n",
    "plt.ylim(0, 100) \n",
    "plt.tight_layout()\n",
    "\n",
    "for i, v in enumerate(accuracy_percentages):\n",
    "    plt.text(i, v + 1, f\"{v:.2f}%\", ha='center', va='bottom')\n",
    "plt.savefig('Accuracy of Different Similarity Algorithms.png', dpi=600)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b77eeab5-aeb1-4568-945e-e44273d6528f",
   "metadata": {},
   "source": [
    "**----End of Step 4 Analysis----**"
   ]
  }
 ],
 "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
}
