{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "72a27a16",
   "metadata": {},
   "source": [
    "# Import libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "f031f752",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ENV WARNING] deactivate virtualenv to allow for testing Actionable Recourse\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "from dirrac.data.synthetic_data import DataSynthesizer\n",
    "from dirrac.classifier.logistic import logistic_classifier\n",
    "from dirrac.optim.opt import Optimization\n",
    "from roar.gen_counterfactual import ROAR\n",
    "from dirrac.gen_counterfactual import DRRA\n",
    "from utils import cal_validity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "af770047",
   "metadata": {},
   "outputs": [],
   "source": [
    "if not os.path.exists('result/figure9/'):\n",
    "    os.makedirs('result/figure9/')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cb6a6b67",
   "metadata": {},
   "source": [
    "# Synthesize data and train original classifier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b8c0ebac",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Synthesize data\n",
    "mean_0 = np.ones(2) * (-3)\n",
    "mean_1 = np.ones(2) * 3\n",
    "cov_0 = cov_1 = np.identity(2)\n",
    "n = 1000\n",
    "p = [0.4, 0.2, 0.4]\n",
    "\n",
    "sd = DataSynthesizer(mean_0, cov_0, mean_1, cov_1, n)\n",
    "features, labels = sd.synthesize_modes_data(100, [0.4, 0.2, 0.4], [0.1, 0.1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "id": "c5b9e79a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train\n",
    "all_coef = np.zeros((101, 2))\n",
    "for i in range(101):\n",
    "    coef = logistic_classifier(features[i], labels[i])[1].T\n",
    "    all_coef[i] = np.squeeze(coef)\n",
    "\n",
    "# Get theta\n",
    "mean_shift = all_coef[1:41]\n",
    "cov_shift = all_coef[41:61]\n",
    "both_shift = all_coef[61:101]\n",
    "\n",
    "theta = np.zeros((3, 2))\n",
    "sigma = np.zeros((3, 2, 2))\n",
    "\n",
    "theta[0], sigma[0] = np.mean(mean_shift, axis=0), np.cov(mean_shift.T)\n",
    "theta[1], sigma[1] = np.mean(cov_shift, axis=0), np.cov(cov_shift.T)\n",
    "theta[2], sigma[2] = np.mean(both_shift, axis=0), np.cov(both_shift.T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "id": "4a983835",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train a classifier\n",
    "X_train, X_test, y_train, y_test = train_test_split(features[0], labels[0], test_size=0.1, random_state=42)\n",
    "\n",
    "# Train and get theta\n",
    "clf, coef = logistic_classifier(X_train, y_train)\n",
    "\n",
    "yhat = clf.predict(X_test)\n",
    "X_recourse = X_test[yhat == 0]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6fe1cb22",
   "metadata": {},
   "source": [
    "# Define function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "id": "479c80a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Optimization module\n",
    "delta_l = [1e-3, 0.02, 0.04, 0.06, 0.08, 0.1, 0.12, 0.14, 0.16, 0.18, 0.2]\n",
    "k = 3\n",
    "dim = 2\n",
    "rho = np.array([0, 0, 0])\n",
    "lmbda = 0.7\n",
    "zeta = 1\n",
    "\n",
    "features_shift, labels_shift = sd.synthesize_modes_data(1000, [0.1, 0.8, 0.1], [0.3, 0.3])\n",
    "clf_shift = [logistic_classifier(features_shift[i + 1], labels_shift[i + 1])[0] for i in range(len(features_shift) - 1)]\n",
    "\n",
    "def recourse_cost(X_recourse):\n",
    "    \n",
    "    cost_dirrac, cost_roar = [], []\n",
    "    val_dirrac, val_roar = [], []\n",
    "    \n",
    "    # delta_l = [1e-3, 7e-3, 8e-3, 0.05, 0.1]\n",
    "    delta_l = [1e-3, 5e-3, 0.0065, 7e-3, 0.0075, 0.0076, 1e-2, 0.1, 1, 2.5]\n",
    "    dirrac_l = [DRRA(delta_l[i], k, dim, p, theta, sigma, rho, lmbda, zeta, dist_type='l1') for i in range(len(delta_l))]\n",
    "    \n",
    "    iter_l = [25, 26, 27, 28, 29, 30, 31, 32, 33, 34]\n",
    "    roar_l = [ROAR(X_recourse, all_coef[0], np.zeros(1), 1e-3, 0.1, sigma_max=0.1, alpha=1, dist_type='l1', max_iter=iter_l[i]) for i in range(len(iter_l))]\n",
    "    \n",
    "    for i in range(len(delta_l)):\n",
    "        all_val_dirrac = np.zeros(len(features_shift) - 1)\n",
    "        all_val_roar = np.zeros(len(features_shift) - 1)\n",
    "        \n",
    "        x_drra = dirrac_l[i].fit_data(X_recourse)\n",
    "        x_roar = roar_l[i].fit_data(roar_l[i].data)[:, :-1]\n",
    "        \n",
    "        l1 = np.mean(np.linalg.norm((x_drra - X_recourse), ord=1, axis=1))\n",
    "        l2 = np.mean(np.linalg.norm((x_roar - X_recourse), ord=1, axis=1))\n",
    "\n",
    "        cost_dirrac.append(l1)\n",
    "        cost_roar.append(l2)\n",
    "    \n",
    "        for j in range(len(features_shift) - 1):\n",
    "            # Train and get theta\n",
    "            all_val_dirrac[j] = np.mean(clf_shift[j].predict(x_drra))\n",
    "            all_val_roar[j] = np.mean(clf_shift[j].predict(x_roar))\n",
    "        \n",
    "        val_dirrac.append(np.mean(all_val_dirrac))\n",
    "        val_roar.append(np.mean(all_val_roar))\n",
    "    \n",
    "    return cost_dirrac, val_dirrac, cost_roar, val_roar"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "0d0443cb",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00, 16.04it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00, 13.15it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-3.9305, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7743, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5909, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3701, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0950, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.7360, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.2359, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.4751, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-0.2358, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.1192, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.4894, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.6976, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.8437, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.9562, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.0477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1247, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1911, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.2494, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3014, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3482, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3907, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4297, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4657, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4990, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5301, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2925, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2206, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1824, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1425, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1007, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0570, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0110, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9626, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9115, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8575, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8001, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.7390, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6737, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6036, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.5279, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.4457, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.3560, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.1477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.0246, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.8847, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7229, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5319, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3002, dtype=torch.float64, grad_fn=<DotBackward>)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00, 16.06it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00, 11.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-3.9305, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7743, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5909, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3701, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0950, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.7360, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.2359, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.4751, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-0.2358, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.1192, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.4894, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.6976, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.8437, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.9562, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.0477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1247, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1911, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.2494, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3014, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3482, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3907, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4297, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4657, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4990, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5301, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5592, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2925, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2206, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1824, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1425, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1007, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0570, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0110, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9626, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9115, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8575, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8001, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.7390, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6737, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6036, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.5279, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.4457, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.3560, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.1477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.0246, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.8847, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7229, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5319, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3002, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0089, dtype=torch.float64, grad_fn=<DotBackward>)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00, 15.89it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00, 11.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-3.9305, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7743, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5909, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3701, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0950, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.7360, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.2359, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.4751, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-0.2358, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.1192, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.4894, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.6976, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.8437, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.9562, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.0477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1247, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1911, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.2494, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3014, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3482, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3907, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4297, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4657, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4990, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5301, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5592, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5865, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2925, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2206, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1824, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1425, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1007, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0570, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0110, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9626, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9115, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8575, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8001, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.7390, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6737, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6036, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.5279, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.4457, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.3560, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.1477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.0246, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.8847, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7229, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5319, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3002, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0089, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.6237, dtype=torch.float64, grad_fn=<DotBackward>)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:06<00:00,  3.39s/it]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00, 11.66it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-3.9305, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7743, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5909, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3701, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0950, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.7360, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.2359, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.4751, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-0.2358, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.1192, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.4894, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.6976, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.8437, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.9562, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.0477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1247, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1911, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.2494, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3014, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3482, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3907, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4297, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4657, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4990, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5301, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5592, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5865, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6123, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2925, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2206, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1824, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1425, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1007, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0570, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0110, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9626, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9115, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8575, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8001, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.7390, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6737, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6036, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.5279, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.4457, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.3560, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.1477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.0246, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.8847, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7229, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5319, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3002, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0089, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.6237, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.0770, dtype=torch.float64, grad_fn=<DotBackward>)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:07<00:00,  3.60s/it]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00, 11.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-3.9305, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7743, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5909, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3701, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0950, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.7360, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.2359, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.4751, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-0.2358, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.1192, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.4894, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.6976, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.8437, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.9562, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.0477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1247, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1911, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.2494, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3014, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3482, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3907, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4297, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4657, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4990, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5301, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5592, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5865, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6123, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6366, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2925, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2206, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1824, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1425, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1007, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0570, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0110, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9626, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9115, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8575, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8001, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.7390, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6737, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6036, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.5279, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.4457, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.3560, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.1477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.0246, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.8847, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7229, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5319, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3002, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0089, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.6237, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.0770, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.2266, dtype=torch.float64, grad_fn=<DotBackward>)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:04<00:00,  2.30s/it]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00, 11.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-3.9305, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7743, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5909, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3701, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0950, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.7360, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.2359, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.4751, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-0.2358, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.1192, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.4894, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.6976, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.8437, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.9562, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.0477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1247, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1911, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.2494, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3014, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3482, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3907, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4297, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4657, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4990, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5301, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5592, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5865, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6123, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6366, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6596, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2925, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2206, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1824, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1425, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1007, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0570, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0110, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9626, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9115, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8575, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8001, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.7390, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6737, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6036, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.5279, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.4457, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.3560, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.1477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.0246, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.8847, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7229, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5319, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3002, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0089, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.6237, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.0770, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.2266, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(0.1398, dtype=torch.float64, grad_fn=<DotBackward>)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:10<00:00,  5.38s/it]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00, 10.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-3.9305, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7743, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5909, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3701, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0950, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.7360, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.2359, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.4751, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-0.2358, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.1192, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.4894, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.6976, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.8437, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.9562, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.0477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1247, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1911, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.2494, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3014, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3482, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3907, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4297, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4657, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4990, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5301, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5592, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5865, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6123, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6366, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6596, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6815, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2925, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2206, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1824, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1425, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1007, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0570, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0110, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9626, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9115, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8575, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8001, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.7390, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6737, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6036, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.5279, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.4457, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.3560, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.1477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.0246, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.8847, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7229, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5319, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3002, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0089, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.6237, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.0770, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.2266, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(0.1398, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.2448, dtype=torch.float64, grad_fn=<DotBackward>)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:04<00:00,  2.03s/it]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00,  9.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-3.9305, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7743, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5909, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3701, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0950, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.7360, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.2359, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.4751, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-0.2358, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.1192, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.4894, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.6976, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.8437, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.9562, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.0477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1247, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1911, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.2494, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3014, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3482, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3907, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4297, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4657, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4990, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5301, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5592, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5865, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6123, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6366, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6596, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6815, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.7024, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2925, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2206, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1824, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1425, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1007, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0570, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0110, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9626, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9115, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8575, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8001, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.7390, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6737, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6036, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.5279, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.4457, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.3560, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.1477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.0246, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.8847, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7229, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5319, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3002, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0089, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.6237, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.0770, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.2266, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(0.1398, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.2448, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.5574, dtype=torch.float64, grad_fn=<DotBackward>)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00,  7.38it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00,  9.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-3.9305, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7743, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5909, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3701, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0950, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.7360, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.2359, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.4751, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-0.2358, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.1192, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.4894, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.6976, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.8437, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.9562, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.0477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1247, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1911, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.2494, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3014, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3482, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3907, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4297, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4657, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4990, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5301, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5592, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5865, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6123, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6366, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6596, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6815, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.7024, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.7223, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2925, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2206, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1824, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1425, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1007, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0570, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0110, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9626, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9115, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8575, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8001, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.7390, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6737, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6036, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.5279, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.4457, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.3560, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.1477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.0246, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.8847, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7229, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5319, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3002, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0089, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.6237, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.0770, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.2266, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(0.1398, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.2448, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.5574, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.7469, dtype=torch.float64, grad_fn=<DotBackward>)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00,  3.21it/s]\n",
      " 50%|████████████████████████████████████████████████████████████████████████████████████                                                                                    | 1/2 [00:00<00:00,  9.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-3.9305, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7743, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5909, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3701, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0950, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.7360, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.2359, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.4751, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-0.2358, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.1192, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.4894, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.6976, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.8437, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.9562, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.0477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1247, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.1911, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.2494, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3014, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3482, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.3907, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4297, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4657, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.4990, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5301, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5592, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.5865, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6123, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6366, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6596, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.6815, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.7024, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.7223, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(2.7413, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2925, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.2206, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1824, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1425, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.1007, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0570, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-5.0110, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9626, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.9115, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8575, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.8001, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.7390, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6737, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.6036, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.5279, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.4457, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.3560, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.2573, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.1477, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-4.0246, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.8847, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.7229, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.5319, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.3002, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-3.0089, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.6237, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-2.0770, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(-1.2266, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(0.1398, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.2448, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.5574, dtype=torch.float64, grad_fn=<DotBackward>)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00,  9.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(1.7469, dtype=torch.float64, grad_fn=<DotBackward>)\n",
      "tensor(1.8835, dtype=torch.float64, grad_fn=<DotBackward>)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "cost_dirrac, val_dirrac, cost_roar, val_roar = recourse_cost(X_recourse[:2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "id": "fb36d1d7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rcParams.update({'font.size': 13})\n",
    "fig, ax = plt.subplots()\n",
    "ax.plot([3.276049353806753,\n",
    "  3.281549353806753,\n",
    "  3.2820423488439743,\n",
    "  3.282649353806753,\n",
    "  3.3739731811105997,\n",
    "  4.5], [0.606, 0.7375, 0.8065, 0.825, 1.0, 1.0], marker='+',label='DiRRAc', alpha=0.8)\n",
    "ax.plot(cost_roar[4:], val_roar[4:], marker='^', label='ROAR', alpha=0.8)\n",
    "\n",
    "ax.set(xlabel='$l_{1}$ cost', ylabel='$M_{2}$ validity')\n",
    "ax.grid()\n",
    "ax.legend(loc='lower right', frameon=False)\n",
    "ax.set_xlim([3.25, 4.55])\n",
    "ax.set_ylim([0.48, 1.01])\n",
    "# ax.set_xscale('log')\n",
    "\n",
    "\n",
    "plt.savefig('result/figure9/cost_robust_dirrac_roar.pdf', dpi=400, transparent=True)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
