{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 127,
   "id": "ea76f771",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import re\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from matplotlib.colors import to_rgba\n",
    "plt.rcParams.update({'font.size': 14})\n",
    "\n",
    "# Tune down the saturation of the last four colors\n",
    "colors = ['dodgerblue', '#F2C14E', '#90BE6D', '#F28482'] + [\n",
    "    to_rgba(color, alpha=0.6) for color in ['#FF7F50', '#6495ED', '#3CB371', '#9370DB']\n",
    "]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "id": "8377a655",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Log cleaned and saved to 'cleaned_log.txt'.\n"
     ]
    }
   ],
   "source": [
    "# Read the log file and clean it\n",
    "\n",
    "log = \"../log_stragglar_3B_8_b8_padding_reorder.txt\"\n",
    "log = \"../log_ring_1B_8_b4.txt\"\n",
    "log = '../log_ring_3B_8_b4.txt'\n",
    "with open(log, 'r') as file:\n",
    "    lines = file.readlines()\n",
    "\n",
    "# Inject a new line signal for lines with two \"Rank\" occurrences\n",
    "cleaned_lines = []\n",
    "for line in lines:\n",
    "    if line.count(\"Rank\") > 1:\n",
    "        parts = line.split(\"Rank\")\n",
    "        for part in parts[1:]:\n",
    "            cleaned_lines.append(\"Rank \" + part.strip() + \"\\n\")\n",
    "    else:\n",
    "        cleaned_lines.append(line)\n",
    "\n",
    "# Write the cleaned log to a new file\n",
    "with open(log, 'w') as file:\n",
    "    file.writelines(cleaned_lines)\n",
    "\n",
    "print(\"Log cleaned and saved to 'cleaned_log.txt'.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "id": "3a5c830b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "     Rank 0   Rank 1   Rank 2   Rank 3   Rank 4   Rank 5   Rank 6   Rank 7\n",
      "0   1383.27  2481.87  2477.26  1715.05  2660.41  2010.19  2453.96  3443.65\n",
      "1    581.51   587.55   572.42   585.29   593.81   593.36   592.05   581.51\n",
      "2    568.81   565.07   560.05   572.74   572.95   568.22   568.02   564.64\n",
      "3    565.20   561.96   554.02   566.81   571.29   566.17   565.04   563.70\n",
      "4    563.49   554.88   552.65   559.70   566.03   561.40   562.30   556.82\n",
      "5    562.64   556.39   553.47   561.68   567.06   562.52   561.70   557.90\n",
      "6    563.67   557.06   553.26   560.31   565.44   561.08   563.30   560.01\n",
      "7    563.44   557.88   552.45   562.94   564.99   563.18   563.41   558.00\n",
      "8    562.05   554.51   553.36   561.43   562.80   560.18   560.38   556.35\n",
      "9    561.67   556.45   553.07   562.31   564.47   562.73   563.33   556.55\n",
      "10   563.34   557.51   553.35   562.56   565.25   561.61   564.21   556.50\n",
      "11   564.79   557.85   553.80   563.49   564.64   563.81   563.11   557.58\n",
      "12   564.54   558.96   553.70   565.42   564.03   563.48   560.66   556.20\n",
      "13   562.59   559.07   553.53   564.07   562.94   564.31   560.12   555.73\n",
      "14   562.57   561.95   553.39   564.22   562.41   563.92   560.81   554.61\n",
      "15   564.26   562.25   555.23   565.89   563.42   564.59   562.46   555.54\n",
      "16   563.93   561.08   554.91   565.12   563.33   563.48   561.73   554.21\n",
      "17   560.54   556.50   552.30   561.93   558.84   561.26   555.96   552.22\n",
      "18   564.46   557.58   555.31   564.08   562.86   563.57   558.65   554.26\n",
      "19   566.99   561.24   555.47   567.03   560.61   565.58   561.81   555.83\n",
      "20   562.93   559.29   553.79   564.58   559.13   563.55   560.01   553.35\n",
      "21   567.45   564.04   557.95   567.84   559.91   568.10   562.93   553.80\n",
      "22   567.89   565.15   560.51   568.54   564.38   568.89   564.86   553.99\n",
      "23   570.48   565.32   561.53   570.17   565.89   569.49   564.81   555.17\n",
      "24   564.58   561.98   556.93   568.07   563.20   565.48   562.41   553.51\n",
      "25   564.62   560.69   557.21   566.45   561.19   565.37   562.74   552.86\n",
      "26   569.39   564.41   561.24   569.22   566.03   569.12   565.98   554.72\n",
      "27   572.84   568.31   563.06   573.24   570.88   571.46   569.95   563.30\n",
      "28   569.02   563.17   560.21   569.43   564.90   568.26   564.42   558.66\n",
      "29   564.01   559.13   555.85   564.25   562.77   563.70   559.81   552.62\n",
      "30   566.52   560.84   557.11   566.88   564.23   566.23   563.74   553.73\n",
      "31   564.84   560.41   556.58   564.99   560.87   564.72   559.07   553.64\n",
      "32   564.22   559.19   555.19   564.59   558.56   563.43   557.54   552.30\n",
      "33   565.22   559.76   556.51   566.24   563.23   564.30   559.02   553.02\n",
      "34   565.42   560.57   556.98   566.72   562.88   564.31   560.07   552.77\n",
      "35   564.90   560.36   554.89   566.03   563.99   565.47   560.31   553.55\n",
      "36   564.32   559.22   554.27   565.23   563.19   564.51   562.10   553.77\n",
      "37   563.40   560.55   555.10   564.42   561.57   562.99   560.10   552.31\n",
      "38   564.94   559.79   554.29   563.46   559.64   563.04   561.12   552.54\n",
      "39   561.89   558.54   552.98   562.39   559.39   561.66   557.35   553.35\n",
      "40   565.59   560.84   556.43   566.24   564.04   565.55   560.60   553.82\n",
      "41   564.13   559.87   555.42   564.29   560.83   561.44   558.99   552.85\n",
      "42   564.27   559.14   556.21   566.96   563.14   566.34   561.17   555.14\n",
      "43   562.76   560.23   554.85   565.24   561.14   563.22   560.93   552.48\n",
      "44   563.43   561.08   556.48   566.22   558.34   562.81   560.47   553.33\n",
      "45   565.50   562.71   555.87   566.64   560.04   563.00   561.59   553.26\n",
      "46   564.36   563.74   555.72   565.91   559.25   562.19   561.11   553.87\n",
      "47   561.68   560.02   554.93   563.58   558.71   561.89   558.79   552.75\n",
      "48   560.98   557.28   552.31   562.48   559.30   559.00   558.27   552.05\n",
      "49   566.82   562.58   557.69   566.09   563.02   565.47   560.81   552.82\n"
     ]
    }
   ],
   "source": [
    "# Initialize a dictionary to store AR times for each rank\n",
    "ar_times = {rank: {} for rank in range(8)}\n",
    "\n",
    "# Read the log file\n",
    "with open(log, 'r') as file:\n",
    "    for line in file:\n",
    "        # Match the log line pattern\n",
    "        match = re.search(r'Rank (\\d+) \\| Step (\\d+) .*? AR Time: ([\\d.]+) ms', line)\n",
    "        if match:\n",
    "            rank = int(match.group(1))\n",
    "            step = int(match.group(2))\n",
    "            ar_time = float(match.group(3))\n",
    "            ar_times[rank][step] = ar_time\n",
    "\n",
    "# Create a DataFrame from the extracted data\n",
    "df = pd.DataFrame(ar_times).sort_index()\n",
    "\n",
    "# Rename columns to indicate ranks\n",
    "df.columns = [f'Rank {col}' for col in df.columns]\n",
    "\n",
    "# Display the table\n",
    "print(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "a94ee3d1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "      Rank 0    Rank 1   Rank 2    Rank 3   Rank 4   Rank 5    Rank 6  \\\n",
      "0   10195.72  10286.36  9915.92  10363.34  9689.45  9913.26  10046.59   \n",
      "1    1244.82   1247.34  1247.80   1058.81  1247.25  1247.75   1058.33   \n",
      "2    1037.59   1037.82  1037.30   1037.91  1036.77  1037.25   1036.65   \n",
      "3    1036.72   1036.65  1036.92   1037.11  1036.37  1036.59   1037.37   \n",
      "4    1037.22   1036.40  1036.71   1036.22  1036.69  1036.61   1036.20   \n",
      "5    1040.79   1040.01  1039.44   1040.07  1040.28  1039.53   1040.17   \n",
      "6    1036.44   1036.97  1036.83   1037.04  1036.91  1036.60   1037.01   \n",
      "7    1038.67   1038.61  1038.59   1038.69  1038.97  1038.87   1038.74   \n",
      "8    1038.17   1037.61  1037.56   1038.05  1037.55  1037.40   1038.12   \n",
      "9    1038.31   1038.25  1037.73   1036.97  1038.88  1038.03   1038.50   \n",
      "10   1038.65   1038.24  1037.92   1038.42  1037.16  1037.90   1037.93   \n",
      "11   1037.16   1037.49  1037.29   1037.09  1037.47  1037.60   1037.70   \n",
      "12   1037.39   1037.56  1037.49   1037.15  1037.72  1037.56   1037.41   \n",
      "13   1043.86   1043.02  1043.42   1044.01  1043.72  1043.55   1043.90   \n",
      "14   1038.50   1037.79  1037.64   1037.45  1037.65  1037.08   1037.40   \n",
      "15   1036.12   1037.03  1037.28   1036.83  1036.70  1037.05   1036.76   \n",
      "16   1037.89   1037.80  1036.79   1037.50  1038.11  1037.68   1038.30   \n",
      "17   1037.09   1036.93  1037.19   1036.71  1037.24  1037.24   1036.85   \n",
      "18   1037.45   1037.35  1036.95   1037.19  1037.12  1037.11   1036.99   \n",
      "19   1036.52   1037.49  1036.84   1037.16  1037.28  1037.19   1037.63   \n",
      "20   1037.57   1036.97  1037.52   1037.23  1037.33  1037.64   1037.54   \n",
      "21   1035.65   1035.82  1035.66   1035.68  1035.44  1035.43   1035.31   \n",
      "22   1037.08   1036.96  1036.49   1036.54  1037.38  1037.04   1037.39   \n",
      "23   1037.28   1037.05  1036.96   1036.52  1036.86  1036.62   1036.71   \n",
      "24   1036.59   1037.56  1036.89   1036.95  1036.87  1037.80   1037.06   \n",
      "25   1036.36   1035.79  1036.18   1036.48  1036.31  1035.75   1036.68   \n",
      "26   1037.35   1036.92  1036.73   1035.95  1036.70  1037.11   1036.49   \n",
      "27   1036.43   1036.39  1036.86   1036.62  1036.66  1036.54   1037.19   \n",
      "28   1034.63   1034.57  1034.49   1034.46  1033.94  1035.22   1034.32   \n",
      "29   1036.22   1036.33  1036.81   1036.67  1036.62  1035.85   1036.81   \n",
      "30   1035.87   1036.14  1035.74   1035.14  1035.58  1035.93   1036.06   \n",
      "31   1036.49   1035.54  1036.28   1036.52  1036.69  1036.69   1035.40   \n",
      "32   1036.55   1036.76  1036.50   1036.01  1036.28  1036.50   1036.36   \n",
      "33   1036.49   1036.89  1036.65   1036.87  1037.19  1036.88   1037.17   \n",
      "34   1036.57   1036.00  1036.72   1036.49  1036.80  1036.52   1036.39   \n",
      "35   1037.26   1036.72  1037.01   1036.54  1035.87  1036.82   1037.00   \n",
      "36   1037.97   1037.54  1037.06   1037.82  1037.70  1037.73   1037.70   \n",
      "37   1035.62   1036.24  1036.77   1035.87  1036.42  1036.51   1036.74   \n",
      "38   1037.36   1037.19  1037.13   1037.62  1037.23  1037.51   1037.55   \n",
      "39   1037.22   1037.17  1037.17   1036.58  1037.11  1037.40   1036.83   \n",
      "40   1037.34   1036.89  1036.58   1037.09  1037.14  1037.06   1037.15   \n",
      "41   1037.19   1036.99  1037.77   1037.12  1037.63  1037.53   1037.76   \n",
      "42   1037.77   1037.90  1037.18   1037.65  1037.82  1038.03   1037.67   \n",
      "43   1036.73   1036.07  1036.75   1036.49  1036.55  1036.67   1036.67   \n",
      "44   1037.71   1037.88  1037.69   1037.49  1037.94  1037.91   1038.04   \n",
      "45   1036.39   1036.12  1036.15   1036.02  1037.02  1036.62   1036.47   \n",
      "46   1036.68   1037.10  1036.85   1036.82  1035.72  1037.20   1036.87   \n",
      "47   1037.49   1036.95  1037.31   1037.22  1037.73  1036.83   1037.03   \n",
      "48   1037.62   1037.64  1037.91   1038.32  1038.38  1037.53   1038.00   \n",
      "49   1037.09   1036.83  1036.36   1035.34  1036.21  1036.77   1036.76   \n",
      "\n",
      "      Rank 7  \n",
      "0   10457.74  \n",
      "1    1232.72  \n",
      "2    1037.54  \n",
      "3    1036.32  \n",
      "4    1036.78  \n",
      "5    1040.54  \n",
      "6    1036.09  \n",
      "7    1038.79  \n",
      "8    1038.01  \n",
      "9    1038.54  \n",
      "10   1037.00  \n",
      "11   1037.48  \n",
      "12   1037.43  \n",
      "13   1044.95  \n",
      "14   1035.80  \n",
      "15   1037.00  \n",
      "16   1037.65  \n",
      "17   1036.96  \n",
      "18   1037.12  \n",
      "19   1036.90  \n",
      "20   1037.66  \n",
      "21   1035.31  \n",
      "22   1036.23  \n",
      "23   1036.94  \n",
      "24   1037.10  \n",
      "25   1035.98  \n",
      "26   1036.57  \n",
      "27   1036.63  \n",
      "28   1035.19  \n",
      "29   1035.58  \n",
      "30   1036.00  \n",
      "31   1036.28  \n",
      "32   1035.91  \n",
      "33   1036.70  \n",
      "34   1036.49  \n",
      "35   1036.73  \n",
      "36   1037.56  \n",
      "37   1036.28  \n",
      "38   1037.34  \n",
      "39   1037.23  \n",
      "40   1035.88  \n",
      "41   1037.20  \n",
      "42   1037.64  \n",
      "43   1036.09  \n",
      "44   1037.59  \n",
      "45   1036.53  \n",
      "46   1035.99  \n",
      "47   1037.51  \n",
      "48   1037.23  \n",
      "49   1036.24  \n",
      "\n",
      "Average of each column (excluding the first row):\n",
      "Rank 0    1041.508776\n",
      "Rank 1    1041.454694\n",
      "Rank 2    1041.425714\n",
      "Rank 3    1037.520408\n",
      "Rank 4    1041.488980\n",
      "Rank 5    1041.514898\n",
      "Rank 6    1037.695510\n",
      "Rank 7    1041.045510\n",
      "dtype: float64\n"
     ]
    }
   ],
   "source": [
    "# Initialize a dictionary to store AR times for each rank\n",
    "itr_times = {rank: {} for rank in range(8)}\n",
    "\n",
    "# Read the log file\n",
    "with open(log, 'r') as file:\n",
    "    for line in file:\n",
    "        # Match the log line pattern\n",
    "        match = re.search(r'Rank (\\d+) \\| Step (\\d+) .*? Iteration Time: ([\\d.]+) ms', line)\n",
    "        if match:\n",
    "            rank = int(match.group(1))\n",
    "            step = int(match.group(2))\n",
    "            itr_time = float(match.group(3))\n",
    "            itr_times[rank][step] = itr_time\n",
    "\n",
    "# Create a DataFrame from the extracted data\n",
    "df = pd.DataFrame(itr_times).sort_index()\n",
    "\n",
    "# Rename columns to indicate ranks\n",
    "df.columns = [f'Rank {col}' for col in df.columns]\n",
    "\n",
    "# Display the table\n",
    "print(df)\n",
    "\n",
    "# Sum the values in each column, neglecting the first row\n",
    "column_sums = df.iloc[1:].sum()\n",
    "# print(\"\\nSum of each column (excluding the first row):\")\n",
    "# print(column_sums)\n",
    "\n",
    "# Calculate the average for each column, neglecting the first row\n",
    "column_averages = df.iloc[1:].mean()\n",
    "print(\"\\nAverage of each column (excluding the first row):\")\n",
    "print(column_averages)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "9d41ef64",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    Step  AR Kernel Time\n",
      "0      0          276.06\n",
      "1      1           88.72\n",
      "2      2           94.53\n",
      "3      3          101.99\n",
      "4      4           94.37\n",
      "5      5           94.94\n",
      "6      6           93.67\n",
      "7      7           91.33\n",
      "8      8           94.04\n",
      "9      9           92.60\n",
      "10    11           92.06\n",
      "11    12           94.67\n",
      "12    14           94.93\n",
      "13    16           90.42\n",
      "14    17           95.11\n",
      "15    18           92.41\n",
      "16    19           92.75\n",
      "17    20           93.70\n",
      "18    22           92.28\n",
      "19    23           97.25\n",
      "20    24           97.40\n",
      "21    25           95.32\n",
      "22    26           93.21\n",
      "23    27           94.51\n",
      "24    28           94.35\n",
      "25    29           95.14\n",
      "26    30           96.32\n",
      "27    31           96.02\n",
      "28    32           94.68\n",
      "29    34           98.12\n",
      "30    35           96.73\n",
      "31    36           95.55\n",
      "32    37           96.12\n",
      "33    38           95.33\n",
      "34    39           97.95\n",
      "35    40           98.51\n",
      "36    41           93.67\n",
      "37    42           94.81\n",
      "38    43           94.67\n",
      "39    44           99.13\n",
      "40    45           97.40\n",
      "41    46           97.09\n",
      "42    47           99.83\n",
      "43    48           97.85\n",
      "\n",
      "Average AR Kernel Time:\n",
      "99.26227272727273\n"
     ]
    }
   ],
   "source": [
    "# Get the first allreduce kernel time\n",
    "first_ar_kernel_time = {}\n",
    "with open(log, 'r') as file:\n",
    "    lines = file.readlines()\n",
    "    for i, line in enumerate(lines):\n",
    "        if \"| Step \" in line:\n",
    "            # Read the AR Kernel Time from the first line after the matched line\n",
    "            nline = lines[i + 1] if i + 1 < len(lines) else \"\"\n",
    "            nnline = lines[i + 2] if i + 2 < len(lines) else \"\"\n",
    "            match1 = re.search(r'Rank (\\d+) \\| Step (\\d+) .*? Iteration Time: ([\\d.]+) ms', line)\n",
    "            if match1:\n",
    "                step = int(match1.group(2))\n",
    "                match2 = re.search(r'AR Kernel Time: ([\\d.]+) ms', nline)\n",
    "                if match2:\n",
    "                    ar_kernel_time = float(match2.group(1))\n",
    "                    first_ar_kernel_time[step] = ar_kernel_time\n",
    "                else:\n",
    "                    match3 = re.search(r'AR Kernel Time: ([\\d.]+) ms', nnline)\n",
    "                    if match3:\n",
    "                        ar_kernel_time = float(match3.group(1))\n",
    "                        first_ar_kernel_time[step] = ar_kernel_time\n",
    "\n",
    "# Create a DataFrame from the extracted data\n",
    "df_kernel = pd.DataFrame(first_ar_kernel_time.items(), columns=['Step', 'AR Kernel Time']).sort_index()\n",
    "\n",
    "# Display the table\n",
    "print(df_kernel)\n",
    "\n",
    "# Calculate the average AR Kernel Time\n",
    "average_ar_kernel_time = df_kernel['AR Kernel Time'].mean()\n",
    "print(\"\\nAverage AR Kernel Time:\")\n",
    "print(average_ar_kernel_time)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "669612d8",
   "metadata": {},
   "source": [
    "# iteration time\n",
    "Llama 3B batch size 4\n",
    "# Ring\n",
    "\n",
    "Rank 0    3042.321224\n",
    "Rank 1    3042.427959\n",
    "Rank 2    3042.253469\n",
    "Rank 3    3042.168571\n",
    "Rank 4    3042.298980\n",
    "Rank 5    3042.428367\n",
    "Rank 6    3042.373878\n",
    "Rank 7    3042.243673\n",
    "\n",
    "# Stragglar\n",
    "\n",
    "Rank 0    2897.885102\n",
    "Rank 1    2897.502041\n",
    "Rank 2    2901.894694\n",
    "Rank 3    2894.479184\n",
    "Rank 4    2897.559388\n",
    "Rank 5    2901.190612\n",
    "Rank 6    2890.842857\n",
    "Rank 7    2893.498776\n",
    "\n",
    "3B batch size 8\n",
    "# ring\n",
    "Rank 0    5271.343061\n",
    "Rank 1    5271.478571\n",
    "Rank 2    5271.094694\n",
    "Rank 3    5271.270816\n",
    "Rank 4    5271.034490\n",
    "Rank 5    5271.535510\n",
    "Rank 6    5271.209796\n",
    "Rank 7    5270.866122\n",
    "\n",
    "# Stragglar\n",
    "Rank 0    5117.651429\n",
    "Rank 1    5117.184694\n",
    "Rank 2    5118.521020\n",
    "Rank 3    5118.439388\n",
    "Rank 4    5118.095714\n",
    "Rank 5    5118.034082\n",
    "Rank 6    5117.943673\n",
    "Rank 7    5117.482041\n",
    "\n",
    "1B batch size 4\n",
    "# Ring\n",
    "Rank 0    1030.732449\n",
    "Rank 1    1030.310408\n",
    "Rank 2    1030.715306\n",
    "Rank 3    1030.907347\n",
    "Rank 4    1030.899184\n",
    "Rank 5    1030.804898\n",
    "Rank 6    1030.300612\n",
    "Rank 7    1030.548571\n",
    "\n",
    "# Stragglar\n",
    "Rank 0    1041.508776\n",
    "Rank 1    1041.454694\n",
    "Rank 2    1041.425714\n",
    "Rank 3    1037.520408\n",
    "Rank 4    1041.488980\n",
    "Rank 5    1041.514898\n",
    "Rank 6    1037.695510\n",
    "Rank 7    1041.045510\n",
    "\n",
    "batch size 8\n",
    "# Ring\n",
    "Rank 0    1896.301633\n",
    "Rank 1    1896.217347\n",
    "Rank 2    1896.312041\n",
    "Rank 3    1896.314490\n",
    "Rank 4    1896.365714\n",
    "Rank 5    1896.540408\n",
    "Rank 6    1896.422245\n",
    "Rank 7    1896.351020\n",
    "\n",
    "# Stragglar\n",
    "Rank 0    1906.067347\n",
    "Rank 1    1906.326939\n",
    "Rank 2    1906.047755\n",
    "Rank 3    1902.438163\n",
    "Rank 4    1906.311429\n",
    "Rank 5    1906.345510\n",
    "Rank 6    1902.192041\n",
    "Rank 7    1905.962245\n",
    "\n",
    "\n",
    "batch size 16\n",
    "# Ring\n",
    "Rank 0    3580.526735\n",
    "Rank 1    3580.159184\n",
    "Rank 2    3580.726735\n",
    "Rank 3    3580.505918\n",
    "Rank 4    3580.198776\n",
    "Rank 5    3580.191633\n",
    "Rank 6    3580.355510\n",
    "Rank 7    3580.371633\n",
    "\n",
    "# Stragglar\n",
    "Rank 0    3588.713878\n",
    "Rank 1    3588.746939\n",
    "Rank 2    3589.044694\n",
    "Rank 3    3585.308571\n",
    "Rank 4    3589.248980\n",
    "Rank 5    3589.189184\n",
    "Rank 6    3585.528776\n",
    "Rank 7    3589.019592\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "id": "944dd85b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Percentage of time each rank has the smallest number:\n",
      "Rank 7    62.0\n",
      "Rank 2    36.0\n",
      "Rank 0     2.0\n",
      "Name: count, dtype: float64\n"
     ]
    },
    {
     "data": {
      "image/png": "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/dEE99EqueXLl5eKFSuawNe3FLCueNW/f3+555575PXXX7e1namMdIggli5dKlu3bpWuXbt6A2ClnXDw4MFy+vRpsz4x3Ktjx44Bqxdec8015tTV77//Lps2bbKlbXCeZ599Vv7zn/+YLyz/QAfu9Mcff8iIESNMgSgNhgP1CwJg99LBNq15oMvF+gbA6sYbbzTXugQsYse7K4jly5eba8339Kenq5SeqgIC0dE+xRcY1DfffGOC4JEjR0rt2rXtbg4cQk9p649lHc07d+6cfPzxx+YMo85BadWqlVx88cV2NxE20jNGOtdEaxwcOXLEpEJY/vGPf5hrPeuI2PENHYTmdlqd0J9OftJT3dY+gK+dO3fKJ598YnK46tata3dzYLNTp06ZUu96RumJJ56wuzlwkHXr1plrHQGuV6+eCYB9Cz499thjZv4J3EnT7caMGWPygjU90zcnWM9WawpNv3797G5mSiMIDkJzf5X/KQiLdkRrH8A377N79+4m8NFJc5z2xtChQ80PZg146A/wtW/fPnOtE58aNGggX3/9tVx66aWyfv166d27t4wfP95Mluvbt6/dTYVN9IeQ5gXff//98sorr3i362RJTdfkbGPOkBMMxInmbvXs2VNWrlwpvXr1MsEw3E0nvulI3pAhQ5jBjYCfGUpPeeuqMg0bNjRnGXVewfvvv29GgzUQhntpClW3bt3MXCRdLu/o0aNm8vXJkyfNqkSaQoPYEQQHYY0ABxvt1fycYKPEcOeX2b333muWRdMPLN9f7HAnndV/9913m9Pcupwe4M/6DtFl88qVK5flNv3RpBPmdIL2oUOHbGoh7KRpdcOGDTMpD/oZUqFCBfMjSUeB58+fb+aesFRrzhAEB2HlAgfK+9VlS44dOxYwXxjuDIB1YouuFqKL28+YMcOM4MDd9DNCPz82bNhgRvqsAhl6sVaWadKkifm3jgLCfbTogdKJcIFY23UVCbjPggULzLWuNhRobpLmCf/444/mswaxIZkkCF36avTo0Wb2rhbK8LVo0SLvPnA3KwB+4403TGGMN998k7xPGLo+9H333RfwNk2Z0QD55ptvNkVWqlSpkvT2wX5WcPPdd98FnF+gAY5WKtU+AvfRpVhDLYOm23XAxVqNCDHQYhnI7syZM55q1ap58ufP71m/fr13+6FDhzw1a9b05MuXz/PTTz/Z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/fXXs4w263HQH9P6A1l/KO3du1e+/vpr87mmr4+vJk2amOtPP/3UHCOkEQ+QRn766SeNwjxt27YNud9rr71m9uvevbt32+LFi71/e+zYMe/28+fPe/r06WNu++CDD7zbly1bZrYNGzYsy31XrlzZXAI5efKk5+eff862/dtvv/UUKVLE06pVq6iep14GDhyY5baFCxea7XXr1s2yvWvXrmb71KlTs2z/9ddfPRUrVvSULl3a88cff3i3N2/e3OwfyIsvvmhumzVrlnfbX/7yF0/hwoU9jRs39jRp0sS7fevWrWbfe++917vtwIEDnmLFinnKly/v2b59e5b7fvfdd83+/fr1i3l/3+MzZsyYLPsPGTLEbB89erQnnH//+99m31tuuSXga3n06FHvv7Uf6L7aLwLRPmH1rxMnTmS7fceOHZ6zZ89m2aZ9T4+b/t2qVau823U/vb+MjAzPZ599luVvevTo4X3ugZ537969s2z/5JNPvPtPnz49y226TfuBr8GDB5vtTz31lGmf5ciRI54rr7zSky9fPs8vv/zi3X733Xeb/StUqGCeY6Sifa9o2/Vx8uTJk+1YXXvttea2L774wrt9y5YtZl/tU/oesBw+fNhTq1atgM89mEhf+w4dOnhOnTqV7dj7f15Fe4yDsY5Jrly5PEuWLMl2ezSPE8/3QjCPP/64+btAbfV9T0+YMMG7Xdvdvn17s71EiRKeefPmeW87ffq0p169euZ13rt3r3d7gwYNzHPzfd19P2sCKVmypKdSpUpRPR84H0EwXBkEL1iwwOx3/fXXe7fdfPPNZlugL+pDhw6ZgKNTp045CoJDuemmm8wHs35wR/o89UPf98vH0rJlS3P72rVrzb/379/vyZ07t+e6664LGdTOnz8/oiB406ZN5rYHHnjAu61OnTrmuA8dOtR86VjtmjZtmtn3jTfe8O77/PPPZ9vmS7+kSpUqFfP+1vGpWrWq59y5c1n2tW7r2LGjJxzri79Lly5xC4Q2btzoica6devM3w0fPty7bfny5Wab9ll/O3fuNK+1/2tXpUoV0798gwFLmzZtIgqC9VhqMFC9evUsQZPl448/Nn8zadKkbEHwxIkTPfES6L1iBXz6I8CfdZv2c8uIESPMtvHjx2fb/80330xIELxt27aAt11wwQU5OsbBWM/71ltvzXZbtI8Tz/dCMHrf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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Compute the difference between the smallest and second smallest values in each row\n",
    "differences = df.apply(lambda row: np.partition(row, 1)[1] - row.min(), axis=1)\n",
    "\n",
    "differences = differences[1:]\n",
    "# Sort the differences to compute the CDF\n",
    "sorted_differences = np.sort(differences)\n",
    "cdf = np.arange(1, len(sorted_differences) + 1) / len(sorted_differences)\n",
    "\n",
    "# Calculate the percentage of time each rank has the smallest number in the row\n",
    "smallest_counts = (df.idxmin(axis=1).value_counts() / len(df)) * 100\n",
    "print(\"Percentage of time each rank has the smallest number:\")\n",
    "print(smallest_counts)\n",
    "\n",
    "# Plot the CDF\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.plot(sorted_differences, cdf, marker='.', linestyle='none')\n",
    "plt.xlabel('Delta between straggler and the rest (ms)')\n",
    "plt.ylabel('CDF')\n",
    "plt.ylim(0, 1)\n",
    "plt.xlim(0, sorted_differences.max())\n",
    "plt.grid()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "170b893a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "     Rank 0   Rank 1   Rank 2   Rank 3   Rank 4   Rank 5   Rank 6   Rank 7\n",
      "0   1890.36  1778.76  1460.94  2380.22  1690.04  2045.43  1443.42  1583.93\n",
      "1    153.73   188.96   151.47   146.15   168.85   155.61   131.91   140.81\n",
      "2    156.70   165.45   146.84   158.28   172.24   154.93   132.37   153.54\n",
      "3    160.00   163.62   146.65   151.51   171.60   155.83   132.20   150.94\n",
      "4    155.73   160.06   142.55   150.59   166.25   150.22   132.89   147.21\n",
      "5    170.58   177.84   163.20   170.28   185.51   168.15   132.68   167.60\n",
      "6    156.47   160.95   146.51   156.62   167.31   153.81   132.73   150.12\n",
      "7    153.70   159.59   140.99   153.16   167.26   153.36   132.39   147.21\n",
      "8    156.67   163.08   137.25   159.29   171.75   155.39   132.01   152.62\n",
      "9    156.64   158.89   142.36   159.87   165.97   155.66   131.91   147.98\n",
      "10   155.65   158.23   139.73   156.92   163.86   150.15   132.24   147.37\n",
      "11   153.35   158.44   140.01   158.67   165.87   152.01   132.21   146.58\n",
      "12   158.56   162.33   145.23   160.28   168.79   155.95   131.99   154.16\n",
      "13   161.63   165.30   147.49   158.89   171.85   161.30   132.45   155.15\n",
      "14   160.81   164.88   146.74   154.73   168.91   159.09   131.86   154.62\n",
      "15   158.67   161.74   145.11   151.70   164.93   153.99   132.06   144.22\n",
      "16   157.98   160.30   144.86   152.12   165.28   155.88   132.03   146.28\n",
      "17   156.40   161.09   146.28   151.26   165.81   155.11   132.07   143.54\n",
      "18   156.16   160.22   145.21   150.11   168.02   152.75   132.23   144.78\n",
      "19   154.72   161.28   144.63   148.96   166.58   155.77   132.49   140.81\n",
      "20   153.36   162.62   145.10   150.26   167.31   155.65   131.98   141.76\n",
      "21   155.78   160.23   143.31   150.34   165.89   157.12   131.88   140.87\n",
      "22   153.18   157.61   140.47   145.72   163.88   153.14   131.94   140.33\n",
      "23   152.82   159.16   141.62   148.83   164.90   154.78   131.95   136.30\n",
      "24   154.30   161.35   142.00   138.22   162.97   155.12   131.90   139.50\n",
      "25   156.43   160.62   140.67   146.56   164.72   155.64   132.08   138.80\n",
      "26   151.34   159.11   142.02   146.72   161.97   152.97   132.14   141.24\n",
      "27   152.60   157.79   138.78   144.08   161.80   152.66   131.90   138.10\n",
      "28   155.98   160.43   142.39   145.41   163.49   153.02   132.06   138.36\n",
      "29   150.82   156.42   141.32   143.54   162.67   153.57   131.72   136.19\n",
      "30   154.91   160.28   141.54   145.04   165.60   155.29   132.17   137.69\n",
      "31   156.92   160.78   143.54   144.49   164.42   155.63   132.29   137.11\n",
      "32   151.95   159.50   139.88   144.11   162.66   153.55   131.91   134.25\n",
      "33   153.09   158.90   138.56   143.97   162.56   152.86   131.78   136.29\n",
      "34   155.45   159.35   142.24   144.92   161.62   152.89   131.94   133.10\n",
      "35   156.41   162.63   142.59   147.87   164.20   155.90   132.23   140.91\n",
      "36   156.48   161.24   144.40   148.00   164.39   154.24   131.90   136.20\n",
      "37   156.37   158.41   142.58   146.20   162.40   152.50   132.15   136.12\n",
      "38   153.51   157.60   142.81   143.72   161.03   152.60   131.86   134.67\n",
      "39   153.53   154.91   141.38   145.31   162.05   152.17   131.92   135.46\n",
      "40   155.98   155.78   143.09   144.56   162.06   153.02   132.30   136.60\n",
      "41   161.41   162.54   148.35   150.01   167.00   157.32   132.01   138.13\n",
      "42   156.04   159.35   142.85   148.33   162.22   155.40   132.04   137.46\n",
      "43   156.05   159.59   142.43   146.71   160.14   152.62   132.13   139.60\n",
      "44   157.02   158.47   142.08   144.05   161.42   152.39   131.91   136.60\n",
      "45   151.48   157.17   140.98   142.95   159.23   151.59   131.84   137.93\n",
      "46   154.71   157.08   141.18   141.86   161.63   153.06   131.84   133.64\n",
      "47   158.10   163.27   147.05   149.25   166.67   157.77   137.23   132.69\n",
      "48   160.25   162.85   147.15   151.99   167.13   157.83   136.95   132.50\n",
      "49   154.78   159.82   142.06   146.33   158.86   154.16   132.08   131.81\n",
      "     Rank 0   Rank 1   Rank 2   Rank 3   Rank 4   Rank 5   Rank 6   Rank 7\n",
      "0   3411.33  1526.74  4214.99  3932.67  2765.50  2989.39  3135.76  3210.82\n",
      "1    180.03   158.24   132.39   144.77   155.81   157.76   159.12   152.89\n",
      "2    159.94   161.19   143.50   149.74   165.98   154.98   132.39   155.18\n",
      "3    157.36   163.65   142.70   153.24   169.21   155.88   132.75   154.72\n",
      "4    152.43   161.39   144.80   148.93   167.15   155.25   132.37   152.49\n",
      "5    158.67   162.95   146.17   147.51   168.89   157.32   132.44   153.11\n",
      "6    156.83   161.08   146.50   148.81   166.46   157.28   132.40   152.38\n",
      "7    153.49   156.79   139.74   142.99   163.20   151.52   132.62   146.39\n",
      "8    157.83   160.10   144.89   148.00   166.30   154.89   132.26   151.35\n",
      "9    153.69   157.31   142.32   148.28   163.86   152.44   132.33   149.00\n",
      "10   152.55   155.64   139.28   142.25   161.36   152.43   132.38   146.75\n",
      "11   155.09   160.79   144.51   147.61   165.89   155.72   132.36   151.90\n",
      "12   154.12   160.01   142.29   146.22   161.72   153.37   132.47   149.98\n",
      "13   152.49   159.23   141.70   144.98   164.65   153.72   132.28   150.20\n",
      "14   153.74   158.62   142.59   141.69   164.18   152.86   132.42   150.87\n",
      "15   154.24   160.35   141.06   144.42   164.41   153.05   132.56   145.96\n",
      "16   155.81   159.75   142.41   145.74   163.01   153.76   132.11   138.39\n",
      "17   154.96   159.03   142.60   143.81   164.16   153.68   132.34   135.99\n",
      "18   152.40   156.15   140.48   143.14   162.40   153.21   132.22   134.09\n",
      "19   153.48   157.71   142.19   145.98   161.49   151.83   132.15   132.56\n",
      "20   154.89   157.39   142.11   143.10   161.95   152.51   132.21   136.91\n",
      "21   155.15   159.68   144.29   146.07   164.95   153.10   132.25   137.32\n",
      "22   153.69   156.82   142.53   143.33   161.74   152.31   132.40   134.18\n",
      "23   157.06   158.91   142.94   148.75   161.16   155.19   132.29   137.61\n",
      "24   154.43   157.36   141.20   143.23   161.23   153.27   132.30   135.83\n",
      "25   153.11   156.72   139.70   144.44   157.97   152.96   132.50   134.20\n",
      "26   153.67   156.43   140.74   145.28   158.43   152.59   132.29   133.59\n",
      "27   154.98   156.82   140.15   142.55   160.03   152.45   132.45   132.42\n",
      "28   153.53   157.23   140.48   142.14   157.14   151.88   132.40   134.91\n",
      "29   153.28   156.39   143.37   144.12   160.54   153.70   132.55   135.94\n",
      "30   151.94   154.72   140.33   139.40   157.64   149.99   132.43   132.71\n",
      "31   156.76   159.80   142.84   146.94   161.14   152.33   132.36   133.72\n",
      "32   154.69   158.59   144.25   146.63   163.81   153.72   135.38   132.37\n",
      "33   150.88   154.36   141.16   143.00   157.05   149.46   132.48   132.23\n",
      "34   157.10   160.60   143.06   147.13   164.69   155.84   135.24   132.40\n",
      "35   152.62   156.36   140.91   144.70   160.58   151.24   133.89   132.60\n",
      "36   151.12   157.49   140.47   144.05   160.66   152.43   132.20   133.11\n",
      "37   152.06   156.41   140.58   142.60   160.26   151.21   132.29   134.78\n",
      "38   151.51   157.33   140.72   145.77   158.85   152.85   132.49   134.87\n",
      "39   153.42   158.08   142.86   145.33   162.66   154.49   132.15   134.16\n",
      "40   153.71   158.38   144.26   146.44   159.53   154.78   135.49   132.34\n",
      "41   154.32   157.59   142.78   146.06   159.06   152.24   133.19   132.32\n",
      "42   154.00   157.95   141.84   145.25   155.89   150.95   132.15   134.68\n",
      "43   157.30   161.78   145.02   148.14   160.24   157.55   137.17   132.42\n",
      "44   154.09   156.21   142.71   143.22   151.41   151.93   132.26   132.63\n",
      "45   155.05   157.93   141.49   146.01   156.68   154.29   133.18   132.66\n",
      "46   153.00   156.50   141.95   147.57   154.35   151.60   132.34   135.71\n",
      "47   155.21   157.86   142.65   145.97   156.66   151.02   132.32   133.68\n",
      "48   155.78   157.08   143.65   137.61   154.68   153.71   132.39   135.70\n",
      "49   154.77   158.96   140.58   144.73   154.36   152.14   132.39   133.08\n",
      "     Rank 0   Rank 1   Rank 2   Rank 3   Rank 4   Rank 5   Rank 6   Rank 7\n",
      "0   2725.60  1895.55  2388.71  1939.91  2785.86  2865.43  1402.70  2226.87\n",
      "1    148.42   156.41   139.79   147.67   162.86   146.99   132.78   150.96\n",
      "2    156.64   161.65   145.65   153.52   170.26   156.01   133.24   153.70\n",
      "3    157.42   160.58   143.88   154.41   171.02   155.25   132.39   151.96\n",
      "4    158.94   164.56   144.29   154.79   171.00   157.09   132.69   152.54\n",
      "5    161.30   162.51   148.84   154.63   172.30   157.62   132.65   152.91\n",
      "6    157.50   162.47   147.07   147.17   170.31   157.63   132.48   151.09\n",
      "7    158.28   158.30   143.90   144.54   167.47   154.02   132.29   151.08\n",
      "8    156.86   159.70   143.36   146.81   165.21   151.08   132.34   149.36\n",
      "9    156.76   159.66   144.89   147.94   164.06   153.48   132.38   149.21\n",
      "10   157.58   160.65   143.17   152.01   164.16   152.86   132.22   149.94\n",
      "11   155.78   160.52   145.02   150.46   166.55   155.18   132.67   141.37\n",
      "12   156.77   159.75   142.87   148.71   165.72   155.73   132.54   145.98\n",
      "13   156.30   160.05   142.76   147.05   165.43   154.10   132.24   141.43\n",
      "14   156.11   157.16   142.62   144.32   164.05   153.45   132.26   139.52\n",
      "15   154.45   159.10   140.31   147.02   163.84   150.46   132.31   140.20\n",
      "16   153.33   157.89   141.99   143.66   161.75   151.59   132.66   137.04\n",
      "17   153.93   159.68   141.26   146.55   164.50   152.69   132.46   139.16\n",
      "18   152.97   157.56   142.22   143.39   163.57   152.93   132.29   137.57\n",
      "19   154.97   160.84   141.60   146.92   165.56   154.30   132.37   139.97\n",
      "20   152.46   157.18   138.56   144.59   160.73   150.58   132.14   135.17\n",
      "21   155.94   160.12   140.88   149.11   165.59   154.31   132.38   136.26\n",
      "22   153.49   157.99   140.69   146.20   163.01   152.64   132.19   135.44\n",
      "23   154.64   159.24   142.59   147.39   166.22   154.59   132.42   136.57\n",
      "24   153.20   157.82   139.29   146.55   163.51   153.67   132.39   134.16\n",
      "25   157.19   158.91   141.59   139.50   160.86   153.82   132.54   137.99\n",
      "26   154.76   157.93   142.93   143.90   159.21   152.91   132.31   136.03\n",
      "27   153.91   157.97   137.69   144.81   159.39   152.91   132.17   133.53\n",
      "28   154.08   157.99   142.24   144.74   160.71   153.47   132.34   133.68\n",
      "29   155.32   158.36   142.44   147.51   160.66   153.72   132.36   134.09\n",
      "30   153.89   155.96   137.41   145.84   158.17   151.39   132.41   132.95\n",
      "31   154.69   157.97   141.15   145.75   157.26   152.57   132.34   134.42\n",
      "32   156.79   159.54   143.59   146.14   157.17   153.66   133.77   132.70\n",
      "33   154.67   156.88   141.10   146.15   159.93   153.88   132.50   133.62\n",
      "34   156.17   159.59   142.26   145.39   161.74   154.98   132.28   135.36\n",
      "35   156.37   159.90   143.13   145.66   158.41   152.44   132.26   133.36\n",
      "36   152.86   156.41   139.94   142.79   156.70   150.21   132.12   133.06\n",
      "37   154.48   157.08   141.60   145.67   157.18   152.30   132.94   134.97\n",
      "38   154.99   158.79   141.91   146.67   161.03   154.15   132.38   135.88\n",
      "39   152.78   157.01   140.74   145.80   157.23   151.08   132.23   134.22\n",
      "40   153.23   156.44   141.16   146.61   154.31   152.00   132.28   132.63\n",
      "41   152.23   154.56   140.45   146.85   155.18   153.06   132.36   132.51\n",
      "42   153.03   156.58   139.36   147.61   155.39   151.61   132.10   134.17\n",
      "43   154.29   157.41   142.53   148.01   156.98   155.19   132.22   136.16\n",
      "44   153.13   154.76   140.12   145.90   158.36   153.60   132.30   133.81\n",
      "45   155.56   155.92   140.81   146.65   152.59   152.89   132.30   134.95\n",
      "46   154.83   158.44   141.27   146.72   154.18   153.99   132.43   134.88\n",
      "47   157.43   158.41   142.12   148.26   154.61   154.43   132.38   133.22\n",
      "48   157.08   159.20   142.79   146.73   155.10   153.06   132.32   134.52\n",
      "49   154.35   156.43   141.09   142.65   156.44   152.49   132.19   132.78\n"
     ]
    }
   ],
   "source": [
    "dir = \"log\"\n",
    "def get_df(filename):\n",
    "    # Initialize a dictionary to store AR times for each rank\n",
    "    ar_times = {rank: {} for rank in range(8)}\n",
    "\n",
    "    # Read the log file\n",
    "    with open(f\"{dir}/{filename}\", 'r') as file:\n",
    "        for line in file:\n",
    "            # Match the log line pattern\n",
    "            match = re.search(r'Rank (\\d+) \\| Step (\\d+) .*? AR Time: ([\\d.]+) ms', line)\n",
    "            if match:\n",
    "                rank = int(match.group(1))\n",
    "                step = int(match.group(2))\n",
    "                ar_time = float(match.group(3))\n",
    "                ar_times[rank][step] = ar_time\n",
    "\n",
    "    # Create a DataFrame from the extracted data\n",
    "    df = pd.DataFrame(ar_times).sort_index()\n",
    "\n",
    "    # Rename columns to indicate ranks\n",
    "    df.columns = [f'Rank {col}' for col in df.columns]\n",
    "\n",
    "    # Display the table\n",
    "    print(df)\n",
    "    return df\n",
    "\n",
    "# files = ['log_4_a100_perlmutter_n0_0.txt', 'log_4_a100_perlmutter_n0_1.txt', 'log_4_a100_perlmutter_n0_2.txt']\n",
    "# files = ['log_4_a100_runpod_n0_0_3B.txt', 'log_4_a100_runpod_n0_1_3B.txt', 'log_4_a100_runpod_n0_2_3B.txt']\n",
    "files = ['log_8_a100_runpod_n0_0_3B.txt', 'log_8_a100_runpod_n0_1_3B.txt', 'log_8_a100_runpod_n0_2_3B.txt']\n",
    "# files = ['log_8_h100_runpod_n0_0.txt', 'log_8_h100_runpod_n0_1.txt', 'log_8_h100_runpod_n0_2.txt']\n",
    "\n",
    "dfs = []\n",
    "for file in files:\n",
    "    df = get_df(file)\n",
    "    dfs.append(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "805b0885",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Percentage of time each rank has the smallest number for Run 1:\n",
      "Rank 6    94.0\n",
      "Rank 7     6.0\n",
      "Name: count, dtype: float64\n",
      "Medium difference for Run 1: 6.72\n",
      "Average difference for Run 1: 7.94\n",
      "Percentage of time each rank has the smallest number for Run 2:\n",
      "Rank 6    78.0\n",
      "Rank 7    18.0\n",
      "Rank 1     2.0\n",
      "Rank 2     2.0\n",
      "Name: count, dtype: float64\n",
      "Medium difference for Run 2: 3.31\n",
      "Average difference for Run 2: 4.87\n",
      "Percentage of time each rank has the smallest number for Run 3:\n",
      "Rank 6    98.0\n",
      "Rank 7     2.0\n",
      "Name: count, dtype: float64\n",
      "Medium difference for Run 3: 3.50\n",
      "Average difference for Run 3: 5.11\n"
     ]
    },
    {
     "data": {
      "image/png": "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TFpRUVFiCRIZtZYuXeru02IcxDfffCM6VtHSMnIvUhONhQsX2t2fiq9QRTOqYkb7k1HvueeeE+vLGc/hwoULeP/990UzlmbNmonVElQLnvp2k/HSFnztvYOSkhJxHfv27SsqT5GJl649eYrIpEs1mp1+7SnHy9hm06ZNkr+/vxQeHi5NmDBBmjRpktS8eXPKiUtz58519+kxDkC+nrGxscafFyxYYHPfgoICKTk5WewzdOhQ6YUXXhD39Lhr165ScXGxy8+fqRt07ei6XXPNNdJDDz0kvfjii9Ldd98taTQaSa1WS4sXLzbbn6+995CVlSUFBQVJffv2lR5++GFpypQp0qOPPmr8/6frqtPpnHrtWXjtoNVqxT9lYGCgtH//fuP41atXpTZt2kgBAQHSmTNn3HqOTP3ZsGGD8TrOnj27SuF99dVXxXb6x7P1IT5r1iyXnDNTf5YvXy6lpKRYjW/dulV82Y6OjpZKSkqM43ztvQedTieVlpba/Mzv37+/uJ4///yzU689C68d1q1bJ36p48ePt9q2cOFCsW369OluOTfGOVQlvHq9XkpMTJTCwsLEN2BT6DGNJyUlufBsGWchz2Z2794tHvO19x0++OADce3ff/99p157zvHaISUlRdxTDsgSKu5BbNmyxeXnxbgHqu+dnp4u8kCU6zeFHtM4VUSjTiaMZyP3XvXzM/SQ4WvvG+j1eqxdu1b83KFDB6deexZeO1TVSIES8WFhYXabMDDeR3WNNapq7sF4DtT289dff0VCQgI6duwoxvjaeydlZWWiwBKVhXzyySfRvn17rFmzBuPHjxeli5157RXXFlApyLWf7bV+ojZR9toOMr7592C6H+N5kJv1gQceQGlpKebMmQONRiPG+dp7r/BOnz7d+JhWNDz77LOYPXu2ccxZ155nvAzD+DwUZqRa71u3bsWECROEADPeTVhYmGigo9PpRKj4448/xvz589G/f39jz3ZnwcJrB/kbjr1vMnRh6tMImfG+vwfT/RjPEt0HH3xQdES7//778d///tdsO19770atVqNJkyZ47LHHMG/ePFHT/4033nDqtWfhtUNVsfvMzEyxcNpe3J/xPqrL5VSXC2KUK7qU06MOZ/fdd58onkIfxKbwtfcdhlaYaWVzrbOuPQuvHaiNILF+/XqrbdRq0HQfxvuhfyyqckPfhgsLC822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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "plt.figure(figsize=(5, 3))\n",
    "# Compute the difference between the smallest and second smallest values in each row\n",
    "for i, df in enumerate(dfs):\n",
    "    # Compute the difference between the smallest and second smallest values in each row\n",
    "    differences = df.apply(lambda row: np.partition(row, 1)[1] - row.min(), axis=1)\n",
    "    differences = differences[1:]\n",
    "    \n",
    "    # Sort the differences to compute the CDF\n",
    "    sorted_differences = np.sort(differences)\n",
    "    cdf = np.arange(1, len(sorted_differences) + 1) / len(sorted_differences)\n",
    "    \n",
    "    # Calculate the percentage of time each rank has the smallest number in the row\n",
    "    smallest_counts = (df.idxmin(axis=1).value_counts() / len(df)) * 100\n",
    "    print(f\"Percentage of time each rank has the smallest number for Run {i + 1}:\")\n",
    "    print(smallest_counts)\n",
    "    # Print the average of the sorted differences\n",
    "    print(f\"Medium difference for Run {i + 1}: {np.median(sorted_differences):.2f}\")\n",
    "    # Print the average of the sorted differences\n",
    "    print(f\"Average difference for Run {i + 1}: {np.mean(sorted_differences):.2f}\")\n",
    "    \n",
    "    # Plot the CDF\n",
    "    plt.plot(sorted_differences, cdf, marker='.', linestyle='-', label=f'Run {i + 1}', color=colors[i])\n",
    "\n",
    "plt.xlabel(r'$T_{rest} - T_{straggler}$ (ms)')\n",
    "plt.ylabel('CDF')\n",
    "plt.ylim(0, 1)\n",
    "plt.xlim(0, max([np.max(np.sort(df.apply(lambda row: np.partition(row, 1)[1] - row.min(), axis=1)[1:])) for df in dfs]))\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.savefig(\"cdf_plot.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "b72bd425",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[ 0.  0.  0.  0.  0.  0. 94.  6.]\n",
      " [ 0.  2.  2.  0.  0.  0. 78. 18.]\n",
      " [ 0.  0.  0.  0.  0.  0. 98.  2.]]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Rank = [\"Rank 0\", \"Rank 1\", \"Rank 2\", \"Rank 3\"]\n",
    "Rank = [\"Rank 0\", \"Rank 1\", \"Rank 2\", \"Rank 3\", \"Rank 4\", \"Rank 5\", \"Rank 6\", \"Rank 7\"]\n",
    "x = np.arange(len(dfs))\n",
    "bottom = 0\n",
    "count_arr = np.zeros((len(dfs), len(Rank)))\n",
    "\n",
    "plt.figure(figsize=(5, 2))\n",
    "for i, df in enumerate(dfs):\n",
    "    # Draw a grouped bar plot indicating the percentage of time each rank has the smallest amount\n",
    "    bar_width = 0.2  # Width of each bar\n",
    "    smallest_counts = (df.idxmin(axis=1).value_counts() / len(df)) * 100\n",
    "    count_arr[i] = np.array([smallest_counts[r] if r in smallest_counts else 0 for r in Rank])\n",
    "\n",
    "print(count_arr)\n",
    "\n",
    "count_arr = count_arr.T\n",
    "\n",
    "bar_labels = [f'Run {i + 1}' for i in range(len(dfs))]\n",
    "x = np.arange(len(bar_labels))\n",
    "bottom = np.zeros(len(bar_labels))\n",
    "\n",
    "for i in range(len(Rank)):\n",
    "    plt.barh(x, count_arr[i], left=bottom, label=Rank[i], height=0.2, color=colors[i])\n",
    "    bottom += count_arr[i]\n",
    "\n",
    "# Formatting\n",
    "plt.yticks(x, bar_labels)\n",
    "plt.xlabel(\"Percent of straggler occurrence (%)\")\n",
    "plt.xlim(0, 100)\n",
    "plt.legend(loc='upper center', bbox_to_anchor=(0.5, 1.4), ncol=4, fontsize='x-small')\n",
    "\n",
    "# plt.tight_layout()\n",
    "plt.savefig(\"bar.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "c687816d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "          Rank 0  Rank 1  Rank 2  Rank 3  Rank 4  Rank 5  Rank 6  Rank 7\n",
      "Run 1 1    35.23    0.00   37.49   42.81   20.11   33.35   57.05   48.15\n",
      "      2    15.54    6.79   25.40   13.96    0.00   17.31   39.87   18.70\n",
      "      3    11.60    7.98   24.95   20.09    0.00   15.77   39.40   20.66\n",
      "      4    10.52    6.19   23.70   15.66    0.00   16.03   33.36   19.04\n",
      "      5    14.93    7.67   22.31   15.23    0.00   17.36   52.83   17.91\n",
      "...          ...     ...     ...     ...     ...     ...     ...     ...\n",
      "Run 3 45    0.36    0.00   15.11    9.27    3.33    3.03   23.62   20.97\n",
      "      46    3.61    0.00   17.17   11.72    4.26    4.45   26.01   23.56\n",
      "      47    0.98    0.00   16.29   10.15    3.80    3.98   26.03   25.19\n",
      "      48    2.12    0.00   16.41   12.47    4.10    6.14   26.88   24.68\n",
      "      49    2.09    0.01   15.35   13.79    0.00    3.95   24.25   23.66\n",
      "\n",
      "[147 rows x 8 columns]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Distribution\n",
    "# Rank = [\"Rank 0\", \"Rank 1\", \"Rank 2\", \"Rank 3\"]\n",
    "Rank = [\"Rank 0\", \"Rank 1\", \"Rank 2\", \"Rank 3\", \"Rank 4\", \"Rank 5\", \"Rank 6\", \"Rank 7\"]\n",
    "\n",
    "# Subtract the minimum of each row from each element in the row\n",
    "normalized_dfs = [df.sub(df.max(axis=1), axis=0).abs() for df in dfs]\n",
    "# Omit the first row from each DataFrame in normalized_dfs\n",
    "normalized_dfs = [df.iloc[1:] for df in normalized_dfs]\n",
    "# Concatenate all DataFrames in normalized_dfs along the rows\n",
    "concatenated_df = pd.concat(normalized_dfs, keys=bar_labels)\n",
    "print(concatenated_df)\n",
    "\n",
    "# Plot probability distribution for each column (Rank) in normalized_dfs\n",
    "# for i, normalized_df in enumerate(normalized_dfs):\n",
    "plt.figure(figsize=(5, 3))\n",
    "for rank in Rank:\n",
    "    data = concatenated_df[rank]\n",
    "    plt.hist(data, bins=30, alpha=0.5, label=rank, density=True)\n",
    "\n",
    "plt.xlabel('Delay (ms)')\n",
    "plt.ylabel('Probability Density')\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.savefig(\"pdf.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 143,
   "id": "002a5116",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAe4AAAEyCAYAAAA86zMCAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAVelJREFUeJztnQm8VOP/x5/bnrRJaSMKJW3I0kKbQrYSsiQRRaJUZCnZt/yiECEp/skeESFRRLZCpSzthJT2vTv/1/vLmc6dO3PvzNw7987c+3l7HTM9Z3vO3HPO93m+a1ogEAg4IYQQQqQERfK7A0IIIYSIHgluIYQQIoWQ4BZCCCFSCAluIYQQIoWQ4BZCCCFSCAluIYQQIoWQ4BZCCCFSCAluIYQQIoUolt8dKOykp6e733//3ZUtW9alpaXld3eEEELkA+RC27Rpk6tevborUiTrObUEdz6D0D7wwAPzuxtCCCGSgJUrV7qaNWtmuY0Edz7DTNv7Y5UrVy6/uyOEECIf2Lhxo03iPJmQFRLc+YynHkdoS3ALIUThJi0Kk6mc04QQQogUQoJbCCGESCEkuIUQQogUQoJbCCGESCEkuIUQQogUQoJbCCFEnkL465gxY1yvXr3cMccc40qWLGne1FdccUXcx1y7dq177rnn3LXXXuuaN2/u9tlnHzvmySefnOV+CxcudP3793cnnXSSO+igg2y/0qVLu0MPPdT17NnT/fDDDy7ZUDiYEEKIPOW1115z119/fa4ec9asWe6yyy6Leb/Zs2e7kSNHugMOOMDVrVvXNWvWzG3dutUE9rPPPusmTJhgy4UXXuiShUItuHfu3OmefPJJ9/LLL9uoiz/W/vvv7xo2bOh69OjhunbtmmmfDz/80I0YMcJ9+eWXbsuWLa5WrVquS5cu7uabb3b77rtvnvZ/165dbs+ePXl6TiHyCtI+Fi9evMCmAl69erUtsVKtWjVbUplDDjnEZsZHH320LbyD77nnnhwd84ADDnC9e/cOHvObb75xV111Vbb7MSP/8ccfXb169TKlo+Zdf8MNN5gm4NRTT3UVK1Z0yUChFdyrVq1yp5xyiglshHWLFi1cmTJlTIUzc+ZM+x4quB9++GE3YMAAe5GceOKJdqMwyrv33nttBPnpp5/asfIiw87ff//tduzYkfBzCZGfFC1a1FSXVapUcSVKlHAFCVTFd9xxR8z7DRs2zN1+++0ulTn77LNt8Xj99ddzfMxmzZrZ4jF//vyo9jv44IMjDhwHDRrknnjiCbdkyRJ7v5955pkuGSiUgnvbtm2uffv2btGiRfYA3HLLLTay92Dm/dNPP2XYZ+7cuW7gwIH2IpkyZYo77bTTgtueddZZbvr06Ta6e/XVVxMutH/77Teb3TNIKMgzElG4Cy6gTeJZ3bBhg1u2bJnlb0aIFxSYHfLu8MP1tmzZ0r4jKLC1hpJss21mzo899pj1e8aMGa5YsYxi5dZbb7XJzVFHHWVq6VKlSrlUoth/14MdPmkIFEKGDh0a4NJ79eoV9T7nnXee7XPFFVdkWrds2bJAkSJFbP2PP/4YU182bNhg+/EZDb/++mtgxYoVgfT09JjOI0Sqsnv3brvvly9fHijobN682d4HLHxPBXbs2BFo2rSp9Xnw4MEZ1r377ruBtLS0QLly5QI///xzxGMMGzbM9u/Zs2eu9WvcuHF2zHbt2sV9jDFjxtgxqlSpEvU7Ol5ikQWFzqscuzCqD8B2Ea0t/J133rHvF110Uab12LlRtcMbb7zhEtl31OPly5fXLFsUGtBy7bfffuZTsnv37vzujggBEwY26goVKrgHH3zQvfvuu0Fz5CWXXGLak2eeeca8tJOZrVu3mm8TS+fOnd1hhx1mWhFMomhSk6mWRKFTlX/77bdmH6bmKTcSnoPYVyivieMBtmvU4P56qKjN+aNC06ZNwx6XduzdqNQTheeI5lfrC1EY8NSUCO5QVaxIDmczQrE6depkwvqrr76yT961ffv2deedd55Ldnbu3OnGjx+foa127dpu7NixJheSiRzPuLE/4Wn94osvmv0i2fn+++/tE3vZTTfd5Bo3bmx27qeeeso98MAD7owzzjAhvGLFiuA+S5cutU9GlJFKrnk1tb1tE4lm26KwoXs++cHZDOdd4qmxZ3/22Wf2Lv3f//7nUoEKFSqYdoDljz/+cFOnTnWVK1d2bdq0iVo7m/SCe9OmTeYij7cn3tndunUzdYgH35nVzpkzxyUT3FTAzBhB3adPH7d48WIbgHzwwQfu8MMPt3Wnn366qaa9awU8zSPhhYLhPJYVqLrZxr94MwlvIQwB+AzX7t1c/iXW9liW3Dpnott1TQX/mngOPM1T6PMRqT2754n9omn3+uNv89q9vkXT7l1TpL57pOI1EdJVv359e5/yvkSFjoYku7+T/7pz65r2/Hcer7+xXFOlSpVM8/rJJ5/Y5O6hhx5yb775ZsLvvWiJS+eE52Pr1q1NwCG4GVUxOvHDzBX7wOTJk93xxx/vkgXvj4pQJqAeb0h/PB/CmyB8QgkmTZpk6p7c5L777gsbAsJv6Q0MGOXVqVPHZu9r1qwJblO1atWg8PfHb6NGRH3O38X/AOC9yUODmt+7bsBTFVMANkM/nJ/9OY5/pkM759u+fXuwnf3x8OVm84elYY/k+Py+qJ486Af9YVv/DYp9jIVj65p0TZGuiePQT55LjsHLFDUsYToe+H4cccQRZvbCvuoR6XlC68aCKQxB41eP8l7jXP7+EOfLrIxn1f8bNGrUyH6br7/+OsM18V6kz56Wz/vdjz32WDsfUS3+38W7Jr9Zj2c+la7ppZdesokQ8DfGFMnfMLu/E989cuuaVvynNWVyxHXEc00cFzX5d999Z5NRQscSde+FPhNZEo/32913322eghdddFHQ85F/X3bZZRm2O/LIIwPHH398IJl49NFHg16bH3/8cdhtunTpYuu7d+9u/37rrbfs3xUqVIh43BEjRtg2eFdmxfbt281r0FtWrlxp+61duzawa9cuW/bs2WPb8um1sWzZsiWwcOHCwNatW82r3L9AaFtW7bEssR47v9p1TQX3mrjnFyxYENi0aZN5mYd7PiK1R3qevHb2i6bd64+/zWtnibbdu6Zwfd+4cWPw/bR+/fqUuqa//vorULNmTev7pZdeajKhYsWKgSVLlmT7d/IiffAqz61reuaZZ+yYbdu2zdHfyZMZp59+ekLvPWRAtF7lcc24GVUxEsRon1VMHmpnMowlE4zSwn0Pt42X1cgL0F+/fr2pzcPZuUnc4t82EsxQwsUDMjsJdbphZuJ3kvNmQMxEwtn8vLZaIzOtcTknLWHty/tFtmHG2u79DZYvX56hjZE2o1/yIl955ZWmEQo9Br4OaEMiJbjIrT7Gc03Rkl99TPQ1eQvPCLOhcM+HR6zt3vGibY/kHBdLu3ct4fro3y/ea83ra0Kr0r17d5tt8omjGs8bKmY0mzjuhjrV+vvuv4bcuqai/7WH/tax/p0+/vhj+44mNpH3XixOl3HZuH/99Vd33HHHZRtIj4rOr/pJBkiF571MIvXNa/fs1vzBvMQPoWoWD6+d44vkgBC9Sy+91JaOHTvag/HWW29Z9iOcaIQQuWcCfO+998y+PXr06GAbmczwc7rxxhtz5TyE29arV8+1a9fO5RaPPPJIcOLlB/PM3XffbVkxeXfEkwc9UcQ142aU4DluZQWjr6wcuvIDNAVk+GEEiDc83o9+uC4cEoDBiTdbw1ntlVdecRMnTjQvQz/M7jyPeuL/RHKA8yQxmX6NBYUN8GsgfS0zAexYHoStXHDBBXmStlaIggIpom+77Tab3PCO9N75CDv8hHjHIhzxi/LSnKLN9L8rPbswA+sTTjgh2M4gwD8Zwh68ePHiDH4cfvz7ejZlQtP87UOHDrX3uQd9YyCPjZpJGhNS+odd+59//jEN6dNPP+0aNGjgUlpwY2znorKKqdy8ebMZ+xmBJRuoQnFEY0SI44H3R+V6SGuK0wHqcP8Ii9AxgvDHjRtnRUVIOO+Nyij9hmMH7aGJ6kXywL06fPhwq/SDwwqpa/2CG4EtoS1E9CAcGQDz/nv88cczve8pk4naHIHN+xSHO0xZOD+GizjieH4nruyidEIJd0yO4W/3Hx9Ix/r++++b1pRBCCZRBh/IOd7tV199dUSzan4Rl6qc/LqMSFAjRIJ1jI6ScQaKmuWuu+6y0RSCG5UqQpdMOY8++qh5eBKXTsYcD0Z9xCNyg6J2ZdZNERKSuJCnnJEalcZEcsNomr8z/PnnnxnWYdfGjBJq3+bFQzuzdzw/qQTH352ROBocVPHkj48EYSTcZwwG8T5t1aqVZeIj/zbHzc4vQohkBTs29z42br92yw+mKSIG1q1bF7zX+YwmHJBZuh/OEQgE7NkJRzTHDO0n2TB5xvFOx0zKBA7ZxSCDgX6yCe24BTfqxho1apjwI1MO6mPvRUgWMtSNXDB/nGjKquUHQ4YMcdOmTQsWG2H2hVDmj8ofzK9K8V834WLEraNN4IWMHZwXOeoYzdZSA28U7x+YRQMPc/PmzW2AxsyCOE9eBMzgGfz5Q1U8SAHJM0LBiCOPPNLuK0JMcI7zUu8KIUTCVeXEyOGIwMwbmwRCj5kDbSy8zMjfTXuy2bj9dOjQwZZYQMXOIlIT6u568ZehlZmyg5wEDNrwj/DyFqO1adu2rZs3b57Z4xjEeRAbS+U5fEKw/fm1T/ybAa5IDjJHYuQP6b5KvfUed65IkhSkIvJDFIDMacw4UC3wsmIW4Rn2EWoUH1+wYEFS2rdF4YTZMHasc845xzQraFwi5Z2PBINQfBz8xQbIb4//A+Ds6AcnOM51/vnnZzIZkbuZvgghRKwUy6m9EFV4sqrDReEGZ5jQEA5mvy+88IK7+OKLYz4egj5cLWQGrRBq5/aiEyKdi/ZE128XQhQ8VGZHFFiwO3ulBPEkRcVNAh28RHFQ88L9ogUP2XB4M/DQEBUvxCWS85mc0oQQeSa4UYMTlI63YGgctAcOXm+//bapCRUiJZIhjtuLcpgxY4bdlwsXLgwm1omGcJmPoiGRWcWEKKgQueRlr4yFatWqhdWMucIuuLFrjxkzJstMMnhYkz6SEAAC3IXIbwjFIl0vA0mS5uCLga07URB5gSMcoSvh/D0ihbQIIZzJmHAFmbIjUspiV9gFN7lbqbTi1aCOpFakigoxzkIkU9wpwppMSeRRJlsaURKJ4KSTTjLBTbgksf+heGGUQojMUF0yNPKDUMqWLVvad0IsybkRSkGfbcctuLHdEf+cHQSuf/TRR/GcQoiEQQ12tECU/SOpDvkIEgGDAmK8SfuIF7mX7hHId4C5SQgRvcrbX/qySZMmSR1unEjiMtqRWSYaex/bRMopK0R+QcYzT5U2cuRIM+ckAiqRkUGQkDCSsFBwAU9y6tOTqa9///7BXPhCCJFQwY2KnExh2cE21atXj+cUQiQUSg9id8bLnCx/iYKELMyu8XD/4YcfLCkRgppkLt4MXBn3hBAJV5WTKQrHAZzUUDuGg3SOOADh2SvylsKe5Sgapy/iuYmO8MMsPJxTC57pkfIw+/MuRwJP9nA5+++88077jDURjBCicBN3rnJmDdddd519J6wGdSAL32ljHduo7rEozPz888+WFjUUUgVTnY6QMIqUCCFEQmfcJK8YO3ashYONGjXKFj/MPiihSA1TxXCLwsz//d//WdlA8h1gYqLeO/WEWYAZPrZwIYRIeOY0SqEhlPHIJUez5+1HQgs8zm+99VapAEWhh7rtzLq/+OILK3CCs2alSpUseRFmJq+uuxBC5EnKU2pUv/HGG1Zrde3atdbGSyneDFNCFDROOOEEW4QQIqlylSOoSWwhhBAiOvZsWO32bMyY0jN917bg952/zXNFimdOMFK0XDVXtHzBTzIiIqMiI0IIkQ9smj3GbZwWOaXnX6P+zRAWSrlThrkKpxXslJ4iAYL78ssvj3pbvGZxZBNCCLGXss17u30aZEzpGQ3MuEXhJi7B/dxzz2W53qt6hHe5BLcQQmQGdbdU3iLPBPe4cePCtuOkRtKVqVOnuq+//tpSOlJoRAghhBD5KLizSxhBbOqNN95ocdzU5RZCCCFE7pCwuC2STpQtW9bddtttiTqFEEIIUehImOAmcxpx3iRnEUIIIUTukNBMKRQ9D5enWQghhBBJFsdNesdPP/3U8jMLIYRIXUbOuM4lAzu27Qp+f/yTQa5k6eIuWejXJmPNjqQT3BMmTIi4jvrGCO3nn3/e8jKT01wUzocsv294coSPHDnSffTRRxbtQPU6al9Xq1bNHX/88a5NmzauS5currBCOVJ+l6VLl9r3SFDp79FHHw1WNSPPelahohQf8kNI6L777uvq1KljudmpGKhMi0LkseCmNrEXqx0Orzbx2Wef7YYMGRJ/74SIk9dff90GjTt27LD8+S1atDBhgelm3rx57vHHH3eTJk3KILhbt27tPvnkEzdjxgz7Lpz9flQ483j22WezFNweZcqUceeee659Z8DEAOHzzz+3355w0lmzZlmVQSFEHgnu7t27RxTc1OCuUaOGO/nkk13z5s3jObwQOeLPP/+0kEWEzsCBA93dd9/tSpUqlWGbb775xr366qv51sdUgSJC69atc9WrV3erV692b7/9tv2+BxxwQJb7odkITdS0YMEC16pVK9ufHA/vvPNOgnsvRMEkIZnThMhPEC6bN282YfPQQw+F3YYa2KqDnT1e1sN+/fq5d99913388cdmKrvhhhtiPtaRRx5panJK/n7wwQc2sCpZsmQCei1EwUb1N0WBgxkdRGtHRRihQUJNDti++be3eAPVZcuW2b+xB6P+HTFihDvqqKPMfuvXQC1cuNANGzbM1PNon9BCoa5HC/Xyyy9n2Zc333zTnXjiiZYDoXz58jZDZWbqP3c4cATFflyhQgXrz7HHHhv0RfGuI1Y45/Tp0y20Ey1bz549g+ryeGnUqJF97tq1y2byQojYUXUwUeA46KCD7HP+/PkmeNq1a5fl9lWrVjXV+nvvvWdC/5RTTrE2j0MPPTSTD8c555xj2yNkjzjiCFMDeyDQmanWq1fPNWzY0ITpihUrzHZOf7744gvbJpQHH3zQDR482L7jPFe7dm33yy+/uDPOOMMyEUYCW/3FF19sKYc5X4MGDdxvv/1mTmIMIuIFAc21duzY0X4P/AH69u3rFi1a5GbPnh2XKWzjxo32WbRoUVOnCyESJLjvvPNOFy+M9IcOHRr3/kLESqdOnWymi/Bq3769zVoR3iQEYiYaOhNHwDKrxiENwX3TTTdl6ZyGEEZI/vDDD+7www/PtP6SSy5xt9xyiwleP4sXL7ZZ98MPP+wuuOACd9xxxwXXzZ071/ZBoL3yyiuuc+fOwXX8m+3D8fvvv7srr7zS+oMHPR7gHjNnzjShGw8cz9M0eNUAS5cubf0YM2aMDUziEdyeXRvtQPHiyRPKI0SBE9zkHkcAe97iHtmp37zqYBLcIi9BVczMlln0nDlzTBXO4tGkSRPXu3dvE3gIynhT+oYT2sBAIRx169a1Z4Fz4xjnF9yPPfaYqd8vvPDCDEIbzjvvPFOxh3OmQ4Biz2/WrFkGoQ0nnXSSu/rqqyPa+bPi/fffdytXrjQntNNPPz3YjrocwU1/GCjwW2eH51X+1FNPuYkTJ7patWq5UaPyLuZViEIpuLHXhULsJzY0vHU7dOjgDjnkkKBdjIeeGG5enFnFhwqRKBCSqKS//PJLm+UhwCl4s2bNGgtJQqC99tprtg4bdKxkF/+NMMWZi5n033//7Xbu3GnteGZ7s28/nn0dlXc4aA8nuKPZLx7B/cwzz9gntm1s3B5oLFDFY4Z46aWXgnbvUBDU4Qb2DFZ4P2C/F0LkoeBmJI7aEZXkE088kSk05K+//nJXXXWVvRQp7ylEfoGg8Ga2aIAQpMOHDze7MHn0mTXG6iFdpUoVt88++0RcP2XKFLMvr127Nltbr8eqVavsM9JAN1J7vPtlBYMbEq341eR+aMM7HBt4JMHtj+PGe5ykTN99950NpNA48PsLIfLQOQ11H/Yp1F6h8bHei4112PjYdvz48XF2T4jcgxkgA84XX3zRbd261YTT5MmTYxbc2HojgV29a9eulqcfhzJmvAhPVMpFihSx2SbOb6FmJ38fY2nP6X7hIOshXt/MtK+44oqw2gTAQQ1HNXwEoonjJikOvw0zddT4ffr0iblvQog4w8F4+fDghRPaHqzD45Z4zXjYvXt30CsYFSGf/Bt7mRA5BfMOoMbOTZhtI7SxUz/wwAMW/lSuXDkT2l4a1nDgTOeZmsIRqT3e/aKJ3eYZ/OyzzzItzJxDt40GPPFx/APK/W7YsCHmvgkh4hTcxF/ycsoO7NyxVAdjFoTjy2mnneYqVqzoGjdubC9YRul88m9Ca1iPowvbCxFKpNlsqGc41KxZM9jm2boRWPHixSbjgBWuX2iiwsFAGCKtz24/tAix7BcJ0pISQkZiFJ5d+hxumTp1anB2HsvvdfPNN1uueMwI4ULihBAJEtzEyRKT6iW6CMcff/xh20RTHWz9+vVu0KBBNntAfTZt2jQTysSOkm0Jj9n69eubLX3Lli22HucitkfNyf5CeIwePdocI1HlhoLQQWWLFzf4w6w8Ie6PyY4VYroBLZHniAZoiphlhusTEB/NrBzbL0lY/NBfHOnCgY0ZezsJWMi/7ofZMb9FLHgzaOoMMEiOBANpnk/eAWSqixb66kWZPPLIIyr7K0ReCW6KN2DnIjY2nCocpx/iZxGy2VUHe/LJJ63YAKNvZjyEtPAiQIWJvfD777+3lxIxs8Ss0o5tkhcddvb//e9/tj8zdSEA+ywRD2Quw98CmzK2ZsKa8LvAI5yBYbdu3TI4V3me4timKaTBOmy8kYRtONiPVKo4jREuRvIUNEZUxkJ17iVYCYV9yKmOgMfpk8EqfSYRC/0itzeEesAz2ODeR+jzTKCV4pkjDp3ZOE6iEE3MNM809mdg4JMVhNF5z3Ys6nLgN+X3wEEvHo93IQo7cQlu7FS8UFCpkUiBmTD/ZuE7L0pmLXjzejatSDDDJqc0MxQENckpSBqBqjwc++23n70M8QZGkJOcAtWbHF2EBwIXp7Nrr73WwhS5T7lP0AAhcIiVJlQLNa9newYE+9NPP23hTpQCxWsaofTTTz9FfW4cuogZJ5kKGiF8M/g3qVFRQ/O8ZKVGZnbNgIOBKvZyBDXXwgwYwmUbYwBCfxksY9Nmxk55Xa7Fi+2OJksZsdkIb2bSPMPZQagY8FvyLEYLgwgGKUC50Ky874UQmUkLRGMQDAM2blR/2Jp5SfjBg7ZXr16WcS2rsBmgZCAj93i8X0Nth5FiWZMZZh3EtOKogxNTdj4DxM8jjLJyDBQFD54lwjIZjMSSvATNA7NnNAFeiFcqkuh7v9bIXD9kgWJAo4zJffKLHdt2ucGnP2nfH3jnKleydPJk3+vXZlSeyYK4c5UTEkM87F133WWJLbx4UmYZqP2ifbhyQ9gi9FNRaAvhB49zZsah2iYE7n333Wf3eTgVNo52zMz9+dU9Gze+I0BcuRCpxIa1W9zGtVsytO3asdcR8rdf1rjiJTOLsHKVyrjylcq4gkyOi4wgoFV3W4icg/aJVKqo1XHqxFZPhjUvyxqph8OVIkVNjnkA+zaOo5gDfv3112DYFkI7NI2qEMnO7Cnz3bQJX0ZcP6pfeIfNU7of507rcbwryORKdTAqGJFtidKFkfI35wakdyRdJaE2Z511Vgb7pBCpDvZvZt2kaiXTGOphninU3PhwRLKPn3DCCSacZ82aZfZ0nELxCKegCVnOsOkLkWo0P7OBa9D831TasVCugM+2cyS48X5FfUdYDUIbUON5tXqZPRCegoMMIV3RQrYlbHgsLVu2DLZj2/OHtuDRjlNMvEUihEg2EMAssULmMi+3uBAFhfKFQOUdL0XiFdp4duMsQxwmsauhPm54xjJzwEs2FvAuR81HMQMP8p0zCEAtj3et562rfMdCCCEKG3EJbmKvSYLSpk0b8/QkFWko5GcmVpP0qLHAsRo2bGiZmzwQ0DjmEL7DQIBCBQhxb3YvhBBCFBbiEtwUDSGemthYYrAjwUzcSy0ZLcR0+tNQwsyZM809nsQUgPcsedCxrQshhBCFibgENxWBSK4SKUmKBzFplPiMBTxp/YVEKAmIdyye635ntMqVK8d87IJCnKH3QqQsuueFyAUbt1+VHQlyNUeznR9m8P5c0XiSI8xDQ868YPXChDdwUYU0Udjw7nlFkggRp+AmHIsc4lmBsMVeTR7xWCDHMnGr999/v820cYDDvh0aCsOxQ1XqBR1SReJFH01lNiEKEmRn5P6PJue6EAWduAQ3QpScyKQ7jQQ5iAkTI/9zLJDjmZSpt956qzv66KPdnDlzLB7Vn3iC3NE4xcUTOpPKMIAhhSwp8TTrFoUFBqpo2MqWLZuj1MhCFOo4bkppEm9NUggKOJx//vnWTuIH0p9SrIBqX6RvpGJRLBx66KFWjYmqX9iwsaVzPj+EgpElKtZBQUGAalcMmpYvX24Ogpgi9DITBdGmzeCUmTZCm/s8mkIpQhQG4i4ygqf3Oeec49atW5dJcHBIMjeRY9mfREXkLLG8ByUpKW/KQEmIggyqcWbaCO1EJltSkZHUKDKSzPRLhSIj1PrFiYwynFOnTnVLlixx6enplmP5tNNOs1kyiVJSBWowUzQFKJwyZMiQsNtRaxxtArHkCE7s/dRLpiQjKv68AHU5Oal3795tixAFERzRENzSKAmRi7nKqb2NExlLJBAs1CiOB1RlxHWTszkSCLCc4qnmeUFkpYBgkDJgwADbjjhyrp/80BSGeO2119ynn36ap+o8ftd4f1shhBCpScJiK5h9kz85nqIjCNJTTjnFZrDVqlWzGrzhltq1a+e4n6ide/ToYechnWok5s6d6wYOHGjqunfeecfC1LDlk56VvOl4wl911VU57o8QQgiRFcUSIbBJTXr33Xeb+jxWKFGIqp1wMsABCxtXokDFTUUmhDGCOBIUVGE2ThUm+udXW48dO9YGEcy6SU5D0QchhBAiX2fcqKyp0EUO8tKlS9tnv379rMiIx3vvvecaNGhgpQSZiWJoR40cC9iWEdr9+/c3BywWQr8iLTmBEoiErXXv3t117Ngx4nY7d+40wQ4XXXRRpvXYuSmqAm+88UaO+iSEEELkeMaNExbe4cRPezZgcpBT0vOzzz6zKmAIXJy7WI9gR8jfdNNN5l0eC9TbbtKkiTmAJZLNmzfbAAM79SOPPJLltlw3KnVo2rRp2G1ox96NSl0IIYTIV8FNbWxsuCVKlLCa240aNTLX9bffftt9/vnn7txzz7XQL+jWrZt74IEHzGYcD9i180LVPGjQIJuxM0POLue6N7NnEBJJbY83vX9bIYQQIt8EN0KZ0AxCofxx2diHsflSLQxPawT8Nddck6MOkQ2NGW4iodTomDFj3AUXXBCsOJYVJIGAMmUiF3X3QsEY0GQFRVNYPLzt/aFd/NYs+AuweHjteNv7vd8jteNIx98lNGTMi4cNzb4WqR3PdS8hhgfHZfvQPkZq1zXpmpL5moqn7e37nkARl+6KuGJpe1ya29u+O1DUBVyaK56W8Zr+bXeueFrGvu8KFHUEshXL1F7Mjutv57gchzMXTUvPtj09UMTtcUVcUXrqa4/U95xeU1rgX6tqwP17rrQQK2uAPgQitac5/suuPWAHCERs9/qQfXs6HQnfHq7vuXRNkJPnKZbQ3qgEN7Pt448/PmwyFdThCG68x3MqtIFUp8SIT5w4Maw9OacQ3N6zZ0+rLoZ9O6/Bye2OO+7I1I6K3RsY0DdqmTN7J22sB7nZWRjYcB0eOMaRUY387f485mgu0BJwbP+LD40J2pOvv/46k7ofe74/Dz0vwmOPPdbOh+OdB+YQstfhg+B3QsSvgXKuv//+u1u1alWwXdeka0rma7qs8t5rmrmxtlu0vYrrXHG+q1hs7zVNXV/PrdpZwXXbf24GIf3K2kZuc3oJd1nljNc0bk1Tt2+Rne68St9nEObj1hzrapTY4DpW2HtN/+wu7V5Z19gdXupvd1K5vde0amd5N3X9Ee6oMr+7Y8rsvaZF2yq7mZvquBZll7p6pfde0zdbatrSofxPrmaJ3Lumytsa2Oea0vNdkUBxV2l73QyCb80+812J9LKuwo5Dgu2703a4daUXu1J7KrpyO/fWldhZZLNbX2qJK7O7iiuz64Bg+7ai69ymkqtc2Z01XOk9+wXbtxT/05byOw52JdL35srYWGKV215snau4/TBXLLC3mNX6kkvdzqKb3P7b6mcQumtLLXbpabuC1+KRW9cEOXmeYkmoFVXmNEa9F154oXmLh8IogQeRtKeTJk1yucHkyZPdFVdc4dq3b28e3MRqR6oKhJCPBTQEpGt96aWXgqlaPQgLYxASmoBlypQp7qyzzrIXkd8ZL1yMNy+gr776KqYZN2p2nP+8bDmFddaja9I15dc11X1cM+6srum6BoP+649m3IEI13Rd20dy9DwhCypVqpR7mdM4YaSqPF4CEMKicgsuhuMRnpVViFa4F0N2YNOmz6NHj7bFjzeqJ7wLs0DVqlVtMIIHPaxfv97U5uHs3CtXrrRPb9tIkHM5XKnTcMlUvD9uKJFSP0Zqj5SkJZZ2futw7ZH6GGu7rknXlJ/XtCvM9AXhFQ4Eb7TtgYjtaWHbEa4I5WjbEd4I5Wj7Hu81mbDK0P+M/zbSIrUjYgM5bg/tQ9zt4fqYS9eUk+cplmRaSZd2C3t6165dbbBADDeJVnI7lSjCngQqkaCIBwthXlC3bl0bSOBZjoqvTZs2mfbxVH9UNBNCCCESRdSCmxjttm3bxrye0TLVvKKFxC2oDnB0u/rqq3O9sACz5khEUpVjCqAS2SuvvGK291DBTaUusr1B586dc7W/QgghRFyC+48//rAl1vWxFgigTGizZs1iLgeaaHDCe/XVV924ceOsqAg1yYFZOM5uqPdpV9Y0IYQQ+S64hw0b5vIKPKs9FXUygQqcQiQ4oJFlrVWrVuZNS9KV1atXmzr9ySefzO9uCiGEKOAkneBu3bp10mYfu/76613Dhg1NgHtlPfF4J56dJZE51YUQQoiow8HyEuLajjnmGIvnRj1d0ImleLoQIjHUGpnfPUhuBjS6Lr+7kPT0azMqz2RB0nmVk/ecHOIIbjzMsSVnFcdNgRAhhBCisBCV4J45c2aOThJLkhQ8u3FoQxGAEJ8zZ06W20twCyGEKEwUi9buHKt3eLxJUhDE8Z5LCCGEKOgUi3bGnFfClHSkQgghhMiB4P7444+j2UyIQgVpbqdOneq++eYbWyi0QaEM4vqfeeaZHB2b491///1mpsJZhTK5Z5xxhhs6dKiFIYZCYQOSFhGR8fPPP1vue/pCvfnmzZtbXoRwRYKEEKlH0jmnCZEqvPbaaxYimNuQ6IeiPpiYqI5F2l9S6j722GOWve/TTz91hx56aKY8+8OHD7fa8vXr17f92P/HH3+0gjosDzzwgLvxxhtzvb9CiLwlvKt2HkLRj9zg9ddfz5XjCBEtCNRrr73Wsul99913FgmRUygLeOmll5rQpWY8+QIQuoRJduvWzf35559W7jY0ipP8Asy2KXWJYEfA82wh0EnTS+pgcg0gyIUQqU2+C27ShJLidNq0aTHvy8vrnXfesVrh5513XkL6J0Qkzj77bFNPEwlBnelYqvtE4pFHHrE0uieffLLr1atXsB3B+8QTT1icJ2Vj33///Qz7oRJv0qRJ2LBJZu9k+qNwD1XvhBCFQHDz0oh3ye5lRh3rxYsXWxpR4rUp7jFjxoyIRcVp/+ijj2z2wPbUycamx3GEiBdmzjhgnnjiiWGjIJhNs57Ut9u3b0+4BopZdShUyeN+j0fD5D2H4UrKCiEKoOBmZhvv4i8eHo5+/fqZGpBKYP/884+79957bbZRoUIFU0U2bdrUqo7xyb9pb9++vdnrqPTVp08f2/+665TZR8QPaWy5x1Az+yvDeZXv7rvvPstmRH34UqVKJaQP1Hr/5Zdf7Dt9CYfXHktaYLRSDIbpd4cOHXKpt0KI/CIq3V52wjen7L///uZ4c88997hnn33WTZ482RKvUC6TxQ8lNlu0aOE6derkLrvsMlMdCpFTuK8QysyoH3zwQVMtn3baaeatfckll9ggFE/xUKew3IQa8B5ok8Jx4IEH2ufSpUsjHofBLOr2zZs326D2hx9+sDz62OIPPvjgBPRcCFFovcoRwnjpsqCOXLBggTnjEA7DTJswmCOPPDJhMx5RuEGjQx4BBoUIa2zJfOLwRThVov0omHH7q+SFA3W5l9c4Ejij8cx4VK5c2SrXnXPOObnaXyFEARTca9ascePHj3eDBg2KeV+EM8VGhMhrhzNKt44YMcIdddRRJgBRT6NKTxUwIcG6dessthzzE06gF1xwgXvhhRfM90QIkbrkulc5avW3337bRvc1a9Z0gwcPzu1TCJFQ8J8gFhqhzcwXFTqq9ETjLwsbyTkT9TdEU0luv/32s6yH7777rjv99NPdpEmTzDNdCJHa5JrgxqnmlltuMRscsxbs1Lt27XKNGzfOrVMIkSfgX4Ft2BOg2Ijzglq1agW/r1ixImK2NojFVo03PCFruZk3QQiRooJ727ZtbsKECebIU7duXZuprF692lWtWtXU499//7379ttvc6+3QiQY7NmolAkJw/nRE3qhTpKJgFm05/xGprRweO040cWCZzP/66+/ctxPIUQKCm6yOV111VWWP5mX26xZsyxOtHTp0vaiwxMXz9wGDRrkfo+FSBB4juOMxv1LlToiHAYOHGhhil27djUNUqLp3Llz0MEsnJp8ypQp9j1WR7Pp06fb5+GHH54r/RRCpIDgpmgBWZ1IrUims6eeeso8W4844gj30EMP2csOZx5QWU6RihCrTcw29u3Ro0cH27jfUZ/nVp5v1NX16tVz7dq1y7Suf//+bp999rEMZ08//XSwfc+ePRbmheMZechD47F5HklkFAqDDdaR4Q382diEEAXYq5wwGEb6vASYlaDSYwZy+eWXW7pRIVIdqnDddtttJjTJ8+2pltEk4dTFoJSBK7Xp8eEAzELeDBkYvMJbb73lTjjhhGA7gwC/ahunN4RsuAxs1atXt5A00pQiZMeOHWv2bELTlixZYqlNmY2HDo5p6927t6tTp46FTBI2RiglIZV//PGHpUJlEHLKKack4NcTQiSd4KYKEi+KGjVqWJKUc88919TiQhQECFtEUDKrffzxx23G7YdkKAhTBDamIfw2EKY7duywmXi447F4ZBVzHWmgXLt2bQvjwgxFljTMUtdcc42V9UR4h4I2AD8T+vP555+bep9nlL4zuMC0RT51IUTqkxYILTMUBq9wAcKblxr1hqlURMYzP+R5nj17tr0ARXTwUifxDLOwaEJ8hBC5T62R+d2D5GZAI6WUzo5+bf41R+WFLIjKxv3NN99YLnEOiuoNhx1itJl5T506NVOJwdxi4cKFlmYSFR/qR3+s+M6dOxNyTiGEECLlVeXY91Ahkk3q1VdfNWGKTZAKRTjaYJfDGxf1XG5ArCoqSQojeFCj2KuMhNMOjjqUNgzn4CPyDuy8LLGC6pdFCCFEAlOeUhLw4osvtgVHGRxnSGn622+/WQy3B4L1/PPPj6sACGkaiQun4ALhZGR+8jx8PTg2uaOZhUtw5y9jxoxxd9xxR8z7DRs2zN1+++0J6ZMQQrjCbuPOCtTWpFRkFk75QBJXYAtHyOPMQzwsVZaihRSpw4cPtwQuDAY4FjZ2kmAQV+uBly7rUOOnMqlu4w434yYxT8uWLe07ZTLDOTJqxi2SCdm4s0Y27uSycee4yAhClTzILGRlYgaOgCXc5aWXXrLQGoR5tLz55pvmsXv//fdnGQ+O1+1nn32W0+6LHBJOAPvzbDdp0iRipSshhBD5XGSEsps33HCD+/HHHy2MBbt0rGFjpJZkNu15skeCog+o1YUQQojCRMLKerZo0cKWRx99NOZynv66xJGgCEM8NnQh8hI57wkhUqoeN5DBKRZIBUmCC9StkVSsFIL47rvvlLVNJD1y3hNCpJzgjhViw1G3DxgwwGoHh1OZs37r1q2WdlUkn3NN+o693+s97lyRki4pWN4v789JGlIvjDFW5z0hhEgJwU1aRxzc8FLHY9yrgvTrr79aHDnOblQnw+nJqzEsRLIi5z0hRIEX3Ni4p02bZvmaSZ9KnmZvZsJC9BrVkSZPnuyKFy+e390VQgghCrfgBmYoCGkEOLHhJHshXvzAAw+0mHDiw1U6VAghRGEkKQW3ByUIVYZQ5BYjZyRHEokd23YFvz/+ySBXsnTxApNEQgiRYnHcQgghhCjEM27Kg65du9Zt37494jbUGxb5x54Nq92ejRnjlNN3bQt+3/nbPFekeGav6aLlqrmi5eU5LYQQSSO4STqxa9euuIQrTmnEvlKBLKvyndi5Y0mnKnKfTbPHuI3TIscp/zXq37CnUMqdMsxVOE1xykIIkTSCu23btu6nn36KWbh+9NFH5oDmCf399tvPlS1bNlHdFDmkbPPebp8GGeOUo4EZd2Fgw9otbuPaveFfsGvH3ufht1/WuOIlMz+G5SqVceUrKUxMCJGHgpuwLW+JhSFDhpjQ7t+/v31HcIvkBXW3VN6RmT1lvps24cuI60f1ey1s+yndj3On9VBmQCFEHgpuZs7erDkW5s2bZ0kpSLYiRKrT/MwGrkHzQ2Lejxm3EELkqeCuXr163LnNyVcuREEAdbdU3kKIAh0OdsIJJ5htXAghhBApILhvvfVW98MPP7iJEyfmd1eEEEKI1FSV33nnnXGfAK/yoUOHRr09pTpfeukld8UVV7gpU6aYhznhZOGqhMFJJ50Ud9+EEEKIAim4qQuMAA71EM8uXzjbxyq4vcQr++yzj3v55ZdtiYTiuIUQQhQ2ohLcw4YNy9S2dOlSN2HCBKvm1aFDB3fIIf96zi5btsy9//77lu3s0ksvdQcffHBMHXrrrbeszjZFRQgF47g4rAkhhBAiTsG9cuVKd/TRR7tOnTq5J554wh1wwAEZ1v/111/uqquusspeX3/9dUwduvvuu22mPmrUKHf11Ve7okWLxrS/EEIIUZCJyzkN1Te1sHEgCxXaUKVKFVtXrFixmNXkCxcudM2aNXN9+/aV0BZCCCFyQ3CjCscpDDV5JFh34oknug8++CCmY5cpU8bVqlUrnm4JIYQQBZ64BPe6devctm17K0BFAjv3P//8E9OxW7du7ebOnRtPt4QQQogCT1yCm/CsGTNmuD///DPiNn/88Ydtc+CBB8Z07Lvuusts6Pfff388XRNCCCEKNHGlPL3ooosstrtdu3bu4Ycfdu3bt8+w/sMPP3TXX3+927Jli20bC1988YW7/PLLLRELHuannnpqlnHc3bt3j+cShBBCiMIjuG+66SY3bdo0N2fOHBOs+++/fzDsi3Cwv//+2zzDSabCtrHQo0ePYMw4QpxzZIUEtxBCiMJEXIIbxzOqf912223uqaeecmvWrLHFg7jrXr162aw8Kwe2SII4u8QuQgghRGEl7upgpUuXdsOHDzeb9LfffutWrVpl7TVq1HDHHHNMzALb47nnnnOJhFKjM2fOdO+99577+OOP3c8//2wq/UqVKrnjjjvO9e7d251++ukR98cMQMnRL7/80vbDA75Lly7u5ptvVqIYIYQQyV/WEwHdvHlzlyp88sknQZt81apVXcuWLS0EjfhxcqOzoC148sknM838secPGDDA2gl1I4Z91qxZ7t5773Wvvfaa+/TTT81sIIQQQiR1dbBffvnFff755ylRjhMnN2bIzLpXr17t3n77bStqQkWySZMmWdIX1P/PP/98hv0IURs4cKCtJyMcAwDyqP/666/mpLd48WLLFieEEEIk5YybQiD33Xefe+yxx4L2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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Get the first allreduce kernel time\n",
    "\n",
    "plt.rcParams.update({'font.size': 16})\n",
    "\n",
    "log1 = '../log_ring_3B_8_b4.txt'\n",
    "log2 = '../log_ring_3B_8_b8.txt'\n",
    "log3 = '../log_stragglar_3B_8_b4_padding_reorder.txt'\n",
    "log4 = '../log_stragglar_3B_8_b8_padding_reorder.txt'\n",
    "\n",
    "# log1 = '../log_ring_1B_8_b4.txt'\n",
    "# log2 = '../log_stragglar_1B_8_b4.txt'\n",
    "# log3 = '../log_ring_1B_8_b8.txt'\n",
    "# log4 = '../log_stragglar_1B_8_b8.txt'\n",
    "# log5 = '../log_ring_1B_8_b16.txt'\n",
    "# log6 = '../log_stragglar_1B_8_b16.txt'\n",
    "\n",
    "# logs = [log1, log2, log3, log4, log5, log6]\n",
    "\n",
    "# legend = ['Ring, B=32', 'Stragglar, B=32', 'Ring, B=64', 'Stragglar, B=64', 'Ring, B=128', 'Stragglar, B=128']\n",
    "\n",
    "logs = [log1, log2, log3, log4]\n",
    "legend = ['Ring, B=32', 'Stragglar, B=32', 'Ring, B=64', 'Stragglar, B=64']\n",
    "\n",
    "# log1 = '../log_stragglar_3B_8_b8_padding.txt'\n",
    "# log2 = '../log_stragglar_3B_8_b8_padding_reorder.txt'\n",
    "\n",
    "def extract_ar_kernel_time(log_file):\n",
    "    ar_kernel_time = {}\n",
    "    with open(log_file, 'r') as file:\n",
    "        lines = file.readlines()\n",
    "        for i, line in enumerate(lines):\n",
    "            if \"| Step \" in line:\n",
    "                # Read the AR Kernel Time from the first line after the matched line\n",
    "                nline = lines[i + 1] if i + 1 < len(lines) else \"\"\n",
    "                nnline = lines[i + 2] if i + 2 < len(lines) else \"\"\n",
    "                match1 = re.search(r'Rank (\\d+) \\| Step (\\d+) .*? Iteration Time: ([\\d.]+) ms', line)\n",
    "                if match1:\n",
    "                    step = int(match1.group(2))\n",
    "                    match2 = re.search(r'AR Kernel Time: ([\\d.]+) ms', nline)\n",
    "                    if match2:\n",
    "                        ar_kernel_time[step] = float(match2.group(1))\n",
    "                    else:\n",
    "                        match3 = re.search(r'AR Kernel Time: ([\\d.]+) ms', nnline)\n",
    "                        if match3:\n",
    "                            ar_kernel_time[step] = float(match3.group(1))\n",
    "    return ar_kernel_time\n",
    "\n",
    "# Extract AR Kernel Times for both logs\n",
    "ar_kernel_time_list = [extract_ar_kernel_time(log) for log in logs]\n",
    "\n",
    "# Convert to DataFrames and omit the first iteration (Step 0)\n",
    "df_list = [pd.DataFrame(ar_kernel_time.items(), columns=['Step', 'AR Kernel Time']).query(\"Step > 0\") for ar_kernel_time in ar_kernel_time_list]\n",
    "\n",
    "# Calculate the average AR Kernel Time for both logs\n",
    "average_ar_kernel_time = [df['AR Kernel Time'].mean() for df in df_list]\n",
    "# Calculate standard deviation for error bars\n",
    "std_ar_kernel_time = [df['AR Kernel Time'].std() for df in df_list]\n",
    "\n",
    "\n",
    "# Draw a bar plot to compare the averages\n",
    "plt.figure(figsize=(5, 3))\n",
    "# Draw two bars side by side for each pair\n",
    "x = np.arange(len(legend) // 2)  # Number of groups\n",
    "bar_width = 0.35  # Width of each bar\n",
    "\n",
    "# Plot the bars\n",
    "plt.bar(x - bar_width / 2, average_ar_kernel_time[:2], bar_width, label='Ring', color=colors[0])\n",
    "plt.bar(x + bar_width / 2, average_ar_kernel_time[2:], bar_width, label='StragglAR', color=colors[2])\n",
    "plt.errorbar(x - bar_width / 2, average_ar_kernel_time[:2], yerr=std_ar_kernel_time[:2], fmt='none', ecolor='black', capsize=5)\n",
    "plt.errorbar(x + bar_width / 2, average_ar_kernel_time[2:], yerr=std_ar_kernel_time[2:], fmt='none', ecolor='black', capsize=5)\n",
    "# Calculate speedup between Ring and Stragglar for one batch size\n",
    "speedup = [average_ar_kernel_time[i] / average_ar_kernel_time[i+2] for i in range(2)]\n",
    "\n",
    "# Annotate the speedup on the Stragglar bars\n",
    "for i, sp in enumerate(speedup):\n",
    "    plt.text(x[i] + bar_width / 2, average_ar_kernel_time[2 + i] + std_ar_kernel_time[2 + i] + 1, \n",
    "             f\"x{sp:.2f}\", ha='center', va='bottom', fontsize=16, color='black')\n",
    "\n",
    "# Formatting\n",
    "plt.xticks(x, ['B=32', 'B=64'])\n",
    "plt.xlabel('Global Batch Size')\n",
    "plt.ylabel('Embed. AllReduce\\nTime (ms)')\n",
    "plt.legend()\n",
    "plt.grid(axis='y', linestyle='--', alpha=0.7)\n",
    "plt.savefig(\"impl_ar.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "id": "66ef594a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "log1 = '../implementation/log/log_ring_3B_b4_e2e.txt'\n",
    "log2 = '../implementation/log/log_stragglar_3B_b4_e2e.txt'\n",
    "\n",
    "def extract_ar_kernel_time(log_file):\n",
    "    eval_loss_list = []\n",
    "    eval_itr_time_list = []\n",
    "    cumulative_itr_time = 0\n",
    "\n",
    "    with open(log_file, 'r') as file:\n",
    "        lines = file.readlines()\n",
    "        for i, line in enumerate(lines):\n",
    "            # Match iteration loss and time\n",
    "            match1 = re.search(r'Rank (\\d+) \\| Step (\\d+) .*? Loss: ([\\d.]+) \\| Iteration Time: ([\\d.]+) ms', line)\n",
    "            if match1 and match1.group(1) == '0':\n",
    "                itr_time = float(match1.group(4)) / 1000  # Convert ms to seconds\n",
    "                cumulative_itr_time += itr_time\n",
    "\n",
    "            # Match evaluation loss\n",
    "            match2 = re.search(r'(\\d+\\.\\d+) \\| Avg Eval Loss: ([\\d.]+)', line)\n",
    "            if match2:\n",
    "                eval_loss = float(match2.group(2))\n",
    "                eval_loss_list.append(eval_loss)\n",
    "                eval_itr_time_list.append(cumulative_itr_time)\n",
    "\n",
    "    return (eval_loss_list, eval_itr_time_list)\n",
    "\n",
    "# Extract loss and iteration time for both logs\n",
    "loss_list1, itr_time_list1 = extract_ar_kernel_time(log1)\n",
    "loss_list2, itr_time_list2 = extract_ar_kernel_time(log2)\n",
    "\n",
    "# Plot time to loss for both logs\n",
    "plt.figure(figsize=(5, 3))\n",
    "plt.plot(itr_time_list1, loss_list1, marker='o', linestyle='-', color='dodgerblue', label='Ring')\n",
    "plt.plot(itr_time_list2, loss_list2, marker='o', linestyle='-', color='orange', label='Stragglar')\n",
    "plt.xlabel('Cumulative Iteration Time (s)')\n",
    "plt.ylabel('Loss')\n",
    "plt.ylim(min(loss_list1) - 0.05, max(loss_list1) * 0.1)\n",
    "plt.xlim(0, 310)\n",
    "# plt.title('Time to Loss Comparison')\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "env",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
