{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 🥇 Main Experiments 🥈🥉\n",
    "\n",
    "🕶️ **To evaluate the frequency estimation performance, we compare our UCL-sketch with seven baselines on four datasets.**\n",
    "\n",
    "- **Baselines** : `CM-sketch`, `C-sketch`, `Elastic Sketch`, `UnivMon`, `Nitrosketch`, `Learned CM-sketch`, and `Learned C-sketch`.\n",
    "\n",
    "- **Datasets** : *CAIDA*, *Retail*, *Kosarak*, and *Zipfian*\n",
    "\n",
    "- **Metrics** : *Average Relative Error (ARE)*, *Weighted Mean Relative Difference (WMRD)*, and *Entropy Relative Error*"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 🚄  Step 1 - Import necessary packets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import random\n",
    "import argparse\n",
    "import numpy as np\n",
    "\n",
    "from tqdm.auto import tqdm\n",
    "from load_data import readTraces\n",
    "from Sketching.unimon import UnivMon\n",
    "from Sketching.cs_sketch import Csketch\n",
    "from Sketching.cm_sketch import CMsketch\n",
    "from Utils.training import learningSolver\n",
    "from UCL_Sketch.ucl_sketch import UCLSketch\n",
    "from Sketching.nitro_sketch import NitroSketch\n",
    "from Sketching.elastic_sketch import ElasticSketch"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 🔨 Step 2 - Configure your parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "parser = argparse.ArgumentParser(description='Main Experiment')\n",
    "\n",
    "parser.add_argument('--data', type=str, default='caida', help='data',\n",
    "                     choices=['retail', 'kosarak', 'caida', 'synthetic'])\n",
    "parser.add_argument('--root_path', type=str, default='./Source_Data/', help='root path of the data file')\n",
    "parser.add_argument('--data_path', type=str, default='test-8s.dat', help='data file',\n",
    "                    choices=['retail.dat', 'kosarak.dat', 'test-8s.dat', ''])\n",
    "parser.add_argument('--seed', type=int, default=12345, help='random seed')\n",
    "\n",
    "parser.add_argument('--slot_num', type=int, default=500, help='Number of slots in the hash table')\n",
    "parser.add_argument('--bf_width', type=int, default=1000000, help='Length of the Bloom Filter')\n",
    "parser.add_argument('--bf_hash', type=int, default=8, help='Number of used hash functions of the Bloom Filter')\n",
    "parser.add_argument('--key_size', type=int, default=13, help='KEY_T_SIZE')\n",
    "parser.add_argument('--hash_num', type=int, default=4, help='Number of used hash functions of the Sketch')\n",
    "parser.add_argument('--bucket_dim', type=int, default=512, help='Number of dimensions of each hash vector in the Sketch')\n",
    "parser.add_argument('--d_model', type=int, default=128, help='dimension of hidden states (d_model)')\n",
    "parser.add_argument('--break_number', type=int, default=1000000, help='number of stream data')\n",
    "parser.add_argument('--e_layers', type=int, default=0, help='Number of middle layers')\n",
    "parser.add_argument('--dropout', type=float, default=0., help='dropout')\n",
    "parser.add_argument('--d_share', type=int, default=1024, help='length of the logical bucket')\n",
    "parser.add_argument('--checkpoints', type=str, default='./checkpoints', help='location to store model checkpoints')\n",
    "\n",
    "parser.add_argument('--num_workers', type=int, default=0, help='data loader num workers')\n",
    "parser.add_argument('--batch_size', type=int, default=32, help='batch size of train input data')\n",
    "parser.add_argument('--train_epochs', type=int, default=300, help='train epochs')\n",
    "parser.add_argument('--patience', type=int, default=30, help='early stopping patience')\n",
    "parser.add_argument('--learning_rate', type=float, default=1e-3, help='optimizer initial learning rate')\n",
    "parser.add_argument('--lradj', type=str, default='type1',help='adjust learning rate')\n",
    "\n",
    "parser.add_argument('--save_pred', action='store_true', help='whether to save the estimated frequency', default=False)\n",
    "parser.add_argument('--use_gpu', type=bool, default=True, help='use gpu')\n",
    "parser.add_argument('--gpu', type=int, default=0, help='gpu')\n",
    "parser.add_argument('--use_multi_gpu', action='store_true', help='use multiple gpus', default=False)\n",
    "parser.add_argument('--devices', type=str, default='0,1,2,3',help='device ids of multile gpus')\n",
    "\n",
    "parser.add_argument('--interval', type=int, default=1000, help='sampling inserval')\n",
    "parser.add_argument('--num_samples', type=int, default=128, help='maintained samples (sliding window)')\n",
    "parser.add_argument('--ablation', type=int, default=0, help='ablational type')\n",
    "\n",
    "args = parser.parse_known_args()[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Global seed set to 12345\n"
     ]
    }
   ],
   "source": [
    "args.use_gpu = True if torch.cuda.is_available() and args.use_gpu else False\n",
    "\n",
    "if args.use_gpu and args.use_multi_gpu:\n",
    "    args.devices = args.devices.replace(' ','')\n",
    "    device_ids = args.devices.split(',')\n",
    "    args.device_ids = [int(id_) for id_ in device_ids]\n",
    "    args.gpu = args.device_ids[0]\n",
    "    print(args.gpu)\n",
    "\n",
    "print(f\"Global seed set to {args.seed}\")\n",
    "random.seed(args.seed)\n",
    "np.random.seed(args.seed)\n",
    "torch.manual_seed(args.seed)\n",
    "torch.cuda.manual_seed_all(args.seed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "----- Memory Usage -----\n",
      "Hash Table Size(Byte): 8048 (7.86 KB)\n",
      "CM Sketch Size(Byte): 8336 (8.14 KB)\n",
      "Total Memory(MB): 16.00 KB\n",
      "------------------------\n"
     ]
    }
   ],
   "source": [
    "ucl_sketch = UCLSketch(args.slot_num, args.bucket_dim, args.hash_num, args.bf_width, args.bf_hash, args.key_size)\n",
    "memory = ucl_sketch.get_memory_usage() // (1024)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CM-Sketch size: 16.11 KB\n",
      "C-Sketch size: 16.11 KB\n",
      "Nitro-Sketch size: 16.14 KB\n",
      "Elastic Sketch size: 16.44 KB\n",
      "UnivMon size: 24.25 KB\n"
     ]
    }
   ],
   "source": [
    "c_sketch = Csketch(args.bucket_dim*2, 4, args.key_size)\n",
    "lc_sketch = Csketch(args.bucket_dim, 4, args.key_size)\n",
    "cm_sketch = CMsketch(args.bucket_dim*2, 4, args.key_size)\n",
    "lcm_sketch = CMsketch(args.bucket_dim, 4, args.key_size)\n",
    "nitro_sketch = NitroSketch(args.bucket_dim*2, 4, args.key_size)\n",
    "elastic_sketch = ElasticSketch(args.slot_num//16, args.slot_num//30, args.bucket_dim, 4, args.key_size)\n",
    "univmon = UnivMon(2, args.bucket_dim*2, 4, args.key_size)\n",
    "\n",
    "print(f'CM-Sketch size: {(c_sketch.get_memory_usage() / (1024)):.2f} KB')\n",
    "print(f'C-Sketch size: {(cm_sketch.get_memory_usage() / (1024)):.2f} KB')\n",
    "print(f'Nitro-Sketch size: {(nitro_sketch.get_memory_usage() / (1024)):.2f} KB')\n",
    "print(f'Elastic Sketch size: {(elastic_sketch.get_memory_usage() / (1024)):.2f} KB')\n",
    "print(f'UnivMon size: {(univmon.get_memory_usage() / (1024)):.2f} KB')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## ⏩ Step 3 - Insert data stream"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Reading in packets data...\n",
      "Successfully read in 3670738 items.\n"
     ]
    }
   ],
   "source": [
    "path = args.root_path + args.data_path\n",
    "size, traces = readTraces(path, args.data, args.key_size)\n",
    "\n",
    "if size > args.break_number:\n",
    "    traces = traces[:args.break_number]\n",
    "    size = args.break_number"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "15a2b1305e1a4df2a8ef762479ff1296",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Inserting packets into the sketch:   0%|          | 0/1000000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Insert 1000000 items with 93703 distinct keys. Meanwhile, 129 points is sampled\n"
     ]
    }
   ],
   "source": [
    "packetCnt = 0\n",
    "ground_truth = {}\n",
    "sample_initial = size - (args.interval + 12) * args.num_samples\n",
    "\n",
    "args.bucket_dim = ucl_sketch.cm.width\n",
    "samples = np.empty([0, args.hash_num, args.bucket_dim])\n",
    "\n",
    "with tqdm(initial=0, total=size, desc='Inserting packets into the sketch') as pbar:\n",
    "    for idx, trace in enumerate(traces):\n",
    "        if trace in ground_truth:\n",
    "            ground_truth[trace] += 1\n",
    "        else:\n",
    "            ground_truth[trace] = 1\n",
    "            \n",
    "        ucl_sketch.insert(trace)\n",
    "        packetCnt += 1\n",
    "        pbar.update(1)\n",
    "        \n",
    "        if idx > sample_initial and idx % args.interval == 0:\n",
    "            sample = ucl_sketch.get_current_state(return_A=False)\n",
    "            samples = np.row_stack([samples, sample])\n",
    "\n",
    "GT_sorted = sorted(ground_truth, key=lambda x: ground_truth[x])\n",
    "topk_keys = GT_sorted[- args.slot_num:]\n",
    "GT_ideal = GT_sorted[:- args.slot_num]\n",
    "\n",
    "for key in GT_ideal:\n",
    "    value = ground_truth[key]\n",
    "    lc_sketch.insert(key, value)\n",
    "    lcm_sketch.insert(key, value)\n",
    "    c_sketch.insert(key, value)\n",
    "    cm_sketch.insert(key, value)\n",
    "    nitro_sketch.insert(key, value)\n",
    "    elastic_sketch.insert(key, value)\n",
    "    univmon.insert(key, value)\n",
    "\n",
    "for key in topk_keys:\n",
    "    value = ground_truth[key]\n",
    "    c_sketch.insert(key, value)\n",
    "    cm_sketch.insert(key, value)\n",
    "    nitro_sketch.insert(key, value)\n",
    "    elastic_sketch.insert(key, value)\n",
    "    univmon.insert(key, value)\n",
    "\n",
    "print(f'Insert {packetCnt} items with {len(ground_truth)} distinct keys. Meanwhile, {samples.shape[0]} points is sampled')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## ⛺ Step 4 - Train the learning-based solver"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Use GPU: cuda:0\n",
      "Epoch: 1 cost time: 1.9768569469451904\n",
      "Epoch: 1, Steps: 4 | Train Loss: 7286.6202393\n",
      "Validation loss decreased (inf --> 7286.620239).  Saving model ...\n",
      "Epoch: 2 cost time: 0.07568097114562988\n",
      "Epoch: 2, Steps: 4 | Train Loss: 5127.3626709\n",
      "Validation loss decreased (7286.620239 --> 5127.362671).  Saving model ...\n",
      "Epoch: 3 cost time: 0.06644749641418457\n",
      "Epoch: 3, Steps: 4 | Train Loss: 2635.8446960\n",
      "Validation loss decreased (5127.362671 --> 2635.844696).  Saving model ...\n",
      "Epoch: 4 cost time: 0.06661391258239746\n",
      "Epoch: 4, Steps: 4 | Train Loss: 865.1760178\n",
      "Validation loss decreased (2635.844696 --> 865.176018).  Saving model ...\n",
      "Epoch: 5 cost time: 0.06732296943664551\n",
      "Epoch: 5, Steps: 4 | Train Loss: 183.6326351\n",
      "Validation loss decreased (865.176018 --> 183.632635).  Saving model ...\n",
      "Epoch: 6 cost time: 0.0678868293762207\n",
      "Epoch: 6, Steps: 4 | Train Loss: 33.0024967\n",
      "Validation loss decreased (183.632635 --> 33.002497).  Saving model ...\n",
      "Epoch: 7 cost time: 0.06763672828674316\n",
      "Epoch: 7, Steps: 4 | Train Loss: 8.0583426\n",
      "Validation loss decreased (33.002497 --> 8.058343).  Saving model ...\n",
      "Epoch: 8 cost time: 0.07305407524108887\n",
      "Epoch: 8, Steps: 4 | Train Loss: 3.2892649\n",
      "Validation loss decreased (8.058343 --> 3.289265).  Saving model ...\n",
      "Epoch: 9 cost time: 0.06703495979309082\n",
      "Epoch: 9, Steps: 4 | Train Loss: 1.9235988\n",
      "Validation loss decreased (3.289265 --> 1.923599).  Saving model ...\n",
      "Epoch: 10 cost time: 0.06985616683959961\n",
      "Epoch: 10, Steps: 4 | Train Loss: 1.3515930\n",
      "Validation loss decreased (1.923599 --> 1.351593).  Saving model ...\n",
      "Epoch: 11 cost time: 0.06579399108886719\n",
      "Epoch: 11, Steps: 4 | Train Loss: 1.0380901\n",
      "Validation loss decreased (1.351593 --> 1.038090).  Saving model ...\n",
      "Epoch: 12 cost time: 0.07083988189697266\n",
      "Epoch: 12, Steps: 4 | Train Loss: 0.8099630\n",
      "Validation loss decreased (1.038090 --> 0.809963).  Saving model ...\n",
      "Epoch: 13 cost time: 0.0686802864074707\n",
      "Epoch: 13, Steps: 4 | Train Loss: 0.6849194\n",
      "Validation loss decreased (0.809963 --> 0.684919).  Saving model ...\n",
      "Epoch: 14 cost time: 0.06638288497924805\n",
      "Epoch: 14, Steps: 4 | Train Loss: 0.6346894\n",
      "Validation loss decreased (0.684919 --> 0.634689).  Saving model ...\n",
      "Epoch: 15 cost time: 0.0704805850982666\n",
      "Epoch: 15, Steps: 4 | Train Loss: 0.6079321\n",
      "Validation loss decreased (0.634689 --> 0.607932).  Saving model ...\n",
      "Epoch: 16 cost time: 0.07021903991699219\n",
      "Epoch: 16, Steps: 4 | Train Loss: 0.5910024\n",
      "Validation loss decreased (0.607932 --> 0.591002).  Saving model ...\n",
      "Epoch: 17 cost time: 0.06600165367126465\n",
      "Epoch: 17, Steps: 4 | Train Loss: 0.5706453\n",
      "Validation loss decreased (0.591002 --> 0.570645).  Saving model ...\n",
      "Epoch: 18 cost time: 0.06183218955993652\n",
      "Epoch: 18, Steps: 4 | Train Loss: 0.5328032\n",
      "Validation loss decreased (0.570645 --> 0.532803).  Saving model ...\n",
      "Epoch: 19 cost time: 0.06791043281555176\n",
      "Epoch: 19, Steps: 4 | Train Loss: 0.4848561\n",
      "Validation loss decreased (0.532803 --> 0.484856).  Saving model ...\n",
      "Epoch: 20 cost time: 0.06769156455993652\n",
      "Epoch: 20, Steps: 4 | Train Loss: 0.4397239\n",
      "Validation loss decreased (0.484856 --> 0.439724).  Saving model ...\n",
      "Epoch: 21 cost time: 0.06902098655700684\n",
      "Epoch: 21, Steps: 4 | Train Loss: 0.4093188\n",
      "Validation loss decreased (0.439724 --> 0.409319).  Saving model ...\n",
      "Epoch: 22 cost time: 0.06708335876464844\n",
      "Epoch: 22, Steps: 4 | Train Loss: 0.3952845\n",
      "Validation loss decreased (0.409319 --> 0.395284).  Saving model ...\n",
      "Epoch: 23 cost time: 0.0702049732208252\n",
      "Epoch: 23, Steps: 4 | Train Loss: 0.3887072\n",
      "Validation loss decreased (0.395284 --> 0.388707).  Saving model ...\n",
      "Epoch: 24 cost time: 0.06627011299133301\n",
      "Epoch: 24, Steps: 4 | Train Loss: 0.3849931\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 25 cost time: 0.0730433464050293\n",
      "Epoch: 25, Steps: 4 | Train Loss: 0.3826027\n",
      "Validation loss decreased (0.388707 --> 0.382603).  Saving model ...\n",
      "Epoch: 26 cost time: 0.0648355484008789\n",
      "Epoch: 26, Steps: 4 | Train Loss: 0.3807314\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 27 cost time: 0.07373833656311035\n",
      "Epoch: 27, Steps: 4 | Train Loss: 0.3789244\n",
      "EarlyStopping counter: 2 out of 30\n",
      "Epoch: 28 cost time: 0.07239007949829102\n",
      "Epoch: 28, Steps: 4 | Train Loss: 0.3768333\n",
      "Validation loss decreased (0.382603 --> 0.376833).  Saving model ...\n",
      "Epoch: 29 cost time: 0.06683993339538574\n",
      "Epoch: 29, Steps: 4 | Train Loss: 0.3738741\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 30 cost time: 0.06662797927856445\n",
      "Epoch: 30, Steps: 4 | Train Loss: 0.3684716\n",
      "Validation loss decreased (0.376833 --> 0.368472).  Saving model ...\n",
      "Epoch: 31 cost time: 0.06877660751342773\n",
      "Epoch: 31, Steps: 4 | Train Loss: 0.3565973\n",
      "Validation loss decreased (0.368472 --> 0.356597).  Saving model ...\n",
      "Epoch: 32 cost time: 0.07237434387207031\n",
      "Epoch: 32, Steps: 4 | Train Loss: 0.3313678\n",
      "Validation loss decreased (0.356597 --> 0.331368).  Saving model ...\n",
      "Epoch: 33 cost time: 0.08012747764587402\n",
      "Epoch: 33, Steps: 4 | Train Loss: 0.2829177\n",
      "Validation loss decreased (0.331368 --> 0.282918).  Saving model ...\n",
      "Epoch: 34 cost time: 0.06745433807373047\n",
      "Epoch: 34, Steps: 4 | Train Loss: 0.2287486\n",
      "Validation loss decreased (0.282918 --> 0.228749).  Saving model ...\n",
      "Epoch: 35 cost time: 0.06732058525085449\n",
      "Epoch: 35, Steps: 4 | Train Loss: 0.1980685\n",
      "Validation loss decreased (0.228749 --> 0.198068).  Saving model ...\n",
      "Epoch: 36 cost time: 0.06871819496154785\n",
      "Epoch: 36, Steps: 4 | Train Loss: 0.1874731\n",
      "Validation loss decreased (0.198068 --> 0.187473).  Saving model ...\n",
      "Epoch: 37 cost time: 0.06806731224060059\n",
      "Epoch: 37, Steps: 4 | Train Loss: 0.1835662\n",
      "Validation loss decreased (0.187473 --> 0.183566).  Saving model ...\n",
      "Epoch: 38 cost time: 0.06545495986938477\n",
      "Epoch: 38, Steps: 4 | Train Loss: 0.1810554\n",
      "Validation loss decreased (0.183566 --> 0.181055).  Saving model ...\n",
      "Epoch: 39 cost time: 0.07037687301635742\n",
      "Epoch: 39, Steps: 4 | Train Loss: 0.1781047\n",
      "Validation loss decreased (0.181055 --> 0.178105).  Saving model ...\n",
      "Epoch: 40 cost time: 0.06958699226379395\n",
      "Epoch: 40, Steps: 4 | Train Loss: 0.1736883\n",
      "Validation loss decreased (0.178105 --> 0.173688).  Saving model ...\n",
      "Epoch: 41 cost time: 0.07272982597351074\n",
      "Epoch: 41, Steps: 4 | Train Loss: 0.1669630\n",
      "Validation loss decreased (0.173688 --> 0.166963).  Saving model ...\n",
      "Epoch: 42 cost time: 0.06536269187927246\n",
      "Epoch: 42, Steps: 4 | Train Loss: 0.1555989\n",
      "Validation loss decreased (0.166963 --> 0.155599).  Saving model ...\n",
      "Epoch: 43 cost time: 0.06578469276428223\n",
      "Epoch: 43, Steps: 4 | Train Loss: 0.1361701\n",
      "Validation loss decreased (0.155599 --> 0.136170).  Saving model ...\n",
      "Epoch: 44 cost time: 0.06626677513122559\n",
      "Epoch: 44, Steps: 4 | Train Loss: 0.1038036\n",
      "Validation loss decreased (0.136170 --> 0.103804).  Saving model ...\n",
      "Epoch: 45 cost time: 0.06690073013305664\n",
      "Epoch: 45, Steps: 4 | Train Loss: 0.0651003\n",
      "Validation loss decreased (0.103804 --> 0.065100).  Saving model ...\n",
      "Epoch: 46 cost time: 0.06577754020690918\n",
      "Epoch: 46, Steps: 4 | Train Loss: 0.0389900\n",
      "Validation loss decreased (0.065100 --> 0.038990).  Saving model ...\n",
      "Epoch: 47 cost time: 0.06849312782287598\n",
      "Epoch: 47, Steps: 4 | Train Loss: 0.0287829\n",
      "Validation loss decreased (0.038990 --> 0.028783).  Saving model ...\n",
      "Epoch: 48 cost time: 0.07390022277832031\n",
      "Epoch: 48, Steps: 4 | Train Loss: 0.0255044\n",
      "Validation loss decreased (0.028783 --> 0.025504).  Saving model ...\n",
      "Epoch: 49 cost time: 0.07171177864074707\n",
      "Epoch: 49, Steps: 4 | Train Loss: 0.0243391\n",
      "Validation loss decreased (0.025504 --> 0.024339).  Saving model ...\n",
      "Epoch: 50 cost time: 0.06579422950744629\n",
      "Epoch: 50, Steps: 4 | Train Loss: 0.0237918\n",
      "Validation loss decreased (0.024339 --> 0.023792).  Saving model ...\n",
      "Epoch: 51 cost time: 0.07255887985229492\n",
      "Epoch: 51, Steps: 4 | Train Loss: 0.0235328\n",
      "Validation loss decreased (0.023792 --> 0.023533).  Saving model ...\n",
      "Epoch: 52 cost time: 0.06039738655090332\n",
      "Epoch: 52, Steps: 4 | Train Loss: 0.0233181\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 53 cost time: 0.07114458084106445\n",
      "Epoch: 53, Steps: 4 | Train Loss: 0.0231078\n",
      "Validation loss decreased (0.023533 --> 0.023108).  Saving model ...\n",
      "Epoch: 54 cost time: 0.06890130043029785\n",
      "Epoch: 54, Steps: 4 | Train Loss: 0.0230029\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 55 cost time: 0.06780743598937988\n",
      "Epoch: 55, Steps: 4 | Train Loss: 0.0229061\n",
      "EarlyStopping counter: 2 out of 30\n",
      "Epoch: 56 cost time: 0.07127547264099121\n",
      "Epoch: 56, Steps: 4 | Train Loss: 0.0227858\n",
      "Validation loss decreased (0.023108 --> 0.022786).  Saving model ...\n",
      "Epoch: 57 cost time: 0.0652921199798584\n",
      "Epoch: 57, Steps: 4 | Train Loss: 0.0227041\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 58 cost time: 0.06377077102661133\n",
      "Epoch: 58, Steps: 4 | Train Loss: 0.0226267\n",
      "EarlyStopping counter: 2 out of 30\n",
      "Epoch: 59 cost time: 0.0656123161315918\n",
      "Epoch: 59, Steps: 4 | Train Loss: 0.0225710\n",
      "EarlyStopping counter: 3 out of 30\n",
      "Epoch: 60 cost time: 0.06233358383178711\n",
      "Epoch: 60, Steps: 4 | Train Loss: 0.0225179\n",
      "Validation loss decreased (0.022786 --> 0.022518).  Saving model ...\n",
      "Epoch: 61 cost time: 0.06698131561279297\n",
      "Epoch: 61, Steps: 4 | Train Loss: 0.0224120\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 62 cost time: 0.06197929382324219\n",
      "Epoch: 62, Steps: 4 | Train Loss: 0.0223960\n",
      "EarlyStopping counter: 2 out of 30\n",
      "Epoch: 63 cost time: 0.06817340850830078\n",
      "Epoch: 63, Steps: 4 | Train Loss: 0.0223585\n",
      "EarlyStopping counter: 3 out of 30\n",
      "Epoch: 64 cost time: 0.06378650665283203\n",
      "Epoch: 64, Steps: 4 | Train Loss: 0.0223257\n",
      "EarlyStopping counter: 4 out of 30\n",
      "Epoch: 65 cost time: 0.06529688835144043\n",
      "Epoch: 65, Steps: 4 | Train Loss: 0.0222332\n",
      "Validation loss decreased (0.022518 --> 0.022233).  Saving model ...\n",
      "Epoch: 66 cost time: 0.06408452987670898\n",
      "Epoch: 66, Steps: 4 | Train Loss: 0.0221952\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 67 cost time: 0.06413769721984863\n",
      "Epoch: 67, Steps: 4 | Train Loss: 0.0221999\n",
      "EarlyStopping counter: 2 out of 30\n",
      "Epoch: 68 cost time: 0.0698556900024414\n",
      "Epoch: 68, Steps: 4 | Train Loss: 0.0221677\n",
      "EarlyStopping counter: 3 out of 30\n",
      "Epoch: 69 cost time: 0.06777071952819824\n",
      "Epoch: 69, Steps: 4 | Train Loss: 0.0221404\n",
      "EarlyStopping counter: 4 out of 30\n",
      "Epoch: 70 cost time: 0.06599712371826172\n",
      "Epoch: 70, Steps: 4 | Train Loss: 0.0221023\n",
      "EarlyStopping counter: 5 out of 30\n",
      "Epoch: 71 cost time: 0.06087088584899902\n",
      "Epoch: 71, Steps: 4 | Train Loss: 0.0220764\n",
      "EarlyStopping counter: 6 out of 30\n",
      "Epoch: 72 cost time: 0.06651997566223145\n",
      "Epoch: 72, Steps: 4 | Train Loss: 0.0220538\n",
      "EarlyStopping counter: 7 out of 30\n",
      "Epoch: 73 cost time: 0.058663368225097656\n",
      "Epoch: 73, Steps: 4 | Train Loss: 0.0219677\n",
      "Validation loss decreased (0.022233 --> 0.021968).  Saving model ...\n",
      "Epoch: 74 cost time: 0.06727361679077148\n",
      "Epoch: 74, Steps: 4 | Train Loss: 0.0219820\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 75 cost time: 0.06716537475585938\n",
      "Epoch: 75, Steps: 4 | Train Loss: 0.0219630\n",
      "EarlyStopping counter: 2 out of 30\n",
      "Epoch: 76 cost time: 0.0653836727142334\n",
      "Epoch: 76, Steps: 4 | Train Loss: 0.0219322\n",
      "EarlyStopping counter: 3 out of 30\n",
      "Epoch: 77 cost time: 0.06002044677734375\n",
      "Epoch: 77, Steps: 4 | Train Loss: 0.0218971\n",
      "EarlyStopping counter: 4 out of 30\n",
      "Epoch: 78 cost time: 0.07415080070495605\n",
      "Epoch: 78, Steps: 4 | Train Loss: 0.0218840\n",
      "EarlyStopping counter: 5 out of 30\n",
      "Epoch: 79 cost time: 0.0660703182220459\n",
      "Epoch: 79, Steps: 4 | Train Loss: 0.0218102\n",
      "EarlyStopping counter: 6 out of 30\n",
      "Epoch: 80 cost time: 0.06543946266174316\n",
      "Epoch: 80, Steps: 4 | Train Loss: 0.0218300\n",
      "EarlyStopping counter: 7 out of 30\n",
      "Epoch: 81 cost time: 0.06442618370056152\n",
      "Epoch: 81, Steps: 4 | Train Loss: 0.0217624\n",
      "EarlyStopping counter: 8 out of 30\n",
      "Epoch: 82 cost time: 0.07001376152038574\n",
      "Epoch: 82, Steps: 4 | Train Loss: 0.0217891\n",
      "EarlyStopping counter: 9 out of 30\n",
      "Epoch: 83 cost time: 0.06030392646789551\n",
      "Epoch: 83, Steps: 4 | Train Loss: 0.0217601\n",
      "EarlyStopping counter: 10 out of 30\n",
      "Epoch: 84 cost time: 0.06839585304260254\n",
      "Epoch: 84, Steps: 4 | Train Loss: 0.0216935\n",
      "Validation loss decreased (0.021968 --> 0.021694).  Saving model ...\n",
      "Epoch: 85 cost time: 0.0675344467163086\n",
      "Epoch: 85, Steps: 4 | Train Loss: 0.0217236\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 86 cost time: 0.06036972999572754\n",
      "Epoch: 86, Steps: 4 | Train Loss: 0.0216486\n",
      "EarlyStopping counter: 2 out of 30\n",
      "Epoch: 87 cost time: 0.06961798667907715\n",
      "Epoch: 87, Steps: 4 | Train Loss: 0.0216833\n",
      "EarlyStopping counter: 3 out of 30\n",
      "Epoch: 88 cost time: 0.05945134162902832\n",
      "Epoch: 88, Steps: 4 | Train Loss: 0.0216426\n",
      "EarlyStopping counter: 4 out of 30\n",
      "Epoch: 89 cost time: 0.07632637023925781\n",
      "Epoch: 89, Steps: 4 | Train Loss: 0.0216353\n",
      "EarlyStopping counter: 5 out of 30\n",
      "Epoch: 90 cost time: 0.06376910209655762\n",
      "Epoch: 90, Steps: 4 | Train Loss: 0.0216199\n",
      "EarlyStopping counter: 6 out of 30\n",
      "Epoch: 91 cost time: 0.06219077110290527\n",
      "Epoch: 91, Steps: 4 | Train Loss: 0.0215436\n",
      "EarlyStopping counter: 7 out of 30\n",
      "Epoch: 92 cost time: 0.06318521499633789\n",
      "Epoch: 92, Steps: 4 | Train Loss: 0.0215603\n",
      "EarlyStopping counter: 8 out of 30\n",
      "Epoch: 93 cost time: 0.06484842300415039\n",
      "Epoch: 93, Steps: 4 | Train Loss: 0.0215409\n",
      "EarlyStopping counter: 9 out of 30\n",
      "Epoch: 94 cost time: 0.06899166107177734\n",
      "Epoch: 94, Steps: 4 | Train Loss: 0.0215310\n",
      "EarlyStopping counter: 10 out of 30\n",
      "Epoch: 95 cost time: 0.06231045722961426\n",
      "Epoch: 95, Steps: 4 | Train Loss: 0.0215189\n",
      "EarlyStopping counter: 11 out of 30\n",
      "Epoch: 96 cost time: 0.05840349197387695\n",
      "Epoch: 96, Steps: 4 | Train Loss: 0.0214478\n",
      "Validation loss decreased (0.021694 --> 0.021448).  Saving model ...\n",
      "Epoch: 97 cost time: 0.07008528709411621\n",
      "Epoch: 97, Steps: 4 | Train Loss: 0.0214700\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 98 cost time: 0.062348127365112305\n",
      "Epoch: 98, Steps: 4 | Train Loss: 0.0214543\n",
      "EarlyStopping counter: 2 out of 30\n",
      "Epoch: 99 cost time: 0.06734251976013184\n",
      "Epoch: 99, Steps: 4 | Train Loss: 0.0214340\n",
      "EarlyStopping counter: 3 out of 30\n",
      "Epoch: 100 cost time: 0.06560945510864258\n",
      "Epoch: 100, Steps: 4 | Train Loss: 0.0214173\n",
      "EarlyStopping counter: 4 out of 30\n",
      "Epoch: 101 cost time: 0.061075687408447266\n",
      "Epoch: 101, Steps: 4 | Train Loss: 0.0213951\n",
      "EarlyStopping counter: 5 out of 30\n",
      "Epoch: 102 cost time: 0.07034015655517578\n",
      "Epoch: 102, Steps: 4 | Train Loss: 0.0213824\n",
      "EarlyStopping counter: 6 out of 30\n",
      "Epoch: 103 cost time: 0.06949567794799805\n",
      "Epoch: 103, Steps: 4 | Train Loss: 0.0213700\n",
      "EarlyStopping counter: 7 out of 30\n",
      "Epoch: 104 cost time: 0.06279754638671875\n",
      "Epoch: 104, Steps: 4 | Train Loss: 0.0213530\n",
      "EarlyStopping counter: 8 out of 30\n",
      "Epoch: 105 cost time: 0.06707763671875\n",
      "Epoch: 105, Steps: 4 | Train Loss: 0.0213370\n",
      "EarlyStopping counter: 9 out of 30\n",
      "Epoch: 106 cost time: 0.06389880180358887\n",
      "Epoch: 106, Steps: 4 | Train Loss: 0.0213219\n",
      "EarlyStopping counter: 10 out of 30\n",
      "Epoch: 107 cost time: 0.07053947448730469\n",
      "Epoch: 107, Steps: 4 | Train Loss: 0.0213046\n",
      "EarlyStopping counter: 11 out of 30\n",
      "Epoch: 108 cost time: 0.07428121566772461\n",
      "Epoch: 108, Steps: 4 | Train Loss: 0.0212883\n",
      "EarlyStopping counter: 12 out of 30\n",
      "Epoch: 109 cost time: 0.060689687728881836\n",
      "Epoch: 109, Steps: 4 | Train Loss: 0.0212711\n",
      "EarlyStopping counter: 13 out of 30\n",
      "Epoch: 110 cost time: 0.06233978271484375\n",
      "Epoch: 110, Steps: 4 | Train Loss: 0.0212464\n",
      "EarlyStopping counter: 14 out of 30\n",
      "Epoch: 111 cost time: 0.06809115409851074\n",
      "Epoch: 111, Steps: 4 | Train Loss: 0.0212413\n",
      "EarlyStopping counter: 15 out of 30\n",
      "Epoch: 112 cost time: 0.06007575988769531\n",
      "Epoch: 112, Steps: 4 | Train Loss: 0.0211840\n",
      "Validation loss decreased (0.021448 --> 0.021184).  Saving model ...\n",
      "Epoch: 113 cost time: 0.07077503204345703\n",
      "Epoch: 113, Steps: 4 | Train Loss: 0.0212003\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 114 cost time: 0.07917237281799316\n",
      "Epoch: 114, Steps: 4 | Train Loss: 0.0211898\n",
      "EarlyStopping counter: 2 out of 30\n",
      "Epoch: 115 cost time: 0.0702064037322998\n",
      "Epoch: 115, Steps: 4 | Train Loss: 0.0211746\n",
      "EarlyStopping counter: 3 out of 30\n",
      "Epoch: 116 cost time: 0.0752861499786377\n",
      "Epoch: 116, Steps: 4 | Train Loss: 0.0211573\n",
      "EarlyStopping counter: 4 out of 30\n",
      "Epoch: 117 cost time: 0.06516122817993164\n",
      "Epoch: 117, Steps: 4 | Train Loss: 0.0211558\n",
      "EarlyStopping counter: 5 out of 30\n",
      "Epoch: 118 cost time: 0.07274556159973145\n",
      "Epoch: 118, Steps: 4 | Train Loss: 0.0211321\n",
      "EarlyStopping counter: 6 out of 30\n",
      "Epoch: 119 cost time: 0.07225584983825684\n",
      "Epoch: 119, Steps: 4 | Train Loss: 0.0211186\n",
      "EarlyStopping counter: 7 out of 30\n",
      "Epoch: 120 cost time: 0.07074403762817383\n",
      "Epoch: 120, Steps: 4 | Train Loss: 0.0210993\n",
      "EarlyStopping counter: 8 out of 30\n",
      "Epoch: 121 cost time: 0.0672769546508789\n",
      "Epoch: 121, Steps: 4 | Train Loss: 0.0210852\n",
      "EarlyStopping counter: 9 out of 30\n",
      "Epoch: 122 cost time: 0.07529115676879883\n",
      "Epoch: 122, Steps: 4 | Train Loss: 0.0210803\n",
      "EarlyStopping counter: 10 out of 30\n",
      "Epoch: 123 cost time: 0.07015466690063477\n",
      "Epoch: 123, Steps: 4 | Train Loss: 0.0210776\n",
      "EarlyStopping counter: 11 out of 30\n",
      "Epoch: 124 cost time: 0.06862258911132812\n",
      "Epoch: 124, Steps: 4 | Train Loss: 0.0210603\n",
      "EarlyStopping counter: 12 out of 30\n",
      "Epoch: 125 cost time: 0.06557846069335938\n",
      "Epoch: 125, Steps: 4 | Train Loss: 0.0210309\n",
      "EarlyStopping counter: 13 out of 30\n",
      "Epoch: 126 cost time: 0.06492805480957031\n",
      "Epoch: 126, Steps: 4 | Train Loss: 0.0210365\n",
      "EarlyStopping counter: 14 out of 30\n",
      "Epoch: 127 cost time: 0.07438158988952637\n",
      "Epoch: 127, Steps: 4 | Train Loss: 0.0210043\n",
      "EarlyStopping counter: 15 out of 30\n",
      "Epoch: 128 cost time: 0.06589794158935547\n",
      "Epoch: 128, Steps: 4 | Train Loss: 0.0209932\n",
      "EarlyStopping counter: 16 out of 30\n",
      "Epoch: 129 cost time: 0.07203483581542969\n",
      "Epoch: 129, Steps: 4 | Train Loss: 0.0209873\n",
      "EarlyStopping counter: 17 out of 30\n",
      "Epoch: 130 cost time: 0.07206535339355469\n",
      "Epoch: 130, Steps: 4 | Train Loss: 0.0209814\n",
      "EarlyStopping counter: 18 out of 30\n",
      "Epoch: 131 cost time: 0.0746314525604248\n",
      "Epoch: 131, Steps: 4 | Train Loss: 0.0209586\n",
      "Validation loss decreased (0.021184 --> 0.020959).  Saving model ...\n",
      "Epoch: 132 cost time: 0.06785798072814941\n",
      "Epoch: 132, Steps: 4 | Train Loss: 0.0209408\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 133 cost time: 0.07037997245788574\n",
      "Epoch: 133, Steps: 4 | Train Loss: 0.0209464\n",
      "EarlyStopping counter: 2 out of 30\n",
      "Epoch: 134 cost time: 0.07202816009521484\n",
      "Epoch: 134, Steps: 4 | Train Loss: 0.0209211\n",
      "EarlyStopping counter: 3 out of 30\n",
      "Epoch: 135 cost time: 0.07241368293762207\n",
      "Epoch: 135, Steps: 4 | Train Loss: 0.0209078\n",
      "EarlyStopping counter: 4 out of 30\n",
      "Epoch: 136 cost time: 0.07100725173950195\n",
      "Epoch: 136, Steps: 4 | Train Loss: 0.0208905\n",
      "EarlyStopping counter: 5 out of 30\n",
      "Epoch: 137 cost time: 0.07306170463562012\n",
      "Epoch: 137, Steps: 4 | Train Loss: 0.0208932\n",
      "EarlyStopping counter: 6 out of 30\n",
      "Epoch: 138 cost time: 0.07219672203063965\n",
      "Epoch: 138, Steps: 4 | Train Loss: 0.0208854\n",
      "EarlyStopping counter: 7 out of 30\n",
      "Epoch: 139 cost time: 0.0736997127532959\n",
      "Epoch: 139, Steps: 4 | Train Loss: 0.0208771\n",
      "EarlyStopping counter: 8 out of 30\n",
      "Epoch: 140 cost time: 0.0658731460571289\n",
      "Epoch: 140, Steps: 4 | Train Loss: 0.0208450\n",
      "EarlyStopping counter: 9 out of 30\n",
      "Epoch: 141 cost time: 0.07415366172790527\n",
      "Epoch: 141, Steps: 4 | Train Loss: 0.0208430\n",
      "EarlyStopping counter: 10 out of 30\n",
      "Epoch: 142 cost time: 0.07103300094604492\n",
      "Epoch: 142, Steps: 4 | Train Loss: 0.0208406\n",
      "EarlyStopping counter: 11 out of 30\n",
      "Epoch: 143 cost time: 0.06795883178710938\n",
      "Epoch: 143, Steps: 4 | Train Loss: 0.0207750\n",
      "EarlyStopping counter: 12 out of 30\n",
      "Epoch: 144 cost time: 0.06908607482910156\n",
      "Epoch: 144, Steps: 4 | Train Loss: 0.0208172\n",
      "EarlyStopping counter: 13 out of 30\n",
      "Epoch: 145 cost time: 0.06910252571105957\n",
      "Epoch: 145, Steps: 4 | Train Loss: 0.0207980\n",
      "EarlyStopping counter: 14 out of 30\n",
      "Epoch: 146 cost time: 0.07140254974365234\n",
      "Epoch: 146, Steps: 4 | Train Loss: 0.0207784\n",
      "EarlyStopping counter: 15 out of 30\n",
      "Epoch: 147 cost time: 0.07323741912841797\n",
      "Epoch: 147, Steps: 4 | Train Loss: 0.0207646\n",
      "EarlyStopping counter: 16 out of 30\n",
      "Epoch: 148 cost time: 0.07131791114807129\n",
      "Epoch: 148, Steps: 4 | Train Loss: 0.0207688\n",
      "EarlyStopping counter: 17 out of 30\n",
      "Epoch: 149 cost time: 0.07414126396179199\n",
      "Epoch: 149, Steps: 4 | Train Loss: 0.0207071\n",
      "Validation loss decreased (0.020959 --> 0.020707).  Saving model ...\n",
      "Epoch: 150 cost time: 0.06657910346984863\n",
      "Epoch: 150, Steps: 4 | Train Loss: 0.0207502\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 151 cost time: 0.07298016548156738\n",
      "Epoch: 151, Steps: 4 | Train Loss: 0.0207211\n",
      "EarlyStopping counter: 2 out of 30\n",
      "Epoch: 152 cost time: 0.07010459899902344\n",
      "Epoch: 152, Steps: 4 | Train Loss: 0.0207183\n",
      "EarlyStopping counter: 3 out of 30\n",
      "Epoch: 153 cost time: 0.06838512420654297\n",
      "Epoch: 153, Steps: 4 | Train Loss: 0.0207084\n",
      "EarlyStopping counter: 4 out of 30\n",
      "Epoch: 154 cost time: 0.07120513916015625\n",
      "Epoch: 154, Steps: 4 | Train Loss: 0.0206974\n",
      "EarlyStopping counter: 5 out of 30\n",
      "Epoch: 155 cost time: 0.0724179744720459\n",
      "Epoch: 155, Steps: 4 | Train Loss: 0.0206940\n",
      "EarlyStopping counter: 6 out of 30\n",
      "Epoch: 156 cost time: 0.06662344932556152\n",
      "Epoch: 156, Steps: 4 | Train Loss: 0.0206727\n",
      "EarlyStopping counter: 7 out of 30\n",
      "Epoch: 157 cost time: 0.0666654109954834\n",
      "Epoch: 157, Steps: 4 | Train Loss: 0.0206625\n",
      "EarlyStopping counter: 8 out of 30\n",
      "Epoch: 158 cost time: 0.06838512420654297\n",
      "Epoch: 158, Steps: 4 | Train Loss: 0.0206561\n",
      "EarlyStopping counter: 9 out of 30\n",
      "Epoch: 159 cost time: 0.07122087478637695\n",
      "Epoch: 159, Steps: 4 | Train Loss: 0.0206503\n",
      "EarlyStopping counter: 10 out of 30\n",
      "Epoch: 160 cost time: 0.06869220733642578\n",
      "Epoch: 160, Steps: 4 | Train Loss: 0.0205927\n",
      "EarlyStopping counter: 11 out of 30\n",
      "Epoch: 161 cost time: 0.07097053527832031\n",
      "Epoch: 161, Steps: 4 | Train Loss: 0.0206270\n",
      "EarlyStopping counter: 12 out of 30\n",
      "Epoch: 162 cost time: 0.07244062423706055\n",
      "Epoch: 162, Steps: 4 | Train Loss: 0.0206259\n",
      "EarlyStopping counter: 13 out of 30\n",
      "Epoch: 163 cost time: 0.06707882881164551\n",
      "Epoch: 163, Steps: 4 | Train Loss: 0.0206013\n",
      "EarlyStopping counter: 14 out of 30\n",
      "Epoch: 164 cost time: 0.07225275039672852\n",
      "Epoch: 164, Steps: 4 | Train Loss: 0.0205558\n",
      "EarlyStopping counter: 15 out of 30\n",
      "Epoch: 165 cost time: 0.0729219913482666\n",
      "Epoch: 165, Steps: 4 | Train Loss: 0.0205874\n",
      "EarlyStopping counter: 16 out of 30\n",
      "Epoch: 166 cost time: 0.07442283630371094\n",
      "Epoch: 166, Steps: 4 | Train Loss: 0.0205832\n",
      "EarlyStopping counter: 17 out of 30\n",
      "Epoch: 167 cost time: 0.07079815864562988\n",
      "Epoch: 167, Steps: 4 | Train Loss: 0.0205637\n",
      "EarlyStopping counter: 18 out of 30\n",
      "Epoch: 168 cost time: 0.0732569694519043\n",
      "Epoch: 168, Steps: 4 | Train Loss: 0.0205684\n",
      "EarlyStopping counter: 19 out of 30\n",
      "Epoch: 169 cost time: 0.07127833366394043\n",
      "Epoch: 169, Steps: 4 | Train Loss: 0.0205498\n",
      "EarlyStopping counter: 20 out of 30\n",
      "Epoch: 170 cost time: 0.07546234130859375\n",
      "Epoch: 170, Steps: 4 | Train Loss: 0.0205506\n",
      "EarlyStopping counter: 21 out of 30\n",
      "Epoch: 171 cost time: 0.06985616683959961\n",
      "Epoch: 171, Steps: 4 | Train Loss: 0.0205318\n",
      "EarlyStopping counter: 22 out of 30\n",
      "Epoch: 172 cost time: 0.07280182838439941\n",
      "Epoch: 172, Steps: 4 | Train Loss: 0.0205239\n",
      "EarlyStopping counter: 23 out of 30\n",
      "Epoch: 173 cost time: 0.06999611854553223\n",
      "Epoch: 173, Steps: 4 | Train Loss: 0.0205060\n",
      "EarlyStopping counter: 24 out of 30\n",
      "Epoch: 174 cost time: 0.06941986083984375\n",
      "Epoch: 174, Steps: 4 | Train Loss: 0.0204620\n",
      "Validation loss decreased (0.020707 --> 0.020462).  Saving model ...\n",
      "Epoch: 175 cost time: 0.06812286376953125\n",
      "Epoch: 175, Steps: 4 | Train Loss: 0.0205036\n",
      "EarlyStopping counter: 1 out of 30\n",
      "Epoch: 176 cost time: 0.07091522216796875\n",
      "Epoch: 176, Steps: 4 | Train Loss: 0.0204452\n",
      "EarlyStopping counter: 2 out of 30\n",
      "Epoch: 177 cost time: 0.07226347923278809\n",
      "Epoch: 177, Steps: 4 | Train Loss: 0.0204798\n",
      "EarlyStopping counter: 3 out of 30\n",
      "Epoch: 178 cost time: 0.07244467735290527\n",
      "Epoch: 178, Steps: 4 | Train Loss: 0.0204302\n",
      "EarlyStopping counter: 4 out of 30\n",
      "Epoch: 179 cost time: 0.07311582565307617\n",
      "Epoch: 179, Steps: 4 | Train Loss: 0.0204697\n",
      "EarlyStopping counter: 5 out of 30\n",
      "Epoch: 180 cost time: 0.07019495964050293\n",
      "Epoch: 180, Steps: 4 | Train Loss: 0.0204549\n",
      "EarlyStopping counter: 6 out of 30\n",
      "Epoch: 181 cost time: 0.06666326522827148\n",
      "Epoch: 181, Steps: 4 | Train Loss: 0.0204503\n",
      "EarlyStopping counter: 7 out of 30\n",
      "Epoch: 182 cost time: 0.06837677955627441\n",
      "Epoch: 182, Steps: 4 | Train Loss: 0.0204275\n",
      "EarlyStopping counter: 8 out of 30\n",
      "Epoch: 183 cost time: 0.07104301452636719\n",
      "Epoch: 183, Steps: 4 | Train Loss: 0.0204263\n",
      "EarlyStopping counter: 9 out of 30\n",
      "Epoch: 184 cost time: 0.06696724891662598\n",
      "Epoch: 184, Steps: 4 | Train Loss: 0.0204157\n",
      "EarlyStopping counter: 10 out of 30\n",
      "Epoch: 185 cost time: 0.07275652885437012\n",
      "Epoch: 185, Steps: 4 | Train Loss: 0.0204229\n",
      "EarlyStopping counter: 11 out of 30\n",
      "Epoch: 186 cost time: 0.07369017601013184\n",
      "Epoch: 186, Steps: 4 | Train Loss: 0.0204151\n",
      "EarlyStopping counter: 12 out of 30\n",
      "Epoch: 187 cost time: 0.07186222076416016\n",
      "Epoch: 187, Steps: 4 | Train Loss: 0.0204008\n",
      "EarlyStopping counter: 13 out of 30\n",
      "Epoch: 188 cost time: 0.0725102424621582\n",
      "Epoch: 188, Steps: 4 | Train Loss: 0.0203803\n",
      "EarlyStopping counter: 14 out of 30\n",
      "Epoch: 189 cost time: 0.07277679443359375\n",
      "Epoch: 189, Steps: 4 | Train Loss: 0.0203909\n",
      "EarlyStopping counter: 15 out of 30\n",
      "Epoch: 190 cost time: 0.0730888843536377\n",
      "Epoch: 190, Steps: 4 | Train Loss: 0.0203799\n",
      "EarlyStopping counter: 16 out of 30\n",
      "Epoch: 191 cost time: 0.07207608222961426\n",
      "Epoch: 191, Steps: 4 | Train Loss: 0.0203548\n",
      "EarlyStopping counter: 17 out of 30\n",
      "Epoch: 192 cost time: 0.06702613830566406\n",
      "Epoch: 192, Steps: 4 | Train Loss: 0.0203160\n",
      "EarlyStopping counter: 18 out of 30\n",
      "Epoch: 193 cost time: 0.06567502021789551\n",
      "Epoch: 193, Steps: 4 | Train Loss: 0.0203529\n",
      "EarlyStopping counter: 19 out of 30\n",
      "Epoch: 194 cost time: 0.07405638694763184\n",
      "Epoch: 194, Steps: 4 | Train Loss: 0.0203500\n",
      "EarlyStopping counter: 20 out of 30\n",
      "Epoch: 195 cost time: 0.07094526290893555\n",
      "Epoch: 195, Steps: 4 | Train Loss: 0.0203236\n",
      "EarlyStopping counter: 21 out of 30\n",
      "Epoch: 196 cost time: 0.07419848442077637\n",
      "Epoch: 196, Steps: 4 | Train Loss: 0.0203158\n",
      "EarlyStopping counter: 22 out of 30\n",
      "Epoch: 197 cost time: 0.07036304473876953\n",
      "Epoch: 197, Steps: 4 | Train Loss: 0.0203239\n",
      "EarlyStopping counter: 23 out of 30\n",
      "Epoch: 198 cost time: 0.0754854679107666\n",
      "Epoch: 198, Steps: 4 | Train Loss: 0.0203100\n",
      "EarlyStopping counter: 24 out of 30\n",
      "Epoch: 199 cost time: 0.06951546669006348\n",
      "Epoch: 199, Steps: 4 | Train Loss: 0.0203128\n",
      "EarlyStopping counter: 25 out of 30\n",
      "Epoch: 200 cost time: 0.06727886199951172\n",
      "Epoch: 200, Steps: 4 | Train Loss: 0.0202938\n",
      "EarlyStopping counter: 26 out of 30\n",
      "Epoch: 201 cost time: 0.06669759750366211\n",
      "Epoch: 201, Steps: 4 | Train Loss: 0.0202812\n",
      "EarlyStopping counter: 27 out of 30\n",
      "Epoch: 202 cost time: 0.07251214981079102\n",
      "Epoch: 202, Steps: 4 | Train Loss: 0.0202811\n",
      "EarlyStopping counter: 28 out of 30\n",
      "Epoch: 203 cost time: 0.06555390357971191\n",
      "Epoch: 203, Steps: 4 | Train Loss: 0.0202828\n",
      "EarlyStopping counter: 29 out of 30\n",
      "Epoch: 204 cost time: 0.07454276084899902\n",
      "Epoch: 204, Steps: 4 | Train Loss: 0.0202801\n",
      "EarlyStopping counter: 30 out of 30\n",
      "Early stopping\n"
     ]
    }
   ],
   "source": [
    "A, index = ucl_sketch.get_current_state(return_A=True)\n",
    "solver = learningSolver(args, A.shape[1])\n",
    "solver.train(samples, A, index)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 🤔 Step 5 - Per-key frequency query"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Querying for all keys ...\n"
     ]
    }
   ],
   "source": [
    "results = {'GT': [], 'UCL': [], 'ES': [], 'UM': [], 'CM': [],\n",
    "           'CS': [], 'NS': [], 'LCM': [], 'LCS': []}\n",
    "\n",
    "print('Querying for all keys ...')\n",
    "\n",
    "for key, value in ground_truth.items():\n",
    "    c_ans = c_sketch.query(key)\n",
    "    cm_ans = cm_sketch.query(key)\n",
    "    nitro_ans = nitro_sketch.query(key)\n",
    "    ela_ans = elastic_sketch.query(key)\n",
    "    uni_ans = univmon.query(key)\n",
    "\n",
    "    if key in topk_keys:\n",
    "        lc_ans = value\n",
    "        lcm_ans = value\n",
    "    else:\n",
    "        lc_ans = lc_sketch.query(key)\n",
    "        lcm_ans = lcm_sketch.query(key)\n",
    "\n",
    "    if ucl_sketch.cmResult == {}:\n",
    "        test_sample = ucl_sketch.get_current_state(return_A=False)\n",
    "        x = solver.test(test_sample)\n",
    "        x = np.ceil(x.squeeze()).astype(np.int32)\n",
    "\n",
    "    ucl_ans = ucl_sketch.query(key, x)\n",
    "\n",
    "    results['GT'].append(value)\n",
    "    results['UCL'].append(ucl_ans)\n",
    "    results['ES'].append(ela_ans)\n",
    "    results['UM'].append(uni_ans)\n",
    "    results['CM'].append(cm_ans)\n",
    "    results['CS'].append(c_ans)\n",
    "    results['NS'].append(nitro_ans)\n",
    "    results['LCM'].append(lcm_ans)\n",
    "    results['LCS'].append(lc_ans)\n",
    "\n",
    "# np.save(f'./results/{args.data}_{memory}KB.npy', results)\n",
    "# print(f'Done. And results has been written into ./results/{args.data}_{memory}KB.npy')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 🏆 Step 6 - Caculate related metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Performace of UCL-sketch:\n",
      "—— AAE: 12.4103, ARE: 4.7685, WMRD: 0.3047, and Entropy Relative Error: 15.5663\n",
      "Performace of CM-sketch:\n",
      "—— AAE: 456.3511, ARE: 291.2143, WMRD: 1.9914, and Entropy Relative Error: 4128.0809\n",
      "Performace of C-sketch:\n",
      "—— AAE: 273.3547, ARE: 175.6649, WMRD: 1.8789, and Entropy Relative Error: 3070.0620\n",
      "Performace of Learned CM-sketch:\n",
      "—— AAE: 854.5208, ARE: 547.7251, WMRD: 1.9893, and Entropy Relative Error: 7481.3402\n",
      "Performace of Learned C-sketch:\n",
      "—— AAE: 575.7531, ARE: 369.7863, WMRD: 1.9849, and Entropy Relative Error: 5880.9794\n",
      "Performace of Elastic Sketch:\n",
      "—— AAE: 1019.7463, ARE: 649.9703, WMRD: 1.9976, and Entropy Relative Error: 9605.7521\n",
      "Performace of UnivMon:\n",
      "—— AAE: 392.5947, ARE: 251.3127, WMRD: 1.9350, and Entropy Relative Error: 4389.7128\n",
      "Performace of NitroSketch:\n",
      "—— AAE: 273.4365, ARE: 174.4529, WMRD: 1.9045, and Entropy Relative Error: 1192.2497\n"
     ]
    }
   ],
   "source": [
    "from Utils.mertrics import *\n",
    "\n",
    "GT = results['GT']\n",
    "\n",
    "print('Performace of UCL-sketch:')\n",
    "ET = results['UCL']\n",
    "AAE = average_absolute_error(GT, ET)\n",
    "ARE = average_relative_error(GT, ET)\n",
    "WMRD = weighted_mean_relative_difference(GT, ET)\n",
    "ERE = entropy_relative_error(GT, ET)\n",
    "print(f'—— AAE: {AAE:.4f}, ARE: {ARE:.4f}, WMRD: {WMRD:.4f}, and Entropy Relative Error: {ERE:.4f}')\n",
    "\n",
    "print('Performace of CM-sketch:')\n",
    "ET = results['CM']\n",
    "AAE = average_absolute_error(GT, ET)\n",
    "ARE = average_relative_error(GT, ET)\n",
    "WMRD = weighted_mean_relative_difference(GT, ET)\n",
    "ERE = entropy_relative_error(GT, ET)\n",
    "print(f'—— AAE: {AAE:.4f}, ARE: {ARE:.4f}, WMRD: {WMRD:.4f}, and Entropy Relative Error: {ERE:.4f}')\n",
    "\n",
    "print('Performace of C-sketch:')\n",
    "ET = results['CS']\n",
    "AAE = average_absolute_error(GT, ET)\n",
    "ARE = average_relative_error(GT, ET)\n",
    "WMRD = weighted_mean_relative_difference(GT, ET)\n",
    "ERE = entropy_relative_error(GT, ET)\n",
    "print(f'—— AAE: {AAE:.4f}, ARE: {ARE:.4f}, WMRD: {WMRD:.4f}, and Entropy Relative Error: {ERE:.4f}')\n",
    "\n",
    "print('Performace of Learned CM-sketch:')\n",
    "ET = results['LCM']\n",
    "AAE = average_absolute_error(GT, ET)\n",
    "ARE = average_relative_error(GT, ET)\n",
    "WMRD = weighted_mean_relative_difference(GT, ET)\n",
    "ERE = entropy_relative_error(GT, ET)\n",
    "print(f'—— AAE: {AAE:.4f}, ARE: {ARE:.4f}, WMRD: {WMRD:.4f}, and Entropy Relative Error: {ERE:.4f}')\n",
    "\n",
    "print('Performace of Learned C-sketch:')\n",
    "ET = results['LCS']\n",
    "AAE = average_absolute_error(GT, ET)\n",
    "ARE = average_relative_error(GT, ET)\n",
    "WMRD = weighted_mean_relative_difference(GT, ET)\n",
    "ERE = entropy_relative_error(GT, ET)\n",
    "print(f'—— AAE: {AAE:.4f}, ARE: {ARE:.4f}, WMRD: {WMRD:.4f}, and Entropy Relative Error: {ERE:.4f}')\n",
    "\n",
    "print('Performace of Elastic Sketch:')\n",
    "ET = results['ES']\n",
    "AAE = average_absolute_error(GT, ET)\n",
    "ARE = average_relative_error(GT, ET)\n",
    "WMRD = weighted_mean_relative_difference(GT, ET)\n",
    "ERE = entropy_relative_error(GT, ET)\n",
    "print(f'—— AAE: {AAE:.4f}, ARE: {ARE:.4f}, WMRD: {WMRD:.4f}, and Entropy Relative Error: {ERE:.4f}')\n",
    "\n",
    "print('Performace of UnivMon:')\n",
    "ET = results['UM']\n",
    "AAE = average_absolute_error(GT, ET)\n",
    "ARE = average_relative_error(GT, ET)\n",
    "WMRD = weighted_mean_relative_difference(GT, ET)\n",
    "ERE = entropy_relative_error(GT, ET)\n",
    "print(f'—— AAE: {AAE:.4f}, ARE: {ARE:.4f}, WMRD: {WMRD:.4f}, and Entropy Relative Error: {ERE:.4f}')\n",
    "\n",
    "print('Performace of NitroSketch:')\n",
    "ET = results['NS']\n",
    "AAE = average_absolute_error(GT, ET)\n",
    "ARE = average_relative_error(GT, ET)\n",
    "WMRD = weighted_mean_relative_difference(GT, ET)\n",
    "ERE = entropy_relative_error(GT, ET)\n",
    "print(f'—— AAE: {AAE:.4f}, ARE: {ARE:.4f}, WMRD: {WMRD:.4f}, and Entropy Relative Error: {ERE:.4f}')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "DPlearning_3.8",
   "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.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
