{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/1739678401/anaconda3/envs/dataclean/lib/python3.7/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",
      "Using backend: pytorch\n"
     ]
    }
   ],
   "source": [
    "import logging\n",
    "import sys, os\n",
    "import time\n",
    "import warnings\n",
    "import torch\n",
    "import argparse\n",
    "from pathlib import Path\n",
    "import numpy as np\n",
    "from datetime import datetime\n",
    "from torch.optim.lr_scheduler import ReduceLROnPlateau\n",
    "from torch.nn import MSELoss, L1Loss\n",
    "import torch.distributed as dist\n",
    "import torch.multiprocessing as mp\n",
    "from torch.nn.parallel import DistributedDataParallel as DDP\n",
    "from torch.serialization import save\n",
    "from gnn.model.metric import EarlyStopping\n",
    "from gnn.model.gated_solv_network import GatedGCNSolvationNetwork, InteractionMap, SelfInteractionMap\n",
    "from gnn.data.dataset import SolvationDataset, train_validation_test_split, solvent_split, element_split, substructure_split, stratified_solvent_split, stratified_split\n",
    "from gnn.data.dataloader import DataLoaderSolvation\n",
    "from gnn.data.grapher import HeteroMoleculeGraph\n",
    "from gnn.data.featurizer import (\n",
    "    SolventAtomFeaturizer,\n",
    "    BondAsNodeFeaturizerFull,\n",
    "    SolventGlobalFeaturizer,\n",
    ")\n",
    "from gnn.data.solvent_graph import HeteroMoleculeGraph2\n",
    "from gnn.data.dataset import load_mols_labels\n",
    "from gnn.utils import (\n",
    "    load_checkpoints,\n",
    "    pickle_load,\n",
    "    save_checkpoints,\n",
    "    seed_torch,\n",
    "    pickle_dump,\n",
    "    yaml_dump,\n",
    ")\n",
    "from sklearn.metrics import mean_squared_error\n",
    "\n",
    "ls=[]\n",
    "p=[]\n",
    "def parse_args():\n",
    "    parser = argparse.ArgumentParser(description=\"GatedSolvationNetwork\")\n",
    "\n",
    "    # input files and global variables\n",
    "    parser.add_argument('--dataset-file', type=str, default=\"/home/1739678401/2024.9dataclean/MMGNN_0901/data/exp_data.csv\")\n",
    "    parser.add_argument('--dataset-pickle', type=str, default=\"/home/1739678401/2024.9dataclean/MMGNN_0901/result/transfer/graphers.pkl\")\n",
    "    parser.add_argument('--dielectric-constants', type=str, default=None)\n",
    "    parser.add_argument('--molecular-refractivity', type=bool, default=False)\n",
    "    parser.add_argument('--molecular-volume', type=bool, default=False)\n",
    "\n",
    "    # output dir\n",
    "    parser.add_argument('--save-dir', type=str, default=\"/home/1739678401/2024.9dataclean/MMGNN_0901/result/transfer\")\n",
    "    parser.add_argument(\"--load-dataset\", type=int, default=0, help=\"read dataset\")\n",
    "    # training params\n",
    "    parser.add_argument('--random-seed', type=int, default=50)\n",
    "    parser.add_argument('--feature-scaling', type=bool, default=True)\n",
    "    parser.add_argument('--solvent-split', type=str, default=None)\n",
    "    parser.add_argument('--solvent-stratified-split', type=str, default=None)\n",
    "    parser.add_argument('--solvent-stratified-frac', type=float, default=0.1)\n",
    "    parser.add_argument('--stratified-split', type=bool, default=False)\n",
    "    parser.add_argument('--element-split', type=str, default=None)\n",
    "    parser.add_argument('--scaffold-split', type=bool, default=False)\n",
    "    parser.add_argument('--attention-map', type=str, default=None)\n",
    "    parser.add_argument('--partial-charges', type=str, default=None)\n",
    "\n",
    "\n",
    "    # embedding layer\n",
    "    parser.add_argument(\"--embedding-size\", type=int, default=48)\n",
    "\n",
    "    # gated layer\n",
    "    parser.add_argument(\"--gated-num-layers\", type=int, default=3)\n",
    "    parser.add_argument(\"--gated-hidden-size\", type=int, nargs=\"+\", default=[1600])\n",
    "    parser.add_argument(\"--gated-num-fc-layers\", type=int, default=3)\n",
    "    parser.add_argument(\"--gated-graph-norm\", type=int, default=0)\n",
    "    parser.add_argument(\"--gated-batch-norm\", type=int, default=0)\n",
    "    parser.add_argument(\"--gated-activation\", type=str, default=\"LeakyReLU\")\n",
    "    parser.add_argument(\"--gated-residual\", type=int, default=1)\n",
    "    parser.add_argument(\"--gated-dropout\", type=float, default=0.0)\n",
    "\n",
    "    # readout layer\n",
    "    parser.add_argument(\n",
    "        \"--num-lstm-iters\",\n",
    "        type=int,\n",
    "        default=6,\n",
    "        help=\"number of iterations for the LSTM in set2set readout layer\",\n",
    "    )\n",
    "    parser.add_argument(\n",
    "        \"--num-lstm-layers\",\n",
    "        type=int,\n",
    "        default=3,\n",
    "        help=\"number of layers for the LSTM in set2set readout layer\",\n",
    "    )\n",
    "\n",
    "    # fc layer\n",
    "    parser.add_argument(\"--fc-num-layers\", type=int, default=4)\n",
    "    parser.add_argument(\"--fc-hidden-size\", type=int, nargs=\"+\", default=[1400])\n",
    "    parser.add_argument(\"--fc-batch-norm\", type=int, default=0)\n",
    "    parser.add_argument(\"--fc-activation\", type=str, default=\"LeakyReLU\")\n",
    "    parser.add_argument(\"--fc-dropout\", type=float, default=0.5)\n",
    "\n",
    "    # training\n",
    "    parser.add_argument(\"--start-epoch\", type=int, default=1)\n",
    "    parser.add_argument(\"--epochs\", type=int, default=1000, help=\"number of epochs\")\n",
    "    parser.add_argument(\"--batch-size\", type=int, default=64, help=\"batch size\")\n",
    "    parser.add_argument(\"--lr\", type=float, default=0.0001, help=\"learning rate\")\n",
    "    parser.add_argument(\"--weight-decay\", type=float, default=0.0, help=\"weight decay\")\n",
    "    parser.add_argument(\"--restore\", type=int, default=0, help=\"read checkpoints\")\n",
    "    parser.add_argument(\n",
    "        \"--dataset-state-dict-filename\", type=str, default=\"dataset_state_dict.pkl\"\n",
    "    )\n",
    "    # gpu\n",
    "    parser.add_argument(\n",
    "        \"--gpu\", type=int, default=3, help=\"GPU index. None to use CPU.\"\n",
    "    )\n",
    "\n",
    "    parser.add_argument(\n",
    "        \"--distributed\",\n",
    "        type=int,\n",
    "        default=0,\n",
    "        help=\"DDP training, --gpu is ignored if this is True\",\n",
    "    )\n",
    "    parser.add_argument(\n",
    "        \"--num-gpu\",\n",
    "        type=int,\n",
    "        default=1,\n",
    "        help=\"Number of GPU to use in distributed mode; ignored otherwise.\",\n",
    "    )\n",
    "    parser.add_argument(\n",
    "        \"--dist-url\",\n",
    "        default=\"tcp://localhost:13456\",\n",
    "        type=str,\n",
    "        help=\"url used to set up distributed training\",\n",
    "    )\n",
    "    \n",
    "    parser.add_argument(\"--dist-backend\", type=str, default=\"nccl\")\n",
    "\n",
    "    # output file (needed by hypertunity)\n",
    "    parser.add_argument(\"--output_file\", type=str, default=\"results.pkl\")\n",
    "\n",
    "    args = parser.parse_args(args=[])\n",
    "    if len(args.gated_hidden_size) == 1:\n",
    "        args.gated_hidden_size = args.gated_hidden_size * args.gated_num_layers\n",
    "    else:\n",
    "        assert len(args.gated_hidden_size) == args.gated_num_layers, (\n",
    "            \"length of `gat-hidden-size` should be equal to `num-gat-layers`, but got \"\n",
    "            \"{} and {}.\".format(args.gated_hidden_size, args.gated_num_layers)\n",
    "        )\n",
    "\n",
    "    if len(args.fc_hidden_size) == 1:\n",
    "        val = 2 * args.gated_hidden_size[-1]\n",
    "        args.fc_hidden_size = [max(val // 2 ** i, 8) for i in range(args.fc_num_layers)]\n",
    "    else:\n",
    "        assert len(args.fc_hidden_size) == args.fc_num_layers, (\n",
    "            \"length of `fc-hidden-size` should be equal to `num-fc-layers`, but got \"\n",
    "            \"{} and {}.\".format(args.fc_hidden_size, args.fc_num_layers)\n",
    "        )\n",
    "    return args\n",
    "\n",
    "def train(optimizer, model, nodes,nodes1, data_loader, loss_fn, metric_fn, device=None):\n",
    "    \"\"\"\n",
    "    Args:\n",
    "        metric_fn (function): the function should be using a `sum` reduction method.\n",
    "    \"\"\"\n",
    "\n",
    "    model.train()\n",
    "\n",
    "    epoch_loss = 0.0\n",
    "    accuracy = 0.0\n",
    "    count = 0.0\n",
    "\n",
    "    for it, (solute_batched_graph, solvent_batched_graph, label) in enumerate(data_loader):\n",
    "        solute_feats = {nt: solute_batched_graph.nodes[nt].data[\"feat\"] for nt in nodes1}\n",
    "        solvent_feats = {nt: solvent_batched_graph.nodes[nt].data[\"feat\"] for nt in nodes}\n",
    "        target = torch.squeeze(label[\"value\"])\n",
    "        solute_norm_atom = label[\"solute_norm_atom\"]\n",
    "        solute_norm_bond = label[\"solute_norm_bond\"]\n",
    "        solvent_norm_atom = label[\"solvent_norm_atom\"]\n",
    "        solvent_norm_bond = label[\"solvent_norm_bond\"]\n",
    "\n",
    "        if device is not None:\n",
    "            solute_feats = {k: v.to(device) for k, v in solute_feats.items()}\n",
    "            solvent_feats = {k: v.to(device) for k, v in solvent_feats.items()}\n",
    "            target = target.to(device)\n",
    "            solute_norm_atom = solute_norm_atom.to(device)\n",
    "            solute_norm_bond = solute_norm_bond.to(device)\n",
    "            solvent_norm_atom = solvent_norm_atom.to(device)\n",
    "            solvent_norm_bond = solvent_norm_bond.to(device)\n",
    "        pred,_ = model(solute_batched_graph, solvent_batched_graph, solute_feats, \n",
    "                     solvent_feats, solute_norm_atom, solute_norm_bond, \n",
    "                     solvent_norm_atom, solvent_norm_bond)\n",
    "\n",
    "        pred = pred.view(-1)\n",
    "        target = target.view(-1)\n",
    "        loss = loss_fn(pred, target)\n",
    "        optimizer.zero_grad()\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        epoch_loss += loss.detach().item()\n",
    "        accuracy += metric_fn(pred, target).detach().item()\n",
    "        count += len(target)\n",
    "    \n",
    "    epoch_loss /= it + 1\n",
    "    accuracy /= count\n",
    "\n",
    "    return epoch_loss, accuracy\n",
    "\n",
    "def evaluate(model, nodes,nodes1, data_loader, metric_fn, scaler = None, device=None, return_preds=False):\n",
    "    \"\"\"\n",
    "    Evaluate the accuracy of a validation set of test set.\n",
    "    Args:\n",
    "        metric_fn (function): the function should be using a `sum` reduction method.\n",
    "    \"\"\"\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        accuracy = 0.0\n",
    "        count = 0.0\n",
    "\n",
    "        preds = []\n",
    "        y_true = []\n",
    "\n",
    "        for solute_batched_graph, solvent_batched_graph, label in data_loader:\n",
    "            solute_feats = {nt: solute_batched_graph.nodes[nt].data[\"feat\"] for nt in nodes1}\n",
    "            solvent_feats = {nt: solvent_batched_graph.nodes[nt].data[\"feat\"] for nt in nodes}\n",
    "            target = torch.squeeze(label[\"value\"])\n",
    "            #stdev = label[\"scaler_stdev\"]\n",
    "            solvent_norm_atom = label[\"solvent_norm_atom\"]\n",
    "            solvent_norm_bond = label[\"solvent_norm_bond\"]\n",
    "            solute_norm_atom = label[\"solute_norm_atom\"]\n",
    "            solute_norm_bond = label[\"solute_norm_bond\"]\n",
    "\n",
    "            if device is not None:\n",
    "                solute_feats = {k: v.to(device) for k, v in solute_feats.items()}\n",
    "                solvent_feats = {k: v.to(device) for k, v in solvent_feats.items()}\n",
    "                target = target.to(device)\n",
    "                solute_norm_atom = solute_norm_atom.to(device)\n",
    "                solute_norm_bond = solute_norm_bond.to(device)\n",
    "                solvent_norm_atom = solvent_norm_atom.to(device)\n",
    "                solvent_norm_bond = solvent_norm_bond.to(device)\n",
    "\n",
    "            pred,loss_1 = model(solute_batched_graph, solvent_batched_graph, solute_feats, \n",
    "                     solvent_feats, solute_norm_atom, solute_norm_bond, \n",
    "                     solvent_norm_atom, solvent_norm_bond)\n",
    "            pred = pred.view(-1)\n",
    "            target = target.view(-1)\n",
    "\n",
    "            if scaler is not None:\n",
    "                pred = scaler.inverse_transform(pred.cpu())\n",
    "                pred = pred.to(device)\n",
    "\n",
    "            accuracy += metric_fn(pred, target).detach().item()\n",
    "            count += len(target)\n",
    "\n",
    "            batch_pred = pred.tolist()\n",
    "            batch_target = target.tolist()\n",
    "            preds.extend(batch_pred)\n",
    "            y_true.extend(batch_target)\n",
    "\n",
    "    if return_preds:\n",
    "        return y_true, preds\n",
    "\n",
    "    else:\n",
    "        return accuracy / count\n",
    "\n",
    "def grapher(dielectric_constant=None, mol_volume=False, mol_refract=False, partial_charges=None,lable=False):\n",
    "    atom_featurizer = SolventAtomFeaturizer(partial_charges=partial_charges)\n",
    "    bond_featurizer = BondAsNodeFeaturizerFull(length_featurizer=None, dative=False)\n",
    "    global_featurizer = SolventGlobalFeaturizer(dielectric_constant=dielectric_constant, mol_volume=mol_volume, mol_refract=mol_refract)\n",
    "    if lable:\n",
    "        grapher = HeteroMoleculeGraph(atom_featurizer, bond_featurizer, global_featurizer, self_loop=True)\n",
    "    else:\n",
    "        grapher = HeteroMoleculeGraph2(atom_featurizer, bond_featurizer, global_featurizer, self_loop=True)\n",
    "\n",
    "    return grapher\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Namespace(attention_map=None, batch_size=64, dataset_file='/home/1739678401/2024.9dataclean/MMGNN_0901/data/exp_data.csv', dataset_pickle='/home/1739678401/2024.9dataclean/MMGNN_0901/result/transfer/graphers.pkl', dataset_state_dict_filename='dataset_state_dict.pkl', dielectric_constants=None, dist_backend='nccl', dist_url='tcp://localhost:13456', distributed=0, element_split=None, embedding_size=48, epochs=1000, fc_activation='LeakyReLU', fc_batch_norm=0, fc_dropout=0.5, fc_hidden_size=[3200, 1600, 800, 400], fc_num_layers=4, feature_scaling=True, gated_activation='LeakyReLU', gated_batch_norm=0, gated_dropout=0.0, gated_graph_norm=0, gated_hidden_size=[1600, 1600, 1600], gated_num_fc_layers=3, gated_num_layers=3, gated_residual=1, gpu=3, load_dataset=0, lr=0.0001, molecular_refractivity=False, molecular_volume=False, num_gpu=1, num_lstm_iters=6, num_lstm_layers=3, output_file='results.pkl', partial_charges=None, random_seed=50, restore=0, save_dir='/home/1739678401/2024.9dataclean/MMGNN_0901/result/transfer', scaffold_split=False, solvent_split=None, solvent_stratified_frac=0.1, solvent_stratified_split=None, start_epoch=1, stratified_split=False, weight_decay=0.0)\n"
     ]
    }
   ],
   "source": [
    "args = parse_args()\n",
    "print(args)\n",
    "\n",
    "if args.save_dir is not None:\n",
    "    os.makedirs(args.save_dir, exist_ok=True)\n",
    "\n",
    "logging.basicConfig(\n",
    "filename=os.path.join(args.save_dir, '{}.log'.format(\n",
    "    datetime.now().strftime(\"gnn_%Y_%m_%d-%I_%M_%p\"))),\n",
    "format=\"%(asctime)s:%(name)s:%(levelname)s: %(message)s\",\n",
    "level=logging.INFO,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "random_seed = args.random_seed\n",
    "world_size=None\n",
    "seed_torch(random_seed)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "Start training at:  2025-05-07 15:15:23.075625\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:23] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:24] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:27] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:28] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:30] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n",
      "[15:15:31] WARNING: not removing hydrogen atom without neighbors\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "len(self._species)=12,type(self._species)=<class 'list'>\n",
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "10\n",
      "11\n",
      "12\n",
      "13\n",
      "14\n",
      "15\n",
      "16\n",
      "17\n",
      "18\n",
      "19\n",
      "20\n",
      "21\n",
      "22\n",
      "23\n",
      "24\n",
      "25\n",
      "26\n",
      "27\n",
      "28\n",
      "29\n",
      "30\n",
      "31\n",
      "32\n",
      "33\n",
      "34\n",
      "35\n",
      "36\n",
      "37\n",
      "38\n",
      "39\n",
      "40\n",
      "41\n",
      "42\n",
      "43\n",
      "44\n",
      "45\n",
      "46\n",
      "47\n",
      "48\n",
      "49\n",
      "50\n",
      "51\n",
      "52\n",
      "53\n",
      "54\n",
      "55\n",
      "56\n",
      "57\n",
      "58\n",
      "59\n",
      "60\n",
      "61\n",
      "62\n",
      "63\n",
      "64\n",
      "65\n",
      "66\n",
      "67\n",
      "68\n",
      "69\n",
      "70\n",
      "71\n",
      "72\n",
      "73\n",
      "74\n",
      "75\n",
      "76\n",
      "77\n",
      "78\n",
      "79\n",
      "80\n",
      "81\n",
      "82\n",
      "83\n",
      "84\n",
      "85\n",
      "86\n",
      "87\n",
      "88\n",
      "89\n",
      "90\n",
      "91\n",
      "92\n",
      "93\n",
      "94\n",
      "95\n",
      "96\n",
      "97\n",
      "98\n",
      "99\n",
      "100\n",
      "101\n",
      "102\n",
      "103\n",
      "104\n",
      "105\n",
      "106\n",
      "107\n",
      "108\n",
      "109\n",
      "110\n",
      "111\n",
      "112\n",
      "113\n",
      "114\n",
      "115\n",
      "116\n",
      "117\n",
      "118\n",
      "119\n",
      "120\n",
      "121\n",
      "122\n",
      "123\n",
      "124\n",
      "125\n",
      "126\n",
      "127\n",
      "128\n",
      "129\n",
      "130\n",
      "131\n",
      "132\n",
      "133\n",
      "134\n",
      "135\n",
      "136\n",
      "137\n",
      "138\n",
      "139\n",
      "140\n",
      "141\n",
      "142\n",
      "143\n",
      "144\n",
      "145\n",
      "146\n",
      "147\n",
      "148\n",
      "149\n",
      "150\n",
      "151\n",
      "152\n",
      "153\n",
      "154\n",
      "155\n",
      "156\n",
      "157\n",
      "158\n",
      "159\n",
      "160\n",
      "161\n",
      "162\n",
      "163\n",
      "164\n",
      "165\n",
      "166\n",
      "167\n",
      "168\n",
      "169\n",
      "170\n",
      "171\n",
      "172\n",
      "173\n",
      "174\n",
      "175\n",
      "176\n",
      "177\n",
      "178\n",
      "179\n",
      "180\n",
      "181\n",
      "182\n",
      "183\n",
      "184\n",
      "185\n",
      "186\n",
      "187\n",
      "188\n",
      "189\n",
      "190\n",
      "191\n",
      "192\n",
      "193\n",
      "194\n",
      "195\n",
      "196\n",
      "197\n",
      "198\n",
      "199\n",
      "200\n",
      "201\n",
      "202\n",
      "203\n",
      "204\n",
      "205\n",
      "206\n",
      "207\n",
      "208\n",
      "209\n",
      "210\n",
      "211\n",
      "212\n",
      "213\n",
      "214\n",
      "215\n",
      "216\n",
      "217\n",
      "218\n",
      "219\n",
      "220\n",
      "221\n",
      "222\n",
      "223\n",
      "224\n",
      "225\n",
      "226\n",
      "227\n",
      "228\n",
      "229\n",
      "230\n",
      "231\n",
      "232\n",
      "233\n",
      "234\n",
      "235\n",
      "236\n",
      "237\n",
      "238\n",
      "239\n",
      "240\n",
      "241\n",
      "242\n",
      "243\n",
      "244\n",
      "245\n",
      "246\n",
      "247\n",
      "248\n",
      "249\n",
      "250\n",
      "251\n",
      "252\n",
      "253\n",
      "254\n",
      "255\n",
      "256\n",
      "257\n",
      "258\n",
      "259\n",
      "260\n",
      "261\n",
      "262\n",
      "263\n",
      "264\n",
      "265\n",
      "266\n",
      "267\n",
      "268\n",
      "269\n",
      "270\n",
      "271\n",
      "272\n",
      "273\n",
      "274\n",
      "275\n",
      "276\n",
      "277\n",
      "278\n",
      "279\n",
      "280\n",
      "281\n",
      "282\n",
      "283\n",
      "284\n",
      "285\n",
      "286\n",
      "287\n",
      "288\n",
      "289\n",
      "290\n",
      "291\n",
      "292\n",
      "293\n",
      "294\n",
      "295\n",
      "296\n",
      "297\n",
      "298\n",
      "299\n",
      "300\n",
      "301\n",
      "302\n",
      "303\n",
      "304\n",
      "305\n",
      "306\n",
      "307\n",
      "308\n",
      "309\n",
      "310\n",
      "311\n",
      "312\n",
      "313\n",
      "314\n",
      "315\n",
      "316\n",
      "317\n",
      "318\n",
      "319\n",
      "320\n",
      "321\n",
      "322\n",
      "323\n",
      "324\n",
      "325\n",
      "326\n",
      "327\n",
      "328\n",
      "329\n",
      "330\n",
      "331\n",
      "332\n",
      "333\n",
      "334\n",
      "335\n",
      "336\n",
      "337\n",
      "338\n",
      "339\n",
      "340\n",
      "341\n",
      "342\n",
      "343\n",
      "344\n",
      "345\n",
      "346\n",
      "347\n",
      "348\n",
      "349\n",
      "350\n",
      "351\n",
      "352\n",
      "353\n",
      "354\n",
      "355\n",
      "356\n",
      "357\n",
      "358\n",
      "359\n",
      "360\n",
      "361\n",
      "362\n",
      "363\n",
      "364\n",
      "365\n",
      "366\n",
      "367\n",
      "368\n",
      "369\n",
      "370\n",
      "371\n",
      "372\n",
      "373\n",
      "374\n",
      "375\n",
      "376\n",
      "377\n",
      "378\n",
      "379\n",
      "380\n",
      "381\n",
      "382\n",
      "383\n",
      "384\n",
      "385\n",
      "386\n",
      "387\n",
      "388\n",
      "389\n",
      "390\n",
      "391\n",
      "392\n",
      "393\n",
      "394\n",
      "395\n",
      "396\n",
      "397\n",
      "398\n",
      "399\n",
      "400\n",
      "401\n",
      "402\n",
      "403\n",
      "404\n",
      "405\n",
      "406\n",
      "407\n",
      "408\n",
      "409\n",
      "410\n",
      "411\n",
      "412\n",
      "413\n",
      "414\n",
      "415\n",
      "416\n",
      "417\n",
      "418\n",
      "419\n",
      "420\n",
      "421\n",
      "422\n",
      "423\n",
      "424\n",
      "425\n",
      "426\n",
      "427\n",
      "428\n",
      "429\n",
      "430\n",
      "431\n",
      "432\n",
      "433\n",
      "434\n",
      "435\n",
      "436\n",
      "437\n",
      "438\n",
      "439\n",
      "440\n",
      "441\n",
      "442\n",
      "443\n",
      "444\n",
      "445\n",
      "446\n",
      "447\n",
      "448\n",
      "449\n",
      "450\n",
      "451\n",
      "452\n",
      "453\n",
      "454\n",
      "455\n",
      "456\n",
      "457\n",
      "458\n",
      "459\n",
      "460\n",
      "461\n",
      "462\n",
      "463\n",
      "464\n",
      "465\n",
      "466\n",
      "467\n",
      "468\n",
      "469\n",
      "470\n",
      "471\n",
      "472\n",
      "473\n",
      "474\n",
      "475\n",
      "476\n",
      "477\n",
      "478\n",
      "479\n",
      "480\n",
      "481\n",
      "482\n",
      "483\n",
      "484\n",
      "485\n",
      "486\n",
      "487\n",
      "488\n",
      "489\n",
      "490\n",
      "491\n",
      "492\n",
      "493\n",
      "494\n",
      "495\n",
      "496\n",
      "497\n",
      "498\n",
      "499\n",
      "500\n",
      "501\n",
      "502\n",
      "503\n",
      "504\n",
      "505\n",
      "506\n",
      "507\n",
      "508\n",
      "509\n",
      "510\n",
      "511\n",
      "512\n",
      "513\n",
      "514\n",
      "515\n",
      "516\n",
      "517\n",
      "518\n",
      "519\n",
      "520\n",
      "521\n",
      "522\n",
      "523\n",
      "524\n",
      "525\n",
      "526\n",
      "527\n",
      "528\n",
      "529\n",
      "530\n",
      "531\n",
      "532\n",
      "533\n",
      "534\n",
      "535\n",
      "536\n",
      "537\n",
      "538\n",
      "539\n",
      "540\n",
      "541\n",
      "542\n",
      "543\n",
      "544\n",
      "545\n",
      "546\n",
      "547\n",
      "548\n",
      "549\n",
      "550\n",
      "551\n",
      "552\n",
      "553\n",
      "554\n",
      "555\n",
      "556\n",
      "557\n",
      "558\n",
      "559\n",
      "560\n",
      "561\n",
      "562\n",
      "563\n",
      "564\n",
      "565\n",
      "566\n",
      "567\n",
      "568\n",
      "569\n",
      "570\n",
      "571\n",
      "572\n",
      "573\n",
      "574\n",
      "575\n",
      "576\n",
      "577\n",
      "578\n",
      "579\n",
      "580\n",
      "581\n",
      "582\n",
      "583\n",
      "584\n",
      "585\n",
      "586\n",
      "587\n",
      "588\n",
      "589\n",
      "590\n",
      "591\n",
      "592\n",
      "593\n",
      "594\n",
      "595\n",
      "596\n",
      "597\n",
      "598\n",
      "599\n",
      "600\n",
      "601\n",
      "602\n",
      "603\n",
      "604\n",
      "605\n",
      "606\n",
      "607\n",
      "608\n",
      "609\n",
      "610\n",
      "611\n",
      "612\n",
      "613\n",
      "614\n",
      "615\n",
      "616\n",
      "617\n",
      "618\n",
      "619\n",
      "620\n",
      "621\n",
      "622\n",
      "623\n",
      "624\n",
      "625\n",
      "626\n",
      "627\n",
      "628\n",
      "629\n",
      "630\n",
      "631\n",
      "632\n",
      "633\n",
      "634\n",
      "635\n",
      "636\n",
      "637\n",
      "638\n",
      "639\n",
      "640\n",
      "641\n",
      "642\n",
      "643\n",
      "644\n",
      "645\n",
      "646\n",
      "647\n",
      "648\n",
      "649\n",
      "650\n",
      "651\n",
      "652\n",
      "653\n",
      "654\n",
      "655\n",
      "656\n",
      "657\n",
      "658\n",
      "659\n",
      "660\n",
      "661\n",
      "662\n",
      "663\n",
      "664\n",
      "665\n",
      "666\n",
      "667\n",
      "668\n",
      "669\n",
      "670\n",
      "671\n",
      "672\n",
      "673\n",
      "674\n",
      "675\n",
      "676\n",
      "677\n",
      "678\n",
      "679\n",
      "680\n",
      "681\n",
      "682\n",
      "683\n",
      "684\n",
      "685\n",
      "686\n",
      "687\n",
      "688\n",
      "689\n",
      "690\n",
      "691\n",
      "692\n",
      "693\n",
      "694\n",
      "695\n",
      "696\n",
      "697\n",
      "698\n",
      "699\n",
      "700\n",
      "701\n",
      "702\n",
      "703\n",
      "704\n",
      "705\n",
      "706\n",
      "707\n",
      "708\n",
      "709\n",
      "710\n",
      "711\n",
      "712\n",
      "713\n",
      "714\n",
      "715\n",
      "716\n",
      "717\n",
      "718\n",
      "719\n",
      "720\n",
      "721\n",
      "722\n",
      "723\n",
      "724\n",
      "725\n",
      "726\n",
      "727\n",
      "728\n",
      "729\n",
      "730\n",
      "731\n",
      "732\n",
      "733\n",
      "734\n",
      "735\n",
      "736\n",
      "737\n",
      "738\n",
      "739\n",
      "740\n",
      "741\n",
      "742\n",
      "743\n",
      "744\n",
      "745\n",
      "746\n",
      "747\n",
      "748\n",
      "749\n",
      "750\n",
      "751\n",
      "752\n",
      "753\n",
      "754\n",
      "755\n",
      "756\n",
      "757\n",
      "758\n",
      "759\n",
      "760\n",
      "761\n",
      "762\n",
      "763\n",
      "764\n",
      "765\n",
      "766\n",
      "767\n",
      "768\n",
      "769\n",
      "770\n",
      "771\n",
      "772\n",
      "773\n",
      "774\n",
      "775\n",
      "776\n",
      "777\n",
      "778\n",
      "779\n",
      "780\n",
      "781\n",
      "782\n",
      "783\n",
      "784\n",
      "785\n",
      "786\n",
      "787\n",
      "788\n",
      "789\n",
      "790\n",
      "791\n",
      "792\n",
      "793\n",
      "794\n",
      "795\n",
      "796\n",
      "797\n",
      "798\n",
      "799\n",
      "800\n",
      "801\n",
      "802\n",
      "803\n",
      "804\n",
      "805\n",
      "806\n",
      "807\n",
      "808\n",
      "809\n",
      "810\n",
      "811\n",
      "812\n",
      "813\n",
      "814\n",
      "815\n",
      "816\n",
      "817\n",
      "818\n",
      "819\n",
      "820\n",
      "821\n",
      "822\n",
      "823\n",
      "824\n",
      "825\n",
      "826\n",
      "827\n",
      "828\n",
      "829\n",
      "830\n",
      "831\n",
      "832\n",
      "833\n",
      "834\n",
      "835\n",
      "836\n",
      "837\n",
      "838\n",
      "839\n",
      "840\n",
      "841\n",
      "842\n",
      "843\n",
      "844\n",
      "845\n",
      "846\n",
      "847\n",
      "848\n",
      "849\n",
      "850\n",
      "851\n",
      "852\n",
      "853\n",
      "854\n",
      "855\n",
      "856\n",
      "857\n",
      "858\n",
      "859\n",
      "860\n",
      "861\n",
      "862\n",
      "863\n",
      "864\n",
      "865\n",
      "866\n",
      "867\n",
      "868\n",
      "869\n",
      "870\n",
      "871\n",
      "872\n",
      "873\n",
      "874\n",
      "875\n",
      "876\n",
      "877\n",
      "878\n",
      "879\n",
      "880\n",
      "881\n",
      "882\n",
      "883\n",
      "884\n",
      "885\n",
      "886\n",
      "887\n",
      "888\n",
      "889\n",
      "890\n",
      "891\n",
      "892\n",
      "893\n",
      "894\n",
      "895\n",
      "896\n",
      "897\n",
      "898\n",
      "899\n",
      "900\n",
      "901\n",
      "902\n",
      "903\n",
      "904\n",
      "905\n",
      "906\n",
      "907\n",
      "908\n",
      "909\n",
      "910\n",
      "911\n",
      "912\n",
      "913\n",
      "914\n",
      "915\n",
      "916\n",
      "917\n",
      "918\n",
      "919\n",
      "920\n",
      "921\n",
      "922\n",
      "923\n",
      "924\n",
      "925\n",
      "926\n",
      "927\n",
      "928\n",
      "929\n",
      "930\n",
      "931\n",
      "932\n",
      "933\n",
      "934\n",
      "935\n",
      "936\n",
      "937\n",
      "938\n",
      "939\n",
      "940\n",
      "941\n",
      "942\n",
      "943\n",
      "944\n",
      "945\n",
      "946\n",
      "947\n",
      "948\n",
      "949\n",
      "950\n",
      "951\n",
      "952\n",
      "953\n",
      "954\n",
      "955\n",
      "956\n",
      "957\n",
      "958\n",
      "959\n",
      "960\n",
      "961\n",
      "962\n",
      "963\n",
      "964\n",
      "965\n",
      "966\n",
      "967\n",
      "968\n",
      "969\n",
      "970\n",
      "971\n",
      "972\n",
      "973\n",
      "974\n",
      "975\n",
      "976\n",
      "977\n",
      "978\n",
      "979\n",
      "980\n",
      "981\n",
      "982\n",
      "983\n",
      "984\n",
      "985\n",
      "986\n",
      "987\n",
      "988\n",
      "989\n",
      "990\n",
      "991\n",
      "992\n",
      "993\n",
      "994\n",
      "995\n",
      "996\n",
      "997\n",
      "998\n",
      "999\n",
      "1000\n",
      "1001\n",
      "1002\n",
      "1003\n",
      "1004\n",
      "1005\n",
      "1006\n",
      "1007\n",
      "1008\n",
      "1009\n",
      "1010\n",
      "1011\n",
      "1012\n",
      "1013\n",
      "1014\n",
      "1015\n",
      "1016\n",
      "1017\n",
      "1018\n",
      "1019\n",
      "1020\n",
      "1021\n",
      "1022\n",
      "1023\n",
      "1024\n",
      "1025\n",
      "1026\n",
      "1027\n",
      "1028\n",
      "1029\n",
      "1030\n",
      "1031\n",
      "1032\n",
      "1033\n",
      "1034\n",
      "1035\n",
      "1036\n",
      "1037\n",
      "1038\n",
      "1039\n",
      "1040\n",
      "1041\n",
      "1042\n",
      "1043\n",
      "1044\n",
      "1045\n",
      "1046\n",
      "1047\n",
      "1048\n",
      "1049\n",
      "1050\n",
      "1051\n",
      "1052\n",
      "1053\n",
      "1054\n",
      "1055\n",
      "1056\n",
      "1057\n",
      "1058\n",
      "1059\n",
      "1060\n",
      "1061\n",
      "1062\n",
      "1063\n",
      "1064\n",
      "1065\n",
      "1066\n",
      "1067\n",
      "1068\n",
      "1069\n",
      "1070\n",
      "1071\n",
      "1072\n",
      "1073\n",
      "1074\n",
      "1075\n",
      "1076\n",
      "1077\n",
      "1078\n",
      "1079\n",
      "1080\n",
      "1081\n",
      "1082\n",
      "1083\n",
      "1084\n",
      "1085\n",
      "1086\n",
      "1087\n",
      "1088\n",
      "1089\n",
      "1090\n",
      "1091\n",
      "1092\n",
      "1093\n",
      "1094\n",
      "1095\n",
      "1096\n",
      "1097\n",
      "1098\n",
      "1099\n",
      "1100\n",
      "1101\n",
      "1102\n",
      "1103\n",
      "1104\n",
      "1105\n",
      "1106\n",
      "1107\n",
      "1108\n",
      "1109\n",
      "1110\n",
      "1111\n",
      "1112\n",
      "1113\n",
      "1114\n",
      "1115\n",
      "1116\n",
      "1117\n",
      "1118\n",
      "1119\n",
      "1120\n",
      "1121\n",
      "1122\n",
      "1123\n",
      "1124\n",
      "1125\n",
      "1126\n",
      "1127\n",
      "1128\n",
      "1129\n",
      "1130\n",
      "1131\n",
      "1132\n",
      "1133\n",
      "1134\n",
      "1135\n",
      "1136\n",
      "1137\n",
      "1138\n",
      "1139\n",
      "1140\n",
      "1141\n",
      "1142\n",
      "1143\n",
      "1144\n",
      "1145\n",
      "1146\n",
      "1147\n",
      "1148\n",
      "1149\n",
      "1150\n",
      "1151\n",
      "1152\n",
      "1153\n",
      "1154\n",
      "1155\n",
      "1156\n",
      "1157\n",
      "1158\n",
      "1159\n",
      "1160\n",
      "1161\n",
      "1162\n",
      "1163\n",
      "1164\n",
      "1165\n",
      "1166\n",
      "1167\n",
      "1168\n",
      "1169\n",
      "1170\n",
      "1171\n",
      "1172\n",
      "1173\n",
      "1174\n",
      "1175\n",
      "1176\n",
      "1177\n",
      "1178\n",
      "1179\n",
      "1180\n",
      "1181\n",
      "1182\n",
      "1183\n",
      "1184\n",
      "1185\n",
      "1186\n",
      "1187\n",
      "1188\n",
      "1189\n",
      "1190\n",
      "1191\n",
      "1192\n",
      "1193\n",
      "1194\n",
      "1195\n",
      "1196\n",
      "1197\n",
      "1198\n",
      "1199\n",
      "1200\n",
      "1201\n",
      "1202\n",
      "1203\n",
      "1204\n",
      "1205\n",
      "1206\n",
      "1207\n",
      "1208\n",
      "1209\n",
      "1210\n",
      "1211\n",
      "1212\n",
      "1213\n",
      "1214\n",
      "1215\n",
      "1216\n",
      "1217\n",
      "1218\n",
      "1219\n",
      "1220\n",
      "1221\n",
      "1222\n",
      "1223\n",
      "1224\n",
      "1225\n",
      "1226\n",
      "1227\n",
      "1228\n",
      "1229\n",
      "1230\n",
      "1231\n",
      "1232\n",
      "1233\n",
      "1234\n",
      "1235\n",
      "1236\n",
      "1237\n",
      "1238\n",
      "1239\n",
      "1240\n",
      "1241\n",
      "1242\n",
      "1243\n",
      "1244\n",
      "1245\n",
      "1246\n",
      "1247\n",
      "1248\n",
      "1249\n",
      "1250\n",
      "1251\n",
      "1252\n",
      "1253\n",
      "1254\n",
      "1255\n",
      "1256\n",
      "1257\n",
      "1258\n",
      "1259\n",
      "1260\n",
      "1261\n",
      "1262\n",
      "1263\n",
      "1264\n",
      "1265\n",
      "1266\n",
      "1267\n",
      "1268\n",
      "1269\n",
      "1270\n",
      "1271\n",
      "1272\n",
      "1273\n",
      "1274\n",
      "1275\n",
      "1276\n",
      "1277\n",
      "1278\n",
      "1279\n",
      "1280\n",
      "1281\n",
      "1282\n",
      "1283\n",
      "1284\n",
      "1285\n",
      "1286\n",
      "1287\n",
      "1288\n",
      "1289\n",
      "1290\n",
      "1291\n",
      "1292\n",
      "1293\n",
      "1294\n",
      "1295\n",
      "1296\n",
      "1297\n",
      "1298\n",
      "1299\n",
      "1300\n",
      "1301\n",
      "1302\n",
      "1303\n",
      "1304\n",
      "1305\n",
      "1306\n",
      "1307\n",
      "1308\n",
      "1309\n",
      "1310\n",
      "1311\n",
      "1312\n",
      "1313\n",
      "1314\n",
      "1315\n",
      "1316\n",
      "1317\n",
      "1318\n",
      "1319\n",
      "1320\n",
      "1321\n",
      "1322\n",
      "1323\n",
      "1324\n",
      "1325\n",
      "1326\n",
      "1327\n",
      "1328\n",
      "1329\n",
      "1330\n",
      "1331\n",
      "1332\n",
      "1333\n",
      "1334\n",
      "1335\n",
      "1336\n",
      "1337\n",
      "1338\n",
      "1339\n",
      "1340\n",
      "1341\n",
      "1342\n",
      "1343\n",
      "1344\n",
      "1345\n",
      "1346\n",
      "1347\n",
      "1348\n",
      "1349\n",
      "1350\n",
      "1351\n",
      "1352\n",
      "1353\n",
      "1354\n",
      "1355\n",
      "1356\n",
      "1357\n",
      "1358\n",
      "1359\n",
      "1360\n",
      "1361\n",
      "1362\n",
      "1363\n",
      "1364\n",
      "1365\n",
      "1366\n",
      "1367\n",
      "1368\n",
      "1369\n",
      "1370\n",
      "1371\n",
      "1372\n",
      "1373\n",
      "1374\n",
      "1375\n",
      "1376\n",
      "1377\n",
      "1378\n",
      "1379\n",
      "1380\n",
      "1381\n",
      "1382\n",
      "1383\n",
      "1384\n",
      "1385\n",
      "1386\n",
      "1387\n",
      "1388\n",
      "1389\n",
      "1390\n",
      "1391\n",
      "1392\n",
      "1393\n",
      "1394\n",
      "1395\n",
      "1396\n",
      "1397\n",
      "1398\n",
      "1399\n",
      "1400\n",
      "1401\n",
      "1402\n",
      "1403\n",
      "1404\n",
      "1405\n",
      "1406\n",
      "1407\n",
      "1408\n",
      "1409\n",
      "1410\n",
      "1411\n",
      "1412\n",
      "1413\n",
      "1414\n",
      "1415\n",
      "1416\n",
      "1417\n",
      "1418\n",
      "1419\n",
      "1420\n",
      "1421\n",
      "1422\n",
      "1423\n",
      "1424\n",
      "1425\n",
      "1426\n",
      "1427\n",
      "1428\n",
      "1429\n",
      "1430\n",
      "1431\n",
      "1432\n",
      "1433\n",
      "1434\n",
      "1435\n",
      "1436\n",
      "1437\n",
      "1438\n",
      "1439\n",
      "1440\n",
      "1441\n",
      "1442\n",
      "1443\n",
      "1444\n",
      "1445\n",
      "1446\n",
      "1447\n",
      "1448\n",
      "1449\n",
      "1450\n",
      "1451\n",
      "1452\n",
      "1453\n",
      "1454\n",
      "1455\n",
      "1456\n",
      "1457\n",
      "1458\n",
      "1459\n",
      "1460\n",
      "1461\n",
      "1462\n",
      "1463\n",
      "1464\n",
      "1465\n",
      "1466\n",
      "1467\n",
      "1468\n",
      "1469\n",
      "1470\n",
      "1471\n",
      "1472\n",
      "1473\n",
      "1474\n",
      "1475\n",
      "1476\n",
      "1477\n",
      "1478\n",
      "1479\n",
      "1480\n",
      "1481\n",
      "1482\n",
      "1483\n",
      "1484\n",
      "1485\n",
      "1486\n",
      "1487\n",
      "1488\n",
      "1489\n",
      "1490\n",
      "1491\n",
      "1492\n",
      "1493\n",
      "1494\n",
      "1495\n",
      "1496\n",
      "1497\n",
      "1498\n",
      "1499\n",
      "1500\n",
      "1501\n",
      "1502\n",
      "1503\n",
      "1504\n",
      "1505\n",
      "1506\n",
      "1507\n",
      "1508\n",
      "1509\n",
      "1510\n",
      "1511\n",
      "1512\n",
      "1513\n",
      "1514\n",
      "1515\n",
      "1516\n",
      "1517\n",
      "1518\n",
      "1519\n",
      "1520\n",
      "1521\n",
      "1522\n",
      "1523\n",
      "1524\n",
      "1525\n",
      "1526\n",
      "1527\n",
      "1528\n",
      "1529\n",
      "1530\n",
      "1531\n",
      "1532\n",
      "1533\n",
      "1534\n",
      "1535\n",
      "1536\n",
      "1537\n",
      "1538\n",
      "1539\n",
      "1540\n",
      "1541\n",
      "1542\n",
      "1543\n",
      "1544\n",
      "1545\n",
      "1546\n",
      "1547\n",
      "1548\n",
      "1549\n",
      "1550\n",
      "1551\n",
      "1552\n",
      "1553\n",
      "1554\n",
      "1555\n",
      "1556\n",
      "1557\n",
      "1558\n",
      "1559\n",
      "1560\n",
      "1561\n",
      "1562\n",
      "1563\n",
      "1564\n",
      "1565\n",
      "1566\n",
      "1567\n",
      "1568\n",
      "1569\n",
      "1570\n",
      "1571\n",
      "1572\n",
      "1573\n",
      "1574\n",
      "1575\n",
      "1576\n",
      "1577\n",
      "1578\n",
      "1579\n",
      "1580\n",
      "1581\n",
      "1582\n",
      "1583\n",
      "1584\n",
      "1585\n",
      "1586\n",
      "1587\n",
      "1588\n",
      "1589\n",
      "1590\n",
      "1591\n",
      "1592\n",
      "1593\n",
      "1594\n",
      "1595\n",
      "1596\n",
      "1597\n",
      "1598\n",
      "1599\n",
      "1600\n",
      "1601\n",
      "1602\n",
      "1603\n",
      "1604\n",
      "1605\n",
      "1606\n",
      "1607\n",
      "1608\n",
      "1609\n",
      "1610\n",
      "1611\n",
      "1612\n",
      "1613\n",
      "1614\n",
      "1615\n",
      "1616\n",
      "1617\n",
      "1618\n",
      "1619\n",
      "1620\n",
      "1621\n",
      "1622\n",
      "1623\n",
      "1624\n",
      "1625\n",
      "1626\n",
      "1627\n",
      "1628\n",
      "1629\n",
      "1630\n",
      "1631\n",
      "1632\n",
      "1633\n",
      "1634\n",
      "1635\n",
      "1636\n",
      "1637\n",
      "1638\n",
      "1639\n",
      "1640\n",
      "1641\n",
      "1642\n",
      "1643\n",
      "1644\n",
      "1645\n",
      "1646\n",
      "1647\n",
      "1648\n",
      "1649\n",
      "1650\n",
      "1651\n",
      "1652\n",
      "1653\n",
      "1654\n",
      "1655\n",
      "1656\n",
      "1657\n",
      "1658\n",
      "1659\n",
      "1660\n",
      "1661\n",
      "1662\n",
      "1663\n",
      "1664\n",
      "1665\n",
      "1666\n",
      "1667\n",
      "1668\n",
      "1669\n",
      "1670\n",
      "1671\n",
      "1672\n",
      "1673\n",
      "1674\n",
      "1675\n",
      "1676\n",
      "1677\n",
      "1678\n",
      "1679\n",
      "1680\n",
      "1681\n",
      "1682\n",
      "1683\n",
      "1684\n",
      "1685\n",
      "1686\n",
      "1687\n",
      "1688\n",
      "1689\n",
      "1690\n",
      "1691\n",
      "1692\n",
      "1693\n",
      "1694\n",
      "1695\n",
      "1696\n",
      "1697\n",
      "1698\n",
      "1699\n",
      "1700\n",
      "1701\n",
      "1702\n",
      "1703\n",
      "1704\n",
      "1705\n",
      "1706\n",
      "1707\n",
      "1708\n",
      "1709\n",
      "1710\n",
      "1711\n",
      "1712\n",
      "1713\n",
      "1714\n",
      "1715\n",
      "1716\n",
      "1717\n",
      "1718\n",
      "1719\n",
      "1720\n",
      "1721\n",
      "1722\n",
      "1723\n",
      "1724\n",
      "1725\n",
      "1726\n",
      "1727\n",
      "1728\n",
      "1729\n",
      "1730\n",
      "1731\n",
      "1732\n",
      "1733\n",
      "1734\n",
      "1735\n",
      "1736\n",
      "1737\n",
      "1738\n",
      "1739\n",
      "1740\n",
      "1741\n",
      "1742\n",
      "1743\n",
      "1744\n",
      "1745\n",
      "1746\n",
      "1747\n",
      "1748\n",
      "1749\n",
      "1750\n",
      "1751\n",
      "1752\n",
      "1753\n",
      "1754\n",
      "1755\n",
      "1756\n",
      "1757\n",
      "1758\n",
      "1759\n",
      "1760\n",
      "1761\n",
      "1762\n",
      "1763\n",
      "1764\n",
      "1765\n",
      "1766\n",
      "1767\n",
      "1768\n",
      "1769\n",
      "1770\n",
      "1771\n",
      "1772\n",
      "1773\n",
      "1774\n",
      "1775\n",
      "1776\n",
      "1777\n",
      "1778\n",
      "1779\n",
      "1780\n",
      "1781\n",
      "1782\n",
      "1783\n",
      "1784\n",
      "1785\n",
      "1786\n",
      "1787\n",
      "1788\n",
      "1789\n",
      "1790\n",
      "1791\n",
      "1792\n",
      "1793\n",
      "1794\n",
      "1795\n",
      "1796\n",
      "1797\n",
      "1798\n",
      "1799\n",
      "1800\n",
      "1801\n",
      "1802\n",
      "1803\n",
      "1804\n",
      "1805\n",
      "1806\n",
      "1807\n",
      "1808\n",
      "1809\n",
      "1810\n",
      "1811\n",
      "1812\n",
      "1813\n",
      "1814\n",
      "1815\n",
      "1816\n",
      "1817\n",
      "1818\n",
      "1819\n",
      "1820\n",
      "1821\n",
      "1822\n",
      "1823\n",
      "1824\n",
      "1825\n",
      "1826\n",
      "1827\n",
      "1828\n",
      "1829\n",
      "1830\n",
      "1831\n",
      "1832\n",
      "1833\n",
      "1834\n",
      "1835\n",
      "1836\n",
      "1837\n",
      "1838\n",
      "1839\n",
      "1840\n",
      "1841\n",
      "1842\n",
      "1843\n",
      "1844\n",
      "1845\n",
      "1846\n",
      "1847\n",
      "1848\n",
      "1849\n",
      "1850\n",
      "1851\n",
      "1852\n",
      "1853\n",
      "1854\n",
      "1855\n",
      "1856\n",
      "1857\n",
      "1858\n",
      "1859\n",
      "1860\n",
      "1861\n",
      "1862\n",
      "1863\n",
      "1864\n",
      "1865\n",
      "1866\n",
      "1867\n",
      "1868\n",
      "1869\n",
      "1870\n",
      "1871\n",
      "1872\n",
      "1873\n",
      "1874\n",
      "1875\n",
      "1876\n",
      "1877\n",
      "1878\n",
      "1879\n",
      "1880\n",
      "1881\n",
      "1882\n",
      "1883\n",
      "1884\n",
      "1885\n",
      "1886\n",
      "1887\n",
      "1888\n",
      "1889\n",
      "1890\n",
      "1891\n",
      "1892\n",
      "1893\n",
      "1894\n",
      "1895\n",
      "1896\n",
      "1897\n",
      "1898\n",
      "1899\n",
      "1900\n",
      "1901\n",
      "1902\n",
      "1903\n",
      "1904\n",
      "1905\n",
      "1906\n",
      "1907\n",
      "1908\n",
      "1909\n",
      "1910\n",
      "1911\n",
      "1912\n",
      "1913\n",
      "1914\n",
      "1915\n",
      "1916\n",
      "1917\n",
      "1918\n",
      "1919\n",
      "1920\n",
      "1921\n",
      "1922\n",
      "1923\n",
      "1924\n",
      "1925\n",
      "1926\n",
      "1927\n",
      "1928\n",
      "1929\n",
      "1930\n",
      "1931\n",
      "1932\n",
      "1933\n",
      "1934\n",
      "1935\n",
      "1936\n",
      "1937\n",
      "1938\n",
      "1939\n",
      "1940\n",
      "1941\n",
      "1942\n",
      "1943\n",
      "1944\n",
      "1945\n",
      "1946\n",
      "1947\n",
      "1948\n",
      "1949\n",
      "1950\n",
      "1951\n",
      "1952\n",
      "1953\n",
      "1954\n",
      "1955\n",
      "1956\n",
      "1957\n",
      "1958\n",
      "1959\n",
      "1960\n",
      "1961\n",
      "1962\n",
      "1963\n",
      "1964\n",
      "1965\n",
      "1966\n",
      "1967\n",
      "1968\n",
      "1969\n",
      "1970\n",
      "1971\n",
      "1972\n",
      "1973\n",
      "1974\n",
      "1975\n",
      "1976\n",
      "1977\n",
      "1978\n",
      "1979\n",
      "1980\n",
      "1981\n",
      "1982\n",
      "1983\n",
      "1984\n",
      "1985\n",
      "1986\n",
      "1987\n",
      "1988\n",
      "1989\n",
      "1990\n",
      "1991\n",
      "1992\n",
      "1993\n",
      "1994\n",
      "1995\n",
      "1996\n",
      "1997\n",
      "1998\n",
      "1999\n",
      "2000\n",
      "2001\n",
      "2002\n",
      "2003\n",
      "2004\n",
      "2005\n",
      "2006\n",
      "2007\n",
      "2008\n",
      "2009\n",
      "2010\n",
      "2011\n",
      "2012\n",
      "2013\n",
      "2014\n",
      "2015\n",
      "2016\n",
      "2017\n",
      "2018\n",
      "2019\n",
      "2020\n",
      "2021\n",
      "2022\n",
      "2023\n",
      "2024\n",
      "2025\n",
      "2026\n",
      "2027\n",
      "2028\n",
      "2029\n",
      "2030\n",
      "2031\n",
      "2032\n",
      "2033\n",
      "2034\n",
      "2035\n",
      "2036\n",
      "2037\n",
      "2038\n",
      "2039\n",
      "2040\n",
      "2041\n",
      "2042\n",
      "2043\n",
      "2044\n",
      "2045\n",
      "2046\n",
      "2047\n",
      "2048\n",
      "2049\n",
      "2050\n",
      "2051\n",
      "2052\n",
      "2053\n",
      "2054\n",
      "2055\n",
      "2056\n",
      "2057\n",
      "2058\n",
      "2059\n",
      "2060\n",
      "2061\n",
      "2062\n",
      "2063\n",
      "2064\n",
      "2065\n",
      "2066\n",
      "2067\n",
      "2068\n",
      "2069\n",
      "2070\n",
      "2071\n",
      "2072\n",
      "2073\n",
      "2074\n",
      "2075\n",
      "2076\n",
      "2077\n",
      "2078\n",
      "2079\n",
      "2080\n",
      "2081\n",
      "2082\n",
      "2083\n",
      "2084\n",
      "2085\n",
      "2086\n",
      "2087\n",
      "2088\n",
      "2089\n",
      "2090\n",
      "2091\n",
      "2092\n",
      "2093\n",
      "2094\n",
      "2095\n",
      "2096\n",
      "2097\n",
      "2098\n",
      "2099\n",
      "2100\n",
      "2101\n",
      "2102\n",
      "2103\n",
      "2104\n",
      "2105\n",
      "2106\n",
      "2107\n",
      "2108\n",
      "2109\n",
      "2110\n",
      "2111\n",
      "2112\n",
      "2113\n",
      "2114\n",
      "2115\n",
      "2116\n",
      "2117\n",
      "2118\n",
      "2119\n",
      "2120\n",
      "2121\n",
      "2122\n",
      "2123\n",
      "2124\n",
      "2125\n",
      "2126\n",
      "2127\n",
      "2128\n",
      "2129\n",
      "2130\n",
      "2131\n",
      "2132\n",
      "2133\n",
      "2134\n",
      "2135\n",
      "2136\n",
      "2137\n",
      "2138\n",
      "2139\n",
      "2140\n",
      "2141\n",
      "2142\n",
      "2143\n",
      "2144\n",
      "2145\n",
      "2146\n",
      "2147\n",
      "2148\n",
      "2149\n",
      "2150\n",
      "2151\n",
      "2152\n",
      "2153\n",
      "2154\n",
      "2155\n",
      "2156\n",
      "2157\n",
      "2158\n",
      "2159\n",
      "2160\n",
      "2161\n",
      "2162\n",
      "2163\n",
      "2164\n",
      "2165\n",
      "2166\n",
      "2167\n",
      "2168\n",
      "2169\n",
      "2170\n",
      "2171\n",
      "2172\n",
      "2173\n",
      "2174\n",
      "2175\n",
      "2176\n",
      "2177\n",
      "2178\n",
      "2179\n",
      "2180\n",
      "2181\n",
      "2182\n",
      "2183\n",
      "2184\n",
      "2185\n",
      "2186\n",
      "2187\n",
      "2188\n",
      "2189\n",
      "2190\n",
      "2191\n",
      "2192\n",
      "2193\n",
      "2194\n",
      "2195\n",
      "2196\n",
      "2197\n",
      "2198\n",
      "2199\n",
      "2200\n",
      "2201\n",
      "2202\n",
      "2203\n",
      "2204\n",
      "2205\n",
      "2206\n",
      "2207\n",
      "2208\n",
      "2209\n",
      "2210\n",
      "2211\n",
      "2212\n",
      "2213\n",
      "2214\n",
      "2215\n",
      "2216\n",
      "2217\n",
      "2218\n",
      "2219\n",
      "2220\n",
      "2221\n",
      "2222\n",
      "2223\n",
      "2224\n",
      "2225\n",
      "2226\n",
      "2227\n",
      "2228\n",
      "2229\n",
      "2230\n",
      "2231\n",
      "2232\n",
      "2233\n",
      "2234\n",
      "2235\n",
      "2236\n",
      "2237\n",
      "2238\n",
      "2239\n",
      "2240\n",
      "2241\n",
      "2242\n",
      "2243\n",
      "2244\n",
      "2245\n",
      "2246\n",
      "2247\n",
      "2248\n",
      "2249\n",
      "2250\n",
      "2251\n",
      "2252\n",
      "2253\n",
      "2254\n",
      "2255\n",
      "2256\n",
      "2257\n",
      "2258\n",
      "2259\n",
      "2260\n",
      "2261\n",
      "2262\n",
      "2263\n",
      "2264\n",
      "2265\n",
      "2266\n",
      "2267\n",
      "2268\n",
      "2269\n",
      "2270\n",
      "2271\n",
      "2272\n",
      "2273\n",
      "2274\n",
      "2275\n",
      "2276\n",
      "2277\n",
      "2278\n",
      "2279\n",
      "2280\n",
      "2281\n",
      "2282\n",
      "2283\n",
      "2284\n",
      "2285\n",
      "2286\n",
      "2287\n",
      "2288\n",
      "2289\n",
      "2290\n",
      "2291\n",
      "2292\n",
      "2293\n",
      "2294\n",
      "2295\n",
      "2296\n",
      "2297\n",
      "2298\n",
      "2299\n",
      "2300\n",
      "2301\n",
      "2302\n",
      "2303\n",
      "2304\n",
      "2305\n",
      "2306\n",
      "2307\n",
      "2308\n",
      "2309\n",
      "2310\n",
      "2311\n",
      "2312\n",
      "2313\n",
      "2314\n",
      "2315\n",
      "2316\n",
      "2317\n",
      "2318\n",
      "2319\n",
      "2320\n",
      "2321\n",
      "2322\n",
      "2323\n",
      "2324\n",
      "2325\n",
      "2326\n",
      "2327\n",
      "2328\n",
      "2329\n",
      "2330\n",
      "2331\n",
      "2332\n",
      "2333\n",
      "2334\n",
      "2335\n",
      "2336\n",
      "2337\n",
      "2338\n",
      "2339\n",
      "2340\n",
      "2341\n",
      "2342\n",
      "2343\n",
      "2344\n",
      "2345\n",
      "2346\n",
      "2347\n",
      "2348\n",
      "2349\n",
      "2350\n",
      "2351\n",
      "2352\n",
      "2353\n",
      "2354\n",
      "2355\n",
      "2356\n",
      "2357\n",
      "2358\n",
      "2359\n",
      "2360\n",
      "2361\n",
      "2362\n",
      "2363\n",
      "2364\n",
      "2365\n",
      "2366\n",
      "2367\n",
      "2368\n",
      "2369\n",
      "2370\n",
      "2371\n",
      "2372\n",
      "2373\n",
      "2374\n",
      "2375\n",
      "2376\n",
      "2377\n",
      "2378\n",
      "2379\n",
      "2380\n",
      "2381\n",
      "2382\n",
      "2383\n",
      "2384\n",
      "2385\n",
      "2386\n",
      "2387\n",
      "2388\n",
      "2389\n",
      "2390\n",
      "2391\n",
      "2392\n",
      "2393\n",
      "2394\n",
      "2395\n",
      "2396\n",
      "2397\n",
      "2398\n",
      "2399\n",
      "2400\n",
      "2401\n",
      "2402\n",
      "2403\n",
      "2404\n",
      "2405\n",
      "2406\n",
      "2407\n",
      "2408\n",
      "2409\n",
      "2410\n",
      "2411\n",
      "2412\n",
      "2413\n",
      "2414\n",
      "2415\n",
      "2416\n",
      "2417\n",
      "2418\n",
      "2419\n",
      "2420\n",
      "2421\n",
      "2422\n",
      "2423\n",
      "2424\n",
      "2425\n",
      "2426\n",
      "2427\n",
      "2428\n",
      "2429\n",
      "2430\n",
      "2431\n",
      "2432\n",
      "2433\n",
      "2434\n",
      "2435\n",
      "2436\n",
      "2437\n",
      "2438\n",
      "2439\n",
      "2440\n",
      "2441\n",
      "2442\n",
      "2443\n",
      "2444\n",
      "2445\n",
      "2446\n",
      "2447\n",
      "2448\n",
      "2449\n",
      "2450\n",
      "2451\n",
      "2452\n",
      "2453\n",
      "2454\n",
      "2455\n",
      "2456\n",
      "2457\n",
      "2458\n",
      "2459\n",
      "2460\n",
      "2461\n",
      "2462\n",
      "2463\n",
      "2464\n",
      "2465\n",
      "2466\n",
      "2467\n",
      "2468\n",
      "2469\n",
      "2470\n",
      "2471\n",
      "2472\n",
      "2473\n",
      "2474\n",
      "2475\n",
      "2476\n",
      "2477\n",
      "2478\n",
      "2479\n",
      "2480\n",
      "2481\n",
      "2482\n",
      "2483\n",
      "2484\n",
      "2485\n",
      "2486\n",
      "2487\n",
      "2488\n",
      "2489\n",
      "2490\n",
      "2491\n",
      "2492\n",
      "2493\n",
      "2494\n",
      "2495\n",
      "2496\n",
      "2497\n",
      "2498\n",
      "2499\n",
      "2500\n",
      "2501\n",
      "2502\n",
      "2503\n",
      "2504\n",
      "2505\n",
      "2506\n",
      "2507\n",
      "2508\n",
      "2509\n",
      "2510\n",
      "2511\n",
      "2512\n",
      "2513\n",
      "2514\n",
      "2515\n",
      "2516\n",
      "2517\n",
      "2518\n",
      "2519\n",
      "2520\n",
      "2521\n",
      "2522\n",
      "2523\n",
      "2524\n",
      "2525\n",
      "2526\n",
      "2527\n",
      "2528\n",
      "2529\n",
      "2530\n",
      "2531\n",
      "2532\n",
      "2533\n",
      "2534\n",
      "2535\n",
      "2536\n",
      "2537\n",
      "2538\n",
      "2539\n",
      "2540\n",
      "2541\n",
      "2542\n",
      "2543\n",
      "2544\n",
      "2545\n",
      "2546\n",
      "2547\n",
      "2548\n",
      "2549\n",
      "2550\n",
      "2551\n",
      "2552\n",
      "2553\n",
      "2554\n",
      "2555\n",
      "2556\n",
      "2557\n",
      "2558\n",
      "2559\n",
      "2560\n",
      "2561\n",
      "2562\n",
      "2563\n",
      "2564\n",
      "2565\n",
      "2566\n",
      "2567\n",
      "2568\n",
      "2569\n",
      "2570\n",
      "2571\n",
      "2572\n",
      "2573\n",
      "2574\n",
      "2575\n",
      "2576\n",
      "2577\n",
      "2578\n",
      "2579\n",
      "2580\n",
      "2581\n",
      "2582\n",
      "2583\n",
      "2584\n",
      "2585\n",
      "2586\n",
      "2587\n",
      "2588\n",
      "2589\n",
      "2590\n",
      "2591\n",
      "2592\n",
      "2593\n",
      "2594\n",
      "2595\n",
      "2596\n",
      "2597\n",
      "2598\n",
      "2599\n",
      "2600\n",
      "2601\n",
      "2602\n",
      "2603\n",
      "2604\n",
      "2605\n",
      "2606\n",
      "2607\n",
      "2608\n",
      "2609\n",
      "2610\n",
      "2611\n",
      "2612\n",
      "2613\n",
      "2614\n",
      "2615\n",
      "2616\n",
      "2617\n",
      "2618\n",
      "2619\n",
      "2620\n",
      "2621\n",
      "2622\n",
      "2623\n",
      "2624\n",
      "2625\n",
      "2626\n",
      "2627\n",
      "2628\n",
      "2629\n",
      "2630\n",
      "2631\n",
      "2632\n",
      "2633\n",
      "2634\n",
      "2635\n",
      "2636\n",
      "2637\n",
      "2638\n",
      "2639\n",
      "2640\n",
      "2641\n",
      "2642\n",
      "2643\n",
      "2644\n",
      "2645\n",
      "2646\n",
      "2647\n",
      "2648\n",
      "2649\n",
      "2650\n",
      "2651\n",
      "2652\n",
      "2653\n",
      "2654\n",
      "2655\n",
      "2656\n",
      "2657\n",
      "2658\n",
      "2659\n",
      "2660\n",
      "2661\n",
      "2662\n",
      "2663\n",
      "2664\n",
      "2665\n",
      "2666\n",
      "2667\n",
      "2668\n",
      "2669\n",
      "2670\n",
      "2671\n",
      "2672\n",
      "2673\n",
      "2674\n",
      "2675\n",
      "2676\n",
      "2677\n",
      "2678\n",
      "2679\n",
      "2680\n",
      "2681\n",
      "2682\n",
      "2683\n",
      "2684\n",
      "2685\n",
      "2686\n",
      "2687\n",
      "2688\n",
      "2689\n",
      "2690\n",
      "2691\n",
      "2692\n",
      "2693\n",
      "2694\n",
      "2695\n",
      "2696\n",
      "2697\n",
      "2698\n",
      "2699\n",
      "2700\n",
      "2701\n",
      "2702\n",
      "2703\n",
      "2704\n",
      "2705\n",
      "2706\n",
      "2707\n",
      "2708\n",
      "2709\n",
      "2710\n",
      "2711\n",
      "2712\n",
      "2713\n",
      "2714\n",
      "2715\n",
      "2716\n",
      "2717\n",
      "2718\n",
      "2719\n",
      "2720\n",
      "2721\n",
      "2722\n",
      "2723\n",
      "2724\n",
      "2725\n",
      "2726\n",
      "2727\n",
      "2728\n",
      "2729\n",
      "2730\n",
      "2731\n",
      "2732\n",
      "2733\n",
      "2734\n",
      "2735\n",
      "2736\n",
      "2737\n",
      "2738\n",
      "2739\n",
      "2740\n",
      "2741\n",
      "2742\n",
      "2743\n",
      "2744\n",
      "2745\n",
      "2746\n",
      "2747\n",
      "2748\n",
      "2749\n",
      "2750\n",
      "2751\n",
      "2752\n",
      "2753\n",
      "2754\n",
      "2755\n",
      "2756\n",
      "2757\n",
      "2758\n",
      "2759\n",
      "2760\n",
      "2761\n",
      "2762\n",
      "2763\n",
      "2764\n",
      "2765\n",
      "2766\n",
      "2767\n",
      "2768\n",
      "2769\n",
      "2770\n",
      "2771\n",
      "2772\n",
      "2773\n",
      "2774\n",
      "2775\n",
      "2776\n",
      "2777\n",
      "2778\n",
      "2779\n",
      "2780\n",
      "2781\n",
      "2782\n",
      "2783\n",
      "2784\n",
      "2785\n",
      "2786\n",
      "2787\n",
      "2788\n",
      "2789\n",
      "2790\n",
      "2791\n",
      "2792\n",
      "2793\n",
      "2794\n",
      "2795\n",
      "2796\n",
      "2797\n",
      "2798\n",
      "2799\n",
      "2800\n",
      "2801\n",
      "2802\n",
      "2803\n",
      "2804\n",
      "2805\n",
      "2806\n",
      "2807\n",
      "2808\n",
      "2809\n",
      "2810\n",
      "2811\n",
      "2812\n",
      "2813\n",
      "2814\n",
      "2815\n",
      "2816\n",
      "2817\n",
      "2818\n",
      "2819\n",
      "2820\n",
      "2821\n",
      "2822\n",
      "2823\n",
      "2824\n",
      "2825\n",
      "2826\n",
      "2827\n",
      "2828\n",
      "2829\n",
      "2830\n",
      "2831\n",
      "2832\n",
      "2833\n",
      "2834\n",
      "2835\n",
      "2836\n",
      "2837\n",
      "2838\n",
      "2839\n",
      "2840\n",
      "2841\n",
      "2842\n",
      "2843\n",
      "2844\n",
      "2845\n",
      "2846\n",
      "2847\n",
      "2848\n",
      "2849\n",
      "2850\n",
      "2851\n",
      "2852\n",
      "2853\n",
      "2854\n",
      "2855\n",
      "2856\n",
      "2857\n",
      "2858\n",
      "2859\n",
      "2860\n",
      "2861\n",
      "2862\n",
      "2863\n",
      "2864\n",
      "2865\n",
      "2866\n",
      "2867\n",
      "2868\n",
      "2869\n",
      "2870\n",
      "2871\n",
      "2872\n",
      "2873\n",
      "2874\n",
      "2875\n",
      "2876\n",
      "2877\n",
      "2878\n",
      "2879\n",
      "2880\n",
      "2881\n",
      "2882\n",
      "2883\n",
      "2884\n",
      "2885\n",
      "2886\n",
      "2887\n",
      "2888\n",
      "2889\n",
      "2890\n",
      "2891\n",
      "2892\n",
      "2893\n",
      "2894\n",
      "2895\n",
      "2896\n",
      "2897\n",
      "2898\n",
      "2899\n",
      "2900\n",
      "2901\n",
      "2902\n",
      "2903\n",
      "2904\n",
      "2905\n",
      "2906\n",
      "2907\n",
      "2908\n",
      "2909\n",
      "2910\n",
      "2911\n",
      "2912\n",
      "2913\n",
      "2914\n",
      "2915\n",
      "2916\n",
      "2917\n",
      "2918\n",
      "2919\n",
      "2920\n",
      "2921\n",
      "2922\n",
      "2923\n",
      "2924\n",
      "2925\n",
      "2926\n",
      "2927\n",
      "2928\n",
      "2929\n",
      "2930\n",
      "2931\n",
      "2932\n",
      "2933\n",
      "2934\n",
      "2935\n",
      "2936\n",
      "2937\n",
      "2938\n",
      "2939\n",
      "2940\n",
      "2941\n",
      "2942\n",
      "2943\n",
      "2944\n",
      "2945\n",
      "2946\n",
      "2947\n",
      "2948\n",
      "2949\n",
      "2950\n",
      "2951\n",
      "2952\n",
      "2953\n",
      "2954\n",
      "2955\n",
      "2956\n",
      "2957\n",
      "2958\n",
      "2959\n",
      "2960\n",
      "2961\n",
      "2962\n",
      "2963\n",
      "2964\n",
      "2965\n",
      "2966\n",
      "2967\n",
      "2968\n",
      "2969\n",
      "2970\n",
      "2971\n",
      "2972\n",
      "2973\n",
      "2974\n",
      "2975\n",
      "2976\n",
      "2977\n",
      "2978\n",
      "2979\n",
      "2980\n",
      "2981\n",
      "2982\n",
      "2983\n",
      "2984\n",
      "2985\n",
      "2986\n",
      "2987\n",
      "2988\n",
      "2989\n",
      "2990\n",
      "2991\n",
      "2992\n",
      "2993\n",
      "2994\n",
      "2995\n",
      "2996\n",
      "2997\n",
      "2998\n",
      "2999\n",
      "3000\n",
      "3001\n",
      "3002\n",
      "3003\n",
      "3004\n",
      "3005\n",
      "3006\n",
      "3007\n",
      "3008\n",
      "3009\n",
      "3010\n",
      "3011\n",
      "3012\n",
      "3013\n",
      "3014\n",
      "3015\n",
      "3016\n",
      "3017\n",
      "3018\n",
      "3019\n",
      "3020\n",
      "3021\n",
      "3022\n",
      "3023\n",
      "3024\n",
      "3025\n",
      "3026\n",
      "3027\n",
      "3028\n",
      "3029\n",
      "3030\n",
      "3031\n",
      "3032\n",
      "3033\n",
      "3034\n",
      "3035\n",
      "3036\n",
      "3037\n",
      "3038\n",
      "3039\n",
      "3040\n",
      "3041\n",
      "3042\n",
      "3043\n",
      "3044\n",
      "3045\n",
      "3046\n",
      "3047\n",
      "3048\n",
      "3049\n",
      "3050\n",
      "3051\n",
      "3052\n",
      "3053\n",
      "3054\n",
      "3055\n",
      "3056\n",
      "3057\n",
      "3058\n",
      "3059\n",
      "3060\n",
      "3061\n",
      "3062\n",
      "3063\n",
      "3064\n",
      "3065\n",
      "3066\n",
      "3067\n",
      "3068\n",
      "3069\n",
      "3070\n",
      "3071\n",
      "3072\n",
      "3073\n",
      "3074\n",
      "3075\n",
      "3076\n",
      "3077\n",
      "3078\n",
      "3079\n",
      "3080\n",
      "3081\n",
      "3082\n",
      "3083\n",
      "3084\n",
      "3085\n",
      "3086\n",
      "3087\n",
      "3088\n",
      "3089\n",
      "3090\n",
      "3091\n",
      "3092\n",
      "3093\n",
      "3094\n",
      "3095\n",
      "3096\n",
      "3097\n",
      "3098\n",
      "3099\n",
      "3100\n",
      "3101\n",
      "3102\n",
      "3103\n",
      "3104\n",
      "3105\n",
      "3106\n",
      "3107\n",
      "3108\n",
      "3109\n",
      "3110\n",
      "3111\n",
      "3112\n",
      "3113\n",
      "3114\n",
      "3115\n",
      "3116\n",
      "3117\n",
      "3118\n",
      "3119\n",
      "3120\n",
      "3121\n",
      "3122\n",
      "3123\n",
      "3124\n",
      "3125\n",
      "3126\n",
      "3127\n",
      "3128\n",
      "3129\n",
      "3130\n",
      "3131\n",
      "3132\n",
      "3133\n",
      "3134\n",
      "3135\n",
      "3136\n",
      "3137\n",
      "3138\n",
      "3139\n",
      "3140\n",
      "3141\n",
      "3142\n",
      "3143\n",
      "3144\n",
      "3145\n",
      "3146\n",
      "3147\n",
      "3148\n",
      "3149\n",
      "3150\n",
      "3151\n",
      "3152\n",
      "3153\n",
      "3154\n",
      "3155\n",
      "3156\n",
      "3157\n",
      "3158\n",
      "3159\n",
      "3160\n",
      "3161\n",
      "3162\n",
      "3163\n",
      "3164\n",
      "3165\n",
      "3166\n",
      "3167\n",
      "3168\n",
      "3169\n",
      "3170\n",
      "3171\n",
      "3172\n",
      "3173\n",
      "3174\n",
      "3175\n",
      "3176\n",
      "3177\n",
      "3178\n",
      "3179\n",
      "3180\n",
      "3181\n",
      "3182\n",
      "3183\n",
      "3184\n",
      "3185\n",
      "3186\n",
      "3187\n",
      "3188\n",
      "3189\n",
      "3190\n",
      "3191\n",
      "3192\n",
      "3193\n",
      "3194\n",
      "3195\n",
      "3196\n",
      "3197\n",
      "3198\n",
      "3199\n",
      "3200\n",
      "3201\n",
      "3202\n",
      "3203\n",
      "3204\n",
      "3205\n",
      "3206\n",
      "3207\n",
      "3208\n",
      "3209\n",
      "3210\n",
      "3211\n",
      "3212\n",
      "3213\n",
      "3214\n",
      "3215\n",
      "3216\n",
      "3217\n",
      "3218\n",
      "3219\n",
      "3220\n",
      "3221\n",
      "3222\n",
      "3223\n",
      "3224\n",
      "3225\n",
      "3226\n",
      "3227\n",
      "3228\n",
      "3229\n",
      "3230\n",
      "3231\n",
      "3232\n",
      "3233\n",
      "3234\n",
      "3235\n",
      "3236\n",
      "3237\n",
      "3238\n",
      "3239\n",
      "3240\n",
      "3241\n",
      "3242\n",
      "3243\n",
      "3244\n",
      "3245\n",
      "3246\n",
      "3247\n",
      "3248\n",
      "3249\n",
      "3250\n",
      "3251\n",
      "3252\n",
      "3253\n",
      "3254\n",
      "3255\n",
      "3256\n",
      "3257\n",
      "3258\n",
      "3259\n",
      "3260\n",
      "3261\n",
      "3262\n",
      "3263\n",
      "3264\n",
      "3265\n",
      "3266\n",
      "3267\n",
      "3268\n",
      "3269\n",
      "3270\n",
      "3271\n",
      "3272\n",
      "3273\n",
      "3274\n",
      "3275\n",
      "3276\n",
      "3277\n",
      "3278\n",
      "3279\n",
      "3280\n",
      "3281\n",
      "3282\n",
      "3283\n",
      "3284\n",
      "3285\n",
      "3286\n",
      "3287\n",
      "3288\n",
      "3289\n",
      "3290\n",
      "3291\n",
      "3292\n",
      "3293\n",
      "3294\n",
      "3295\n",
      "3296\n",
      "3297\n",
      "3298\n",
      "3299\n",
      "3300\n",
      "3301\n",
      "3302\n",
      "3303\n",
      "3304\n",
      "3305\n",
      "3306\n",
      "3307\n",
      "3308\n",
      "3309\n",
      "3310\n",
      "3311\n",
      "3312\n",
      "3313\n",
      "3314\n",
      "3315\n",
      "3316\n",
      "3317\n",
      "3318\n",
      "3319\n",
      "3320\n",
      "3321\n",
      "3322\n",
      "3323\n",
      "3324\n",
      "3325\n",
      "3326\n",
      "3327\n",
      "3328\n",
      "3329\n",
      "3330\n",
      "3331\n",
      "3332\n",
      "3333\n",
      "3334\n",
      "3335\n",
      "3336\n",
      "3337\n",
      "3338\n",
      "3339\n",
      "3340\n",
      "3341\n",
      "3342\n",
      "3343\n",
      "3344\n",
      "3345\n",
      "3346\n",
      "3347\n",
      "3348\n",
      "3349\n",
      "3350\n",
      "3351\n",
      "3352\n",
      "3353\n",
      "3354\n",
      "3355\n",
      "3356\n",
      "3357\n",
      "3358\n",
      "3359\n",
      "3360\n",
      "3361\n",
      "3362\n",
      "3363\n",
      "3364\n",
      "3365\n",
      "3366\n",
      "3367\n",
      "3368\n",
      "3369\n",
      "3370\n",
      "3371\n",
      "3372\n",
      "3373\n",
      "3374\n",
      "3375\n",
      "3376\n",
      "3377\n",
      "3378\n",
      "3379\n",
      "3380\n",
      "3381\n",
      "3382\n",
      "3383\n",
      "3384\n",
      "3385\n",
      "3386\n",
      "3387\n",
      "3388\n",
      "3389\n",
      "3390\n",
      "3391\n",
      "3392\n",
      "3393\n",
      "3394\n",
      "3395\n",
      "3396\n",
      "3397\n",
      "3398\n",
      "3399\n",
      "3400\n",
      "3401\n",
      "3402\n",
      "3403\n",
      "3404\n",
      "3405\n",
      "3406\n",
      "3407\n",
      "3408\n",
      "3409\n",
      "3410\n",
      "3411\n",
      "3412\n",
      "3413\n",
      "3414\n",
      "3415\n",
      "3416\n",
      "3417\n",
      "3418\n",
      "3419\n",
      "3420\n",
      "3421\n",
      "3422\n",
      "3423\n",
      "3424\n",
      "3425\n",
      "3426\n",
      "3427\n",
      "3428\n",
      "3429\n",
      "3430\n",
      "3431\n",
      "3432\n",
      "3433\n",
      "3434\n",
      "3435\n",
      "3436\n",
      "3437\n",
      "3438\n",
      "3439\n",
      "3440\n",
      "3441\n",
      "3442\n",
      "3443\n",
      "3444\n",
      "3445\n",
      "3446\n",
      "3447\n",
      "3448\n",
      "3449\n",
      "3450\n",
      "3451\n",
      "3452\n",
      "3453\n",
      "3454\n",
      "3455\n",
      "3456\n",
      "3457\n",
      "3458\n",
      "3459\n",
      "3460\n",
      "3461\n",
      "3462\n",
      "3463\n",
      "3464\n",
      "3465\n",
      "3466\n",
      "3467\n",
      "3468\n",
      "3469\n",
      "3470\n",
      "3471\n",
      "3472\n",
      "3473\n",
      "3474\n",
      "3475\n",
      "3476\n",
      "3477\n",
      "3478\n",
      "3479\n",
      "3480\n",
      "3481\n",
      "3482\n",
      "3483\n",
      "3484\n",
      "3485\n",
      "3486\n",
      "3487\n",
      "3488\n",
      "3489\n",
      "3490\n",
      "3491\n",
      "3492\n",
      "3493\n",
      "3494\n",
      "3495\n",
      "3496\n",
      "3497\n",
      "3498\n",
      "3499\n",
      "3500\n",
      "3501\n",
      "3502\n",
      "3503\n",
      "3504\n",
      "3505\n",
      "3506\n",
      "3507\n",
      "3508\n",
      "3509\n",
      "3510\n",
      "3511\n",
      "3512\n",
      "3513\n",
      "3514\n",
      "3515\n",
      "3516\n",
      "3517\n",
      "3518\n",
      "3519\n",
      "3520\n",
      "3521\n",
      "3522\n",
      "3523\n",
      "3524\n",
      "3525\n",
      "3526\n",
      "3527\n",
      "3528\n",
      "3529\n",
      "3530\n",
      "3531\n",
      "3532\n",
      "3533\n",
      "3534\n",
      "3535\n",
      "3536\n",
      "3537\n",
      "3538\n",
      "3539\n",
      "3540\n",
      "3541\n",
      "3542\n",
      "3543\n",
      "3544\n",
      "3545\n",
      "3546\n",
      "3547\n",
      "3548\n",
      "3549\n",
      "3550\n",
      "3551\n",
      "3552\n",
      "3553\n",
      "3554\n",
      "3555\n",
      "3556\n",
      "3557\n",
      "3558\n",
      "3559\n",
      "3560\n",
      "3561\n",
      "3562\n",
      "3563\n",
      "3564\n",
      "3565\n",
      "3566\n",
      "3567\n",
      "3568\n",
      "3569\n",
      "3570\n",
      "3571\n",
      "3572\n",
      "3573\n",
      "3574\n",
      "3575\n",
      "3576\n",
      "3577\n",
      "3578\n",
      "3579\n",
      "3580\n",
      "3581\n",
      "3582\n",
      "3583\n",
      "3584\n",
      "3585\n",
      "3586\n",
      "3587\n",
      "3588\n",
      "3589\n",
      "3590\n",
      "3591\n",
      "3592\n",
      "3593\n",
      "3594\n",
      "3595\n",
      "3596\n",
      "3597\n",
      "3598\n",
      "3599\n",
      "3600\n",
      "3601\n",
      "3602\n",
      "3603\n",
      "3604\n",
      "3605\n",
      "3606\n",
      "3607\n",
      "3608\n",
      "3609\n",
      "3610\n",
      "3611\n",
      "3612\n",
      "3613\n",
      "3614\n",
      "3615\n",
      "3616\n",
      "3617\n",
      "3618\n",
      "3619\n",
      "3620\n",
      "3621\n",
      "3622\n",
      "3623\n",
      "3624\n",
      "3625\n",
      "3626\n",
      "3627\n",
      "3628\n",
      "3629\n",
      "3630\n",
      "3631\n",
      "3632\n",
      "3633\n",
      "3634\n",
      "3635\n",
      "3636\n",
      "3637\n",
      "3638\n",
      "3639\n",
      "3640\n",
      "3641\n",
      "3642\n",
      "3643\n",
      "3644\n",
      "3645\n",
      "3646\n",
      "3647\n",
      "3648\n",
      "3649\n",
      "3650\n",
      "3651\n",
      "3652\n",
      "3653\n",
      "3654\n",
      "3655\n",
      "3656\n",
      "3657\n",
      "3658\n",
      "3659\n",
      "3660\n",
      "3661\n",
      "3662\n",
      "3663\n",
      "3664\n",
      "3665\n",
      "3666\n",
      "3667\n",
      "3668\n",
      "3669\n",
      "3670\n",
      "3671\n",
      "3672\n",
      "3673\n",
      "3674\n",
      "3675\n",
      "3676\n",
      "3677\n",
      "3678\n",
      "3679\n",
      "3680\n",
      "3681\n",
      "3682\n",
      "3683\n",
      "3684\n",
      "3685\n",
      "3686\n",
      "3687\n",
      "3688\n",
      "3689\n",
      "3690\n",
      "3691\n",
      "3692\n",
      "3693\n",
      "3694\n",
      "3695\n",
      "3696\n",
      "3697\n",
      "3698\n",
      "3699\n",
      "3700\n",
      "3701\n",
      "3702\n",
      "3703\n",
      "3704\n",
      "3705\n",
      "3706\n",
      "3707\n",
      "3708\n",
      "3709\n",
      "3710\n",
      "3711\n",
      "3712\n",
      "3713\n",
      "3714\n",
      "3715\n",
      "3716\n",
      "3717\n",
      "3718\n",
      "3719\n",
      "3720\n",
      "3721\n",
      "3722\n",
      "3723\n",
      "3724\n",
      "3725\n",
      "3726\n",
      "3727\n",
      "3728\n",
      "3729\n",
      "3730\n",
      "3731\n",
      "3732\n",
      "3733\n",
      "3734\n",
      "3735\n",
      "3736\n",
      "3737\n",
      "3738\n",
      "3739\n",
      "3740\n",
      "3741\n",
      "3742\n",
      "3743\n",
      "3744\n",
      "3745\n",
      "3746\n",
      "3747\n",
      "3748\n",
      "3749\n",
      "3750\n",
      "3751\n",
      "3752\n",
      "3753\n",
      "3754\n",
      "3755\n",
      "3756\n",
      "3757\n",
      "3758\n",
      "3759\n",
      "3760\n",
      "3761\n",
      "3762\n",
      "3763\n",
      "3764\n",
      "3765\n",
      "3766\n",
      "3767\n",
      "3768\n",
      "3769\n",
      "3770\n",
      "3771\n",
      "3772\n",
      "3773\n",
      "3774\n",
      "3775\n",
      "3776\n",
      "3777\n",
      "3778\n",
      "3779\n",
      "3780\n",
      "3781\n",
      "3782\n",
      "3783\n",
      "3784\n",
      "3785\n",
      "3786\n",
      "3787\n",
      "3788\n",
      "3789\n",
      "3790\n",
      "3791\n",
      "3792\n",
      "3793\n",
      "3794\n",
      "3795\n",
      "3796\n",
      "3797\n",
      "3798\n",
      "3799\n",
      "3800\n",
      "3801\n",
      "3802\n",
      "3803\n",
      "3804\n",
      "3805\n",
      "3806\n",
      "3807\n",
      "3808\n",
      "3809\n",
      "3810\n",
      "3811\n",
      "3812\n",
      "3813\n",
      "3814\n",
      "3815\n",
      "3816\n",
      "3817\n",
      "3818\n",
      "3819\n",
      "3820\n",
      "3821\n",
      "3822\n",
      "3823\n",
      "3824\n",
      "3825\n",
      "3826\n",
      "3827\n",
      "3828\n",
      "3829\n",
      "3830\n",
      "3831\n",
      "3832\n",
      "3833\n",
      "3834\n",
      "3835\n",
      "3836\n",
      "3837\n",
      "3838\n",
      "3839\n",
      "3840\n",
      "3841\n",
      "3842\n",
      "3843\n",
      "3844\n",
      "3845\n",
      "3846\n",
      "3847\n",
      "3848\n",
      "3849\n",
      "3850\n",
      "3851\n",
      "3852\n",
      "3853\n",
      "3854\n",
      "3855\n",
      "3856\n",
      "3857\n",
      "3858\n",
      "3859\n",
      "3860\n",
      "3861\n",
      "3862\n",
      "3863\n",
      "3864\n",
      "3865\n",
      "3866\n",
      "3867\n",
      "3868\n",
      "3869\n",
      "3870\n",
      "3871\n",
      "3872\n",
      "3873\n",
      "3874\n",
      "3875\n",
      "3876\n",
      "3877\n",
      "3878\n",
      "3879\n",
      "3880\n",
      "3881\n",
      "3882\n",
      "3883\n",
      "3884\n",
      "3885\n",
      "3886\n",
      "3887\n",
      "3888\n",
      "3889\n",
      "3890\n",
      "3891\n",
      "3892\n",
      "3893\n",
      "3894\n",
      "3895\n",
      "3896\n",
      "3897\n",
      "3898\n",
      "3899\n",
      "3900\n",
      "3901\n",
      "3902\n",
      "3903\n",
      "3904\n",
      "3905\n",
      "3906\n",
      "3907\n",
      "3908\n",
      "3909\n",
      "3910\n",
      "3911\n",
      "3912\n",
      "3913\n",
      "3914\n",
      "3915\n",
      "3916\n",
      "3917\n",
      "3918\n",
      "3919\n",
      "3920\n",
      "3921\n",
      "3922\n",
      "3923\n",
      "3924\n",
      "3925\n",
      "3926\n",
      "3927\n",
      "3928\n",
      "3929\n",
      "3930\n",
      "3931\n",
      "3932\n",
      "3933\n",
      "3934\n",
      "3935\n",
      "3936\n",
      "3937\n",
      "3938\n",
      "3939\n",
      "3940\n",
      "3941\n",
      "3942\n",
      "3943\n",
      "3944\n",
      "3945\n",
      "3946\n",
      "3947\n",
      "3948\n",
      "3949\n",
      "3950\n",
      "3951\n",
      "3952\n",
      "3953\n",
      "3954\n",
      "3955\n",
      "3956\n",
      "3957\n",
      "3958\n",
      "3959\n",
      "3960\n",
      "3961\n",
      "3962\n",
      "3963\n",
      "3964\n",
      "3965\n",
      "3966\n",
      "3967\n",
      "3968\n",
      "3969\n",
      "3970\n",
      "3971\n",
      "3972\n",
      "3973\n",
      "3974\n",
      "3975\n",
      "3976\n",
      "3977\n",
      "3978\n",
      "3979\n",
      "3980\n",
      "3981\n",
      "3982\n",
      "3983\n",
      "3984\n",
      "3985\n",
      "3986\n",
      "3987\n",
      "3988\n",
      "3989\n",
      "3990\n",
      "3991\n",
      "3992\n",
      "3993\n",
      "3994\n",
      "3995\n",
      "3996\n",
      "3997\n",
      "3998\n",
      "3999\n",
      "4000\n",
      "4001\n",
      "4002\n",
      "4003\n",
      "4004\n",
      "4005\n",
      "4006\n",
      "4007\n",
      "4008\n",
      "4009\n",
      "4010\n",
      "4011\n",
      "4012\n",
      "4013\n",
      "4014\n",
      "4015\n",
      "4016\n",
      "4017\n",
      "4018\n",
      "4019\n",
      "4020\n",
      "4021\n",
      "4022\n",
      "4023\n",
      "4024\n",
      "4025\n",
      "4026\n",
      "4027\n",
      "4028\n",
      "4029\n",
      "4030\n",
      "4031\n",
      "4032\n",
      "4033\n",
      "4034\n",
      "4035\n",
      "4036\n",
      "4037\n",
      "4038\n",
      "4039\n",
      "4040\n",
      "4041\n",
      "4042\n",
      "4043\n",
      "4044\n",
      "4045\n",
      "4046\n",
      "4047\n",
      "4048\n",
      "4049\n",
      "4050\n",
      "4051\n",
      "4052\n",
      "4053\n",
      "4054\n",
      "4055\n",
      "4056\n",
      "4057\n",
      "4058\n",
      "4059\n",
      "4060\n",
      "4061\n",
      "4062\n",
      "4063\n",
      "4064\n",
      "4065\n",
      "4066\n",
      "4067\n",
      "4068\n",
      "4069\n",
      "4070\n",
      "4071\n",
      "4072\n",
      "4073\n",
      "4074\n",
      "4075\n",
      "4076\n",
      "4077\n",
      "4078\n",
      "4079\n",
      "4080\n",
      "4081\n",
      "4082\n",
      "4083\n",
      "4084\n",
      "4085\n",
      "4086\n",
      "4087\n",
      "4088\n",
      "4089\n",
      "4090\n",
      "4091\n",
      "4092\n",
      "4093\n",
      "4094\n",
      "4095\n",
      "4096\n",
      "4097\n",
      "4098\n",
      "4099\n",
      "4100\n",
      "4101\n",
      "4102\n",
      "4103\n",
      "4104\n",
      "4105\n",
      "4106\n",
      "4107\n",
      "4108\n",
      "4109\n",
      "4110\n",
      "4111\n",
      "4112\n",
      "4113\n",
      "4114\n",
      "4115\n",
      "4116\n",
      "4117\n",
      "4118\n",
      "4119\n",
      "4120\n",
      "4121\n",
      "4122\n",
      "4123\n",
      "4124\n",
      "4125\n",
      "4126\n",
      "4127\n",
      "4128\n",
      "4129\n",
      "4130\n",
      "4131\n",
      "4132\n",
      "4133\n",
      "4134\n",
      "4135\n",
      "4136\n",
      "4137\n",
      "4138\n",
      "4139\n",
      "4140\n",
      "4141\n",
      "4142\n",
      "4143\n",
      "4144\n",
      "4145\n",
      "4146\n",
      "4147\n",
      "4148\n",
      "4149\n",
      "4150\n",
      "4151\n",
      "4152\n",
      "4153\n",
      "4154\n",
      "4155\n",
      "4156\n",
      "4157\n",
      "4158\n",
      "4159\n",
      "4160\n",
      "4161\n",
      "4162\n",
      "4163\n",
      "4164\n",
      "4165\n",
      "4166\n",
      "4167\n",
      "4168\n",
      "4169\n",
      "4170\n",
      "4171\n",
      "4172\n",
      "4173\n",
      "4174\n",
      "4175\n",
      "4176\n",
      "4177\n",
      "4178\n",
      "4179\n",
      "4180\n",
      "4181\n",
      "4182\n",
      "4183\n",
      "4184\n",
      "4185\n",
      "4186\n",
      "4187\n",
      "4188\n",
      "4189\n",
      "4190\n",
      "4191\n",
      "4192\n",
      "4193\n",
      "4194\n",
      "4195\n",
      "4196\n",
      "4197\n",
      "4198\n",
      "4199\n",
      "4200\n",
      "4201\n",
      "4202\n",
      "4203\n",
      "4204\n",
      "4205\n",
      "4206\n",
      "4207\n",
      "4208\n",
      "4209\n",
      "4210\n",
      "4211\n",
      "4212\n",
      "4213\n",
      "4214\n",
      "4215\n",
      "4216\n",
      "4217\n",
      "4218\n",
      "4219\n",
      "4220\n",
      "4221\n",
      "4222\n",
      "4223\n",
      "4224\n",
      "4225\n",
      "4226\n",
      "4227\n",
      "4228\n",
      "4229\n",
      "4230\n",
      "4231\n",
      "4232\n",
      "4233\n",
      "4234\n",
      "4235\n",
      "4236\n",
      "4237\n",
      "4238\n",
      "4239\n",
      "4240\n",
      "4241\n",
      "4242\n",
      "4243\n",
      "4244\n",
      "4245\n",
      "4246\n",
      "4247\n",
      "4248\n",
      "4249\n",
      "4250\n",
      "4251\n",
      "4252\n",
      "4253\n",
      "4254\n",
      "4255\n",
      "4256\n",
      "4257\n",
      "4258\n",
      "4259\n",
      "4260\n",
      "4261\n",
      "4262\n",
      "4263\n",
      "4264\n",
      "4265\n",
      "4266\n",
      "4267\n",
      "4268\n",
      "4269\n",
      "4270\n",
      "4271\n",
      "4272\n",
      "4273\n",
      "4274\n",
      "4275\n",
      "4276\n",
      "4277\n",
      "4278\n",
      "4279\n",
      "4280\n",
      "4281\n",
      "4282\n",
      "4283\n",
      "4284\n",
      "4285\n",
      "4286\n",
      "4287\n",
      "4288\n",
      "4289\n",
      "4290\n",
      "4291\n",
      "4292\n",
      "4293\n",
      "4294\n",
      "4295\n",
      "4296\n",
      "4297\n",
      "4298\n",
      "4299\n",
      "4300\n",
      "4301\n",
      "4302\n",
      "4303\n",
      "4304\n",
      "4305\n",
      "4306\n",
      "4307\n",
      "4308\n",
      "4309\n",
      "4310\n",
      "4311\n",
      "4312\n",
      "4313\n",
      "4314\n",
      "4315\n",
      "4316\n",
      "4317\n",
      "4318\n",
      "4319\n",
      "4320\n",
      "4321\n",
      "4322\n",
      "4323\n",
      "4324\n",
      "4325\n",
      "4326\n",
      "4327\n",
      "4328\n",
      "4329\n",
      "4330\n",
      "4331\n",
      "4332\n",
      "4333\n",
      "4334\n",
      "4335\n",
      "4336\n",
      "4337\n",
      "4338\n",
      "4339\n",
      "4340\n",
      "4341\n",
      "4342\n",
      "4343\n",
      "4344\n",
      "4345\n",
      "4346\n",
      "4347\n",
      "4348\n",
      "4349\n",
      "4350\n",
      "4351\n",
      "4352\n",
      "4353\n",
      "4354\n",
      "4355\n",
      "4356\n",
      "4357\n",
      "4358\n",
      "4359\n",
      "4360\n",
      "4361\n",
      "4362\n",
      "4363\n",
      "4364\n",
      "4365\n",
      "4366\n",
      "4367\n",
      "4368\n",
      "4369\n",
      "4370\n",
      "4371\n",
      "4372\n",
      "4373\n",
      "4374\n",
      "4375\n",
      "4376\n",
      "4377\n",
      "4378\n",
      "4379\n",
      "4380\n",
      "4381\n",
      "4382\n",
      "4383\n",
      "4384\n",
      "4385\n",
      "4386\n",
      "4387\n",
      "4388\n",
      "4389\n",
      "4390\n",
      "4391\n",
      "4392\n",
      "4393\n",
      "4394\n",
      "4395\n",
      "4396\n",
      "4397\n",
      "4398\n",
      "4399\n",
      "4400\n",
      "4401\n",
      "4402\n",
      "4403\n",
      "4404\n",
      "4405\n",
      "4406\n",
      "4407\n",
      "4408\n",
      "4409\n",
      "4410\n",
      "4411\n",
      "4412\n",
      "4413\n",
      "4414\n",
      "4415\n",
      "4416\n",
      "4417\n",
      "4418\n",
      "4419\n",
      "4420\n",
      "4421\n",
      "4422\n",
      "4423\n",
      "4424\n",
      "4425\n",
      "4426\n",
      "4427\n",
      "4428\n",
      "4429\n",
      "4430\n",
      "4431\n",
      "4432\n",
      "4433\n",
      "4434\n",
      "4435\n",
      "4436\n",
      "4437\n",
      "4438\n",
      "4439\n",
      "4440\n",
      "4441\n",
      "4442\n",
      "4443\n",
      "4444\n",
      "4445\n",
      "4446\n",
      "4447\n",
      "4448\n",
      "4449\n",
      "4450\n",
      "4451\n",
      "4452\n",
      "4453\n",
      "4454\n",
      "4455\n",
      "4456\n",
      "4457\n",
      "4458\n",
      "4459\n",
      "4460\n",
      "4461\n",
      "4462\n",
      "4463\n",
      "4464\n",
      "4465\n",
      "4466\n",
      "4467\n",
      "4468\n",
      "4469\n",
      "4470\n",
      "4471\n",
      "4472\n",
      "4473\n",
      "4474\n",
      "4475\n",
      "4476\n",
      "4477\n",
      "4478\n",
      "4479\n",
      "4480\n",
      "4481\n",
      "4482\n",
      "4483\n",
      "4484\n",
      "4485\n",
      "4486\n",
      "4487\n",
      "4488\n",
      "4489\n",
      "4490\n",
      "4491\n",
      "4492\n",
      "4493\n",
      "4494\n",
      "4495\n",
      "4496\n",
      "4497\n",
      "4498\n",
      "4499\n",
      "4500\n",
      "4501\n",
      "4502\n",
      "4503\n",
      "4504\n",
      "4505\n",
      "4506\n",
      "4507\n",
      "4508\n",
      "4509\n",
      "4510\n",
      "4511\n",
      "4512\n",
      "4513\n",
      "4514\n",
      "4515\n",
      "4516\n",
      "4517\n",
      "4518\n",
      "4519\n",
      "4520\n",
      "4521\n",
      "4522\n",
      "4523\n",
      "4524\n",
      "4525\n",
      "4526\n",
      "4527\n",
      "4528\n",
      "4529\n",
      "4530\n",
      "4531\n",
      "4532\n",
      "4533\n",
      "4534\n",
      "4535\n",
      "4536\n",
      "4537\n",
      "4538\n",
      "4539\n",
      "4540\n",
      "4541\n",
      "4542\n",
      "4543\n",
      "4544\n",
      "4545\n",
      "4546\n",
      "4547\n",
      "4548\n",
      "4549\n",
      "4550\n",
      "4551\n",
      "4552\n",
      "4553\n",
      "4554\n",
      "4555\n",
      "4556\n",
      "4557\n",
      "4558\n",
      "4559\n",
      "4560\n",
      "4561\n",
      "4562\n",
      "4563\n",
      "4564\n",
      "4565\n",
      "4566\n",
      "4567\n",
      "4568\n",
      "4569\n",
      "4570\n",
      "4571\n",
      "4572\n",
      "4573\n",
      "4574\n",
      "4575\n",
      "4576\n",
      "4577\n",
      "4578\n",
      "4579\n",
      "4580\n",
      "4581\n",
      "4582\n",
      "4583\n",
      "4584\n",
      "4585\n",
      "4586\n",
      "4587\n",
      "4588\n",
      "4589\n",
      "4590\n",
      "4591\n",
      "4592\n",
      "4593\n",
      "4594\n",
      "4595\n",
      "4596\n",
      "4597\n",
      "4598\n",
      "4599\n",
      "4600\n",
      "4601\n",
      "4602\n",
      "4603\n",
      "4604\n",
      "4605\n",
      "4606\n",
      "4607\n",
      "4608\n",
      "4609\n",
      "4610\n",
      "4611\n",
      "4612\n",
      "4613\n",
      "4614\n",
      "4615\n",
      "4616\n",
      "4617\n",
      "4618\n",
      "4619\n",
      "4620\n",
      "4621\n",
      "4622\n",
      "4623\n",
      "4624\n",
      "4625\n",
      "4626\n",
      "4627\n",
      "4628\n",
      "4629\n",
      "4630\n",
      "4631\n",
      "4632\n",
      "4633\n",
      "4634\n",
      "4635\n",
      "4636\n",
      "4637\n",
      "4638\n",
      "4639\n",
      "4640\n",
      "4641\n",
      "4642\n",
      "4643\n",
      "4644\n",
      "4645\n",
      "4646\n",
      "4647\n",
      "4648\n",
      "4649\n",
      "4650\n",
      "4651\n",
      "4652\n",
      "4653\n",
      "4654\n",
      "4655\n",
      "4656\n",
      "4657\n",
      "4658\n",
      "4659\n",
      "4660\n",
      "4661\n",
      "4662\n",
      "4663\n",
      "4664\n",
      "4665\n",
      "4666\n",
      "4667\n",
      "4668\n",
      "4669\n",
      "4670\n",
      "4671\n",
      "4672\n",
      "4673\n",
      "4674\n",
      "4675\n",
      "4676\n",
      "4677\n",
      "4678\n",
      "4679\n",
      "4680\n",
      "4681\n",
      "4682\n",
      "4683\n",
      "4684\n",
      "4685\n",
      "4686\n",
      "4687\n",
      "4688\n",
      "4689\n",
      "4690\n",
      "4691\n",
      "4692\n",
      "4693\n",
      "4694\n",
      "4695\n",
      "4696\n",
      "4697\n",
      "4698\n",
      "4699\n",
      "4700\n",
      "4701\n",
      "4702\n",
      "4703\n",
      "4704\n",
      "4705\n",
      "4706\n",
      "4707\n",
      "4708\n",
      "4709\n",
      "4710\n",
      "4711\n",
      "4712\n",
      "4713\n",
      "4714\n",
      "4715\n",
      "4716\n",
      "4717\n",
      "4718\n",
      "4719\n",
      "4720\n",
      "4721\n",
      "4722\n",
      "4723\n",
      "4724\n",
      "4725\n",
      "4726\n",
      "4727\n",
      "4728\n",
      "4729\n",
      "4730\n",
      "4731\n",
      "4732\n",
      "4733\n",
      "4734\n",
      "4735\n",
      "4736\n",
      "4737\n",
      "4738\n",
      "4739\n",
      "4740\n",
      "4741\n",
      "4742\n",
      "4743\n",
      "4744\n",
      "4745\n",
      "4746\n",
      "4747\n",
      "4748\n",
      "4749\n",
      "4750\n",
      "4751\n",
      "4752\n",
      "4753\n",
      "4754\n",
      "4755\n",
      "4756\n",
      "4757\n",
      "4758\n",
      "4759\n",
      "4760\n",
      "4761\n",
      "4762\n",
      "4763\n",
      "4764\n",
      "4765\n",
      "4766\n",
      "4767\n",
      "4768\n",
      "4769\n",
      "4770\n",
      "4771\n",
      "4772\n",
      "4773\n",
      "4774\n",
      "4775\n",
      "4776\n",
      "4777\n",
      "4778\n",
      "4779\n",
      "4780\n",
      "4781\n",
      "4782\n",
      "4783\n",
      "4784\n",
      "4785\n",
      "4786\n",
      "4787\n",
      "4788\n",
      "4789\n",
      "4790\n",
      "4791\n",
      "4792\n",
      "4793\n",
      "4794\n",
      "4795\n",
      "4796\n",
      "4797\n",
      "4798\n",
      "4799\n",
      "4800\n",
      "4801\n",
      "4802\n",
      "4803\n",
      "4804\n",
      "4805\n",
      "4806\n",
      "4807\n",
      "4808\n",
      "4809\n",
      "4810\n",
      "4811\n",
      "4812\n",
      "4813\n",
      "4814\n",
      "4815\n",
      "4816\n",
      "4817\n",
      "4818\n",
      "4819\n",
      "4820\n",
      "4821\n",
      "4822\n",
      "4823\n",
      "4824\n",
      "4825\n",
      "4826\n",
      "4827\n",
      "4828\n",
      "4829\n",
      "4830\n",
      "4831\n",
      "4832\n",
      "4833\n",
      "4834\n",
      "4835\n",
      "4836\n",
      "4837\n",
      "4838\n",
      "4839\n",
      "4840\n",
      "4841\n",
      "4842\n",
      "4843\n",
      "4844\n",
      "4845\n",
      "4846\n",
      "4847\n",
      "4848\n",
      "4849\n",
      "4850\n",
      "4851\n",
      "4852\n",
      "4853\n",
      "4854\n",
      "4855\n",
      "4856\n",
      "4857\n",
      "4858\n",
      "4859\n",
      "4860\n",
      "4861\n",
      "4862\n",
      "4863\n",
      "4864\n",
      "4865\n",
      "4866\n",
      "4867\n",
      "4868\n",
      "4869\n",
      "4870\n",
      "4871\n",
      "4872\n",
      "4873\n",
      "4874\n",
      "4875\n",
      "4876\n",
      "4877\n",
      "4878\n",
      "4879\n",
      "4880\n",
      "4881\n",
      "4882\n",
      "4883\n",
      "4884\n",
      "4885\n",
      "4886\n",
      "4887\n",
      "4888\n",
      "4889\n",
      "4890\n",
      "4891\n",
      "4892\n",
      "4893\n",
      "4894\n",
      "4895\n",
      "4896\n",
      "4897\n",
      "4898\n",
      "4899\n",
      "4900\n",
      "4901\n",
      "4902\n",
      "4903\n",
      "4904\n",
      "4905\n",
      "4906\n",
      "4907\n",
      "4908\n",
      "4909\n",
      "4910\n",
      "4911\n",
      "4912\n",
      "4913\n",
      "4914\n",
      "4915\n",
      "4916\n",
      "4917\n",
      "4918\n",
      "4919\n",
      "4920\n",
      "4921\n",
      "4922\n",
      "4923\n",
      "4924\n",
      "4925\n",
      "4926\n",
      "4927\n",
      "4928\n",
      "4929\n",
      "4930\n",
      "4931\n",
      "4932\n",
      "4933\n",
      "4934\n",
      "4935\n",
      "4936\n",
      "4937\n",
      "4938\n",
      "4939\n",
      "4940\n",
      "4941\n",
      "4942\n",
      "4943\n",
      "4944\n",
      "4945\n",
      "4946\n",
      "4947\n",
      "4948\n",
      "4949\n",
      "4950\n",
      "4951\n",
      "4952\n",
      "4953\n",
      "4954\n",
      "4955\n",
      "4956\n",
      "4957\n",
      "4958\n",
      "4959\n",
      "4960\n",
      "4961\n",
      "4962\n",
      "4963\n",
      "4964\n",
      "4965\n",
      "4966\n",
      "4967\n",
      "4968\n",
      "4969\n",
      "4970\n",
      "4971\n",
      "4972\n",
      "4973\n",
      "4974\n",
      "4975\n",
      "4976\n",
      "4977\n",
      "4978\n",
      "4979\n",
      "4980\n",
      "4981\n",
      "4982\n",
      "4983\n",
      "4984\n",
      "4985\n",
      "4986\n",
      "4987\n",
      "4988\n",
      "4989\n",
      "4990\n",
      "4991\n",
      "4992\n",
      "4993\n",
      "4994\n",
      "4995\n",
      "4996\n",
      "4997\n",
      "4998\n",
      "4999\n",
      "5000\n",
      "5001\n",
      "5002\n",
      "5003\n",
      "5004\n",
      "5005\n",
      "5006\n",
      "5007\n",
      "5008\n",
      "5009\n",
      "5010\n",
      "5011\n",
      "5012\n",
      "5013\n",
      "5014\n",
      "5015\n",
      "5016\n",
      "5017\n",
      "5018\n",
      "5019\n",
      "5020\n",
      "5021\n",
      "5022\n",
      "5023\n",
      "5024\n",
      "5025\n",
      "5026\n",
      "5027\n",
      "5028\n",
      "5029\n",
      "5030\n",
      "5031\n",
      "5032\n",
      "5033\n",
      "5034\n",
      "5035\n",
      "5036\n",
      "5037\n",
      "5038\n",
      "5039\n",
      "5040\n",
      "5041\n",
      "5042\n",
      "5043\n",
      "5044\n",
      "5045\n",
      "5046\n",
      "5047\n",
      "5048\n",
      "5049\n",
      "5050\n",
      "5051\n",
      "5052\n",
      "5053\n",
      "5054\n",
      "5055\n",
      "5056\n",
      "5057\n",
      "5058\n",
      "5059\n",
      "5060\n",
      "5061\n",
      "5062\n",
      "5063\n",
      "5064\n",
      "5065\n",
      "5066\n",
      "5067\n",
      "5068\n",
      "5069\n",
      "5070\n",
      "5071\n",
      "5072\n",
      "5073\n",
      "5074\n",
      "5075\n",
      "5076\n",
      "5077\n",
      "5078\n",
      "5079\n",
      "5080\n",
      "5081\n",
      "5082\n",
      "5083\n",
      "5084\n",
      "5085\n",
      "5086\n",
      "5087\n",
      "5088\n",
      "5089\n",
      "5090\n",
      "5091\n",
      "5092\n",
      "5093\n",
      "5094\n",
      "5095\n",
      "5096\n",
      "5097\n",
      "5098\n",
      "5099\n",
      "5100\n",
      "5101\n",
      "5102\n",
      "5103\n",
      "5104\n",
      "5105\n",
      "5106\n",
      "5107\n",
      "5108\n",
      "5109\n",
      "5110\n",
      "5111\n",
      "5112\n",
      "5113\n",
      "5114\n",
      "5115\n",
      "5116\n",
      "5117\n",
      "5118\n",
      "5119\n",
      "5120\n",
      "5121\n",
      "5122\n",
      "5123\n",
      "5124\n",
      "5125\n",
      "5126\n",
      "5127\n",
      "5128\n",
      "5129\n",
      "5130\n",
      "5131\n",
      "5132\n",
      "5133\n",
      "5134\n",
      "5135\n",
      "5136\n",
      "5137\n",
      "5138\n",
      "5139\n",
      "5140\n",
      "5141\n",
      "5142\n",
      "5143\n",
      "5144\n",
      "5145\n",
      "5146\n",
      "5147\n",
      "5148\n",
      "5149\n",
      "5150\n",
      "5151\n",
      "5152\n",
      "5153\n",
      "5154\n",
      "5155\n",
      "5156\n",
      "5157\n",
      "5158\n",
      "5159\n",
      "5160\n",
      "5161\n",
      "5162\n",
      "5163\n",
      "5164\n",
      "5165\n",
      "5166\n",
      "5167\n",
      "5168\n",
      "5169\n",
      "5170\n",
      "5171\n",
      "5172\n",
      "5173\n",
      "5174\n",
      "5175\n",
      "5176\n",
      "5177\n",
      "5178\n",
      "5179\n",
      "5180\n",
      "5181\n",
      "5182\n",
      "5183\n",
      "5184\n",
      "5185\n",
      "5186\n",
      "5187\n",
      "5188\n",
      "5189\n",
      "5190\n",
      "5191\n",
      "5192\n",
      "5193\n",
      "5194\n",
      "5195\n",
      "5196\n",
      "5197\n",
      "5198\n",
      "5199\n",
      "5200\n",
      "5201\n",
      "5202\n",
      "5203\n",
      "5204\n",
      "5205\n",
      "5206\n",
      "5207\n",
      "5208\n",
      "5209\n",
      "5210\n",
      "5211\n",
      "5212\n",
      "5213\n",
      "5214\n",
      "5215\n",
      "5216\n",
      "5217\n",
      "5218\n",
      "5219\n",
      "5220\n",
      "5221\n",
      "5222\n",
      "5223\n",
      "5224\n",
      "5225\n",
      "5226\n",
      "5227\n",
      "5228\n",
      "5229\n",
      "5230\n",
      "5231\n",
      "5232\n",
      "5233\n",
      "5234\n",
      "5235\n",
      "5236\n",
      "5237\n",
      "5238\n",
      "5239\n",
      "5240\n",
      "5241\n",
      "5242\n",
      "5243\n",
      "5244\n",
      "5245\n",
      "5246\n",
      "5247\n",
      "5248\n",
      "5249\n",
      "5250\n",
      "5251\n",
      "5252\n",
      "5253\n",
      "5254\n",
      "5255\n",
      "5256\n",
      "5257\n",
      "5258\n",
      "5259\n",
      "5260\n",
      "5261\n",
      "5262\n",
      "5263\n",
      "5264\n",
      "5265\n",
      "5266\n",
      "5267\n",
      "5268\n",
      "5269\n",
      "5270\n",
      "5271\n",
      "5272\n",
      "5273\n",
      "5274\n",
      "5275\n",
      "5276\n",
      "5277\n",
      "5278\n",
      "5279\n",
      "5280\n",
      "5281\n",
      "5282\n",
      "5283\n",
      "5284\n",
      "5285\n",
      "5286\n",
      "5287\n",
      "5288\n",
      "5289\n",
      "5290\n",
      "5291\n",
      "5292\n",
      "5293\n",
      "5294\n",
      "5295\n",
      "5296\n",
      "5297\n",
      "5298\n",
      "5299\n",
      "5300\n",
      "5301\n",
      "5302\n",
      "5303\n",
      "5304\n",
      "5305\n",
      "5306\n",
      "5307\n",
      "5308\n",
      "5309\n",
      "5310\n",
      "5311\n",
      "5312\n",
      "5313\n",
      "5314\n",
      "5315\n",
      "5316\n",
      "5317\n",
      "5318\n",
      "5319\n",
      "5320\n",
      "5321\n",
      "5322\n",
      "5323\n",
      "5324\n",
      "5325\n",
      "5326\n",
      "5327\n",
      "5328\n",
      "5329\n",
      "5330\n",
      "5331\n",
      "5332\n",
      "5333\n",
      "5334\n",
      "5335\n",
      "5336\n",
      "5337\n",
      "5338\n",
      "5339\n",
      "5340\n",
      "5341\n",
      "5342\n",
      "5343\n",
      "5344\n",
      "5345\n",
      "5346\n",
      "5347\n",
      "5348\n",
      "5349\n",
      "5350\n",
      "5351\n",
      "5352\n",
      "5353\n",
      "5354\n",
      "5355\n",
      "5356\n",
      "5357\n",
      "5358\n",
      "5359\n",
      "5360\n",
      "5361\n",
      "5362\n",
      "5363\n",
      "5364\n",
      "5365\n",
      "5366\n",
      "5367\n",
      "5368\n",
      "5369\n",
      "5370\n",
      "5371\n",
      "5372\n",
      "5373\n",
      "5374\n",
      "5375\n",
      "5376\n",
      "5377\n",
      "5378\n",
      "5379\n",
      "5380\n",
      "5381\n",
      "5382\n",
      "5383\n",
      "5384\n",
      "5385\n",
      "5386\n",
      "5387\n",
      "5388\n",
      "5389\n",
      "5390\n",
      "5391\n",
      "5392\n",
      "5393\n",
      "5394\n",
      "5395\n",
      "5396\n",
      "5397\n",
      "5398\n",
      "5399\n",
      "5400\n",
      "5401\n",
      "5402\n",
      "5403\n",
      "5404\n",
      "5405\n",
      "5406\n",
      "5407\n",
      "5408\n",
      "5409\n",
      "5410\n",
      "5411\n",
      "5412\n",
      "5413\n",
      "5414\n",
      "5415\n",
      "5416\n",
      "5417\n",
      "5418\n",
      "5419\n",
      "5420\n",
      "5421\n",
      "5422\n",
      "5423\n",
      "5424\n",
      "5425\n",
      "5426\n",
      "5427\n",
      "5428\n",
      "5429\n",
      "5430\n",
      "5431\n",
      "5432\n",
      "5433\n",
      "5434\n",
      "5435\n",
      "5436\n",
      "5437\n",
      "5438\n",
      "5439\n",
      "5440\n",
      "5441\n",
      "5442\n",
      "5443\n",
      "5444\n",
      "5445\n",
      "5446\n",
      "5447\n",
      "5448\n",
      "5449\n",
      "5450\n",
      "5451\n",
      "5452\n",
      "5453\n",
      "5454\n",
      "5455\n",
      "5456\n",
      "5457\n",
      "5458\n",
      "5459\n",
      "5460\n",
      "5461\n",
      "5462\n",
      "5463\n",
      "5464\n",
      "5465\n",
      "5466\n",
      "5467\n",
      "5468\n",
      "5469\n",
      "5470\n",
      "5471\n",
      "5472\n",
      "5473\n",
      "5474\n",
      "5475\n",
      "5476\n",
      "5477\n",
      "5478\n",
      "5479\n",
      "5480\n",
      "5481\n",
      "5482\n",
      "5483\n",
      "5484\n",
      "5485\n",
      "5486\n",
      "5487\n",
      "5488\n",
      "5489\n",
      "5490\n",
      "5491\n",
      "5492\n",
      "5493\n",
      "5494\n",
      "5495\n",
      "5496\n",
      "5497\n",
      "5498\n",
      "5499\n",
      "5500\n",
      "5501\n",
      "5502\n",
      "5503\n",
      "5504\n",
      "5505\n",
      "5506\n",
      "5507\n",
      "5508\n",
      "5509\n",
      "5510\n",
      "5511\n",
      "5512\n",
      "5513\n",
      "5514\n",
      "5515\n",
      "5516\n",
      "5517\n",
      "5518\n",
      "5519\n",
      "5520\n",
      "5521\n",
      "5522\n",
      "5523\n",
      "5524\n",
      "5525\n",
      "5526\n",
      "5527\n",
      "5528\n",
      "5529\n",
      "5530\n",
      "5531\n",
      "5532\n",
      "5533\n",
      "5534\n",
      "5535\n",
      "5536\n",
      "5537\n",
      "5538\n",
      "5539\n",
      "5540\n",
      "5541\n",
      "5542\n",
      "5543\n",
      "5544\n",
      "5545\n",
      "5546\n",
      "5547\n",
      "5548\n",
      "5549\n",
      "5550\n",
      "5551\n",
      "5552\n",
      "5553\n",
      "5554\n",
      "5555\n",
      "5556\n",
      "5557\n",
      "5558\n",
      "5559\n",
      "5560\n",
      "5561\n",
      "5562\n",
      "5563\n",
      "5564\n",
      "5565\n",
      "5566\n",
      "5567\n",
      "5568\n",
      "5569\n",
      "5570\n",
      "5571\n",
      "5572\n",
      "5573\n",
      "5574\n",
      "5575\n",
      "5576\n",
      "5577\n",
      "5578\n",
      "5579\n",
      "5580\n",
      "5581\n",
      "5582\n",
      "5583\n",
      "5584\n",
      "5585\n",
      "5586\n",
      "5587\n",
      "5588\n",
      "5589\n",
      "5590\n",
      "5591\n",
      "5592\n",
      "5593\n",
      "5594\n",
      "5595\n",
      "5596\n",
      "5597\n",
      "5598\n",
      "5599\n",
      "5600\n",
      "5601\n",
      "5602\n",
      "5603\n",
      "5604\n",
      "5605\n",
      "5606\n",
      "5607\n",
      "5608\n",
      "5609\n",
      "5610\n",
      "5611\n",
      "5612\n",
      "5613\n",
      "5614\n",
      "5615\n",
      "5616\n",
      "5617\n",
      "5618\n",
      "5619\n",
      "5620\n",
      "5621\n",
      "5622\n",
      "5623\n",
      "5624\n",
      "5625\n",
      "5626\n",
      "5627\n",
      "5628\n",
      "5629\n",
      "5630\n",
      "5631\n",
      "5632\n",
      "5633\n",
      "5634\n",
      "5635\n",
      "5636\n",
      "5637\n",
      "5638\n",
      "5639\n",
      "5640\n",
      "5641\n",
      "5642\n",
      "5643\n",
      "5644\n",
      "5645\n",
      "5646\n",
      "5647\n",
      "5648\n",
      "5649\n",
      "5650\n",
      "5651\n",
      "5652\n",
      "5653\n",
      "5654\n",
      "5655\n",
      "5656\n",
      "5657\n",
      "5658\n",
      "5659\n",
      "5660\n",
      "5661\n",
      "5662\n",
      "5663\n",
      "5664\n",
      "5665\n",
      "5666\n",
      "5667\n",
      "5668\n",
      "5669\n",
      "5670\n",
      "5671\n",
      "5672\n",
      "5673\n",
      "5674\n",
      "5675\n",
      "5676\n",
      "5677\n",
      "5678\n",
      "5679\n",
      "5680\n",
      "5681\n",
      "5682\n",
      "5683\n",
      "5684\n",
      "5685\n",
      "5686\n",
      "5687\n",
      "5688\n",
      "5689\n",
      "5690\n",
      "5691\n",
      "5692\n",
      "5693\n",
      "5694\n",
      "5695\n",
      "5696\n",
      "5697\n",
      "5698\n",
      "5699\n",
      "5700\n",
      "5701\n",
      "5702\n",
      "5703\n",
      "5704\n",
      "5705\n",
      "5706\n",
      "5707\n",
      "5708\n",
      "5709\n",
      "5710\n",
      "5711\n",
      "5712\n",
      "5713\n",
      "5714\n",
      "5715\n",
      "5716\n",
      "5717\n",
      "5718\n",
      "5719\n",
      "5720\n",
      "5721\n",
      "5722\n",
      "5723\n",
      "5724\n",
      "5725\n",
      "5726\n",
      "5727\n",
      "5728\n",
      "5729\n",
      "5730\n",
      "5731\n",
      "5732\n",
      "5733\n",
      "5734\n",
      "5735\n",
      "5736\n",
      "5737\n",
      "5738\n",
      "5739\n",
      "5740\n",
      "5741\n",
      "5742\n",
      "5743\n",
      "5744\n",
      "5745\n",
      "5746\n",
      "5747\n",
      "5748\n",
      "5749\n",
      "5750\n",
      "5751\n",
      "5752\n",
      "5753\n",
      "5754\n",
      "5755\n",
      "5756\n",
      "5757\n",
      "5758\n",
      "5759\n",
      "5760\n",
      "5761\n",
      "5762\n",
      "5763\n",
      "5764\n",
      "5765\n",
      "5766\n",
      "5767\n",
      "5768\n",
      "5769\n",
      "5770\n",
      "5771\n",
      "5772\n",
      "5773\n",
      "5774\n",
      "5775\n",
      "5776\n",
      "5777\n",
      "5778\n",
      "5779\n",
      "5780\n",
      "5781\n",
      "5782\n",
      "5783\n",
      "5784\n",
      "5785\n",
      "5786\n",
      "5787\n",
      "5788\n",
      "5789\n",
      "5790\n",
      "5791\n",
      "5792\n",
      "5793\n",
      "5794\n",
      "5795\n",
      "5796\n",
      "5797\n",
      "5798\n",
      "5799\n",
      "5800\n",
      "5801\n",
      "5802\n",
      "5803\n",
      "5804\n",
      "5805\n",
      "5806\n",
      "5807\n",
      "5808\n",
      "5809\n",
      "5810\n",
      "5811\n",
      "5812\n",
      "5813\n",
      "5814\n",
      "5815\n",
      "5816\n",
      "5817\n",
      "5818\n",
      "5819\n",
      "5820\n",
      "5821\n",
      "5822\n",
      "5823\n",
      "5824\n",
      "5825\n",
      "5826\n",
      "5827\n",
      "5828\n",
      "5829\n",
      "5830\n",
      "5831\n",
      "5832\n",
      "5833\n",
      "5834\n",
      "5835\n",
      "5836\n",
      "5837\n",
      "5838\n",
      "5839\n",
      "5840\n",
      "5841\n",
      "5842\n",
      "5843\n",
      "5844\n",
      "5845\n",
      "5846\n",
      "5847\n",
      "5848\n",
      "5849\n",
      "5850\n",
      "5851\n",
      "5852\n",
      "5853\n",
      "5854\n",
      "5855\n",
      "5856\n",
      "5857\n",
      "5858\n",
      "5859\n",
      "5860\n",
      "5861\n",
      "5862\n",
      "5863\n",
      "5864\n",
      "5865\n",
      "5866\n",
      "5867\n",
      "5868\n",
      "5869\n",
      "5870\n",
      "5871\n",
      "5872\n",
      "5873\n",
      "5874\n",
      "5875\n",
      "5876\n",
      "5877\n",
      "5878\n",
      "5879\n",
      "5880\n",
      "5881\n",
      "5882\n",
      "5883\n",
      "5884\n",
      "5885\n",
      "5886\n",
      "5887\n",
      "5888\n",
      "5889\n",
      "5890\n",
      "5891\n",
      "5892\n",
      "5893\n",
      "5894\n",
      "5895\n",
      "5896\n",
      "5897\n",
      "5898\n",
      "5899\n",
      "5900\n",
      "5901\n",
      "5902\n",
      "5903\n",
      "5904\n",
      "5905\n",
      "5906\n",
      "5907\n",
      "5908\n",
      "5909\n",
      "5910\n",
      "5911\n",
      "5912\n",
      "5913\n",
      "5914\n",
      "5915\n",
      "5916\n",
      "5917\n",
      "5918\n",
      "5919\n",
      "5920\n",
      "5921\n",
      "5922\n",
      "5923\n",
      "5924\n",
      "5925\n",
      "5926\n",
      "5927\n",
      "5928\n",
      "5929\n",
      "5930\n",
      "5931\n",
      "5932\n",
      "5933\n",
      "5934\n",
      "5935\n",
      "5936\n",
      "5937\n",
      "5938\n",
      "5939\n",
      "5940\n",
      "5941\n",
      "5942\n",
      "5943\n",
      "5944\n",
      "5945\n",
      "5946\n",
      "5947\n",
      "5948\n",
      "5949\n",
      "5950\n",
      "5951\n",
      "5952\n",
      "5953\n",
      "5954\n",
      "5955\n",
      "5956\n",
      "5957\n",
      "5958\n",
      "5959\n",
      "5960\n",
      "5961\n",
      "5962\n",
      "5963\n",
      "5964\n",
      "5965\n",
      "5966\n",
      "5967\n",
      "5968\n",
      "5969\n",
      "5970\n",
      "5971\n",
      "5972\n",
      "5973\n",
      "5974\n",
      "5975\n",
      "5976\n",
      "5977\n",
      "5978\n",
      "5979\n",
      "5980\n",
      "5981\n",
      "5982\n",
      "5983\n",
      "5984\n",
      "5985\n",
      "5986\n",
      "5987\n",
      "5988\n",
      "5989\n",
      "5990\n",
      "5991\n",
      "5992\n",
      "5993\n",
      "5994\n",
      "5995\n",
      "5996\n",
      "5997\n",
      "5998\n",
      "5999\n",
      "6000\n",
      "6001\n",
      "6002\n",
      "6003\n",
      "6004\n",
      "6005\n",
      "6006\n",
      "6007\n",
      "6008\n",
      "6009\n",
      "6010\n",
      "6011\n",
      "6012\n",
      "6013\n",
      "6014\n",
      "6015\n",
      "6016\n",
      "6017\n",
      "6018\n",
      "6019\n",
      "6020\n",
      "6021\n",
      "6022\n",
      "6023\n",
      "6024\n",
      "6025\n",
      "6026\n",
      "6027\n",
      "6028\n",
      "6029\n",
      "6030\n",
      "6031\n",
      "6032\n",
      "6033\n",
      "6034\n",
      "6035\n",
      "6036\n",
      "6037\n",
      "6038\n",
      "6039\n",
      "6040\n",
      "6041\n",
      "6042\n",
      "6043\n",
      "6044\n",
      "6045\n",
      "6046\n",
      "6047\n",
      "6048\n",
      "6049\n",
      "6050\n",
      "6051\n",
      "6052\n",
      "6053\n",
      "6054\n",
      "6055\n",
      "6056\n",
      "6057\n",
      "6058\n",
      "6059\n",
      "6060\n",
      "6061\n",
      "6062\n",
      "6063\n",
      "6064\n",
      "6065\n",
      "6066\n",
      "6067\n",
      "6068\n",
      "6069\n",
      "6070\n",
      "6071\n",
      "6072\n",
      "6073\n",
      "6074\n",
      "6075\n",
      "6076\n",
      "6077\n",
      "6078\n",
      "6079\n",
      "6080\n",
      "6081\n",
      "6082\n",
      "6083\n",
      "6084\n",
      "6085\n",
      "6086\n",
      "6087\n",
      "6088\n",
      "6089\n",
      "6090\n",
      "6091\n",
      "6092\n",
      "6093\n",
      "6094\n",
      "6095\n",
      "6096\n",
      "6097\n",
      "6098\n",
      "6099\n",
      "6100\n",
      "6101\n",
      "6102\n",
      "6103\n",
      "6104\n",
      "6105\n",
      "6106\n",
      "6107\n",
      "6108\n",
      "6109\n",
      "6110\n",
      "6111\n",
      "6112\n",
      "6113\n",
      "6114\n",
      "6115\n",
      "6116\n",
      "6117\n",
      "6118\n",
      "6119\n",
      "6120\n",
      "6121\n",
      "6122\n",
      "6123\n",
      "6124\n",
      "6125\n",
      "6126\n",
      "6127\n",
      "6128\n",
      "6129\n",
      "6130\n",
      "6131\n",
      "6132\n",
      "6133\n",
      "6134\n",
      "6135\n",
      "6136\n",
      "6137\n",
      "6138\n",
      "6139\n",
      "6140\n",
      "6141\n",
      "6142\n",
      "6143\n",
      "6144\n",
      "6145\n",
      "6146\n",
      "6147\n",
      "6148\n",
      "6149\n",
      "6150\n",
      "6151\n",
      "6152\n",
      "6153\n",
      "6154\n",
      "6155\n",
      "6156\n",
      "6157\n",
      "6158\n",
      "6159\n",
      "6160\n",
      "6161\n",
      "6162\n",
      "6163\n",
      "6164\n",
      "6165\n",
      "6166\n",
      "6167\n",
      "6168\n",
      "6169\n",
      "6170\n",
      "6171\n",
      "6172\n",
      "6173\n",
      "6174\n",
      "6175\n",
      "6176\n",
      "6177\n",
      "6178\n",
      "6179\n",
      "6180\n",
      "6181\n",
      "6182\n",
      "6183\n",
      "6184\n",
      "6185\n",
      "6186\n",
      "6187\n",
      "6188\n",
      "6189\n",
      "6190\n",
      "6191\n",
      "6192\n",
      "6193\n",
      "6194\n",
      "6195\n",
      "6196\n",
      "6197\n",
      "6198\n",
      "6199\n",
      "6200\n",
      "6201\n",
      "6202\n",
      "6203\n",
      "6204\n",
      "6205\n",
      "6206\n",
      "6207\n",
      "6208\n",
      "6209\n",
      "6210\n",
      "6211\n",
      "6212\n",
      "6213\n",
      "6214\n",
      "6215\n",
      "6216\n",
      "6217\n",
      "6218\n",
      "6219\n",
      "6220\n",
      "6221\n",
      "6222\n",
      "6223\n",
      "6224\n",
      "6225\n",
      "6226\n",
      "6227\n",
      "6228\n",
      "6229\n",
      "6230\n",
      "6231\n",
      "6232\n",
      "6233\n",
      "6234\n",
      "6235\n",
      "6236\n",
      "6237\n",
      "6238\n",
      "6239\n",
      "6240\n",
      "6241\n",
      "6242\n",
      "6243\n",
      "6244\n",
      "6245\n",
      "6246\n",
      "6247\n",
      "6248\n",
      "6249\n",
      "6250\n",
      "6251\n",
      "6252\n",
      "6253\n",
      "6254\n",
      "6255\n",
      "6256\n",
      "6257\n",
      "6258\n",
      "6259\n",
      "6260\n",
      "6261\n",
      "6262\n",
      "6263\n",
      "6264\n",
      "6265\n",
      "6266\n",
      "6267\n",
      "6268\n",
      "6269\n",
      "6270\n",
      "6271\n",
      "6272\n",
      "6273\n",
      "6274\n",
      "6275\n",
      "6276\n",
      "6277\n",
      "6278\n",
      "6279\n",
      "6280\n",
      "6281\n",
      "6282\n",
      "6283\n",
      "6284\n",
      "6285\n",
      "6286\n",
      "6287\n",
      "6288\n",
      "6289\n",
      "6290\n",
      "6291\n",
      "6292\n",
      "6293\n",
      "6294\n",
      "6295\n",
      "6296\n",
      "6297\n",
      "6298\n",
      "6299\n",
      "6300\n",
      "6301\n",
      "6302\n",
      "6303\n",
      "6304\n",
      "6305\n",
      "6306\n",
      "6307\n",
      "6308\n",
      "6309\n",
      "6310\n",
      "6311\n",
      "6312\n",
      "6313\n",
      "6314\n",
      "6315\n",
      "6316\n",
      "6317\n",
      "6318\n",
      "6319\n",
      "6320\n",
      "6321\n",
      "6322\n",
      "6323\n",
      "6324\n",
      "6325\n",
      "6326\n",
      "6327\n",
      "6328\n",
      "6329\n",
      "6330\n",
      "6331\n",
      "6332\n",
      "6333\n",
      "6334\n",
      "6335\n",
      "6336\n",
      "6337\n",
      "6338\n",
      "6339\n",
      "6340\n",
      "6341\n",
      "6342\n",
      "6343\n",
      "6344\n",
      "6345\n",
      "6346\n",
      "6347\n",
      "6348\n",
      "6349\n",
      "6350\n",
      "6351\n",
      "6352\n",
      "6353\n",
      "6354\n",
      "6355\n",
      "6356\n",
      "6357\n",
      "6358\n",
      "6359\n",
      "6360\n",
      "6361\n",
      "6362\n",
      "6363\n",
      "6364\n",
      "6365\n",
      "6366\n",
      "6367\n",
      "6368\n",
      "6369\n",
      "6370\n",
      "6371\n",
      "6372\n",
      "6373\n",
      "6374\n",
      "6375\n",
      "6376\n",
      "6377\n",
      "6378\n",
      "6379\n",
      "6380\n",
      "6381\n",
      "6382\n",
      "6383\n",
      "6384\n",
      "6385\n",
      "6386\n",
      "6387\n",
      "6388\n",
      "6389\n",
      "6390\n",
      "6391\n",
      "6392\n",
      "6393\n",
      "6394\n",
      "6395\n",
      "6396\n",
      "6397\n",
      "6398\n",
      "6399\n",
      "6400\n",
      "6401\n",
      "6402\n",
      "6403\n",
      "6404\n",
      "6405\n",
      "6406\n",
      "6407\n",
      "6408\n",
      "6409\n",
      "6410\n",
      "6411\n",
      "6412\n",
      "6413\n",
      "6414\n",
      "6415\n",
      "6416\n",
      "6417\n",
      "6418\n",
      "6419\n",
      "6420\n",
      "6421\n",
      "6422\n",
      "6423\n",
      "6424\n",
      "6425\n",
      "6426\n",
      "6427\n",
      "6428\n",
      "6429\n",
      "6430\n",
      "6431\n",
      "6432\n",
      "6433\n",
      "6434\n",
      "6435\n",
      "6436\n",
      "6437\n",
      "6438\n",
      "6439\n",
      "6440\n",
      "6441\n",
      "6442\n",
      "6443\n",
      "6444\n",
      "6445\n",
      "6446\n",
      "6447\n",
      "6448\n",
      "6449\n",
      "6450\n",
      "6451\n",
      "6452\n",
      "6453\n",
      "6454\n",
      "6455\n",
      "6456\n",
      "6457\n",
      "6458\n",
      "6459\n",
      "6460\n",
      "6461\n",
      "6462\n",
      "6463\n",
      "6464\n",
      "6465\n",
      "6466\n",
      "6467\n",
      "6468\n",
      "6469\n",
      "6470\n",
      "6471\n",
      "6472\n",
      "6473\n",
      "6474\n",
      "6475\n",
      "6476\n",
      "6477\n",
      "6478\n",
      "6479\n",
      "6480\n",
      "6481\n",
      "6482\n",
      "6483\n",
      "6484\n",
      "6485\n",
      "6486\n",
      "6487\n",
      "6488\n",
      "6489\n",
      "6490\n",
      "6491\n",
      "6492\n",
      "6493\n",
      "6494\n",
      "6495\n",
      "6496\n",
      "6497\n",
      "6498\n",
      "6499\n",
      "6500\n",
      "6501\n",
      "6502\n",
      "6503\n",
      "6504\n",
      "6505\n",
      "6506\n",
      "6507\n",
      "6508\n",
      "6509\n",
      "6510\n",
      "6511\n",
      "6512\n",
      "6513\n",
      "6514\n",
      "6515\n",
      "6516\n",
      "6517\n",
      "6518\n",
      "6519\n",
      "6520\n",
      "6521\n",
      "6522\n",
      "6523\n",
      "6524\n",
      "6525\n",
      "6526\n",
      "6527\n",
      "6528\n",
      "6529\n",
      "6530\n",
      "6531\n",
      "6532\n",
      "6533\n",
      "6534\n",
      "6535\n",
      "6536\n",
      "6537\n",
      "6538\n",
      "6539\n",
      "6540\n",
      "6541\n",
      "6542\n",
      "6543\n",
      "6544\n",
      "6545\n",
      "6546\n",
      "6547\n",
      "6548\n",
      "6549\n",
      "6550\n",
      "6551\n",
      "6552\n",
      "6553\n",
      "6554\n",
      "6555\n",
      "6556\n",
      "6557\n",
      "6558\n",
      "6559\n",
      "6560\n",
      "6561\n",
      "6562\n",
      "6563\n",
      "6564\n",
      "6565\n",
      "6566\n",
      "6567\n",
      "6568\n",
      "6569\n",
      "6570\n",
      "6571\n",
      "6572\n",
      "6573\n",
      "6574\n",
      "6575\n",
      "6576\n",
      "6577\n",
      "6578\n",
      "6579\n",
      "6580\n",
      "6581\n",
      "6582\n",
      "6583\n",
      "6584\n",
      "6585\n",
      "6586\n",
      "6587\n",
      "6588\n",
      "6589\n",
      "6590\n",
      "6591\n",
      "6592\n",
      "6593\n",
      "6594\n",
      "6595\n",
      "6596\n",
      "6597\n",
      "6598\n",
      "6599\n",
      "6600\n",
      "6601\n",
      "6602\n",
      "6603\n",
      "6604\n",
      "6605\n",
      "6606\n",
      "6607\n",
      "6608\n",
      "6609\n",
      "6610\n",
      "6611\n",
      "6612\n",
      "6613\n",
      "6614\n",
      "6615\n",
      "6616\n",
      "6617\n",
      "6618\n",
      "6619\n",
      "6620\n",
      "6621\n",
      "6622\n",
      "6623\n",
      "6624\n",
      "6625\n",
      "6626\n",
      "6627\n",
      "6628\n",
      "6629\n",
      "6630\n",
      "6631\n",
      "6632\n",
      "6633\n",
      "6634\n",
      "6635\n",
      "6636\n",
      "6637\n",
      "6638\n",
      "6639\n",
      "6640\n",
      "6641\n",
      "6642\n",
      "6643\n",
      "6644\n",
      "6645\n",
      "6646\n",
      "6647\n",
      "6648\n",
      "6649\n",
      "6650\n",
      "6651\n",
      "6652\n",
      "6653\n",
      "6654\n",
      "6655\n",
      "6656\n",
      "6657\n",
      "6658\n",
      "6659\n",
      "6660\n",
      "6661\n",
      "6662\n",
      "6663\n",
      "6664\n",
      "6665\n",
      "6666\n",
      "6667\n",
      "6668\n",
      "6669\n",
      "6670\n",
      "6671\n",
      "6672\n",
      "6673\n",
      "6674\n",
      "6675\n",
      "6676\n",
      "6677\n",
      "6678\n",
      "6679\n",
      "6680\n",
      "6681\n",
      "6682\n",
      "6683\n",
      "6684\n",
      "6685\n",
      "6686\n",
      "6687\n",
      "6688\n",
      "6689\n",
      "6690\n",
      "6691\n",
      "6692\n",
      "6693\n",
      "6694\n",
      "6695\n",
      "6696\n",
      "6697\n",
      "6698\n",
      "6699\n",
      "6700\n",
      "6701\n",
      "6702\n",
      "6703\n",
      "6704\n",
      "6705\n",
      "6706\n",
      "6707\n",
      "6708\n",
      "6709\n",
      "6710\n",
      "6711\n",
      "6712\n",
      "6713\n",
      "6714\n",
      "6715\n",
      "6716\n",
      "6717\n",
      "6718\n",
      "6719\n",
      "6720\n",
      "6721\n",
      "6722\n",
      "6723\n",
      "6724\n",
      "6725\n",
      "6726\n",
      "6727\n",
      "6728\n",
      "6729\n",
      "6730\n",
      "6731\n",
      "6732\n",
      "6733\n",
      "6734\n",
      "6735\n",
      "6736\n",
      "6737\n",
      "6738\n",
      "6739\n",
      "6740\n",
      "6741\n",
      "6742\n",
      "6743\n",
      "6744\n",
      "6745\n",
      "6746\n",
      "6747\n",
      "6748\n",
      "6749\n",
      "6750\n",
      "6751\n",
      "6752\n",
      "6753\n",
      "6754\n",
      "6755\n",
      "6756\n",
      "6757\n",
      "6758\n",
      "6759\n",
      "6760\n",
      "6761\n",
      "6762\n",
      "6763\n",
      "6764\n",
      "6765\n",
      "6766\n",
      "6767\n",
      "6768\n",
      "6769\n",
      "6770\n",
      "6771\n",
      "6772\n",
      "6773\n",
      "6774\n",
      "6775\n",
      "6776\n",
      "6777\n",
      "6778\n",
      "6779\n",
      "6780\n",
      "6781\n",
      "6782\n",
      "6783\n",
      "6784\n",
      "6785\n",
      "6786\n",
      "6787\n",
      "6788\n",
      "6789\n",
      "6790\n",
      "6791\n",
      "6792\n",
      "6793\n",
      "6794\n",
      "6795\n",
      "6796\n",
      "6797\n",
      "6798\n",
      "6799\n",
      "6800\n",
      "6801\n",
      "6802\n",
      "6803\n",
      "6804\n",
      "6805\n",
      "6806\n",
      "6807\n",
      "6808\n",
      "6809\n",
      "6810\n",
      "6811\n",
      "6812\n",
      "6813\n",
      "6814\n",
      "6815\n",
      "6816\n",
      "6817\n",
      "6818\n",
      "6819\n",
      "6820\n",
      "6821\n",
      "6822\n",
      "6823\n",
      "6824\n",
      "6825\n",
      "6826\n",
      "6827\n",
      "6828\n",
      "6829\n",
      "6830\n",
      "6831\n",
      "6832\n",
      "6833\n",
      "6834\n",
      "6835\n",
      "6836\n",
      "6837\n",
      "6838\n",
      "6839\n",
      "6840\n",
      "6841\n",
      "6842\n",
      "6843\n",
      "6844\n",
      "6845\n",
      "6846\n",
      "6847\n",
      "6848\n",
      "6849\n",
      "6850\n",
      "6851\n",
      "6852\n",
      "6853\n",
      "6854\n",
      "6855\n",
      "6856\n",
      "6857\n",
      "6858\n",
      "6859\n",
      "6860\n",
      "6861\n",
      "6862\n",
      "6863\n",
      "6864\n",
      "6865\n",
      "6866\n",
      "6867\n",
      "6868\n",
      "6869\n",
      "6870\n",
      "6871\n",
      "6872\n",
      "6873\n",
      "6874\n",
      "6875\n",
      "6876\n",
      "6877\n",
      "6878\n",
      "6879\n",
      "6880\n",
      "6881\n",
      "6882\n",
      "6883\n",
      "6884\n",
      "6885\n",
      "6886\n",
      "6887\n",
      "6888\n",
      "6889\n",
      "6890\n",
      "6891\n",
      "6892\n",
      "6893\n",
      "6894\n",
      "6895\n",
      "6896\n",
      "6897\n",
      "6898\n",
      "6899\n",
      "6900\n",
      "6901\n",
      "6902\n",
      "6903\n",
      "6904\n",
      "6905\n",
      "6906\n",
      "6907\n",
      "6908\n",
      "6909\n",
      "6910\n",
      "6911\n",
      "6912\n",
      "6913\n",
      "6914\n",
      "6915\n",
      "6916\n",
      "6917\n",
      "6918\n",
      "6919\n",
      "6920\n",
      "6921\n",
      "6922\n",
      "6923\n",
      "6924\n",
      "6925\n",
      "6926\n",
      "6927\n",
      "6928\n",
      "6929\n",
      "6930\n",
      "6931\n",
      "6932\n",
      "6933\n",
      "6934\n",
      "6935\n",
      "6936\n",
      "6937\n",
      "6938\n",
      "6939\n",
      "6940\n",
      "6941\n",
      "6942\n",
      "6943\n",
      "6944\n",
      "6945\n",
      "6946\n",
      "6947\n",
      "6948\n",
      "6949\n",
      "6950\n",
      "6951\n",
      "6952\n",
      "6953\n",
      "6954\n",
      "6955\n",
      "6956\n",
      "6957\n",
      "6958\n",
      "6959\n",
      "6960\n",
      "6961\n",
      "6962\n",
      "6963\n",
      "6964\n",
      "6965\n",
      "6966\n",
      "6967\n",
      "6968\n",
      "6969\n",
      "6970\n",
      "6971\n",
      "6972\n",
      "6973\n",
      "6974\n",
      "6975\n",
      "6976\n",
      "6977\n",
      "6978\n",
      "6979\n",
      "6980\n",
      "6981\n",
      "6982\n",
      "6983\n",
      "6984\n",
      "6985\n",
      "6986\n",
      "6987\n",
      "6988\n",
      "6989\n",
      "6990\n",
      "6991\n",
      "6992\n",
      "6993\n",
      "6994\n",
      "6995\n",
      "6996\n",
      "6997\n",
      "6998\n",
      "6999\n",
      "7000\n",
      "7001\n",
      "7002\n",
      "7003\n",
      "7004\n",
      "7005\n",
      "7006\n",
      "7007\n",
      "7008\n",
      "7009\n",
      "7010\n",
      "7011\n",
      "7012\n",
      "7013\n",
      "7014\n",
      "7015\n",
      "7016\n",
      "7017\n",
      "7018\n",
      "7019\n",
      "7020\n",
      "7021\n",
      "7022\n",
      "7023\n",
      "7024\n",
      "7025\n",
      "7026\n",
      "7027\n",
      "7028\n",
      "7029\n",
      "7030\n",
      "7031\n",
      "7032\n",
      "7033\n",
      "7034\n",
      "7035\n",
      "7036\n",
      "7037\n",
      "7038\n",
      "7039\n",
      "7040\n",
      "7041\n",
      "7042\n",
      "7043\n",
      "7044\n",
      "7045\n",
      "7046\n",
      "7047\n",
      "7048\n",
      "7049\n",
      "7050\n",
      "7051\n",
      "7052\n",
      "7053\n",
      "7054\n",
      "7055\n",
      "7056\n",
      "7057\n",
      "7058\n",
      "7059\n",
      "7060\n",
      "7061\n",
      "7062\n",
      "7063\n",
      "7064\n",
      "7065\n",
      "7066\n",
      "7067\n",
      "7068\n",
      "7069\n",
      "7070\n",
      "7071\n",
      "7072\n",
      "7073\n",
      "7074\n",
      "7075\n",
      "7076\n",
      "7077\n",
      "7078\n",
      "7079\n",
      "7080\n",
      "7081\n",
      "7082\n",
      "7083\n",
      "7084\n",
      "7085\n",
      "7086\n",
      "7087\n",
      "7088\n",
      "7089\n",
      "7090\n",
      "7091\n",
      "7092\n",
      "7093\n",
      "7094\n",
      "7095\n",
      "7096\n",
      "7097\n",
      "7098\n",
      "7099\n",
      "7100\n",
      "7101\n",
      "7102\n",
      "7103\n",
      "7104\n",
      "7105\n",
      "7106\n",
      "7107\n",
      "7108\n",
      "7109\n",
      "7110\n",
      "7111\n",
      "7112\n",
      "7113\n",
      "7114\n",
      "7115\n",
      "7116\n",
      "7117\n",
      "7118\n",
      "7119\n",
      "7120\n",
      "7121\n",
      "7122\n",
      "7123\n",
      "7124\n",
      "7125\n",
      "7126\n",
      "7127\n",
      "7128\n",
      "7129\n",
      "7130\n",
      "7131\n",
      "7132\n",
      "7133\n",
      "7134\n",
      "7135\n",
      "7136\n",
      "7137\n",
      "7138\n",
      "7139\n",
      "7140\n",
      "7141\n",
      "7142\n",
      "7143\n",
      "7144\n",
      "7145\n",
      "7146\n",
      "7147\n",
      "7148\n",
      "7149\n",
      "7150\n",
      "7151\n",
      "7152\n",
      "7153\n",
      "7154\n",
      "7155\n",
      "7156\n",
      "7157\n",
      "7158\n",
      "7159\n",
      "7160\n",
      "7161\n",
      "7162\n",
      "7163\n",
      "7164\n",
      "7165\n",
      "7166\n",
      "7167\n",
      "7168\n",
      "7169\n",
      "7170\n",
      "7171\n",
      "7172\n",
      "7173\n",
      "7174\n",
      "7175\n",
      "7176\n",
      "7177\n",
      "7178\n",
      "7179\n",
      "7180\n",
      "7181\n",
      "7182\n",
      "7183\n",
      "7184\n",
      "7185\n",
      "7186\n",
      "7187\n",
      "7188\n",
      "7189\n",
      "7190\n",
      "7191\n",
      "7192\n",
      "7193\n",
      "7194\n",
      "7195\n",
      "7196\n",
      "7197\n",
      "7198\n",
      "7199\n",
      "7200\n",
      "7201\n",
      "7202\n",
      "7203\n",
      "7204\n",
      "7205\n",
      "7206\n",
      "7207\n",
      "7208\n",
      "7209\n",
      "7210\n",
      "7211\n",
      "7212\n",
      "7213\n",
      "7214\n",
      "7215\n",
      "7216\n",
      "7217\n",
      "7218\n",
      "7219\n",
      "7220\n",
      "7221\n",
      "7222\n",
      "7223\n",
      "7224\n",
      "7225\n",
      "7226\n",
      "7227\n",
      "7228\n",
      "7229\n",
      "7230\n",
      "7231\n",
      "7232\n",
      "7233\n",
      "7234\n",
      "7235\n",
      "7236\n",
      "7237\n",
      "7238\n",
      "7239\n",
      "7240\n",
      "7241\n",
      "7242\n",
      "7243\n",
      "7244\n",
      "7245\n",
      "7246\n",
      "7247\n",
      "7248\n",
      "7249\n",
      "7250\n",
      "7251\n",
      "7252\n",
      "7253\n",
      "7254\n",
      "7255\n",
      "7256\n",
      "7257\n",
      "7258\n",
      "7259\n",
      "7260\n",
      "7261\n",
      "7262\n",
      "7263\n",
      "7264\n",
      "7265\n",
      "7266\n",
      "7267\n",
      "7268\n",
      "7269\n",
      "7270\n",
      "7271\n",
      "7272\n",
      "7273\n",
      "7274\n",
      "7275\n",
      "7276\n",
      "7277\n",
      "7278\n",
      "7279\n",
      "7280\n",
      "7281\n",
      "7282\n",
      "7283\n",
      "7284\n",
      "7285\n",
      "7286\n",
      "7287\n",
      "7288\n",
      "7289\n",
      "7290\n",
      "7291\n",
      "7292\n",
      "7293\n",
      "7294\n",
      "7295\n",
      "7296\n",
      "7297\n",
      "7298\n",
      "7299\n",
      "7300\n",
      "7301\n",
      "7302\n",
      "7303\n",
      "7304\n",
      "7305\n",
      "7306\n",
      "7307\n",
      "7308\n",
      "7309\n",
      "7310\n",
      "7311\n",
      "7312\n",
      "7313\n",
      "7314\n",
      "7315\n",
      "7316\n",
      "7317\n",
      "7318\n",
      "7319\n",
      "7320\n",
      "7321\n",
      "7322\n",
      "7323\n",
      "7324\n",
      "7325\n",
      "7326\n",
      "7327\n",
      "7328\n",
      "7329\n",
      "7330\n",
      "7331\n",
      "7332\n",
      "7333\n",
      "7334\n",
      "7335\n",
      "7336\n",
      "7337\n",
      "7338\n",
      "7339\n",
      "7340\n",
      "7341\n",
      "7342\n",
      "7343\n",
      "7344\n",
      "7345\n",
      "7346\n",
      "7347\n",
      "7348\n",
      "7349\n",
      "7350\n",
      "7351\n",
      "7352\n",
      "7353\n",
      "7354\n",
      "7355\n",
      "7356\n",
      "7357\n",
      "7358\n",
      "7359\n",
      "7360\n",
      "7361\n",
      "7362\n",
      "7363\n",
      "7364\n",
      "7365\n",
      "7366\n",
      "7367\n",
      "7368\n",
      "7369\n",
      "7370\n",
      "7371\n",
      "7372\n",
      "7373\n",
      "7374\n",
      "7375\n",
      "7376\n",
      "7377\n",
      "7378\n",
      "7379\n",
      "7380\n",
      "7381\n",
      "7382\n",
      "7383\n",
      "7384\n",
      "7385\n",
      "7386\n",
      "7387\n",
      "7388\n",
      "7389\n",
      "7390\n",
      "7391\n",
      "7392\n",
      "7393\n",
      "7394\n",
      "7395\n",
      "7396\n",
      "7397\n",
      "7398\n",
      "7399\n",
      "7400\n",
      "7401\n",
      "7402\n",
      "7403\n",
      "7404\n",
      "7405\n",
      "7406\n",
      "7407\n",
      "7408\n",
      "7409\n",
      "7410\n",
      "7411\n",
      "7412\n",
      "7413\n",
      "7414\n",
      "7415\n",
      "7416\n",
      "7417\n",
      "7418\n",
      "7419\n",
      "7420\n",
      "7421\n",
      "7422\n",
      "7423\n",
      "7424\n",
      "7425\n",
      "7426\n",
      "7427\n",
      "7428\n",
      "7429\n",
      "7430\n",
      "7431\n",
      "7432\n",
      "7433\n",
      "7434\n",
      "7435\n",
      "7436\n",
      "7437\n",
      "7438\n",
      "7439\n",
      "7440\n",
      "7441\n",
      "7442\n",
      "7443\n",
      "7444\n",
      "7445\n",
      "7446\n",
      "7447\n",
      "7448\n",
      "7449\n",
      "7450\n",
      "7451\n",
      "7452\n",
      "7453\n",
      "7454\n",
      "7455\n",
      "7456\n",
      "7457\n",
      "7458\n",
      "7459\n",
      "7460\n",
      "7461\n",
      "7462\n",
      "7463\n",
      "7464\n",
      "7465\n",
      "7466\n",
      "7467\n",
      "7468\n",
      "7469\n",
      "7470\n",
      "7471\n",
      "7472\n",
      "7473\n",
      "7474\n",
      "7475\n",
      "7476\n",
      "7477\n",
      "7478\n",
      "7479\n",
      "7480\n",
      "7481\n",
      "7482\n",
      "7483\n",
      "7484\n",
      "7485\n",
      "7486\n",
      "7487\n",
      "7488\n",
      "7489\n",
      "7490\n",
      "7491\n",
      "7492\n",
      "7493\n",
      "7494\n",
      "7495\n",
      "7496\n",
      "7497\n",
      "7498\n",
      "7499\n",
      "7500\n",
      "7501\n",
      "7502\n",
      "7503\n",
      "7504\n",
      "7505\n",
      "7506\n",
      "7507\n",
      "7508\n",
      "7509\n",
      "7510\n",
      "7511\n",
      "7512\n",
      "7513\n",
      "7514\n",
      "7515\n",
      "7516\n",
      "7517\n",
      "7518\n",
      "7519\n",
      "7520\n",
      "7521\n",
      "7522\n",
      "7523\n",
      "7524\n",
      "7525\n",
      "7526\n",
      "7527\n",
      "7528\n",
      "7529\n",
      "7530\n",
      "7531\n",
      "7532\n",
      "7533\n",
      "7534\n",
      "7535\n",
      "7536\n",
      "7537\n",
      "7538\n",
      "7539\n",
      "7540\n",
      "7541\n",
      "7542\n",
      "7543\n",
      "7544\n",
      "7545\n",
      "7546\n",
      "7547\n",
      "7548\n",
      "7549\n",
      "7550\n",
      "7551\n",
      "7552\n",
      "7553\n",
      "7554\n",
      "7555\n",
      "7556\n",
      "7557\n",
      "7558\n",
      "7559\n",
      "7560\n",
      "7561\n",
      "7562\n",
      "7563\n",
      "7564\n",
      "7565\n",
      "7566\n",
      "7567\n",
      "7568\n",
      "7569\n",
      "7570\n",
      "7571\n",
      "7572\n",
      "7573\n",
      "7574\n",
      "7575\n",
      "7576\n",
      "7577\n",
      "7578\n",
      "7579\n",
      "7580\n",
      "7581\n",
      "7582\n",
      "7583\n",
      "7584\n",
      "7585\n",
      "7586\n",
      "7587\n",
      "7588\n",
      "7589\n",
      "7590\n",
      "7591\n",
      "7592\n",
      "7593\n",
      "7594\n",
      "7595\n",
      "7596\n",
      "7597\n",
      "7598\n",
      "7599\n",
      "7600\n",
      "7601\n",
      "7602\n",
      "7603\n",
      "7604\n",
      "7605\n",
      "7606\n",
      "7607\n",
      "7608\n",
      "7609\n",
      "7610\n",
      "7611\n",
      "7612\n",
      "7613\n",
      "7614\n",
      "7615\n",
      "7616\n",
      "7617\n",
      "7618\n",
      "7619\n",
      "7620\n",
      "7621\n",
      "7622\n",
      "7623\n",
      "7624\n",
      "7625\n",
      "7626\n",
      "7627\n",
      "7628\n",
      "7629\n",
      "7630\n",
      "7631\n",
      "7632\n",
      "7633\n",
      "7634\n",
      "7635\n",
      "7636\n",
      "7637\n",
      "7638\n",
      "7639\n",
      "7640\n",
      "7641\n",
      "7642\n",
      "7643\n",
      "7644\n",
      "7645\n",
      "7646\n",
      "7647\n",
      "7648\n",
      "7649\n",
      "7650\n",
      "7651\n",
      "7652\n",
      "7653\n",
      "7654\n",
      "7655\n",
      "7656\n",
      "7657\n",
      "7658\n",
      "7659\n",
      "7660\n",
      "7661\n",
      "7662\n",
      "7663\n",
      "7664\n",
      "7665\n",
      "7666\n",
      "7667\n",
      "7668\n",
      "7669\n",
      "7670\n",
      "7671\n",
      "7672\n",
      "7673\n",
      "7674\n",
      "7675\n",
      "7676\n",
      "7677\n",
      "7678\n",
      "7679\n",
      "7680\n",
      "7681\n",
      "7682\n",
      "7683\n",
      "7684\n",
      "7685\n",
      "7686\n",
      "7687\n",
      "7688\n",
      "7689\n",
      "7690\n",
      "7691\n",
      "7692\n",
      "7693\n",
      "7694\n",
      "7695\n",
      "7696\n",
      "7697\n",
      "7698\n",
      "7699\n",
      "7700\n",
      "7701\n",
      "7702\n",
      "7703\n",
      "7704\n",
      "7705\n",
      "7706\n",
      "7707\n",
      "7708\n",
      "7709\n",
      "7710\n",
      "7711\n",
      "7712\n",
      "7713\n",
      "7714\n",
      "7715\n",
      "7716\n",
      "7717\n",
      "7718\n",
      "7719\n",
      "7720\n",
      "7721\n",
      "7722\n",
      "7723\n",
      "7724\n",
      "7725\n",
      "7726\n",
      "7727\n",
      "7728\n",
      "7729\n",
      "7730\n",
      "7731\n",
      "7732\n",
      "7733\n",
      "7734\n",
      "7735\n",
      "7736\n",
      "7737\n",
      "7738\n",
      "7739\n",
      "7740\n",
      "7741\n",
      "7742\n",
      "7743\n",
      "7744\n",
      "7745\n",
      "7746\n",
      "7747\n",
      "7748\n",
      "7749\n",
      "7750\n",
      "7751\n",
      "7752\n",
      "7753\n",
      "7754\n",
      "7755\n",
      "7756\n",
      "7757\n",
      "7758\n",
      "7759\n",
      "7760\n",
      "7761\n",
      "7762\n",
      "7763\n",
      "7764\n",
      "7765\n",
      "7766\n",
      "7767\n",
      "7768\n",
      "7769\n",
      "7770\n",
      "7771\n",
      "7772\n",
      "7773\n",
      "7774\n",
      "7775\n",
      "7776\n",
      "7777\n",
      "7778\n",
      "7779\n",
      "7780\n",
      "7781\n",
      "7782\n",
      "7783\n",
      "7784\n",
      "7785\n",
      "7786\n",
      "7787\n",
      "7788\n",
      "7789\n",
      "7790\n",
      "7791\n",
      "7792\n",
      "7793\n",
      "7794\n",
      "7795\n",
      "7796\n",
      "7797\n",
      "7798\n",
      "7799\n",
      "7800\n",
      "7801\n",
      "7802\n",
      "7803\n",
      "7804\n",
      "7805\n",
      "7806\n",
      "7807\n",
      "7808\n",
      "7809\n",
      "7810\n",
      "7811\n",
      "7812\n",
      "7813\n",
      "7814\n",
      "7815\n",
      "7816\n",
      "7817\n",
      "7818\n",
      "7819\n",
      "7820\n",
      "7821\n",
      "7822\n",
      "7823\n",
      "7824\n",
      "7825\n",
      "7826\n",
      "7827\n",
      "7828\n",
      "7829\n",
      "7830\n",
      "7831\n",
      "7832\n",
      "7833\n",
      "7834\n",
      "7835\n",
      "7836\n",
      "7837\n",
      "7838\n",
      "7839\n",
      "7840\n",
      "7841\n",
      "7842\n",
      "7843\n",
      "7844\n",
      "7845\n",
      "7846\n",
      "7847\n",
      "7848\n",
      "7849\n",
      "7850\n",
      "7851\n",
      "7852\n",
      "7853\n",
      "7854\n",
      "7855\n",
      "7856\n",
      "7857\n",
      "7858\n",
      "7859\n",
      "7860\n",
      "7861\n",
      "7862\n",
      "7863\n",
      "7864\n",
      "7865\n",
      "7866\n",
      "7867\n",
      "7868\n",
      "7869\n",
      "7870\n",
      "7871\n",
      "7872\n",
      "7873\n",
      "7874\n",
      "7875\n",
      "7876\n",
      "7877\n",
      "7878\n",
      "7879\n",
      "7880\n",
      "7881\n",
      "7882\n",
      "7883\n",
      "7884\n",
      "7885\n",
      "7886\n",
      "7887\n",
      "7888\n",
      "7889\n",
      "7890\n",
      "7891\n",
      "7892\n",
      "7893\n",
      "7894\n",
      "7895\n",
      "7896\n",
      "7897\n",
      "7898\n",
      "7899\n",
      "7900\n",
      "7901\n",
      "7902\n",
      "7903\n",
      "7904\n",
      "7905\n",
      "7906\n",
      "7907\n",
      "7908\n",
      "7909\n",
      "7910\n",
      "7911\n",
      "7912\n",
      "7913\n",
      "7914\n",
      "7915\n",
      "7916\n",
      "7917\n",
      "7918\n",
      "7919\n",
      "7920\n",
      "7921\n",
      "7922\n",
      "7923\n",
      "7924\n",
      "7925\n",
      "7926\n",
      "7927\n",
      "7928\n",
      "7929\n",
      "7930\n",
      "7931\n",
      "7932\n",
      "7933\n",
      "7934\n",
      "7935\n",
      "7936\n",
      "7937\n",
      "7938\n",
      "7939\n",
      "7940\n",
      "7941\n",
      "7942\n",
      "7943\n",
      "7944\n",
      "7945\n",
      "7946\n",
      "7947\n",
      "7948\n",
      "7949\n",
      "7950\n",
      "7951\n",
      "7952\n",
      "7953\n",
      "7954\n",
      "7955\n",
      "7956\n",
      "7957\n",
      "7958\n",
      "7959\n",
      "7960\n",
      "7961\n",
      "7962\n",
      "7963\n",
      "7964\n",
      "7965\n",
      "7966\n",
      "7967\n",
      "7968\n",
      "7969\n",
      "7970\n",
      "7971\n",
      "7972\n",
      "7973\n",
      "7974\n",
      "7975\n",
      "7976\n",
      "7977\n",
      "7978\n",
      "7979\n",
      "7980\n",
      "7981\n",
      "7982\n",
      "7983\n",
      "7984\n",
      "7985\n",
      "7986\n",
      "7987\n",
      "7988\n",
      "7989\n",
      "7990\n",
      "7991\n",
      "7992\n",
      "7993\n",
      "7994\n",
      "7995\n",
      "7996\n",
      "7997\n",
      "7998\n",
      "7999\n",
      "8000\n",
      "8001\n",
      "8002\n",
      "8003\n",
      "8004\n",
      "8005\n",
      "8006\n",
      "8007\n",
      "8008\n",
      "8009\n",
      "8010\n",
      "8011\n",
      "8012\n",
      "8013\n",
      "8014\n",
      "8015\n",
      "8016\n",
      "8017\n",
      "8018\n",
      "8019\n",
      "8020\n",
      "8021\n",
      "8022\n",
      "8023\n",
      "8024\n",
      "8025\n",
      "8026\n",
      "8027\n",
      "8028\n",
      "8029\n",
      "8030\n",
      "8031\n",
      "8032\n",
      "8033\n",
      "8034\n",
      "8035\n",
      "8036\n",
      "8037\n",
      "8038\n",
      "8039\n",
      "8040\n",
      "8041\n",
      "8042\n",
      "8043\n",
      "8044\n",
      "8045\n",
      "8046\n",
      "8047\n",
      "8048\n",
      "8049\n",
      "8050\n",
      "8051\n",
      "8052\n",
      "8053\n",
      "8054\n",
      "8055\n",
      "8056\n",
      "8057\n",
      "8058\n",
      "8059\n",
      "8060\n",
      "8061\n",
      "8062\n",
      "8063\n",
      "8064\n",
      "8065\n",
      "8066\n",
      "8067\n",
      "8068\n",
      "8069\n",
      "8070\n",
      "8071\n",
      "8072\n",
      "8073\n",
      "8074\n",
      "8075\n",
      "8076\n",
      "8077\n",
      "8078\n",
      "8079\n",
      "8080\n",
      "8081\n",
      "8082\n",
      "8083\n",
      "8084\n",
      "8085\n",
      "8086\n",
      "8087\n",
      "8088\n",
      "8089\n",
      "8090\n",
      "8091\n",
      "8092\n",
      "8093\n",
      "8094\n",
      "8095\n",
      "8096\n",
      "8097\n",
      "8098\n",
      "8099\n",
      "8100\n",
      "8101\n",
      "8102\n",
      "8103\n",
      "8104\n",
      "8105\n",
      "8106\n",
      "8107\n",
      "8108\n",
      "8109\n",
      "8110\n",
      "8111\n",
      "8112\n",
      "8113\n",
      "8114\n",
      "8115\n",
      "8116\n",
      "8117\n",
      "8118\n",
      "8119\n",
      "8120\n",
      "8121\n",
      "8122\n",
      "8123\n",
      "8124\n",
      "8125\n",
      "8126\n",
      "8127\n",
      "8128\n",
      "8129\n",
      "8130\n",
      "8131\n",
      "8132\n",
      "8133\n",
      "8134\n",
      "8135\n",
      "8136\n",
      "8137\n",
      "8138\n",
      "8139\n",
      "8140\n",
      "8141\n",
      "8142\n",
      "8143\n",
      "8144\n",
      "8145\n",
      "8146\n",
      "8147\n",
      "8148\n",
      "8149\n",
      "8150\n",
      "8151\n",
      "8152\n",
      "8153\n",
      "8154\n",
      "8155\n",
      "8156\n",
      "8157\n",
      "8158\n",
      "8159\n",
      "8160\n",
      "8161\n",
      "8162\n",
      "8163\n",
      "8164\n",
      "8165\n",
      "8166\n",
      "8167\n",
      "8168\n",
      "8169\n",
      "8170\n",
      "8171\n",
      "8172\n",
      "8173\n",
      "8174\n",
      "8175\n",
      "8176\n",
      "8177\n",
      "8178\n",
      "8179\n",
      "8180\n",
      "8181\n",
      "8182\n",
      "8183\n",
      "8184\n",
      "8185\n",
      "8186\n",
      "8187\n",
      "8188\n",
      "8189\n",
      "8190\n",
      "8191\n",
      "8192\n",
      "8193\n",
      "8194\n",
      "8195\n",
      "8196\n",
      "8197\n",
      "8198\n",
      "8199\n",
      "8200\n",
      "8201\n",
      "8202\n",
      "8203\n",
      "8204\n",
      "8205\n",
      "8206\n",
      "8207\n",
      "8208\n",
      "8209\n",
      "8210\n",
      "8211\n",
      "8212\n",
      "8213\n",
      "8214\n",
      "8215\n",
      "8216\n",
      "8217\n",
      "8218\n",
      "8219\n",
      "8220\n",
      "8221\n",
      "8222\n",
      "8223\n",
      "8224\n",
      "8225\n",
      "8226\n",
      "8227\n",
      "8228\n",
      "8229\n",
      "8230\n",
      "8231\n",
      "8232\n",
      "8233\n",
      "8234\n",
      "8235\n",
      "8236\n",
      "8237\n",
      "8238\n",
      "8239\n",
      "8240\n",
      "8241\n",
      "8242\n",
      "8243\n",
      "8244\n",
      "8245\n",
      "8246\n",
      "8247\n",
      "8248\n",
      "8249\n",
      "8250\n",
      "8251\n",
      "8252\n",
      "8253\n",
      "8254\n",
      "8255\n",
      "8256\n",
      "8257\n",
      "8258\n",
      "8259\n",
      "8260\n",
      "8261\n",
      "8262\n",
      "8263\n",
      "8264\n",
      "8265\n",
      "8266\n",
      "8267\n",
      "8268\n",
      "8269\n",
      "8270\n",
      "8271\n",
      "8272\n",
      "8273\n",
      "8274\n",
      "8275\n",
      "8276\n",
      "8277\n",
      "8278\n",
      "8279\n",
      "8280\n",
      "8281\n",
      "8282\n",
      "8283\n",
      "8284\n",
      "8285\n",
      "8286\n",
      "8287\n",
      "8288\n",
      "8289\n",
      "8290\n",
      "8291\n",
      "8292\n",
      "8293\n",
      "8294\n",
      "8295\n",
      "8296\n",
      "8297\n",
      "8298\n",
      "8299\n",
      "8300\n",
      "8301\n",
      "8302\n",
      "8303\n",
      "8304\n",
      "8305\n",
      "8306\n",
      "8307\n",
      "8308\n",
      "8309\n",
      "8310\n",
      "8311\n",
      "8312\n",
      "8313\n",
      "8314\n",
      "8315\n",
      "8316\n",
      "8317\n",
      "8318\n",
      "8319\n",
      "8320\n",
      "8321\n",
      "8322\n",
      "8323\n",
      "8324\n",
      "8325\n",
      "8326\n",
      "8327\n",
      "8328\n",
      "8329\n",
      "8330\n",
      "8331\n",
      "8332\n",
      "8333\n",
      "8334\n",
      "8335\n",
      "8336\n",
      "8337\n",
      "8338\n",
      "8339\n",
      "8340\n",
      "8341\n",
      "8342\n",
      "8343\n",
      "8344\n",
      "8345\n",
      "8346\n",
      "8347\n",
      "8348\n",
      "8349\n",
      "8350\n",
      "8351\n",
      "8352\n",
      "8353\n",
      "8354\n",
      "8355\n",
      "8356\n",
      "8357\n",
      "8358\n",
      "8359\n",
      "8360\n",
      "8361\n",
      "8362\n",
      "8363\n",
      "8364\n",
      "8365\n",
      "8366\n",
      "8367\n",
      "8368\n",
      "8369\n",
      "8370\n",
      "8371\n",
      "8372\n",
      "8373\n",
      "8374\n",
      "8375\n",
      "8376\n",
      "8377\n",
      "8378\n",
      "8379\n",
      "8380\n",
      "8381\n",
      "8382\n",
      "8383\n",
      "8384\n",
      "8385\n",
      "8386\n",
      "8387\n",
      "8388\n",
      "8389\n",
      "8390\n",
      "8391\n",
      "8392\n",
      "8393\n",
      "8394\n",
      "8395\n",
      "8396\n",
      "8397\n",
      "8398\n",
      "8399\n",
      "8400\n",
      "8401\n",
      "8402\n",
      "8403\n",
      "8404\n",
      "8405\n",
      "8406\n",
      "8407\n",
      "8408\n",
      "8409\n",
      "8410\n",
      "8411\n",
      "8412\n",
      "8413\n",
      "8414\n",
      "8415\n",
      "8416\n",
      "8417\n",
      "8418\n",
      "8419\n",
      "8420\n",
      "8421\n",
      "8422\n",
      "8423\n",
      "8424\n",
      "8425\n",
      "8426\n",
      "8427\n",
      "8428\n",
      "8429\n",
      "8430\n",
      "8431\n",
      "8432\n",
      "8433\n",
      "8434\n",
      "8435\n",
      "8436\n",
      "8437\n",
      "8438\n",
      "8439\n",
      "8440\n",
      "8441\n",
      "8442\n",
      "8443\n",
      "8444\n",
      "8445\n",
      "8446\n",
      "8447\n",
      "8448\n",
      "8449\n",
      "8450\n",
      "8451\n",
      "8452\n",
      "8453\n",
      "8454\n",
      "8455\n",
      "8456\n",
      "8457\n",
      "8458\n",
      "8459\n",
      "8460\n",
      "8461\n",
      "8462\n",
      "8463\n",
      "8464\n",
      "8465\n",
      "8466\n",
      "8467\n",
      "8468\n",
      "8469\n",
      "8470\n",
      "8471\n",
      "8472\n",
      "8473\n",
      "8474\n",
      "8475\n",
      "8476\n",
      "8477\n",
      "8478\n",
      "8479\n",
      "8480\n",
      "8481\n",
      "8482\n",
      "8483\n",
      "8484\n",
      "8485\n",
      "8486\n",
      "8487\n",
      "8488\n",
      "8489\n",
      "8490\n",
      "8491\n",
      "8492\n",
      "8493\n",
      "8494\n",
      "8495\n",
      "8496\n",
      "8497\n",
      "8498\n",
      "8499\n",
      "8500\n",
      "8501\n",
      "8502\n",
      "8503\n",
      "8504\n",
      "8505\n",
      "8506\n",
      "8507\n",
      "8508\n",
      "8509\n",
      "8510\n",
      "8511\n",
      "8512\n",
      "8513\n",
      "8514\n",
      "8515\n",
      "8516\n",
      "8517\n",
      "8518\n",
      "8519\n",
      "8520\n",
      "8521\n",
      "8522\n",
      "8523\n",
      "8524\n",
      "8525\n",
      "8526\n",
      "8527\n",
      "8528\n",
      "8529\n",
      "8530\n",
      "8531\n",
      "8532\n",
      "8533\n",
      "8534\n",
      "8535\n",
      "8536\n",
      "8537\n",
      "8538\n",
      "8539\n",
      "8540\n",
      "8541\n",
      "8542\n",
      "8543\n",
      "8544\n",
      "8545\n",
      "8546\n",
      "8547\n",
      "8548\n",
      "8549\n",
      "8550\n",
      "8551\n",
      "8552\n",
      "8553\n",
      "8554\n",
      "8555\n",
      "8556\n",
      "8557\n",
      "8558\n",
      "8559\n",
      "8560\n",
      "8561\n",
      "8562\n",
      "8563\n",
      "8564\n",
      "8565\n",
      "8566\n",
      "8567\n",
      "8568\n",
      "8569\n",
      "8570\n",
      "8571\n",
      "8572\n",
      "8573\n",
      "8574\n",
      "8575\n",
      "8576\n",
      "8577\n",
      "8578\n",
      "8579\n",
      "8580\n",
      "8581\n",
      "8582\n",
      "8583\n",
      "8584\n",
      "8585\n",
      "8586\n",
      "8587\n",
      "8588\n",
      "8589\n",
      "8590\n",
      "8591\n",
      "8592\n",
      "8593\n",
      "8594\n",
      "8595\n",
      "8596\n",
      "8597\n",
      "8598\n",
      "8599\n",
      "8600\n",
      "8601\n",
      "8602\n",
      "8603\n",
      "8604\n",
      "8605\n",
      "8606\n",
      "8607\n",
      "8608\n",
      "8609\n",
      "8610\n",
      "8611\n",
      "8612\n",
      "8613\n",
      "8614\n",
      "8615\n",
      "8616\n",
      "8617\n",
      "8618\n",
      "8619\n",
      "8620\n",
      "8621\n",
      "8622\n",
      "8623\n",
      "8624\n",
      "8625\n",
      "8626\n",
      "8627\n",
      "8628\n",
      "8629\n",
      "8630\n",
      "8631\n",
      "8632\n",
      "8633\n",
      "8634\n",
      "8635\n",
      "8636\n",
      "8637\n",
      "8638\n",
      "8639\n",
      "8640\n",
      "8641\n",
      "8642\n",
      "8643\n",
      "8644\n",
      "8645\n",
      "8646\n",
      "8647\n",
      "8648\n",
      "8649\n",
      "8650\n",
      "8651\n",
      "8652\n",
      "8653\n",
      "8654\n",
      "8655\n",
      "8656\n",
      "8657\n",
      "8658\n",
      "8659\n",
      "8660\n",
      "8661\n",
      "8662\n",
      "8663\n",
      "8664\n",
      "8665\n",
      "8666\n",
      "8667\n",
      "8668\n",
      "8669\n",
      "8670\n",
      "8671\n",
      "8672\n",
      "8673\n",
      "8674\n",
      "8675\n",
      "8676\n",
      "8677\n",
      "8678\n",
      "8679\n",
      "8680\n",
      "8681\n",
      "8682\n",
      "8683\n",
      "8684\n",
      "8685\n",
      "8686\n",
      "8687\n",
      "8688\n",
      "8689\n",
      "8690\n",
      "8691\n",
      "8692\n",
      "8693\n",
      "8694\n",
      "8695\n",
      "8696\n",
      "8697\n",
      "8698\n",
      "8699\n",
      "8700\n",
      "8701\n",
      "8702\n",
      "8703\n",
      "8704\n",
      "8705\n",
      "8706\n",
      "8707\n",
      "8708\n",
      "8709\n",
      "8710\n",
      "8711\n",
      "8712\n",
      "8713\n",
      "8714\n",
      "8715\n",
      "8716\n",
      "8717\n",
      "8718\n",
      "8719\n",
      "8720\n",
      "8721\n",
      "8722\n",
      "8723\n",
      "8724\n",
      "8725\n",
      "8726\n",
      "8727\n",
      "8728\n",
      "8729\n",
      "8730\n",
      "8731\n",
      "8732\n",
      "8733\n",
      "8734\n",
      "8735\n",
      "8736\n",
      "8737\n",
      "8738\n",
      "8739\n",
      "8740\n",
      "8741\n",
      "8742\n",
      "8743\n",
      "8744\n",
      "8745\n",
      "8746\n",
      "8747\n",
      "8748\n",
      "8749\n",
      "8750\n",
      "8751\n",
      "8752\n",
      "8753\n",
      "8754\n",
      "8755\n",
      "8756\n",
      "8757\n",
      "8758\n",
      "8759\n",
      "8760\n",
      "8761\n",
      "8762\n",
      "8763\n",
      "8764\n",
      "8765\n",
      "8766\n",
      "8767\n",
      "8768\n",
      "8769\n",
      "8770\n",
      "8771\n",
      "8772\n",
      "8773\n",
      "8774\n",
      "8775\n",
      "8776\n",
      "8777\n",
      "8778\n",
      "8779\n"
     ]
    }
   ],
   "source": [
    "if not args.distributed or (args.distributed and args.gpu == 0):\n",
    "    print(\"\\n\\nStart training at: \", datetime.now())\n",
    "\n",
    "if args.save_dir is None:\n",
    "    args.save_dir = os.getcwd()\n",
    "\n",
    "if args.distributed:\n",
    "    dist.init_process_group(\n",
    "        args.dist_backend,\n",
    "        init_method = args.dist_url,\n",
    "        world_size = world_size,\n",
    "        rank = args.gpu\n",
    "    )\n",
    "\n",
    "if args.restore:\n",
    "    dataset_state_dict_filename = args.dataset_state_dict_filename\n",
    "\n",
    "    if dataset_state_dict_filename is None:\n",
    "        warnings.warn(\"Restore with `args.dataset_state_dict_filename` set to None.\")\n",
    "    elif not Path(dataset_state_dict_filename).exists():\n",
    "        warnings.warn(\n",
    "            f\"`{dataset_state_dict_filename} not found; set \"\n",
    "            f\"args.dataset_state_dict_filename` to None\"\n",
    "        )\n",
    "        dataset_state_dict_filename = None\n",
    "else:\n",
    "    dataset_state_dict_filename = None\n",
    "\n",
    "# Load molecules and labels from file\n",
    "mols, labels = load_mols_labels(args.dataset_file)\n",
    "\n",
    "if args.load_dataset:\n",
    "    data_dict = args.dataset_pickle\n",
    "    dataset = pickle_load(data_dict)\n",
    "\n",
    "else:\n",
    "    if args.dielectric_constants is not None:\n",
    "        dc_file = Path(args.dielectric_constants)        \n",
    "        dataset = SolvationDataset(\n",
    "            solute_grapher = grapher(mol_volume = args.molecular_volume,\n",
    "                                    mol_refract = args.molecular_refractivity,\n",
    "                                    partial_charges=args.partial_charges),\n",
    "            solvent_grapher = grapher(dielectric_constant=True,\n",
    "                                    mol_volume = args.molecular_volume,\n",
    "                                    mol_refract = args.molecular_refractivity,\n",
    "                                    partial_charges=args.partial_charges),\n",
    "            molecules = mols,\n",
    "            labels = labels,\n",
    "            solute_extra_features = None,\n",
    "            solvent_extra_features=dc_file,\n",
    "            feature_transformer = False,\n",
    "            label_transformer= False,\n",
    "            state_dict_filename=dataset_state_dict_filename)\n",
    "\n",
    "    else:\n",
    "        dataset = SolvationDataset(\n",
    "            solute_grapher = grapher(mol_volume=args.molecular_volume, mol_refract = args.molecular_refractivity, partial_charges=args.partial_charges),\n",
    "            solvent_grapher = grapher(mol_volume=args.molecular_volume, mol_refract = args.molecular_refractivity, partial_charges=args.partial_charges,lable=True),\n",
    "            molecules = mols,\n",
    "            labels = labels,\n",
    "            solute_extra_features = None,\n",
    "            solvent_extra_features = None,\n",
    "            feature_transformer = False,\n",
    "            label_transformer= False,\n",
    "            state_dict_filename=dataset_state_dict_filename)\n",
    "pickle_dump([dataset.solute_grapher, dataset.solvent_grapher], os.path.join(args.save_dir,\"graphers.pkl\"))\n",
    "# Save the solute and solvent graphers for loading datasets later\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "pickle_dump(dataset,os.path.join(args.save_dir,\"dataset.pkl\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "best = np.finfo(np.float32).max\n",
    "os.makedirs(args.save_dir, exist_ok=True)\n",
    "\n",
    "\n",
    "trainset, valset, testset = train_validation_test_split(\n",
    "    dataset, validation=0.1, test=0.1, random_seed=args.random_seed)\n",
    "\n",
    "# Scale training dataset features\n",
    "if args.feature_scaling:\n",
    "    solute_features_scaler,solvent_features_scaler= trainset.normalize_features()\n",
    "    #solute_features_scaler, solvent_features_scaler = trainset.normalize_features()\n",
    "    valset.normalize_features(solute_features_scaler, solvent_features_scaler)\n",
    "    testset.normalize_features(solute_features_scaler, solvent_features_scaler)\n",
    "    #testset.normalize_features(solute_features_scaler)\n",
    "else:\n",
    "    solute_features_scaler, solvent_features_scaler = None, None\n",
    "\n",
    "label_scaler = trainset.normalize_labels()\n",
    "if not args.distributed or (args.distributed and args.gpu == 0):\n",
    "    torch.save(dataset.state_dict(), os.path.join(args.save_dir, args.dataset_state_dict_filename))\n",
    "    print(\n",
    "        \"Trainset size: {}, valset size: {}: testset size: {}.\".format(\n",
    "            len(trainset), len(valset), len(testset)\n",
    "        )\n",
    "    )\n",
    "if args.distributed:\n",
    "    train_sampler = torch.utils.data.distributed.DistributedSampler(trainset)\n",
    "else:\n",
    "    train_sampler = None\n",
    "\n",
    "train_loader = DataLoaderSolvation(\n",
    "    trainset,\n",
    "    batch_size = args.batch_size,\n",
    "    shuffle = (train_sampler is None),\n",
    "    sampler = train_sampler\n",
    ")\n",
    "# larger val and test set batch_size is faster but needs more memory\n",
    "# adjust the batch size of val and test set to fit memory\n",
    "bs = max(len(valset) // 10, 1)\n",
    "val_loader = DataLoaderSolvation(valset, batch_size=bs, shuffle=False)\n",
    "bs = max(len(testset) // 10, 1)\n",
    "test_loader = DataLoaderSolvation(testset, batch_size=bs, shuffle=False)\n",
    "### model\n",
    "feature_names = [\"atom\", \"bond\", \"global\"]\n",
    "solute_feature_names = [\"atom\", \"bond\",\"atom2\", \"bond2\", \"global\"]\n",
    "set2set_ntypes_direct = [\"global\"]\n",
    "solute_feature_size = dataset.feature_sizes[0]\n",
    "# solute_feature_size ={'bond': 11,'atom': 28,'atom2': 28, 'bond2': 11, 'global': 3}\n",
    "solute_feature_size = {'bond': 11, 'atom': 30, 'atom2': 30, 'bond2': 11, 'global': 3}\n",
    "\n",
    "solvent_feature_size = dataset.feature_sizes[1]\n",
    "args.solute_feature_size = solute_feature_size\n",
    "args.solvent_feature_size = solvent_feature_size\n",
    "args.set2set_ntypes_direct = set2set_ntypes_direct\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Transfer Learning"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "ename": "AttributeError",
     "evalue": "'Namespace' object has no attribute 'solute_feature_size'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAttributeError\u001b[0m                            Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_3969762/583019804.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m model = GatedGCNSolvationNetwork(\n\u001b[0;32m----> 2\u001b[0;31m         \u001b[0msolute_in_feats\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msolute_feature_size\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m         \u001b[0msolvent_in_feats\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msolvent_feature_size\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m         \u001b[0membedding_size\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0membedding_size\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m         \u001b[0mgated_num_layers\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgated_num_layers\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mAttributeError\u001b[0m: 'Namespace' object has no attribute 'solute_feature_size'"
     ]
    }
   ],
   "source": [
    "model = GatedGCNSolvationNetwork(\n",
    "        solute_in_feats=args.solute_feature_size,\n",
    "        solvent_in_feats=args.solvent_feature_size,\n",
    "        embedding_size=args.embedding_size,\n",
    "        gated_num_layers=args.gated_num_layers,\n",
    "        gated_hidden_size=args.gated_hidden_size,\n",
    "        gated_num_fc_layers=args.gated_num_fc_layers,\n",
    "        gated_graph_norm=args.gated_graph_norm,\n",
    "        gated_batch_norm=args.gated_batch_norm,\n",
    "        gated_activation=args.gated_activation,\n",
    "        gated_residual=args.gated_residual,\n",
    "        gated_dropout=args.gated_dropout,\n",
    "        num_lstm_iters=args.num_lstm_iters,\n",
    "        num_lstm_layers=args.num_lstm_layers,\n",
    "        set2set_ntypes_direct=args.set2set_ntypes_direct,\n",
    "        fc_num_layers=args.fc_num_layers,\n",
    "        fc_hidden_size=args.fc_hidden_size,\n",
    "        fc_batch_norm=args.fc_batch_norm,\n",
    "        fc_activation=args.fc_activation,\n",
    "        fc_dropout=args.fc_dropout,\n",
    "        outdim=1,\n",
    "        conv=\"GatedGCNConv\",\n",
    "    )\n",
    "optimizer = torch.optim.Adam(\n",
    "    model.parameters(), lr=args.lr, weight_decay=args.weight_decay\n",
    ")\n",
    "loss_func = MSELoss(reduction=\"mean\")\n",
    "metric = L1Loss(reduction=\"sum\")\n",
    "\n",
    "scheduler = ReduceLROnPlateau(\n",
    "    optimizer, mode=\"min\", factor=0.4, patience=50, verbose=True\n",
    ")\n",
    "stopper = EarlyStopping(patience=150)\n",
    "\n",
    "state_dict_objs = {\"model\": model, \"optimizer\": optimizer, \"scheduler\": scheduler}\n",
    "loc = \"cuda:{}\".format(args.gpu)\n",
    "checkpoint = load_checkpoints(\n",
    "    state_dict_objs, map_location=loc, save_dir=\"/home/1739678401/2024.9dataclean/MMGNN_0901/result/exp\", filename=\"best_checkpoint.pkl\"\n",
    ")\n",
    "for name, param in model.named_parameters():\n",
    "    if not any(layer_name in name for layer_name in ['fc_layers']):\n",
    "        param.requires_grad = False\n",
    "optimizer = torch.optim.Adam(\n",
    "    filter(lambda p: p.requires_grad, model.parameters()), lr=1e-4)       "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model.to(args.gpu)\n",
    "print(args.gpu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "if not args.distributed or (args.distributed and args.gpu == 0):\n",
    "    print(\"\\n\\n# Epoch     Loss         TrainAcc        ValAcc     Time (s)\")\n",
    "    sys.stdout.flush()\n",
    "for epoch in range(args.start_epoch, args.epochs):\n",
    "    ti = time.time()\n",
    "    # In distributed mode, calling the set_epoch method is needed to make shuffling\n",
    "    # work; each process will use the same random seed otherwise.\n",
    "    if args.distributed:\n",
    "        train_sampler.set_epoch(epoch)\n",
    "    # train\n",
    "    loss, train_acc = train(\n",
    "        optimizer, model, feature_names, solute_feature_names,train_loader, loss_func, metric, args.gpu)\n",
    "    # bad, we get nan\n",
    "    if np.isnan(loss):\n",
    "        print(\"\\n\\nBad, we get nan for loss. Exiting\")\n",
    "        sys.stdout.flush()\n",
    "        sys.exit(1)\n",
    "    # evaluate\n",
    "    val_acc = evaluate(model, feature_names, solute_feature_names,val_loader, metric, label_scaler, args.gpu)\n",
    "    if stopper.step(val_acc):\n",
    "        pickle_dump(best, os.path.join(args.save_dir, args.output_file))  # save results for hyperparam tune\n",
    "        break\n",
    "    scheduler.step(val_acc)\n",
    "    is_best = val_acc < best\n",
    "    if is_best:\n",
    "        best = val_acc\n",
    "    # save checkpoint\n",
    "    if not args.distributed or (args.distributed and args.gpu == 0):\n",
    "        misc_objs = {\"best\": best, \"epoch\": epoch}\n",
    "        scaler_objs = {'label_scaler': {\n",
    "                        'means': label_scaler.mean,\n",
    "                        'stds': label_scaler.std\n",
    "                        } if label_scaler is not None else None,\n",
    "                        'solute_features_scaler': {\n",
    "                        'means': solute_features_scaler.mean,\n",
    "                        'stds': solute_features_scaler.std\n",
    "                        } if solute_features_scaler is not None else None,\n",
    "                        'solvent_features_scaler': {\n",
    "                        'means': solvent_features_scaler.mean,\n",
    "                        'stds': solvent_features_scaler.std\n",
    "                        } if solvent_features_scaler is not None else None}\n",
    "        save_checkpoints(\n",
    "            state_dict_objs,\n",
    "            misc_objs,\n",
    "            scaler_objs,\n",
    "            is_best,\n",
    "            msg=f\"epoch: {epoch}, score {val_acc}\",\n",
    "            save_dir=args.save_dir)\n",
    "        tt = time.time() - ti\n",
    "        print(\n",
    "            \"{:5d}   {:12.6e}   {:12.6e}   {:12.6e}   {:.2f}\".format(\n",
    "                epoch, loss, train_acc, val_acc, tt\n",
    "            )\n",
    "        )\n",
    "        ls.append( val_acc)\n",
    "        if epoch % 10 == 0:\n",
    "            sys.stdout.flush()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "#del dataset\n",
    "dataset = pickle_load(\"/home/1739678401/2024.9dataclean/MMGNN_0901/result/transfer/dataset.pkl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[4313, 4316, 4327, 4461, 4372, 4366, 4373, 4457, 4364, 4338, 4439, 4315, 4321, 4318, 4438, 4440, 4319, 4385, 4410, 4322, 4375, 4437, 4398, 4400, 4325, 4442, 4307, 4363, 4389, 4344, 4369, 4348, 4444, 4387, 4378, 4396, 4399, 4458, 4336, 4416, 4350, 4380, 4446, 4395, 4383, 4342, 4393, 4391, 4402, 4360, 4412, 4419, 4421, 4382, 4404, 4310, 4371, 4414, 4306, 4397, 4311, 4452, 4436, 4428, 4435, 4447, 4454, 4434, 4423, 4433, 4448, 4456, 4431, 4425, 4312, 4405, 4430, 4450, 4451, 4407, 4429, 4424, 4453, 4406, 4455, 4459, 4652, 4654, 8333, 8330, 3273, 8344, 6419, 2321, 8340, 8342, 8335, 8331, 4512, 4992, 2319, 7300, 8339, 8329, 6780, 8334, 4314, 8336, 8324, 2318, 6248, 1621, 8343, 8337, 4873, 8316, 8318, 8325, 7296, 8321, 2317, 2322, 5707, 3286, 2342, 8345, 7279, 8317, 8322, 1619, 7265, 7267, 7297, 7269, 8332, 4653, 2316, 8338, 7289, 2558, 3289, 3291, 3293, 7275, 2341, 2343, 6249, 1623, 7278, 7282, 8319, 8323, 7266, 7290, 8320, 2315, 2320, 7294, 3412, 3284, 2561, 2563, 2565, 3290, 3292, 3278, 2340, 2344, 4317, 7293, 2918, 7261, 7280, 8326, 7264, 7271, 7291, 7276, 7272, 2314, 8268, 7286, 2557, 3283, 2562, 2564, 3287, 6773, 6775, 6778, 6727, 1817, 2339, 4946, 7284, 4947, 2345, 4514, 7262, 7270, 2910, 7281, 6776, 1620, 7298, 7268, 7285, 7301, 2313, 7287, 3427, 2556, 3282, 3285, 2559, 3288, 2312, 1624, 1626, 1653, 6774, 6779, 6723, 6420, 2338, 6726, 6719, 8043, 8048, 8262, 8341, 8172, 8184, 1796, 7295, 7263, 7273, 2917, 8169, 6725, 4114, 7274, 7299, 6320, 2555, 3281, 2560, 6485, 6724, 8179, 2567, 4522, 2337, 6722, 6720, 1355, 8269, 8175, 8180, 7288, 1270, 2916, 8167, 6721, 4112, 4111, 7277, 2919, 4871, 6061, 8559, 3411, 6777, 3416, 2554, 3280, 7820, 7283, 6728, 8183, 2566, 6920, 8046, 4781, 4980, 3152, 4647, 3316, 8173, 2921, 8181, 1685, 1690, 1800, 2915, 7292, 2912, 8177, 8168, 4109, 4108, 8263, 8560, 8547, 8549, 2553, 1797, 8554, 8176, 1733, 7087, 8047, 4324, 6570, 3302, 6633, 8166, 8174, 8185, 1269, 2909, 2914, 2901, 8170, 8266, 4106, 4105, 8265, 8548, 8555, 8264, 3419, 2552, 3315, 6634, 8171, 382, 8557, 6632, 2922, 2924, 6513, 3307, 5153, 1268, 2908, 2911, 2897, 8545, 8267, 4103, 4102, 8145, 8551, 8556, 6631, 6319, 3305, 3314, 1689, 1921, 8552, 587, 6635, 8178, 6630, 588, 1612, 1613, 6629, 4329, 4330, 6469, 4113, 1267, 2907, 2899, 1724, 4100, 4099, 4328, 6155, 2913, 8561, 8550, 6578, 6027, 3423, 3420, 6377, 3301, 6122, 4643, 4205, 3300, 8182, 860, 3306, 1990, 1616, 2920, 2930, 2925, 2927, 373, 3313, 8558, 4990, 5152, 5989, 4110, 1266, 2906, 1264, 1265, 2894, 2900, 2895, 2892, 7088, 8546, 4097, 4096, 2903, 4532, 4534, 7959, 4641, 6018, 3430, 4617, 3311, 8050, 4780, 6741, 375, 6492, 4633, 6731, 6736, 2365, 6207, 4524, 3433, 1567, 1798, 1799, 1922, 6363, 4639, 5151, 5234, 4107, 2905, 1263, 8053, 2896, 2889, 6735, 3404, 5917, 1859, 5657, 8553, 4094, 4093, 374, 8636, 2902, 2898, 7960, 7947, 7949, 8276, 1622, 3413, 3417, 4513, 4620, 3317, 6318, 8102, 7954, 4331, 4333, 4334, 4346, 4347, 6465, 5469, 6737, 6059, 4509, 6206, 4645, 1974, 6729, 6740, 3409, 4207, 6771, 3371, 3299, 2118, 5958, 4872, 6479, 3312, 4208, 4649, 372, 6376, 950, 1611, 1991, 1996, 1614, 5630, 2002, 2931, 2937, 2923, 2933, 4367, 4374, 8049, 6169, 5150, 2904, 4104, 1262, 2891, 2887, 8075, 8635, 5339, 2010, 5900, 6739, 4876, 1635, 1726, 5644, 4091, 4090, 3557, 8085, 6618, 1889, 5094, 7948, 7955, 1473, 2737, 2739, 2740, 3429, 3402, 6153, 578, 1731, 5882, 867, 2490, 7141, 6738, 6758, 3156, 1360, 3408, 6210, 6636, 8642, 862, 6429, 6911, 6730, 6734, 5798, 4747, 4550, 4560, 4579, 4603, 6913, 855, 1359, 3298, 8270, 8079, 4572, 5230, 2535, 1688, 4971, 4972, 6131, 7957, 4973, 369, 1661, 1676, 4538, 6055, 1989, 1615, 2000, 1271, 2935, 5267, 8360, 108, 2100, 3103, 5008, 5233, 5629, 4101, 378, 1261, 8052, 8051, 353, 8069, 6733, 3407, 5916, 1725, 6222, 6234, 7946, 4088, 4086, 3537, 8095, 379, 2893, 5575, 7951, 7956, 1801, 1856, 872, 853, 5877, 7192, 5222, 6362, 6367, 2732, 3403, 3414, 3431, 3418, 3428, 2744, 8575, 7952, 5064, 5468, 6742, 6768, 3155, 1361, 365, 4206, 3092, 6912, 1978, 6732, 3410, 3304, 8092, 4556, 4594, 3297, 8277, 8042, 8099, 346, 2119, 2120, 4525, 6121, 1566, 2534, 1572, 6379, 1354, 1687, 1625, 1627, 1654, 368, 4736, 4727, 6141, 1988, 1992, 1993, 2001, 2929, 2926, 6163, 5259, 5282, 4352, 4354, 4355, 4357, 6579, 6585, 8562, 4510, 8076, 5232, 4098, 330, 352, 8074, 8078, 2928, 5338, 7363, 2015, 2018, 2019, 5899, 5884, 2025, 2538, 1636, 5915, 1642, 5925, 1858, 6188, 4084, 6772, 5263, 5157, 6187, 3558, 5562, 305, 309, 8061, 8063, 345, 2234, 1890, 1894, 4875, 1727, 859, 6456, 6506, 6564, 5574, 7961, 7950, 8247, 371, 6040, 6378, 8084, 8086, 1867, 1874, 1511, 2070, 2731, 2741, 3401, 2394, 8643, 6324, 6143, 2131, 2137, 7140, 7246, 5467, 6769, 3154, 3425, 4761, 291, 6236, 4365, 3264, 852, 6142, 6050, 4238, 8072, 329, 334, 8077, 7135, 1973, 4884, 2210, 4885, 4886, 5928, 6746, 6762, 1983, 4746, 6209, 6219, 359, 4575, 8059, 4339, 3296, 320, 321, 322, 319, 338, 7198, 2117, 5229, 5007, 2082, 2087, 2089, 2190, 2195, 2197, 2203, 1565, 2533, 3359, 2536, 5734, 1686, 5873, 6218, 6227, 8563, 1662, 1677, 5881, 2037, 4613, 1055, 1987, 1994, 1997, 1998, 4593, 2939, 1272, 5017, 5266, 2027, 8621, 3400, 6062, 3575, 2101, 2106, 2108, 3104, 6430, 7958, 5929, 5231, 4095, 2890, 328, 8054, 6021, 351, 8073, 8098, 8638, 5337, 2009, 5898, 2024, 1901, 5908, 6761, 3405, 3394, 3395, 1634, 5914, 1641, 1857, 8090, 1648, 3539, 304, 308, 344, 4619, 8082, 8088, 5009, 5237, 6914, 1888, 4874, 8271, 1900, 6365, 5863, 8055, 1698, 1741, 8109, 4557, 4561, 4578, 4582, 4586, 4597, 4599, 4607, 4612, 8081, 8083, 5292, 2223, 5003, 5221, 2730, 2736, 2738, 3424, 3421, 2742, 5758, 982, 1729, 1732, 6333, 6643, 8089, 6035, 4553, 4562, 4605, 4611, 366, 5218, 7367, 5255, 2489, 7148, 7242, 5466, 6763, 1362, 857, 3153, 4760, 5188, 1810, 6183, 6221, 6233, 1309, 3089, 6165, 3090, 3545, 5251, 5276, 7123, 1972, 1979, 5927, 2205, 6744, 6767, 6178, 358, 8058, 1923, 6079, 4209, 8240, 318, 7333, 2116, 2122, 5228, 2081, 2189, 7169, 4854, 4855, 4856, 6119]\n",
      "1000\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "df = pd.read_csv(\"/home/1739678401/2024.9dataclean/MMGNN_0901/top_1000_indices.csv\")\n",
    "index_list = df['Index'].tolist()\n",
    "print(index_list)\n",
    "print(len(index_list))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "from gnn.data.dataset import Subset\n",
    "def gettest(dataset,indices):\n",
    "    \"\"\"\n",
    "    Split a dataset into training, validation, and test set.\n",
    "    The training set will be automatically determined based on `validation` and `test`,\n",
    "    i.e. train = 1 - validation - test.\n",
    "    Args:\n",
    "        dataset: the dataset\n",
    "        validation (float, optional): The amount of data (fraction) to be assigned to\n",
    "            validation set. Defaults to 0.1.\n",
    "        test (float, optional): The amount of data (fraction) to be assigned to test\n",
    "            set. Defaults to 0.1.\n",
    "        random_seed (int, optional): random seed that determines the permutation of the\n",
    "            dataset. Defaults to 0.\n",
    "    Returns:\n",
    "        [train set, validation set, test_set]\n",
    "    \"\"\"\n",
    "    test_idx = indices\n",
    "    return Subset(dataset, test_idx)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "trainset, valset, testset = train_validation_test_split(\n",
    "    dataset, validation=0.1, test=0.1, random_seed=args.random_seed)\n",
    "testset=gettest(dataset,index_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trainset size: 7024, valset size: 878: testset size: 1000.\n"
     ]
    }
   ],
   "source": [
    "\n",
    "if args.feature_scaling:\n",
    "    solute_features_scaler,solvent_features_scaler= trainset.normalize_features()\n",
    "    #solute_features_scaler, solvent_features_scaler = trainset.normalize_features()\n",
    "    valset.normalize_features(solute_features_scaler, solvent_features_scaler)\n",
    "    testset.normalize_features(solute_features_scaler, solvent_features_scaler)\n",
    "    #testset.normalize_features(solute_features_scaler)\n",
    "else:\n",
    "    solute_features_scaler, solvent_features_scaler = None, None\n",
    "\n",
    "label_scaler = trainset.normalize_labels()\n",
    "if not args.distributed or (args.distributed and args.gpu == 0):\n",
    "    torch.save(dataset.state_dict(), os.path.join(args.save_dir, args.dataset_state_dict_filename))\n",
    "    print(\n",
    "        \"Trainset size: {}, valset size: {}: testset size: {}.\".format(\n",
    "            len(trainset), len(valset), len(testset)\n",
    "        )\n",
    "    )\n",
    "if args.distributed:\n",
    "    train_sampler = torch.utils.data.distributed.DistributedSampler(trainset)\n",
    "else:\n",
    "    train_sampler = None\n",
    "\n",
    "train_loader = DataLoaderSolvation(\n",
    "    trainset,\n",
    "    batch_size = args.batch_size,\n",
    "    shuffle = (train_sampler is None),\n",
    "    sampler = train_sampler\n",
    ")\n",
    "# larger val and test set batch_size is faster but needs more memory\n",
    "# adjust the batch size of val and test set to fit memory\n",
    "bs = max(len(testset) // 10, 1)\n",
    "test_loader = DataLoaderSolvation(testset, batch_size=bs, shuffle=False)\n",
    "### model\n",
    "feature_names = [\"atom\", \"bond\", \"global\"]\n",
    "solute_feature_names = [\"atom\", \"bond\",\"atom2\", \"bond2\", \"global\"]\n",
    "set2set_ntypes_direct = [\"global\"]\n",
    "solute_feature_size = dataset.feature_sizes[0]\n",
    "# solute_feature_size ={'bond': 11,'atom': 28,'atom2': 28, 'bond2': 11, 'global': 3}\n",
    "solute_feature_size = {'bond': 11, 'atom': 30, 'atom2': 30, 'bond2': 11, 'global': 3}\n",
    "\n",
    "solvent_feature_size = dataset.feature_sizes[1]\n",
    "args.solute_feature_size = solute_feature_size\n",
    "args.solvent_feature_size = solvent_feature_size\n",
    "args.set2set_ntypes_direct = set2set_ntypes_direct\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "GatedGCNSolvationNetwork(\n",
       "  (solute_embedding): UnifySize(\n",
       "    (linears): ModuleDict(\n",
       "      (bond): Linear(in_features=11, out_features=48, bias=False)\n",
       "      (atom): Linear(in_features=30, out_features=48, bias=False)\n",
       "      (atom2): Linear(in_features=30, out_features=48, bias=False)\n",
       "      (bond2): Linear(in_features=11, out_features=48, bias=False)\n",
       "      (global): Linear(in_features=3, out_features=48, bias=False)\n",
       "    )\n",
       "  )\n",
       "  (gated_layers): ModuleList(\n",
       "    (0): GatedGCNConv(\n",
       "      (activation): LeakyReLU(negative_slope=0.01)\n",
       "      (A): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=48, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (B): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=48, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (C): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=48, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (D): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=48, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (E): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=48, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (F): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=48, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (G): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (H): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (I): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=48, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (w1): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (dropout): Identity()\n",
       "    )\n",
       "    (1): GatedGCNConv(\n",
       "      (activation): LeakyReLU(negative_slope=0.01)\n",
       "      (A): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (B): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (C): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (D): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (E): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (F): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (G): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (H): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (I): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (w1): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (dropout): Identity()\n",
       "    )\n",
       "    (2): GatedGCNConv(\n",
       "      (activation): LeakyReLU(negative_slope=0.01)\n",
       "      (A): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (B): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (C): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (D): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (E): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (F): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (G): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (H): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (I): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (w1): LinearN(\n",
       "        (fc_layers): ModuleList(\n",
       "          (0): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (1): LeakyReLU(negative_slope=0.01)\n",
       "          (2): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (3): LeakyReLU(negative_slope=0.01)\n",
       "          (4): Linear(in_features=1600, out_features=1600, bias=True)\n",
       "          (5): Identity()\n",
       "        )\n",
       "      )\n",
       "      (dropout): Identity()\n",
       "    )\n",
       "  )\n",
       "  (readout_layer): Set2SetThenCat(\n",
       "    (layers): ModuleDict(\n",
       "      (atom): Set2Set(\n",
       "        n_iters=6\n",
       "        (lstm): LSTM(3200, 1600, num_layers=3)\n",
       "      )\n",
       "      (atom2): Set2Set(\n",
       "        n_iters=6\n",
       "        (lstm): LSTM(3200, 1600, num_layers=3)\n",
       "      )\n",
       "    )\n",
       "  )\n",
       "  (fc_layers): ModuleList(\n",
       "    (0): Linear(in_features=6400, out_features=3200, bias=True)\n",
       "    (1): LeakyReLU(negative_slope=0.01)\n",
       "    (2): Dropout(p=0.5, inplace=False)\n",
       "    (3): Linear(in_features=3200, out_features=1600, bias=True)\n",
       "    (4): LeakyReLU(negative_slope=0.01)\n",
       "    (5): Dropout(p=0.5, inplace=False)\n",
       "    (6): Linear(in_features=1600, out_features=800, bias=True)\n",
       "    (7): LeakyReLU(negative_slope=0.01)\n",
       "    (8): Dropout(p=0.5, inplace=False)\n",
       "    (9): Linear(in_features=800, out_features=400, bias=True)\n",
       "    (10): LeakyReLU(negative_slope=0.01)\n",
       "    (11): Dropout(p=0.5, inplace=False)\n",
       "    (12): Linear(in_features=400, out_features=1, bias=True)\n",
       "  )\n",
       "  (MLP): Sequential(\n",
       "    (0): Linear(in_features=1600, out_features=200, bias=True)\n",
       "    (1): BatchNorm1d(200, eps=1e-05, momentum=0.1, affine=True, track_running_stats=True)\n",
       "    (2): ReLU(inplace=True)\n",
       "    (3): Linear(in_features=200, out_features=1, bias=True)\n",
       "    (4): Sigmoid()\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model = GatedGCNSolvationNetwork(\n",
    "        solute_in_feats=args.solute_feature_size,\n",
    "        solvent_in_feats=args.solvent_feature_size,\n",
    "        embedding_size=args.embedding_size,\n",
    "        gated_num_layers=args.gated_num_layers,\n",
    "        gated_hidden_size=args.gated_hidden_size,\n",
    "        gated_num_fc_layers=args.gated_num_fc_layers,\n",
    "        gated_graph_norm=args.gated_graph_norm,\n",
    "        gated_batch_norm=args.gated_batch_norm,\n",
    "        gated_activation=args.gated_activation,\n",
    "        gated_residual=args.gated_residual,\n",
    "        gated_dropout=args.gated_dropout,\n",
    "        num_lstm_iters=args.num_lstm_iters,\n",
    "        num_lstm_layers=args.num_lstm_layers,\n",
    "        set2set_ntypes_direct=args.set2set_ntypes_direct,\n",
    "        fc_num_layers=args.fc_num_layers,\n",
    "        fc_hidden_size=args.fc_hidden_size,\n",
    "        fc_batch_norm=args.fc_batch_norm,\n",
    "        fc_activation=args.fc_activation,\n",
    "        fc_dropout=args.fc_dropout,\n",
    "        outdim=1,\n",
    "        conv=\"GatedGCNConv\",\n",
    "    )\n",
    "optimizer = torch.optim.Adam(\n",
    "    model.parameters(), lr=args.lr, weight_decay=args.weight_decay\n",
    ")\n",
    "loss_func = MSELoss(reduction=\"mean\")\n",
    "metric = L1Loss(reduction=\"sum\")\n",
    "\n",
    "scheduler = ReduceLROnPlateau(\n",
    "    optimizer, mode=\"min\", factor=0.4, patience=50, verbose=True\n",
    ")\n",
    "stopper = EarlyStopping(patience=150)\n",
    "\n",
    "state_dict_objs = {\"model\": model, \"optimizer\": optimizer, \"scheduler\": scheduler}\n",
    "model.to(args.gpu)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "pre_trained"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.save_dir=\"/home/1739678401/2024.9dataclean/MMGNN_0901/result/transfer\"\n",
    "loc = \"cuda:{}\".format(args.gpu)\n",
    "checkpoint = load_checkpoints(\n",
    "        state_dict_objs, map_location=loc, save_dir=args.save_dir, filename=\"best_checkpoint.pkl\")\n",
    "\n",
    "if not args.distributed or (args.distributed and args.gpu == 0):\n",
    "    test_acc = evaluate(model, feature_names,solute_feature_names, test_loader, metric, label_scaler, args.gpu)\n",
    "    y_true, y_pred = evaluate(model, feature_names,solute_feature_names, test_loader, metric, \n",
    "                                label_scaler, args.gpu, return_preds=True)\n",
    "    \n",
    "    print(len(y_true))\n",
    "    print(len(y_pred))\n",
    "    print(\"\\n#Test MAE: {:12.6e} \\n\".format(test_acc))\n",
    "    print(\"\\n#Test RMSE: {:12.6e} \\n\".format(mean_squared_error(y_true, y_pred, squared=False)))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "theory"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.save_dir=\"/home/1739678401/2024.9dataclean/MMGNN_0901/result/theory_random\"\n",
    "loc = \"cuda:{}\".format(args.gpu)\n",
    "checkpoint = load_checkpoints(\n",
    "        state_dict_objs, map_location=loc, save_dir=args.save_dir, filename=\"best_checkpoint.pkl\")\n",
    "\n",
    "if not args.distributed or (args.distributed and args.gpu == 0):\n",
    "    test_acc = evaluate(model, feature_names,solute_feature_names, test_loader, metric, label_scaler, args.gpu)\n",
    "    y_true, y_pred = evaluate(model, feature_names,solute_feature_names, test_loader, metric, \n",
    "                                label_scaler, args.gpu, return_preds=True)\n",
    "    \n",
    "    print(len(y_true))\n",
    "    print(len(y_pred))\n",
    "    print(\"\\n#Test MAE: {:12.6e} \\n\".format(test_acc))\n",
    "    print(\"\\n#Test RMSE: {:12.6e} \\n\".format(mean_squared_error(y_true, y_pred, squared=False)))\n",
    "    print(\"\\nFinish training at:\", datetime.now())\n",
    "    p.append(mean_squared_error(y_true, y_pred, squared=False))\n",
    "    results_dict = {'y_true': y_true, 'y_pred': y_pred}\n",
    "    pickle_dump(results_dict, os.path.join(args.save_dir, f'seed_{random_seed}_test_results.pkl'))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "exp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "ename": "DGLError",
     "evalue": "[16:44:54] /opt/dgl/src/runtime/cuda/cuda_device_api.cc:97: Check failed: e == cudaSuccess || e == cudaErrorCudartUnloading: CUDA: out of memory\nStack trace:\n  [bt] (0) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dmlc::LogMessageFatal::~LogMessageFatal()+0x4f) [0x1554193324df]\n  [bt] (1) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dgl::runtime::CUDADeviceAPI::AllocDataSpace(DLContext, unsigned long, unsigned long, DLDataType)+0xfc) [0x155419b96abc]\n  [bt] (2) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dgl::runtime::NDArray::Empty(std::vector<long, std::allocator<long> >, DLDataType, DLContext)+0x351) [0x155419a52831]\n  [bt] (3) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dgl::runtime::NDArray::CopyTo(DLContext const&) const+0xc0) [0x155419a89a30]\n  [bt] (4) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dgl::aten::COOMatrix::CopyTo(DLContext const&) const+0x7d) [0x155419b792ad]\n  [bt] (5) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dgl::UnitGraph::CopyTo(std::shared_ptr<dgl::BaseHeteroGraph>, DLContext const&)+0x292) [0x155419b69a32]\n  [bt] (6) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dgl::HeteroGraph::CopyTo(std::shared_ptr<dgl::BaseHeteroGraph>, DLContext const&)+0xf5) [0x155419a9ac55]\n  [bt] (7) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(+0xcbfceb) [0x155419aa7ceb]\n  [bt] (8) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(DGLFuncCall+0x48) [0x155419a366f8]\n\n",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mDGLError\u001b[0m                                  Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_312967/1287792013.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      6\u001b[0m \u001b[0;31m#test_acc = evaluate(model, feature_names,solute_feature_names, test_loader, metric, label_scaler, args.gpu)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      7\u001b[0m y_true, y_pred = evaluate(model, feature_names,solute_feature_names, test_loader, metric, \n\u001b[0;32m----> 8\u001b[0;31m                         label_scaler, args.gpu, return_preds=True)\n\u001b[0m\u001b[1;32m      9\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     10\u001b[0m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my_true\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/tmp/ipykernel_312967/2526520012.py\u001b[0m in \u001b[0;36mevaluate\u001b[0;34m(model, nodes, nodes1, data_loader, metric_fn, scaler, device, return_preds)\u001b[0m\n\u001b[1;32m    240\u001b[0m             pred,loss_1 = model(solute_batched_graph, solvent_batched_graph, solute_feats, \n\u001b[1;32m    241\u001b[0m                      \u001b[0msolvent_feats\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msolute_norm_atom\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msolute_norm_bond\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 242\u001b[0;31m                      solvent_norm_atom, solvent_norm_bond)\n\u001b[0m\u001b[1;32m    243\u001b[0m             \u001b[0mpred\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpred\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mview\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    244\u001b[0m             \u001b[0mtarget\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtarget\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mview\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/dataclean/lib/python3.7/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m_call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m   1192\u001b[0m         if not (self._backward_hooks or self._forward_hooks or self._forward_pre_hooks or _global_backward_hooks\n\u001b[1;32m   1193\u001b[0m                 or _global_forward_hooks or _global_forward_pre_hooks):\n\u001b[0;32m-> 1194\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mforward_call\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1195\u001b[0m         \u001b[0;31m# Do not call functions when jit is used\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1196\u001b[0m         \u001b[0mfull_backward_hooks\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnon_full_backward_hooks\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/2024.9dataclean/MMGNN_0901/gnn/model/gated_solv_network.py\u001b[0m in \u001b[0;36mforward\u001b[0;34m(self, solute_graph, solvent_graph, solute_feats, solvent_feats, solute_norm_atom, solute_norm_bond, solvent_norm_atom, solvent_norm_bond)\u001b[0m\n\u001b[1;32m     33\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     34\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0mlayer\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgated_layers\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 35\u001b[0;31m             \u001b[0mdic\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlayer\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_emb\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msolute_graph\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdic\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msolute_norm_atom\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msolute_norm_bond\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     36\u001b[0m         \u001b[0matom1_pro\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mMLP\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdic\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m\"atom\"\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     37\u001b[0m         \u001b[0matom2_pro\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mMLP\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdic\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m\"atom2\"\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/2024.9dataclean/MMGNN_0901/gnn/layer/gatedconv.py\u001b[0m in \u001b[0;36mget_emb\u001b[0;34m(self, g, feats, norm_atom, norm_bond)\u001b[0m\n\u001b[1;32m    337\u001b[0m             \u001b[0mupdated\u001b[0m \u001b[0mnode\u001b[0m \u001b[0mfeatures\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    338\u001b[0m         \"\"\"\n\u001b[0;32m--> 339\u001b[0;31m         \u001b[0mg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mto\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'cuda:3'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    340\u001b[0m         \u001b[0mg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlocal_var\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    341\u001b[0m         \u001b[0;31m#print(feats)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/heterograph.py\u001b[0m in \u001b[0;36mto\u001b[0;34m(self, device, **kwargs)\u001b[0m\n\u001b[1;32m   5190\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   5191\u001b[0m         \u001b[0;31m# 1. Copy graph structure\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 5192\u001b[0;31m         \u001b[0mret\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_graph\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_graph\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcopy_to\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mutils\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mto_dgl_context\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdevice\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   5193\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   5194\u001b[0m         \u001b[0;31m# 2. Copy features\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/heterograph_index.py\u001b[0m in \u001b[0;36mcopy_to\u001b[0;34m(self, ctx)\u001b[0m\n\u001b[1;32m    232\u001b[0m             \u001b[0mThe\u001b[0m \u001b[0mgraph\u001b[0m \u001b[0mindex\u001b[0m \u001b[0mon\u001b[0m \u001b[0mthe\u001b[0m \u001b[0mgiven\u001b[0m \u001b[0mdevice\u001b[0m \u001b[0mcontext\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    233\u001b[0m         \"\"\"\n\u001b[0;32m--> 234\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0m_CAPI_DGLHeteroCopyTo\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mctx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdevice_type\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mctx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdevice_id\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    235\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    236\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mshared_memory\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mname\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mntypes\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0metypes\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mformats\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'coo'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'csr'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'csc'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32mdgl/_ffi/_cython/./function.pxi\u001b[0m in \u001b[0;36mdgl._ffi._cy3.core.FunctionBase.__call__\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32mdgl/_ffi/_cython/./function.pxi\u001b[0m in \u001b[0;36mdgl._ffi._cy3.core.FuncCall\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32mdgl/_ffi/_cython/./function.pxi\u001b[0m in \u001b[0;36mdgl._ffi._cy3.core.FuncCall3\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32mdgl/_ffi/_cython/./base.pxi\u001b[0m in \u001b[0;36mdgl._ffi._cy3.core.CALL\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;31mDGLError\u001b[0m: [16:44:54] /opt/dgl/src/runtime/cuda/cuda_device_api.cc:97: Check failed: e == cudaSuccess || e == cudaErrorCudartUnloading: CUDA: out of memory\nStack trace:\n  [bt] (0) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dmlc::LogMessageFatal::~LogMessageFatal()+0x4f) [0x1554193324df]\n  [bt] (1) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dgl::runtime::CUDADeviceAPI::AllocDataSpace(DLContext, unsigned long, unsigned long, DLDataType)+0xfc) [0x155419b96abc]\n  [bt] (2) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dgl::runtime::NDArray::Empty(std::vector<long, std::allocator<long> >, DLDataType, DLContext)+0x351) [0x155419a52831]\n  [bt] (3) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dgl::runtime::NDArray::CopyTo(DLContext const&) const+0xc0) [0x155419a89a30]\n  [bt] (4) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dgl::aten::COOMatrix::CopyTo(DLContext const&) const+0x7d) [0x155419b792ad]\n  [bt] (5) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dgl::UnitGraph::CopyTo(std::shared_ptr<dgl::BaseHeteroGraph>, DLContext const&)+0x292) [0x155419b69a32]\n  [bt] (6) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(dgl::HeteroGraph::CopyTo(std::shared_ptr<dgl::BaseHeteroGraph>, DLContext const&)+0xf5) [0x155419a9ac55]\n  [bt] (7) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(+0xcbfceb) [0x155419aa7ceb]\n  [bt] (8) /home/1739678401/anaconda3/envs/dataclean/lib/python3.7/site-packages/dgl/libdgl.so(DGLFuncCall+0x48) [0x155419a366f8]\n\n"
     ]
    }
   ],
   "source": [
    "args.save_dir=\"/home/1739678401/2024.9dataclean/MMGNN_0901/result/exp\"\n",
    "loc = \"cuda:{}\".format(args.gpu)\n",
    "checkpoint = load_checkpoints(\n",
    "        state_dict_objs, map_location=loc, save_dir=args.save_dir, filename=\"best_checkpoint.pkl\")\n",
    "label_scaler = testset.normalize_labels()\n",
    "#test_acc = evaluate(model, feature_names,solute_feature_names, test_loader, metric, label_scaler, args.gpu)\n",
    "y_true, y_pred = evaluate(model, feature_names,solute_feature_names, test_loader, metric, \n",
    "                        label_scaler, args.gpu, return_preds=True)\n",
    "\n",
    "print(len(y_true))\n",
    "print(len(y_pred))\n",
    "mae = np.mean(np.abs(np.array(y_true) - np.array(y_pred)))\n",
    "print(\"MAE:\", mae)\n",
    "print(\"\\n#Test RMSE: {:12.6e} \\n\".format(mean_squared_error(y_true, y_pred, squared=False)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MAE (前300): 2.537457289665218\n",
      "RMSE (前300): 3.7795436474054296\n"
     ]
    }
   ],
   "source": [
    "y_true_300 = y_true[:300]\n",
    "y_pred_300 = y_pred[:300]\n",
    "\n",
    "mae = mae = np.mean(np.abs(np.array(y_true_300) - np.array(y_pred_300)))\n",
    "rmse = mean_squared_error(y_true_300, y_pred_300, squared=False)  # squared=False gives RMSE\n",
    "\n",
    "print(\"MAE (前300):\", mae)\n",
    "print(\"RMSE (前300):\", rmse)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-1.574657678604126 -2.0406779457127473\n",
      "-14.600000381469727 -2.690680252708357\n",
      "-0.927505373954773 -1.9349292173250174\n",
      "-1.6580196619033813 -1.6438285402868176\n",
      "-13.479999542236328 -4.309522964113922\n",
      "-2.057279586791992 -2.7806853792048036\n",
      "-1.820356011390686 -2.7806853792048036\n",
      "-1.9629490375518799 -2.6018996949977033\n",
      "-1.607563853263855 -2.6485974179207803\n",
      "-0.712519109249115 -1.8754676674992967\n",
      "-13.4399995803833 -12.73644509481852\n",
      "-1.0986167192459106 -1.74656407412508\n",
      "-1.2477909326553345 -2.353958614694739\n",
      "-0.8858245015144348 -1.8501158060180405\n",
      "-1.5417516231536865 -3.4210942344646282\n",
      "-1.5176204442977905 -3.2767450982091164\n",
      "-10.260000228881836 -9.586265939146628\n",
      "-9.5600004196167 -2.3511872364797197\n",
      "-0.9647989273071289 -1.9931240842842266\n",
      "-1.1732038259506226 -1.7237458500805936\n",
      "-0.9362803101539612 -2.4931255453919112\n",
      "-1.5198142528533936 -3.2397988227504557\n",
      "-2.4653143882751465 -3.0146915894574056\n",
      "-2.5048017501831055 -3.014692132864899\n",
      "-0.7256816029548645 -1.8188473237514642\n",
      "-1.3355402946472168 -3.097993241118464\n",
      "0.013607623055577278 -0.6208989842320802\n",
      "-0.33519652485847473 -1.8057055569373408\n",
      "-1.853262186050415 -2.9154162028317185\n",
      "-1.0064798593521118 -1.7003247154224677\n",
      "-1.186366319656372 -2.4638676708499565\n",
      "-0.5128892064094543 -1.7872411137279007\n",
      "-0.9691863059997559 -2.889805135976234\n",
      "-11.829999923706055 -11.14089907775515\n",
      "-1.2477909326553345 -2.52000546874388\n",
      "-1.4781333208084106 -3.1534650931295434\n",
      "-1.493489384651184 -2.752046445797537\n",
      "-1.5527204275131226 -3.2736014858612954\n",
      "-0.6138010025024414 -1.7461453786516148\n",
      "-7.989999771118164 -7.85091177054418\n",
      "-0.40758979320526123 -1.6769769407759152\n",
      "-9.699999809265137 -2.433245300092725\n",
      "-1.0393860340118408 -2.658022277481819\n",
      "-1.1205542087554932 -2.9960448330340164\n",
      "-1.2543721199035645 -2.8306419168642476\n",
      "-0.3593275547027588 -1.754198134292472\n",
      "-1.0964230298995972 -3.160886137559624\n",
      "-1.1227480173110962 -2.6302481770998862\n",
      "-0.9340865015983582 -3.1335589898408\n",
      "-0.4404957890510559 -1.7473658718812097\n",
      "-0.8375622034072876 -2.4870105808715945\n",
      "-0.6159947514533997 -2.487010309167848\n",
      "-8.949999809265137 -8.149332689922483\n",
      "-0.7278753519058228 -2.4041039864580496\n",
      "-9.220000267028809 -8.273151075975886\n",
      "0.3251182436943054 0.02866587973155088\n",
      "-0.2671905755996704 -1.7213763217067521\n",
      "-0.36152133345603943 -2.2554562252280457\n",
      "0.2439500242471695 0.5875023418253642\n",
      "-0.4558520019054413 -2.231318336086466\n",
      "0.3207307755947113 0.04367207765464087\n",
      "0.09038837999105453 -1.6901374551485522\n",
      "0.16058798134326935 -2.011640694613008\n",
      "0.09038837999105453 -2.3999265413545277\n",
      "0.18252533674240112 -1.9136143301103061\n",
      "0.18910658359527588 -1.4967629099730937\n",
      "0.2483374923467636 -1.445855952608146\n",
      "0.3053745925426483 -1.8494851816222502\n",
      "0.26808103919029236 -2.284095973746552\n",
      "0.30976206064224243 -1.6950764858537113\n",
      "-3.930000066757202 -3.8426156985978945\n",
      "0.3865428566932678 -1.1497700552278705\n",
      "0.445773720741272 -1.6621644676241298\n",
      "0.25711241364479065 -1.2266964501793982\n",
      "0.4633236527442932 0.06161267604069298\n",
      "0.355830579996109 -2.141116224373756\n",
      "0.4545486569404602 -1.425628695490956\n",
      "0.4896484613418579 -0.9373411980091673\n",
      "0.11013204604387283 -1.5079304773646358\n",
      "0.4962296783924103 -0.7609731337390517\n",
      "0.5949478149414062 -1.4555707200667758\n",
      "0.3887366056442261 -0.8578893167332664\n",
      "0.33389317989349365 -1.1137714824372473\n",
      "0.5291357636451721 -0.36655330321495594\n",
      "-3.2200000286102295 -3.7689290991204736\n",
      "-2.7699999809265137 0.15410226159578144\n",
      "-4.819194316864014 -11.383326745632708\n",
      "-5.332528591156006 -11.203101303272529\n",
      "0.8450338244438171 -1.0701652047426498\n",
      "-0.4099999964237213 -0.9365527137366199\n",
      "-1.3201842308044434 -5.4820357743795896\n",
      "0.621272623538971 -0.42650093104329123\n",
      "-1.9015241861343384 -2.897092502163002\n",
      "-4.659051418304443 -6.981484506559423\n",
      "-1.3600000143051147 -1.3315496430184313\n",
      "1.0293077230453491 -1.0503954967346854\n",
      "-2.4100000858306885 -1.0498762708749885\n",
      "0.5686229467391968 -1.0493605771639976\n",
      "-3.3932652473449707 -6.0659177349989175\n",
      "-1.526395320892334 -2.8791214729573342\n",
      "-4.672214031219482 -7.0414987018056685\n",
      "0.3821553885936737 -0.19026865199503717\n",
      "1.1960316896438599 -0.4110197949711951\n",
      "0.9371707439422607 -1.0444052442340448\n",
      "0.35802432894706726 -0.5349205072598089\n",
      "0.798965334892273 -1.043903679117875\n",
      "-3.0799999237060547 -2.9828375856169695\n",
      "0.8143214583396912 -0.11854103653038983\n",
      "-3.9200000762939453 -3.797670600692071\n",
      "-4.661244869232178 -7.118641916346959\n",
      "-5.027598857879639 -9.832009751251075\n",
      "-2.127479314804077 -3.217458797299934\n",
      "1.5097359418869019 -0.40315886217541674\n",
      "-1.690000057220459 -0.4024415642844703\n",
      "-4.779706954956055 -9.34010533349494\n",
      "0.4699048399925232 -2.4673965591104148\n",
      "-3.2200000286102295 -2.4673973742216546\n",
      "0.445773720741272 -2.467397102517908\n",
      "-0.003942252602428198 -2.543055999491684\n",
      "0.4348050653934479 -2.796252645364562\n",
      "-26.799999237060547 -27.12153531754606\n",
      "-4.632726669311523 -6.772412956685218\n",
      "-4.865262508392334 -6.983188768309787\n",
      "-24.829999923706055 -23.951682908696235\n",
      "-27.280000686645508 -9.576313974317241\n",
      "1.1017009019851685 -0.39518055336111946\n",
      "-4.519999980926514 -2.01933181256718\n",
      "0.5949478149414062 -2.23244699344972\n",
      "0.5488793253898621 -2.232446450042227\n",
      "-1.6492446660995483 -5.5209016198262875\n",
      "0.21981889009475708 -2.352604714925578\n",
      "0.2483374923467636 -2.3526068885555507\n",
      "0.14303810894489288 -2.3526082470742837\n",
      "0.10793836414813995 -2.1293723733357375\n",
      "0.902070939540863 -1.0328844619719613\n",
      "-6.199054718017578 -7.340683787971201\n",
      "-4.66343879699707 -7.325774859989383\n",
      "0.6410163044929504 -1.032413055971661\n",
      "0.10793836414813995 -2.7227157546515017\n",
      "-4.193979263305664 -6.11187384254573\n",
      "-25.0 -6.434067752933968\n",
      "-24.899999618530273 -24.373099766887073\n",
      "-4.261984825134277 -6.434066937822728\n",
      "-0.06536692380905151 -2.1576906963220512\n",
      "-27.56999969482422 -9.585932015242092\n",
      "-4.904749870300293 -8.86688353705674\n",
      "-4.867456436157227 -9.775364139054812\n",
      "-13.859999656677246 -3.1784906384111684\n",
      "-3.5199999809265137 -3.8769373158646836\n",
      "0.3602180480957031 -1.7672325781267002\n",
      "0.6695348620414734 -1.9844235869115447\n",
      "0.6475974917411804 -1.9844233152077981\n",
      "0.39531779289245605 -2.1468483583151543\n",
      "0.2900184988975525 -2.14685107535262\n",
      "-2.6500000953674316 -2.7719204880441852\n",
      "-4.626145362854004 -7.49359390172553\n",
      "-26.3700008392334 -26.79146743258221\n",
      "0.2593061029911041 -2.5771257473854026\n",
      "-0.09607920795679092 3.826677787982688\n",
      "-4.290503978729248 -6.627417029660996\n",
      "-4.268566608428955 -6.039702229196219\n",
      "-4.242241382598877 -6.03969937630688\n",
      "-4.253210544586182 -6.039701821640598\n",
      "-4.277341365814209 -6.380456120623784\n",
      "-4.272953510284424 -6.380454082845685\n",
      "-1.3684464693069458 -1.9780958783576637\n",
      "-4.9332685470581055 -9.598417345804501\n",
      "-27.40999984741211 -8.308763014335138\n",
      "0.5335232019424438 0.36959267663084105\n",
      "-4.429999828338623 -2.1005584627156795\n",
      "-17.860000610351562 -8.183294299725066\n",
      "0.36899298429489136 -2.2837473778397017\n",
      "-3.200000047683716 -1.4911128305631594\n",
      "0.7507031559944153 -1.72530135402971\n",
      "0.5444918870925903 -1.9168128266149345\n",
      "-3.2799999713897705 -1.9168171738748794\n",
      "0.44138625264167786 -1.9168179889861192\n",
      "0.38434913754463196 -1.5733744002823462\n",
      "0.3865428566932678 -1.573456726517557\n",
      "-4.6283392906188965 -7.8097986464281135\n",
      "-3.7899999618530273 -0.43401353963596634\n",
      "0.35363683104515076 -2.433744419875175\n",
      "-4.2268853187561035 -6.180407037061948\n",
      "-4.2883100509643555 -6.658807506909782\n",
      "-25.059999465942383 -6.00194338972047\n",
      "-4.255403518676758 -6.0019422349795475\n",
      "-4.303666114807129 -6.195400193205203\n",
      "0.5971415638923645 -2.154283531340057\n",
      "0.5401043891906738 -2.1542867917850157\n",
      "0.494035929441452 -2.1542881503037483\n",
      "0.23078760504722595 -2.625352890697925\n",
      "-10.59000015258789 -11.096404872216763\n",
      "-4.895974636077881 -9.64278874124944\n",
      "-3.0203299522399902 -11.006986625812907\n",
      "0.3931240737438202 -2.0212625393903103\n",
      "-3.0378799438476562 -11.006986082405415\n",
      "-4.909137725830078 -5.958522821536654\n",
      "-3.553408145904541 -6.126496530630536\n",
      "0.48306724429130554 -2.4034282592403287\n",
      "0.5225545167922974 -2.3054537901532215\n",
      "-2.1384477615356445 -6.341450874173613\n",
      "0.6475974917411804 -1.1591693746367309\n",
      "0.32950571179389954 -2.3039792539205832\n",
      "-1.269728422164917 -5.481326432313973\n",
      "0.5883666276931763 -1.6737759989375678\n",
      "0.5291357636451721 -1.2451035638983114\n",
      "-3.0899999141693115 -3.2827204070036955\n",
      "-3.3499999046325684 -3.5514344613988365\n",
      "-4.626145362854004 -8.659950159816171\n",
      "0.494035929441452 -5.449014794456891\n",
      "-0.13117896020412445 3.611992159444971\n",
      "-4.2488226890563965 -6.203745166225497\n",
      "-4.292697429656982 -6.684418981320887\n",
      "-4.312440872192383 -6.683952465988025\n",
      "-4.314634799957275 -5.837963046441808\n",
      "-4.299278736114502 -5.6986496844067185\n",
      "-3.081754684448242 -4.805725735140804\n",
      "-1.6229199171066284 -3.139605756720727\n",
      "-1.532976746559143 -3.139605756720727\n",
      "-1.6887320280075073 -3.139605756720727\n",
      "-2.359999895095825 -2.544495485941015\n",
      "0.6432100534439087 -1.925552992734615\n",
      "-3.7899999618530273 -2.4235066227043975\n",
      "-0.368102490901947 -0.6156768382229947\n",
      "-27.65999984741211 -27.788155025681924\n",
      "0.32731199264526367 -2.847389192395362\n",
      "0.3733804523944855 -2.3403791331448907\n",
      "-2.3499999046325684 -2.4314545006990786\n",
      "0.5006171464920044 -2.203972712512875\n",
      "-3.630000114440918 -3.643845388719292\n",
      "0.5899999737739563 -0.37488102304734205\n",
      "0.12987570464611053 -2.3819997998595506\n",
      "-4.690000057220459 -2.6409329269337722\n",
      "-13.760000228881836 -13.470243554293948\n",
      "0.6410163044929504 -0.5251913395026113\n",
      "0.6322413682937622 -2.384930124766314\n",
      "-2.2899999618530273 -2.943092489864886\n",
      "-2.533320665359497 -8.73470102286891\n",
      "0.1671692430973053 -2.5993299209626395\n",
      "0.2044626772403717 -2.4301924367962586\n",
      "-18.889999389648438 -7.835637672726971\n",
      "-2.369999885559082 -2.5936670714766166\n",
      "0.6388225555419922 -0.8058988048269953\n",
      "-2.8667681217193604 -8.708614202753179\n",
      "-4.31682825088501 -6.226323611713634\n",
      "-4.312440872192383 -6.722149257940277\n",
      "-4.297084808349609 -5.388162945050712\n",
      "-4.53000020980835 -3.741415019224009\n",
      "0.5159732699394226 -2.21216512387947\n",
      "-5.369999885559082 -2.5770801011559787\n",
      "-4.402384281158447 -4.994804338416268\n",
      "-2.263490915298462 -5.4012618505988135\n",
      "-4.781900882720947 -9.658618473228387\n",
      "0.4128677248954773 -2.710195374305785\n",
      "-3.180000066757202 -3.1861752354754227\n",
      "-4.308053493499756 -5.521547009622555\n",
      "0.41506147384643555 -0.41761893556790053\n",
      "-4.300000190734863 -4.323674246198428\n",
      "-4.010000228881836 -3.751669526175201\n",
      "0.761671781539917 -2.3283062488697754\n",
      "-2.498220920562744 -8.749755040651396\n",
      "-2.4697020053863525 -8.750717143618003\n",
      "0.31853699684143066 -2.39576458336456\n",
      "0.347055584192276 -2.377174341320458\n",
      "-2.97426176071167 -7.218999091439617\n",
      "-18.3799991607666 -17.876856639453262\n",
      "-2.259999990463257 -0.1809785574922973\n",
      "-2.5442891120910645 -6.244349796779856\n",
      "-3.5643768310546875 -5.952636122126425\n",
      "-3.981186628341675 0.21197189917034542\n",
      "-3.9600000381469727 -4.044320952346952\n",
      "-0.16189123690128326 3.3906573968211786\n",
      "0.48745474219322205 -2.984329782593135\n",
      "-5.929999828338623 3.3906590270436583\n",
      "-4.334378242492676 -6.25270550209814\n",
      "-4.312440872192383 -6.7533753544223885\n",
      "1.1038947105407715 3.250794632829039\n",
      "0.792384147644043 -0.8368974852732274\n",
      "0.6607599258422852 -1.9904852974975333\n",
      "0.1540067344903946 -2.491647205306821\n",
      "-4.444065093994141 -4.110145260509862\n",
      "0.9196208119392395 -2.326797749668816\n",
      "0.7199907898902893 -2.0282727677555763\n",
      "-1.9059118032455444 2.250666183482754\n",
      "-3.0027801990509033 -6.24986008461218\n",
      "-4.349734306335449 -5.82238141394645\n",
      "-2.0177924633026123 -5.522079396132476\n",
      "-3.553408145904541 -3.1177811532774493\n",
      "0.38434913754463196 -1.8943320586236885\n",
      "-2.3907272815704346 -4.931917555309406\n",
      "0.47209858894348145 -2.277585680274975\n",
      "-12.890000343322754 -3.0995359749914915\n",
      "-1.4276772737503052 -3.0995365183989847\n",
      "-1.598788857460022 -3.0995365183989847\n",
      "-2.3995025157928467 -8.776863195150485\n",
      "0.945945680141449 -2.038826012976122\n",
      "-2.166966438293457 -6.201594902775137\n",
      "0.3755742013454437 -2.7718145235830227\n",
      "0.4655173718929291 -2.160496580912885\n",
      "-2.84702467918396 -6.758086969091668\n",
      "-2.6671383380889893 -6.830619642757403\n",
      "0.4128677248954773 -0.9807192445566457\n",
      "0.43041759729385376 -2.4146238121177674\n",
      "0.45674240589141846 -2.414624627229007\n",
      "0.4786797761917114 -2.4146238121177674\n",
      "-4.301472187042236 -6.260934321766775\n",
      "-1.7984187602996826 -3.3891413304604407\n",
      "0.4282238781452179 -2.7222155480540655\n",
      "0.3053745925426483 -2.434614958679187\n",
      "-1.6997005939483643 -3.1713912912170272\n",
      "0.9305895566940308 -2.2713457320312367\n",
      "0.8318713307380676 -2.469206921173814\n",
      "0.3755742013454437 0.5206257250519872\n",
      "0.19130027294158936 0.5206257250519872\n",
      "0.00044521642848849297 2.6691301653558623\n",
      "0.4699048399925232 -2.0816011489099604\n",
      "0.16497546434402466 -2.774661163735842\n",
      "0.5028108954429626 -1.5728779975373621\n",
      "-2.6500000953674316 -2.0656646373586125\n",
      "-2.263490915298462 -7.710845636297734\n",
      "-1.914686679840088 -6.496646695695966\n",
      "-2.542095422744751 -7.036146953109468\n",
      "-2.0682482719421387 -5.768925773549766\n",
      "0.6190788745880127 -1.869942028405292\n",
      "0.43699881434440613 -2.077979609671922\n",
      "-2.700044631958008 -6.340711160723574\n",
      "-2.5530643463134766 -6.390458894053778\n",
      "0.5839791297912598 -0.40194760687320485\n",
      "0.5773979425430298 -2.171093570436629\n",
      "0.5313294529914856 -2.171093570436629\n",
      "0.355830579996109 -2.5791034789566893\n",
      "-0.1443413645029068 3.1409643707603268\n",
      "-4.329990863800049 -6.210661113390703\n",
      "-20.829999923706055 -4.064337231504929\n",
      "-2.7200000286102295 -1.8193219901967228\n",
      "0.30976206064224243 -2.9383496292647506\n",
      "-0.13861578702926636 -2.5589047507328897\n",
      "0.5269420146942139 -2.117857296852332\n",
      "0.45235493779182434 -2.3886532812055696\n",
      "-2.406083822250366 -4.943336041110905\n",
      "-2.0594732761383057 -4.476190932927723\n",
      "0.4479674696922302 -5.445930311636918\n",
      "-3.623607635498047 -2.970472348110545\n",
      "-10.300000190734863 -10.14683994669976\n",
      "-2.1516103744506836 -7.037623798823953\n",
      "-1.890555739402771 -6.511765786525757\n",
      "-2.3731775283813477 -6.513215597717457\n",
      "-1.8971368074417114 -5.394768283889135\n",
      "0.5993353128433228 -2.257804832413401\n",
      "0.586172878742218 -1.8412593506948274\n",
      "-2.542095422744751 -5.972748822151467\n",
      "-2.3885340690612793 -5.9956563688026385\n",
      "0.7375407218933105 -2.137913380609182\n",
      "0.6475974917411804 -1.9153918160203705\n",
      "0.6168851852416992 -1.9153918160203705\n",
      "0.2658873498439789 -2.0434025908833564\n",
      "-2.307365655899048 -6.507112724013863\n",
      "-3.3581655025482178 -4.60311828910126\n",
      "-3.3691341876983643 -4.3641877201458135\n",
      "-1.256565809249878 -3.058462247918678\n",
      "-1.3552839756011963 -3.058462247918678\n",
      "0.608110249042511 -2.383409942304252\n",
      "-10.869999885559082 -10.840605576155484\n",
      "-2.059999942779541 -2.3760000377277803\n",
      "0.4633236527442932 -3.1379271709744145\n",
      "0.614691436290741 -1.281276842197979\n",
      "-9.779999732971191 -2.499533678254777\n",
      "-0.9604113698005676 -2.4995315046248043\n",
      "-10.420000076293945 -2.500171366947978\n",
      "0.5817854404449463 -1.0009242219666161\n",
      "0.5949478149414062 0.5915317083870058\n",
      "0.4282238781452179 0.5915317083870058\n",
      "0.5071983337402344 0.5915317083870058\n",
      "2.501305103302002 3.936905824336379\n",
      "-2.0002424716949463 -6.511503184854696\n",
      "-1.844487190246582 -6.512338130467907\n",
      "-14.380000114440918 -5.472106658137142\n",
      "-17.09000015258789 -15.545045092895606\n",
      "-2.4038901329040527 -5.565421424952049\n",
      "-2.250328302383423 -5.569239185239565\n",
      "0.6454037427902222 -0.03747876714856524\n",
      "-0.13556642830371857 0.6147172758968553\n",
      "-14.760000228881836 -4.856116998794761\n",
      "-2.1500000953674316 -2.2556705994840898\n",
      "0.6783097982406616 -1.1887163419650362\n",
      "0.3887366056442261 0.8549968539540238\n",
      "-2.673719644546509 -4.912868541489219\n",
      "-6.679999828338623 -6.593227596266913\n",
      "-0.20795972645282745 2.864124336564628\n",
      "0.05090116336941719 -0.5346738002579228\n",
      "-0.0982728898525238 2.301223186422119\n",
      "-2.193291187286377 3.5145901701518865\n",
      "-1.0920356512069702 -5.382284787327015\n",
      "-3.3976523876190186 -6.732390315556013\n",
      "-18.6299991607666 -17.841625358042954\n",
      "0.5532668232917786 -2.9689586865384006\n",
      "-0.13556642830371857 2.384080330753789\n",
      "-3.562182903289795 -3.8583137901116267\n",
      "-1.6777633428573608 -2.884179509903491\n",
      "-1.0766795873641968 -2.6414255258263046\n",
      "-2.4126648902893066 -4.93602958773594\n",
      "-1.7479628324508667 -4.1608688178458735\n",
      "-2.0682482719421387 -4.483439037923112\n",
      "-14.5 -14.424631221312577\n",
      "0.3544923663139343 -0.7538669939512461\n",
      "-20.56999969482422 -19.535553671517032\n",
      "0.7397344708442688 -0.5606410707251612\n",
      "-0.9998986721038818 -2.4882644936620175\n",
      "-10.279999732971191 -2.488270471144442\n",
      "-19.6200008392334 -19.352366658319237\n",
      "5.739999771118164 5.290640397619414\n",
      "-1.774287462234497 -6.527587910799799\n",
      "-1.818162441253662 -6.528406961743835\n",
      "-1.888361930847168 -6.02776112123819\n",
      "-1.9190740585327148 -6.027334546356075\n",
      "-14.869999885559082 -5.531824322706974\n",
      "-1.8028061389923096 -5.006759710820991\n",
      "-13.65999984741211 -5.147826156373406\n",
      "-12.920000076293945 -4.786174612796955\n",
      "0.9920141100883484 -2.0001775135451973\n",
      "-1.7400000095367432 -2.42046652948402\n",
      "-2.267878293991089 -5.2224267332913215\n",
      "-2.079216957092285 -5.217640603869545\n",
      "-1.9432053565979004 -4.596257497796607\n",
      "-0.8704681992530823 -4.609547614856358\n",
      "-0.8529183268547058 -4.605018720956647\n",
      "0.38434913754463196 -2.5389307215075037\n",
      "-8.699999809265137 -9.56351672785377\n",
      "-2.206453800201416 -3.6630331073021027\n",
      "-0.2211221158504486 2.7294212267198636\n",
      "0.2900184988975525 -1.730478397216865\n",
      "-3.103691816329956 -4.319163284745992\n",
      "-5.210000038146973 -1.2466829777771258\n",
      "-15.420000076293945 -2.7315939462744403\n",
      "-4.5 -2.7214936311994276\n",
      "0.13165263831615448 -0.35332948186936797\n",
      "0.6432100534439087 -5.453029183349503\n",
      "-0.6116073727607727 -4.33882811510778\n",
      "0.18910658359527588 -2.6649455606481824\n",
      "-4.800000190734863 -4.681797037366294\n",
      "-3.421783685684204 -4.163891114470851\n",
      "-0.5304390788078308 -2.2352335870745477\n",
      "-2.4433774948120117 -5.537682569640492\n",
      "-2.84702467918396 -5.482046234973833\n",
      "-2.3556275367736816 -5.102867439317285\n",
      "-10.710000038146973 -10.871959101694738\n",
      "-10.829999923706055 -10.87195964510223\n",
      "-1.1249415874481201 -3.0193168023352754\n",
      "-1.528589129447937 -7.161179719058168\n",
      "-1.0240297317504883 -3.426088556882214\n",
      "-10.239999771118164 -2.440003930788667\n",
      "-12.420000076293945 -12.360328315478402\n",
      "2.4289116859436035 3.743465798557998\n",
      "-13.430000305175781 -6.502480446838582\n",
      "-1.7172505855560303 -5.507467635632727\n",
      "-0.20137856900691986 -3.1113575333010286\n",
      "-1.6514384746551514 -4.707310698428633\n",
      "-1.574657678604126 -4.542927622271617\n",
      "0.02238256111741066 -2.6287551650124814\n",
      "-1.6163387298583984 2.4214107953101003\n",
      "-2.1559977531433105 -5.529611949478298\n",
      "-2.829474687576294 -4.880306375796316\n",
      "-3.1102731227874756 -5.032367313453706\n",
      "0.8625836968421936 -3.0197431055136446\n",
      "-2.0901856422424316 -4.909212258134588\n",
      "-14.300000190734863 -14.72358685366413\n",
      "0.0016079067718237638 -2.523940010697968\n",
      "0.37996166944503784 -5.440099863392971\n",
      "-1.7413816452026367 -3.7978355248662394\n",
      "-1.7786750793457031 -4.382839095532894\n",
      "0.4786797761917114 -2.2891118966119905\n",
      "0.5576542615890503 -2.2891124400194838\n",
      "0.608110249042511 -2.289110809797004\n",
      "-3.9600000381469727 -0.748608983047613\n",
      "-0.738844096660614 -2.4684915252090938\n",
      "-0.2628031075000763 2.6048113676527\n",
      "-0.23428462445735931 2.6048097374302204\n",
      "-25.440000534057617 -23.710002426121747\n",
      "0.4282238781452179 -1.3618739547656746\n",
      "-2.5969388484954834 0.9037758275758305\n",
      "-1.2982467412948608 -3.947078996560599\n",
      "0.35802432894706726 -0.7445600538162189\n",
      "0.35802432894706726 -2.70709251751995\n",
      "0.5225545167922974 0.6623686789703944\n",
      "0.7726404666900635 0.6623681355629012\n",
      "0.3009871244430542 0.6623681355629012\n",
      "0.4128677248954773 0.6623681355629012\n",
      "-3.3399999141693115 -3.3222988125072583\n",
      "0.24175623059272766 0.6623681355629012\n",
      "-1.4386459589004517 -3.3336799390436047\n",
      "0.3514430522918701 -2.5098312502498\n",
      "-2.8009562492370605 0.3665034050323337\n",
      "0.3667992651462555 -0.8424799104502654\n",
      "-1.1293292045593262 -2.261782303559447\n",
      "-0.6467071771621704 -5.120786233477675\n",
      "-1.6163387298583984 -2.9429305544319297\n",
      "0.32950571179389954 -2.4177071062338498\n",
      "0.3009871244430542 -2.935480981108459\n",
      "-0.743231475353241 -5.4188774913039675\n",
      "-19.290000915527344 -6.262332509246627\n",
      "0.3755742013454437 -0.6966755289281217\n",
      "-15.100000381469727 -17.50493116210774\n",
      "-2.8536059856414795 -5.482390848722647\n",
      "-11.569999694824219 -11.869255854594265\n",
      "-3.055429697036743 -3.9958343319564547\n",
      "-2.0441172122955322 -4.880760121053088\n",
      "0.29221218824386597 0.9030574428698985\n",
      "-3.597282648086548 -3.793875035204354\n",
      "-3.191441535949707 -5.48945420366111\n",
      "-2.0506982803344727 -5.547322079406692\n",
      "-0.12240402400493622 -2.51654803856877\n",
      "-0.054398197680711746 -0.5393867734459352\n",
      "-9.59000015258789 -2.337198569087536\n",
      "-9.449999809265137 -9.466357913413868\n",
      "-13.100000381469727 -12.955569275760215\n",
      "-1.6624071598052979 -2.8301289401907224\n",
      "-10.239999771118164 -10.23425791012136\n",
      "-1.1578477621078491 -2.493068215901385\n",
      "-1.853262186050415 -2.9899062302877484\n",
      "-1.7611252069473267 -4.163201394510182\n",
      "-1.454002022743225 -3.831569718632943\n",
      "-2.070441961288452 -4.466192914313295\n",
      "-13.140000343322754 -4.16349157411152\n",
      "0.19130027294158936 1.1052191589131946\n",
      "0.03773875534534454 1.1052191589131946\n",
      "1.2508751153945923 -1.0993326019369967\n",
      "-2.702238082885742 0.032168141024844665\n",
      "-1.0349984169006348 -2.384043012033761\n",
      "-1.491295576095581 -6.404466716560096\n",
      "2.3850369453430176 3.6389522354021784\n",
      "-1.6295009851455688 -5.072398037769373\n",
      "-13.510000228881836 -4.787030479598653\n",
      "-1.4167085886001587 -4.364450729372494\n",
      "-0.10046667605638504 -2.785130995906191\n",
      "-1.090000033378601 3.1941857006385623\n",
      "-1.609757423400879 -3.5437610041881915\n",
      "-1.4408397674560547 -3.2477293117053563\n",
      "-1.9804989099502563 -4.560432679551917\n",
      "-4.820000171661377 -4.711450784267002\n",
      "-1.633888602256775 -5.137396196727866\n",
      "-13.600000381469727 -5.488678735696172\n",
      "-17.299999237060547 -16.387341922674057\n",
      "-2.7307567596435547 -3.5412408160868765\n",
      "-14.380000114440918 -4.632760081037118\n",
      "-1.78306245803833 -4.654201038790238\n",
      "-3.1936354637145996 -5.132699355949806\n",
      "-0.1882161647081375 -3.046415990610727\n",
      "0.3975115418434143 -2.2257016762373603\n",
      "-1.1797850131988525 -3.0983581392501085\n",
      "0.21543140709400177 0.15700514442414093\n",
      "-2.140000104904175 -2.0294742417229115\n",
      "0.6059165000915527 -2.0294736983154182\n",
      "-0.13556642830371857 -1.118441526433302\n",
      "-12.529999732971191 -3.2882628917299876\n",
      "-1.5176204442977905 -3.288260989803762\n",
      "-1.559301495552063 -3.288881289457182\n",
      "-0.2606094479560852 2.4849019834012083\n",
      "-0.2606094479560852 2.4849025268087015\n",
      "-0.07194807380437851 0.6211392656507959\n",
      "-0.3571338653564453 -2.4549902943382578\n",
      "-0.49533921480178833 -2.455634775625123\n",
      "-14.420000076293945 -14.961020063272226\n",
      "0.6651473641395569 -3.9438068683406504\n",
      "-1.642663598060608 -3.5249409007744905\n",
      "0.1978815346956253 -3.375093159947758\n",
      "0.49184221029281616 -2.2919316380938994\n",
      "0.07722597569227219 -3.119597221119527\n",
      "-3.072979688644409 -4.579037593598334\n",
      "-3.0576233863830566 -4.5787453762188965\n",
      "-11.3100004196167 1.6743798199691948\n",
      "-1.4342585802078247 -2.7573528199680597\n",
      "0.8450338244438171 -5.603668133976991\n",
      "-0.3176465332508087 1.6693027637607782\n",
      "-0.5479889512062073 2.4150567314928013\n",
      "-1.5527204275131226 -5.458989446549116\n",
      "0.3316994607448578 -0.41796997680846903\n",
      "0.4633236527442932 -2.1546709808826665\n",
      "-3.7300000190734863 -3.5710217203409793\n",
      "-3.169504165649414 -3.462520497148617\n",
      "-7.710000038146973 -2.2215633564733444\n",
      "-3.559999942779541 -1.9826113229219193\n",
      "0.32950571179389954 -1.982611594625666\n",
      "0.33389317989349365 -1.9826118663294126\n",
      "0.28343725204467773 -1.9826126814406524\n",
      "-3.9200000762939453 -3.949678250452166\n",
      "-6.5 1.6787363178417065\n",
      "-2.776824951171875 -5.48266929411843\n",
      "-2.860187292098999 -5.482677555610474\n",
      "0.3733804523944855 -1.2276050275079298\n",
      "-6.440000057220459 -2.8286408187707557\n",
      "-6.960000038146973 -4.144470681629103\n",
      "-1.3859963417053223 -2.9351177131992943\n",
      "-2.2130348682403564 -3.8569086741862373\n",
      "-4.329990863800049 -5.650069733779274\n",
      "-0.1640850305557251 0.5385228508385884\n",
      "-0.1684724986553192 0.5385228508385884\n",
      "0.26149988174438477 -0.5437981554752547\n",
      "-4.53000020980835 -4.331897495940259\n",
      "-0.15969756245613098 0.5385228508385884\n",
      "0.3977747857570648 -1.228338899327417\n",
      "-1.528589129447937 -4.6183343781685755\n",
      "-1.633888602256775 -4.595156146659884\n",
      "-0.9560239911079407 -4.786355024084679\n",
      "-1.6843444108963013 -3.417547413756896\n",
      "-1.6646008491516113 -2.800426830023125\n",
      "-1.0262234210968018 -2.584016969509671\n",
      "-1.8773932456970215 -2.9887998526317134\n",
      "-2.3556275367736816 -4.854286258950369\n",
      "-1.5110392570495605 -4.003736020314219\n",
      "-11.260000228881836 -11.407612713316167\n",
      "1.2421001195907593 -1.1005503781291255\n",
      "-0.291321724653244 -2.1911504693047186\n",
      "-1.6470508575439453 -3.532029379818769\n",
      "-12.84000015258789 -5.492005332026566\n",
      "-1.4364521503448486 -2.822017224836859\n",
      "-12.329999923706055 -12.242553435859968\n",
      "-1.2192723751068115 -2.1906222772213857\n",
      "2.352130889892578 3.5258403354823864\n",
      "-0.1506813019514084 -2.759964164676349\n",
      "-1.5198142528533936 -4.7520641093412515\n",
      "0.02018887922167778 -2.727566209935279\n",
      "-4.71999979019165 -2.7275140428159372\n",
      "0.05406014621257782 -2.5632620637166412\n",
      "0.11451951414346695 -2.5632607051979086\n",
      "0.2746622860431671 -2.5019113577410157\n",
      "-1.6843444108963013 2.213426467977798\n",
      "-2.224003553390503 -5.549570521307726\n",
      "-2.410470962524414 -3.4256144338444487\n",
      "-1.572463870048523 -5.099296470939077\n",
      "-1.574657678604126 -3.107626769156869\n",
      "-4.889999866485596 -4.725769300007522\n",
      "-13.59000015258789 -14.220811569007708\n",
      "-1.6185322999954224 -4.4333600977258385\n",
      "-19.059999465942383 -17.273191776212776\n",
      "-0.04342947155237198 -2.855618827175237\n",
      "-0.07324235886335373 -2.673504500368901\n",
      "-1.565882682800293 -4.054712397986416\n",
      "0.18033164739608765 0.2672293769253802\n",
      "-1.940000057220459 -1.7728139164887522\n",
      "0.7199907898902893 -1.772815818414978\n",
      "-1.1468790769577026 -2.9810201592561594\n",
      "-0.9933175444602966 -2.9810198875524128\n",
      "0.4896484613418579 1.8592492227657562\n",
      "0.432611346244812 1.8590432713258558\n",
      "-5.71999979019165 -5.81456602549119\n",
      "-0.4843705892562866 -4.087210883113716\n",
      "-1.0591295957565308 -3.0910251268339164\n",
      "-1.9695301055908203 -7.144766774987209\n",
      "-1.223659873008728 -7.227736676373705\n",
      "-1.5439454317092896 -3.2581880040220956\n",
      "-0.29570919275283813 2.3752863672922864\n",
      "-6.78000020980835 2.3752863672922864\n",
      "-0.2847405672073364 2.3752863672922864\n",
      "-0.27377185225486755 2.3752863672922864\n",
      "-0.2847405672073364 2.3752798464023694\n",
      "-1.7479628324508667 -3.356096449098786\n",
      "0.36899298429489136 -0.7560889871907\n",
      "-3.059999942779541 -2.833679564750906\n",
      "-11.630000114440918 -3.281019541550164\n",
      "-12.010000228881836 -11.839100542577388\n",
      "-2.5899999141693115 -2.6587140352205876\n",
      "-4.53000020980835 -2.912820345236984\n",
      "-3.1409852504730225 -4.608183390344827\n",
      "-3.0203299522399902 -4.607677885524333\n",
      "-6.118299961090088 -2.2451782159027753\n",
      "-2.263490915298462 -6.910627837454408\n",
      "-1.9717239141464233 -5.49815665390447\n",
      "0.4786797761917114 0.212562583115389\n",
      "-1.6163387298583984 -2.882236013004272\n",
      "0.6103039383888245 -1.8459269493571626\n",
      "-0.7871061563491821 1.5898984306405266\n",
      "-3.011554718017578 1.5759774174812398\n",
      "-0.20137856900691986 -2.801469629002463\n",
      "0.4808735251426697 -1.7055321894292383\n",
      "-3.559999942779541 -1.7055330045404782\n",
      "-2.882124662399292 -5.482807684723597\n",
      "0.36460551619529724 -0.7310373583494032\n",
      "-1.3838025331497192 -4.109833072905052\n",
      "-0.0609794557094574 -2.6801126071892427\n",
      "-6.0406999588012695 -6.072581812791053\n",
      "-11.579999923706055 -11.843327166059037\n",
      "-1.302634358406067 -3.3335556345795485\n",
      "-0.07852933555841446 -4.533611444209207\n",
      "-0.6532883048057556 -3.310370610477192\n",
      "-2.41485857963562 -5.229219700548236\n",
      "-2.219616174697876 -3.823139023080606\n",
      "-2.4477646350860596 -5.38314941657454\n",
      "-0.03246085345745087 0.39455899049571386\n",
      "-25.3700008392334 -23.741318999951467\n",
      "-4.395802974700928 -5.713509790621575\n",
      "-0.4799831211566925 -2.4360500978685726\n",
      "-0.4580457806587219 -2.4360500978685726\n",
      "-0.4843705892562866 -2.4360500978685726\n",
      "0.4615028202533722 -0.7274400007448101\n",
      "-0.7871061563491821 -1.7958312993794743\n",
      "-9.460000038146973 -1.7958304842682349\n",
      "-1.7699002027511597 -5.8383808588780965\n",
      "-1.6602134704589844 -2.7663983810988855\n",
      "-1.5834325551986694 -2.766224762404827\n",
      "-1.603176236152649 -2.766395392357673\n",
      "-1.892749309539795 -3.0026483208906667\n",
      "-1.7720938920974731 -4.153520725871747\n",
      "-2.083604335784912 -4.41642534660959\n",
      "-1.3311529159545898 -5.608010443819487\n",
      "-1.3596715927124023 -4.075371935764398\n",
      "-11.789999961853027 -3.5338822635185068\n",
      "0.3711867332458496 0.7308939940779613\n",
      "-3.359999895095825 -3.10453287859467\n",
      "0.7090221047401428 0.7308939940779613\n",
      "0.5839791297912598 0.7308939940779613\n",
      "0.41067400574684143 0.7308939940779613\n",
      "0.7726404666900635 0.7308939940779613\n",
      "1.2355189323425293 -1.094898668496712\n",
      "-3.4200000762939453 -3.6240999981966455\n",
      "-0.12679149210453033 -3.0105565301383486\n",
      "-1.495683193206787 -2.7923958106819935\n",
      "2.3148372173309326 3.409895108893358\n",
      "0.012247542850673199 -2.562868093284114\n",
      "0.2106820046901703 -2.334321769818847\n",
      "0.25491863489151 -2.3343128035952105\n",
      "0.20665647089481354 -2.3342992184078817\n",
      "-13.75 -3.8709226100268523\n",
      "-12.899999618530273 -3.5038907888608124\n",
      "-1.0744857788085938 -3.414232220493116\n",
      "-1.4496147632598877 -3.178823203796971\n",
      "-1.4232898950576782 -3.1788207584632517\n",
      "-1.3574777841567993 -3.1794250275956246\n",
      "-14.550000190734863 -4.484642413816673\n",
      "-1.9190740585327148 -4.485267196581912\n",
      "-1.528589129447937 -3.343378268425566\n",
      "-2.9150307178497314 -5.859917422387042\n",
      "-1.8006123304367065 -5.525591213755981\n",
      "-2.2788469791412354 -5.5630609392185235\n",
      "-1.8006123304367065 -5.549452330177968\n",
      "-2.3446590900421143 -5.626302669307312\n",
      "-2.860187292098999 -5.314831869925678\n",
      "-5.329999923706055 -1.4104659962098411\n",
      "-1.4430335760116577 -4.294350483497931\n",
      "0.30318090319633484 -0.6753071160753361\n",
      "-1.2609531879425049 -3.5212731718995354\n",
      "-0.9998986721038818 -3.3474900970742913\n",
      "0.4852609932422638 -1.409212898530658\n",
      "-2.700044631958008 -4.925765299449872\n",
      "-0.9472490549087524 -5.501279803563877\n",
      "0.10295850783586502 -2.651802707019073\n",
      "0.2686734199523926 -2.6517997182778608\n",
      "0.18033164739608765 -2.65180216361158\n",
      "0.20885014533996582 -2.65180216361158\n",
      "0.09190212935209274 -2.432948056193977\n",
      "-9.670000076293945 -9.652580400868349\n",
      "-1.1775914430618286 -3.0370259091292495\n",
      "-1.1666226387023926 -3.0370234637955305\n",
      "-1.3092155456542969 -4.782229066841132\n",
      "-2.6824944019317627 -3.2358064078983486\n",
      "-0.03904200345277786 1.7003737174035978\n",
      "0.3602180480957031 0.951584818822381\n",
      "0.3667992651462555 0.951584818822381\n",
      "0.4633236527442932 0.951584818822381\n",
      "0.178137868642807 0.3488671148424407\n",
      "0.8362588882446289 -1.5575492872670922\n",
      "0.3624117970466614 -0.9693386614277921\n",
      "0.3602180480957031 -0.7404508063530857\n",
      "-4.942500114440918 -4.9155120830914765\n",
      "-2.0046298503875732 -2.9572240734277657\n",
      "-5.619999885559082 -0.5450708158241904\n",
      "-0.014910978265106678 -3.4756213725488814\n",
      "0.07283850759267807 -3.0140077111272876\n",
      "-1.0349984169006348 -3.1393117732669378\n",
      "-0.9998986721038818 -3.139309871340712\n",
      "-4.900000095367432 -4.496537467989658\n",
      "-1.1315228939056396 -4.143691299432065\n",
      "-1.526395320892334 -3.2224785240178244\n",
      "-1.528589129447937 -3.2232680951053583\n",
      "-0.26938438415527344 2.2727116820719937\n",
      "-1.6295009851455688 -5.402635533797022\n",
      "-4.880000114440918 1.1561788268049762\n",
      "-0.01929844729602337 -1.4985341466969868\n",
      "-1.3421217203140259 -2.708866199577562\n",
      "-10.520000457763672 -3.349309017805708\n",
      "-1.0393860340118408 -3.3493075234351015\n",
      "0.41067400574684143 -2.9709671206330497\n",
      "-4.010000228881836 -3.7324005681721655\n",
      "-1.4232898950576782 -3.249307367065438\n",
      "0.3360869288444519 -2.7027409103148763\n",
      "-3.147566556930542 -4.665825476031639\n",
      "-11.600000381469727 -9.530726161198906\n",
      "-0.5808950066566467 -2.1292267401275757\n",
      "-0.4536583125591278 -2.3939784029346054\n",
      "-1.155653953552246 -2.832051244197709\n",
      "0.3733804523944855 1.0995182709026512\n",
      "-18.0 -6.291110554972137\n",
      "-0.9977048635482788 1.4699194902299126\n",
      "-1.4079335927963257 -3.3026972891184205\n",
      "-1.3443152904510498 -3.2160057256632744\n",
      "-1.1468790769577026 -2.6635405805746664\n",
      "0.11890698224306107 -2.4946886570459315\n",
      "-0.054047245532274246 -2.5298321781460964\n",
      "0.059094805270433426 -2.440100657322446\n",
      "-0.056591883301734924 -4.024306439263327\n",
      "-3.7799999713897705 -2.946660775168597\n",
      "-1.6646008491516113 -2.852705347900761\n",
      "-15.630000114440918 -3.830436714009744\n",
      "-12.289999961853027 -12.311320023894488\n",
      "-15.539999961853027 -3.8304369857134906\n",
      "-2.197678804397583 -3.830436714009744\n",
      "-1.4605834484100342 -3.2832529463469737\n",
      "-4.110000133514404 -2.6391573429499338\n",
      "0.272468626499176 -3.0752448449368464\n",
      "-1.9212678670883179 -3.023055989295579\n",
      "-0.49533921480178833 -2.155555104874007\n",
      "-11.15999984741211 -2.818661411862967\n",
      "-11.489999771118164 -11.399145881165536\n",
      "-0.1266818642616272 -3.04653934411167\n",
      "0.564235508441925 -1.3359322244506133\n",
      "0.23956254124641418 -2.0262735715883102\n",
      "0.7836092114448547 0.04393780391878721\n",
      "-2.994004964828491 -5.482631841455113\n",
      "-5.378200054168701 -5.318468624573525\n",
      "-5.267399787902832 -2.574298669902336\n",
      "0.0468427836894989 -2.5742978547910966\n",
      "0.07011834532022476 -2.5742989416060826\n",
      "0.025475746020674706 -2.2663213863496545\n",
      "-5.769999980926514 -4.053958284237808\n",
      "-1.3421217203140259 -3.292933479133535\n",
      "-11.789999961853027 -11.776992869963816\n",
      "-1.3421217203140259 -2.8741454905426416\n",
      "-1.3750276565551758 -4.111388576854168\n",
      "-1.3179904222488403 -4.111387490039181\n",
      "-1.4452271461486816 -4.111679979122365\n",
      "-11.9399995803833 -3.4880829290334656\n",
      "-1.3552839756011963 -3.4880808912553665\n",
      "-1.4583896398544312 -3.488626608230353\n",
      "-1.5878201723098755 -3.612638175647567\n",
      "-2.4126648902893066 -5.2963391525451105\n",
      "-2.2349722385406494 -3.8154537467569853\n",
      "-3.4503021240234375 -9.70828673321272\n",
      "-15.949999809265137 -4.000979314101514\n",
      "-2.3622090816497803 -3.9396517029443467\n",
      "-4.391415596008301 -5.911893703809586\n",
      "-1.9300428628921509 -6.873095089458774\n",
      "-10.979999542236328 -11.269546997903845\n",
      "-1.2434033155441284 -2.9229429400192153\n",
      "0.41067400574684143 -1.218329061600012\n",
      "-1.5549139976501465 -4.4144898649708955\n",
      "-1.6602134704589844 -4.379014050188674\n",
      "-2.3446590900421143 -5.79914425668772\n",
      "-0.9779612421989441 -2.7250958794714597\n",
      "0.2242063581943512 -2.1910727620332\n",
      "-1.5856263637542725 -2.7293037553945974\n",
      "-1.6360821723937988 -2.7293042988020906\n",
      "-1.598788857460022 -2.7290880226198206\n",
      "-1.7391878366470337 -2.730260695990019\n",
      "-1.9124929904937744 -3.0151939696848142\n",
      "-5.070000171661377 -2.727764825374022\n",
      "-1.0503547191619873 -3.283558884765612\n",
      "-2.0594732761383057 -4.384916406527299\n",
      "-1.2390159368515015 -3.3231124293763634\n",
      "-1.2894718647003174 -3.3231189502662812\n",
      "-1.5176204442977905 -3.0971784015824992\n",
      "1.2289376258850098 -1.0799286071719152\n",
      "-0.89240562915802 1.804637856520066\n",
      "-2.719787836074829 -0.19589998384645746\n",
      "-2.066054582595825 -3.0177737967585014\n",
      "-1.6624071598052979 -3.4438829786526113\n",
      "-1.5834325551986694 -3.443880805022639\n",
      "-12.729999542236328 -3.444567264538349\n",
      "-1.6141449213027954 -5.559083688831771\n",
      "-1.3355402946472168 -5.559122899078698\n",
      "0.3777679204940796 -0.21627993846921978\n",
      "-13.489999771118164 -13.335599675865936\n",
      "-1.4715518951416016 -2.7566504657831747\n",
      "2.270962715148926 3.2906801994181007\n",
      "-1.2938593626022339 -4.668161584844652\n",
      "0.12882263958454132 -2.3950665764396204\n",
      "-4.019999980926514 -2.3059529099356717\n",
      "-0.03684832155704498 -2.2578537390877838\n",
      "-3.9043500423431396 -2.093543343682975\n",
      "0.4238364100456238 -2.093530030199393\n",
      "0.34486186504364014 -2.093512912863359\n",
      "-0.6072198152542114 2.843234122305806\n",
      "-12.970000267028809 -12.887308600101807\n",
      "-12.029999732971191 -11.995538865332808\n",
      "-1.9958549737930298 -4.464167498734485\n",
      "-1.526395320892334 -3.3262230297189763\n",
      "-11.75 -11.717419106490762\n",
      "-15.420000076293945 -14.978102621226608\n",
      "0.05528862774372101 -2.567602802771852\n",
      "-1.7413816452026367 2.025999246111022\n",
      "-19.579999923706055 -16.860678106389564\n",
      "-2.9457428455352783 -8.372625349744062\n",
      "-1.8093873262405396 -5.540345491361548\n",
      "-2.2656846046447754 -5.60258524171355\n",
      "-1.844487190246582 -5.560945818949635\n",
      "-2.855799674987793 -5.832764912251326\n",
      "0.32731199264526367 -2.50267158482392\n",
      "-2.6517820358276367 -5.56980962725549\n",
      "-2.3380777835845947 -2.9694588931358368\n",
      "0.2512185275554657 -2.441454557091607\n",
      "-3.8494250774383545 -2.441454013684114\n",
      "0.23897016048431396 -2.1857840486062043\n",
      "-4.0 -2.4431388486165977\n",
      "0.12987570464611053 -2.927614070830256\n",
      "0.21104393899440765 -2.185760138676506\n",
      "-10.739999771118164 -3.167316550129709\n",
      "-1.228047251701355 -3.1673217125008937\n",
      "0.3711867332458496 0.22777690610835322\n",
      "-1.186366319656372 -3.005059148233987\n",
      "-1.199528694152832 -4.615441004971346\n",
      "0.3777679204940796 -1.208780033426791\n",
      "-1.4693583250045776 -3.161569472482249\n",
      "-1.7172505855560303 -6.14573274833211\n",
      "-9.65999984741211 -11.691985462181787\n",
      "0.43041759729385376 -1.2096611686769192\n",
      "-11.789999961853027 -5.2502825485750355\n",
      "-1.3728338479995728 -5.25184172052473\n",
      "0.6600000262260437 0.13375491142260731\n",
      "0.3755742013454437 -2.5537404776218238\n",
      "-3.7200000286102295 -3.9193805656720864\n",
      "0.34924933314323425 -2.553741021029317\n",
      "-3.9700000286102295 -3.919372278707816\n",
      "0.30976206064224243 -2.553744009770529\n",
      "0.39093032479286194 -2.5537415644368098\n",
      "-4.010000228881836 -3.9193726862634355\n",
      "-3.9600000381469727 -3.9193736372265486\n",
      "0.272468626499176 -2.553744009770529\n",
      "0.14303810894489288 -3.9099793443369992\n",
      "0.11232583224773407 -2.5453119556994594\n",
      "-0.9187304377555847 -3.2179503093774797\n",
      "-0.8441433906555176 -4.078868355427142\n",
      "-1.0328046083450317 -3.0284802828921134\n",
      "-10.329999923706055 -10.440996747479385\n",
      "-1.5154268741607666 -3.1862317498547092\n",
      "-1.4693583250045776 -3.1862306630397232\n",
      "-12.34000015258789 -12.25356015463354\n",
      "-6.960000038146973 -6.949491390400743\n",
      "-0.306677907705307 2.176523665118588\n",
      "-13.539999961853027 -13.44175052579859\n",
      "-1.8971368074417114 -3.2499795621344534\n",
      "-0.33519652485847473 -2.2903245104329346\n",
      "-0.3286152482032776 -2.290090301803391\n",
      "-0.49314552545547485 -2.2913686679310055\n",
      "0.11232583224773407 -1.4571667078741308\n",
      "0.23517507314682007 -0.8718934712390043\n",
      "0.17594417929649353 -3.0424572670231944\n",
      "-1.526395320892334 -3.1562606529780073\n",
      "0.41506147384643555 -2.493223630444423\n",
      "0.35363683104515076 -2.493226075778142\n",
      "0.3163433074951172 -2.493225532370649\n",
      "-4.159999847412109 -2.4932263474818885\n",
      "0.36789608001708984 -2.4782503086746677\n",
      "-1.0306110382080078 -3.1316519012436212\n",
      "-0.537020206451416 -3.3508673746441633\n",
      "-9.899999618530273 -4.148882335362169\n",
      "-1.6755695343017578 -3.460354339029083\n",
      "-3.130000114440918 -2.7592411610067247\n",
      "0.4545486569404602 -2.372475225023521\n",
      "-1.4167085886001587 -3.2127053402536823\n",
      "0.46771112084388733 -2.488564182894485\n",
      "-2.180128812789917 -3.641997123983246\n",
      "-0.21892844140529633 1.8973513259623278\n",
      "-3.309903144836426 -5.043301147697261\n",
      "-0.591863751411438 -2.093101825094798\n",
      "-0.3878461420536041 -2.3372841557677058\n",
      "-7.079999923706055 -6.94769950419211\n",
      "-5.929999828338623 -1.3535475934520207\n",
      "-1.6580196619033813 -5.088286933239134\n",
      "-13.149999618530273 -12.775687266935702\n",
      "-2.0090174674987793 -5.760610178497069\n",
      "-1.9848862886428833 -5.760604693477686\n",
      "-2.2261972427368164 -7.180452480913655\n",
      "-2.0002424716949463 -5.721110567080013\n",
      "-1.859843373298645 -5.415934786895251\n",
      "-1.0196423530578613 -3.3425503871097657\n",
      "-1.0525482892990112 -3.3425503871097657\n",
      "-4.269999980926514 -3.617057029529917\n",
      "-13.15999984741211 -13.15197848008112\n",
      "-13.0600004196167 -13.268362779924605\n",
      "-1.462777018547058 -3.264181516967695\n",
      "-1.522007942199707 -3.424938842478601\n",
      "0.4282238781452179 -2.3877965992926327\n",
      "0.41506147384643555 -2.893026455595574\n",
      "0.00044521642848849297 0.5719744727088587\n",
      "0.02650684304535389 -3.303663331789352\n",
      "0.39531779289245605 -1.786009752348443\n",
      "-9.25 -10.123985314353233\n",
      "-1.4035462141036987 -3.6545884190068176\n",
      "-2.127479314804077 -5.436672116852174\n",
      "0.3931240737438202 -1.193374974403735\n",
      "0.20011913776397705 -2.501422290997189\n",
      "-1.3136030435562134 -3.630318481844405\n",
      "-1.3223780393600464 -3.2386628293860444\n",
      "-1.3706400394439697 -3.2395219566327005\n",
      "-11.779999732971191 -2.8443325252464433\n",
      "-1.4079335927963257 -4.139248807323764\n",
      "-11.760000228881836 -3.4563350255060654\n",
      "-0.7607813477516174 -3.471663192368842\n",
      "-1.5878201723098755 -3.3135525330532793\n",
      "-1.568076491355896 -3.3135525330532793\n",
      "-1.565882682800293 -3.3135525330532793\n",
      "-0.738844096660614 -4.114546861204304\n"
     ]
    }
   ],
   "source": [
    "for i in range(1000):\n",
    "    print(y_true[i],y_pred[i])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "solvent split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "del dataset\n",
    "dataset = pickle_load(\"/home/1739678401/2024.9dataclean/MMGNN_0901/result/transfer/dataset.pkl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "possible_solvents = ['hexane', 'water', 'acetone', 'ethanol', 'benzene', 'ethylacetate',\n",
    "               'dichloromethane', 'acetonitrile', 'thf', 'dmso', 'dmf', 'octanol', 'hexadecane', 'cyclohexane']\n",
    "\n",
    "p_s= 'cyclohexane'\n",
    "args.solvent_split=p_s\n",
    "trainset, valset, testset = solvent_split(\n",
    "    dataset, args.solvent_split, random_seed=args.random_seed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Scale training dataset features\n",
    "if args.feature_scaling:\n",
    "    solute_features_scaler,solvent_features_scaler= trainset.normalize_features()\n",
    "    #solute_features_scaler, solvent_features_scaler = trainset.normalize_features()\n",
    "    valset.normalize_features(solute_features_scaler, solvent_features_scaler)\n",
    "    testset.normalize_features(solute_features_scaler, solvent_features_scaler)\n",
    "    #testset.normalize_features(solute_features_scaler)\n",
    "else:\n",
    "    solute_features_scaler, solvent_features_scaler = None, None\n",
    "\n",
    "label_scaler = trainset.normalize_labels()\n",
    "if not args.distributed or (args.distributed and args.gpu == 0):\n",
    "    torch.save(dataset.state_dict(), os.path.join(args.save_dir, args.dataset_state_dict_filename))\n",
    "    print(\n",
    "        \"Trainset size: {}, valset size: {}: testset size: {}.\".format(\n",
    "            len(trainset), len(valset), len(testset)\n",
    "        )\n",
    "    )\n",
    "bs = max(len(valset) // 10, 1)\n",
    "val_loader = DataLoaderSolvation(valset, batch_size=bs, shuffle=False)\n",
    "bs = max(len(testset) //10, 1)\n",
    "test_loader = DataLoaderSolvation(testset, batch_size=bs, shuffle=False)\n",
    "### model\n",
    "feature_names = [\"atom\", \"bond\", \"global\"]\n",
    "solute_feature_names = [\"atom\", \"bond\",\"atom2\", \"bond2\", \"global\"]\n",
    "set2set_ntypes_direct = [\"global\"]\n",
    "solute_feature_size = dataset.feature_sizes[0]\n",
    "# solute_feature_size ={'bond': 11,'atom': 28,'atom2': 28, 'bond2': 11, 'global': 3}\n",
    "solute_feature_size = {'bond': 11, 'atom': 30, 'atom2': 30, 'bond2': 11, 'global': 3}\n",
    "\n",
    "solvent_feature_size = dataset.feature_sizes[1]\n",
    "args.solute_feature_size = solute_feature_size\n",
    "args.solvent_feature_size = solvent_feature_size\n",
    "args.set2set_ntypes_direct = set2set_ntypes_direct\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = GatedGCNSolvationNetwork(\n",
    "        solute_in_feats=args.solute_feature_size,\n",
    "        solvent_in_feats=args.solvent_feature_size,\n",
    "        embedding_size=args.embedding_size,\n",
    "        gated_num_layers=args.gated_num_layers,\n",
    "        gated_hidden_size=args.gated_hidden_size,\n",
    "        gated_num_fc_layers=args.gated_num_fc_layers,\n",
    "        gated_graph_norm=args.gated_graph_norm,\n",
    "        gated_batch_norm=args.gated_batch_norm,\n",
    "        gated_activation=args.gated_activation,\n",
    "        gated_residual=args.gated_residual,\n",
    "        gated_dropout=args.gated_dropout,\n",
    "        num_lstm_iters=args.num_lstm_iters,\n",
    "        num_lstm_layers=args.num_lstm_layers,\n",
    "        set2set_ntypes_direct=args.set2set_ntypes_direct,\n",
    "        fc_num_layers=args.fc_num_layers,\n",
    "        fc_hidden_size=args.fc_hidden_size,\n",
    "        fc_batch_norm=args.fc_batch_norm,\n",
    "        fc_activation=args.fc_activation,\n",
    "        fc_dropout=args.fc_dropout,\n",
    "        outdim=1,\n",
    "        conv=\"GatedGCNConv\",\n",
    "    )\n",
    "optimizer = torch.optim.Adam(\n",
    "    model.parameters(), lr=args.lr, weight_decay=args.weight_decay\n",
    ")\n",
    "loss_func = MSELoss(reduction=\"mean\")\n",
    "metric = L1Loss(reduction=\"sum\")\n",
    "\n",
    "scheduler = ReduceLROnPlateau(\n",
    "    optimizer, mode=\"min\", factor=0.4, patience=50, verbose=True\n",
    ")\n",
    "stopper = EarlyStopping(patience=150)\n",
    "\n",
    "state_dict_objs = {\"model\": model, \"optimizer\": optimizer, \"scheduler\": scheduler}\n",
    "model.to(args.gpu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.save_dir=\"/home/1739678401/2024.9dataclean/MMGNN_0901/result/exp\"\n",
    "loc = \"cuda:{}\".format(args.gpu)\n",
    "checkpoint = load_checkpoints(\n",
    "        state_dict_objs, map_location=loc, save_dir=args.save_dir, filename=\"best_checkpoint.pkl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_acc = evaluate(model, feature_names,solute_feature_names, test_loader, metric, label_scaler, args.gpu)\n",
    "y_true, y_pred = evaluate(model, feature_names,solute_feature_names, test_loader, metric, \n",
    "                                label_scaler, args.gpu, return_preds=True)\n",
    "\n",
    "print(p_s)\n",
    "print(len(y_pred))\n",
    "print(\"\\n#Test MAE: {:12.6e} \\n\".format(test_acc))\n",
    "print(\"\\n#Test RMSE: {:12.6e} \\n\".format(mean_squared_error(y_true, y_pred, squared=False)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(y_pred)\n",
    "print(testset.indices)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "\n",
    "# 假设这些变量已经定义好\n",
    "csv_path = '/home/1739678401/2024.9dataclean/MMGNN_0901/data/exp_data.csv'\n",
    "output_filename = f'{args.solvent_split}.csv'  # 输出文件名\n",
    "indices = testset.indices     # 你的编号列表（如 [626, 102, 54] 等）\n",
    "predictions = y_pred  # 与编号列表对应的预测结果\n",
    "\n",
    "# 读取CSV文件\n",
    "df = pd.read_csv(csv_path)\n",
    "\n",
    "\n",
    "rows = []\n",
    "for idx, pred in zip(indices, predictions):\n",
    "    true_idx = idx \n",
    "    row = df.iloc[true_idx]\n",
    "    rows.append([\n",
    "        row.iloc[0],  # 第一列\n",
    "        row.iloc[1],  # 第二列\n",
    "        row.iloc[4],  # 第五列（索引从0开始）\n",
    "        pred          # 预测值\n",
    "    ])\n",
    "\n",
    "# 创建新的DataFrame\n",
    "output_df = pd.DataFrame(rows, columns=['smiles1', 'smiles2', 'd', 'Prediction'])\n",
    "\n",
    "# 保存为CSV\n",
    "output_df.to_csv(output_filename, index=False)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "from rdkit import Chem\n",
    "from rdkit.Chem import Descriptors\n",
    "import os\n",
    "\n",
    "# 定义可能的溶剂文件名（假设文件后缀为.csv）\n",
    "possible_solvents = [\n",
    "    'hexane', 'water', 'acetone', 'ethanol', 'benzene', 'ethylacetate',\n",
    "    'dichloromethane', 'acetonitrile', 'thf', 'dmso', 'dmf',\n",
    "    'octanol', 'hexadecane', 'cyclohexane'\n",
    "]\n",
    "\n",
    "# 遍历所有csv文件\n",
    "for solvent in possible_solvents:\n",
    "    filename = f\"{solvent}.csv\"\n",
    "    if os.path.exists(filename):\n",
    "        df = pd.read_csv(filename)\n",
    "        if 'smiles2' not in df.columns:\n",
    "            print(f\"File {filename} does not contain 'smiles2' column. Skipping.\")\n",
    "            continue\n",
    "\n",
    "        # 计算分子量\n",
    "        def compute_mol_weight(smiles):\n",
    "            mol = Chem.MolFromSmiles(smiles)\n",
    "            if mol:\n",
    "                return Descriptors.MolWt(mol)\n",
    "            else:\n",
    "                return None\n",
    "\n",
    "        df['MolecularWeight'] = df['smiles2'].apply(compute_mol_weight)\n",
    "\n",
    "        # 保存文件（覆盖原文件）\n",
    "        df.to_csv(filename, index=False)\n",
    "        print(f\"Updated file: {filename}\")\n",
    "    else:\n",
    "        print(f\"File {filename} not found.\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from rdkit import Chem\n",
    "from rdkit.Chem import Descriptors\n",
    "\n",
    "# 创建分子对象\n",
    "mol = Chem.MolFromSmiles('CCO')\n",
    "\n",
    "# 计算相对分子质量\n",
    "mol_weight = Descriptors.MolWt(mol)\n",
    "\n",
    "print(f\"CCO 的相对分子质量是: {mol_weight:.4f}\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "element split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "del dataset\n",
    "dataset = pickle_load(\"/home/1739678401/2024.9dataclean/MMGNN_0901/result/transfer/dataset.pkl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "possible_elems = ['Br', 'Cl', 'F', 'I', 'N', 'O', 'S']\n",
    "p_e='S'\n",
    "args.element_split=p_e\n",
    "trainset, valset, testset = element_split(dataset, args.element_split, random_seed=args.random_seed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Scale training dataset features\n",
    "if args.feature_scaling:\n",
    "    solute_features_scaler,solvent_features_scaler= trainset.normalize_features()\n",
    "    #solute_features_scaler, solvent_features_scaler = trainset.normalize_features()\n",
    "    valset.normalize_features(solute_features_scaler, solvent_features_scaler)\n",
    "    testset.normalize_features(solute_features_scaler, solvent_features_scaler)\n",
    "    #testset.normalize_features(solute_features_scaler)\n",
    "else:\n",
    "    solute_features_scaler, solvent_features_scaler = None, None\n",
    "\n",
    "label_scaler = trainset.normalize_labels()\n",
    "if not args.distributed or (args.distributed and args.gpu == 0):\n",
    "    torch.save(dataset.state_dict(), os.path.join(args.save_dir, args.dataset_state_dict_filename))\n",
    "    print(\n",
    "        \"Trainset size: {}, valset size: {}: testset size: {}.\".format(\n",
    "            len(trainset), len(valset), len(testset)\n",
    "        )\n",
    "    )\n",
    "bs = max(len(valset) // 10, 1)\n",
    "val_loader = DataLoaderSolvation(valset, batch_size=bs, shuffle=False)\n",
    "bs = max(len(testset) //10, 1)\n",
    "test_loader = DataLoaderSolvation(testset, batch_size=bs, shuffle=False)\n",
    "### model\n",
    "feature_names = [\"atom\", \"bond\", \"global\"]\n",
    "solute_feature_names = [\"atom\", \"bond\",\"atom2\", \"bond2\", \"global\"]\n",
    "set2set_ntypes_direct = [\"global\"]\n",
    "solute_feature_size = dataset.feature_sizes[0]\n",
    "# solute_feature_size ={'bond': 11,'atom': 28,'atom2': 28, 'bond2': 11, 'global': 3}\n",
    "solute_feature_size = {'bond': 11, 'atom': 30, 'atom2': 30, 'bond2': 11, 'global': 3}\n",
    "\n",
    "solvent_feature_size = dataset.feature_sizes[1]\n",
    "args.solute_feature_size = solute_feature_size\n",
    "args.solvent_feature_size = solvent_feature_size\n",
    "args.set2set_ntypes_direct = set2set_ntypes_direct\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = GatedGCNSolvationNetwork(\n",
    "        solute_in_feats=args.solute_feature_size,\n",
    "        solvent_in_feats=args.solvent_feature_size,\n",
    "        embedding_size=args.embedding_size,\n",
    "        gated_num_layers=args.gated_num_layers,\n",
    "        gated_hidden_size=args.gated_hidden_size,\n",
    "        gated_num_fc_layers=args.gated_num_fc_layers,\n",
    "        gated_graph_norm=args.gated_graph_norm,\n",
    "        gated_batch_norm=args.gated_batch_norm,\n",
    "        gated_activation=args.gated_activation,\n",
    "        gated_residual=args.gated_residual,\n",
    "        gated_dropout=args.gated_dropout,\n",
    "        num_lstm_iters=args.num_lstm_iters,\n",
    "        num_lstm_layers=args.num_lstm_layers,\n",
    "        set2set_ntypes_direct=args.set2set_ntypes_direct,\n",
    "        fc_num_layers=args.fc_num_layers,\n",
    "        fc_hidden_size=args.fc_hidden_size,\n",
    "        fc_batch_norm=args.fc_batch_norm,\n",
    "        fc_activation=args.fc_activation,\n",
    "        fc_dropout=args.fc_dropout,\n",
    "        outdim=1,\n",
    "        conv=\"GatedGCNConv\",\n",
    "    )\n",
    "optimizer = torch.optim.Adam(\n",
    "    model.parameters(), lr=args.lr, weight_decay=args.weight_decay\n",
    ")\n",
    "loss_func = MSELoss(reduction=\"mean\")\n",
    "metric = L1Loss(reduction=\"sum\")\n",
    "\n",
    "scheduler = ReduceLROnPlateau(\n",
    "    optimizer, mode=\"min\", factor=0.4, patience=50, verbose=True\n",
    ")\n",
    "stopper = EarlyStopping(patience=150)\n",
    "\n",
    "state_dict_objs = {\"model\": model, \"optimizer\": optimizer, \"scheduler\": scheduler}\n",
    "model.to(args.gpu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.save_dir=\"/home/1739678401/2024.9dataclean/MMGNN_0901/result/exp\"\n",
    "loc = \"cuda:{}\".format(args.gpu)\n",
    "checkpoint = load_checkpoints(\n",
    "        state_dict_objs, map_location=loc, save_dir=args.save_dir, filename=\"best_checkpoint.pkl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_acc = evaluate(model, feature_names,solute_feature_names, test_loader, metric, label_scaler, args.gpu)\n",
    "y_true, y_pred = evaluate(model, feature_names,solute_feature_names, test_loader, metric, \n",
    "                                label_scaler, args.gpu, return_preds=True)\n",
    "\n",
    "print(p_e)\n",
    "print(len(y_true))\n",
    "print(\"\\n#Test MAE: {:12.6e} \\n\".format(test_acc))\n",
    "print(\"\\n#Test RMSE: {:12.6e} \\n\".format(mean_squared_error(y_true, y_pred, squared=False)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.save_dir=\"/home/1739678401/2024.9dataclean/MMGNN_0901/result/theory\"\n",
    "loc = \"cuda:{}\".format(args.gpu)\n",
    "checkpoint = load_checkpoints(\n",
    "        state_dict_objs, map_location=loc, save_dir=args.save_dir, filename=\"best_checkpoint.pkl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_acc = evaluate(model, feature_names,solute_feature_names, test_loader, metric, label_scaler, args.gpu)\n",
    "y_true, y_pred = evaluate(model, feature_names,solute_feature_names, test_loader, metric, \n",
    "                                label_scaler, args.gpu, return_preds=True)\n",
    "\n",
    "print(p_e)\n",
    "print(len(y_true))\n",
    "print(\"\\n#Test MAE: {:12.6e} \\n\".format(test_acc))\n",
    "print(\"\\n#Test RMSE: {:12.6e} \\n\".format(mean_squared_error(y_true, y_pred, squared=False)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.save_dir=\"/home/1739678401/2024.9dataclean/MMGNN_0901/result/transfer\"\n",
    "loc = \"cuda:{}\".format(args.gpu)\n",
    "checkpoint = load_checkpoints(\n",
    "        state_dict_objs, map_location=loc, save_dir=args.save_dir, filename=\"best_checkpoint.pkl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_acc = evaluate(model, feature_names,solute_feature_names, test_loader, metric, label_scaler, args.gpu)\n",
    "y_true, y_pred = evaluate(model, feature_names,solute_feature_names, test_loader, metric, \n",
    "                                label_scaler, args.gpu, return_preds=True)\n",
    "\n",
    "print(p_e)\n",
    "print(len(y_true))\n",
    "print(\"\\n#Test MAE: {:12.6e} \\n\".format(test_acc))\n",
    "print(\"\\n#Test RMSE: {:12.6e} \\n\".format(mean_squared_error(y_true, y_pred, squared=False)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "cgib3",
   "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.7.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
