{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "59fbe4a829d74dcd93c7bec75e8a469c",
       "version_major": 2,
       "version_minor": 0
      },
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAoAAAAHgCAYAAAA10dzkAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAbYUlEQVR4nO3dYWzcdf3A8c9B3bHN9iIId2s2SIWCwhjRoWOLsCmuyaJEwhNkxkx5Am4QmmmGcw+YhrRjJguSKQY1OmLmeCAoD9SsCVA0y5IOt7AUQjBMqMlKBWdbx+gC/v4PDBdqh3813N3o5/VKfsnu+/v18tm+K/fm12tXKoqiCAAA0jij1QMAANBcAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhm1gbg1q1bo1QqTTtqtVr9fFEUsXXr1ujs7Iy5c+fGqlWrYnh4uIUTAwA0x6wNwIiIyy67LI4ePVo/Dh8+XD+3ffv22LFjR+zcuTOGhoaiVqvF6tWrY3JysoUTAwA03qwOwLa2tqjVavXj3HPPjYh/3v279957Y8uWLXHDDTfE4sWLY9euXfHaa6/F7t27Wzw1AEBjzeoAfP7556OzszO6urriC1/4QrzwwgsREXHkyJEYHR2Nnp6e+rXlcjlWrlwZ+/bta9W4AABN0dbqARpl2bJl8eCDD8bFF18cL7/8ctx9992xYsWKGB4ejtHR0YiIqFar0z6mWq3Giy+++I7POTU1FVNTU/XH//jHP+Kvf/1rnHPOOVEqlRrzGwEA3lVFUcTk5GR0dnbGGWfM6nth72jWBuCaNWvqv7788stj+fLlceGFF8auXbviqquuioiYEW1FUfzbkOvv749vfetbjRkYAGiqkZGRWLhwYavHaIlZG4D/av78+XH55ZfH888/H9dff31ERIyOjsaCBQvq14yNjc24K/h2mzdvjo0bN9Yfj4+Px/nnnx8jIyPR0dHRsNkBgHfPxMRELFq0KNrb21s9SsukCcCpqal49tln4+qrr46urq6o1WoxMDAQH/3oRyMi4uTJkzE4OBj33HPPOz5HuVyOcrk8Y72jo0MAAsB7TOa3b83aAPz6178e1113XZx//vkxNjYWd999d0xMTMS6deuiVCpFb29v9PX1RXd3d3R3d0dfX1/Mmzcv1q5d2+rRAQAaatYG4J///Oe46aab4pVXXolzzz03rrrqqti/f39ccMEFERGxadOmOHHiRKxfvz6OHTsWy5Yti71796a+HQwA5FAqiqJo9RDvVRMTE1GpVGJ8fNyXgAHgPcLr9yz/OYAAAMwkAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkEyKAOzv749SqRS9vb31taIoYuvWrdHZ2Rlz586NVatWxfDwcOuGBABoklkfgENDQ/HAAw/EkiVLpq1v3749duzYETt37oyhoaGo1WqxevXqmJycbNGkAADNMasD8O9//3t88YtfjB/+8IfxgQ98oL5eFEXce++9sWXLlrjhhhti8eLFsWvXrnjttddi9+7dLZwYAKDxZnUAbtiwIT772c/GZz7zmWnrR44cidHR0ejp6amvlcvlWLlyZezbt6/ZYwIANFVbqwdolD179sQf/vCHGBoamnFudHQ0IiKq1eq09Wq1Gi+++OI7PufU1FRMTU3VH09MTLxL0wIANM+svAM4MjISd9xxR/zsZz+Ls8466x2vK5VK0x4XRTFj7e36+/ujUqnUj0WLFr1rMwMA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IgBvu+22ePrpp+PnP//5jHOlUmna46IoZqy9ZfPmzTE+Pl4/RkZGGjIvAEAjtbV6gEa7/fbb49FHH40nn3wyFi5cWF+v1WoR8c87gQsWLKivj42Nzbgr+JZyuRzlcrmxAwMANNisvQNYFEXcdttt8fDDD8djjz0WXV1d0853dXVFrVaLgYGB+trJkydjcHAwVqxY0exxAQCaZtbeAdywYUPs3r07fvWrX0V7e3v9fX2VSiXmzp0bpVIpent7o6+vL7q7u6O7uzv6+vpi3rx5sXbt2hZPDwDQOLM2AO+///6IiFi1atW09Z/85Cfx5S9/OSIiNm3aFCdOnIj169fHsWPHYtmyZbF3795ob29v8rQAAM2T5ucANoKfIwQA7z1ev2fxewABADg1AQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGRmbQA++eSTcd1110VnZ2eUSqX45S9/Oe18URSxdevW6OzsjLlz58aqVatieHi4NcMCADTRrA3A48ePxxVXXBE7d+485fnt27fHjh07YufOnTE0NBS1Wi1Wr14dk5OTTZ4UAKC52lo9QKOsWbMm1qxZc8pzRVHEvffeG1u2bIkbbrghIiJ27doV1Wo1du/eHbfcckszRwUAaKpZewfw3zly5EiMjo5GT09Pfa1cLsfKlStj37597/hxU1NTMTExMe0AAHivSRmAo6OjERFRrVanrVer1fq5U+nv749KpVI/Fi1a1NA5AQAaIWUAvqVUKk17XBTFjLW327x5c4yPj9ePkZGRRo8IAPCum7XvAfx3arVaRPzzTuCCBQvq62NjYzPuCr5duVyOcrnc8PkA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7W9/i1/84hexbt26GBwcrJ+3D80xMjISd9xxR+zduzfOOuusd7zOfjTemjVr6r++/PLLY/ny5XHhhRfGrl274qqrroqI3PvgS8D/pQ9+8INx5plnzrjbNzY2NuP/JGiut767y9401+233x6PPvpoPP7447Fw4cL6uv1orjlz5sRFF10UV155ZfT398cVV1wR3/3ud+1Dkz311FMxNjYWS5cujba2tmhra4vBwcG47777oq2trf5nbj+ab/78+XH55ZfH888/7/MiBOB/bc6cObF06dIYGBiYtj4wMBArVqxo0VRERHR1dUWtVpu2NydPnozBwUF70wBFUcRtt90WDz/8cDz22GPR1dU17bz9aK2iKGJqaso+NNm1114bhw8fjkOHDtWPK6+8Mr74xS/GoUOH4kMf+pD9aJGpqal49tlnY8GCBT4vInwX8P9iz549xfve977ixz/+cfHMM88Uvb29xfz584s//elPrR5t1pucnCwOHjxYHDx4sIiIYseOHcXBgweLF198sSiKoti2bVtRqVSKhx9+uDh8+HBx0003FQsWLCgmJiZaPPns89WvfrWoVCrFE088URw9erR+vPbaa/Vr7EdzbN68uXjyySeLI0eOFE8//XTxzW9+szjjjDOKvXv3FkVhH1rt7d8FXBT2o1m+9rWvFU888UTxwgsvFPv37y8+97nPFe3t7fXX6uz7IAD/R9/73veKCy64oJgzZ07xsY99rP6jL2isxx9/vIiIGce6deuKovjnt/bfddddRa1WK8rlcnHNNdcUhw8fbu3Qs9Sp9iEiip/85Cf1a+xHc9x88831/x6de+65xbXXXluPv6KwD632rwFoP5rjxhtvLBYsWFC8733vKzo7O4sbbrihGB4erp/Pvg+loiiK1tx7BACgFbwHEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBk/g8PSESxkKL9uQAAAABJRU5ErkJggg==",
      "text/html": [
       "\n",
       "            <div style=\"display: inline-block;\">\n",
       "                <div class=\"jupyter-widgets widget-label\" style=\"text-align: center;\">\n",
       "                    Figure\n",
       "                </div>\n",
       "                <img src='data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAoAAAAHgCAYAAAA10dzkAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAbYUlEQVR4nO3dYWzcdf3A8c9B3bHN9iIId2s2SIWCwhjRoWOLsCmuyaJEwhNkxkx5Am4QmmmGcw+YhrRjJguSKQY1OmLmeCAoD9SsCVA0y5IOt7AUQjBMqMlKBWdbx+gC/v4PDBdqh3813N3o5/VKfsnu+/v18tm+K/fm12tXKoqiCAAA0jij1QMAANBcAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhm1gbg1q1bo1QqTTtqtVr9fFEUsXXr1ujs7Iy5c+fGqlWrYnh4uIUTAwA0x6wNwIiIyy67LI4ePVo/Dh8+XD+3ffv22LFjR+zcuTOGhoaiVqvF6tWrY3JysoUTAwA03qwOwLa2tqjVavXj3HPPjYh/3v279957Y8uWLXHDDTfE4sWLY9euXfHaa6/F7t27Wzw1AEBjzeoAfP7556OzszO6urriC1/4QrzwwgsREXHkyJEYHR2Nnp6e+rXlcjlWrlwZ+/bta9W4AABN0dbqARpl2bJl8eCDD8bFF18cL7/8ctx9992xYsWKGB4ejtHR0YiIqFar0z6mWq3Giy+++I7POTU1FVNTU/XH//jHP+Kvf/1rnHPOOVEqlRrzGwEA3lVFUcTk5GR0dnbGGWfM6nth72jWBuCaNWvqv7788stj+fLlceGFF8auXbviqquuioiYEW1FUfzbkOvv749vfetbjRkYAGiqkZGRWLhwYavHaIlZG4D/av78+XH55ZfH888/H9dff31ERIyOjsaCBQvq14yNjc24K/h2mzdvjo0bN9Yfj4+Px/nnnx8jIyPR0dHRsNkBgHfPxMRELFq0KNrb21s9SsukCcCpqal49tln4+qrr46urq6o1WoxMDAQH/3oRyMi4uTJkzE4OBj33HPPOz5HuVyOcrk8Y72jo0MAAsB7TOa3b83aAPz6178e1113XZx//vkxNjYWd999d0xMTMS6deuiVCpFb29v9PX1RXd3d3R3d0dfX1/Mmzcv1q5d2+rRAQAaatYG4J///Oe46aab4pVXXolzzz03rrrqqti/f39ccMEFERGxadOmOHHiRKxfvz6OHTsWy5Yti71796a+HQwA5FAqiqJo9RDvVRMTE1GpVGJ8fNyXgAHgPcLr9yz/OYAAAMwkAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkEyKAOzv749SqRS9vb31taIoYuvWrdHZ2Rlz586NVatWxfDwcOuGBABoklkfgENDQ/HAAw/EkiVLpq1v3749duzYETt37oyhoaGo1WqxevXqmJycbNGkAADNMasD8O9//3t88YtfjB/+8IfxgQ98oL5eFEXce++9sWXLlrjhhhti8eLFsWvXrnjttddi9+7dLZwYAKDxZnUAbtiwIT772c/GZz7zmWnrR44cidHR0ejp6amvlcvlWLlyZezbt6/ZYwIANFVbqwdolD179sQf/vCHGBoamnFudHQ0IiKq1eq09Wq1Gi+++OI7PufU1FRMTU3VH09MTLxL0wIANM+svAM4MjISd9xxR/zsZz+Ls8466x2vK5VK0x4XRTFj7e36+/ujUqnUj0WLFr1rMwMA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IgBvu+22ePrpp+PnP//5jHOlUmna46IoZqy9ZfPmzTE+Pl4/RkZGGjIvAEAjtbV6gEa7/fbb49FHH40nn3wyFi5cWF+v1WoR8c87gQsWLKivj42Nzbgr+JZyuRzlcrmxAwMANNisvQNYFEXcdttt8fDDD8djjz0WXV1d0853dXVFrVaLgYGB+trJkydjcHAwVqxY0exxAQCaZtbeAdywYUPs3r07fvWrX0V7e3v9fX2VSiXmzp0bpVIpent7o6+vL7q7u6O7uzv6+vpi3rx5sXbt2hZPDwDQOLM2AO+///6IiFi1atW09Z/85Cfx5S9/OSIiNm3aFCdOnIj169fHsWPHYtmyZbF3795ob29v8rQAAM2T5ucANoKfIwQA7z1ev2fxewABADg1AQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGRmbQA++eSTcd1110VnZ2eUSqX45S9/Oe18URSxdevW6OzsjLlz58aqVatieHi4NcMCADTRrA3A48ePxxVXXBE7d+485fnt27fHjh07YufOnTE0NBS1Wi1Wr14dk5OTTZ4UAKC52lo9QKOsWbMm1qxZc8pzRVHEvffeG1u2bIkbbrghIiJ27doV1Wo1du/eHbfcckszRwUAaKpZewfw3zly5EiMjo5GT09Pfa1cLsfKlStj37597/hxU1NTMTExMe0AAHivSRmAo6OjERFRrVanrVer1fq5U+nv749KpVI/Fi1a1NA5AQAaIWUAvqVUKk17XBTFjLW327x5c4yPj9ePkZGRRo8IAPCum7XvAfx3arVaRPzzTuCCBQvq62NjYzPuCr5duVyOcrnc8PkA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7W9/i1/84hexbt26GBwcrJ+3D80xMjISd9xxR+zduzfOOuusd7zOfjTemjVr6r++/PLLY/ny5XHhhRfGrl274qqrroqI3PvgS8D/pQ9+8INx5plnzrjbNzY2NuP/JGiut767y9401+233x6PPvpoPP7447Fw4cL6uv1orjlz5sRFF10UV155ZfT398cVV1wR3/3ud+1Dkz311FMxNjYWS5cujba2tmhra4vBwcG47777oq2trf5nbj+ab/78+XH55ZfH888/7/MiBOB/bc6cObF06dIYGBiYtj4wMBArVqxo0VRERHR1dUWtVpu2NydPnozBwUF70wBFUcRtt90WDz/8cDz22GPR1dU17bz9aK2iKGJqaso+NNm1114bhw8fjkOHDtWPK6+8Mr74xS/GoUOH4kMf+pD9aJGpqal49tlnY8GCBT4vInwX8P9iz549xfve977ixz/+cfHMM88Uvb29xfz584s//elPrR5t1pucnCwOHjxYHDx4sIiIYseOHcXBgweLF198sSiKoti2bVtRqVSKhx9+uDh8+HBx0003FQsWLCgmJiZaPPns89WvfrWoVCrFE088URw9erR+vPbaa/Vr7EdzbN68uXjyySeLI0eOFE8//XTxzW9+szjjjDOKvXv3FkVhH1rt7d8FXBT2o1m+9rWvFU888UTxwgsvFPv37y8+97nPFe3t7fXX6uz7IAD/R9/73veKCy64oJgzZ07xsY99rP6jL2isxx9/vIiIGce6deuKovjnt/bfddddRa1WK8rlcnHNNdcUhw8fbu3Qs9Sp9iEiip/85Cf1a+xHc9x88831/x6de+65xbXXXluPv6KwD632rwFoP5rjxhtvLBYsWFC8733vKzo7O4sbbrihGB4erp/Pvg+loiiK1tx7BACgFbwHEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBk/g8PSESxkKL9uQAAAABJRU5ErkJggg==' width=640.0/>\n",
       "            </div>\n",
       "        "
      ],
      "text/plain": [
       "Canvas(toolbar=Toolbar(toolitems=[('Home', 'Reset original view', 'home', 'home'), ('Back', 'Back to previous …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\n",
    "%matplotlib ipympl\n",
    "import numpy as np\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.animation as animation\n",
    "\n",
    "# Box dimensions\n",
    "box_size = 50\n",
    "\n",
    "# Number of particles\n",
    "num_particles = 4\n",
    "particle_radius = 1.0  # Radius of the particles\n",
    "large_num = 1000  # A large number for no collision\n",
    "\n",
    "# Time parameters\n",
    "t_max = 100 # Total simulation time\n",
    "dt = 0.1     # Time step\n",
    "\n",
    "# Initialize positions and velocities\n",
    "np.random.seed(0)  # For reproducibility\n",
    "positions = np.array([[10.0, 25.0],[13, 20.0],[37, 20.0],[40.0, 20]])\n",
    "velocities = np.array([[1.5, 5.0],[1.5, 3],[-1.5, -2.0],[-1.5, 0.0]])\n",
    "\n",
    "# Function to compute the time to the first collision between two particles\n",
    "def particle_collision_time(pos_i, vel_i, pos_j, vel_j):\n",
    "    delta_x = pos_j[0] - pos_i[0]\n",
    "    delta_vx = vel_j[0] - vel_i[0]\n",
    "    delta_y = pos_j[1] - pos_i[1]\n",
    "    delta_vy = vel_j[1] - vel_i[1]\n",
    "    #print(f'delta_x:{delta_x}, delta_y:{delta_y}, delta_vy:{delta_vy}, delta_vx:{delta_vx}')\n",
    "    a = delta_vx**2 + delta_vy**2\n",
    "    b = 2 * (delta_x * delta_vx + delta_y * delta_vy)\n",
    "    c = delta_x**2 + delta_y**2 - 4 * particle_radius**2  # Adjusting for radius\n",
    "    \n",
    "    if a == 0:\n",
    "        return large_num  # Particles moving parallel (no collision)\n",
    "    \n",
    "    Delta = b**2 - 4 * a * c\n",
    "    if Delta < 0:\n",
    "        return large_num  # No real roots, no collision\n",
    "    elif Delta == 0:\n",
    "        t = -b / (2 * a)\n",
    "        return t if t >= 0 else large_num\n",
    "    else:\n",
    "        t1 = (-b + math.sqrt(Delta)) / (2 * a)\n",
    "        t2 = (-b - math.sqrt(Delta)) / (2 * a)\n",
    "        if t1 >= 0 and t2 >= 0:\n",
    "            #print(f'delta>0 and {t1} and {t2}')\n",
    "            return min(t1, t2)\n",
    "        elif t1 >= 0:\n",
    "            return t1\n",
    "        elif t2 >= 0:\n",
    "            return t2\n",
    "        return large_num\n",
    "\n",
    "# Function to compute the time to collision with the walls\n",
    "def wall_collision_time(position, velocity):\n",
    "    times = []\n",
    "    for i in range(2):  # x and y directions\n",
    "        if velocity[i] > 0:\n",
    "            t_wall = (box_size - particle_radius - position[i]) / velocity[i]\n",
    "        elif velocity[i] < 0:\n",
    "            t_wall = (particle_radius - position[i]) / velocity[i]\n",
    "        else:\n",
    "            t_wall = large_num  # No movement in this direction\n",
    "        times.append(t_wall)\n",
    "    \n",
    "    return min(times)\n",
    "\n",
    "# Function to find the next collision event\n",
    "def find_earliest_collision(positions, velocities):\n",
    "    min_time = large_num\n",
    "    collision_pair = (-1, -1)  # (-1, -1) means wall collision\n",
    "    \n",
    "    # Check particle-particle collisions\n",
    "    for i in range(num_particles):\n",
    "        for j in range(i + 1, num_particles):\n",
    "            t_collision = particle_collision_time(positions[i], velocities[i], positions[j], velocities[j])\n",
    "            if t_collision < min_time:\n",
    "                min_time = t_collision\n",
    "                #print(min_time)\n",
    "                collision_pair = (i, j)\n",
    "    \n",
    "    # Check particle-wall collisions\n",
    "    for i in range(num_particles):\n",
    "        t_wall = wall_collision_time(positions[i], velocities[i])\n",
    "        if t_wall < min_time:\n",
    "            min_time = t_wall\n",
    "            collision_pair = (i, -1)  # Indicate wall collision for this particle\n",
    "    \n",
    "    return min_time, collision_pair\n",
    "def update_positions(positions, velocities, dt):\n",
    "    # Update positions\n",
    "    positions += velocities * dt\n",
    "    \n",
    "    #print(positions)\n",
    "    # Check for boundary collisions and reflect velocities\n",
    "    for i in range(num_particles):\n",
    "        for j in range(2):  # x and y directions\n",
    "            if positions[i, j] <= particle_radius or positions[i, j] >= box_size - particle_radius:\n",
    "                velocities[i, j] *= -1\n",
    "                \n",
    "                #pressure += 1\n",
    "                positions[i, j] = np.clip(positions[i, j], particle_radius, box_size - particle_radius)\n",
    "                #print(f'wall collision for {i} at {dt}s and position:{positions[i]}')\n",
    "                #print(f'({i}, {j})position of wall colision {positions[i]} and new v:{velocities[i]}')\n",
    "    # Check for particle collisions\n",
    "    for i in range(num_particles):\n",
    "        for j in range(i + 1, num_particles):\n",
    "            dist = np.linalg.norm(positions[i] - positions[j])\n",
    "            if dist <= 2 * particle_radius:  # Collision condition\n",
    "                #print(f'for {i}, {j} we have a collision at position{positions[i]} and {positions[j]}')\n",
    "                resolve_collision(i, j, positions, velocities)\n",
    "    positions += velocities * 0.00000001\n",
    "    \n",
    "    return positions\n",
    "# Function to resolve the collision (particles or walls)\n",
    "def resolve_collision(i, j, positions, velocities):\n",
    "    # Calculate the normal vector\n",
    "    delta_pos = positions[i] - positions[j]\n",
    "    dist = np.linalg.norm(delta_pos)\n",
    "    delta_v = velocities[i] - velocities[j]\n",
    "    # Normal vector\n",
    "    n_hat = delta_pos / (dist**2)\n",
    "    \n",
    "    # Relative velocity\n",
    "    \n",
    "    \n",
    "    # Velocity component along the normal direction\n",
    "    v_rel = np.dot(delta_v, delta_pos)\n",
    "    \n",
    "    # Update velocities if particles are moving towards each other\n",
    "    if v_rel < 0:\n",
    "        velocities[i] -= v_rel * n_hat\n",
    "        velocities[j] += v_rel * n_hat\n",
    "    #print(f'({i},{j}) new i: p:{positions[i]}, v:{velocities[i]}\\n and j: p:{positions[j]},v:{velocities[j]}')\n",
    "    \n",
    "\n",
    "# t = 0\n",
    "# while t < t_max:\n",
    "#     delta_t, collision_pair = find_earliest_collision(positions, velocities)\n",
    "#     print(f'delta t is {delta_t}')\n",
    "#     positions = update_positions(positions, velocities, delta_t)\n",
    "#     t += (delta_t +0.00000001)\n",
    "#     print(f'delta t is {delta_t}')\n",
    "    \n",
    "#Visualization setup\n",
    "fig, ax = plt.subplots()\n",
    "ax.set_xlim(0, box_size)\n",
    "ax.set_ylim(0, box_size)\n",
    "particles, = ax.plot([], [], 'bo', ms=10)\n",
    "\n",
    "def init():\n",
    "    particles.set_data([], [])\n",
    "    return particles,\n",
    "\n",
    "def animate(frame):\n",
    "    global positions, velocities, dt\n",
    "    \n",
    "    # Find the earliest collision\n",
    "    delta_t, collision_pair = find_earliest_collision(positions, velocities)\n",
    "    \n",
    "    # Update positions to the collision time\n",
    "    if delta_t < dt:\n",
    "        positions = update_positions(positions, velocities, delta_t)\n",
    "        # positions += velocities * delta_t\n",
    "        #print(f'colision pair is {collision_pair}')\n",
    "        #print(delta_t)\n",
    "        # #print(f'delta t is {delta_t} and poistions {positions}')\n",
    "        # resolve_collision(collision_pair, positions, velocities)\n",
    "        # #positions += velocities * 0.001\n",
    "        # #t += (delta_t + 0.01)\n",
    "        # #print(f'delta t is {delta_t}')\n",
    "        dt -= (delta_t + 0.00000001)\n",
    "    else:\n",
    "        positions = update_positions(positions, velocities, dt)\n",
    "        dt = 0.1  # Reset time step after each update\n",
    "    \n",
    "    particles.set_data(positions[:, 0], positions[:, 1])\n",
    "    return particles,\n",
    "\n",
    "# Animation\n",
    "ani = animation.FuncAnimation(fig, animate, frames=int(t_max/dt), init_func=init,\n",
    "                              interval=20, blit=True, repeat=False)\n",
    "\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.animation import FuncAnimation\n",
    "import matplotlib.patches as patches\n",
    "plt.rcParams['font.size'] = 16\n",
    "# Set random seed for reproducibility\n",
    "np.random.seed(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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19cTFxdHenq6z3wFERERkUmlqwv+tROaTNl34mNgejrExajO6ziXkZFBWVkZdXV1xMbG+jxu3Jck7dlNeO/evT47EE+fPr3Pti9+8Yvk5uZy33338e6777Jz505ycnL4/Oc/z/e+973u0qUiIiIi0o+gIMjNMjMFALUN5iM22gQHCbEKDia4cT9TMN5opkBEREQC1s59UHmk7/aYKBMcJMYpOBhnBjpTMO5zCkRERERknMjJNLMGvTU4YXuByTuoPKKKRROQggIRERERGZhwB2T1U6SlscnMJvxrJ1TUKDiYQBQUiIiIiMjAZaZBeFj/xzib4dNC2LLD5B7IuKegQEREREQGLigIcjP7PyY4GNKTYE42xEWPybBkeBQUiIiIiMjgTIk3ScW+pCbCrOmmOpESjycEBQUiIiIiMngzM31f8JdWwu5i5RRMIAoKRERERGTwIsNhWqr7cUiw5/7yatixDzq7xnZcMiQKCkRERERkaKangyPU/Dt1ChyXC0E9Zg+qa+GTPdDR4ZfhycApKBARERGRoQkONsuIwOQZTImH42eb7S51jbB1D7S1+2OEMkAKCkRERERk6JITTNKxq8pQfAyclAehIe5jGpvg413Q0uqfMcoxKSgQERERkaGzLJib49npODoSTpoDYQ73tuZW+GiX6WEg446CAhEREREZnt5JxmASkRfMMZ9d2trNjEF949iNTQZEQYGIiIiIjI4wh5kxiIlyb+voNDkGNXX+G5f0oaBAREREREZPaAicOBsSYt3burpgewFU1vhvXOJBQYGIiIiIjK7gYFOuNDnBvc22YWchlFX6b1zSTUGBiIiIiIy+oCCTkJye7Ll9z344UKbux36moEBERERExoZlwawsyErz3F50CAoPKjDwIwUFIiIiIjJ2LAtmTIOcaZ7bD5bDnmIFBn6ioEBERERExl5mGuRle247XA079plEZBlTCgpERERExD/SkmB+rpk9cKmuhU/2mtKlMmYUFIiIiIiI/yTFwwmzIbjHZWltA2zdbZqdyZhQUCAiIiIi/hUfAyfmmZ4GLo1N8PFuaGn137gCiIICEREREfG/mCjT/TjM4d7W3AIf7wJns//GFSAUFIiIiIjI+BAZDgvmmM8ure1mxqDe6b9xBQAFBSIiIiIyfoQ54KQ8iIl0b+vogG274Ui9x6G2DfX1UFFhPqua6dCF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ffddnE4n2dnZfP7zn+d73/tedyk5kcmmpKSE3/72t7z33nsUFBRQWVmJbdukp6dz9tln8/Wvf73f9c163kgg27NnD7/4xS/YtGkTJSUl3c+dc845h9WrV7Nw4UKv5+l5I0OloEBEREREJMAp0VhEREREJMApKBARERERCXAKCkREREREApyCAhERERGRAKegQEREREQkwCkoEBEREREJcAoKREREREQCnIICEREREZEAp6BARERERCTAKSgQEREREQlwCgpERPyguLgYy7LIzs4e03P94aGHHsKyLJ5++ukx+57nnXcelmXxxhtvjNn3HEuPP/44lmVx/fXXj+r36ezsZPbs2eTk5NDW1jaq30tE/EtBgYhMetnZ2ViW5fERERHBzJkz+dKXvsSOHTv8PUQPDz74IHfffTe1tbX+HsqwNTY28uMf/5g5c+bw//7f//P3cCa92tpa7r77bh588MER+XrBwcHccccdFBUV8Zvf/GZEvqaIjE8KCkQkYMyaNYvFixezePFiZs6cycGDB3nsscc4+eSTefHFF8d0LKGhoeTl5TFz5sw++x588EF+9KMf+QwK+jt3vFm7di3l5eXcfvvtBAXpLWekxMXFkZeXR3p6usf22tpafvSjH41YUABw7bXXkpmZyZo1a3A6nSP2dUVkfNErtIgEjO9///u8/fbbvP3222zfvp0DBw7wmc98htbWVlatWkVjY+OYjWXq1Kns2rWLjRs3jum5Y6mzs5P//d//JTIyks997nP+Hs6k8tnPfpZdu3Zx3333jfr3CgkJ4ZprrqGqqmpMl4CJyNhSUCAiASs1NZUnn3ySsLAwqquree211/w9pEnlpZdeorS0lMsuu4yoqCh/D0eG4eqrrwbgkUce8fNIRGS0KCgQkYCWlpbGrFmzANi7d6/Hvr/97W9ceOGFJCUlERYWxowZM/j6179OSUmJ169VXV3Nd77zHebMmUN4eDhRUVFkZ2dz4YUX8tBDD3kc6y1Z2JU8un//fgBmzJjhkQfhSpo9VqJxdXU13/3ud8nLyyMiIoKEhATOO+88nnrqKWzb7nN8z6TV1tZW7r77bnJzcwkPDyczM5NvfetbQ1o28uc//xmASy65xOv+2tpaHn30US6//HJyc3OJiIggLi6O0047jV/96ld0dHR4Pc/1+wBYv34955xzDvHx8ViWRXFxcZ/jN2/ezCWXXEJiYiJRUVGceeaZ/PWvfx30z9Of66+/HsuyePzxx73uv/vuu7Esi7vvvtvn9rq6OlavXk1WVhZhYWHk5uZyzz33eP09eEs0vv7665kxYwYA+/fv75NH42LbNk888UT3783hcJCWlsbJJ5/Md7/7XQ4ePNjn+5100klMnTqV999/nwMHDgz+FyQi416IvwcgIuJv3i6U77jjDn76058CMG3aNLKzs/n000/5zW9+w9NPP82GDRs45ZRTuo+vq6vjtNNOY9++fTgcju6L6oMHD7Jhwwbef/99vv71r/c7jtTUVBYvXsyHH35Ia2srp5xyCmFhYd374+LijvmzFBQUsGTJEkpKSnA4HBx33HHU1tby5ptv8uabb7Jhw4buC8re2tvbueCCC3jrrbeYN28e2dnZ7N27l7Vr17J9+3Y2bNhwzO/f01tvvQXAqaee6nX/Sy+9xI033ojD4SA9PZ3jjz+e6upqPvzwQzZv3syGDRt44YUXfOYi3H///dx+++2kpqYye/ZsrwHBW2+9xZo1a3A4HMyZM4dDhw7x3nvv8dnPfpZf/OIXfOtb3xrUzzRa6urqOOOMM9i7dy/HHXccwcHB7Nu3jx/+8IccOHCAhx9++JhfY/bs2Zxyyil8+OGHhIWFefx99nTbbbfxi1/8AoCsrCxmz55NVVUV27dvJz8/nzPPPJNp06b1Oe/UU0/lueee45///Cf//u//PrwfWETGH1tEZJKbPn26DdiPPfZYn31lZWV2WFiYDdjr16+3bdu2X3zxRRuwQ0JC7D/84Q/dx9bV1dmf/exnbcDOzs62m5qauvc98MADNmBfcMEFdnV1tcf32L9/v7127VqPbUVFRTZgT58+3ed4i4qKvP48vs7t6uqyTznlFBuwzz33XPvw4cPd+1555RU7KirKBuyHHnrI47zHHnvMBuzQ0FB73rx59u7du7v3vffee3ZsbKwN2K+88orX8Xizf/9+G7BjYmLsrq4ur8ds3brVfumll+yWlhaP7fv27bPPOeccG7Aff/zxPucBNmA7HA77d7/7XffXb29vt9vb223btu1zzz23+//h1VdfbTc2Nnb/jn71q1917/v4448H/DP157rrrvP5N2bbtn3XXXfZgH3XXXd53R4aGmqfc8459qFDh7r3vfDCC3ZwcLAN2J9++qnHea7/Z9ddd53H9v7+rmzbtisqKuygoCA7Li7Ofvvttz32NTc323/605/srVu3ej33Jz/5iQ3YX/nKV7zuF5GJTcuHRCRgVVRUcO2119La2kpCQgLLli0D6J4huPnmm/nCF77QfXxsbCx/+MMfSEpKori4mD/96U/d+1xLj26++WYSExM9vk9WVharV68e5Z8GNm7c2H2X+OmnnyY1NbV734UXXshdd90FmDvstpfZkY6ODn7/+98ze/bs7m2nn346N954IwCvvPLKgMfiWgKVlpbmdVYC4IQTTuCSSy7xmA0ByMnJ4f/+7/8AeOqpp3x+j6985SvcdNNN3V8/JCSEkBDPCfDExEQee+yx7pwGy7L4xje+wZVXXklHRwe//OUvB/wzjaaQkBCeeuopMjIyurddeumlXH755cDgfvf92bdvH11dXSxZsoTFixd77AsPD+fqq6/mhBNO8Hquq9KR6/+tiEwuCgpEJGD85Cc/4ayzzuKss87iuOOOIzMzk3/84x+Ehoby8MMPExMTQ2NjI++99x4A3/jGN/p8jcjISG666SYAj+U0mZmZADz33HM+18KPNtd4rrrqKtLS0vrs/+pXv0pYWBj79+9n9+7dffafdNJJXpecLFq0CIDCwsIBj6WqqgqgT4DUW2trK3/84x+56aabWL58OWeffTZnnXUW1113HQBbt271ee4Xv/jFY47jhhtuIDw8vM9211Kuv//978f8GmPhwgsv9LpkZyi/+/64/k4/+OCDQecGuP5fVlZWjshYRGR8UU6BiASMvXv3dt/RdyVXnnPOOXz729/mpJNOAsya/K6uLsLCwsjJyfH6debPnw/Anj17uretWrWKn//85zz++OO88sorXHjhhZx99tmcf/75Pr/OSHONZ968eV73x8TEkJmZSUFBAXv27GHOnDke+331PUhJSQEYVMnWlpYWgD6zAD0dOHCACy64wGuA4lJTU+Nz39y5c485Dl/HuLaXl5dTX19PbGzsMb/WaBrJ331/pk6dylVXXcW6devIzc3l/PPP57zzzuPss8/m9NNP7zPT0lNERAQAzc3NIzIWERlfNFMgIgHjsccew7ZtbNumtbWV/fv38+STT3YHBOC++EpOTva57MW1LKehoaF7W0ZGBu+99x4rV66krq6O3//+99x4443MnDmTM844o3v2YTS5xu66kPTG29hdfJUNdSX6elty5IvrrnJ/XZmvv/56du/ezWmnncarr77K4cOHaWtrw7Zt2tvbAfqddRlImVNfv4ue2739LsbaSP7uj+WJJ57grrvuIiUlhQ0bNvD973+fs88+m4yMDB544AG6urq8nucK0JKSkkZsLCIyfigoEBHpITo6GjBLJHxdiJWXlwPmzntPc+fO5S9/+Qu1tbW8/vrr3H333cyZM4f333+fCy64wGt1nNEYe0VFhc9jfI19pLkuun3d6S8tLeX1118nMjKSl19+meXLl5OamkpoaCiAz7Kvg+VrqUvP7SPxu3AFkL7+ZsZTJ+Dw8HDuvvtuDh48yKeffspvf/tbLr30Uqqrq7ntttt85lm4/l8mJyeP5XBFZIwoKBAR6SE3N5egoCBaW1t9ruPesWMHgEdCbk9hYWGcd9553HXXXWzfvp3FixfT2NjokZjcH18zFMfiGs/OnTu97m9oaOi+2PY19pEyd+5cHA4Hhw4dor6+vs9+V7LqnDlzvOYd9JdLMBiffvppv9tTU1NHZOmQ606/ryCkoKBg2N9jIAb7tzNnzhy+/OUv88ILL3T30vBV/tT1d7Vw4cLhDVJExiUFBSIiPURHR3PmmWcC8Otf/7rP/ubm5u6ursuXLz/m1wsODu5OFi0tLR3QGIa6dts1nnXr1nH48OE++3/729/S2trK9OnTycvLG9TXHqzw8HBOOeUUbNsmPz+/z37Xz1hRUeH17vrPfvazERnHo48+Smtra5/trgvgCy64YES+jytvZMuWLX32HTx4cMwSmoez7v/0008HfP+dbt68GYCzzz57iKMTkfFMQYGISC/f+973AHPh+Mc//rF7e0NDA1/84heprKwkOzubq6++unvff/7nf/Loo4/2WUO/fft2nnnmGWDgd1hdF5hvvvnmoMa9ZMkSFi1aRGtrK5///Oc9lhFt2LCBH/3oRwDcfvvtQ56NGAzXBffbb7/dZ9/8+fNJSEjg4MGD3Hvvvd2BQUtLC7fccgsfffTRiIyhurqaG264oXv5jm3bPPTQQzz77LMEBwf3aV72/vvvk52d7bNbtC8XXXQRAH/96195+eWXu7eXlZXxhS98YcwqUiUnJxMTE0NFRYXXWZKNGzdy22239ZlNamxs5Oc//zng/e+0sbGRrVu3Eh8f77MZnYhMbAoKRER6WbFiBbfffjvt7e184QtfICsri0WLFpGens5f/vIXEhISeOaZZ7rvyoJZUnTjjTcyZcoUZs2axWmnncasWbM4/vjjKS0t5fzzz+faa68d0Pf/t3/7NwC+9rWvcfzxx3Peeedx3nnn8fHHH/d7nmVZ/PGPf2TatGm88cYbZGVlcfLJJzNr1iyWL19OY2Mj1157LV/5yleG/LsZjFWrVhEUFMSf//znPvtCQ0O55557APjBD35ARkYGixYtIjU1lV//+tdeZ2mG4oc//CHr1q0jPT2dRYsWMW3aNG6++WZs2+a+++7zSDIHE5Ts379/0LX4586dyw033EBHRweXXHIJOTk5LFiwgKysLCoqKo7ZzXqkWJbFVVddBZiL+0WLFnX//YAJbB944AHmz59PSkoKixYt4qSTTiI1NZWnnnqKuLg41q5d2+frPv/887S2tnLNNdf0W1FKRCYuBQUiIl7cd999vPjiiyxbtozGxka2bdtGUlISX/3qV9m6dWv3kiCXO++8k9tvv51FixbR2NjIxx9/THNzM+eeey5PPPEEGzZs6LfcY0/XXnst//Vf/8UJJ5zAvn37ePPNN3nzzTf7reTjkpuby0cffcR3vvMdsrKy2LFjBxUVFZxzzjk8+eST/P73vx+TWQIwTduWL1/O9u3b2bZtW5/9N998M3/4wx846aSTqKmpoaCggFNOOYWXX365u2HacJ199tm89dZbnHXWWRQUFHDkyBFOP/10nn32WW677bYR+R4u//u//8uPf/xjZs6cyaFDh6isrOQrX/kK7733HvHx8SP6vfrzX//1X9xyyy2kpaWxdevW7r8fML+PX/3qV1x66aVER0ezc+dOiouLyc3N5bvf/S67du3yOlPgyocZqf8vIjL+WPZI1jkTERHp4Z133uGss87ihhtu6M7FkImloKCAOXPmsHz5cv72t7/5ezgiMko0UyAiIqNm8eLFXHHFFTzxxBODXpIj44Mr5+OnP/2pv4ciIqNIHY1FRGRUPfDAA5x44omUlJQwffp0fw9HBqGzs5Pc3FweeeQRjj/+eH8PR0RGkZYPiYiIiIgEOC0fEhEREREJcAoKREREREQCnIICEREREZEAp6BARERERCTAKSgQEREREQlwCgpERERERAKcggIRERERkQCnoEBEREREJMApKBARERERCXAKCkRERERE+fj0ywAAAAhJREFUAtz/B+FlsoMUd3UhAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\n",
    "# Simulation parameters\n",
    "num_particles = 60\n",
    "box_size = 100.0  # Size of the square box\n",
    "max_velocity = 0.25  # Maximum velocity magnitude\n",
    "\n",
    "# Initialize particle positions and velocities\n",
    "positions = np.random.rand(num_particles, 2) * (box_size-2)\n",
    "velocities = (np.random.rand(num_particles, 2) * 2 - 1) * max_velocity  # Random direction, random magnitude\n",
    "\n",
    "# Create figure and axis\n",
    "fig, ax = plt.subplots(figsize=(8, 8))\n",
    "ax.set_xlim(0, box_size)\n",
    "ax.set_ylim(0, box_size)\n",
    "ax.set_aspect('equal')\n",
    "ax.set_ylabel('Position (arb. units)')\n",
    "ax.set_xlabel('Position (arb. units)')\n",
    "\n",
    "# Create box boundary\n",
    "box = patches.Rectangle((0, 0), box_size, box_size, linewidth=2, edgecolor='black', facecolor='none')\n",
    "ax.add_patch(box)\n",
    "\n",
    "# Scatter plot for particles\n",
    "particles = ax.scatter(positions[:, 0], positions[:, 1], s=100, color='blue', alpha=0.7)\n",
    "\n",
    "# Quiver plot for velocity vectors\n",
    "vectors = ax.quiver(positions[:, 0], positions[:, 1], velocities[:, 0], velocities[:, 1], \n",
    "                    color='pink', scale=3.5, width=0.005)\n",
    "\n",
    "\n",
    "def update(frame):\n",
    "    global positions, velocities\n",
    "    \n",
    "    # Update positions based on velocities\n",
    "    positions += velocities\n",
    "    \n",
    "    # Handle collisions with box boundaries\n",
    "    for i in range(num_particles):\n",
    "        for dim in range(2):  # For both x and y dimensions\n",
    "            if positions[i, dim] < 0:\n",
    "                positions[i, dim] = -positions[i, dim]\n",
    "                velocities[i, dim] *= -1\n",
    "            elif positions[i, dim] > box_size:\n",
    "                positions[i, dim] = 2 * box_size - positions[i, dim]\n",
    "                velocities[i, dim] *= -1\n",
    "    \n",
    "    # Update scatter plot and velocity vectors\n",
    "    particles.set_offsets(positions)\n",
    "    vectors.set_offsets(positions)\n",
    "    vectors.set_UVC(velocities[:, 0], velocities[:, 1])\n",
    "    \n",
    "    return particles, vectors\n",
    "\n",
    "# Create animation\n",
    "animation = FuncAnimation(fig, update, frames=100, interval=50, blit=True)\n",
    "tick_values = [20, 50, 80]\n",
    "plt.xticks(tick_values, [str(int(round(v))) for v in tick_values])\n",
    "plt.yticks(tick_values, [str(int(round(v))) for v in tick_values])\n",
    "plt.tight_layout()\n",
    "plt.savefig('gasinbox.pdf', dpi=1500, format='pdf')\n",
    "plt.show()\n",
    "\n",
    "# For a still image only, without animation\n",
    "def plot_still_image():\n",
    "    fig, ax = plt.subplots(figsize=(8, 8))\n",
    "    ax.set_xlim(0, box_size)\n",
    "    ax.set_ylim(0, box_size)\n",
    "    ax.set_aspect('equal')\n",
    "    ax.set_title('2D Particle Simulation with Velocity Vectors (Still Image)')\n",
    "    \n",
    "    # Create box boundary\n",
    "    box = patches.Rectangle((0, 0), box_size, box_size, linewidth=2, edgecolor='black', facecolor='none')\n",
    "    ax.add_patch(box)\n",
    "    \n",
    "    # Scatter plot for particles\n",
    "    ax.scatter(positions[:, 0], positions[:, 1], s=100, color='blue', alpha=0.7)\n",
    "    \n",
    "    # Quiver plot for velocity vectors\n",
    "    ax.quiver(positions[:, 0], positions[:, 1], velocities[:, 0], velocities[:, 1], \n",
    "              color='red', scale=3, width=0.005)\n",
    "    \n",
    "    plt.tight_layout()\n",
    "    plt.show()\n",
    "\n",
    "# Uncomment to see the still image\n",
    "plot_still_image()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[  18.4   20. ]\n",
      " [  19.4   20. ]\n",
      " [-257.4   20. ]\n",
      " [-256.4   20. ]]\n"
     ]
    }
   ],
   "source": [
    "print(positions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0253c8ce59eb4f89a66b314f99b6ebfa",
       "version_major": 2,
       "version_minor": 0
      },
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAoAAAAHgCAYAAAA10dzkAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAbYUlEQVR4nO3dYWzcdf3A8c9B3bHN9iIId2s2SIWCwhjRoWOLsCmuyaJEwhNkxkx5Am4QmmmGcw+YhrRjJguSKQY1OmLmeCAoD9SsCVA0y5IOt7AUQjBMqMlKBWdbx+gC/v4PDBdqh3813N3o5/VKfsnu+/v18tm+K/fm12tXKoqiCAAA0jij1QMAANBcAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhm1gbg1q1bo1QqTTtqtVr9fFEUsXXr1ujs7Iy5c+fGqlWrYnh4uIUTAwA0x6wNwIiIyy67LI4ePVo/Dh8+XD+3ffv22LFjR+zcuTOGhoaiVqvF6tWrY3JysoUTAwA03qwOwLa2tqjVavXj3HPPjYh/3v279957Y8uWLXHDDTfE4sWLY9euXfHaa6/F7t27Wzw1AEBjzeoAfP7556OzszO6urriC1/4QrzwwgsREXHkyJEYHR2Nnp6e+rXlcjlWrlwZ+/bta9W4AABN0dbqARpl2bJl8eCDD8bFF18cL7/8ctx9992xYsWKGB4ejtHR0YiIqFar0z6mWq3Giy+++I7POTU1FVNTU/XH//jHP+Kvf/1rnHPOOVEqlRrzGwEA3lVFUcTk5GR0dnbGGWfM6nth72jWBuCaNWvqv7788stj+fLlceGFF8auXbviqquuioiYEW1FUfzbkOvv749vfetbjRkYAGiqkZGRWLhwYavHaIlZG4D/av78+XH55ZfH888/H9dff31ERIyOjsaCBQvq14yNjc24K/h2mzdvjo0bN9Yfj4+Px/nnnx8jIyPR0dHRsNkBgHfPxMRELFq0KNrb21s9SsukCcCpqal49tln4+qrr46urq6o1WoxMDAQH/3oRyMi4uTJkzE4OBj33HPPOz5HuVyOcrk8Y72jo0MAAsB7TOa3b83aAPz6178e1113XZx//vkxNjYWd999d0xMTMS6deuiVCpFb29v9PX1RXd3d3R3d0dfX1/Mmzcv1q5d2+rRAQAaatYG4J///Oe46aab4pVXXolzzz03rrrqqti/f39ccMEFERGxadOmOHHiRKxfvz6OHTsWy5Yti71796a+HQwA5FAqiqJo9RDvVRMTE1GpVGJ8fNyXgAHgPcLr9yz/OYAAAMwkAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkEyKAOzv749SqRS9vb31taIoYuvWrdHZ2Rlz586NVatWxfDwcOuGBABoklkfgENDQ/HAAw/EkiVLpq1v3749duzYETt37oyhoaGo1WqxevXqmJycbNGkAADNMasD8O9//3t88YtfjB/+8IfxgQ98oL5eFEXce++9sWXLlrjhhhti8eLFsWvXrnjttddi9+7dLZwYAKDxZnUAbtiwIT772c/GZz7zmWnrR44cidHR0ejp6amvlcvlWLlyZezbt6/ZYwIANFVbqwdolD179sQf/vCHGBoamnFudHQ0IiKq1eq09Wq1Gi+++OI7PufU1FRMTU3VH09MTLxL0wIANM+svAM4MjISd9xxR/zsZz+Ls8466x2vK5VK0x4XRTFj7e36+/ujUqnUj0WLFr1rMwMA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IgBvu+22ePrpp+PnP//5jHOlUmna46IoZqy9ZfPmzTE+Pl4/RkZGGjIvAEAjtbV6gEa7/fbb49FHH40nn3wyFi5cWF+v1WoR8c87gQsWLKivj42Nzbgr+JZyuRzlcrmxAwMANNisvQNYFEXcdttt8fDDD8djjz0WXV1d0853dXVFrVaLgYGB+trJkydjcHAwVqxY0exxAQCaZtbeAdywYUPs3r07fvWrX0V7e3v9fX2VSiXmzp0bpVIpent7o6+vL7q7u6O7uzv6+vpi3rx5sXbt2hZPDwDQOLM2AO+///6IiFi1atW09Z/85Cfx5S9/OSIiNm3aFCdOnIj169fHsWPHYtmyZbF3795ob29v8rQAAM2T5ucANoKfIwQA7z1ev2fxewABADg1AQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGRmbQA++eSTcd1110VnZ2eUSqX45S9/Oe18URSxdevW6OzsjLlz58aqVatieHi4NcMCADTRrA3A48ePxxVXXBE7d+485fnt27fHjh07YufOnTE0NBS1Wi1Wr14dk5OTTZ4UAKC52lo9QKOsWbMm1qxZc8pzRVHEvffeG1u2bIkbbrghIiJ27doV1Wo1du/eHbfcckszRwUAaKpZewfw3zly5EiMjo5GT09Pfa1cLsfKlStj37597/hxU1NTMTExMe0AAHivSRmAo6OjERFRrVanrVer1fq5U+nv749KpVI/Fi1a1NA5AQAaIWUAvqVUKk17XBTFjLW327x5c4yPj9ePkZGRRo8IAPCum7XvAfx3arVaRPzzTuCCBQvq62NjYzPuCr5duVyOcrnc8PkA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7W9/i1/84hexbt26GBwcrJ+3D80xMjISd9xxR+zduzfOOuusd7zOfjTemjVr6r++/PLLY/ny5XHhhRfGrl274qqrroqI3PvgS8D/pQ9+8INx5plnzrjbNzY2NuP/JGiut767y9401+233x6PPvpoPP7447Fw4cL6uv1orjlz5sRFF10UV155ZfT398cVV1wR3/3ud+1Dkz311FMxNjYWS5cujba2tmhra4vBwcG47777oq2trf5nbj+ab/78+XH55ZfH888/7/MiBOB/bc6cObF06dIYGBiYtj4wMBArVqxo0VRERHR1dUWtVpu2NydPnozBwUF70wBFUcRtt90WDz/8cDz22GPR1dU17bz9aK2iKGJqaso+NNm1114bhw8fjkOHDtWPK6+8Mr74xS/GoUOH4kMf+pD9aJGpqal49tlnY8GCBT4vInwX8P9iz549xfve977ixz/+cfHMM88Uvb29xfz584s//elPrR5t1pucnCwOHjxYHDx4sIiIYseOHcXBgweLF198sSiKoti2bVtRqVSKhx9+uDh8+HBx0003FQsWLCgmJiZaPPns89WvfrWoVCrFE088URw9erR+vPbaa/Vr7EdzbN68uXjyySeLI0eOFE8//XTxzW9+szjjjDOKvXv3FkVhH1rt7d8FXBT2o1m+9rWvFU888UTxwgsvFPv37y8+97nPFe3t7fXX6uz7IAD/R9/73veKCy64oJgzZ07xsY99rP6jL2isxx9/vIiIGce6deuKovjnt/bfddddRa1WK8rlcnHNNdcUhw8fbu3Qs9Sp9iEiip/85Cf1a+xHc9x88831/x6de+65xbXXXluPv6KwD632rwFoP5rjxhtvLBYsWFC8733vKzo7O4sbbrihGB4erp/Pvg+loiiK1tx7BACgFbwHEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBk/g8PSESxkKL9uQAAAABJRU5ErkJggg==",
      "text/html": [
       "\n",
       "            <div style=\"display: inline-block;\">\n",
       "                <div class=\"jupyter-widgets widget-label\" style=\"text-align: center;\">\n",
       "                    Figure\n",
       "                </div>\n",
       "                <img src='data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAoAAAAHgCAYAAAA10dzkAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAbYUlEQVR4nO3dYWzcdf3A8c9B3bHN9iIId2s2SIWCwhjRoWOLsCmuyaJEwhNkxkx5Am4QmmmGcw+YhrRjJguSKQY1OmLmeCAoD9SsCVA0y5IOt7AUQjBMqMlKBWdbx+gC/v4PDBdqh3813N3o5/VKfsnu+/v18tm+K/fm12tXKoqiCAAA0jij1QMAANBcAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhm1gbg1q1bo1QqTTtqtVr9fFEUsXXr1ujs7Iy5c+fGqlWrYnh4uIUTAwA0x6wNwIiIyy67LI4ePVo/Dh8+XD+3ffv22LFjR+zcuTOGhoaiVqvF6tWrY3JysoUTAwA03qwOwLa2tqjVavXj3HPPjYh/3v279957Y8uWLXHDDTfE4sWLY9euXfHaa6/F7t27Wzw1AEBjzeoAfP7556OzszO6urriC1/4QrzwwgsREXHkyJEYHR2Nnp6e+rXlcjlWrlwZ+/bta9W4AABN0dbqARpl2bJl8eCDD8bFF18cL7/8ctx9992xYsWKGB4ejtHR0YiIqFar0z6mWq3Giy+++I7POTU1FVNTU/XH//jHP+Kvf/1rnHPOOVEqlRrzGwEA3lVFUcTk5GR0dnbGGWfM6nth72jWBuCaNWvqv7788stj+fLlceGFF8auXbviqquuioiYEW1FUfzbkOvv749vfetbjRkYAGiqkZGRWLhwYavHaIlZG4D/av78+XH55ZfH888/H9dff31ERIyOjsaCBQvq14yNjc24K/h2mzdvjo0bN9Yfj4+Px/nnnx8jIyPR0dHRsNkBgHfPxMRELFq0KNrb21s9SsukCcCpqal49tln4+qrr46urq6o1WoxMDAQH/3oRyMi4uTJkzE4OBj33HPPOz5HuVyOcrk8Y72jo0MAAsB7TOa3b83aAPz6178e1113XZx//vkxNjYWd999d0xMTMS6deuiVCpFb29v9PX1RXd3d3R3d0dfX1/Mmzcv1q5d2+rRAQAaatYG4J///Oe46aab4pVXXolzzz03rrrqqti/f39ccMEFERGxadOmOHHiRKxfvz6OHTsWy5Yti71796a+HQwA5FAqiqJo9RDvVRMTE1GpVGJ8fNyXgAHgPcLr9yz/OYAAAMwkAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkEyKAOzv749SqRS9vb31taIoYuvWrdHZ2Rlz586NVatWxfDwcOuGBABoklkfgENDQ/HAAw/EkiVLpq1v3749duzYETt37oyhoaGo1WqxevXqmJycbNGkAADNMasD8O9//3t88YtfjB/+8IfxgQ98oL5eFEXce++9sWXLlrjhhhti8eLFsWvXrnjttddi9+7dLZwYAKDxZnUAbtiwIT772c/GZz7zmWnrR44cidHR0ejp6amvlcvlWLlyZezbt6/ZYwIANFVbqwdolD179sQf/vCHGBoamnFudHQ0IiKq1eq09Wq1Gi+++OI7PufU1FRMTU3VH09MTLxL0wIANM+svAM4MjISd9xxR/zsZz+Ls8466x2vK5VK0x4XRTFj7e36+/ujUqnUj0WLFr1rMwMA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IgBvu+22ePrpp+PnP//5jHOlUmna46IoZqy9ZfPmzTE+Pl4/RkZGGjIvAEAjtbV6gEa7/fbb49FHH40nn3wyFi5cWF+v1WoR8c87gQsWLKivj42Nzbgr+JZyuRzlcrmxAwMANNisvQNYFEXcdttt8fDDD8djjz0WXV1d0853dXVFrVaLgYGB+trJkydjcHAwVqxY0exxAQCaZtbeAdywYUPs3r07fvWrX0V7e3v9fX2VSiXmzp0bpVIpent7o6+vL7q7u6O7uzv6+vpi3rx5sXbt2hZPDwDQOLM2AO+///6IiFi1atW09Z/85Cfx5S9/OSIiNm3aFCdOnIj169fHsWPHYtmyZbF3795ob29v8rQAAM2T5ucANoKfIwQA7z1ev2fxewABADg1AQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGRmbQA++eSTcd1110VnZ2eUSqX45S9/Oe18URSxdevW6OzsjLlz58aqVatieHi4NcMCADTRrA3A48ePxxVXXBE7d+485fnt27fHjh07YufOnTE0NBS1Wi1Wr14dk5OTTZ4UAKC52lo9QKOsWbMm1qxZc8pzRVHEvffeG1u2bIkbbrghIiJ27doV1Wo1du/eHbfcckszRwUAaKpZewfw3zly5EiMjo5GT09Pfa1cLsfKlStj37597/hxU1NTMTExMe0AAHivSRmAo6OjERFRrVanrVer1fq5U+nv749KpVI/Fi1a1NA5AQAaIWUAvqVUKk17XBTFjLW327x5c4yPj9ePkZGRRo8IAPCum7XvAfx3arVaRPzzTuCCBQvq62NjYzPuCr5duVyOcrnc8PkA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7W9/i1/84hexbt26GBwcrJ+3D80xMjISd9xxR+zduzfOOuusd7zOfjTemjVr6r++/PLLY/ny5XHhhRfGrl274qqrroqI3PvgS8D/pQ9+8INx5plnzrjbNzY2NuP/JGiut767y9401+233x6PPvpoPP7447Fw4cL6uv1orjlz5sRFF10UV155ZfT398cVV1wR3/3ud+1Dkz311FMxNjYWS5cujba2tmhra4vBwcG47777oq2trf5nbj+ab/78+XH55ZfH888/7/MiBOB/bc6cObF06dIYGBiYtj4wMBArVqxo0VRERHR1dUWtVpu2NydPnozBwUF70wBFUcRtt90WDz/8cDz22GPR1dU17bz9aK2iKGJqaso+NNm1114bhw8fjkOHDtWPK6+8Mr74xS/GoUOH4kMf+pD9aJGpqal49tlnY8GCBT4vInwX8P9iz549xfve977ixz/+cfHMM88Uvb29xfz584s//elPrR5t1pucnCwOHjxYHDx4sIiIYseOHcXBgweLF198sSiKoti2bVtRqVSKhx9+uDh8+HBx0003FQsWLCgmJiZaPPns89WvfrWoVCrFE088URw9erR+vPbaa/Vr7EdzbN68uXjyySeLI0eOFE8//XTxzW9+szjjjDOKvXv3FkVhH1rt7d8FXBT2o1m+9rWvFU888UTxwgsvFPv37y8+97nPFe3t7fXX6uz7IAD/R9/73veKCy64oJgzZ07xsY99rP6jL2isxx9/vIiIGce6deuKovjnt/bfddddRa1WK8rlcnHNNdcUhw8fbu3Qs9Sp9iEiip/85Cf1a+xHc9x88831/x6de+65xbXXXluPv6KwD632rwFoP5rjxhtvLBYsWFC8733vKzo7O4sbbrihGB4erp/Pvg+loiiK1tx7BACgFbwHEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBk/g8PSESxkKL9uQAAAABJRU5ErkJggg==' width=640.0/>\n",
       "            </div>\n",
       "        "
      ],
      "text/plain": [
       "Canvas(toolbar=Toolbar(toolitems=[('Home', 'Reset original view', 'home', 'home'), ('Back', 'Back to previous …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "%matplotlib ipympl\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.animation as animation\n",
    "\n",
    "# Box dimensions\n",
    "box_size = 50\n",
    "\n",
    "# Number of particles\n",
    "num_particles = 4\n",
    "particle_radius = 1.0  # Radius of the particles\n",
    "large_num = 1000  # A large number for no collision\n",
    "\n",
    "# Time parameters\n",
    "t_max = 100 # Total simulation time\n",
    "dt = 0.05    # Time step\n",
    "\n",
    "# Initialize positions and velocities\n",
    "np.random.seed(0)  # For reproducibility\n",
    "positions = np.array([[10.0, 20.0],[14, 20.0],[36, 20.0],[40.0, 20]])\n",
    "velocities = np.array([[2.0, 0],[2.0, 0],[-2.0, 0.0],[-2.0, 0.0]])\n",
    "\n",
    "Temp = np.mean(velocities[:,0]**2 + velocities[:,1]**2)\n",
    "pressure = 0\n",
    "large_num = 100\n",
    "import math\n",
    "# def particle_colision_time(position_i, V_i, positin_j, V_j):\n",
    "#     delta_x = positin_j[0] - position_i[0]\n",
    "#     delta_vx = V_j[0] - V_i[0]\n",
    "#     delta_y = positin_j[1] - position_i[1]\n",
    "#     delta_yv = V_j[1] - V_i[1]\n",
    "#     # The colision equation is: (\\delta_vx^2 + \\delta_vy^2)*t^2 + (2\\deltax*\\delta_vx + 2*\\deltay*\\delta_vy)*t + (\\deltax^2 + \\deltay^2) = 4\n",
    "#     # ax^2 + bx + c = 0\n",
    "#     a = delta_vx**2 + delta_yv**2\n",
    "#     b = 2 * (delta_x * delta_vx + delta_y * delta_yv)\n",
    "#     c = delta_x**2 + delta_y**2 - particle_radius\n",
    "#     Delta = b**2 - 4 * a * c\n",
    "#     if a == 0:\n",
    "#         return large_num\n",
    "#     if Delta < 0:\n",
    "#         return large_num\n",
    "#     elif Delta == 0:\n",
    "#         t = -1 * b / (2 * a)\n",
    "#         if t >= 0:\n",
    "#             return t\n",
    "#         else:\n",
    "#             return large_num\n",
    "#     else:\n",
    "#         t1 = (-1 * b + math.sqrt(Delta)) / (2 * a)\n",
    "#         t2 = (-1 * b - math.sqrt(Delta)) / (2 * a)\n",
    "#         if t1 < 0 and t2 < 0:\n",
    "#             # print('colision occured in negative time')\n",
    "#             return large_num\n",
    "#         elif t1 < 0 and t2 >= 0:\n",
    "#             return t2\n",
    "#         elif t2 < 0 and t1 >= 0:\n",
    "#             return t1\n",
    "#         elif t2 >= 0 and t1 >= 0:\n",
    "#             # print(f'were here and t1:{t1} and t2:{t2}' )\n",
    "#             return min(t1, t2)\n",
    "colors = ['r', 'g', 'b', 'm'] \n",
    "# Function to update positions and velocities\n",
    "def update_positions(positions, velocities, dt):\n",
    "    # Update positions\n",
    "    positions += velocities * dt\n",
    "    \n",
    "    # Check for boundary collisions and reflect velocities\n",
    "    for i in range(num_particles):\n",
    "        for j in range(2):  # x and y directions\n",
    "            if positions[i, j] <= particle_radius or positions[i, j] >= box_size - particle_radius:\n",
    "                velocities[i, j] *= -1\n",
    "                #pressure += 1\n",
    "                positions[i, j] = np.clip(positions[i, j], particle_radius, box_size - particle_radius)\n",
    "                #print(f'({i}, {j})position of wall colision {positions[i]} and new v:{velocities[i]}')\n",
    "    # Check for particle collisions\n",
    "    for i in range(num_particles):\n",
    "        for j in range(i + 1, num_particles):\n",
    "            dist = np.linalg.norm(positions[i] - positions[j])\n",
    "            if dist < 2 * particle_radius:  # Collision condition\n",
    "                resolve_collision(i, j, positions, velocities)\n",
    "    \n",
    "    return positions\n",
    "\n",
    "# Function to resolve elastic collision between two particles\n",
    "def resolve_collision(i, j, positions, velocities):\n",
    "    # Calculate the normal vector\n",
    "    delta_pos = positions[i] - positions[j]\n",
    "    dist = np.linalg.norm(delta_pos)\n",
    "    \n",
    "    # Normal vector\n",
    "    n_hat = delta_pos / dist\n",
    "    \n",
    "    # Relative velocity\n",
    "    delta_v = velocities[i] - velocities[j]\n",
    "    \n",
    "    # Velocity component along the normal direction\n",
    "    v_rel = np.dot(delta_v, n_hat)\n",
    "    \n",
    "    # Update velocities if particles are moving towards each other\n",
    "    if v_rel < 0:\n",
    "        velocities[i] -= v_rel * n_hat\n",
    "        velocities[j] += v_rel * n_hat\n",
    "    #print(f'({i},{j}) new i: p:{positions[i]}, v:{velocities[i]}\\n and j: p:{positions[j]},v:{velocities[j]}')\n",
    "\n",
    "# Visualization setup\n",
    "fig, ax = plt.subplots()\n",
    "ax.set_xlim(0, box_size)\n",
    "ax.set_ylim(0, box_size)\n",
    "particles = [ax.plot([], [], 'o', color=colors[i], ms=10)[0] for i in range(num_particles)]\n",
    "\n",
    "\n",
    "def init():\n",
    "    for particle in particles:\n",
    "        particle.set_data([], [])\n",
    "    return particles\n",
    "\n",
    "def animate(frame):\n",
    "    global positions\n",
    "    \n",
    "    positions = update_positions(positions, velocities, dt)\n",
    "    # Update the positions of the particles\n",
    "    for i, particle in enumerate(particles):\n",
    "        particle.set_data(positions[i, 0], positions[i, 1])\n",
    "    return particles,\n",
    "\n",
    "# Animation\n",
    "ani = animation.FuncAnimation(fig, animate, frames=int(t_max/dt), init_func=init,\n",
    "                              interval=20, blit=True, repeat=False)\n",
    "\n",
    "plt.show()\n",
    "\n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a9e121159f5641c7a778f4a25acabd36",
       "version_major": 2,
       "version_minor": 0
      },
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAoAAAAHgCAYAAAA10dzkAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAbYUlEQVR4nO3dYWzcdf3A8c9B3bHN9iIId2s2SIWCwhjRoWOLsCmuyaJEwhNkxkx5Am4QmmmGcw+YhrRjJguSKQY1OmLmeCAoD9SsCVA0y5IOt7AUQjBMqMlKBWdbx+gC/v4PDBdqh3813N3o5/VKfsnu+/v18tm+K/fm12tXKoqiCAAA0jij1QMAANBcAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhm1gbg1q1bo1QqTTtqtVr9fFEUsXXr1ujs7Iy5c+fGqlWrYnh4uIUTAwA0x6wNwIiIyy67LI4ePVo/Dh8+XD+3ffv22LFjR+zcuTOGhoaiVqvF6tWrY3JysoUTAwA03qwOwLa2tqjVavXj3HPPjYh/3v279957Y8uWLXHDDTfE4sWLY9euXfHaa6/F7t27Wzw1AEBjzeoAfP7556OzszO6urriC1/4QrzwwgsREXHkyJEYHR2Nnp6e+rXlcjlWrlwZ+/bta9W4AABN0dbqARpl2bJl8eCDD8bFF18cL7/8ctx9992xYsWKGB4ejtHR0YiIqFar0z6mWq3Giy+++I7POTU1FVNTU/XH//jHP+Kvf/1rnHPOOVEqlRrzGwEA3lVFUcTk5GR0dnbGGWfM6nth72jWBuCaNWvqv7788stj+fLlceGFF8auXbviqquuioiYEW1FUfzbkOvv749vfetbjRkYAGiqkZGRWLhwYavHaIlZG4D/av78+XH55ZfH888/H9dff31ERIyOjsaCBQvq14yNjc24K/h2mzdvjo0bN9Yfj4+Px/nnnx8jIyPR0dHRsNkBgHfPxMRELFq0KNrb21s9SsukCcCpqal49tln4+qrr46urq6o1WoxMDAQH/3oRyMi4uTJkzE4OBj33HPPOz5HuVyOcrk8Y72jo0MAAsB7TOa3b83aAPz6178e1113XZx//vkxNjYWd999d0xMTMS6deuiVCpFb29v9PX1RXd3d3R3d0dfX1/Mmzcv1q5d2+rRAQAaatYG4J///Oe46aab4pVXXolzzz03rrrqqti/f39ccMEFERGxadOmOHHiRKxfvz6OHTsWy5Yti71796a+HQwA5FAqiqJo9RDvVRMTE1GpVGJ8fNyXgAHgPcLr9yz/OYAAAMwkAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkEyKAOzv749SqRS9vb31taIoYuvWrdHZ2Rlz586NVatWxfDwcOuGBABoklkfgENDQ/HAAw/EkiVLpq1v3749duzYETt37oyhoaGo1WqxevXqmJycbNGkAADNMasD8O9//3t88YtfjB/+8IfxgQ98oL5eFEXce++9sWXLlrjhhhti8eLFsWvXrnjttddi9+7dLZwYAKDxZnUAbtiwIT772c/GZz7zmWnrR44cidHR0ejp6amvlcvlWLlyZezbt6/ZYwIANFVbqwdolD179sQf/vCHGBoamnFudHQ0IiKq1eq09Wq1Gi+++OI7PufU1FRMTU3VH09MTLxL0wIANM+svAM4MjISd9xxR/zsZz+Ls8466x2vK5VK0x4XRTFj7e36+/ujUqnUj0WLFr1rMwMA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IgBvu+22ePrpp+PnP//5jHOlUmna46IoZqy9ZfPmzTE+Pl4/RkZGGjIvAEAjtbV6gEa7/fbb49FHH40nn3wyFi5cWF+v1WoR8c87gQsWLKivj42Nzbgr+JZyuRzlcrmxAwMANNisvQNYFEXcdttt8fDDD8djjz0WXV1d0853dXVFrVaLgYGB+trJkydjcHAwVqxY0exxAQCaZtbeAdywYUPs3r07fvWrX0V7e3v9fX2VSiXmzp0bpVIpent7o6+vL7q7u6O7uzv6+vpi3rx5sXbt2hZPDwDQOLM2AO+///6IiFi1atW09Z/85Cfx5S9/OSIiNm3aFCdOnIj169fHsWPHYtmyZbF3795ob29v8rQAAM2T5ucANoKfIwQA7z1ev2fxewABADg1AQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGRmbQA++eSTcd1110VnZ2eUSqX45S9/Oe18URSxdevW6OzsjLlz58aqVatieHi4NcMCADTRrA3A48ePxxVXXBE7d+485fnt27fHjh07YufOnTE0NBS1Wi1Wr14dk5OTTZ4UAKC52lo9QKOsWbMm1qxZc8pzRVHEvffeG1u2bIkbbrghIiJ27doV1Wo1du/eHbfcckszRwUAaKpZewfw3zly5EiMjo5GT09Pfa1cLsfKlStj37597/hxU1NTMTExMe0AAHivSRmAo6OjERFRrVanrVer1fq5U+nv749KpVI/Fi1a1NA5AQAaIWUAvqVUKk17XBTFjLW327x5c4yPj9ePkZGRRo8IAPCum7XvAfx3arVaRPzzTuCCBQvq62NjYzPuCr5duVyOcrnc8PkA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7W9/i1/84hexbt26GBwcrJ+3D80xMjISd9xxR+zduzfOOuusd7zOfjTemjVr6r++/PLLY/ny5XHhhRfGrl274qqrroqI3PvgS8D/pQ9+8INx5plnzrjbNzY2NuP/JGiut767y9401+233x6PPvpoPP7447Fw4cL6uv1orjlz5sRFF10UV155ZfT398cVV1wR3/3ud+1Dkz311FMxNjYWS5cujba2tmhra4vBwcG47777oq2trf5nbj+ab/78+XH55ZfH888/7/MiBOB/bc6cObF06dIYGBiYtj4wMBArVqxo0VRERHR1dUWtVpu2NydPnozBwUF70wBFUcRtt90WDz/8cDz22GPR1dU17bz9aK2iKGJqaso+NNm1114bhw8fjkOHDtWPK6+8Mr74xS/GoUOH4kMf+pD9aJGpqal49tlnY8GCBT4vInwX8P9iz549xfve977ixz/+cfHMM88Uvb29xfz584s//elPrR5t1pucnCwOHjxYHDx4sIiIYseOHcXBgweLF198sSiKoti2bVtRqVSKhx9+uDh8+HBx0003FQsWLCgmJiZaPPns89WvfrWoVCrFE088URw9erR+vPbaa/Vr7EdzbN68uXjyySeLI0eOFE8//XTxzW9+szjjjDOKvXv3FkVhH1rt7d8FXBT2o1m+9rWvFU888UTxwgsvFPv37y8+97nPFe3t7fXX6uz7IAD/R9/73veKCy64oJgzZ07xsY99rP6jL2isxx9/vIiIGce6deuKovjnt/bfddddRa1WK8rlcnHNNdcUhw8fbu3Qs9Sp9iEiip/85Cf1a+xHc9x88831/x6de+65xbXXXluPv6KwD632rwFoP5rjxhtvLBYsWFC8733vKzo7O4sbbrihGB4erp/Pvg+loiiK1tx7BACgFbwHEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBk/g8PSESxkKL9uQAAAABJRU5ErkJggg==",
      "text/html": [
       "\n",
       "            <div style=\"display: inline-block;\">\n",
       "                <div class=\"jupyter-widgets widget-label\" style=\"text-align: center;\">\n",
       "                    Figure\n",
       "                </div>\n",
       "                <img src='data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAoAAAAHgCAYAAAA10dzkAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAbYUlEQVR4nO3dYWzcdf3A8c9B3bHN9iIId2s2SIWCwhjRoWOLsCmuyaJEwhNkxkx5Am4QmmmGcw+YhrRjJguSKQY1OmLmeCAoD9SsCVA0y5IOt7AUQjBMqMlKBWdbx+gC/v4PDBdqh3813N3o5/VKfsnu+/v18tm+K/fm12tXKoqiCAAA0jij1QMAANBcAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhGAAIAJCMAAQCSEYAAAMkIQACAZAQgAEAyAhAAIBkBCACQjAAEAEhm1gbg1q1bo1QqTTtqtVr9fFEUsXXr1ujs7Iy5c+fGqlWrYnh4uIUTAwA0x6wNwIiIyy67LI4ePVo/Dh8+XD+3ffv22LFjR+zcuTOGhoaiVqvF6tWrY3JysoUTAwA03qwOwLa2tqjVavXj3HPPjYh/3v279957Y8uWLXHDDTfE4sWLY9euXfHaa6/F7t27Wzw1AEBjzeoAfP7556OzszO6urriC1/4QrzwwgsREXHkyJEYHR2Nnp6e+rXlcjlWrlwZ+/bta9W4AABN0dbqARpl2bJl8eCDD8bFF18cL7/8ctx9992xYsWKGB4ejtHR0YiIqFar0z6mWq3Giy+++I7POTU1FVNTU/XH//jHP+Kvf/1rnHPOOVEqlRrzGwEA3lVFUcTk5GR0dnbGGWfM6nth72jWBuCaNWvqv7788stj+fLlceGFF8auXbviqquuioiYEW1FUfzbkOvv749vfetbjRkYAGiqkZGRWLhwYavHaIlZG4D/av78+XH55ZfH888/H9dff31ERIyOjsaCBQvq14yNjc24K/h2mzdvjo0bN9Yfj4+Px/nnnx8jIyPR0dHRsNkBgHfPxMRELFq0KNrb21s9SsukCcCpqal49tln4+qrr46urq6o1WoxMDAQH/3oRyMi4uTJkzE4OBj33HPPOz5HuVyOcrk8Y72jo0MAAsB7TOa3b83aAPz6178e1113XZx//vkxNjYWd999d0xMTMS6deuiVCpFb29v9PX1RXd3d3R3d0dfX1/Mmzcv1q5d2+rRAQAaatYG4J///Oe46aab4pVXXolzzz03rrrqqti/f39ccMEFERGxadOmOHHiRKxfvz6OHTsWy5Yti71796a+HQwA5FAqiqJo9RDvVRMTE1GpVGJ8fNyXgAHgPcLr9yz/OYAAAMwkAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkEyKAOzv749SqRS9vb31taIoYuvWrdHZ2Rlz586NVatWxfDwcOuGBABoklkfgENDQ/HAAw/EkiVLpq1v3749duzYETt37oyhoaGo1WqxevXqmJycbNGkAADNMasD8O9//3t88YtfjB/+8IfxgQ98oL5eFEXce++9sWXLlrjhhhti8eLFsWvXrnjttddi9+7dLZwYAKDxZnUAbtiwIT772c/GZz7zmWnrR44cidHR0ejp6amvlcvlWLlyZezbt6/ZYwIANFVbqwdolD179sQf/vCHGBoamnFudHQ0IiKq1eq09Wq1Gi+++OI7PufU1FRMTU3VH09MTLxL0wIANM+svAM4MjISd9xxR/zsZz+Ls8466x2vK5VK0x4XRTFj7e36+/ujUqnUj0WLFr1rMwMA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IgBvu+22ePrpp+PnP//5jHOlUmna46IoZqy9ZfPmzTE+Pl4/RkZGGjIvAEAjtbV6gEa7/fbb49FHH40nn3wyFi5cWF+v1WoR8c87gQsWLKivj42Nzbgr+JZyuRzlcrmxAwMANNisvQNYFEXcdttt8fDDD8djjz0WXV1d0853dXVFrVaLgYGB+trJkydjcHAwVqxY0exxAQCaZtbeAdywYUPs3r07fvWrX0V7e3v9fX2VSiXmzp0bpVIpent7o6+vL7q7u6O7uzv6+vpi3rx5sXbt2hZPDwDQOLM2AO+///6IiFi1atW09Z/85Cfx5S9/OSIiNm3aFCdOnIj169fHsWPHYtmyZbF3795ob29v8rQAAM2T5ucANoKfIwQA7z1ev2fxewABADg1AQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGQEIABAMgIQACAZAQgAkIwABABIRgACACQjAAEAkhGAAADJCEAAgGRmbQA++eSTcd1110VnZ2eUSqX45S9/Oe18URSxdevW6OzsjLlz58aqVatieHi4NcMCADTRrA3A48ePxxVXXBE7d+485fnt27fHjh07YufOnTE0NBS1Wi1Wr14dk5OTTZ4UAKC52lo9QKOsWbMm1qxZc8pzRVHEvffeG1u2bIkbbrghIiJ27doV1Wo1du/eHbfcckszRwUAaKpZewfw3zly5EiMjo5GT09Pfa1cLsfKlStj37597/hxU1NTMTExMe0AAHivSRmAo6OjERFRrVanrVer1fq5U+nv749KpVI/Fi1a1NA5AQAaIWUAvqVUKk17XBTFjLW327x5c4yPj9ePkZGRRo8IAPCum7XvAfx3arVaRPzzTuCCBQvq62NjYzPuCr5duVyOcrnc8PkA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7W9/i1/84hexbt26GBwcrJ+3D80xMjISd9xxR+zduzfOOuusd7zOfjTemjVr6r++/PLLY/ny5XHhhRfGrl274qqrroqI3PvgS8D/pQ9+8INx5plnzrjbNzY2NuP/JGiut767y9401+233x6PPvpoPP7447Fw4cL6uv1orjlz5sRFF10UV155ZfT398cVV1wR3/3ud+1Dkz311FMxNjYWS5cujba2tmhra4vBwcG47777oq2trf5nbj+ab/78+XH55ZfH888/7/MiBOB/bc6cObF06dIYGBiYtj4wMBArVqxo0VRERHR1dUWtVpu2NydPnozBwUF70wBFUcRtt90WDz/8cDz22GPR1dU17bz9aK2iKGJqaso+NNm1114bhw8fjkOHDtWPK6+8Mr74xS/GoUOH4kMf+pD9aJGpqal49tlnY8GCBT4vInwX8P9iz549xfve977ixz/+cfHMM88Uvb29xfz584s//elPrR5t1pucnCwOHjxYHDx4sIiIYseOHcXBgweLF198sSiKoti2bVtRqVSKhx9+uDh8+HBx0003FQsWLCgmJiZaPPns89WvfrWoVCrFE088URw9erR+vPbaa/Vr7EdzbN68uXjyySeLI0eOFE8//XTxzW9+szjjjDOKvXv3FkVhH1rt7d8FXBT2o1m+9rWvFU888UTxwgsvFPv37y8+97nPFe3t7fXX6uz7IAD/R9/73veKCy64oJgzZ07xsY99rP6jL2isxx9/vIiIGce6deuKovjnt/bfddddRa1WK8rlcnHNNdcUhw8fbu3Qs9Sp9iEiip/85Cf1a+xHc9x88831/x6de+65xbXXXluPv6KwD632rwFoP5rjxhtvLBYsWFC8733vKzo7O4sbbrihGB4erp/Pvg+loiiK1tx7BACgFbwHEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBkBCAAQDICEAAgGQEIAJCMAAQASEYAAgAkIwABAJIRgAAAyQhAAIBk/g8PSESxkKL9uQAAAABJRU5ErkJggg==' width=640.0/>\n",
       "            </div>\n",
       "        "
      ],
      "text/plain": [
       "Canvas(toolbar=Toolbar(toolitems=[('Home', 'Reset original view', 'home', 'home'), ('Back', 'Back to previous …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "%matplotlib ipympl\n",
    "import numpy as np\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.animation as animation\n",
    "\n",
    "# Box dimensions\n",
    "box_size = 50\n",
    "\n",
    "# Number of particles\n",
    "num_particles = 4\n",
    "particle_radius = 1.0  # Radius of the particles\n",
    "large_num = 1000  # A large number for no collision\n",
    "\n",
    "# Time parameters\n",
    "t_max = 100 # Total simulation time\n",
    "dt = 0.1     # Time step\n",
    "\n",
    "# Initialize positions and velocities\n",
    "np.random.seed(0)  # For reproducibility\n",
    "positions = np.array([[10.0, 20.0],[12, 20.0],[38, 20.0],[40.0, 20]])\n",
    "velocities = np.array([[3.0, 0],[3.0, 0],[-3.0, 0.0],[-3.0, 0.0]]) # random velocities between (-1, 1)\n",
    "\n",
    "# Function to compute the time to the first collision between two particles\n",
    "def particle_collision_time(pos_i, vel_i, pos_j, vel_j):\n",
    "    delta_x = pos_j[0] - pos_i[0]\n",
    "    delta_vx = vel_j[0] - vel_i[0]\n",
    "    delta_y = pos_j[1] - pos_i[1]\n",
    "    delta_vy = vel_j[1] - vel_i[1]\n",
    "    \n",
    "    a = delta_vx**2 + delta_vy**2\n",
    "    b = 2 * (delta_x * delta_vx + delta_y * delta_vy)\n",
    "    c = delta_x**2 + delta_y**2 - 4 * particle_radius**2  # Adjusting for radius\n",
    "    \n",
    "    if a == 0:\n",
    "        return large_num  # Particles moving parallel (no collision)\n",
    "    \n",
    "    Delta = b**2 - 4 * a * c\n",
    "    if Delta < 0:\n",
    "        return large_num  # No real roots, no collision\n",
    "    elif Delta == 0:\n",
    "        t = -b / (2 * a)\n",
    "        return t if t >= 0 else large_num\n",
    "    else:\n",
    "        t1 = (-b + math.sqrt(Delta)) / (2 * a)\n",
    "        t2 = (-b - math.sqrt(Delta)) / (2 * a)\n",
    "        if t1 >= 0 and t2 >= 0:\n",
    "            return min(t1, t2)\n",
    "        elif t1 >= 0:\n",
    "            return t1\n",
    "        elif t2 >= 0:\n",
    "            return t2\n",
    "        return large_num\n",
    "\n",
    "# Function to compute the time to collision with the walls\n",
    "def wall_collision_time(position, velocity):\n",
    "    times = []\n",
    "    for i in range(2):  # x and y directions\n",
    "        if velocity[i] > 0:\n",
    "            t_wall = (box_size - particle_radius - position[i]) / velocity[i]\n",
    "        elif velocity[i] < 0:\n",
    "            t_wall = (particle_radius - position[i]) / velocity[i]\n",
    "        else:\n",
    "            t_wall = large_num  # No movement in this direction\n",
    "        times.append(t_wall)\n",
    "    \n",
    "    return min(times)\n",
    "\n",
    "# Function to find the next collision event\n",
    "def find_earliest_collision(positions, velocities):\n",
    "    min_time = large_num\n",
    "    collision_pair = (-1, -1)  # (-1, -1) means wall collision\n",
    "    \n",
    "    # Check particle-particle collisions\n",
    "    for i in range(num_particles):\n",
    "        for j in range(i + 1, num_particles):\n",
    "            t_collision = particle_collision_time(positions[i], velocities[i], positions[j], velocities[j])\n",
    "            if t_collision < min_time:\n",
    "                min_time = t_collision\n",
    "                collision_pair = (i, j)\n",
    "    \n",
    "    # Check particle-wall collisions\n",
    "    for i in range(num_particles):\n",
    "        t_wall = wall_collision_time(positions[i], velocities[i])\n",
    "        if t_wall < min_time:\n",
    "            min_time = t_wall\n",
    "            collision_pair = (i, -1)  # Indicate wall collision for this particle\n",
    "    \n",
    "    return min_time, collision_pair\n",
    "\n",
    "# Function to resolve the collision (particles or walls)\n",
    "def resolve_collision(collision_pair, positions, velocities):\n",
    "    i, j = collision_pair\n",
    "    if j == -1:  # Wall collision\n",
    "        if positions[i][0] <= particle_radius or positions[i][0] >= box_size - particle_radius:\n",
    "            velocities[i][0] *= -1  # Reverse x-velocity\n",
    "        if positions[i][1] <= particle_radius or positions[i][1] >= box_size - particle_radius:\n",
    "            velocities[i][1] *= -1  # Reverse y-velocity\n",
    "        #print(f'({i}, {j})position of wall colision {positions[i]} and new v:{velocities[i]}')\n",
    "    else:  # Particle-particle collision\n",
    "        delta_pos = positions[i] - positions[j]\n",
    "        dist = np.linalg.norm(delta_pos)\n",
    "        n_hat = delta_pos / dist\n",
    "        delta_v = velocities[i] - velocities[j]\n",
    "        v_rel = np.dot(delta_v, n_hat)\n",
    "        \n",
    "        if v_rel < 0:  # Only resolve if they are moving towards each other\n",
    "            velocities[i] -= v_rel * n_hat\n",
    "            velocities[j] += v_rel * n_hat\n",
    "        #print(f'({i}, {j}) new i: p:{positions[i]}, v:{velocities[i]}\\n and j: p:{positions[j]},v:{velocities[j]}')\n",
    "    \n",
    "\n",
    "#t = 0\n",
    "# while t < t_max:\n",
    "#     delta_t, collision_pair = find_earliest_collision(positions, velocities)\n",
    "#     positions += velocities * delta_t\n",
    "#     resolve_collision(collision_pair, positions, velocities)\n",
    "#     positions += velocities * 0.01\n",
    "#     t += (delta_t + 0.01)\n",
    "#     print(f'delta t is {delta_t}')\n",
    "# Visualization setup\n",
    "fig, ax = plt.subplots()\n",
    "ax.set_xlim(0, box_size)\n",
    "ax.set_ylim(0, box_size)\n",
    "particles, = ax.plot([], [], 'bo', ms=10)\n",
    "\n",
    "def init():\n",
    "    particles.set_data([], [])\n",
    "    return particles,\n",
    "\n",
    "def animate(frame):\n",
    "    global positions, velocities, dt\n",
    "    \n",
    "    # Find the earliest collision\n",
    "    delta_t, collision_pair = find_earliest_collision(positions, velocities)\n",
    "    \n",
    "    # Update positions to the collision time\n",
    "    if delta_t < dt:\n",
    "        \n",
    "        positions += velocities * delta_t\n",
    "        resolve_collision(collision_pair, positions, velocities)\n",
    "        #positions += velocities * 0.001\n",
    "        #t += (delta_t + 0.01)\n",
    "        #print(f'delta t is {delta_t}')\n",
    "        dt -= delta_t\n",
    "    else:\n",
    "        positions += velocities * dt\n",
    "        dt = 0.1  # Reset time step after each update\n",
    "    \n",
    "    particles.set_data(positions[:, 0], positions[:, 1])\n",
    "    return particles,\n",
    "\n",
    "# Animation\n",
    "ani = animation.FuncAnimation(fig, animate, frames=int(t_max/dt), init_func=init,\n",
    "                              interval=20, blit=True, repeat=False)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ff09b5591b2840d5b3fc183a63a32231",
       "version_major": 2,
       "version_minor": 0
      },
      "image/png": "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",
      "text/html": [
       "\n",
       "            <div style=\"display: inline-block;\">\n",
       "                <div class=\"jupyter-widgets widget-label\" style=\"text-align: center;\">\n",
       "                    Figure\n",
       "                </div>\n",
       "                <img src='data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAoAAAAHgCAYAAAA10dzkAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAeX0lEQVR4nO3df5DU9X348dfJj+Wgd1eBcstFIMfMzWhyJkGwTJEGUuUyDTF1nEYjasyk04EihpM2/Chpg069E9pSp6Ehg9MxtpbidKKp7diWy4+eWtpK+JEgdrSZULhYb65JyB4Gehfh3T8c9tsN2JB83Vu49+Mx8/lj35/3ru/dtzf75HPLUpdSSgEAQDYuq/UCAAAYWQIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgM5dkAD7zzDNx4403RktLS9TV1cUXv/jFivMppdi0aVO0tLREfX19LF68OA4fPlwxZ2hoKO65556YOnVqTJo0KT70oQ/Ft7/97RF8FgAAtXFJBuAPfvCDePe73x3btm077/ktW7bE1q1bY9u2bbF3794oFouxZMmSOHHiRHlOZ2dnPPnkk7Fr16547rnn4rXXXosPfvCDcfr06ZF6GgAANVGXUkq1XsT/j7q6unjyySfjpptuiog3rv61tLREZ2dnrFu3LiLeuNrX3NwcmzdvjuXLl0epVIqf+7mfiz//8z+PW2+9NSIi/vM//zNmzJgRTz/9dLz//e+v1dMBAKi6S/IK4P/lyJEj0d/fHx0dHeWxQqEQixYtij179kRExL59++KHP/xhxZyWlpZob28vzwEAGK3G1noBb7X+/v6IiGhubq4Yb25ujqNHj5bnjB8/Pi6//PJz5py9//kMDQ3F0NBQ+faZM2fie9/7XkyZMiXq6ureqqcAAFRRSilOnDgRLS0tcdllo+5a2AUZdQF41o8GWUrpx0baj5vT3d0d991331uyPgCgtvr6+uKKK66o9TJqYtQFYLFYjIg3rvJNnz69PD4wMFC+KlgsFmN4eDiOHz9ecRVwYGAgFixY8KaPvWHDhlizZk35dqlUipkzZ0ZfX180Nja+1U8FAKiCwcHBmDFjRjQ0NNR6KTUz6gKwtbU1isVi9PT0xJw5cyIiYnh4OHp7e2Pz5s0RETF37twYN25c9PT0xC233BIREa+++mq88MILsWXLljd97EKhEIVC4ZzxxsZGAQgAl5icP751SQbga6+9Ft/85jfLt48cORIHDx6MyZMnx8yZM6OzszO6urqira0t2traoqurKyZOnBjLli2LiIimpqb4tV/7tfjN3/zNmDJlSkyePDl+67d+K66++uq44YYbavW0AABGxCUZgF/72tfife97X/n22V/L3nXXXfH5z38+1q5dG6dOnYqVK1fG8ePHY/78+bF79+6KS71/9Ed/FGPHjo1bbrklTp06Fddff318/vOfjzFjxoz48wEAGEmX/PcA1tLg4GA0NTVFqVTyK2AAuER4/x6F3wMIAMD/TQACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZGbUBuDrr78en/rUp6K1tTXq6+tj9uzZcf/998eZM2fKc1JKsWnTpmhpaYn6+vpYvHhxHD58uIarBgCovlEbgJs3b47Pfe5zsW3btvi3f/u32LJlS/z+7/9+fOYznynP2bJlS2zdujW2bdsWe/fujWKxGEuWLIkTJ07UcOUAANU1agPwn//5n+NXfuVXYunSpfH2t789fvVXfzU6Ojria1/7WkS8cfXvoYceio0bN8bNN98c7e3t8eijj8bJkydj586dNV49AED1jNoAXLhwYXz5y1+Ol19+OSIivv71r8dzzz0XH/jAByIi4siRI9Hf3x8dHR3l+xQKhVi0aFHs2bOnJmsGABgJY2u9gGpZt25dlEqluPLKK2PMmDFx+vTpeOCBB+K2226LiIj+/v6IiGhubq64X3Nzcxw9evS8jzk0NBRDQ0Pl24ODg1VaPQBA9YzaK4CPP/54PPbYY7Fz587Yv39/PProo/EHf/AH8eijj1bMq6urq7idUjpn7Kzu7u5oamoqHzNmzKja+gEAqmXUBuAnP/nJWL9+fXzkIx+Jq6++Ou6888649957o7u7OyIiisViRPy/K4FnDQwMnHNV8KwNGzZEqVQqH319fdV9EgAAVTBqA/DkyZNx2WWVT2/MmDHlr4FpbW2NYrEYPT095fPDw8PR29sbCxYsOO9jFgqFaGxsrDgAAC41o/YzgDfeeGM88MADMXPmzHjnO98ZBw4ciK1bt8bHP/7xiHjjV7+dnZ3R1dUVbW1t0dbWFl1dXTFx4sRYtmxZjVcPAFA9ozYAP/OZz8Tv/M7vxMqVK2NgYCBaWlpi+fLl8bu/+7vlOWvXro1Tp07FypUr4/jx4zF//vzYvXt3NDQ01HDlAADVVZdSSrVexKVqcHAwmpqaolQq+XUwAFwivH+P4s8AAgBwfgIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDMCEAAgMwIQACAzAhAAIDOjOgBfeeWVuOOOO2LKlCkxceLEeM973hP79u0rn08pxaZNm6KlpSXq6+tj8eLFcfjw4RquGACg+kZtAB4/fjyuu+66GDduXPzd3/1dvPjii/GHf/iH8bM/+7PlOVu2bImtW7fGtm3bYu/evVEsFmPJkiVx4sSJ2i0cAKDK6lJKqdaLqIb169fHP/3TP8Wzzz573vMppWhpaYnOzs5Yt25dREQMDQ1Fc3NzbN68OZYvX/5j/xuDg4PR1NQUpVIpGhsb39L1AwDV4f17FF8BfOqpp2LevHnx4Q9/OKZNmxZz5syJhx9+uHz+yJEj0d/fHx0dHeWxQqEQixYtij179pz3MYeGhmJwcLDiAAC41IzaAPzWt74V27dvj7a2tviHf/iHWLFiRXziE5+IP/uzP4uIiP7+/oiIaG5urrhfc3Nz+dyP6u7ujqampvIxY8aM6j4JAIAqGLUBeObMmbjmmmuiq6sr5syZE8uXL49f//Vfj+3bt1fMq6urq7idUjpn7KwNGzZEqVQqH319fVVbPwBAtYzaAJw+fXq84x3vqBi76qqr4tixYxERUSwWIyLOudo3MDBwzlXBswqFQjQ2NlYcAACXmlEbgNddd1289NJLFWMvv/xyzJo1KyIiWltbo1gsRk9PT/n88PBw9Pb2xoIFC0Z0rQAAI2lsrRdQLffee28sWLAgurq64pZbbonnn38+duzYETt27IiIN37129nZGV1dXdHW1hZtbW3R1dUVEydOjGXLltV49QAA1TNqA/Daa6+NJ598MjZs2BD3339/tLa2xkMPPRS33357ec7atWvj1KlTsXLlyjh+/HjMnz8/du/eHQ0NDTVcOQBAdY3a7wEcCb5HCAAuPd6/R/FnAAEAOD8BCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJCZLAKwu7s76urqorOzszyWUopNmzZFS0tL1NfXx+LFi+Pw4cO1WyQAwAgZ9QG4d+/e2LFjR7zrXe+qGN+yZUts3bo1tm3bFnv37o1isRhLliyJEydO1GilAAAjY1QH4GuvvRa33357PPzww3H55ZeXx1NK8dBDD8XGjRvj5ptvjvb29nj00Ufj5MmTsXPnzhquGACg+kZ1AN59992xdOnSuOGGGyrGjxw5Ev39/dHR0VEeKxQKsWjRotizZ8+bPt7Q0FAMDg5WHAAAl5qxtV5AtezatSv2798fe/fuPedcf39/REQ0NzdXjDc3N8fRo0ff9DG7u7vjvvvue2sXCgAwwkblFcC+vr5YvXp1PPbYYzFhwoQ3nVdXV1dxO6V0ztj/tmHDhiiVSuWjr6/vLVszAMBIGZVXAPft2xcDAwMxd+7c8tjp06fjmWeeiW3btsVLL70UEW9cCZw+fXp5zsDAwDlXBf+3QqEQhUKhegsHABgBo/IK4PXXXx+HDh2KgwcPlo958+bF7bffHgcPHozZs2dHsViMnp6e8n2Gh4ejt7c3FixYUMOVAwBU36i8AtjQ0BDt7e0VY5MmTYopU6aUxzs7O6Orqyva2tqira0turq6YuLEibFs2bJaLBkAYMSMygC8EGvXro1Tp07FypUr4/jx4zF//vzYvXt3NDQ01HppAABVVZdSSrVexKVqcHAwmpqaolQqRWNjY62XAwBcAO/fo/QzgAAAvDkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJAZAQgAkBkBCACQGQEIAJCZURuA3d3dce2110ZDQ0NMmzYtbrrppnjppZcq5qSUYtOmTdHS0hL19fWxePHiOHz4cI1WDAAwMkZtAPb29sbdd98d//Iv/xI9PT3x+uuvR0dHR/zgBz8oz9myZUts3bo1tm3bFnv37o1isRhLliyJEydO1HDlAADVVZdSSrVexEj4r//6r5g2bVr09vbGe9/73kgpRUtLS3R2dsa6desiImJoaCiam5tj8+bNsXz58h/7mIODg9HU1BSlUikaGxur/RQAgLeA9+9RfAXwR5VKpYiImDx5ckREHDlyJPr7+6Ojo6M8p1AoxKJFi2LPnj3nfYyhoaEYHBysOAAALjVZBGBKKdasWRMLFy6M9vb2iIjo7++PiIjm5uaKuc3NzeVzP6q7uzuamprKx4wZM6q7cACAKsgiAFetWhXf+MY34i//8i/POVdXV1dxO6V0zthZGzZsiFKpVD76+vqqsl4AgGoaW+sFVNs999wTTz31VDzzzDNxxRVXlMeLxWJEvHElcPr06eXxgYGBc64KnlUoFKJQKFR3wQAAVTZqrwCmlGLVqlXxxBNPxFe+8pVobW2tON/a2hrFYjF6enrKY8PDw9Hb2xsLFiwY6eUCAIyYUXsF8O67746dO3fGX//1X0dDQ0P5c31NTU1RX18fdXV10dnZGV1dXdHW1hZtbW3R1dUVEydOjGXLltV49QAA1TNqA3D79u0REbF48eKK8UceeSQ+9rGPRUTE2rVr49SpU7Fy5co4fvx4zJ8/P3bv3h0NDQ0jvFoAgJGTzfcAVoPvEQKAS4/371H8GUAAAM5PAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkRgACAGRGAAIAZEYAAgBkJvsA/OxnPxutra0xYcKEmDt3bjz77LO1XhIAQFVlHYCPP/54dHZ2xsaNG+PAgQPxi7/4i/HLv/zLcezYsVovDQCgaupSSqnWi6iV+fPnxzXXXBPbt28vj1111VVx0003RXd394+9/+DgYDQ1NUWpVIrGxsZqLhUAeIt4/44YW+sF1Mrw8HDs27cv1q9fXzHe0dERe/bsOe99hoaGYmhoqHy7VCpFxBv/IwEAl4az79sZXwPLNwC/853vxOnTp6O5ublivLm5Ofr7+897n+7u7rjvvvvOGZ8xY0ZV1ggAVM93v/vdaGpqqvUyaiLbADyrrq6u4nZK6ZyxszZs2BBr1qwp3/7+978fs2bNimPHjmX7P9DFYnBwMGbMmBF9fX3ZXs6/WNiLi4v9uHjYi4tHqVSKmTNnxuTJk2u9lJrJNgCnTp0aY8aMOedq38DAwDlXBc8qFApRKBTOGW9qavLDfJFobGy0FxcJe3FxsR8XD3tx8bjssnz/Lmy2z3z8+PExd+7c6OnpqRjv6emJBQsW1GhVAADVl+0VwIiINWvWxJ133hnz5s2LX/iFX4gdO3bEsWPHYsWKFbVeGgBA1WQdgLfeemt897vfjfvvvz9effXVaG9vj6effjpmzZp1QfcvFArx6U9/+ry/FmZk2YuLh724uNiPi4e9uHjYi8y/BxAAIEfZfgYQACBXAhAAIDMCEAAgMwIQACAzAvCn9NnPfjZaW1tjwoQJMXfu3Hj22WdrvaRRr7u7O6699tpoaGiIadOmxU033RQvvfRSxZyUUmzatClaWlqivr4+Fi9eHIcPH67RivPR3d0ddXV10dnZWR6zFyPrlVdeiTvuuCOmTJkSEydOjPe85z2xb9++8nn7MTJef/31+NSnPhWtra1RX18fs2fPjvvvvz/OnDlTnmMvquOZZ56JG2+8MVpaWqKuri6++MUvVpy/kNd9aGgo7rnnnpg6dWpMmjQpPvShD8W3v/3tEXwWIyjxE9u1a1caN25cevjhh9OLL76YVq9enSZNmpSOHj1a66WNau9///vTI488kl544YV08ODBtHTp0jRz5sz02muvlec8+OCDqaGhIX3hC19Ihw4dSrfeemuaPn16GhwcrOHKR7fnn38+vf3tb0/vete70urVq8vj9mLkfO9730uzZs1KH/vYx9K//uu/piNHjqQvfelL6Zvf/GZ5jv0YGb/3e7+XpkyZkv72b/82HTlyJP3VX/1V+pmf+Zn00EMPlefYi+p4+umn08aNG9MXvvCFFBHpySefrDh/Ia/7ihUr0tve9rbU09OT9u/fn973vveld7/73en1118f4WdTfQLwp/DzP//zacWKFRVjV155ZVq/fn2NVpSngYGBFBGpt7c3pZTSmTNnUrFYTA8++GB5zn//93+npqam9LnPfa5WyxzVTpw4kdra2lJPT09atGhROQDtxchat25dWrhw4Zuetx8jZ+nSpenjH/94xdjNN9+c7rjjjpSSvRgpPxqAF/K6f//730/jxo1Lu3btKs955ZVX0mWXXZb+/u//fsTWPlL8CvgnNDw8HPv27YuOjo6K8Y6OjtizZ0+NVpWnUqkUEVH+x7yPHDkS/f39FXtTKBRi0aJF9qZK7r777li6dGnccMMNFeP2YmQ99dRTMW/evPjwhz8c06ZNizlz5sTDDz9cPm8/Rs7ChQvjy1/+crz88ssREfH1r389nnvuufjABz4QEfaiVi7kdd+3b1/88Ic/rJjT0tIS7e3to3Jvsv6XQH4a3/nOd+L06dPR3NxcMd7c3Bz9/f01WlV+UkqxZs2aWLhwYbS3t0dElF//8+3N0aNHR3yNo92uXbti//79sXfv3nPO2YuR9a1vfSu2b98ea9asid/+7d+O559/Pj7xiU9EoVCIj370o/ZjBK1bty5KpVJceeWVMWbMmDh9+nQ88MADcdttt0WEn41auZDXvb+/P8aPHx+XX375OXNG4/u7APwp1dXVVdxOKZ0zRvWsWrUqvvGNb8Rzzz13zjl7U319fX2xevXq2L17d0yYMOFN59mLkXHmzJmYN29edHV1RUTEnDlz4vDhw7F9+/b46Ec/Wp5nP6rv8ccfj8ceeyx27twZ73znO+PgwYPR2dkZLS0tcdddd5Xn2Yva+Gle99G6N34F/BOaOnVqjBkz5pw/DQwMDJzzJwuq45577omnnnoqvvrVr8YVV1xRHi8WixER9mYE7Nu3LwYGBmLu3LkxduzYGDt2bPT29sYf//Efx9ixY8uvt70YGdOnT493vOMdFWNXXXVVHDt2LCL8bIykT37yk7F+/fr4yEc+EldffXXceeedce+990Z3d3dE2ItauZDXvVgsxvDwcBw/fvxN54wmAvAnNH78+Jg7d2709PRUjPf09MSCBQtqtKo8pJRi1apV8cQTT8RXvvKVaG1trTjf2toaxWKxYm+Gh4ejt7fX3rzFrr/++jh06FAcPHiwfMybNy9uv/32OHjwYMyePdtejKDrrrvunK9Eevnll2PWrFkR4WdjJJ08eTIuu6zyrXXMmDHlr4GxF7VxIa/73LlzY9y4cRVzXn311XjhhRdG597U7K+fXMLOfg3Mn/7pn6YXX3wxdXZ2pkmTJqX/+I//qPXSRrXf+I3fSE1NTekf//Ef06uvvlo+Tp48WZ7z4IMPpqampvTEE0+kQ4cOpdtuu83XK4yQ//23gFOyFyPp+eefT2PHjk0PPPBA+vd///f0F3/xF2nixInpscceK8+xHyPjrrvuSm9729vKXwPzxBNPpKlTp6a1a9eW59iL6jhx4kQ6cOBAOnDgQIqItHXr1nTgwIHyV7RdyOu+YsWKdMUVV6QvfelLaf/+/emXfumXfA0Mlf7kT/4kzZo1K40fPz5dc8015a8ioXoi4rzHI488Up5z5syZ9OlPfzoVi8VUKBTSe9/73nTo0KHaLTojPxqA9mJk/c3f/E1qb29PhUIhXXnllWnHjh0V5+3HyBgcHEyrV69OM2fOTBMmTEizZ89OGzduTENDQ+U59qI6vvrVr573PeKuu+5KKV3Y637q1Km0atWqNHny5FRfX58++MEPpmPHjtXg2VRfXUop1ebaIwAAteAzgAAAmRGAAACZEYAAAJkRgAAAmRGAAACZEYAAAJkRgAAAmRGAAACZEYAAAJkRgAAAmRGAAACZEYAAAJkRgAAAmRGAAACZEYAAAJkRgAAAmRGAAACZEYAAAJkRgAAAmRGAAACZEYAAAJkRgAAAmRGAAACZEYAAAJkRgAAAmRGAAACZEYAAAJkRgAAAmRGAAACZEYAAAJkRgAAAmfkfm9oJWosAOa4AAAAASUVORK5CYII=' width=640.0/>\n",
       "            </div>\n",
       "        "
      ],
      "text/plain": [
       "Canvas(toolbar=Toolbar(toolitems=[('Home', 'Reset original view', 'home', 'home'), ('Back', 'Back to previous …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\n",
    "%matplotlib ipympl\n",
    "import numpy as np\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.animation as animation\n",
    "\n",
    "# Box dimensions\n",
    "box_size = 100\n",
    "\n",
    "# Number of particles\n",
    "num_particles = 4\n",
    "particle_radius = 2.0  # Radius of the particles\n",
    "large_num = 1000  # A large number for no collision\n",
    "\n",
    "# Time parameters\n",
    "t_max = 100 # Total simulation time\n",
    "dt = 0.1     # Time step\n",
    "\n",
    "# Initialize positions and velocities\n",
    "np.random.seed(0)  # For reproducibility\n",
    "positions = np.array([[10.0, 10.0],[19, 9.0],[40, 40.0],[36.0, 40]])\n",
    "velocities = np.array([[1.5, 1.5],[-3, 0],[-1.5, 0.0],[-1.5, 0.0]])\n",
    "\n",
    "# Function to compute the time to the first collision between two particles\n",
    "def particle_collision_time(pos_i, vel_i, pos_j, vel_j):\n",
    "    delta_x = pos_j[0] - pos_i[0]\n",
    "    delta_vx = vel_j[0] - vel_i[0]\n",
    "    delta_y = pos_j[1] - pos_i[1]\n",
    "    delta_vy = vel_j[1] - vel_i[1]\n",
    "    #print(f'delta_x:{delta_x}, delta_y:{delta_y}, delta_vy:{delta_vy}, delta_vx:{delta_vx}')\n",
    "    a = delta_vx**2 + delta_vy**2\n",
    "    b = 2 * (delta_x * delta_vx + delta_y * delta_vy)\n",
    "    c = delta_x**2 + delta_y**2 - 4 * particle_radius**2  # Adjusting for radius\n",
    "    \n",
    "    if a == 0:\n",
    "        return large_num  # Particles moving parallel (no collision)\n",
    "    \n",
    "    Delta = b**2 - 4 * a * c\n",
    "    if Delta < 0:\n",
    "        return large_num  # No real roots, no collision\n",
    "    elif Delta == 0:\n",
    "        t = -b / (2 * a)\n",
    "        return t if t >= 0 else large_num\n",
    "    else:\n",
    "        t1 = (-b + math.sqrt(Delta)) / (2 * a)\n",
    "        t2 = (-b - math.sqrt(Delta)) / (2 * a)\n",
    "        if t1 >= 0 and t2 >= 0:\n",
    "            #print(f'delta>0 and {t1} and {t2}')\n",
    "            return min(t1, t2)\n",
    "        elif t1 >= 0:\n",
    "            return t1\n",
    "        elif t2 >= 0:\n",
    "            return t2\n",
    "        return large_num\n",
    "\n",
    "# Function to compute the time to collision with the walls\n",
    "def wall_collision_time(position, velocity):\n",
    "    times = []\n",
    "    for i in range(2):  # x and y directions\n",
    "        if velocity[i] > 0:\n",
    "            t_wall = (box_size - particle_radius - position[i]) / velocity[i]\n",
    "        elif velocity[i] < 0:\n",
    "            t_wall = (particle_radius - position[i]) / velocity[i]\n",
    "        else:\n",
    "            t_wall = large_num  # No movement in this direction\n",
    "        times.append(t_wall)\n",
    "    \n",
    "    return min(times)\n",
    "\n",
    "# Function to find the next collision event\n",
    "def find_earliest_collision(positions, velocities):\n",
    "    min_time = large_num\n",
    "    collision_pair = (-1, -1)  # (-1, -1) means wall collision\n",
    "    \n",
    "    # Check particle-particle collisions\n",
    "    for i in range(num_particles):\n",
    "        for j in range(i + 1, num_particles):\n",
    "            t_collision = particle_collision_time(positions[i], velocities[i], positions[j], velocities[j])\n",
    "            if t_collision < min_time:\n",
    "                min_time = t_collision\n",
    "                #print(min_time)\n",
    "                collision_pair = (i, j)\n",
    "    \n",
    "    # Check particle-wall collisions\n",
    "    for i in range(num_particles):\n",
    "        t_wall = wall_collision_time(positions[i], velocities[i])\n",
    "        if t_wall < min_time:\n",
    "            min_time = t_wall\n",
    "            collision_pair = (i, -1)  # Indicate wall collision for this particle\n",
    "    \n",
    "    return min_time, collision_pair\n",
    "def update_positions(positions, velocities, dt):\n",
    "    # Update positions\n",
    "    positions += velocities * dt\n",
    "    \n",
    "    #print(positions)\n",
    "    # Check for boundary collisions and reflect velocities\n",
    "    for i in range(num_particles):\n",
    "        for j in range(2):  # x and y directions\n",
    "            if positions[i, j] <= particle_radius or positions[i, j] >= box_size - particle_radius:\n",
    "                velocities[i, j] *= -1\n",
    "                \n",
    "                #pressure += 1\n",
    "                positions[i, j] = np.clip(positions[i, j], particle_radius, box_size - particle_radius)\n",
    "                #print(f'wall collision for {i} at {dt}s and position:{positions[i]}')\n",
    "                #print(f'({i}, {j})position of wall colision {positions[i]} and new v:{velocities[i]}')\n",
    "    # Check for particle collisions\n",
    "    for i in range(num_particles):\n",
    "        for j in range(i + 1, num_particles):\n",
    "            dist = np.linalg.norm(positions[i] - positions[j])\n",
    "            if dist <= 2 * particle_radius:  # Collision condition\n",
    "                #print(f'for {i}, {j} we have a collision at position{positions[i]} and {positions[j]}')\n",
    "                resolve_collision(i, j, positions, velocities)\n",
    "    positions += velocities * 0.00000001\n",
    "    \n",
    "    return positions\n",
    "# Function to resolve the collision (particles or walls)\n",
    "def resolve_collision(i, j, positions, velocities):\n",
    "    # Calculate the normal vector\n",
    "    delta_pos = positions[i] - positions[j]\n",
    "    dist = np.linalg.norm(delta_pos)\n",
    "    delta_v = velocities[i] - velocities[j]\n",
    "    # Normal vector\n",
    "    n_hat = delta_pos / (dist**2)\n",
    "    #print(f'dist is {dist}')\n",
    "    # Relative velocity\n",
    "    \n",
    "    \n",
    "    # Velocity component along the normal direction\n",
    "    v_rel = np.dot(delta_v, delta_pos)\n",
    "    \n",
    "    # Update velocities if particles are moving towards each other\n",
    "    if v_rel < 0:\n",
    "        velocities[i] -= v_rel * n_hat\n",
    "        velocities[j] += v_rel * n_hat\n",
    "    #print(f'({i},{j}) new i: p:{positions[i]}, v:{velocities[i]}\\n and j: p:{positions[j]},v:{velocities[j]}')\n",
    "    \n",
    "\n",
    "# t = 0\n",
    "# while t < t_max:\n",
    "#     delta_t, collision_pair = find_earliest_collision(positions, velocities)\n",
    "#     print(f'delta t is {delta_t}')\n",
    "#     positions = update_positions(positions, velocities, delta_t)\n",
    "#     t += (delta_t +0.00000001)\n",
    "#     print(f'delta t is {delta_t}')\n",
    "    \n",
    "#Visualization setup\n",
    "fig, ax = plt.subplots()\n",
    "ax.set_xlim(0, box_size)\n",
    "ax.set_ylim(0, box_size)\n",
    "particles, = ax.plot([], [], 'bo', ms=10)\n",
    "\n",
    "def init():\n",
    "    particles.set_data([], [])\n",
    "    return particles,\n",
    "\n",
    "def animate(frame):\n",
    "    global positions, velocities, dt\n",
    "    \n",
    "    # Find the earliest collision\n",
    "    delta_t, collision_pair = find_earliest_collision(positions, velocities)\n",
    "    \n",
    "    # Update positions to the collision time\n",
    "    if delta_t < dt:\n",
    "        positions = update_positions(positions, velocities, delta_t)\n",
    "        # positions += velocities * delta_t\n",
    "        #print(f'colision pair is {collision_pair}')\n",
    "        #print(delta_t)\n",
    "        # #print(f'delta t is {delta_t} and poistions {positions}')\n",
    "        # resolve_collision(collision_pair, positions, velocities)\n",
    "        # #positions += velocities * 0.001\n",
    "        # #t += (delta_t + 0.01)\n",
    "        # #print(f'delta t is {delta_t}')\n",
    "        dt -= (delta_t + 0.00000001)\n",
    "    else:\n",
    "        positions = update_positions(positions, velocities, dt)\n",
    "        dt = 0.1  # Reset time step after each update\n",
    "    \n",
    "    particles.set_data(positions[:, 0], positions[:, 1])\n",
    "    return particles,\n",
    "\n",
    "# Animation\n",
    "ani = animation.FuncAnimation(fig, animate, frames=int(t_max/dt), init_func=init,\n",
    "                              interval=20, blit=True, repeat=False)\n",
    "\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[10. 10.]\n",
      " [90. 90.]]\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e4c74b7b5dce4b07b8e1a4e66c016daf",
       "version_major": 2,
       "version_minor": 0
      },
      "image/png": "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",
      "text/html": [
       "\n",
       "            <div style=\"display: inline-block;\">\n",
       "                <div class=\"jupyter-widgets widget-label\" style=\"text-align: center;\">\n",
       "                    Figure\n",
       "                </div>\n",
       "                <img src='data:image/png;base64,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' width=640.0/>\n",
       "            </div>\n",
       "        "
      ],
      "text/plain": [
       "Canvas(toolbar=Toolbar(toolitems=[('Home', 'Reset original view', 'home', 'home'), ('Back', 'Back to previous …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "for 0, 1 we have a collision at position[48.58578944 48.58578944] and [51.41421056 51.41421056],dist:3.999991514718629\n",
      "wall collision for 0 at 0.09024429175122618s and position:[2.       1.999997]\n",
      "wall collision for 0 at 0.09024429175122618s and position:[2. 2.]\n",
      "wall collision for 1 at 0.09024429175122618s and position:[98.       98.000003]\n",
      "wall collision for 1 at 0.09024429175122618s and position:[98. 98.]\n",
      "for 0, 1 we have a collision at position[48.58578944 48.58578944] and [51.41421056 51.41421056],dist:3.999991514718629\n",
      "wall collision for 0 at 0.04712725016911429s and position:[2.       1.999997]\n",
      "wall collision for 0 at 0.04712725016911429s and position:[2. 2.]\n",
      "wall collision for 1 at 0.04712725016911429s and position:[98.       98.000003]\n",
      "wall collision for 1 at 0.04712725016911429s and position:[98. 98.]\n",
      "for 0, 1 we have a collision at position[48.58578944 48.58578944] and [51.41421056 51.41421056],dist:3.9999915147186194\n",
      "wall collision for 0 at 0.004010208587007149s and position:[2.       1.999997]\n",
      "wall collision for 0 at 0.004010208587007149s and position:[2. 2.]\n",
      "wall collision for 1 at 0.004010208587007149s and position:[98.       98.000003]\n",
      "wall collision for 1 at 0.004010208587007149s and position:[98. 98.]\n",
      "for 0, 1 we have a collision at position[48.58578944 48.58578944] and [51.41421056 51.41421056],dist:3.9999915147186194\n",
      "wall collision for 0 at 0.06089416700489885s and position:[2.       1.999997]\n",
      "wall collision for 0 at 0.06089416700489885s and position:[2. 2.]\n",
      "wall collision for 1 at 0.06089416700489885s and position:[98.       98.000003]\n",
      "wall collision for 1 at 0.06089416700489885s and position:[98. 98.]\n",
      "for 0, 1 we have a collision at position[48.58578944 48.58578944] and [51.41421056 51.41421056],dist:3.999991514718629\n"
     ]
    }
   ],
   "source": [
    "\n",
    "\n",
    "%matplotlib ipympl\n",
    "import numpy as np\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.animation as animation\n",
    "\n",
    "# Box dimensions\n",
    "box_size = 100\n",
    "\n",
    "# Number of particles\n",
    "num_particles = 2\n",
    "particle_radius = 2.0  # Radius of the particles\n",
    "large_num = 100 # A large number for no collision\n",
    "epsilon = 1e-5  # Small threshold to avoid repeated collisions\n",
    "\n",
    "# Time parameters\n",
    "t_max = 150 # Total simulation time\n",
    "dt = 0.1     # Time step\n",
    "\n",
    "# Initialize positions and velocities\n",
    "np.random.seed(0)  # For reproducibility\n",
    "positions = np.array([[10.0, 10.0],[90, 90.0]])\n",
    "velocities = np.array([[3.0, 3.0],[-3.0, -3.0]])\n",
    "print(positions)\n",
    "# Function to compute the time to the first collision between two particles\n",
    "def particle_collision_time(pos_i, vel_i, pos_j, vel_j):\n",
    "    delta_x = pos_j[0] - pos_i[0]\n",
    "    delta_vx = vel_j[0] - vel_i[0]\n",
    "    delta_y = pos_j[1] - pos_i[1]\n",
    "    delta_vy = vel_j[1] - vel_i[1]\n",
    "    #print(f'delta_x:{delta_x}, delta_y:{delta_y}, delta_vy:{delta_vy}, delta_vx:{delta_vx}')\n",
    "    a = delta_vx**2 + delta_vy**2\n",
    "    b = 2 * (delta_x * delta_vx + delta_y * delta_vy)\n",
    "    c = delta_x**2 + delta_y**2 - 4 * particle_radius**2  # Adjusting for radius\n",
    "    \n",
    "    if a == 0:\n",
    "        return large_num  # Particles moving parallel (no collision)\n",
    "    \n",
    "    Delta = b**2 - 4 * a * c\n",
    "    if Delta < 0:\n",
    "        return large_num  # No real roots, no collision\n",
    "    elif Delta == 0:\n",
    "        t = -b / (2 * a)\n",
    "        return t if t >= 0 else large_num\n",
    "    else:\n",
    "        t1 = (-b + math.sqrt(Delta)) / (2 * a)\n",
    "        t2 = (-b - math.sqrt(Delta)) / (2 * a)\n",
    "        if t1 >= 0 and t2 >= 0:\n",
    "            #print(f'delta>0 and {t1} and {t2}')\n",
    "            return min(t1, t2)\n",
    "        elif t1 >= 0:\n",
    "            return t1\n",
    "        elif t2 >= 0:\n",
    "            return t2\n",
    "        return large_num\n",
    "\n",
    "# Function to compute the time to collision with the walls\n",
    "def wall_collision_time(position, velocity):\n",
    "    times = []\n",
    "    for i in range(2):  # x and y directions\n",
    "        if velocity[i] > 0:\n",
    "            t_wall = (box_size - particle_radius - position[i]) / velocity[i]\n",
    "        elif velocity[i] < 0:\n",
    "            t_wall = (particle_radius - position[i]) / velocity[i]\n",
    "        else:\n",
    "            t_wall = large_num  # No movement in this direction\n",
    "        times.append(t_wall)\n",
    "    \n",
    "    return min(times)\n",
    "\n",
    "# Function to find the next collision event\n",
    "def find_earliest_collision(positions, velocities):\n",
    "    min_time = large_num\n",
    "    collision_pair = (-1, -1)  # (-1, -1) means wall collision\n",
    "    \n",
    "    # Check particle-particle collisions\n",
    "    for i in range(num_particles):\n",
    "        for j in range(i + 1, num_particles):\n",
    "            t_collision = particle_collision_time(positions[i], velocities[i], positions[j], velocities[j])\n",
    "            if t_collision < min_time:\n",
    "                min_time = t_collision\n",
    "                #print(min_time)\n",
    "                collision_pair = (i, j)\n",
    "    \n",
    "    # Check particle-wall collisions\n",
    "    for i in range(num_particles):\n",
    "        t_wall = wall_collision_time(positions[i], velocities[i])\n",
    "        if t_wall < min_time:\n",
    "            min_time = t_wall\n",
    "            collision_pair = (i, -1)  # Indicate wall collision for this particle\n",
    "    \n",
    "    return min_time, collision_pair\n",
    "def update_positions(positions, velocities, dt, collision_pair):\n",
    "    # Update positions\n",
    "    positions += velocities * dt\n",
    "    p, q = collision_pair\n",
    "    #print(f'dist is {np.linalg.norm(positions[p] - positions[q])}')\n",
    "    #print(positions)\n",
    "    # Check for boundary collisions and reflect velocities\n",
    "    for i in range(num_particles):\n",
    "        for j in range(2):  # x and y directions\n",
    "            if positions[i, j] <= particle_radius or positions[i, j] >= box_size - particle_radius:\n",
    "                velocities[i, j] *= -1\n",
    "                \n",
    "                #pressure += 1\n",
    "                positions[i, j] = np.clip(positions[i, j], particle_radius, box_size - particle_radius)\n",
    "                print(f'wall collision for {i} at {dt}s and position:{positions[i]}')\n",
    "                #print(f'({i}, {j})position of wall colision {positions[i]} and new v:{velocities[i]}')\n",
    "    # Check for particle collisions\n",
    "    for i in range(num_particles):\n",
    "        for j in range(i + 1, num_particles):\n",
    "            dist = np.linalg.norm(positions[i] - positions[j])\n",
    "            if dist <= 2 * particle_radius:  # Collision condition\n",
    "                print(f'for {i}, {j} we have a collision at position{positions[i]} and {positions[j]},dist:{dist}')\n",
    "                resolve_collision(i, j, positions, velocities)\n",
    "    positions += velocities * 0.000001\n",
    "    \n",
    "    return positions\n",
    "# Function to resolve the collision (particles or walls)\n",
    "def resolve_collision(i, j, positions, velocities):\n",
    "    # Calculate the normal vector\n",
    "    delta_pos = positions[i] - positions[j]\n",
    "    dist = np.linalg.norm(delta_pos)\n",
    "    delta_v = velocities[i] - velocities[j]\n",
    "    # Normal vector\n",
    "    n_hat = delta_pos / (dist**2)\n",
    "    #print(f'dist is {dist}')\n",
    "    # Relative velocity\n",
    "    \n",
    "    \n",
    "    # Velocity component along the normal direction\n",
    "    v_rel = np.dot(delta_v, delta_pos)\n",
    "    \n",
    "    # Update velocities if particles are moving towards each other\n",
    "    if v_rel < 0:\n",
    "        velocities[i] -= v_rel * n_hat\n",
    "        velocities[j] += v_rel * n_hat\n",
    "    #print(f'({i},{j}) new i: p:{positions[i]}, v:{velocities[i]}\\n and j: p:{positions[j]},v:{velocities[j]}')\n",
    "    \n",
    "\n",
    "# t = 0\n",
    "# while t < t_max:\n",
    "#     delta_t, collision_pair = find_earliest_collision(positions, velocities)\n",
    "#     print(f'delta t is {delta_t} and pair:{collision_pair}')\n",
    "#     delta_t += 0.000001\n",
    "#     positions = update_positions(positions, velocities, delta_t, collision_pair)\n",
    "#     t += (delta_t + 0.000001)\n",
    "#     print(f'delta t is {delta_t}')\n",
    "    \n",
    "#Visualization setup\n",
    "fig, ax = plt.subplots()\n",
    "ax.set_xlim(0, box_size)\n",
    "ax.set_ylim(0, box_size)\n",
    "particles, = ax.plot([], [], 'bo', ms=10)\n",
    "\n",
    "def init():\n",
    "    particles.set_data([], [])\n",
    "    return particles,\n",
    "\n",
    "def animate(frame):\n",
    "    global positions, velocities, dt\n",
    "    \n",
    "    # Find the earliest collision\n",
    "    delta_t, collision_pair = find_earliest_collision(positions, velocities)\n",
    "    \n",
    "    # Update positions to the collision time\n",
    "    if delta_t < dt:\n",
    "        delta_t += 0.000001\n",
    "        positions = update_positions(positions, velocities, delta_t, collision_pair)\n",
    "        #positions = update_positions(positions, velocities, delta_t)\n",
    "        # positions += velocities * delta_t\n",
    "        #print(f'colision pair is {collision_pair}')\n",
    "        #print(delta_t)\n",
    "        # #print(f'delta t is {delta_t} and poistions {positions}')\n",
    "        # resolve_collision(collision_pair, positions, velocities)\n",
    "        # #positions += velocities * 0.001\n",
    "        # #t += (delta_t + 0.01)\n",
    "        # #print(f'delta t is {delta_t}')\n",
    "        dt -= (delta_t + 0.000001)\n",
    "    else:\n",
    "        positions = update_positions(positions, velocities, dt, collision_pair)\n",
    "        dt = 0.1  # Reset time step after each update\n",
    "    \n",
    "    particles.set_data(positions[:, 0], positions[:, 1])\n",
    "    return particles,\n",
    "\n",
    "# Animation\n",
    "ani = animation.FuncAnimation(fig, animate, frames=int(t_max/dt), init_func=init,\n",
    "                              interval=20, blit=True, repeat=False)\n",
    "\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "signal",
   "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.4"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "e380abb910e00fe6da634510ec9345db91bedb5da9fdd3318ebcbe12a8309139"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
