{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# install / upgrade necessary packages\n",
    "# !pip install easydict\n",
    "# !pip install numpy\n",
    "# !pip install numpy --upgrade # upgrade numpy to at least 1.16\n",
    "# !pip install torch --upgrade # upgrade pytorch to 1.5.1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "numpy version: 1.19.2\n",
      "pytorch version: 1.9.1+cu102\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "from easydict import EasyDict\n",
    "from utils import *\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "import numpy as np\n",
    "import random\n",
    "# set experiment configs\n",
    "opt = EasyDict()\n",
    "# choose a dataset from [\"quarter-circle\", \"half-circle\"]\n",
    "opt.data = \"half-circle\"\n",
    "# choose a model from [\"CIDA\", \"PCIDA\", \"ADDA\", \"SO\", \"DANN\", \"CDANN\", \"MDD\", \"CUA\"]\n",
    "opt.model = \"ADDA\"\n",
    "# choose run on which device [\"cuda\", \"cpu\"]\n",
    "opt.device = \"cuda\"\n",
    "\n",
    "# set random seed\n",
    "opt.seed = 2333\n",
    "\n",
    "print(\"numpy version:\", np.__version__)\n",
    "print(\"pytorch version:\", torch.__version__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# training configs\n",
    "opt.num_epoch = 800\n",
    "opt.batch_size = 10\n",
    "opt.lr = 1e-4\n",
    "opt.lr_T = 1e-4\n",
    "opt.gamma = 100\n",
    "opt.beta1 = 0.9\n",
    "opt.weight_decay = 5e-4\n",
    "opt.wgan = False\n",
    "opt.no_bn = True  # do not use batch normalization # True\n",
    "\n",
    "# model size configs\n",
    "opt.nx = 2  # dimension of the input data\n",
    "opt.nh = 800  # dimension of hidden\n",
    "opt.nc = 2  # number of label class\n",
    "\n",
    "# dataset configs\n",
    "\n",
    "opt.dim_domain = 1  # dimension of domain index\n",
    "\n",
    "# number of domains in the dataset\n",
    "if opt.data == \"quarter-circle\":\n",
    "    opt.num_domain = 15\n",
    "    opt.num_source = 6\n",
    "    opt.normalize_domain = False\n",
    "elif opt.data == \"half-circle\":\n",
    "    opt.num_domain = 30\n",
    "    opt.num_source = 6\n",
    "    opt.normalize_domain = False    \n",
    "elif opt.data == \"sine\":\n",
    "    opt.num_domain = 12\n",
    "    opt.num_source = 5\n",
    "    opt.normalize_domain = True  # normalize data per domain\n",
    "else:\n",
    "    assert False, \"Can't find data\"\n",
    "opt.num_target = opt.num_domain - opt.num_source\n",
    "\n",
    "# model specific configs\n",
    "\n",
    "opt.cond_disc = False  # use conditional discriminator\n",
    "opt.continual_da = False  # use continual domain adaptation\n",
    "\n",
    "opt.lambda_gan = 2.0\n",
    "\n",
    "if opt.model == 'CIDA':\n",
    "    opt.lambda_gan = 0.4\n",
    "\n",
    "elif opt.model == 'PCIDA':\n",
    "    opt.lambda_gan = 1.0\n",
    "    opt.nmix = 1  # number of mix guassian for the discriminator prediction\n",
    "    # opt.no_bn = False\n",
    "\n",
    "elif opt.model == \"MDD\":\n",
    "    opt.lambda_src = 1.0\n",
    "    opt.lambda_tgt = 1.0\n",
    "    opt.lambda_gan = 2.0\n",
    "    opt.num_epoch = 160  # early stop (optional) \n",
    "\n",
    "elif opt.model == 'CDANN':\n",
    "    opt.cond_disc = True\n",
    "\n",
    "elif opt.model == 'CUA':\n",
    "    opt.continual_da = True\n",
    "    opt.num_da_step = 5  # number of steps of domain adaptation\n",
    "    opt.num_epoch_pre = 10  # number of epochs of pretraining in source domain\n",
    "    opt.num_epoch_sub = 50  # number of epochs of adapting to a new sub target domain\n",
    "    opt.lr_decay_period = 500\n",
    "    opt.lambda_gan = 1.0\n",
    "    opt.lambda_rpy = 0.3\n",
    "\n",
    "opt.exp = opt.data + '_' + opt.model\n",
    "opt.outf = './dump/' + opt.exp\n",
    "os.system('mkdir -p ' + opt.outf)\n",
    "\n",
    "opt.use_resample = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data: (3000, 2)\n",
      "Label: (3000,)\n",
      "SeqDataset Size 100 Sub Size [100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100]\n"
     ]
    }
   ],
   "source": [
    "from dataset import *\n",
    "from plot import plot_dataset\n",
    "\n",
    "# load raw data\n",
    "data_pkl = read_pickle(f'./data/{opt.data}.pkl')\n",
    "print(f\"Data: {data_pkl['data'].shape}\\nLabel: {data_pkl['label'].shape}\")\n",
    "# visualize raw data\n",
    "plot_dataset(data_pkl)\n",
    "\n",
    "# build dataset\n",
    "data = data_pkl['data']\n",
    "data_mean = data.mean(0, keepdims=True)\n",
    "data_std = data.std(0, keepdims=True)\n",
    "data_pkl['data'] = (data - data_mean) / data_std  # normalize the raw data\n",
    "datasets = [ToyDataset(data_pkl, i, opt) for i in range(opt.num_domain)]  # sub dataset for each domain\n",
    "dataset = SeqToyDataset(datasets, size=len(datasets[0]))  # mix sub dataset to a large one\n",
    "dataloader = DataLoader(\n",
    "    dataset=dataset,\n",
    "    shuffle=True,\n",
    "    batch_size=opt.batch_size\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n",
      "===> Discrinimator Output Activation: sigmoid\n",
      "ADDA(\n",
      "  (netE): FeatureNet(\n",
      "    (fc1): Linear(in_features=2, out_features=800, bias=True)\n",
      "    (fc2): Linear(in_features=1600, out_features=1600, bias=True)\n",
      "    (fc3): Linear(in_features=1600, out_features=1600, bias=True)\n",
      "    (fc4): Linear(in_features=1600, out_features=1600, bias=True)\n",
      "    (fc_final): Linear(in_features=1600, out_features=800, bias=True)\n",
      "    (fc1_var): Linear(in_features=1, out_features=800, bias=True)\n",
      "    (fc2_var): Linear(in_features=800, out_features=800, bias=True)\n",
      "  )\n",
      "  (netF): PredNet(\n",
      "    (fc3): Linear(in_features=800, out_features=800, bias=True)\n",
      "    (bn3): Identity()\n",
      "    (fc4): Linear(in_features=800, out_features=800, bias=True)\n",
      "    (bn4): Identity()\n",
      "    (fc_final): Linear(in_features=800, out_features=2, bias=True)\n",
      "  )\n",
      "  (netD): DiscNet(\n",
      "    (fc3): Linear(in_features=800, out_features=800, bias=True)\n",
      "    (bn3): Identity()\n",
      "    (fc4): Linear(in_features=800, out_features=800, bias=True)\n",
      "    (bn4): Identity()\n",
      "    (fc5): Linear(in_features=800, out_features=800, bias=True)\n",
      "    (bn5): Identity()\n",
      "    (fc6): Linear(in_features=800, out_features=800, bias=True)\n",
      "    (bn6): Identity()\n",
      "    (fc7): Linear(in_features=800, out_features=800, bias=True)\n",
      "    (bn7): Identity()\n",
      "    (fc_final): Linear(in_features=800, out_features=1, bias=True)\n",
      "  )\n",
      ")\n",
      "[Train][9] Loss: D 1.324 E_gan 0.902 E_pred 0.141\n",
      "[Train][9] Accuracy: total average 61.2, in each domain [88. 88. 94. 99. 96. 97. 95. 85. 74. 67. 55. 47. 44. 49. 47. 32. 43. 54.\n",
      " 58. 46. 43. 49. 51. 44. 55. 49. 42. 45. 55. 44.]\n",
      "[Train][19] Loss: D 1.367 E_gan 0.800 E_pred 0.090\n",
      "[Train][19] Accuracy: total average 76.2, in each domain [ 97.  99.  98. 100.  99.  97.  96.  94.  94.  93.  92.  89.  86.  80.\n",
      "  88.  86.  83.  78.  80.  62.  58.  52.  52.  44.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][29] Loss: D 1.385 E_gan 1.001 E_pred 0.137\n",
      "[Train][29] Accuracy: total average 71.2, in each domain [94. 91. 95. 96. 98. 95. 98. 97. 91. 77. 72. 71. 64. 51. 58. 70. 57. 47.\n",
      " 46. 57. 63. 61. 68. 74. 62. 62. 64. 55. 53. 50.]\n",
      "[Train][39] Loss: D 1.307 E_gan 0.869 E_pred 0.113\n",
      "[Train][39] Accuracy: total average 67.9, in each domain [92. 96. 96. 94. 96. 97. 95. 93. 92. 78. 75. 70. 63. 53. 56. 70. 57. 46.\n",
      " 42. 54. 57. 51. 49. 56. 45. 51. 58. 55. 45. 56.]\n",
      "[Train][49] Loss: D 1.339 E_gan 0.817 E_pred 0.042\n",
      "[Train][49] Accuracy: total average 76.3, in each domain [ 99.  98. 100. 100.  99.  99.  99.  98.  97.  92.  88.  88.  70.  64.\n",
      "  68.  78.  60.  48.  58.  61.  68.  72.  66.  81.  73.  60.  54.  46.\n",
      "  56.  48.]\n",
      "[Test][49] Accuracy: total average 79.1, in each domain [ 98.  97.  98. 100.  99. 100.  98.  97.  97.  98.  94.  93.  84.  76.\n",
      "  77.  83.  74.  74.  81.  83.  86.  81.  68.  46.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][59] Loss: D 1.363 E_gan 0.781 E_pred 0.061\n",
      "[Train][59] Accuracy: total average 74.7, in each domain [98. 94. 98. 98. 98. 99. 99. 97. 95. 84. 80. 79. 66. 59. 67. 78. 65. 58.\n",
      " 70. 76. 83. 81. 75. 53. 56. 49. 42. 45. 55. 44.]\n",
      "[Train][69] Loss: D 1.374 E_gan 0.940 E_pred 0.117\n",
      "[Train][69] Accuracy: total average 76.1, in each domain [89. 97. 90. 96. 99. 97. 94. 96. 97. 96. 94. 90. 74. 68. 75. 84. 72. 70.\n",
      " 82. 79. 81. 74. 56. 44. 55. 49. 42. 45. 55. 44.]\n",
      "[Train][79] Loss: D 1.371 E_gan 0.859 E_pred 0.040\n",
      "[Train][79] Accuracy: total average 75.0, in each domain [ 98.  94.  99.  98.  99. 100.  98.  98.  96.  91.  85.  85.  67.  62.\n",
      "  67.  77.  62.  56.  64.  68.  82.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][89] Loss: D 1.361 E_gan 0.860 E_pred 0.082\n",
      "[Train][89] Accuracy: total average 74.5, in each domain [ 96.  93.  95. 100.  99.  99.  97. 100.  94.  90.  89.  84.  66.  61.\n",
      "  67.  77.  64.  53.  64.  66.  78.  78.  80.  55.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][99] Loss: D 1.391 E_gan 0.761 E_pred 0.064\n",
      "[Train][99] Accuracy: total average 73.9, in each domain [ 93.  96.  97.  99.  98. 100.  98.  98.  98.  90.  86.  83.  66.  59.\n",
      "  66.  75.  61.  52.  66.  70.  81.  77.  73.  46.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][99] Accuracy: total average 73.9, in each domain [ 98.  97.  97. 100.  98. 100.  98.  98.  98.  89.  85.  80.  66.  58.\n",
      "  62.  75.  59.  51.  65.  68.  82.  78.  75.  50.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][109] Loss: D 1.355 E_gan 0.873 E_pred 0.045\n",
      "[Train][109] Accuracy: total average 74.0, in each domain [ 95.  97. 100.  99.  97. 100.  97.  99.  98.  88.  84.  82.  66.  59.\n",
      "  64.  76.  60.  50.  61.  65.  75.  81.  80.  56.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][119] Loss: D 1.388 E_gan 0.705 E_pred 0.035\n",
      "[Train][119] Accuracy: total average 74.4, in each domain [97. 97. 99. 99. 99. 99. 98. 98. 98. 93. 86. 84. 66. 60. 66. 77. 60. 51.\n",
      " 65. 68. 82. 78. 73. 48. 55. 49. 42. 45. 55. 44.]\n",
      "[Train][129] Loss: D 1.384 E_gan 0.707 E_pred 0.049\n",
      "[Train][129] Accuracy: total average 73.5, in each domain [ 97.  97.  97.  99.  98. 100.  98.  99.  97.  89.  85.  78.  66.  58.\n",
      "  63.  76.  59.  51.  62.  67.  82.  78.  71.  47.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][139] Loss: D 1.382 E_gan 0.704 E_pred 0.021\n",
      "[Train][139] Accuracy: total average 73.4, in each domain [ 99.  99. 100. 100.  99. 100.  99.  99.  97.  88.  84.  77.  65.  54.\n",
      "  59.  74.  58.  50.  61.  66.  76.  80.  77.  52.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][149] Loss: D 1.385 E_gan 0.706 E_pred 0.028\n",
      "[Train][149] Accuracy: total average 73.8, in each domain [ 98.  96.  98. 100. 100. 100.  99. 100.  96.  89.  84.  80.  66.  58.\n",
      "  64.  76.  60.  52.  64.  68.  81.  77.  71.  47.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][149] Accuracy: total average 73.7, in each domain [ 99.  97.  99. 100.  99.  99.  98. 100.  96.  89.  84.  78.  66.  58.\n",
      "  64.  76.  59.  51.  63.  68.  81.  78.  71.  48.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][159] Loss: D 1.384 E_gan 0.698 E_pred 0.019\n",
      "[Train][159] Accuracy: total average 74.0, in each domain [ 99. 100. 100. 100.  99.  99.  99. 100.  97.  89.  84.  80.  66.  59.\n",
      "  64.  77.  60.  53.  66.  67.  82.  77.  69.  45.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][169] Loss: D 1.384 E_gan 0.709 E_pred 0.015\n",
      "[Train][169] Accuracy: total average 74.2, in each domain [ 99.  99.  99. 100.  99. 100.  99. 100.  97.  89.  84.  81.  66.  60.\n",
      "  65.  77.  61.  54.  66.  69.  81.  78.  69.  44.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][179] Loss: D 1.387 E_gan 0.703 E_pred 0.018\n",
      "[Train][179] Accuracy: total average 74.4, in each domain [100.  98.  98. 100. 100. 100. 100. 100.  96.  89.  83.  81.  66.  60.\n",
      "  66.  77.  61.  55.  66.  69.  83.  77.  71.  46.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][189] Loss: D 1.385 E_gan 0.705 E_pred 0.016\n",
      "[Train][189] Accuracy: total average 74.5, in each domain [ 99.  99.  99. 100. 100. 100. 100. 100.  96.  89.  83.  81.  66.  60.\n",
      "  66.  77.  61.  53.  66.  69.  83.  78.  71.  48.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][199] Loss: D 1.385 E_gan 0.701 E_pred 0.028\n",
      "[Train][199] Accuracy: total average 74.6, in each domain [ 98.  97.  98. 100.  98. 100.  99. 100.  96.  89.  86.  82.  66.  61.\n",
      "  67.  77.  64.  56.  66.  69.  83.  78.  72.  47.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][199] Accuracy: total average 74.7, in each domain [ 99.  98.  99. 100.  99. 100. 100. 100.  96.  89.  84.  82.  66.  61.\n",
      "  67.  77.  63.  56.  66.  69.  83.  78.  72.  48.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][209] Loss: D 1.385 E_gan 0.707 E_pred 0.007\n",
      "[Train][209] Accuracy: total average 74.9, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  84.  82.  66.  61.\n",
      "  67.  77.  63.  56.  66.  69.  82.  78.  73.  48.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][219] Loss: D 1.386 E_gan 0.704 E_pred 0.011\n",
      "[Train][219] Accuracy: total average 75.2, in each domain [ 98.  98. 100. 100. 100. 100. 100. 100.  96.  90.  87.  83.  67.  62.\n",
      "  67.  78.  65.  56.  66.  70.  83.  78.  75.  48.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][229] Loss: D 1.386 E_gan 0.700 E_pred 0.008\n",
      "[Train][229] Accuracy: total average 75.2, in each domain [100. 100.  99. 100. 100. 100. 100. 100.  96.  90.  86.  82.  66.  61.\n",
      "  67.  77.  64.  56.  66.  68.  82.  79.  76.  50.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][239] Loss: D 1.387 E_gan 0.702 E_pred 0.007\n",
      "[Train][239] Accuracy: total average 75.3, in each domain [100.  99. 100. 100. 100. 100. 100. 100.  96.  90.  86.  82.  66.  61.\n",
      "  67.  78.  65.  56.  66.  68.  82.  80.  76.  50.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][249] Loss: D 1.386 E_gan 0.697 E_pred 0.008\n",
      "[Train][249] Accuracy: total average 75.1, in each domain [100.  99. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  63.  55.  64.  68.  80.  80.  78.  52.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][249] Accuracy: total average 75.0, in each domain [100.  99. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  63.  55.  64.  68.  79.  80.  78.  52.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][259] Loss: D 1.386 E_gan 0.704 E_pred 0.008\n",
      "[Train][259] Accuracy: total average 75.3, in each domain [100. 100.  99. 100. 100. 100.  99. 100.  96.  90.  86.  82.  66.  61.\n",
      "  67.  77.  65.  56.  65.  68.  81.  81.  78.  52.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][269] Loss: D 1.386 E_gan 0.682 E_pred 0.011\n",
      "[Train][269] Accuracy: total average 75.3, in each domain [ 99. 100.  99.  99. 100. 100. 100.  99.  97.  90.  86.  83.  66.  61.\n",
      "  67.  77.  64.  56.  65.  68.  82.  80.  78.  52.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][279] Loss: D 1.386 E_gan 0.698 E_pred 0.018\n",
      "[Train][279] Accuracy: total average 75.0, in each domain [ 98.  99.  98. 100.  99. 100. 100. 100.  96.  89.  84.  82.  66.  61.\n",
      "  67.  77.  63.  55.  64.  68.  81.  80.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][289] Loss: D 1.386 E_gan 0.706 E_pred 0.006\n",
      "[Train][289] Accuracy: total average 75.5, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  90.  86.  82.  66.  61.\n",
      "  67.  77.  65.  56.  66.  68.  83.  81.  78.  52.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][299] Loss: D 1.386 E_gan 0.688 E_pred 0.005\n",
      "[Train][299] Accuracy: total average 75.4, in each domain [100.  99. 100. 100. 100. 100. 100. 100.  96.  90.  86.  82.  66.  61.\n",
      "  67.  77.  65.  56.  66.  68.  83.  80.  78.  52.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][299] Accuracy: total average 75.4, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  90.  86.  82.  66.  61.\n",
      "  67.  77.  65.  56.  66.  68.  81.  80.  78.  52.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][309] Loss: D 1.387 E_gan 0.701 E_pred 0.005\n",
      "[Train][309] Accuracy: total average 75.2, in each domain [100. 100. 100. 100. 100. 100. 100.  99.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  63.  55.  64.  68.  81.  80.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][319] Loss: D 1.386 E_gan 0.689 E_pred 0.018\n",
      "[Train][319] Accuracy: total average 75.2, in each domain [ 98.  98. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  65.  56.  66.  68.  81.  80.  78.  52.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][329] Loss: D 1.386 E_gan 0.688 E_pred 0.005\n",
      "[Train][329] Accuracy: total average 75.4, in each domain [100.  99. 100. 100. 100. 100.  99. 100.  96.  90.  86.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  68.  83.  81.  78.  52.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][339] Loss: D 1.387 E_gan 0.715 E_pred 0.012\n",
      "[Train][339] Accuracy: total average 75.6, in each domain [100.  98.  99. 100. 100. 100.  99. 100.  97.  90.  86.  82.  66.  61.\n",
      "  67.  78.  66.  57.  66.  70.  84.  81.  78.  52.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][349] Loss: D 1.386 E_gan 0.685 E_pred 0.004\n",
      "[Train][349] Accuracy: total average 75.3, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  65.  56.  66.  68.  81.  80.  78.  53.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][349] Accuracy: total average 75.4, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  65.  56.  66.  68.  83.  81.  78.  53.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][359] Loss: D 1.386 E_gan 0.695 E_pred 0.010\n",
      "[Train][359] Accuracy: total average 75.3, in each domain [100.  99.  98. 100. 100. 100. 100. 100.  96.  89.  86.  82.  66.  61.\n",
      "  67.  77.  65.  56.  66.  68.  83.  81.  78.  52.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][369] Loss: D 1.386 E_gan 0.687 E_pred 0.004\n",
      "[Train][369] Accuracy: total average 75.5, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  65.  56.  66.  68.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][379] Loss: D 1.386 E_gan 0.690 E_pred 0.003\n",
      "[Train][379] Accuracy: total average 75.4, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  64.  56.  66.  68.  82.  80.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][389] Loss: D 1.386 E_gan 0.694 E_pred 0.005\n",
      "[Train][389] Accuracy: total average 75.3, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  63.  56.  65.  68.  82.  80.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][399] Loss: D 1.386 E_gan 0.694 E_pred 0.004\n",
      "[Train][399] Accuracy: total average 75.4, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  65.  56.  66.  68.  82.  80.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][399] Accuracy: total average 75.4, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  65.  56.  66.  68.  82.  80.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][409] Loss: D 1.386 E_gan 0.696 E_pred 0.004\n",
      "[Train][409] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  86.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  70.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][419] Loss: D 1.386 E_gan 0.691 E_pred 0.007\n",
      "[Train][419] Accuracy: total average 75.3, in each domain [ 99.  99. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  65.  56.  66.  68.  82.  80.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][429] Loss: D 1.386 E_gan 0.694 E_pred 0.003\n",
      "[Train][429] Accuracy: total average 75.5, in each domain [100. 100. 100. 100. 100. 100.  99. 100.  96.  89.  86.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  68.  83.  80.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][439] Loss: D 1.386 E_gan 0.691 E_pred 0.003\n",
      "[Train][439] Accuracy: total average 75.4, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  68.  82.  80.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][449] Loss: D 1.386 E_gan 0.688 E_pred 0.003\n",
      "[Train][449] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  70.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][449] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  70.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][459] Loss: D 1.386 E_gan 0.696 E_pred 0.004\n",
      "[Train][459] Accuracy: total average 75.5, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  68.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][469] Loss: D 1.386 E_gan 0.692 E_pred 0.003\n",
      "[Train][469] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  70.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][479] Loss: D 1.386 E_gan 0.693 E_pred 0.003\n",
      "[Train][479] Accuracy: total average 75.5, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  69.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][489] Loss: D 1.386 E_gan 0.693 E_pred 0.003\n",
      "[Train][489] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][499] Loss: D 1.386 E_gan 0.690 E_pred 0.003\n",
      "[Train][499] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][499] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  70.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][509] Loss: D 1.386 E_gan 0.693 E_pred 0.003\n",
      "[Train][509] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][519] Loss: D 1.386 E_gan 0.695 E_pred 0.003\n",
      "[Train][519] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][529] Loss: D 1.386 E_gan 0.693 E_pred 0.003\n",
      "[Train][529] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][539] Loss: D 1.386 E_gan 0.690 E_pred 0.003\n",
      "[Train][539] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100.  99. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  67.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][549] Loss: D 1.386 E_gan 0.695 E_pred 0.003\n",
      "[Train][549] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  70.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][549] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  70.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][559] Loss: D 1.386 E_gan 0.695 E_pred 0.002\n",
      "[Train][559] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][569] Loss: D 1.386 E_gan 0.693 E_pred 0.003\n",
      "[Train][569] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  70.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][579] Loss: D 1.386 E_gan 0.692 E_pred 0.003\n",
      "[Train][579] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  70.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][589] Loss: D 1.386 E_gan 0.693 E_pred 0.002\n",
      "[Train][589] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  70.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][599] Loss: D 1.386 E_gan 0.693 E_pred 0.002\n",
      "[Train][599] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][599] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][609] Loss: D 1.386 E_gan 0.692 E_pred 0.002\n",
      "[Train][609] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  70.  83.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][619] Loss: D 1.386 E_gan 0.694 E_pred 0.003\n",
      "[Train][619] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  56.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][629] Loss: D 1.386 E_gan 0.692 E_pred 0.002\n",
      "[Train][629] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][639] Loss: D 1.386 E_gan 0.694 E_pred 0.002\n",
      "[Train][639] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][649] Loss: D 1.386 E_gan 0.694 E_pred 0.002\n",
      "[Train][649] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][649] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][659] Loss: D 1.386 E_gan 0.694 E_pred 0.002\n",
      "[Train][659] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][669] Loss: D 1.386 E_gan 0.694 E_pred 0.002\n",
      "[Train][669] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][679] Loss: D 1.386 E_gan 0.693 E_pred 0.002\n",
      "[Train][679] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][689] Loss: D 1.386 E_gan 0.694 E_pred 0.002\n",
      "[Train][689] Accuracy: total average 75.7, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  58.  67.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][699] Loss: D 1.386 E_gan 0.694 E_pred 0.002\n",
      "[Train][699] Accuracy: total average 75.7, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  58.  67.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][699] Accuracy: total average 75.7, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  58.  67.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][709] Loss: D 1.386 E_gan 0.694 E_pred 0.002\n",
      "[Train][709] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][719] Loss: D 1.386 E_gan 0.693 E_pred 0.002\n",
      "[Train][719] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][729] Loss: D 1.386 E_gan 0.694 E_pred 0.002\n",
      "[Train][729] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][739] Loss: D 1.386 E_gan 0.694 E_pred 0.002\n",
      "[Train][739] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][749] Loss: D 1.386 E_gan 0.693 E_pred 0.002\n",
      "[Train][749] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][749] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][759] Loss: D 1.386 E_gan 0.694 E_pred 0.002\n",
      "[Train][759] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][769] Loss: D 1.386 E_gan 0.693 E_pred 0.002\n",
      "[Train][769] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][779] Loss: D 1.386 E_gan 0.694 E_pred 0.002\n",
      "[Train][779] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][789] Loss: D 1.386 E_gan 0.694 E_pred 0.002\n",
      "[Train][789] Accuracy: total average 75.6, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  66.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Train][799] Loss: D 1.386 E_gan 0.693 E_pred 0.002\n",
      "[Train][799] Accuracy: total average 75.7, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  67.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n",
      "[Test][799] Accuracy: total average 75.7, in each domain [100. 100. 100. 100. 100. 100. 100. 100.  96.  89.  85.  82.  66.  61.\n",
      "  67.  77.  66.  57.  67.  70.  84.  81.  78.  54.  55.  49.  42.  45.\n",
      "  55.  44.]\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "from model import get_model\n",
    "\n",
    "# set random seed (for reproducibility)\n",
    "np.random.seed(opt.seed)\n",
    "random.seed(opt.seed)\n",
    "torch.manual_seed(opt.seed)\n",
    "\n",
    "# build the model\n",
    "modelClass = get_model(opt.model)\n",
    "model = modelClass(opt)\n",
    "model.to(opt.device)\n",
    "print(model)\n",
    "\n",
    "if opt.normalize_domain:\n",
    "    model.set_data_stats(\n",
    "        dm=[d.data_m for d in datasets],\n",
    "        ds=[d.data_s for d in datasets],\n",
    "    )\n",
    "    \n",
    "# train the model\n",
    "if not opt.continual_da:\n",
    "    # one-step adaptation\n",
    "    for epoch in range(opt.num_epoch):\n",
    "        model.learn(epoch, dataloader)\n",
    "        if (epoch + 1) % 100 == 0 or (epoch + 1) == opt.num_epoch:\n",
    "            model.save()\n",
    "            # model.visualize_D()\n",
    "            # model.visualize_F()\n",
    "            # model.visualize_E()\n",
    "        if (epoch + 1) % 50 == 0:    \n",
    "            model.test(epoch, dataloader)\n",
    "else:\n",
    "    # pretrain on source\n",
    "    print('===> pretrain the classifer')\n",
    "    model.prepare_trainer(init=True)\n",
    "    for epoch in range(opt.num_epoch_pre):\n",
    "        model.learn(epoch, dataloader, init=True)\n",
    "        if (epoch + 1) % 10 == 0:\n",
    "            model.save()\n",
    "            model.visualize_F()\n",
    "            model.test(epoch, dataloader)\n",
    "    # step-by-step domain adapt\n",
    "    ds_size = len(datasets[0])\n",
    "    replay_datasets = [datasets[i] for i in range(opt.num_source)]\n",
    "    print('===> start continual DA')\n",
    "    model.prepare_trainer(init=False)\n",
    "    for phase in range(opt.num_source, opt.num_domain):\n",
    "        continual_dataset = SeqToyDataset(replay_datasets, size=ds_size)\n",
    "        continual_dataloader = DataLoader(\n",
    "            dataset=continual_dataset,\n",
    "            shuffle=True,\n",
    "            batch_size=opt.batch_size,\n",
    "            num_workers=4,\n",
    "        )\n",
    "        model.set_phase(phase)\n",
    "        for epoch in range(opt.num_epoch_sub):\n",
    "            model.learn(epoch, (dataloader, continual_dataloader), init=False)\n",
    "        # model.visualize_F(phase)\n",
    "        model.save()\n",
    "        model.test(epoch, dataloader)\n",
    "        replay_data, replay_label = model.gen_replay_dataset(dataloader)\n",
    "        replay_datasets.append(ReplayDataset(replay_data, replay_label, opt))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(3000, 2)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x324 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# visualize the model result\n",
    "from plot import plot_data_and_label\n",
    "from matplotlib.backends.backend_pdf import PdfPages\n",
    "plt.rc('font',family='Times New Roman')\n",
    "info = read_pickle(opt.outf + '/pred.pkl')\n",
    "fig, ax = plt.subplots(1, 1, figsize=(6, 6 * 0.75))\n",
    "print(info['data'].shape)\n",
    "info['data'] = info['data'] * data_std + data_mean\n",
    "plot_data_and_label(ax, info['data'], info['label'])\n",
    "plt.tight_layout(h_pad=-0.1)\n",
    "pdf = PdfPages('%s.pdf' % ('MMD'))\n",
    "pdf.savefig()\n",
    "pdf.close()\n",
    "plt.show()\n",
    "plt.close()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
