{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[nltk_data] Downloading package words to\n",
      "[nltk_data]     /Users/USERNAME/nltk_data...\n",
      "[nltk_data]   Package words is already up-to-date!\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "17 ['it']\n",
      "20 ['inception']\n",
      "28 ['big']\n",
      "29 ['soul']\n",
      "39 ['brave']\n",
      "41 ['ted']\n",
      "43 ['interstellar']\n",
      "44 ['joker']\n",
      "45 ['moonlight']\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[17, 20, 28, 29, 39, 41, 43, 44, 45]"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import json\n",
    "\n",
    "\n",
    "d = json.load(open('process.emoji_movies.json', 'r'))\n",
    "with open(\"process.emoji_movies.jsonl\", 'w') as fout:\n",
    "    for e in d['examples']:\n",
    "        string = json.dumps(e)\n",
    "        fout.write(string+\"\\n\")\n",
    "\n",
    "\n",
    "all_test = []\n",
    "with open(\"process.emoji_movies_test.jsonl\", 'r') as f:\n",
    "    for e in f.readlines():\n",
    "        string = json.loads(e.strip()) \n",
    "        all_test.append(string)\n",
    "\n",
    "from nltk.corpus import words\n",
    "import nltk\n",
    "nltk.download('words')\n",
    "\n",
    "drop_ids = []\n",
    "for id, item in enumerate(all_test):\n",
    "    if len(item['target'].split(\" \")) == 1 and item['target'] in words.words():\n",
    "        print(id, item['target'].split(\" \"))\n",
    "        drop_ids.append(id)\n",
    "drop_ids"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import json\n",
    "\n",
    "mpl.rcParams.update(mpl.rcParamsDefault)\n",
    "\n",
    "\n",
    "plt.rcParams['font.family'] = 'serif'\n",
    "plt.rcParams['font.serif'] = ['Times New Roman'] + plt.rcParams['font.serif']\n",
    "plt.rcParams.update({'text.usetex': True\n",
    "                     })\n",
    "import os\n",
    "os.environ[\"PATH\"] += os.pathsep + '/usr/local/texlive/2023/bin/universal-darwin/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "params_num_all = np.array([0.036, 0.109, 0.241, 0.499, 0.892, 1.54, 2.45])\n",
    "params_num = params_num_all\n",
    "flop = np.array([6 * p * p * 20 for p in params_num])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Index(['0.03b', '0.1b', '0.2b', '0.5b', '0.9b', '1.5b', '2.4b', 'Unnamed: 7',\n",
      "       '1.5b 新'],\n",
      "      dtype='object')\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>0.03b</th>\n",
       "      <th>0.1b</th>\n",
       "      <th>0.2b</th>\n",
       "      <th>0.5b</th>\n",
       "      <th>0.9b</th>\n",
       "      <th>1.5b</th>\n",
       "      <th>2.4b</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000026</td>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.002500</td>\n",
       "      <td>0.001875</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000027</td>\n",
       "      <td>0.000417</td>\n",
       "      <td>0.001875</td>\n",
       "      <td>0.000625</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000208</td>\n",
       "      <td>0.000268</td>\n",
       "      <td>0.000937</td>\n",
       "      <td>0.000469</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.000250</td>\n",
       "      <td>0.000313</td>\n",
       "      <td>0.001250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000045</td>\n",
       "      <td>0.000035</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000050</td>\n",
       "      <td>0.000021</td>\n",
       "      <td>0.000313</td>\n",
       "      <td>0.000250</td>\n",
       "      <td>0.005625</td>\n",
       "      <td>0.000937</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>0.000023</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.000313</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.003125</td>\n",
       "      <td>0.002500</td>\n",
       "      <td>0.000625</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000417</td>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.001875</td>\n",
       "      <td>0.005625</td>\n",
       "      <td>0.003750</td>\n",
       "      <td>0.004375</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000027</td>\n",
       "      <td>0.000046</td>\n",
       "      <td>0.000139</td>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.000937</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000139</td>\n",
       "      <td>0.000069</td>\n",
       "      <td>0.000033</td>\n",
       "      <td>0.000134</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000083</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000022</td>\n",
       "      <td>0.000010</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000060</td>\n",
       "      <td>0.000417</td>\n",
       "      <td>0.000179</td>\n",
       "      <td>0.000375</td>\n",
       "      <td>0.000125</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000208</td>\n",
       "      <td>0.000250</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.005625</td>\n",
       "      <td>0.018125</td>\n",
       "      <td>0.045625</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>0.000060</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000313</td>\n",
       "      <td>0.000937</td>\n",
       "      <td>0.000625</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000057</td>\n",
       "      <td>0.000250</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.006250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000023</td>\n",
       "      <td>0.000032</td>\n",
       "      <td>0.000156</td>\n",
       "      <td>0.000156</td>\n",
       "      <td>0.000313</td>\n",
       "      <td>0.000179</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>0.700625</td>\n",
       "      <td>0.568125</td>\n",
       "      <td>0.708750</td>\n",
       "      <td>0.564375</td>\n",
       "      <td>0.668125</td>\n",
       "      <td>0.588750</td>\n",
       "      <td>0.596250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000083</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.003125</td>\n",
       "      <td>0.005000</td>\n",
       "      <td>0.008750</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000024</td>\n",
       "      <td>0.000010</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>0.000032</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000114</td>\n",
       "      <td>0.000313</td>\n",
       "      <td>0.000417</td>\n",
       "      <td>0.002500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>0.000179</td>\n",
       "      <td>0.000234</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.000125</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.000937</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000179</td>\n",
       "      <td>0.000417</td>\n",
       "      <td>0.000208</td>\n",
       "      <td>0.000417</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000083</td>\n",
       "      <td>0.000036</td>\n",
       "      <td>0.000313</td>\n",
       "      <td>0.000417</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000208</td>\n",
       "      <td>0.000139</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000114</td>\n",
       "      <td>0.000156</td>\n",
       "      <td>0.000625</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.000625</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.000250</td>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.001875</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.001563</td>\n",
       "      <td>0.001250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>0.035625</td>\n",
       "      <td>0.049375</td>\n",
       "      <td>0.015000</td>\n",
       "      <td>0.028125</td>\n",
       "      <td>0.038750</td>\n",
       "      <td>0.019375</td>\n",
       "      <td>0.035000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>0.013125</td>\n",
       "      <td>0.005625</td>\n",
       "      <td>0.003750</td>\n",
       "      <td>0.002500</td>\n",
       "      <td>0.003750</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.001250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000156</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000250</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.000417</td>\n",
       "      <td>0.001250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>0.000032</td>\n",
       "      <td>0.000156</td>\n",
       "      <td>0.000075</td>\n",
       "      <td>0.000114</td>\n",
       "      <td>0.000313</td>\n",
       "      <td>0.000417</td>\n",
       "      <td>0.001250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000139</td>\n",
       "      <td>0.000937</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000096</td>\n",
       "      <td>0.000313</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.005000</td>\n",
       "      <td>0.015000</td>\n",
       "      <td>0.005625</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>0.000054</td>\n",
       "      <td>0.000042</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000034</td>\n",
       "      <td>0.000156</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.001250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000125</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.000313</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.000937</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000021</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.000250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39</th>\n",
       "      <td>0.001875</td>\n",
       "      <td>0.010000</td>\n",
       "      <td>0.040000</td>\n",
       "      <td>0.015000</td>\n",
       "      <td>0.007500</td>\n",
       "      <td>0.040000</td>\n",
       "      <td>0.015625</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000139</td>\n",
       "      <td>0.000042</td>\n",
       "      <td>0.000208</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>0.138125</td>\n",
       "      <td>0.101250</td>\n",
       "      <td>0.115000</td>\n",
       "      <td>0.196875</td>\n",
       "      <td>0.182500</td>\n",
       "      <td>0.155000</td>\n",
       "      <td>0.191250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42</th>\n",
       "      <td>0.000089</td>\n",
       "      <td>0.000375</td>\n",
       "      <td>0.003125</td>\n",
       "      <td>0.008125</td>\n",
       "      <td>0.002500</td>\n",
       "      <td>0.004375</td>\n",
       "      <td>0.005625</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000179</td>\n",
       "      <td>0.000375</td>\n",
       "      <td>0.000375</td>\n",
       "      <td>0.000469</td>\n",
       "      <td>0.001250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>44</th>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.000417</td>\n",
       "      <td>0.001875</td>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.000937</td>\n",
       "      <td>0.002500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.001563</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.001042</td>\n",
       "      <td>0.000208</td>\n",
       "      <td>0.000937</td>\n",
       "      <td>0.001250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>0.000139</td>\n",
       "      <td>0.000050</td>\n",
       "      <td>0.000179</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.002500</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.005625</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47</th>\n",
       "      <td>0.000078</td>\n",
       "      <td>0.000313</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.001875</td>\n",
       "      <td>0.001250</td>\n",
       "      <td>0.001875</td>\n",
       "      <td>0.004375</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000096</td>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.001563</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000038</td>\n",
       "      <td>0.000313</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       0.03b      0.1b      0.2b      0.5b      0.9b      1.5b      2.4b\n",
       "0   0.000000  0.000000  0.000000  0.000026  0.000625  0.002500  0.001875\n",
       "1   0.000000  0.000000  0.000000  0.000027  0.000417  0.001875  0.000625\n",
       "2   0.000000  0.000010  0.000010  0.000208  0.000268  0.000937  0.000469\n",
       "3   0.000000  0.000000  0.000000  0.000625  0.000250  0.000313  0.001250\n",
       "4   0.000000  0.000000  0.000000  0.000000  0.000000  0.000045  0.000035\n",
       "5   0.000000  0.000050  0.000021  0.000313  0.000250  0.005625  0.000937\n",
       "6   0.000023  0.001250  0.000313  0.001250  0.003125  0.002500  0.000625\n",
       "7   0.000000  0.000417  0.000625  0.001875  0.005625  0.003750  0.004375\n",
       "8   0.000000  0.000000  0.000027  0.000046  0.000139  0.000625  0.000937\n",
       "9   0.000000  0.000010  0.000010  0.000139  0.000069  0.000033  0.000134\n",
       "10  0.000000  0.000083  0.000010  0.000000  0.000010  0.000022  0.000010\n",
       "11  0.000000  0.000010  0.000060  0.000417  0.000179  0.000375  0.000125\n",
       "12  0.000010  0.000208  0.000250  0.001250  0.005625  0.018125  0.045625\n",
       "13  0.000060  0.000000  0.000000  0.000010  0.000313  0.000937  0.000625\n",
       "14  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000\n",
       "15  0.000000  0.000000  0.000057  0.000250  0.001250  0.001250  0.006250\n",
       "16  0.000000  0.000023  0.000032  0.000156  0.000156  0.000313  0.000179\n",
       "17  0.700625  0.568125  0.708750  0.564375  0.668125  0.588750  0.596250\n",
       "18  0.000000  0.000000  0.000083  0.001250  0.003125  0.005000  0.008750\n",
       "19  0.000000  0.000000  0.000000  0.000000  0.000000  0.000024  0.000010\n",
       "20  0.000032  0.000010  0.000010  0.000114  0.000313  0.000417  0.002500\n",
       "21  0.000179  0.000234  0.001250  0.000125  0.001250  0.001250  0.000937\n",
       "22  0.000000  0.000000  0.000000  0.000179  0.000417  0.000208  0.000417\n",
       "23  0.000000  0.000010  0.000000  0.000083  0.000036  0.000313  0.000417\n",
       "24  0.000000  0.000000  0.000000  0.000000  0.000000  0.000208  0.000139\n",
       "25  0.000000  0.000000  0.000000  0.000000  0.000114  0.000156  0.000625\n",
       "26  0.000000  0.000000  0.000010  0.000010  0.000010  0.000625  0.000625\n",
       "27  0.000625  0.000250  0.000625  0.001875  0.001250  0.001563  0.001250\n",
       "28  0.035625  0.049375  0.015000  0.028125  0.038750  0.019375  0.035000\n",
       "29  0.013125  0.005625  0.003750  0.002500  0.003750  0.001250  0.001250\n",
       "30  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000156\n",
       "31  0.000000  0.000000  0.000000  0.000250  0.001250  0.000417  0.001250\n",
       "32  0.000032  0.000156  0.000075  0.000114  0.000313  0.000417  0.001250\n",
       "33  0.000000  0.000000  0.000000  0.000010  0.000000  0.000139  0.000937\n",
       "34  0.000000  0.000096  0.000313  0.001250  0.005000  0.015000  0.005625\n",
       "35  0.000054  0.000042  0.000010  0.000034  0.000156  0.001250  0.001250\n",
       "36  0.000000  0.000010  0.000000  0.000000  0.000125  0.001250  0.000313\n",
       "37  0.000000  0.000000  0.000000  0.000000  0.000625  0.000625  0.000937\n",
       "38  0.000000  0.000000  0.000000  0.000021  0.001250  0.000625  0.000250\n",
       "39  0.001875  0.010000  0.040000  0.015000  0.007500  0.040000  0.015625\n",
       "40  0.000000  0.000000  0.000000  0.000000  0.000139  0.000042  0.000208\n",
       "41  0.138125  0.101250  0.115000  0.196875  0.182500  0.155000  0.191250\n",
       "42  0.000089  0.000375  0.003125  0.008125  0.002500  0.004375  0.005625\n",
       "43  0.000000  0.000000  0.000179  0.000375  0.000375  0.000469  0.001250\n",
       "44  0.000625  0.000625  0.000417  0.001875  0.000625  0.000937  0.002500\n",
       "45  0.000625  0.001563  0.001250  0.001042  0.000208  0.000937  0.001250\n",
       "46  0.000139  0.000050  0.000179  0.001250  0.002500  0.001250  0.005625\n",
       "47  0.000078  0.000313  0.001250  0.001875  0.001250  0.001875  0.004375\n",
       "48  0.000000  0.000000  0.000000  0.000000  0.000096  0.000625  0.001563\n",
       "49  0.000000  0.000000  0.000000  0.000000  0.000010  0.000038  0.000313"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "df = pd.read_excel(\"0908result.xlsx\", sheet_name=\"emoji_pass_until\")\n",
    "print(df.columns)\n",
    "df.drop(columns=\"Unnamed: 7\", inplace=True)\n",
    "df.drop(columns='1.5b', inplace=True)\n",
    "df.rename(columns={'1.5b 新': '1.5b'}, inplace=True)\n",
    "\n",
    "new_order = ['0.03b', '0.1b', '0.2b', '0.5b', '0.9b', '1.5b', '2.4b']\n",
    "df = df[new_order]\n",
    "df\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Hoslic View"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## partview"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Fit Genral\n",
    "\n",
    "Take all individual as all "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.03b    0.000031\n",
      "0.1b     0.000088\n",
      "0.2b     0.000203\n",
      "0.5b     0.000562\n",
      "0.9b     0.000969\n",
      "1.5b     0.001866\n",
      "2.4b     0.002608\n",
      "dtype: float64\n"
     ]
    }
   ],
   "source": [
    "df.drop(drop_ids, inplace=True)\n",
    "mean_values = df.mean()\n",
    "print(mean_values)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [],
   "source": [
    "# from scipy.optimize import curve_fit\n",
    "# import matplotlib.pyplot as plt\n",
    "# mean_values = df.mean()\n",
    "\n",
    "\n",
    "# x_data= np.log(params_num[:-1])\n",
    "# y_data=np.log(-np.log(mean_values.values[:-1]))\n",
    "# # 定义线性函数\n",
    "# def linear_function(x, a, b):\n",
    "#     return a * x + b\n",
    "\n",
    "# # 使用curve_fit进行拟合\n",
    "# params, covariance = curve_fit(linear_function, x_data, y_data)\n",
    "\n",
    "# # 提取拟合参数\n",
    "# a, b = params\n",
    "\n",
    "# # 打印拟合参数\n",
    "# print(f'a = {a}, b = {b}')\n",
    "\n",
    "# # 使用拟合参数生成拟合线\n",
    "# x_fit = np.linspace(min(x_data), max(x_data)+1, 100)\n",
    "# y_fit = linear_function(x_fit, a, b)\n",
    "\n",
    "# # Plotting the mean values\n",
    "# fig, axs = plt.subplots(1,2,figsize=(15, 6))\n",
    "\n",
    "\n",
    "# colorlist = ['#FA7F6F', '#82B0D2',  '#8ECFC9', '#FFBE7A', '#BEB8DC', '#999999']\n",
    "\n",
    "# axs[0].plot(x_data, y_data, marker='o', linestyle='-', color='#415E5C', label='Mean Values')\n",
    "# axs[0].plot(x_fit, y_fit, label=f'Fit: a={a:.2f}, b={b:.2f}', linestyle='--', color='#78AFAA')\n",
    "\n",
    "# # new data\n",
    "# x_new = np.log(params_num[-1:])\n",
    "# y_new = np.log(-np.log(mean_values.values[-1:]))\n",
    "\n",
    "# axs[0].scatter(x_new, y_new, color=colorlist[0])\n",
    "\n",
    "\n",
    "\n",
    "# axs[0].set_ylabel('Negative Log PassUntil')\n",
    "# # plt.title('Mean PassUntil vs Model Size')\n",
    "# axs[0].grid(True, linestyle='--', linewidth=0.5, color='gray')\n",
    "\n",
    "# axs[0].set_xticks(np.log(np.array([0.0625, 0.125, 0.25, 0.5, 1, 2, 4])))\n",
    "# axs[0].set_xticklabels([\"{}\".format(x) for x in [0.0625, 0.125, 0.25, 0.5, 1, 2, 4]])\n",
    "\n",
    "# plt.legend()\n",
    "\n",
    "# axs[1].set_ylabel('PassUntil')\n",
    "\n",
    "# axs[1].plot(x_data, np.exp(-np.exp(y_data)), marker='o', linestyle='-', color='#415E5C', label='Mean Values')\n",
    "# axs[1].plot(x_fit, np.exp(-np.exp(y_fit)), label=f'Fit: a={a:.2f}, b={b:.2f}', linestyle='--', color='#78AFAA')\n",
    "# axs[1].scatter(x_new, np.exp(-np.exp(y_new)), color=colorlist[0])\n",
    "# axs[1].text(0.5, 0.05, \"$e^{-1.26 N^{-0.29}}$\", fontsize=18, ha='right')\n",
    "# axs[1].set_xticks(np.log(np.array([0.0625, 0.125, 0.25, 0.5, 1, 2, 4])))\n",
    "# axs[1].set_xticklabels([\"{}\".format(x) for x in [0.0625, 0.125, 0.25, 0.5, 1, 2, 4]])\n",
    "# axs[1].grid(True, linestyle='--', linewidth=0.5, color='gray')\n",
    "\n",
    "# # axs[1].plot(x_fit, np.exp(-np.exp(y_fit)), label=f'Fit: a={a:.2f}, b={b:.2f}', linestyle='--', color=colorlist[2])\n",
    "\n",
    "\n",
    "# plt.xlabel('Model Size (B)')\n",
    "\n",
    "\n",
    "# plt.savefig(\"passrate_vs_modelsize.pdf\",bbox_inches='tight', pad_inches=0)\n",
    "# plt.show()\n",
    "\n",
    "# np.exp(-np.exp(linear_function(np.log(2.45), a, b)))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## seperate each individual"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[1.98550832 0.50551039]\n",
      "[2.02295965 0.45798951]\n",
      "[2.05294439 0.20164551]\n",
      "[ 2.07761811 -0.08097396]\n",
      "[1.92145229 0.22701734]\n",
      "[1.79395894 0.14093202]\n",
      "[1.72613978 0.15487776]\n",
      "[2.1243987 0.187796 ]\n",
      "[2.27986848 0.06632797]\n",
      "[ 2.41267448 -0.04455292]\n",
      "[2.08781647 0.13763857]\n",
      "[1.61629149 0.26328691]\n",
      "[2.12444654 0.06799522]\n",
      "[1.94847902 0.22277596]\n",
      "[2.13845218 0.1100081 ]\n",
      "[1.75097021 0.30857602]\n",
      "[1.9529161  0.06215873]\n",
      "[2.11262332 0.01770949]\n",
      "[2.20208424 0.1119161 ]\n",
      "[2.2394635  0.20720852]\n",
      "[1.88557902 0.05474577]\n",
      "[2.01491764 0.05974803]\n",
      "[2.10411136 0.06544799]\n",
      "[1.62343148 0.29820505]\n",
      "[2.13975545 0.08218854]\n",
      "[2.06524048 0.18118245]\n",
      "[2.04861416 0.34017965]\n",
      "[1.66473319 0.15199729]\n",
      "[1.89056784 0.11969957]\n",
      "[1.83524887 0.10865077]\n"
     ]
    }
   ],
   "source": [
    "from scipy.optimize import curve_fit\n",
    "\n",
    "# Define the function to fit\n",
    "def func(logN, logC, alpha):\n",
    "    return logC - alpha *logN\n",
    "\n",
    "\n",
    "model_sizes = params_num[:-1]\n",
    "fit_params_df = pd.DataFrame(columns=['logC', 'alpha'])\n",
    "for i, row in df.iterrows():\n",
    "    y_data = row.values[:-1]\n",
    "    x_data_clean = np.log(np.array(model_sizes)[~(y_data<=1e-10)])\n",
    "    y_data_clean = np.log(- np.log(y_data[~(y_data<=1e-10)]))\n",
    "    # print(y_data_clean, x_data_clean)\n",
    "    if len(y_data_clean) > 2:  # At least two points are required for fitting\n",
    "        params, covariance = curve_fit(func, x_data_clean, y_data_clean, p0=[1, 1])\n",
    "        print(params)\n",
    "        fit_params_df.loc[i] = params\n",
    "    else:\n",
    "        fit_params_df.loc[i] = [np.nan, np.nan]\n",
    "    # print(params)\n",
    "    # if i > 3:\n",
    "    #     break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "41"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(fit_params_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/USERNAME/Library/Python/3.9/lib/python/site-packages/pandas/core/arraylike.py:396: RuntimeWarning: divide by zero encountered in log\n",
      "  result = getattr(ufunc, method)(*inputs, **kwargs)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.08, 0.5, 'PassUntil')"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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B7TyV0TJiUhZHE95l8lkSE9Ph5ubGy688ELbLdbsITMzE7/97W8RHh6OZ555RvpG9kCk/hPlvYynvNuQbM6AYAx3WoXVamX3338/A8AuvfRSVlZWNqz9Hzt2jJ1zzjlMLpez119/nRkMBimaPSjkcC2HlFPhevLaa68xuVzOpk2bxrKysobVltLSUnbJJZcwAOwf//hHv7eNkhoR+pAc9iHldOduPvvsM+bh4cHi4uKGveZKfX09u/766xkAtmrVKtbe3j6s140GUfpQFIczPI7I+5EjR1hgYCALDg5mu3btGtYlh21tbWz9+vVMJpOxBQsWsKampuG+hREjSk5EyaIzHI44pikuLmZxcXHM29ubvfzyy8O6XNdkMrHNmzczlUrF0tLSWEVFxbDfw0gRof+c6RHBQdP7OUQmk+H//u//8OmnnyIrKwsJCQlYvnw59u3b12eKXF1dHT766CNcccUVmDp1Kjo7O/Hjjz9i1apVOH78uMPbSg7XcziCP/3pTzh06BDa2tpw1lln4YorrsBHH32Eurq6XtvpdDrs27cP119/PRISEpCXl4c9e/bgwQcfREFBgcPbKUofkmNsWbhwIX755ReEhITgggsuwLx587Bz505UVlb2mt3V1taGgwcPYs2aNYiKisJnn32G//znP3jttddQVFTk8HaK0oeiOJzpkZJp06bh2LFjmDFjBv7whz9g2rRpePXVV1FcXNwr7waDAUeOHMFdd92FyMhIvPzyy3j88cfxySefjGq69HARJSciZXE85j0mJgYZGRlYunQp1qxZg6SkJDz99NPIz8+H1Wq1bWc2m5GVlYWHH34YMTExuO+++3D77bfj+++/R1NTk8PbKVL/ifJexmPelWPdAFFYtGgRcnNz8dprr2HLli3Yvn07ACAyMhIeHh5oaWlBdXU1ACAtLQ2vvPIKli9f7tBrmgnCUcyYMQO//PILtm3bhpdeegmLFy8GAISFhcHHxwcdHR22A7/4+Hg8+uij+NOf/gStVjuGrSaIkTFp0iQcOHAA7733HrZs2YLrr78eABAUFAQ/Pz8YjUaUl5fDarUiPDwcGzduxF/+8heHXsNPEI4iLCwMH330Efbu3YsXX3wRN998Mxhj8PX1RVBQECwWCyoqKmAymeDn54eVK1di7dq1iI2NHeumE4TdaLVavPrqq1i1ahWef/55/O1v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q6vZ3r172f33388iIyMZALZkyRJWW1vLGGOsqanJge+GkcMFHfZk2N68nzp1il199dUMAJs4cSJ74IEH2N69e1l1dTVra2tjdXV17JtvvmGPPvooS05OZgDYvHnzWHFxMWNMjPqSgz/HcHNsb95bWlrYLbfcwgCwwMBAdscdd7CPP/6YVVRUsNbWVtbY2MgOHTrEnnnmGfab3/yGAWBTp05lv/zyC2NMnPqSgy+PlHm3WCxs3bp1DAD785//POx/Gz35+eef2VlnncU8PT3Zvn377H69PYiSE1Gy6AyH1Mc06enpTC6Xs7lz57KioiK725OZmcnS0tKYu7s7++9//2v36+1BhP5zpkcEh73HKcOBBv0DYE+x33//febp6cmio6PZnj17mNVqHXR7k8nEtm3bxgICAlhgYCD7/vvvWXV1tVRNHxByuJbDUYP+gwcPssDAQBYYGMjeeustZjabB93earWyzz77jEVFRTEvLy+2a9cuIepLDv4cjhj05+XlsZiYGObp6cmeffZZ1tnZOeRrfvjhB3bWWWcxpVLJnn/+eWHqSw6+PFLmfcOGDUwmk7FXXnllVG1qa2tjCxcuZB4eHuy7774b1b4GQ5SciJJFZzikPKbZsWMHk8lk7M9//vOQxzCD0dnZya688krm5ubGvvjiixHvZyhE6D9nekRwOGLQT9f0j5L3338f11xzDa644gpkZWVhwYIFQ05hViqVWL58OXJycpCSkoJLLrkEX375pcPb2t90VHKI7ZCaQ4cOYf78+Zg8eTJycnKwbNmyIacwy2QyLFy4EFlZWVi0aBGuvvpq7Nixw+FtFaUPyTF2FBQUYO7cufD09MSxY8dw2223Qa1WD/m68847D4cPH8a6detw66234qmnnnJ4W0XpQ1EczvSMlo8++ghPPfUUnn32Wdx0002j2penpyd27dqF6dOn47rrruv3si8pECUnImVxvOS9sLAQf/rTn7Bs2TJs2bJlVJdhqdVqvP3227joootw/fXX91n8TypE6j9R3st4yXtPaNA/Co4fP44bbrgB1157LbZv3w5vb2+7Xh8SEoI9e/Zg2rRp2LBhAxobGx3UUoIYPfX19bjyyisxffp07NmzB8HBwXa93sfHBzt37sSSJUtw7733orCw0EEtJYjRYzAY8Ic//AH+/v7Yv38/4uLi7Hq9SqXCU089hbvu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VDy8OMSGin6JYLfbyUGOMQMv7UsOaTmkCi/tSw5peqQGL+eQF0ekPJR3ckjFw4tDbBQjvQO8YrVaUVJSgoqKCthsNmg0GkycOBGFhYVQKPo3eySGH5Fj7DkihcPhQGlpKY4ePQqLxQKVSoW8vDxMnToVarW63/q8tC85pOWIFGazGfv27UNpaSnMZjMUCgUyMzNxyimnIDU1td/6vLQvOaTpCTd2ux0HDhxASUkJurq6IJfLkZKSgpNPPhnZ2dkQBMFnfV7OIS+OSHl4yTsA1NXVYe/evTAYDBAEAQkJCZgxYwaSkpL6rctL21IWpecQGyr6RaSrqwtvvfUWXn31Vfz0009+PwXSarWYM2cObr31Vlx66aVQqVQAgOTk5LDvHznGniOc2Gw2bNq0CX//+9/x3XffwWw291tHqVTilFNOwU033YRrrrkG0dHRAPhpX3JIyxFOLBYL3nnnHfztb3/Djh074HQ6AQAKhQIOh8O7Xk5ODq6//nrceuut3vv48tK+5JCmJxw4nU589NFHePHFF/Hll1/CarUCcOfd6XTCMx1USkoKrrzyStx+++0oLCwEwM855MURKc9ozjsA7N27Fy+88AL+85//oL6+3u86OTk5uOyyy7BixQoUFBQA4KdtKYvSc4gNDe8XAafTiaeeegqZmZm4/fbbkZKSgmeeeQY7duxAa2srurq60NTUhK1bt+KRRx6B0+nEVVddhdzcXLz55ptgjOHYsWNh309yjD1HOGCM4Y033kBOTg6uvvpquFwuPPLII9i6dSuamprQ1dWF1tZW7NixA8888wySkpJw2223ITMzE8888wycTic37UsOaTnCAWMMb775preYV6vVWLduHX744QeYzWbY7Xa4XC4cP34c//rXv3DBBRfgueeew7hx43DLLbfAYDBw077kkKZHbD777DNMnDgRl1xyCdra2vCnP/0JX3/9NTo7O2G32+F0OlFTU4P3338fy5Ytw8aNG1FUVIRLL70U9fX13JxDXhyR8ozWvJeVleHss8/GSSedhA8//BDXX3893n33XRw/fhydnZ0wGo04cuQINmzYgCVLluCf//wnJk2ahKVLl6Kuro6btqUsSs8hOozwi8FgYACYwWAYdL1jx46x008/nQmCwO644w5WUVER0Pb379/PrrzySgaAXXLJJWzbtm1i7Pag7Nu3jxxjyBFohoNZt6mpiV100UUMALvqqqvYgQMHAtqX8vJytnLlSiYIAps7dy77+OOPA3recODhHJIjOALNcaDrtba2sksuuYQBYFdccQUrLS0NaD+MRiN75plnWExMDMvKymKvvPJKwMcQKrycQ14ckfCInXez2cxuvfVWBoAtXLiQ/fjjjwHth8ViYa+//jpLSUlh8fHx7Iknngj4GEKFl5zwksVIOMR+T+Nyudi6deuYVqtl48ePZ//+97+ZzWYbcttms5mtX7+epaWlsbi4OPanP/0pqOMIBR7OXyQ9PDiCyXugUNE/AIE0dklJCUtNTWUTJkxgX3/9dUieTZs2saSkJFZQUMBqa2tD3d2AaG9vD+v2ySEth9j/IGtqatikSZNYcnIy27x5c0j79NVXX7Hx48ez1NTUgD8wCBUeziE5gkPMIqixsZFNnTqVJSQksHfeeSek/amoqGALFixgKpWKvffeeyFtI1B4OYe8OCLhETPv3d3d7Oyzz2YajYa98MILzOl0Br0/LS0t7IorrmAA2F//+tegnx8MvOSElyxGwiHmexqXy8V+/etfMwDsjjvuYF1dXUHvT2trK7vmmmsYAPb4448H/fxg4OH8RdLDgyMcRT9d0x8ilZWVOPfcc5GWloYtW7aEfG3HpZdeiuLiYpx11lk477zz8M0330Cv14u8t24sFktYtksO6TrEoqOjA+eeey5MJhO+/fZb5Ofnh7SdefPmYceOHTj33HNxzjnn4LvvvvNe9yw2vJxDckQek8mERYsWoampCV9//TWKiopC2k5ubi4+/fRTXHfddbj88svx6aefYuHChSLvrRteziEvjkh6hovL5cLll1+O7777Dp9++inOPPPMkLaTmJiIjRs3IisrC3fccQf0ej2uu+46kffWDS854SmLoyXvALB69Wo888wz+Otf/4qVK1eGtI2EhAS88cYbGD9+PH77298iNjYWK1asEHlP3fB0/ng5ltGUdw90TX8IuFwu3HjjjVCpVPjss8+GPZnDxIkTsWXLFlRWVmLVqlUi7WV/mpubw7ZtckjTIRb33HMPampqsGXLlpALfg8pKSn47LPPoFAo8Itf/MI7IZTY8HIOyRF57r//fpSWluLTTz8NueD3oFKp8MYbb2Du3LlYtmwZDAaDSHvpCy/nkBdHJD3DZd26dfj444/xzjvvhFzwexAEAU8++SSu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",
      "text/plain": [
       "<Figure size 1200x600 with 15 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from functools import partial\n",
    "func_pool = []\n",
    "func_pool_id_rec = []\n",
    "\n",
    "n_rows = 3\n",
    "n_columns = 5\n",
    "\n",
    "fig, ax = plt.subplots(n_rows,n_columns,figsize=(12, 6), sharex=True, sharey=True)\n",
    "\n",
    "count = 0\n",
    "for i, row in fit_params_df.iterrows():\n",
    "    logC, alpha = row.values\n",
    "    \n",
    "    if not np.isnan(logC):\n",
    "        func_pool.append(partial(func, logC=logC, alpha=alpha))\n",
    "        func_pool_id_rec.append(i)\n",
    "        if alpha > 0.0 and count < n_rows * n_columns:\n",
    "            ax_row_id = count // n_columns\n",
    "            ax_column_id = count % n_columns\n",
    "            x_data = np.arange(np.log(0.03), np.log(2.5), 0.1)\n",
    "            # y_data = np.exp(-np.exp(np.array([func(logn, logC, alpha) for logn in x_data])))\n",
    "            y_data = np.array([func(logn, logC, alpha) for logn in x_data])\n",
    "\n",
    "            ax[ax_row_id, ax_column_id].plot(x_data, y_data, linestyle='-', label=str(i), color=colorlist[count%len(colorlist)])\n",
    "            # ax.scatter(np.log(2.45), df.iloc[i, -1], color=colorlist[count%len(colorlist)])\n",
    "            \n",
    "\n",
    "            ax[ax_row_id, ax_column_id].scatter(np.log(params_num[:-1]), np.log(-np.log(df.iloc[i, :-1])), s=10, color=colorlist[count%len(colorlist)])\n",
    "            ax[ax_row_id, ax_column_id].scatter(np.log(params_num[-1]), np.log(-np.log(df.iloc[i, -1])), marker='*', s=40, color=colorlist[count%len(colorlist)])\n",
    "\n",
    "            ax[ax_row_id, ax_column_id].set_xticks(np.log([0.05, 0.1, 0.2, 0.4, 0.8, 1.6, 3.2]))\n",
    "            ax[ax_row_id, ax_column_id].set_xticklabels([0.05, 0.1, 0.2, 0.4, 0.8, 1.6, 3.2])\n",
    "\n",
    "            ax[ax_row_id, ax_column_id].set_yticks([np.log(-np.log(x)) for x in [1e-4,1e-2,2e-1, 6e-1, 9e-1]])\n",
    "            ax[ax_row_id, ax_column_id].set_yticklabels(['1e-4','1e-2','2e-1','6e-1', '9e-1'])\n",
    "            ax[ax_row_id, ax_column_id].set_ylim(*[np.log(-np.log(x)) for x in [3e-6, 9.7e-1]])\n",
    "\n",
    "            ax[ax_row_id, ax_column_id].text(x=np.log(0.04), y=np.log(-np.log(0.9)) , s=f\"{i}\", ha='center', va='center', bbox=dict(facecolor='white', edgecolor='black', boxstyle='circle'))       \n",
    "\n",
    "\n",
    "            # ax.set_xlabel('Model Size')\n",
    "            # ax.set_ylabel('Mean of Negative Logarithm of Values')\n",
    "            # ax.set_title('Mean of Negative Logarithm vs Model Size')\n",
    "            ax[ax_row_id, ax_column_id].grid(True, linestyle='--', linewidth=0.5, color='gray', alpha=0.5)\n",
    "            ax[ax_row_id, ax_column_id].tick_params(axis='y', direction='in', length=1.5)\n",
    "            ax[ax_row_id, ax_column_id].tick_params(axis='x', direction='in', length=1.5)\n",
    "\n",
    "            # plt.legend()\n",
    "            count += 1\n",
    "    else:\n",
    "        pass\n",
    "\n",
    "for j in range(ax_column_id+1, n_columns):\n",
    "    ax[-1, j].axis('off') \n",
    "\n",
    "# axes[-1, -1].axis('off') \n",
    "plt.subplots_adjust(wspace=0.06, hspace=0.1)\n",
    "\n",
    "for ax in axs.flat:\n",
    "    ax.label_outer()\n",
    "\n",
    "fig.text(0.5, 0.05, 'Model Size (B)', ha='center', va='center')\n",
    "fig.text(0.08, 0.5, 'PassUntil', ha='center', va='center', rotation='vertical')\n",
    "\n",
    "# ax.text(0.5, 0.05, \"$e^{-1.26 N^{-0.29}}$\", fontsize=18, ha='right')\n",
    "# ax.set_xticks(np.log(np.array([0.0625, 0.125, 0.25, 0.5, 1, 2, 4])))\n",
    "# ax.set_xticklabels([\"{}\".format(x) for x in [0.0625, 0.125, 0.25, 0.5, 1, 2, 4]])\n",
    "# plt.savefig(\"individual_passrate_vs_modelsize_part_main.pdf\",bbox_inches='tight', pad_inches=0)\n",
    "\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Add LossFit to pass until\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "np.set_printoptions(suppress=True, precision=3)\n",
    "sizelist = [0.03, 0.1, 0.2, 0.5, 0.9, 1.5, 2.4]\n",
    "\n",
    "def lookinto(lookinto_id):\n",
    "    all_tokens_loss = []\n",
    "    all_tokens_loss_sum = []\n",
    "    all_tokens_loss_mean = []\n",
    "\n",
    "    first_non_zero = -1\n",
    "    for size in sizelist:\n",
    "        res_list = [json.loads(line.strip()) for line in open(f\"./res_dict_{size}b.jsonl\")]\n",
    "        loss = res_list[lookinto_id]['tokens_loss']\n",
    "        # print(loss)\n",
    "        if first_non_zero < 0:\n",
    "            for i, l in enumerate(loss):\n",
    "                if l > 0.0:\n",
    "                    first_non_zero = i\n",
    "                    break\n",
    "        # loss = loss[first_non_zero-1:]\n",
    "        all_tokens_loss.append(np.array(loss).reshape(1, -1))\n",
    "        all_tokens_loss_sum.append((np.array(loss)**1).sum())\n",
    "        all_tokens_loss_mean.append((np.array(loss)**1).mean())\n",
    "\n",
    "\n",
    "    all_tokens_loss = np.concatenate(all_tokens_loss, axis=0)\n",
    "    # print(all_tokens_loss)\n",
    "    # print(all_tokens_loss_sum)\n",
    "\n",
    "\n",
    "    # res = res_list[lookinto_id]\n",
    "    # print(res)\n",
    "\n",
    "    # print(list(df.iloc[lookinto_id]))\n",
    "\n",
    "    return all_tokens_loss_sum, all_tokens_loss_mean, list(df.iloc[lookinto_id])\n",
    "\n",
    "\n",
    "sumlosses, passuntils =[], []\n",
    "meanlosses = []\n",
    "\n",
    "for i in range(0, 41):\n",
    "    # print(\"=====\" + str(i) + \"=====\")\n",
    "    sumloss, meanloss, passuntil = lookinto(i)\n",
    "    sumlosses.append(sumloss)\n",
    "    meanlosses.append(meanloss)\n",
    "    passuntils.append(passuntil)\n",
    "    # a = list(zip(loss, passuntil))\n",
    "    # all_align.append(a)\n",
    "    # print(all_align)\n",
    "sumlosses = np.array(sumlosses)\n",
    "meanlosses = np.array(meanlosses)\n",
    "passuntils = np.array(passuntils)\n",
    "# print(list(zip(*all_align)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(41, 41)"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(sumlosses), len(passuntils)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((41, 7), (41, 7))"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sumlosses.shape, passuntils.shape\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Test loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([24.657, 22.795, 20.974, 18.603, 17.152, 15.685, 13.896])"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sumlosses.mean(axis=0)\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Add loss\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "from functools import partial\n",
    "\n",
    "def fit_loss_sum(model_size_end_value_df):\n",
    "    model_size_end_value_df = pd.DataFrame(model_size_end_value_df)\n",
    "    from scipy.optimize import curve_fit\n",
    "\n",
    "    # Define the function to fit\n",
    "    def func_log(logN, logC, alpha):\n",
    "        return logC - alpha *logN\n",
    "\n",
    "    # Define the function to fit\n",
    "    def inv_loss_scaling_func(l, C, alpha, l0):\n",
    "        return - np.log((l - l0)/C) * 1 / alpha\n",
    "\n",
    "    # def loss_scaling_func(N, C, alpha, l0):\n",
    "        return C * N**(-alpha) +l0\n",
    "\n",
    "    def compute_scaling_func(compute, C, alpha, l0):\n",
    "        return C* np.sqrt(C/120)**(-alpha) + l0\n",
    "\n",
    "\n",
    "    \n",
    "\n",
    "    # plt.scatter(model_size_end_value_df.iloc[:, 0], model_size_end_value_df.iloc[:, 1], linestyle=\"--\")\n",
    "\n",
    "    try:\n",
    "        inv_loss_fit_params, covariance = curve_fit(func_log, np.log(model_size_end_value_df.iloc[:, 0]), np.log(model_size_end_value_df.iloc[:, 1]), p0=[1, 1])\n",
    "    except:\n",
    "        print(model_size_end_value_df)\n",
    "        \n",
    "    # print(inv_loss_fit_params)\n",
    "\n",
    "    # x_fit = np.exp(np.linspace(np.log(0.03), np.log(3), 100))\n",
    "    # y_fit = [loss_scaling_func(t, *inv_loss_fit_params) for t in x_fit]\n",
    "\n",
    "    # plt.plot(x_fit, y_fit, linestyle=\"--\")\n",
    "    # plt.show()\n",
    "    def test_loss_scaling_func(N, logC, alpha):\n",
    "        return np.exp(func_log(np.log(N), logC, alpha))\n",
    "\n",
    "\n",
    "    return partial(test_loss_scaling_func, logC=inv_loss_fit_params[0], alpha=inv_loss_fit_params[1]), partial(func_log, logC=inv_loss_fit_params[0], alpha=inv_loss_fit_params[1])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[18.863, 16.708, 11.721, 10.644, 11.322,  8.327],\n",
       "       [16.707, 11.056,  8.667,  7.711,  7.6  ,  7.687],\n",
       "       [10.855,  8.141,  9.265,  6.024,  6.737,  4.898],\n",
       "       [15.674, 10.951, 12.687,  8.219,  7.927,  8.446],\n",
       "       [13.788, 13.758, 11.969,  9.671,  9.229,  9.748],\n",
       "       [11.603,  9.873,  9.825,  7.781,  7.774,  6.198],\n",
       "       [19.251, 17.011, 14.21 ,  9.482,  6.783,  8.08 ],\n",
       "       [11.201,  8.736,  6.438,  6.968,  7.288,  6.925],\n",
       "       [21.293, 16.074, 13.948, 11.302, 11.181, 11.032],\n",
       "       [14.459, 13.379, 11.178,  9.773,  8.353,  8.579],\n",
       "       [20.651, 19.307, 12.246, 11.445, 10.679,  9.931],\n",
       "       [11.465, 11.586,  9.45 , 10.77 ,  9.148,  9.963],\n",
       "       [13.881, 13.473, 11.113, 10.728, 11.719, 14.845],\n",
       "       [13.51 , 10.535, 11.616, 10.635, 10.807,  9.213],\n",
       "       [ 8.705,  9.303,  8.644,  8.175,  7.555,  9.223],\n",
       "       [17.036, 19.11 , 13.735,  9.838,  7.466,  7.16 ],\n",
       "       [14.028, 11.105,  9.359, 10.544, 11.808,  9.381],\n",
       "       [17.391, 16.586, 14.066, 11.537, 10.982,  9.305],\n",
       "       [15.816, 12.333,  5.971,  6.036,  7.581,  6.118],\n",
       "       [10.848, 11.538, 11.704,  7.185,  8.231,  5.032],\n",
       "       [10.318,  9.457, 11.891,  7.734,  7.48 ,  7.378],\n",
       "       [10.221, 12.752, 12.199,  6.581,  6.208,  5.093],\n",
       "       [12.087,  9.476,  9.135,  9.648,  8.793, 11.318],\n",
       "       [12.064, 11.225,  8.701,  7.404,  7.917,  7.052],\n",
       "       [17.975, 18.468, 14.112, 11.99 , 12.407,  8.798],\n",
       "       [25.597, 23.2  , 17.169, 10.667, 10.225, 10.046],\n",
       "       [13.696, 12.887, 10.718,  8.027,  6.53 ,  6.279],\n",
       "       [15.95 , 16.117, 11.594,  9.013, 13.984, 10.015],\n",
       "       [23.231, 19.572, 14.067,  8.615,  9.017,  7.761],\n",
       "       [23.244, 19.732, 14.573, 10.404,  6.149,  8.386],\n",
       "       [16.244, 17.836, 16.247, 14.463, 12.65 , 12.065],\n",
       "       [14.797, 12.99 , 12.534,  8.198,  6.839,  5.787],\n",
       "       [16.296, 12.65 , 11.338,  5.425,  5.038,  6.675],\n",
       "       [13.423, 14.231, 14.78 ,  8.833,  6.819,  7.215],\n",
       "       [11.046,  9.016,  9.385,  5.524,  6.796,  6.782],\n",
       "       [16.208, 13.32 , 11.948, 11.01 ,  9.89 ,  8.183],\n",
       "       [11.835, 11.807, 10.661,  8.382,  6.634,  9.074],\n",
       "       [16.098, 13.675, 12.156,  9.755, 10.72 , 10.93 ],\n",
       "       [11.443,  9.575,  8.412,  7.496,  7.786,  7.724],\n",
       "       [23.86 , 22.069, 21.563, 10.968,  8.058,  5.565],\n",
       "       [ 9.609,  7.492,  7.765,  7.695,  5.796,  7.933],\n",
       "       [12.268, 11.642, 10.344,  7.341,  6.669,  5.344],\n",
       "       [16.775, 14.228, 15.199, 11.155,  8.443,  7.928],\n",
       "       [16.999, 15.643, 14.924, 11.328,  8.746, 11.853],\n",
       "       [16.279, 13.228, 10.622, 11.89 , 10.429,  9.829],\n",
       "       [10.334,  8.691,  5.84 ,  5.459,  6.395,  4.711],\n",
       "       [13.325, 11.544,  9.645, 10.888,  9.882,  8.966]])"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 logC     1.985508\n",
      "alpha    0.505510\n",
      "Name: 0, dtype: float64\n",
      "1 logC     2.02296\n",
      "alpha    0.45799\n",
      "Name: 1, dtype: float64\n",
      "2 logC     2.052944\n",
      "alpha    0.201646\n",
      "Name: 2, dtype: float64\n",
      "3 logC     2.077618\n",
      "alpha   -0.080974\n",
      "Name: 3, dtype: float64\n",
      "4 logC    NaN\n",
      "alpha   NaN\n",
      "Name: 4, dtype: float64\n",
      "5 logC     1.921452\n",
      "alpha    0.227017\n",
      "Name: 5, dtype: float64\n",
      "6 logC     1.793959\n",
      "alpha    0.140932\n",
      "Name: 6, dtype: float64\n",
      "7 logC     1.726140\n",
      "alpha    0.154878\n",
      "Name: 7, dtype: float64\n",
      "8 logC     2.124399\n",
      "alpha    0.187796\n",
      "Name: 8, dtype: float64\n",
      "9 logC     2.279868\n",
      "alpha    0.066328\n",
      "Name: 9, dtype: float64\n",
      "10 logC     2.412674\n",
      "alpha   -0.044553\n",
      "Name: 10, dtype: float64\n",
      "11 logC     2.087816\n",
      "alpha    0.137639\n",
      "Name: 11, dtype: float64\n",
      "12 logC     1.616291\n",
      "alpha    0.263287\n",
      "Name: 12, dtype: float64\n",
      "13 logC     2.124447\n",
      "alpha    0.067995\n",
      "Name: 13, dtype: float64\n",
      "14 logC    NaN\n",
      "alpha   NaN\n",
      "Name: 14, dtype: float64\n",
      "15 logC     1.948479\n",
      "alpha    0.222776\n",
      "Name: 15, dtype: float64\n",
      "16 logC     2.138452\n",
      "alpha    0.110008\n",
      "Name: 16, dtype: float64\n",
      "17 logC     1.750970\n",
      "alpha    0.308576\n",
      "Name: 18, dtype: float64\n",
      "18 logC    NaN\n",
      "alpha   NaN\n",
      "Name: 19, dtype: float64\n",
      "19 logC     1.952916\n",
      "alpha    0.062159\n",
      "Name: 21, dtype: float64\n",
      "20 logC     2.112623\n",
      "alpha    0.017709\n",
      "Name: 22, dtype: float64\n",
      "21 logC     2.202084\n",
      "alpha    0.111916\n",
      "Name: 23, dtype: float64\n",
      "22 logC    NaN\n",
      "alpha   NaN\n",
      "Name: 24, dtype: float64\n",
      "23 logC    NaN\n",
      "alpha   NaN\n",
      "Name: 25, dtype: float64\n",
      "24 logC     2.239463\n",
      "alpha    0.207209\n",
      "Name: 26, dtype: float64\n",
      "25 logC     1.885579\n",
      "alpha    0.054746\n",
      "Name: 27, dtype: float64\n",
      "26 logC    NaN\n",
      "alpha   NaN\n",
      "Name: 30, dtype: float64\n",
      "27 logC     2.014918\n",
      "alpha    0.059748\n",
      "Name: 31, dtype: float64\n",
      "28 logC     2.104111\n",
      "alpha    0.065448\n",
      "Name: 32, dtype: float64\n",
      "29 logC    NaN\n",
      "alpha   NaN\n",
      "Name: 33, dtype: float64\n",
      "30 logC     1.623431\n",
      "alpha    0.298205\n",
      "Name: 34, dtype: float64\n",
      "31 logC     2.139755\n",
      "alpha    0.082189\n",
      "Name: 35, dtype: float64\n",
      "32 logC     2.065240\n",
      "alpha    0.181182\n",
      "Name: 36, dtype: float64\n",
      "33 logC    NaN\n",
      "alpha   NaN\n",
      "Name: 37, dtype: float64\n",
      "34 logC     2.048614\n",
      "alpha    0.340180\n",
      "Name: 38, dtype: float64\n",
      "35 logC    NaN\n",
      "alpha   NaN\n",
      "Name: 40, dtype: float64\n",
      "36 logC     1.664733\n",
      "alpha    0.151997\n",
      "Name: 42, dtype: float64\n",
      "37 logC     1.890568\n",
      "alpha    0.119700\n",
      "Name: 46, dtype: float64\n",
      "38 logC     1.835249\n",
      "alpha    0.108651\n",
      "Name: 47, dtype: float64\n",
      "39 logC    NaN\n",
      "alpha   NaN\n",
      "Name: 48, dtype: float64\n",
      "40 logC    NaN\n",
      "alpha   NaN\n",
      "Name: 49, dtype: float64\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/jq/j1z91stx47z_k2bkqs12nqk40000gn/T/ipykernel_50591/773479726.py:46: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  if df.iloc[i][-prediction_frac] == 0 or count >= n_rows*n_columns: # not draw , for better display, only draw those with non zero passrate\n",
      "/var/folders/jq/j1z91stx47z_k2bkqs12nqk40000gn/T/ipykernel_50591/773479726.py:66: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  ax[ax_row_id, ax_column_id].scatter(np.log(params_num[-prediction_frac]), -np.log(-np.log(df.iloc[i][-prediction_frac])/ratio_loss_logpassuntil), marker='>', s=30, color=colorlist[count%len(colorlist)])\n"
     ]
    }
   ],
   "source": [
    "from functools import partial\n",
    "func_pool = []\n",
    "func_pool_id_rec = []\n",
    "\n",
    "n_rows = 3\n",
    "n_columns = 5\n",
    "offset = 0\n",
    "prediction_frac = 1\n",
    "ratio_loss_logpassuntil = 0.4336954722674853\n",
    "\n",
    "fig, ax = plt.subplots(n_rows,n_columns,figsize=(12, 6), sharex=True, sharey=True)\n",
    "\n",
    "passrate_from_loss = []\n",
    "count = 0\n",
    "for i, (index, row) in enumerate(fit_params_df.iterrows()):\n",
    "    print(i, row)\n",
    "    logC, alpha = row.values\n",
    "    \n",
    "    if not np.isnan(logC) and alpha > 0.0:\n",
    "        func_pool.append(partial(func, logC=logC, alpha=alpha))\n",
    "        func_pool_id_rec.append(i)\n",
    "            # count += 1\n",
    "            # if count < offset:\n",
    "                # continue\n",
    "\n",
    "             \n",
    "    else:\n",
    "\n",
    "        sumlossmax_i = max(sumlosses[i][:-prediction_frac])\n",
    "\n",
    "        normalized_sumlosses_i = sumlosses[i][:-prediction_frac]/sumlossmax_i\n",
    "        a = pd.DataFrame(np.vstack([params_num_all[:-1], normalized_sumlosses_i]).transpose())\n",
    "\n",
    "        loss_scaling_func, func_log = fit_loss_sum(a)\n",
    "\n",
    "        def passrate_from_loss_func(N, loss_scaling_func, sumlossmax_i, ratio_loss_logpassuntil):\n",
    "            return np.exp(-ratio_loss_logpassuntil * loss_scaling_func(N) * sumlossmax_i)\n",
    "\n",
    "        # pred_loss = loss_scaling_func(params_num_all[-prediction_frac]) * sumlossmax_i\n",
    "        # print(pred_loss)\n",
    "        # passrate = np.exp(-ratio_loss_logpassuntil * pred_loss)\n",
    "        # print(passrate)\n",
    "        # passrate_from_loss.append(passrate)\n",
    "        passrate_from_loss.append(partial(passrate_from_loss_func,loss_scaling_func=loss_scaling_func, sumlossmax_i=sumlossmax_i, ratio_loss_logpassuntil=ratio_loss_logpassuntil))\n",
    "        \n",
    "        if df.iloc[i][-prediction_frac] == 0 or count >= n_rows*n_columns: # not draw , for better display, only draw those with non zero passrate\n",
    "            continue\n",
    "        \n",
    "        # if count >= n_rows*n_columns: # not draw\n",
    "        #     continue\n",
    "        \n",
    "        \n",
    "        ax_row_id = (count-offset) // n_columns\n",
    "        ax_column_id = (count-offset) % n_columns\n",
    "        x_data = np.arange(np.log(0.03), np.log(2.5), 0.1)\n",
    "        # y_data = np.exp(-np.exp(np.array([func(logn, logC, alpha) for logn in x_data])))\n",
    "        y_data = np.array([func_log(logn) for logn in x_data])\n",
    "\n",
    "        ax[ax_row_id, ax_column_id].plot(x_data, -y_data-np.log(sumlossmax_i), linestyle='-', label=str(i), color=colorlist[count%len(colorlist)])\n",
    "        # ax.scatter(np.log(2.45), df.iloc[i, -1], color=colorlist[count%len(colorlist)])\n",
    "        \n",
    "\n",
    "        # print(len(params_num[:-1]), len(sumlosses[i]))\n",
    "        ax[ax_row_id, ax_column_id].scatter(np.log(params_num[:-1]), -np.log(normalized_sumlosses_i)-np.log(sumlossmax_i), s=10, color=colorlist[count%len(colorlist)])\n",
    "        ax[ax_row_id, ax_column_id].scatter(np.log(params_num[-prediction_frac]), -np.log(sumlosses[i][-prediction_frac]), marker='*', s=40, color=colorlist[count%len(colorlist)])\n",
    "        ax[ax_row_id, ax_column_id].scatter(np.log(params_num[-prediction_frac]), -np.log(-np.log(df.iloc[i][-prediction_frac])/ratio_loss_logpassuntil), marker='>', s=30, color=colorlist[count%len(colorlist)])\n",
    "\n",
    "        # print(-np.log(df.iloc[i][-prediction_frac])/0.22/sumlossmax_i)\n",
    "        ax[ax_row_id, ax_column_id].set_xticks(np.log([0.05, 0.1, 0.2, 0.4, 0.8, 1.6, 3.2]))\n",
    "        ax[ax_row_id, ax_column_id].set_xticklabels([0.05, 0.1, 0.2, 0.4, 0.8, 1.6, 3.2])\n",
    "\n",
    "        yticks = ['1e-8', '1e-3', '1e-1','5e-1', '8e-1']\n",
    "        # yticks_label_right = [np.exp(-float(ystr)) for ystr in yticks]\n",
    "        ax[ax_row_id, ax_column_id].set_yticks([-np.log(-np.log(x)/ratio_loss_logpassuntil) for x in [float(ystr) for ystr in yticks]])\n",
    "        ax[ax_row_id, ax_column_id].set_yticklabels(yticks)\n",
    "        ax[ax_row_id, ax_column_id].set_ylim(*[-np.log(-np.log(x)/ratio_loss_logpassuntil) for x in [1e-10, 8.5e-1]])\n",
    "\n",
    "        ax[ax_row_id, ax_column_id].text(x=np.log(0.04), y=-np.log(-np.log(0.7)/ratio_loss_logpassuntil) , s=f\"{i}\", ha='center', va='center', bbox=dict(facecolor='white', edgecolor='black', boxstyle='circle'))       \n",
    "\n",
    "\n",
    "        # ax.set_xlabel('Model Size')\n",
    "        # ax.set_ylabel('Mean of Negative Logarithm of Values')\n",
    "        # ax.set_title('Mean of Negative Logarithm vs Model Size')\n",
    "        ax[ax_row_id, ax_column_id].grid(True, linestyle='--', linewidth=0.5, color='gray', alpha=0.5)\n",
    "        ax[ax_row_id, ax_column_id].tick_params(axis='y', direction='in', length=1.5)\n",
    "        ax[ax_row_id, ax_column_id].tick_params(axis='x', direction='in', length=1.5)  \n",
    "        ax[ax_row_id, ax_column_id].tick_params(axis='y', which='both', right=True)\n",
    "        # right_labels = ['Label 1', 'Label 2', 'Label 3', 'Label 4', 'Label 5']\n",
    "        # ax2 = ax.twinx()\n",
    "        # ax2.tick_params(axis='y', colors='red')\n",
    "        # ax2.set_yticks([-np.log(-np.log(x)/ratio_loss_logpassuntil) for x in [float(ystr) for ystr in yticks]])\n",
    "        # ax2.set_yticklabels(yticks)\n",
    "        # ax2.set_ylim(*[-np.log(-np.log(x)/ratio_loss_logpassuntil) for x in [1e-10, 8.5e-1]])\n",
    "        count += 1\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "passrate_from_passrate = [np.exp(-np.exp(thisfunc(np.log(2.45)))) for thisfunc in func_pool]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "30"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(passrate_from_passrate)#, len(passrate_from_loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'passrate_from_loss' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[21], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m (\u001b[39msum\u001b[39m(passrate_from_passrate) \u001b[39m+\u001b[39m \u001b[39msum\u001b[39m(passrate_from_loss))\u001b[39m/\u001b[39m\u001b[39mlen\u001b[39m(df),  \u001b[39msum\u001b[39m([df\u001b[39m.\u001b[39miloc[i, \u001b[39m-\u001b[39m\u001b[39m1\u001b[39m] \u001b[39mfor\u001b[39;00m i \u001b[39min\u001b[39;00m \u001b[39mrange\u001b[39m(\u001b[39mlen\u001b[39m(df))])\u001b[39m/\u001b[39m\u001b[39mlen\u001b[39m(df)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'passrate_from_loss' is not defined"
     ]
    }
   ],
   "source": [
    "# (sum(passrate_from_passrate) + sum(passrate_from_loss))/len(df),  sum([df.iloc[i, -1] for i in range(len(df))])/len(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0.00047120570700049253,\n",
       " 0.0011668581626046817,\n",
       " 0.0002555941539251991,\n",
       " 0.00013832592072535678,\n",
       " 0.0006823235843699398,\n",
       " 0.00029042941734552666,\n",
       " 0.0001379184298016706,\n",
       " 9.030780346881356e-06,\n",
       " 0.00013145341146236664,\n",
       " 0.00012781515473319447,\n",
       " 0.0001842432578922046,\n",
       " 0.000159771528822345,\n",
       " 0.0004744563580006852,\n",
       " 9.776920650608841e-05,\n",
       " 9.854577557951425e-06,\n",
       " 0.014067085409244751,\n",
       " 0.0004596614791568795,\n",
       " 0.0009658544886092162,\n",
       " 0.00012712691737922258,\n",
       " 0.0045697023938906295,\n",
       " 0.00012236526249124062,\n",
       " 0.00016524297144311894,\n",
       " 0.0002361044085669194,\n",
       " 0.0008392961049864873]"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[thisfunc(N) for thisfunc in passrate_from_loss]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(41, 0.003112422189744884, 0.002607868757259001)"
      ]
     },
     "execution_count": 52,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "N = 2.45\n",
    "passrate_of_N_individual =  [np.exp(-np.exp(thisfunc(np.log(N)))) for thisfunc in func_pool] + [thisfunc(N) for thisfunc in passrate_from_loss]\n",
    "len(passrate_of_N_individual), sum(passrate_of_N_individual)/len(df), sum([df.iloc[i, -1] for i in range(len(df))])/len(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.003112422189744884"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "def passrate_of_N(N):\n",
    "    a = [np.exp(-np.exp(thisfunc(np.log(N)))) for thisfunc in func_pool] + [thisfunc(N) for thisfunc in passrate_from_loss]\n",
    "    return sum(a)/len(a)\n",
    "\n",
    "passrate_of_N(2.45) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "a = -0.1743502538464397, b = 1.8757600159075687\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "0.003765454449111283"
      ]
     },
     "execution_count": 77,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from scipy.optimize import curve_fit\n",
    "mean_values = df.mean()\n",
    "\n",
    "\n",
    "x_data= np.log(params_num[:-1])\n",
    "y_data=np.log(-np.log(mean_values.values[:-1]))\n",
    "# 定义线性函数\n",
    "def linear_function(x, a, b):\n",
    "    return a * x + b\n",
    "\n",
    "# 使用curve_fit进行拟合\n",
    "params, covariance = curve_fit(linear_function, x_data, y_data)\n",
    "\n",
    "# 提取拟合参数\n",
    "a, b = params\n",
    "\n",
    "# 打印拟合参数\n",
    "print(f'a = {a}, b = {b}')\n",
    "\n",
    "# 使用拟合参数生成拟合线\n",
    "x_fit = np.linspace(min(x_data), max(x_data)+2, 100)\n",
    "y_fit = linear_function(x_fit, a, b)\n",
    "\n",
    "# Plotting the mean values\n",
    "fig, axs = plt.subplots(1,1,figsize=(8, 6))\n",
    "\n",
    "axs = [None, axs]\n",
    "\n",
    "colorlist = ['#FA7F6F', '#82B0D2',  '#8ECFC9', '#FFBE7A', '#BEB8DC', '#999999']\n",
    "\n",
    "# axs[0].plot(x_data, y_data, marker='o', linestyle='-', color='#415E5C', label='Mean Values')\n",
    "# axs[0].plot(x_fit, y_fit, label=f'Fit: a={a:.2f}, b={b:.2f}', linestyle='--', color='#78AFAA')\n",
    "\n",
    "# new data\n",
    "x_new = np.log(params_num[-1:])\n",
    "y_new = np.log(-np.log(mean_values.values[-1:]))\n",
    "\n",
    "# axs[0].scatter(x_new, y_new, color=colorlist[0])\n",
    "\n",
    "\n",
    "\n",
    "# axs[0].set_ylabel('Negative Log PassUntil')\n",
    "\n",
    "# axs[0].grid(True, linestyle='--', linewidth=0.5, color='gray')\n",
    "\n",
    "# axs[0].set_xticks(np.log(np.array([0.0625, 0.125, 0.25, 0.5, 1, 2, 4])))\n",
    "# axs[0].set_xticklabels([\"{}\".format(x) for x in [0.0625, 0.125, 0.25, 0.5, 1, 2, 4]])\n",
    "\n",
    "# plt.legend()\n",
    "\n",
    "axs[1].set_ylabel('PassUntil')\n",
    "\n",
    "axs[1].plot(x_data, np.exp(-np.exp(y_data)), marker='o', linestyle='-', color='#415E5C', )\n",
    "\n",
    "y_individual_fit = np.array([passrate_of_N(np.exp(x)) for x in x_fit])\n",
    "\n",
    "axs[1].plot(x_fit, np.exp(-np.exp(y_fit)), label=f'Dataset-level Fit', linestyle='--', color='#999999')\n",
    "axs[1].plot(x_fit, y_individual_fit, label=f'Instance-level Fit', linestyle='--', color='#78AFAA')\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "axs[1].scatter(x_new, passrate_of_N(params_num_all[-1]), color=colorlist[2], marker='v', s=80, label=\"Prediction\")\n",
    "axs[1].scatter(x_new, np.exp(-np.exp(y_new)), color=colorlist[0], s=80, marker='*', label=\"Real Value\")\n",
    "\n",
    "# axs[1].text(0.5, 0.05, \"$e^{-1.26 N^{-0.29}}$\", fontsize=18, ha='right')\n",
    "axs[1].set_xticks(np.log(np.array([0.0625, 0.125, 0.25, 0.5, 1, 2, 4,8])))\n",
    "axs[1].set_xticklabels([\"{}\".format(x) for x in [0.0625, 0.125, 0.25, 0.5, 1, 2, 4,8]])\n",
    "axs[1].grid(True, linestyle='--', linewidth=0.5, color='gray')\n",
    "axs[1].set_ylim([0, 0.01])\n",
    "\n",
    "\n",
    "# axs[1].plot(x_fit, np.exp(-np.exp(y_fit)), label=f'Fit: a={a:.2f}, b={b:.2f}', linestyle='--', color=colorlist[2])\n",
    "\n",
    "# plt.annotate('')\n",
    "\n",
    "axs[1].legend(fontsize=16)\n",
    "axs[1].tick_params(axis='x', labelsize=16)\n",
    "axs[1].tick_params(axis='y', labelsize=16)\n",
    "axs[1].set_ylabel('{PU}', fontsize=16)\n",
    "# axs[0].set_xlabel(\"Model Size (B)\", fontsize=16)\n",
    "axs[1].set_xlabel(\"Model Size (B)\", fontsize=16)\n",
    "\n",
    "\n",
    "plt.savefig(\"individual_passrate_vs_modelsize_add_loss.pdf\",bbox_inches='tight', pad_inches=0)\n",
    "plt.show()\n",
    "\n",
    "np.exp(-np.exp(linear_function(np.log(2.45), a, b)))\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.004301520643868059"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(0.06013179732175409-0.05987424701219508)/0.05987424701219508"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.6.9 64-bit",
   "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.9.6"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "31f2aee4e71d21fbe5cf8b01ff0e069b9275f58929596ceb00d14d90e3e16cd6"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
