{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/data1/XXX/.local/lib/python3.9/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import sys\n",
    "base_path = os.path.abspath(os.path.join(os.path.abspath(\"__file__\"), '../../../../..'))\n",
    "sys.path.append(base_path)\n",
    "\n",
    "import pickle\n",
    "from utils.utils import split_rawdata\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------------------------------------------------------------------------\n",
      "\tproblem dataset:   \t[5007] raw data with [841] different random seeds, ave cost = [6.114]\n",
      "\tprompt dataset:   \t[1998] raw data with [400] different random seeds, ave cost = [6.101]\n",
      "\ttrain dataset:   \t[210511] raw data with [41080] different random seeds, ave cost = [6.126]\n",
      "--------------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "def load_raw_data(num_nodes:int, check_data_num:dict):\n",
    "    datasets = {}\n",
    "    print('-'*80)\n",
    "    for data_type in check_data_num.keys():\n",
    "        path = f'{base_path}/data/used/_raw/cvrp/cvrp{num_nodes}_{data_type}.pkl' \n",
    "        with open(path, 'rb') as f:\n",
    "            dataset = pickle.load(f)\n",
    "            check_num = check_data_num[data_type]\n",
    "            if check_num != 0:\n",
    "                dataset = split_rawdata(dataset, 0, check_num)\n",
    "        datasets[data_type] = dataset\n",
    "        assert len(dataset.answer_list) == len(dataset.problem_list) == len(dataset.cost_list)\n",
    "        print(f'\\t{data_type} dataset:   \\t[{len(dataset.answer_list)}] raw data with [{len(dataset.seed_list)}] different random seeds, ave cost = [{np.mean(dataset.cost_list):.3f}]')    \n",
    "    print('-'*80)\n",
    "    return datasets\n",
    "\n",
    "num_nodes = 20\n",
    "check_data_num = {\n",
    "    'problem': 0,\n",
    "    'prompt': 0,\n",
    "    'train': 0,\n",
    "}\n",
    "\n",
    "datasets = load_raw_data(num_nodes, check_data_num)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAj4AAAHHCAYAAAC/R1LgAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABKoklEQVR4nO3deViU9f7/8dcAAiqKIAiiKO77kpCkLWryDbNM0tyOBS5ZpyOKh6wjLaKZkUumpulpUcs0TTPNOmVK7pmaZlmWZmHuqKngkqBw//7ox8SwKIMzDDDPx3XNFffn3t73MMl7PqvJMAxDAAAATsDF0QEAAACUFBIfAADgNEh8AACA0yDxAQAAToPEBwAAOA0SHwAA4DRIfAAAgNMg8QEAAE6DxAcAADgNEh+ghJlMJsXGxtrsegsWLJDJZNI333xzw2M7d+6szp07m7cPHTokk8mkBQsWmMvGjRsnk8lks/jKg5CQEA0aNMjRYZRKOZ+/Q4cOOToUoEhIfAD9/Y93zsvT01ONGzdWbGysUlNTHR2ew7300ktauXKlTa+5YcMGi/fcw8NDAQEB6ty5s1566SWdPn3apvezpX379mncuHE2/2M/aNAgi/ck9+vzzz+36b2sZY/PAOAIbo4OAChNXnjhBdWrV09XrlzRli1bNGfOHP3vf//TDz/8oEqVKjk6vJv2xRdf3PCY5557TmPGjLEoe+mll/TQQw8pKirK5jGNHDlSt956q7KysnT69Gl99dVXSkxM1LRp0/TBBx/o7rvvtvk9rbV//365uPz9PXHfvn0aP368OnfurJCQEJvey8PDQ2+99Va+8jZt2tj0PtYq7DPwyCOPqH///vLw8HBMYICVSHyAXO69916FhYVJkh599FFVr15d06ZN06pVqzRgwIACz7l06ZIqV65ckmEWm7u7+w2PcXNzk5tbyf3TcOedd+qhhx6yKPvuu+90zz33qHfv3tq3b59q1qxZYvEUpCT/qLu5uenhhx8usfvdLFdXV7m6ujo6DKDIaOoCriOntiElJUXSX00RXl5e+vXXX9W9e3dVqVJFAwcOlPRXAvTkk08qODhYHh4eatKkiaZOnSrDMAq89qJFi9SkSRN5enoqNDRUmzZtstj/+++/61//+peaNGmiihUrqnr16urTp0+hzSuXL1/W448/rurVq6tq1aqKjo7WuXPnLI7J28enIHn7+JhMJl26dEnvvPOOudll0KBBWr9+vUwmkz766KN811i8eLFMJpO2bdt23XsVpk2bNpo+fbrOnz+vWbNmWew7duyYhgwZooCAAHl4eKhFixaaN2+exTE5zWgffPCBJk6cqNq1a8vT01Ndu3bVwYMHLY795Zdf1Lt3bwUGBsrT01O1a9dW//79lZaWZj4mdx+fBQsWqE+fPpKkLl26mN+TDRs2KCYmRn5+frp69Wq+Z7rnnnvUpEmTYr0feZ9rw4YNFuUF9dXK+aweO3ZMUVFR8vLykr+/v0aPHq2srCyL87OzszVjxgy1atVKnp6e8vf3V7du3cz9xgr7DOS8HwX18Xn99dfVokULeXh4KCgoSMOHD9f58+ctjuncubNatmypffv2qUuXLqpUqZJq1aqlyZMn39T7BFwPNT7Adfz666+SpOrVq5vLrl27psjISN1xxx2aOnWqKlWqJMMw9MADD2j9+vUaOnSo2rZtqzVr1uipp57SsWPH9Oqrr1pcd+PGjVq6dKlGjhwpDw8Pvf766+rWrZt27Nihli1bSpJ27typr776Sv3791ft2rV16NAhzZkzR507d9a+ffvyNb3FxsaqWrVqGjdunPbv3685c+bo999/N/+xLK6FCxfq0UcfVfv27fXYY49Jkho0aKDbbrtNwcHBWrRokR588EGLcxYtWqQGDRqoQ4cOxb7vQw89pKFDh+qLL77QxIkTJUmpqam67bbbzB3E/f399dlnn2no0KFKT0/XqFGjLK7x8ssvy8XFRaNHj1ZaWpomT56sgQMHavv27ZKkzMxMRUZGKiMjQyNGjFBgYKCOHTumTz75ROfPn5e3t3e+uO666y6NHDlSM2fO1DPPPKNmzZpJkpo1a6ZHHnlE7777rtasWaP777/ffM7Jkyf15ZdfKjExsUjPfubMGYvtChUqFBjLjWRlZSkyMlLh4eGaOnWq1q1bp1deeUUNGjTQE088YT5u6NChWrBgge699149+uijunbtmjZv3qyvv/5aYWFhhX4GCjNu3DiNHz9eEREReuKJJ8yfx507d2rr1q2qUKGC+dhz586pW7du6tWrl/r27avly5frP//5j1q1aqV7773X6mcGbsgAYMyfP9+QZKxbt844ffq0ceTIEWPJkiVG9erVjYoVKxpHjx41DMMwYmJiDEnGmDFjLM5fuXKlIcl48cUXLcofeughw2QyGQcPHjSXSTIkGd9884257Pfffzc8PT2NBx980Fx2+fLlfHFu27bNkGS8++67+WIPDQ01MjMzzeWTJ082JBmrVq0yl3Xq1Mno1KmTeTslJcWQZMyfP99clpiYaOT9p6Fy5cpGTExMvngSEhIMDw8P4/z58+ayU6dOGW5ubkZiYmK+43Nbv369IclYtmxZoce0adPG8PHxMW8PHTrUqFmzpnHmzBmL4/r37294e3ub37Ocazdr1szIyMgwHzdjxgxDkrF3717DMAzj22+/vWEMhmEYdevWtXj+ZcuWGZKM9evXWxyXlZVl1K5d2+jXr59F+bRp0wyTyWT89ttv171Pzucr7yvnd5bzXHnvW9DvMedaL7zwgsWxt9xyixEaGmre/vLLLw1JxsiRI/PFk52dbf65sM9AzucvJSXFMIy/fv/u7u7GPffcY2RlZZmPmzVrliHJmDdvnrmsU6dO+T7PGRkZRmBgoNG7d+9C3yfgZtDUBeQSEREhf39/BQcHq3///vLy8tJHH32kWrVqWRyX+9uyJP3vf/+Tq6urRo4caVH+5JNPyjAMffbZZxblHTp0UGhoqHm7Tp066tmzp9asWWNuhqhYsaJ5/9WrV/XHH3+oYcOGqlatmnbv3p0v9scee8zim/QTTzwhNzc3/e9//7PyXSi66OhoZWRkaPny5eaypUuX6tq1azbpp+Ll5aULFy5IkgzD0IcffqgePXrIMAydOXPG/IqMjFRaWlq+92Xw4MEW/ZruvPNOSdJvv/0mSeZalDVr1ujy5cs3Ha+Li4sGDhyojz/+2By39FcNWMeOHVWvXr0bXsPT01Nr1661eL3yyivFjumf//ynxfadd95pfn5J+vDDD2UymQqsjSpOTeG6deuUmZmpUaNGWXQIHzZsmKpWrapPP/3U4ngvLy+Lz4q7u7vat29vESNgSyQ+QC6zZ8/W2rVrtX79eu3bt0+//fabIiMjLY5xc3NT7dq1Lcp+//13BQUFqUqVKhblOc0gv//+u0V5o0aN8t27cePGunz5snkY959//qmxY8ea+wz5+fnJ399f58+ft+h/Utg1vby8VLNmTbvOr9K0aVPdeuutWrRokbls0aJFuu2229SwYcObvv7FixfN7+np06d1/vx5vfHGG/L397d4DR48WJJ06tQpi/Pr1Kljse3j4yNJ5r5P9erVU3x8vN566y35+fkpMjJSs2fPLvD9Laro6Gj9+eef5r5P+/fv165du/TII48U6XxXV1dFRERYvHInydbI6a+Tm4+Pj0Xfr19//VVBQUHy9fUt1j3yyvms5+3P5O7urvr16+f7f6F27dr5Eqy8MQK2RB8fIJf27dubR3UVxsPDw+KbrL2MGDFC8+fP16hRo9ShQwd5e3vLZDKpf//+ys7Otvv9iyo6OlpxcXE6evSoMjIy9PXXX+frkFwcV69e1YEDB8x9nnKe+eGHH1ZMTEyB57Ru3dpiu7DRRkauDuevvPKKBg0apFWrVumLL77QyJEjlZSUpK+//jpfglsUzZs3V2hoqN577z1FR0frvffek7u7u/r27Wv1tfIqrAYmb2flHGVhtFVRfkeALZH4ADZQt25drVu3ThcuXLCo9fn555/N+3P75Zdf8l3jwIEDqlSpkvkb+vLlyxUTE2PRzHHlypV8I2NyX7NLly7m7YsXL+rEiRPq3r17sZ8rx/WaPPr376/4+Hi9//77+vPPP1WhQgX169fvpu+5fPly/fnnn+YaN39/f1WpUkVZWVmKiIi46evn1qpVK7Vq1UrPPfecvvrqK91+++2aO3euXnzxxQKPv1ETUHR0tOLj43XixAktXrxY9913n7m26WbkXCPvZyBvLYo1GjRooDVr1ujs2bPXrfUparNXzmd9//79ql+/vrk8MzNTKSkpNv/dAdaiqQuwge7duysrKytfTcerr74qk8mUb3TKtm3bLPqjHDlyRKtWrdI999xj/gbs6uqa71vva6+9Vui3+zfeeMNiGPWcOXN07do1m4yMqVy5cqEJl5+fn+6991699957WrRokbp16yY/P7+but93332nUaNGycfHR8OHD5f01/vRu3dvffjhh/rhhx/ynVOcmZ7T09N17do1i7JWrVrJxcVFGRkZhZ6XM29TYe/JgAEDZDKZFBcXp99++81m8/LUrVtXrq6u+aY+eP3114t9zd69e8swDI0fPz7fvtyfv+t9BnKLiIiQu7u7Zs6caXH+22+/rbS0NN13333FjhWwBWp8ABvo0aOHunTpomeffVaHDh1SmzZt9MUXX2jVqlUaNWpUvqG/LVu2VGRkpMVwdkkWf3zuv/9+LVy4UN7e3mrevLm2bdumdevWWQytzy0zM1Ndu3ZV3759tX//fr3++uu644479MADD9z084WGhmrdunWaNm2agoKCVK9ePYWHh5v3R0dHmychnDBhglXX3rx5s65cuaKsrCz98ccf2rp1qz7++GN5e3vro48+UmBgoPnYl19+WevXr1d4eLiGDRum5s2b6+zZs9q9e7fWrVuns2fPWnXvL7/8UrGxserTp48aN26sa9euaeHCheYkqzBt27aVq6urJk2apLS0NHl4eOjuu+9WjRo1JMk8D86yZctUrVo1m/2x9/b2Vp8+ffTaa6/JZDKpQYMG+uSTT/L1bbJGly5d9Mgjj2jmzJn65Zdf1K1bN2VnZ2vz5s3q0qWLeV25G30Gcvj7+yshIUHjx49Xt27d9MADD5g/j7feemuZmpwR5ZTDxpMBpUjOkNydO3de97iYmBijcuXKBe67cOGC8e9//9sICgoyKlSoYDRq1MiYMmWKxZBgw/hrOPvw4cON9957z2jUqJHh4eFh3HLLLfmGKJ87d84YPHiw4efnZ3h5eRmRkZHGzz//nG9odU7sGzduNB577DHDx8fH8PLyMgYOHGj88ccfFtcs7nD2n3/+2bjrrruMihUrGpLyDWvOyMgwfHx8DG9vb+PPP/+87nuYI2dods6rQoUKhr+/v3HXXXcZEydONE6dOlXgeampqcbw4cON4OBgo0KFCkZgYKDRtWtX44033sh37bzD1PM+72+//WYMGTLEaNCggeHp6Wn4+voaXbp0MdatW2dxXt733DAM48033zTq169vuLq6FjjE/IMPPjAkGY899liR3g/DuP7nK8fp06eN3r17G5UqVTJ8fHyMxx9/3Pjhhx8KHM5e0LUK+v1eu3bNmDJlitG0aVPD3d3d8Pf3N+69915j165d5mMK+wzkHc6eY9asWUbTpk2NChUqGAEBAcYTTzxhnDt3zuKYTp06GS1atCjwfahbt+513weguEyGQQ8yADfn2rVrCgoKUo8ePfT22287OpxSYdWqVYqKitKmTZvMw+gBOB59fADctJUrV+r06dOKjo52dCilxptvvqn69evrjjvucHQoAHKhjw+AYtu+fbu+//57TZgwQbfccos6derk6JAcbsmSJfr+++/16aefasaMGTe1XAgA26OpC0CxDRo0SO+9957atm2rBQsWmOfccWYmk0leXl7q16+f5s6dW6Ir3QO4MRIfAADgNOjjAwAAnAaJDwAAcBpO1/icnZ2t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eeeMzyzx3M703M74zJLtn9vhExgCAACUFIcvWQEAAFBSSHwAAIDTIPEBAABOg8QHAAA4DadJfObMmaPWrVubJ37q0KGDPvvsM0eHVaJefvllmUwmi8kfy6tx48bJZDJZvJo2berosOzu2LFjevjhh1W9enVVrFhRrVq10jfffOPosOwqJCQk3+/aZDJp+PDhjg7NrrKysvT888+rXr16qlixoho0aKAJEybc9DpGpd2FCxc0atQo1a1bVxUrVlTHjh21c+dOR4dlU5s2bVKPHj0UFBQkk8mUbxFuwzA0duxY1axZUxUrVlRERIR++eUXxwRrQzd67hUrVuiee+5R9erVZTKZtGfPnmLdx2kSn9q1a+vll1/Wrl279M033+juu+9Wz5499eOPP9745HJg586d+u9//6vWrVs7OpQS06JFC504ccL82rJli6NDsqtz587p9ttvV4UKFfTZZ59p3759euWVV+Tj4+Po0Oxq586dFr/ntWvXSlKxp7woKyZNmqQ5c+Zo1qxZ+umnnzRp0iRNnjxZr732mqNDs6tHH31Ua9eu1cKFC7V3717dc889ioiI0LFjxxwdms1cunRJbdq00ezZswvcP3nyZM2cOVNz587V9u3bVblyZUVGRurKlSslHKlt3ei5L126pDvuuEOTJk26uRsZTszHx8d46623HB2G3V24cMFo1KiRsXbtWqNTp05GXFyco0Oyu8TERKNNmzaODqNE/ec//zHuuOMOR4fhcHFxcUaDBg2M7OxsR4diV/fdd58xZMgQi7JevXoZAwcOdFBE9nf58mXD1dXV+OSTTyzK27VrZzz77LMOisq+JBkfffSReTs7O9sIDAw0pkyZYi47f/684eHhYbz//vsOiNA+8j53bikpKYYk49tvvy3WtZ2mxie3rKwsLVmyRJcuXSp0ja/yZPjw4brvvvsUERHh6FBK1C+//KKgoCDVr19fAwcO1OHDhx0dkl19/PHHCgsLU58+fVSjRg3dcsstevPNNx0dVonKzMzUe++9pyFDhshkMjk6HLvq2LGjkpOTdeDAAUnSd999py1btujee+91cGT2c+3aNWVlZcnT09OivGLFiuW+RjdHSkqKTp48afHvube3t8LDw7Vt2zYHRlZ2lIqZm0vK3r171aFDB125ckVeXl766KOP1Lx5c0eHZVdLlizR7t27y10b+I2Eh4drwYIFatKkiU6cOKHx48frzjvv1A8//KAqVao4Ojy7+O233zRnzhzFx8frmWee0c6dOzVy5Ei5u7srJibG0eGViJUrV+r8+fMaNGiQo0OxuzFjxig9PV1NmzaVq6ursrKyNHHiRA0cONDRodlNlSpV1KFDB02YMEHNmjVTQECA3n//fW3btk0NGzZ0dHgl4uTJk5JkXtYpR0BAgHkfrs+pEp8mTZpoz549SktL0/LlyxUTE6ONGzeW2+TnyJEjiouL09q1a/N9Qyrvcn/rbd26tcLDw1W3bl198MEHGjp0qAMjs5/s7GyFhYXppZdekiTdcsst+uGHHzR37lynSXzefvtt3XvvvQoKCnJ0KHb3wQcfaNGiRVq8eLFatGihPXv2aNSoUQoKCirXv++FCxdqyJAhqlWrllxdXdWuXTsNGDBAu3btcnRoKCOcqqnL3d1dDRs2VGhoqJKSktSmTRvNmDHD0WHZza5du3Tq1Cm1a9dObm5ucnNz08aNGzVz5ky5ubkpKyvL0SGWmGrVqqlx48Y6ePCgo0Oxm5o1a+ZL4ps1a1bum/hy/P7771q3bp0effRRR4dSIp566imNGTNG/fv3V6tWrfTII4/o3//+t5KSkhwdml01aNBAGzdu1MWLF3XkyBHt2LFDV69eVf369R0dWokIDAyUJKWmplqUp6ammvfh+pwq8ckrOztbGRkZjg7Dbrp27aq9e/dqz5495ldYWJgGDhyoPXv2yNXV1dEhlpiLFy/q119/Vc2aNR0dit3cfvvt2r9/v0XZgQMHVLduXQdFVLLmz5+vGjVq6L777nN0KCXi8uXLcnGx/Cfc1dVV2dnZDoqoZFWuXFk1a9bUuXPntGbNGvXs2dPRIZWIevXqKTAwUMnJyeay9PR0bd++3Sn6rNqC0zR1JSQk6N5771WdOnV04cIFLV68WBs2bNCaNWscHZrdVKlSRS1btrQoq1y5sqpXr56vvLwZPXq0evToobp16+r48eNKTEyUq6urBgwY4OjQ7Obf//63OnbsqJdeekl9+/bVjh079MYbb+iNN95wdGh2l52drfnz5ysmJkZubs7xz1qPHj00ceJE1alTRy1atNC3336radOmaciQIY4Oza7WrFkjwzDUpEkTHTx4UE899ZSaNm2qwYMHOzo0m7l48aJF7XRKSor27NkjX19f1alTR6NGjdKLL76oRo0aqV69enr++ecVFBSkqKgoxwVtAzd67rNnz+rw4cM6fvy4JJm/6AUGBlpX21XssWZlzJAhQ4y6desa7u7uhr+/v9G1a1fjiy++cHRYJc5ZhrP369fPqFmzpuHu7m7UqlXL6Nevn3Hw4EFHh2V3q1evNlq2bGl4eHgYTZs2Nd544w1Hh1Qi1qxZY0gy9u/f7+hQSkx6eroRFxdn1KlTx/D09DTq169vPPvss0ZGRoajQ7OrpUuXGvXr1zfc3d2NwMBAY/jw4cb58+cdHZZNrV+/3pCU7xUTE2MYxl9D2p9//nkjICDA8PDwMLp27VouPvs3eu758+cXuD8xMdGq+5gMo5xP8wkAAPD/OXUfHwAA4FxIfAAAgNMg8QEAAE6DxAcAADgNEh8AAOA0SHwAAIDTIPEBAABOg8QHQLnQuXNnjRo1ytFhACjlSHwAOFyPHj3UrVu3Avdt3rxZJpNJ33//fQlHBaA8IvEB4HBDhw7V2rVrdfTo0Xz75s+fr7CwMLVu3doBkQEob0h8ADjc/fffL39/fy1YsMCi/OLFi1q2bJmioqI0YMAA1apVS5UqVVKrVq30/vvvX/eaJpNJK1eutCirVq2axT2OHDmivn37qlq1avL19VXPnj116NAh2zwUgFKJxAeAw7m5uSk6OloLFixQ7uUDly1bpqysLD388MMKDQ3Vp59+qh9++EGPPfaYHnnkEe3YsaPY97x69aoiIyNVpUoVbd68WVu3bpWXl5e6deumzMxMWzwWgFKIxAdAqTBkyBD9+uuv2rhxo7ls/vz56t27t+rWravRo0erbdu2ql+/vkaMGKFu3brpgw8+KPb9li5dquzsbL311ltq1aqVmjVrpvnz5+vw4cPasGGDDZ4IQGlE4gOgVGjatKk6duyoefPmSZIOHjyozZs3a+jQocrKytKECRPUqlUr+fr6ysvLS2vWrNHhw4eLfb/vvvtOBw8eVJUqVeTl5SUvLy/5+vrqypUr+vXXX231WABKGTdHBwAAOYYOHaoRI0Zo9uzZmj9/vho0aKBOnTpp0qRJmjFjhqZPn65WrVqpcuXKGjVq1HWbpEwmk0WzmfRX81aOixcvKjQ0VIsWLcp3rr+/v+0eCkCpQuIDoNTo27ev4uLitHjxYr377rt64oknZDKZtHXrVvXs2VMPP/ywJCk7O1sHDhxQ8+bNC72Wv7+/Tpw4Yd7+5ZdfdPnyZfN2u3bttHTpUtWoUUNVq1a130MBKFVo6gJQanh5ealfv35KSEjQiRMnNGjQIElSo0aNtHbtWn311Vf66aef9Pjjjys1NfW617r77rs1a9Ysffvtt/rmm2/0z3/+UxUqVDDvHzhwoPz8/NSzZ09t3rxZKSkp2rBhg0aOHFngsHoA5QOJD4BSZejQoTp37pwiIyMVFBQkSXruuefUrl07RUZGqnPnzgoMDFRUVNR1r/PKK68oODhYd955p/7xj39o9OjRqlSpknl/pUqVtGnTJtWpU0e9evVSs2bNNHToUF25coUaIKAcMxl5G8EBAADKKWp8AACA0yDxAQAAToPEBwAAOA0SHwAA4DRIfAAAgNMg8QEAAE6DxAcAADgNEh8AAOA0SHwAAIDTIPEBAABOg8QHAAA4DRIfAADgNP4fnoUnXWwVOzUAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# 绘制概率密度函数\n",
    "plt.hist(datasets['train'].cost_list, bins=100, density=True, alpha=0.6, label='train') \n",
    "#plt.hist(datasets['prompt'].cost_list, bins=100, density=True, alpha=0.6, label='prompt') \n",
    "plt.hist(datasets['problem'].cost_list, bins=100, density=True, alpha=0.6, label='problem') \n",
    "plt.title('Probability Density Function')\n",
    "plt.xlabel('Value')\n",
    "plt.ylabel('Probability Density')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "10.668457224539022"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "max(datasets['train'].cost_list)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "torch-2.0.1-cu117-py39",
   "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.17"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
