{
 "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",
    "\n",
    "base_path = os.path.abspath(os.path.join(os.getcwd(), '../../..'))\n",
    "sys.path.append(base_path)\n",
    "\n",
    "import numpy as np\n",
    "from utils.utils import load_data_and_check_quantity, create_folder_overwrite_if_exist\n",
    "from utils.COP_slover import knapsack_dp\n",
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "file_names = ['atsp20_problem.pkl','atsp20_train.pkl']\n",
    "ENV_NAME = 'ATSP_V1'\n",
    "num_problem = 0\n",
    "num_episode = 5000\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "------------------------------------------------------------\n",
      "atsp20_problem      \t5000\t3.84369184314512\n",
      "\tposition          \tin range [0.0, 1.0]\n",
      "\tnode_embedding    \tin range [0.15356955, 3.6900256]\n",
      "\n",
      "atsp20_train        \t5000\n",
      "\tvisited           \tin range [0, 1]\n",
      "\tcurrent_embedding \tin range [0.15309486, 3.6147804]\n",
      "\n",
      "------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "file_data = load_data_and_check_quantity(file_names, ENV_NAME, num_problem, num_episode, check_ave_obj=True)\n",
    "problems = file_data['atsp20_problem']\n",
    "episodes = file_data['atsp20_problem']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x76abfc39aa00>]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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peb++++39WeOWosXLzY///nPzfbt283WrVvNZz7zGTN16lTT0dGRWee2224z9fX1Zu3atWbTpk3m4osvNpdccklmeSwWM+eee65ZtGiR2bJli3niiSfM+PHjzfLlyzPrvP/++6asrMx87WtfM2+++ab5yU9+Yjwej3nqqaes/r2j0R//+Efz+OOPm3feecfs3LnTfOc73zE+n89s377dGMP2KyavvPKKmTZtmpk3b5654447Mu+zDQvb9773PTNnzhxz4MCBzOPQoUOZ5cW6/YjPLBdeeKFZtmxZ5nU8HjeTJk0yjY2NDo4Kxpjj4jORSJi6ujpz9913Z95rbW01gUDA/PrXvzbGGPPmm28aSebVV1/NrPPkk08al8tl9u3bZ4wx5qc//akZM2aMCYfDmXW+9a1vmVmzZuX5Lzr9HDx40Egy69evN8Ykt5fP5zMPP/xwZp233nrLSDIbN240xiT/B4jb7TbNzc2ZdVasWGGCwWBmm33zm980c+bMyfld119/vVm8eHG+/6TT0pgxY8yDDz7I9isi7e3tZubMmWbNmjXmiiuuyMQn27Dwfe973zPz58/vd1kxbz92u6dEIhFt3rxZixYtyrzndru1aNEibdy40cGRoT+7d+9Wc3NzzvaqqqrSRRddlNleGzduVHV1tT760Y9m1lm0aJHcbrdefvnlzDqXX365/H5/Zp3Fixdr586dOnbsmKW/5vTQ1tYmSRo7dqwkafPmzYpGoznb8Oyzz9bUqVNztuHcuXNVW1ubWWfx4sUKhULasWNHZp3s70ivw3+3Iysej2vVqlXq7OxUQ0MD26+ILFu2TNdcc81x/85sw+Lw7rvvatKkSTrzzDN14403qqmpSVJxbz/iM+Xw4cOKx+M5G0iSamtr1dzc7NCoMJD0NjnR9mpublZNTU3Ocq/Xq7Fjx+as0993ZP8OnLpEIqE777xTl156qc4991xJyX9fv9+v6urqnHX7bsOTbZ+B1gmFQuru7s7Hn3Na2bZtmyoqKhQIBHTbbbdp9erVmj17NtuvSKxatUqvvfaaGhsbj1vGNix8F110kVauXKmnnnpKK1as0O7du3XZZZepvb29qLefNy/fCgBZli1bpu3bt+v55593eigYolmzZmnr1q1qa2vT7373O910001av36908PCIOzdu1d33HGH1qxZo5KSEqeHg2G4+uqrM8/nzZuniy66SGeccYZ++9vfqrS01MGRnRpmPlPGjx8vj8dz3FliLS0tqqurc2hUGEh6m5xoe9XV1engwYM5y2OxmI4ePZqzTn/fkf07cGpuv/12PfbYY3ruuec0ZcqUzPt1dXWKRCJqbW3NWb/vNjzZ9hlonWAwWNT/z7lQ+P1+zZgxQwsXLlRjY6Pmz5+ve+65h+1XBDZv3qyDBw/q/PPPl9frldfr1fr16/Vf//Vf8nq9qq2tZRsWmerqap111lnatWtXUf83SHym+P1+LVy4UGvXrs28l0gktHbtWjU0NDg4MvRn+vTpqqury9leoVBIL7/8cmZ7NTQ0qLW1VZs3b86s8+yzzyqRSOiiiy7KrLNhwwZFo9HMOmvWrNGsWbM0ZswYS3/N6GSM0e23367Vq1fr2Wef1fTp03OWL1y4UD6fL2cb7ty5U01NTTnbcNu2bTn/I2LNmjUKBoOaPXt2Zp3s70ivw3+3+ZFIJBQOh9l+ReDKK6/Utm3btHXr1szjox/9qG688cbMc7Zhceno6NB7772niRMnFvd/g3k7lakIrVq1ygQCAbNy5Urz5ptvmr/6q78y1dXVOWeJwZ729nazZcsWs2XLFiPJ/Md//IfZsmWL+eCDD4wxyUstVVdXm0cffdS88cYb5rrrruv3UksLFiwwL7/8snn++efNzJkzcy611Nraampra80Xv/hFs337drNq1SpTVlbGpZZGwFe/+lVTVVVl1q1bl3OZkK6ursw6t912m5k6dap59tlnzaZNm0xDQ4NpaGjILE9fJuSqq64yW7duNU899ZSZMGFCv5cJ+cY3vmHeeustc++993KZlxHy7W9/26xfv97s3r3bvPHGG+bb3/62cblc5plnnjHGsP2KUfbZ7sawDQvd17/+dbNu3Tqze/du88ILL5hFixaZ8ePHm4MHDxpjinf7EZ99/OQnPzFTp041fr/fXHjhheall15yekinreeee85IOu5x0003GWOSl1v6x3/8R1NbW2sCgYC58sorzc6dO3O+48iRI+aGG24wFRUVJhgMmi9/+cumvb09Z53XX3/dfOxjHzOBQMBMnjzZ3HXXXbb+xFGtv20nyfz85z/PrNPd3W3+5m/+xowZM8aUlZWZz33uc+bAgQM537Nnzx5z9dVXm9LSUjN+/Hjz9a9/3USj0Zx1nnvuOXPeeecZv99vzjzzzJzfgeH7yle+Ys444wzj9/vNhAkTzJVXXpkJT2PYfsWob3yyDQvb9ddfbyZOnGj8fr+ZPHmyuf76682uXbsyy4t1+7mMMSZ/86oAAABAL475BAAAgDXEJwAAAKwhPgEAAGAN8QkAAABriE8AAABYQ3wCAADAGuITAAAA1hCfAAAAsIb4BAAAgDXEJwAAAKwhPgEAAGDN/w+W6NFRmvJfpgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# 绘图\n",
    "max_v = [epi['node_embedding'].max() for epi in problems.problem_list]\n",
    "mean_v = [epi['node_embedding'].mean() for epi in problems.problem_list]\n",
    "fig = plt.figure(figsize=(8,8))\n",
    "x = np.arange(len(max_v))\n",
    "plt.plot(x, sorted(max_v), \"-\", label='max', linewidth=1)\n",
    "plt.plot(x, sorted(mean_v), \"-\", label='mean', linewidth=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7e507f594160>]"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# 绘图\n",
    "max_v = [p['node_embedding'].max() for p in problems.problem_list]\n",
    "mean_v = [p['node_embedding'].mean() for p in problems.problem_list]\n",
    "fig = plt.figure(figsize=(8,8))\n",
    "x = np.arange(len(max_v))\n",
    "plt.plot(x, sorted(max_v), \"-\", label='max', linewidth=1)\n",
    "plt.plot(x, sorted(mean_v), \"-\", label='mean', linewidth=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "------------------------------------------------------------\n",
      "atsp20_problem      \t10000\t3.8436918431451197\n",
      "\tposition          \tin range [0.0, 1.0]\n",
      "\tnode_embedding    \tin range [2.3035433, 55.350384]\n",
      "\n",
      "------------------------------------------------------------\n",
      "55.350384\n",
      "problems_node_embedding 3.6900256\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(array([ 66600, 166600]), array([11, 11]))"
      ]
     },
     "execution_count": 110,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "file_data = load_data_and_check_quantity(['atsp20_problem.pkl'], ENV_NAME, 10000, num_episode, check_ave_obj=True)\n",
    "problems = file_data['atsp20_problem']\n",
    "\n",
    "problems_node_embedding = np.vstack([p['node_embedding'] for p in problems.problem_list])\n",
    "print(problems_node_embedding.max())\n",
    "if problems_node_embedding.max() > 4:\n",
    "    for i in range(5000):\n",
    "        problems.problem_list[i]['node_embedding'] /= 15\n",
    "    problems_node_embedding = np.vstack([p['node_embedding'] for p in problems.problem_list])\n",
    "    print('problems_node_embedding', problems_node_embedding.max())\n",
    "\n",
    "np.where(problems_node_embedding == problems_node_embedding.max())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7e5077c52460>]"
      ]
     },
     "execution_count": 111,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# 绘图\n",
    "max_v = [p['node_embedding'].max() for p in problems.problem_list]\n",
    "mean_v = [p['node_embedding'].mean() for p in problems.problem_list]\n",
    "fig = plt.figure(figsize=(8,8))\n",
    "x = np.arange(len(max_v))\n",
    "plt.plot(x, sorted(max_v), \"-\", label='max', linewidth=1)\n",
    "plt.plot(x, sorted(mean_v), \"-\", label='mean', linewidth=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
