{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "99444850",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import os\n",
    "# os.environ['CUDA_VISIBLE_DEVICES'] = \"1\"\n",
    "import torch\n",
    "import torchvision\n",
    "import torchvision.transforms as transforms\n",
    "import matplotlib.pyplot as plt\n",
    "import torch.nn as nn\n",
    "import pickle\n",
    "import pandas as pd\n",
    "import hashlib\n",
    "import time\n",
    "from matplotlib.pyplot import figure "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "46ec6b73",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define column names\n",
    "column_names = ['Age', 'Workclass', 'Fnlwgt', 'Education', 'Education-num', 'Marital-status', 'Occupation',\n",
    "                'Relationship', 'Race', 'Sex', 'Capital-gain', 'Capital-loss', 'Hours-per-week', \n",
    "                'Native-country', 'Income']\n",
    "\n",
    "# Read the csv file\n",
    "df = pd.read_csv('adult.data', names=column_names)\n",
    "df_test = pd.read_csv('adult.test', names=column_names)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "581f1fc3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Drop non-categorical columns\n",
    "df = df.drop(['Age', 'Fnlwgt', 'Education-num', 'Capital-gain', 'Capital-loss', 'Hours-per-week'], axis=1)\n",
    "df_test = df_test.drop(['Age', 'Fnlwgt', 'Education-num', 'Capital-gain', 'Capital-loss', 'Hours-per-week'], axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "id": "690e4c1b",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_test = df_test[1:].copy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "962b89a9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([' <=50K.', ' <=50K.', ' >50K.', ..., ' <=50K.', ' <=50K.',\n",
       "       ' >50K.'], dtype=object)"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_test.Income.values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "479e3619",
   "metadata": {},
   "outputs": [],
   "source": [
    "df['Income'] = df['Income'].apply(lambda x: 1 if x == ' >50K' else 0)\n",
    "df_test['Income'] = df_test['Income'].apply(lambda x: 1 if x == ' >50K.' else 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "id": "72e2a969",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(24720, 7841, 12435, 3846)"
      ]
     },
     "execution_count": 91,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sum(df.Income == 0), np.sum(df.Income == 1), np.sum(df_test.Income == 0), np.sum(df_test.Income == 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "8808109b",
   "metadata": {},
   "outputs": [],
   "source": [
    "assert np.sum(df.Income == 0) +  np.sum(df.Income == 1) == len(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "d545b7b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "assert np.sum(df_test.Income == 0) +  np.sum(df_test.Income == 1) == len(df_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "c397bf37",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_test[\"test\"] = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "81a858f9",
   "metadata": {},
   "outputs": [],
   "source": [
    "df[\"test\"] = 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "9a88ccd3",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_df = pd.concat([df_test,df])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "47416d14",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "full_df_dummies = pd.get_dummies(full_df, columns=['Workclass', 'Education', 'Marital-status', 'Occupation', 'Relationship', 'Race', 'Sex', 'Native-country'])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "id": "d0f55d63",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_test_dummies = full_df_dummies[full_df_dummies.test == 1]\n",
    "df_dummies = full_df_dummies[full_df_dummies.test == 0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "id": "ece8074b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Split the data into features and target\n",
    "features = df_dummies.drop('Income', axis=1).values\n",
    "target = df['Income'].values\n",
    "test_features = df_test_dummies.drop('Income', axis=1).values\n",
    "test_target = df_test['Income'].values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "id": "c22048f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Convert numpy arrays to PyTorch tensors\n",
    "features_tensor = torch.tensor(features, dtype=torch.float)\n",
    "target_tensor = torch.tensor(target, dtype=torch.float)\n",
    "\n",
    "# Convert numpy arrays to PyTorch tensors\n",
    "test_features_tensor = torch.tensor(test_features, dtype=torch.float)\n",
    "test_target_tensor = torch.tensor(test_target, dtype=torch.float)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "id": "5ccdd704",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([32561, 103])\n",
      "torch.Size([16281, 103])\n",
      "torch.Size([32561])\n",
      "torch.Size([16281])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(None, None)"
      ]
     },
     "execution_count": 101,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Print the tensors\n",
    "print(features_tensor.shape), print(test_features_tensor.shape)\n",
    "print(target_tensor.shape), print(test_target_tensor.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "id": "e4cee054",
   "metadata": {},
   "outputs": [],
   "source": [
    "stack_targets = torch.stack([1-target_tensor,target_tensor]).squeeze().T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "id": "e81da072",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/3000, Loss: 0.5545718669891357\n",
      "tensor(1., device='cuda:0') tensor(0.7638, device='cuda:0') tensor(0., device='cuda:0') tensor(0.2362, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 20/3000, Loss: 0.48163098096847534\n",
      "tensor(1., device='cuda:0') tensor(0.7672, device='cuda:0') tensor(0.0003, device='cuda:0') tensor(0.2325, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 30/3000, Loss: 0.4419630765914917\n",
      "tensor(1., device='cuda:0') tensor(0.7826, device='cuda:0') tensor(0.0066, device='cuda:0') tensor(0.2108, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 40/3000, Loss: 0.4163948595523834\n",
      "tensor(1., device='cuda:0') tensor(0.8157, device='cuda:0') tensor(0.0230, device='cuda:0') tensor(0.1612, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 50/3000, Loss: 0.4014928936958313\n",
      "tensor(1., device='cuda:0') tensor(0.8189, device='cuda:0') tensor(0.0326, device='cuda:0') tensor(0.1485, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 60/3000, Loss: 0.39181578159332275\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8243, device='cuda:0') tensor(0.0380, device='cuda:0') tensor(0.1377, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 70/3000, Loss: 0.38513538241386414\n",
      "tensor(1., device='cuda:0') tensor(0.8244, device='cuda:0') tensor(0.0384, device='cuda:0') tensor(0.1372, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 80/3000, Loss: 0.3804193139076233\n",
      "tensor(1., device='cuda:0') tensor(0.8270, device='cuda:0') tensor(0.0412, device='cuda:0') tensor(0.1317, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 90/3000, Loss: 0.3768931031227112\n",
      "tensor(1., device='cuda:0') tensor(0.8285, device='cuda:0') tensor(0.0417, device='cuda:0') tensor(0.1298, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 100/3000, Loss: 0.37417954206466675\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8304, device='cuda:0') tensor(0.0462, device='cuda:0') tensor(0.1235, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 110/3000, Loss: 0.372021347284317\n",
      "tensor(1., device='cuda:0') tensor(0.8314, device='cuda:0') tensor(0.0481, device='cuda:0') tensor(0.1205, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 120/3000, Loss: 0.3702639043331146\n",
      "tensor(1., device='cuda:0') tensor(0.8309, device='cuda:0') tensor(0.0491, device='cuda:0') tensor(0.1200, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 130/3000, Loss: 0.3688030540943146\n",
      "tensor(1., device='cuda:0') tensor(0.8313, device='cuda:0') tensor(0.0493, device='cuda:0') tensor(0.1193, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 140/3000, Loss: 0.36756789684295654\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8327, device='cuda:0') tensor(0.0505, device='cuda:0') tensor(0.1168, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 150/3000, Loss: 0.366508811712265\n",
      "tensor(1., device='cuda:0') tensor(0.8326, device='cuda:0') tensor(0.0507, device='cuda:0') tensor(0.1167, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 160/3000, Loss: 0.36559033393859863\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8323, device='cuda:0') tensor(0.0511, device='cuda:0') tensor(0.1166, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 170/3000, Loss: 0.3647864758968353\n",
      "tensor(1., device='cuda:0') tensor(0.8327, device='cuda:0') tensor(0.0512, device='cuda:0') tensor(0.1161, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 180/3000, Loss: 0.3640781342983246\n",
      "tensor(1., device='cuda:0') tensor(0.8329, device='cuda:0') tensor(0.0511, device='cuda:0') tensor(0.1160, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 190/3000, Loss: 0.3634504973888397\n",
      "tensor(1., device='cuda:0') tensor(0.8329, device='cuda:0') tensor(0.0513, device='cuda:0') tensor(0.1158, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 200/3000, Loss: 0.362892210483551\n",
      "tensor(1., device='cuda:0') tensor(0.8331, device='cuda:0') tensor(0.0514, device='cuda:0') tensor(0.1155, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 210/3000, Loss: 0.3623940944671631\n",
      "tensor(1., device='cuda:0') tensor(0.8331, device='cuda:0') tensor(0.0524, device='cuda:0') tensor(0.1145, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 220/3000, Loss: 0.3619488477706909\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8329, device='cuda:0') tensor(0.0530, device='cuda:0') tensor(0.1141, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 230/3000, Loss: 0.36155012249946594\n",
      "tensor(1., device='cuda:0') tensor(0.8329, device='cuda:0') tensor(0.0531, device='cuda:0') tensor(0.1140, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 240/3000, Loss: 0.3611927330493927\n",
      "tensor(1., device='cuda:0') tensor(0.8331, device='cuda:0') tensor(0.0531, device='cuda:0') tensor(0.1139, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 250/3000, Loss: 0.36087220907211304\n",
      "tensor(1., device='cuda:0') tensor(0.8335, device='cuda:0') tensor(0.0529, device='cuda:0') tensor(0.1136, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 260/3000, Loss: 0.36058446764945984\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8335, device='cuda:0') tensor(0.0530, device='cuda:0') tensor(0.1134, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 270/3000, Loss: 0.36032605171203613\n",
      "tensor(1., device='cuda:0') tensor(0.8337, device='cuda:0') tensor(0.0529, device='cuda:0') tensor(0.1134, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 280/3000, Loss: 0.36009398102760315\n",
      "tensor(1., device='cuda:0') tensor(0.8337, device='cuda:0') tensor(0.0530, device='cuda:0') tensor(0.1133, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 290/3000, Loss: 0.3598853349685669\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8338, device='cuda:0') tensor(0.0533, device='cuda:0') tensor(0.1129, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 300/3000, Loss: 0.3596978485584259\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8339, device='cuda:0') tensor(0.0534, device='cuda:0') tensor(0.1128, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 310/3000, Loss: 0.3595292270183563\n",
      "tensor(1., device='cuda:0') tensor(0.8342, device='cuda:0') tensor(0.0542, device='cuda:0') tensor(0.1117, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 320/3000, Loss: 0.35937750339508057\n",
      "tensor(1., device='cuda:0') tensor(0.8341, device='cuda:0') tensor(0.0544, device='cuda:0') tensor(0.1115, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 330/3000, Loss: 0.35924091935157776\n",
      "tensor(1., device='cuda:0') tensor(0.8342, device='cuda:0') tensor(0.0544, device='cuda:0') tensor(0.1115, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 340/3000, Loss: 0.35911792516708374\n",
      "tensor(1., device='cuda:0') tensor(0.8343, device='cuda:0') tensor(0.0544, device='cuda:0') tensor(0.1114, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 350/3000, Loss: 0.3590070605278015\n",
      "tensor(1., device='cuda:0') tensor(0.8343, device='cuda:0') tensor(0.0545, device='cuda:0') tensor(0.1112, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 360/3000, Loss: 0.3589070737361908\n",
      "tensor(1., device='cuda:0') tensor(0.8343, device='cuda:0') tensor(0.0545, device='cuda:0') tensor(0.1112, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 370/3000, Loss: 0.35881686210632324\n",
      "tensor(1., device='cuda:0') tensor(0.8344, device='cuda:0') tensor(0.0544, device='cuda:0') tensor(0.1112, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 380/3000, Loss: 0.3587353527545929\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8345, device='cuda:0') tensor(0.0543, device='cuda:0') tensor(0.1112, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 390/3000, Loss: 0.35866162180900574\n",
      "tensor(1., device='cuda:0') tensor(0.8345, device='cuda:0') tensor(0.0543, device='cuda:0') tensor(0.1112, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 400/3000, Loss: 0.3585949242115021\n",
      "tensor(1., device='cuda:0') tensor(0.8345, device='cuda:0') tensor(0.0543, device='cuda:0') tensor(0.1112, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 410/3000, Loss: 0.35853439569473267\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8345, device='cuda:0') tensor(0.0542, device='cuda:0') tensor(0.1114, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 420/3000, Loss: 0.3584795296192169\n",
      "tensor(1., device='cuda:0') tensor(0.8341, device='cuda:0') tensor(0.0541, device='cuda:0') tensor(0.1118, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 430/3000, Loss: 0.3584296405315399\n",
      "tensor(1., device='cuda:0') tensor(0.8340, device='cuda:0') tensor(0.0541, device='cuda:0') tensor(0.1118, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 440/3000, Loss: 0.35838422179222107\n",
      "tensor(1., device='cuda:0') tensor(0.8342, device='cuda:0') tensor(0.0541, device='cuda:0') tensor(0.1117, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 450/3000, Loss: 0.3583427965641022\n",
      "tensor(1., device='cuda:0') tensor(0.8343, device='cuda:0') tensor(0.0541, device='cuda:0') tensor(0.1116, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 460/3000, Loss: 0.3583050072193146\n",
      "tensor(1., device='cuda:0') tensor(0.8343, device='cuda:0') tensor(0.0541, device='cuda:0') tensor(0.1116, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 470/3000, Loss: 0.35827043652534485\n",
      "tensor(1., device='cuda:0') tensor(0.8343, device='cuda:0') tensor(0.0541, device='cuda:0') tensor(0.1115, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 480/3000, Loss: 0.35823872685432434\n",
      "tensor(1., device='cuda:0') tensor(0.8343, device='cuda:0') tensor(0.0541, device='cuda:0') tensor(0.1115, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 490/3000, Loss: 0.35820963978767395\n",
      "tensor(1., device='cuda:0') tensor(0.8343, device='cuda:0') tensor(0.0541, device='cuda:0') tensor(0.1115, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 500/3000, Loss: 0.3581828773021698\n",
      "tensor(1., device='cuda:0') tensor(0.8343, device='cuda:0') tensor(0.0542, device='cuda:0') tensor(0.1115, device='cuda:0')\n",
      "\n",
      " \n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 510/3000, Loss: 0.3581581711769104\n",
      "tensor(1., device='cuda:0') tensor(0.8343, device='cuda:0') tensor(0.0542, device='cuda:0') tensor(0.1115, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 520/3000, Loss: 0.3581353724002838\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0545, device='cuda:0') tensor(0.1106, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 530/3000, Loss: 0.3581143021583557\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0545, device='cuda:0') tensor(0.1106, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 540/3000, Loss: 0.358094722032547\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0545, device='cuda:0') tensor(0.1106, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 550/3000, Loss: 0.3580765426158905\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0545, device='cuda:0') tensor(0.1106, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 560/3000, Loss: 0.3580595552921295\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0545, device='cuda:0') tensor(0.1105, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 570/3000, Loss: 0.3580437898635864\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0545, device='cuda:0') tensor(0.1105, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 580/3000, Loss: 0.35802897810935974\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0545, device='cuda:0') tensor(0.1105, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 590/3000, Loss: 0.35801514983177185\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0545, device='cuda:0') tensor(0.1105, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 600/3000, Loss: 0.3580021560192108\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0545, device='cuda:0') tensor(0.1105, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 610/3000, Loss: 0.35798993706703186\n",
      "tensor(1., device='cuda:0') tensor(0.8349, device='cuda:0') tensor(0.0545, device='cuda:0') tensor(0.1106, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 620/3000, Loss: 0.3579784035682678\n",
      "tensor(1., device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0546, device='cuda:0') tensor(0.1106, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 630/3000, Loss: 0.3579675257205963\n",
      "tensor(1., device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0546, device='cuda:0') tensor(0.1106, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 640/3000, Loss: 0.35795727372169495\n",
      "tensor(1., device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0546, device='cuda:0') tensor(0.1106, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 650/3000, Loss: 0.35794752836227417\n",
      "tensor(1., device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0546, device='cuda:0') tensor(0.1106, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 660/3000, Loss: 0.35793834924697876\n",
      "tensor(1., device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0546, device='cuda:0') tensor(0.1106, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 670/3000, Loss: 0.3579295873641968\n",
      "tensor(1., device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0546, device='cuda:0') tensor(0.1106, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 680/3000, Loss: 0.3579212427139282\n",
      "tensor(1., device='cuda:0') tensor(0.8349, device='cuda:0') tensor(0.0546, device='cuda:0') tensor(0.1105, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 690/3000, Loss: 0.3579133152961731\n",
      "tensor(1., device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 700/3000, Loss: 0.357905775308609\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 710/3000, Loss: 0.3578985631465912\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 720/3000, Loss: 0.3578917384147644\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 730/3000, Loss: 0.35788512229919434\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 740/3000, Loss: 0.35787883400917053\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 750/3000, Loss: 0.35787278413772583\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 760/3000, Loss: 0.357867032289505\n",
      "tensor(1., device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 770/3000, Loss: 0.3578614294528961\n",
      "tensor(1., device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 780/3000, Loss: 0.3578560948371887\n",
      "tensor(1., device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 790/3000, Loss: 0.3578509986400604\n",
      "tensor(1., device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 800/3000, Loss: 0.3578460216522217\n",
      "tensor(1., device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 810/3000, Loss: 0.35784128308296204\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 820/3000, Loss: 0.35783669352531433\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8348, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1104, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 830/3000, Loss: 0.35783225297927856\n",
      "tensor(1., device='cuda:0') tensor(0.8349, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 840/3000, Loss: 0.35782796144485474\n",
      "tensor(1., device='cuda:0') tensor(0.8349, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 850/3000, Loss: 0.35782381892204285\n",
      "tensor(1., device='cuda:0') tensor(0.8349, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 860/3000, Loss: 0.3578198254108429\n",
      "tensor(1., device='cuda:0') tensor(0.8349, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 870/3000, Loss: 0.3578159809112549\n",
      "tensor(1., device='cuda:0') tensor(0.8349, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 880/3000, Loss: 0.35781219601631165\n",
      "tensor(1., device='cuda:0') tensor(0.8349, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 890/3000, Loss: 0.35780856013298035\n",
      "tensor(1., device='cuda:0') tensor(0.8349, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 900/3000, Loss: 0.3578050434589386\n",
      "tensor(1., device='cuda:0') tensor(0.8349, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 910/3000, Loss: 0.3578016459941864\n",
      "tensor(1., device='cuda:0') tensor(0.8349, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 920/3000, Loss: 0.357798308134079\n",
      "tensor(1., device='cuda:0') tensor(0.8349, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 930/3000, Loss: 0.3577950596809387\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 940/3000, Loss: 0.357791930437088\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 950/3000, Loss: 0.3577888607978821\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 960/3000, Loss: 0.3577858507633209\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 970/3000, Loss: 0.3577829599380493\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 980/3000, Loss: 0.3577800691127777\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 990/3000, Loss: 0.35777732729911804\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1000/3000, Loss: 0.3577745854854584\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1010/3000, Loss: 0.35777193307876587\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1020/3000, Loss: 0.35776934027671814\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1030/3000, Loss: 0.3577667772769928\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1040/3000, Loss: 0.3577643036842346\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1050/3000, Loss: 0.35776185989379883\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1060/3000, Loss: 0.3577594757080078\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1070/3000, Loss: 0.3577570915222168\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1080/3000, Loss: 0.35775476694107056\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1090/3000, Loss: 0.3577525019645691\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1100/3000, Loss: 0.35775026679039\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1110/3000, Loss: 0.35774803161621094\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1120/3000, Loss: 0.357745885848999\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1130/3000, Loss: 0.3577437400817871\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1140/3000, Loss: 0.3577416241168976\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1150/3000, Loss: 0.35773953795433044\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1160/3000, Loss: 0.3577375113964081\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1170/3000, Loss: 0.3577354848384857\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1180/3000, Loss: 0.35773345828056335\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1190/3000, Loss: 0.35773152112960815\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1200/3000, Loss: 0.35772955417633057\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1210/3000, Loss: 0.35772761702537537\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1220/3000, Loss: 0.35772570967674255\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1230/3000, Loss: 0.35772383213043213\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1240/3000, Loss: 0.3577219545841217\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1250/3000, Loss: 0.35772010684013367\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1260/3000, Loss: 0.357718288898468\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1270/3000, Loss: 0.35771650075912476\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1280/3000, Loss: 0.3577146828174591\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1290/3000, Loss: 0.35771292448043823\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1300/3000, Loss: 0.35771116614341736\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1310/3000, Loss: 0.35770943760871887\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1320/3000, Loss: 0.3577077090740204\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1330/3000, Loss: 0.3577059507369995\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1340/3000, Loss: 0.3577042818069458\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1350/3000, Loss: 0.3577026128768921\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1360/3000, Loss: 0.357700914144516\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1370/3000, Loss: 0.35769930481910706\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1380/3000, Loss: 0.35769766569137573\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1390/3000, Loss: 0.3576960265636444\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1400/3000, Loss: 0.3576944172382355\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1410/3000, Loss: 0.3576928377151489\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1420/3000, Loss: 0.3576911985874176\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1430/3000, Loss: 0.35768964886665344\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1440/3000, Loss: 0.3576880991458893\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1450/3000, Loss: 0.35768651962280273\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1460/3000, Loss: 0.35768502950668335\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1470/3000, Loss: 0.3576834797859192\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1480/3000, Loss: 0.3576819598674774\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1490/3000, Loss: 0.35768046975135803\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1500/3000, Loss: 0.35767897963523865\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1510/3000, Loss: 0.35767748951911926\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1520/3000, Loss: 0.35767602920532227\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1530/3000, Loss: 0.35767459869384766\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1540/3000, Loss: 0.35767310857772827\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1550/3000, Loss: 0.35767170786857605\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1560/3000, Loss: 0.35767027735710144\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1570/3000, Loss: 0.3576688766479492\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1580/3000, Loss: 0.357667475938797\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1590/3000, Loss: 0.3576660752296448\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1600/3000, Loss: 0.35766470432281494\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1610/3000, Loss: 0.3576633334159851\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1620/3000, Loss: 0.35766199231147766\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1630/3000, Loss: 0.3576606512069702\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1640/3000, Loss: 0.3576592803001404\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1650/3000, Loss: 0.3576579689979553\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1660/3000, Loss: 0.35765671730041504\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1670/3000, Loss: 0.35765540599823\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1680/3000, Loss: 0.3576540946960449\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1690/3000, Loss: 0.35765284299850464\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1700/3000, Loss: 0.35765156149864197\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1710/3000, Loss: 0.3576503396034241\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1720/3000, Loss: 0.3576490879058838\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1730/3000, Loss: 0.3576478660106659\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1740/3000, Loss: 0.357646644115448\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1750/3000, Loss: 0.3576454520225525\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1760/3000, Loss: 0.3576442301273346\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1770/3000, Loss: 0.3576430380344391\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1780/3000, Loss: 0.35764190554618835\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1790/3000, Loss: 0.35764074325561523\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1800/3000, Loss: 0.3576395809650421\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1810/3000, Loss: 0.3576384484767914\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1820/3000, Loss: 0.35763734579086304\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1830/3000, Loss: 0.3576362133026123\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1840/3000, Loss: 0.35763511061668396\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1850/3000, Loss: 0.357634037733078\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1860/3000, Loss: 0.35763290524482727\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1870/3000, Loss: 0.3576318919658661\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1880/3000, Loss: 0.35763075947761536\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1890/3000, Loss: 0.3576297461986542\n",
      "tensor(1.0000, device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1103, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1900/3000, Loss: 0.3576287031173706\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1910/3000, Loss: 0.3576276898384094\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1920/3000, Loss: 0.35762670636177063\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1930/3000, Loss: 0.35762566328048706\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1940/3000, Loss: 0.35762467980384827\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1950/3000, Loss: 0.35762372612953186\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1960/3000, Loss: 0.35762274265289307\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1970/3000, Loss: 0.35762178897857666\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1980/3000, Loss: 0.35762080550193787\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 1990/3000, Loss: 0.35761988162994385\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2000/3000, Loss: 0.3576189875602722\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2010/3000, Loss: 0.3576180636882782\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2020/3000, Loss: 0.3576171398162842\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2030/3000, Loss: 0.35761624574661255\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2040/3000, Loss: 0.3576153814792633\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2050/3000, Loss: 0.3576144874095917\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2060/3000, Loss: 0.3576136529445648\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2070/3000, Loss: 0.35761281847953796\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2080/3000, Loss: 0.3576119542121887\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2090/3000, Loss: 0.35761114954948425\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2100/3000, Loss: 0.3576103448867798\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2110/3000, Loss: 0.35760951042175293\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2120/3000, Loss: 0.35760873556137085\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2130/3000, Loss: 0.35760796070098877\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2140/3000, Loss: 0.3576071560382843\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2150/3000, Loss: 0.3576063811779022\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2160/3000, Loss: 0.35760563611984253\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2170/3000, Loss: 0.35760489106178284\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2180/3000, Loss: 0.35760417580604553\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2190/3000, Loss: 0.3576034605503082\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2200/3000, Loss: 0.3576027750968933\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2210/3000, Loss: 0.3576020300388336\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2220/3000, Loss: 0.3576013445854187\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2230/3000, Loss: 0.35760068893432617\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2240/3000, Loss: 0.35759997367858887\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2250/3000, Loss: 0.3575993478298187\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2260/3000, Loss: 0.3575987219810486\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2270/3000, Loss: 0.35759806632995605\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2280/3000, Loss: 0.35759738087654114\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2290/3000, Loss: 0.3575967848300934\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2300/3000, Loss: 0.35759618878364563\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2310/3000, Loss: 0.3575955927371979\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2320/3000, Loss: 0.35759496688842773\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2330/3000, Loss: 0.35759440064430237\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2340/3000, Loss: 0.3575938045978546\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2350/3000, Loss: 0.35759323835372925\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2360/3000, Loss: 0.35759270191192627\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2370/3000, Loss: 0.3575921356678009\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2380/3000, Loss: 0.3575915992259979\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2390/3000, Loss: 0.35759109258651733\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2400/3000, Loss: 0.35759055614471436\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2410/3000, Loss: 0.35759007930755615\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2420/3000, Loss: 0.3575895428657532\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2430/3000, Loss: 0.35758906602859497\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2440/3000, Loss: 0.3575885593891144\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2450/3000, Loss: 0.3575880527496338\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2460/3000, Loss: 0.357587605714798\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2470/3000, Loss: 0.35758712887763977\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2480/3000, Loss: 0.35758671164512634\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2490/3000, Loss: 0.35758623480796814\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2500/3000, Loss: 0.3575858175754547\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2510/3000, Loss: 0.3575854003429413\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2520/3000, Loss: 0.35758495330810547\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2530/3000, Loss: 0.35758456587791443\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2540/3000, Loss: 0.357584148645401\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2550/3000, Loss: 0.3575837314128876\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2560/3000, Loss: 0.35758334398269653\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2570/3000, Loss: 0.3575829565525055\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2580/3000, Loss: 0.35758256912231445\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2590/3000, Loss: 0.3575822114944458\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2600/3000, Loss: 0.35758185386657715\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2610/3000, Loss: 0.3575814962387085\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2620/3000, Loss: 0.35758113861083984\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2630/3000, Loss: 0.3575808107852936\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2640/3000, Loss: 0.3575804829597473\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2650/3000, Loss: 0.35758015513420105\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2660/3000, Loss: 0.3575798273086548\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2670/3000, Loss: 0.3575795292854309\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2680/3000, Loss: 0.35757923126220703\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2690/3000, Loss: 0.3575788736343384\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2700/3000, Loss: 0.3575785756111145\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2710/3000, Loss: 0.357578307390213\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2720/3000, Loss: 0.35757800936698914\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2730/3000, Loss: 0.35757777094841003\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2740/3000, Loss: 0.35757747292518616\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2750/3000, Loss: 0.35757720470428467\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2760/3000, Loss: 0.35757696628570557\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2770/3000, Loss: 0.3575766980648041\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2780/3000, Loss: 0.357576459646225\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2790/3000, Loss: 0.3575762212276459\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2800/3000, Loss: 0.3575759828090668\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2810/3000, Loss: 0.3575757145881653\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2820/3000, Loss: 0.35757550597190857\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2830/3000, Loss: 0.35757526755332947\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2840/3000, Loss: 0.35757505893707275\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2850/3000, Loss: 0.35757485032081604\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2860/3000, Loss: 0.3575746417045593\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2870/3000, Loss: 0.3575744032859802\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2880/3000, Loss: 0.3575742244720459\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2890/3000, Loss: 0.3575740456581116\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2900/3000, Loss: 0.35757386684417725\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2910/3000, Loss: 0.35757365822792053\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2920/3000, Loss: 0.3575734794139862\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2930/3000, Loss: 0.3575732707977295\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2940/3000, Loss: 0.35757312178611755\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2950/3000, Loss: 0.3575729727745056\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2960/3000, Loss: 0.3575727939605713\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2970/3000, Loss: 0.35757261514663696\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2980/3000, Loss: 0.3575724959373474\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 2990/3000, Loss: 0.3575723171234131\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n",
      "Epoch 3000/3000, Loss: 0.35757219791412354\n",
      "tensor(1., device='cuda:0') tensor(0.8350, device='cuda:0') tensor(0.0548, device='cuda:0') tensor(0.1102, device='cuda:0')\n",
      "\n",
      " \n",
      "\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "\n",
    "# Define the Logistic Regression model\n",
    "class LogisticRegression(nn.Module):\n",
    "    def __init__(self, input_size, output_size):\n",
    "        super(LogisticRegression, self).__init__()\n",
    "        self.linear = nn.Linear(input_size, output_size)\n",
    "\n",
    "    def forward(self, x):\n",
    "        out = torch.sigmoid(self.linear(x))\n",
    "        return out\n",
    "\n",
    "# Set the input size and output size\n",
    "# The input size should be the number of features in your data\n",
    "# The output size is 1 because the output is binary (1 or 0)\n",
    "input_size = features_tensor.shape[1]\n",
    "output_size = 1\n",
    "\n",
    "# Create the model\n",
    "model = LogisticRegression(input_size, output_size)\n",
    "model = model.cuda()\n",
    "features_tensor = features_tensor.cuda() \n",
    "test_target_tensor = test_target_tensor.cuda()\n",
    "# Define the loss function and the optimizer\n",
    "# l = nn.BCELoss()\n",
    "optimizer = optim.Adam(model.parameters(), lr=0.01)\n",
    "\n",
    "# Training\n",
    "num_epochs = 3000\n",
    "for epoch in range(num_epochs):\n",
    "    # Forward pass\n",
    "    outputs = model(features_tensor)\n",
    "#     print(outputs.shape, target_tensor.shape)\n",
    "\n",
    "    stack_outputs = torch.stack([1-outputs,outputs]).squeeze().T\n",
    "    stack_targets = torch.stack([1-target_tensor,target_tensor]).squeeze().T.cuda()\n",
    "    \n",
    "    \n",
    "    out_log = torch.log(stack_outputs)\n",
    "\n",
    "    l = - torch.mean( torch.sum(stack_targets * out_log,dim=1) )\n",
    "#     loss = l(outputs.squeeze(), target_tensor)\n",
    "\n",
    "    # Backward and optimize\n",
    "    optimizer.zero_grad()\n",
    "    l.backward()\n",
    "    optimizer.step()\n",
    "\n",
    "    # Print loss every 10 epochs\n",
    "    with torch.no_grad():\n",
    "        if (epoch+1) % 10 == 0:\n",
    "            print(f'Epoch {epoch+1}/{num_epochs}, Loss: {l.item()}')\n",
    "            outputs = model(test_features_tensor.cuda())\n",
    "            outputs[outputs.squeeze() >= 0.5] = 1 \n",
    "            outputs[outputs.squeeze() < 0.5] = 0\n",
    "\n",
    "            accuracy = torch.sum(outputs.squeeze() == test_target_tensor) / len(df_test)\n",
    "            true_poor_fake_rich = torch.sum(outputs.squeeze() - test_target_tensor == 1)  / len(df_test)\n",
    "            fake_poor_true_rich = torch.sum(outputs.squeeze() - test_target_tensor == -1) / len(df_test)\n",
    "            print(accuracy + true_poor_fake_rich + fake_poor_true_rich, accuracy, true_poor_fake_rich, fake_poor_true_rich)\n",
    "            print(\"\\n \\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "1a1ce6fb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cuda', index=0)"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stack_targets.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "35db6f0a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.float32, torch.float32)"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_target_tensor.dtype, outputs.squeeze().dtype"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "2873e045",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor(0.9464, device='cuda:0'),\n",
       " tensor(0.8355, device='cuda:0'),\n",
       " tensor(0.0555, device='cuda:0'),\n",
       " tensor(0.0555, device='cuda:0'))"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "accuracy + true_poor_fake_rich + true_poor_fake_rich, accuracy, true_poor_fake_rich, true_poor_fake_rich"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "0bb070de",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([16281, 103]), torch.Size([16281, 1]))"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_features_tensor.shape, outputs.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "118e4dc1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(16281, device='cuda:0')"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.sum(outputs == 0) + torch.sum(outputs == 1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8b6b0bd6",
   "metadata": {},
   "source": [
    "# Now with privacy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "2b4daf63",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(32561, torch.Size([32561, 103]), torch.Size([32561]))"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(df), features_tensor.shape, target_tensor.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "4c449187",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'0'"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "str(int(target_tensor[0].item()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "f2d715c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_dict = {}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2a59e0ca",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "For epsilon 10  and d  6512200 We have true:  32518 and false:  43\n",
      "The time it took for the full run of 4001 epochs: 8.532274723052979 \n",
      "\n",
      "For epsilon 0.1  and d  6512200 We have true:  20821 and false:  11740\n",
      "The time it took for the full run of 4001 epochs: 8.658543109893799 \n",
      "\n",
      "For epsilon 1  and d  6512200 We have true:  26436 and false:  6125\n",
      "The time it took for the full run of 4001 epochs: 8.29695177078247 \n",
      "\n",
      "For epsilon 0.25  and d  6512200 We have true:  21674 and false:  10887\n",
      "The time it took for the full run of 4001 epochs: 9.443172216415405 \n",
      "\n",
      "For epsilon 0.5  and d  6512200 We have true:  23213 and false:  9348\n",
      "The time it took for the full run of 4001 epochs: 8.535400629043579 \n",
      "\n",
      "For epsilon 2  and d  6512200 We have true:  30207 and false:  2354\n",
      "The time it took for the full run of 4001 epochs: 8.398268222808838 \n",
      "\n",
      "For epsilon 4  and d  6512200 We have true:  32191 and false:  370\n",
      "The time it took for the full run of 4001 epochs: 8.359879732131958 \n",
      "\n",
      "For epsilon 8  and d  6512200 We have true:  32511 and false:  50\n",
      "The time it took for the full run of 4001 epochs: 8.566942930221558 \n",
      "\n",
      "For epsilon 20  and d  6512200 We have true:  32522 and false:  39\n",
      "The time it took for the full run of 4001 epochs: 8.21095871925354 \n",
      "\n",
      "For epsilon 50  and d  6512200 We have true:  32524 and false:  37\n",
      "The time it took for the full run of 4001 epochs: 8.528562545776367 \n",
      "\n",
      "For epsilon 0.05  and d  6512200 We have true:  20736 and false:  11825\n",
      "The time it took for the full run of 4001 epochs: 9.047944068908691 \n",
      "\n",
      "For epsilon 0.01  and d  6512200 We have true:  20441 and false:  12120\n",
      "The time it took for the full run of 4001 epochs: 8.97263216972351 \n",
      "\n",
      "For epsilon 10  and d  651220 We have true:  32143 and false:  418\n",
      "The time it took for the full run of 4001 epochs: 8.22199821472168 \n",
      "\n",
      "For epsilon 0.1  and d  651220 We have true:  21049 and false:  11512\n",
      "The time it took for the full run of 4001 epochs: 7.759547472000122 \n",
      "\n",
      "For epsilon 1  and d  651220 We have true:  26259 and false:  6302\n",
      "The time it took for the full run of 4001 epochs: 8.152506351470947 \n",
      "\n",
      "For epsilon 0.25  and d  651220 We have true:  21675 and false:  10886\n",
      "The time it took for the full run of 4001 epochs: 8.220593929290771 \n",
      "\n",
      "For epsilon 0.5  and d  651220 We have true:  23356 and false:  9205\n",
      "The time it took for the full run of 4001 epochs: 7.977470636367798 \n",
      "\n",
      "For epsilon 2  and d  651220 We have true:  29871 and false:  2690\n",
      "The time it took for the full run of 4001 epochs: 7.995708227157593 \n",
      "\n",
      "For epsilon 4  and d  651220 We have true:  31908 and false:  653\n",
      "The time it took for the full run of 4001 epochs: 8.397306680679321 \n",
      "\n",
      "For epsilon 8  and d  651220 We have true:  32173 and false:  388\n",
      "The time it took for the full run of 4001 epochs: 8.242287158966064 \n",
      "\n",
      "For epsilon 20  and d  651220 We have true:  32193 and false:  368\n",
      "The time it took for the full run of 4001 epochs: 7.927674293518066 \n",
      "\n",
      "For epsilon 50  and d  651220 We have true:  32172 and false:  389\n",
      "The time it took for the full run of 4001 epochs: 8.088594675064087 \n",
      "\n",
      "For epsilon 0.05  and d  651220 We have true:  20760 and false:  11801\n",
      "The time it took for the full run of 4001 epochs: 7.870491027832031 \n",
      "\n",
      "For epsilon 0.01  and d  651220 We have true:  20617 and false:  11944\n",
      "The time it took for the full run of 4001 epochs: 8.19194507598877 \n",
      "\n",
      "For epsilon 10  and d  65122 We have true:  29070 and false:  3491\n",
      "The time it took for the full run of 4001 epochs: 7.879210472106934 \n",
      "\n",
      "For epsilon 0.1  and d  65122 We have true:  20955 and false:  11606\n",
      "The time it took for the full run of 4001 epochs: 8.160661935806274 \n",
      "\n",
      "For epsilon 1  and d  65122 We have true:  25095 and false:  7466\n",
      "The time it took for the full run of 4001 epochs: 8.003637552261353 \n",
      "\n",
      "For epsilon 0.25  and d  65122 We have true:  21627 and false:  10934\n",
      "The time it took for the full run of 4001 epochs: 8.033816576004028 \n",
      "\n",
      "For epsilon 0.5  and d  65122 We have true:  22994 and false:  9567\n",
      "The time it took for the full run of 4001 epochs: 7.987020254135132 \n",
      "\n",
      "For epsilon 2  and d  65122 We have true:  27588 and false:  4973\n",
      "The time it took for the full run of 4001 epochs: 7.878307819366455 \n",
      "\n",
      "For epsilon 4  and d  65122 We have true:  28993 and false:  3568\n",
      "The time it took for the full run of 4001 epochs: 7.803360462188721 \n",
      "\n",
      "For epsilon 8  and d  65122 We have true:  29205 and false:  3356\n",
      "The time it took for the full run of 4001 epochs: 7.798712730407715 \n",
      "\n",
      "For epsilon 20  and d  65122 We have true:  29043 and false:  3518\n",
      "The time it took for the full run of 4001 epochs: 8.0331711769104 \n",
      "\n",
      "For epsilon 50  and d  65122 We have true:  29135 and false:  3426\n",
      "The time it took for the full run of 4001 epochs: 8.161709785461426 \n",
      "\n",
      "For epsilon 0.05  and d  65122 We have true:  20610 and false:  11951\n",
      "The time it took for the full run of 4001 epochs: 7.660550355911255 \n",
      "\n",
      "For epsilon 0.01  and d  65122 We have true:  20536 and false:  12025\n",
      "The time it took for the full run of 4001 epochs: 8.014545202255249 \n",
      "\n",
      "For epsilon 10  and d  6512 We have true:  22731 and false:  9830\n",
      "The time it took for the full run of 4001 epochs: 7.707878351211548 \n",
      "\n",
      "For epsilon 0.1  and d  6512 We have true:  20826 and false:  11735\n",
      "The time it took for the full run of 4001 epochs: 7.814776659011841 \n",
      "\n",
      "For epsilon 1  and d  6512 We have true:  22276 and false:  10285\n",
      "The time it took for the full run of 4001 epochs: 7.617390871047974 \n",
      "\n",
      "For epsilon 0.25  and d  6512 We have true:  21447 and false:  11114\n",
      "The time it took for the full run of 4001 epochs: 8.043185234069824 \n",
      "\n",
      "For epsilon 0.5  and d  6512 We have true:  21944 and false:  10617\n",
      "The time it took for the full run of 4001 epochs: 7.9799981117248535 \n",
      "\n",
      "For epsilon 2  and d  6512 We have true:  22644 and false:  9917\n",
      "The time it took for the full run of 4001 epochs: 7.968243360519409 \n",
      "\n",
      "For epsilon 4  and d  6512 We have true:  22751 and false:  9810\n",
      "The time it took for the full run of 4001 epochs: 7.7072062492370605 \n",
      "\n",
      "For epsilon 8  and d  6512 We have true:  22671 and false:  9890\n",
      "The time it took for the full run of 4001 epochs: 8.110306024551392 \n",
      "\n",
      "For epsilon 20  and d  6512 We have true:  22799 and false:  9762\n",
      "The time it took for the full run of 4001 epochs: 7.9415318965911865 \n",
      "\n",
      "For epsilon 50  and d  6512 We have true:  22793 and false:  9768\n",
      "The time it took for the full run of 4001 epochs: 7.623526096343994 \n",
      "\n",
      "For epsilon 0.05  and d  6512 We have true:  20704 and false:  11857\n",
      "The time it took for the full run of 4001 epochs: 8.013651371002197 \n",
      "\n",
      "For epsilon 0.01  and d  6512 We have true:  20620 and false:  11941\n",
      "The time it took for the full run of 4001 epochs: 7.982734680175781 \n",
      "\n",
      "For epsilon 10  and d  3256 We have true:  22108 and false:  10453\n",
      "The time it took for the full run of 4001 epochs: 9.458379745483398 \n",
      "\n",
      "For epsilon 0.1  and d  3256 We have true:  20928 and false:  11633\n",
      "The time it took for the full run of 4001 epochs: 7.663127183914185 \n",
      "\n",
      "For epsilon 1  and d  3256 We have true:  21808 and false:  10753\n",
      "The time it took for the full run of 4001 epochs: 7.928256034851074 \n",
      "\n",
      "For epsilon 0.25  and d  3256 We have true:  21067 and false:  11494\n",
      "The time it took for the full run of 4001 epochs: 8.143057823181152 \n",
      "\n",
      "For epsilon 0.5  and d  3256 We have true:  21536 and false:  11025\n",
      "The time it took for the full run of 4001 epochs: 7.767504930496216 \n",
      "\n",
      "For epsilon 2  and d  3256 We have true:  21939 and false:  10622\n",
      "The time it took for the full run of 4001 epochs: 8.06023120880127 \n",
      "\n",
      "For epsilon 4  and d  3256 We have true:  21934 and false:  10627\n",
      "The time it took for the full run of 4001 epochs: 7.871798515319824 \n",
      "\n",
      "For epsilon 8  and d  3256 We have true:  22028 and false:  10533\n",
      "The time it took for the full run of 4001 epochs: 8.33631157875061 \n",
      "\n",
      "For epsilon 20  and d  3256 We have true:  21981 and false:  10580\n",
      "The time it took for the full run of 4001 epochs: 8.142113208770752 \n",
      "\n",
      "For epsilon 50  and d  3256 We have true:  21976 and false:  10585\n",
      "The time it took for the full run of 4001 epochs: 8.095537900924683 \n",
      "\n",
      "For epsilon 0.05  and d  3256 We have true:  20736 and false:  11825\n",
      "The time it took for the full run of 4001 epochs: 8.22957968711853 \n",
      "\n",
      "For epsilon 0.01  and d  3256 We have true:  20417 and false:  12144\n",
      "The time it took for the full run of 4001 epochs: 7.976320505142212 \n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "For epsilon 10  and d  651 We have true:  21140 and false:  11421\n",
      "The time it took for the full run of 4001 epochs: 7.947306394577026 \n",
      "\n",
      "For epsilon 0.1  and d  651 We have true:  20691 and false:  11870\n",
      "The time it took for the full run of 4001 epochs: 7.86779260635376 \n",
      "\n",
      "For epsilon 1  and d  651 We have true:  21007 and false:  11554\n",
      "The time it took for the full run of 4001 epochs: 8.173574209213257 \n",
      "\n",
      "For epsilon 0.25  and d  651 We have true:  20923 and false:  11638\n",
      "The time it took for the full run of 4001 epochs: 7.739257335662842 \n",
      "\n",
      "For epsilon 0.5  and d  651 We have true:  20860 and false:  11701\n",
      "The time it took for the full run of 4001 epochs: 8.604100704193115 \n",
      "\n",
      "For epsilon 2  and d  651 We have true:  20843 and false:  11718\n",
      "The time it took for the full run of 4001 epochs: 7.640839576721191 \n",
      "\n",
      "For epsilon 4  and d  651 We have true:  21130 and false:  11431\n",
      "The time it took for the full run of 4001 epochs: 7.911477088928223 \n",
      "\n",
      "For epsilon 8  and d  651 We have true:  21034 and false:  11527\n",
      "The time it took for the full run of 4001 epochs: 7.465947389602661 \n",
      "\n",
      "For epsilon 20  and d  651 We have true:  20903 and false:  11658\n",
      "The time it took for the full run of 4001 epochs: 7.949930429458618 \n",
      "\n",
      "For epsilon 50  and d  651 We have true:  21057 and false:  11504\n",
      "The time it took for the full run of 4001 epochs: 7.820422172546387 \n",
      "\n",
      "For epsilon 0.05  and d  651 We have true:  20768 and false:  11793\n",
      "The time it took for the full run of 4001 epochs: 7.611034393310547 \n",
      "\n",
      "For epsilon 0.01  and d  651 We have true:  20576 and false:  11985\n",
      "The time it took for the full run of 4001 epochs: 7.678120136260986 \n",
      "\n",
      "For epsilon 10  and d  6512200 We have true:  32513 and false:  48\n",
      "The time it took for the full run of 4001 epochs: 8.461848258972168 \n",
      "\n",
      "For epsilon 0.1  and d  6512200 We have true:  20992 and false:  11569\n",
      "The time it took for the full run of 4001 epochs: 9.125917434692383 \n",
      "\n",
      "For epsilon 1  and d  6512200 We have true:  26288 and false:  6273\n",
      "The time it took for the full run of 4001 epochs: 8.242291927337646 \n",
      "\n",
      "For epsilon 0.25  and d  6512200 We have true:  21778 and false:  10783\n",
      "The time it took for the full run of 4001 epochs: 8.869678020477295 \n",
      "\n",
      "For epsilon 0.5  and d  6512200 We have true:  23165 and false:  9396\n",
      "The time it took for the full run of 4001 epochs: 8.785117149353027 \n",
      "\n",
      "For epsilon 2  and d  6512200 We have true:  30205 and false:  2356\n",
      "The time it took for the full run of 4001 epochs: 8.471640586853027 \n",
      "\n",
      "For epsilon 4  and d  6512200 We have true:  32244 and false:  317\n",
      "The time it took for the full run of 4001 epochs: 8.379245042800903 \n",
      "\n",
      "For epsilon 8  and d  6512200 We have true:  32521 and false:  40\n",
      "The time it took for the full run of 4001 epochs: 8.748369216918945 \n",
      "\n",
      "For epsilon 20  and d  6512200 We have true:  32514 and false:  47\n",
      "The time it took for the full run of 4001 epochs: 8.447977304458618 \n",
      "\n",
      "For epsilon 50  and d  6512200 We have true:  32518 and false:  43\n",
      "The time it took for the full run of 4001 epochs: 8.53193974494934 \n",
      "\n",
      "For epsilon 0.05  and d  6512200 We have true:  20508 and false:  12053\n",
      "The time it took for the full run of 4001 epochs: 9.024315357208252 \n",
      "\n",
      "For epsilon 0.01  and d  6512200 We have true:  20450 and false:  12111\n",
      "The time it took for the full run of 4001 epochs: 9.783752918243408 \n",
      "\n",
      "For epsilon 10  and d  651220 We have true:  32169 and false:  392\n",
      "The time it took for the full run of 4001 epochs: 7.981684684753418 \n",
      "\n",
      "For epsilon 0.1  and d  651220 We have true:  20968 and false:  11593\n",
      "The time it took for the full run of 4001 epochs: 8.51649022102356 \n",
      "\n",
      "For epsilon 1  and d  651220 We have true:  26086 and false:  6475\n",
      "The time it took for the full run of 4001 epochs: 8.242699146270752 \n",
      "\n",
      "For epsilon 0.25  and d  651220 We have true:  21529 and false:  11032\n",
      "The time it took for the full run of 4001 epochs: 8.455461025238037 \n",
      "\n",
      "For epsilon 0.5  and d  651220 We have true:  23182 and false:  9379\n",
      "The time it took for the full run of 4001 epochs: 8.09321928024292 \n",
      "\n",
      "For epsilon 2  and d  651220 We have true:  29912 and false:  2649\n",
      "The time it took for the full run of 4001 epochs: 8.163713693618774 \n",
      "\n",
      "For epsilon 4  and d  651220 We have true:  31918 and false:  643\n",
      "The time it took for the full run of 4001 epochs: 8.211556673049927 \n",
      "\n",
      "For epsilon 8  and d  651220 We have true:  32164 and false:  397\n",
      "The time it took for the full run of 4001 epochs: 7.847936630249023 \n",
      "\n",
      "For epsilon 20  and d  651220 We have true:  32182 and false:  379\n",
      "The time it took for the full run of 4001 epochs: 8.040098905563354 \n",
      "\n",
      "For epsilon 50  and d  651220 We have true:  32175 and false:  386\n",
      "The time it took for the full run of 4001 epochs: 8.442355632781982 \n",
      "\n",
      "For epsilon 0.05  and d  651220 We have true:  20709 and false:  11852\n",
      "The time it took for the full run of 4001 epochs: 7.965272426605225 \n",
      "\n",
      "For epsilon 0.01  and d  651220 We have true:  20553 and false:  12008\n",
      "The time it took for the full run of 4001 epochs: 8.098713874816895 \n",
      "\n",
      "For epsilon 10  and d  65122 We have true:  29187 and false:  3374\n",
      "The time it took for the full run of 4001 epochs: 7.738317251205444 \n",
      "\n",
      "For epsilon 0.1  and d  65122 We have true:  20986 and false:  11575\n",
      "The time it took for the full run of 4001 epochs: 8.483958959579468 \n",
      "\n",
      "For epsilon 1  and d  65122 We have true:  25135 and false:  7426\n",
      "The time it took for the full run of 4001 epochs: 8.132582426071167 \n",
      "\n",
      "For epsilon 0.25  and d  65122 We have true:  21588 and false:  10973\n",
      "The time it took for the full run of 4001 epochs: 7.965081453323364 \n",
      "\n",
      "For epsilon 0.5  and d  65122 We have true:  22939 and false:  9622\n",
      "The time it took for the full run of 4001 epochs: 8.2503342628479 \n",
      "\n",
      "For epsilon 2  and d  65122 We have true:  27527 and false:  5034\n",
      "The time it took for the full run of 4001 epochs: 8.103412389755249 \n",
      "\n",
      "For epsilon 4  and d  65122 We have true:  28977 and false:  3584\n",
      "The time it took for the full run of 4001 epochs: 8.21757459640503 \n",
      "\n",
      "For epsilon 8  and d  65122 We have true:  29077 and false:  3484\n",
      "The time it took for the full run of 4001 epochs: 8.077224493026733 \n",
      "\n",
      "For epsilon 20  and d  65122 We have true:  29098 and false:  3463\n",
      "The time it took for the full run of 4001 epochs: 8.331837892532349 \n",
      "\n",
      "For epsilon 50  and d  65122 We have true:  29107 and false:  3454\n",
      "The time it took for the full run of 4001 epochs: 8.435497045516968 \n",
      "\n",
      "For epsilon 0.05  and d  65122 We have true:  20725 and false:  11836\n",
      "The time it took for the full run of 4001 epochs: 7.857808351516724 \n",
      "\n",
      "For epsilon 0.01  and d  65122 We have true:  20517 and false:  12044\n",
      "The time it took for the full run of 4001 epochs: 8.349185943603516 \n",
      "\n",
      "For epsilon 10  and d  6512 We have true:  22776 and false:  9785\n",
      "The time it took for the full run of 4001 epochs: 8.25466775894165 \n",
      "\n",
      "For epsilon 0.1  and d  6512 We have true:  20950 and false:  11611\n",
      "The time it took for the full run of 4001 epochs: 8.225443601608276 \n",
      "\n",
      "For epsilon 1  and d  6512 We have true:  22283 and false:  10278\n",
      "The time it took for the full run of 4001 epochs: 7.961158037185669 \n",
      "\n",
      "For epsilon 0.25  and d  6512 We have true:  21339 and false:  11222\n",
      "The time it took for the full run of 4001 epochs: 8.177270412445068 \n",
      "\n",
      "For epsilon 0.5  and d  6512 We have true:  21772 and false:  10789\n",
      "The time it took for the full run of 4001 epochs: 8.197981357574463 \n",
      "\n",
      "For epsilon 2  and d  6512 We have true:  22595 and false:  9966\n",
      "The time it took for the full run of 4001 epochs: 7.8855299949646 \n",
      "\n",
      "For epsilon 4  and d  6512 We have true:  22652 and false:  9909\n",
      "The time it took for the full run of 4001 epochs: 8.090271472930908 \n",
      "\n",
      "For epsilon 8  and d  6512 We have true:  22765 and false:  9796\n",
      "The time it took for the full run of 4001 epochs: 8.189417600631714 \n",
      "\n",
      "For epsilon 20  and d  6512 We have true:  22723 and false:  9838\n",
      "The time it took for the full run of 4001 epochs: 8.00510835647583 \n",
      "\n",
      "For epsilon 50  and d  6512 We have true:  22744 and false:  9817\n",
      "The time it took for the full run of 4001 epochs: 8.097516298294067 \n",
      "\n",
      "For epsilon 0.05  and d  6512 We have true:  20762 and false:  11799\n",
      "The time it took for the full run of 4001 epochs: 7.87319540977478 \n",
      "\n",
      "For epsilon 0.01  and d  6512 We have true:  20587 and false:  11974\n",
      "The time it took for the full run of 4001 epochs: 8.327255964279175 \n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "For epsilon 10  and d  3256 We have true:  21931 and false:  10630\n",
      "The time it took for the full run of 4001 epochs: 7.892251014709473 \n",
      "\n",
      "For epsilon 0.1  and d  3256 We have true:  20740 and false:  11821\n",
      "The time it took for the full run of 4001 epochs: 7.8572680950164795 \n",
      "\n",
      "For epsilon 1  and d  3256 We have true:  21895 and false:  10666\n",
      "The time it took for the full run of 4001 epochs: 8.216433763504028 \n",
      "\n",
      "For epsilon 0.25  and d  3256 We have true:  21216 and false:  11345\n",
      "The time it took for the full run of 4001 epochs: 8.024431705474854 \n",
      "\n",
      "For epsilon 0.5  and d  3256 We have true:  21524 and false:  11037\n",
      "The time it took for the full run of 4001 epochs: 7.9301228523254395 \n",
      "\n",
      "For epsilon 2  and d  3256 We have true:  21845 and false:  10716\n",
      "The time it took for the full run of 4001 epochs: 7.993886232376099 \n",
      "\n",
      "For epsilon 4  and d  3256 We have true:  21841 and false:  10720\n",
      "The time it took for the full run of 4001 epochs: 8.421506643295288 \n",
      "\n",
      "For epsilon 8  and d  3256 We have true:  21869 and false:  10692\n",
      "The time it took for the full run of 4001 epochs: 8.568015098571777 \n",
      "\n",
      "For epsilon 20  and d  3256 We have true:  22094 and false:  10467\n",
      "The time it took for the full run of 4001 epochs: 7.818110704421997 \n",
      "\n",
      "For epsilon 50  and d  3256 We have true:  21954 and false:  10607\n",
      "The time it took for the full run of 4001 epochs: 8.303586483001709 \n",
      "\n",
      "For epsilon 0.05  and d  3256 We have true:  20756 and false:  11805\n",
      "The time it took for the full run of 4001 epochs: 7.990360498428345 \n",
      "\n",
      "For epsilon 0.01  and d  3256 We have true:  20503 and false:  12058\n",
      "The time it took for the full run of 4001 epochs: 7.884188890457153 \n",
      "\n",
      "For epsilon 10  and d  651 We have true:  21102 and false:  11459\n",
      "The time it took for the full run of 4001 epochs: 8.14060664176941 \n",
      "\n",
      "For epsilon 0.1  and d  651 We have true:  20863 and false:  11698\n",
      "The time it took for the full run of 4001 epochs: 8.18394947052002 \n",
      "\n",
      "For epsilon 1  and d  651 We have true:  21155 and false:  11406\n",
      "The time it took for the full run of 4001 epochs: 8.348958969116211 \n",
      "\n",
      "For epsilon 0.25  and d  651 We have true:  20857 and false:  11704\n",
      "The time it took for the full run of 4001 epochs: 7.879957675933838 \n",
      "\n",
      "For epsilon 0.5  and d  651 We have true:  21096 and false:  11465\n",
      "The time it took for the full run of 4001 epochs: 8.167011976242065 \n",
      "\n",
      "For epsilon 2  and d  651 We have true:  20972 and false:  11589\n",
      "The time it took for the full run of 4001 epochs: 8.281249284744263 \n",
      "\n",
      "For epsilon 4  and d  651 We have true:  20933 and false:  11628\n",
      "The time it took for the full run of 4001 epochs: 7.965115308761597 \n",
      "\n",
      "For epsilon 8  and d  651 We have true:  20993 and false:  11568\n",
      "The time it took for the full run of 4001 epochs: 7.952179431915283 \n",
      "\n",
      "For epsilon 20  and d  651 We have true:  20982 and false:  11579\n",
      "The time it took for the full run of 4001 epochs: 8.203429222106934 \n",
      "\n",
      "For epsilon 50  and d  651 We have true:  20915 and false:  11646\n",
      "The time it took for the full run of 4001 epochs: 8.195603847503662 \n",
      "\n",
      "For epsilon 0.05  and d  651 We have true:  20619 and false:  11942\n",
      "The time it took for the full run of 4001 epochs: 7.654107332229614 \n",
      "\n",
      "For epsilon 0.01  and d  651 We have true:  20453 and false:  12108\n",
      "The time it took for the full run of 4001 epochs: 7.807849645614624 \n",
      "\n",
      "For epsilon 10  and d  6512200 We have true:  32527 and false:  34\n",
      "The time it took for the full run of 4001 epochs: 8.377708911895752 \n",
      "\n",
      "For epsilon 0.1  and d  6512200 We have true:  21118 and false:  11443\n",
      "The time it took for the full run of 4001 epochs: 8.899153232574463 \n",
      "\n",
      "For epsilon 1  and d  6512200 We have true:  26342 and false:  6219\n",
      "The time it took for the full run of 4001 epochs: 8.810202598571777 \n",
      "\n",
      "For epsilon 0.25  and d  6512200 We have true:  21808 and false:  10753\n",
      "The time it took for the full run of 4001 epochs: 9.733551025390625 \n",
      "\n",
      "For epsilon 0.5  and d  6512200 We have true:  23152 and false:  9409\n",
      "The time it took for the full run of 4001 epochs: 8.452515125274658 \n",
      "\n",
      "For epsilon 2  and d  6512200 We have true:  30194 and false:  2367\n",
      "The time it took for the full run of 4001 epochs: 8.38214921951294 \n",
      "\n",
      "For epsilon 4  and d  6512200 We have true:  32194 and false:  367\n",
      "The time it took for the full run of 4001 epochs: 8.182934761047363 \n",
      "\n",
      "For epsilon 8  and d  6512200 We have true:  32508 and false:  53\n",
      "The time it took for the full run of 4001 epochs: 8.31558108329773 \n",
      "\n",
      "For epsilon 20  and d  6512200 We have true:  32514 and false:  47\n",
      "The time it took for the full run of 4001 epochs: 8.161588430404663 \n",
      "\n",
      "For epsilon 50  and d  6512200 We have true:  32519 and false:  42\n",
      "The time it took for the full run of 4001 epochs: 8.12149691581726 \n",
      "\n",
      "For epsilon 0.05  and d  6512200 We have true:  20701 and false:  11860\n",
      "The time it took for the full run of 4001 epochs: 8.781834125518799 \n",
      "\n",
      "For epsilon 0.01  and d  6512200 We have true:  20595 and false:  11966\n",
      "The time it took for the full run of 4001 epochs: 8.617173433303833 \n",
      "\n",
      "For epsilon 10  and d  651220 We have true:  32158 and false:  403\n",
      "The time it took for the full run of 4001 epochs: 8.145281076431274 \n",
      "\n",
      "For epsilon 0.1  and d  651220 We have true:  20909 and false:  11652\n",
      "The time it took for the full run of 4001 epochs: 8.76201319694519 \n",
      "\n",
      "For epsilon 1  and d  651220 We have true:  26260 and false:  6301\n",
      "The time it took for the full run of 4001 epochs: 8.520065784454346 \n",
      "\n",
      "For epsilon 0.25  and d  651220 We have true:  21687 and false:  10874\n",
      "The time it took for the full run of 4001 epochs: 8.485826015472412 \n",
      "\n",
      "For epsilon 0.5  and d  651220 We have true:  23211 and false:  9350\n",
      "The time it took for the full run of 4001 epochs: 8.240095853805542 \n",
      "\n",
      "For epsilon 2  and d  651220 We have true:  29932 and false:  2629\n",
      "The time it took for the full run of 4001 epochs: 8.526182651519775 \n",
      "\n",
      "For epsilon 4  and d  651220 We have true:  31842 and false:  719\n",
      "The time it took for the full run of 4001 epochs: 8.389105319976807 \n",
      "\n",
      "For epsilon 8  and d  651220 We have true:  32146 and false:  415\n",
      "The time it took for the full run of 4001 epochs: 7.937861919403076 \n",
      "\n",
      "For epsilon 20  and d  651220 We have true:  32197 and false:  364\n",
      "The time it took for the full run of 4001 epochs: 8.214247226715088 \n",
      "\n",
      "For epsilon 50  and d  651220 We have true:  32184 and false:  377\n",
      "The time it took for the full run of 4001 epochs: 8.150639772415161 \n",
      "\n",
      "For epsilon 0.05  and d  651220 We have true:  20706 and false:  11855\n",
      "The time it took for the full run of 4001 epochs: 7.7199931144714355 \n",
      "\n",
      "For epsilon 0.01  and d  651220 We have true:  20557 and false:  12004\n",
      "The time it took for the full run of 4001 epochs: 8.127295732498169 \n",
      "\n",
      "For epsilon 10  and d  65122 We have true:  29104 and false:  3457\n",
      "The time it took for the full run of 4001 epochs: 8.32275128364563 \n",
      "\n",
      "For epsilon 0.1  and d  65122 We have true:  21002 and false:  11559\n",
      "The time it took for the full run of 4001 epochs: 8.37870717048645 \n",
      "\n",
      "For epsilon 1  and d  65122 We have true:  25104 and false:  7457\n",
      "The time it took for the full run of 4001 epochs: 8.421780347824097 \n",
      "\n",
      "For epsilon 0.25  and d  65122 We have true:  21798 and false:  10763\n",
      "The time it took for the full run of 4001 epochs: 8.344743251800537 \n",
      "\n",
      "For epsilon 0.5  and d  65122 We have true:  22844 and false:  9717\n",
      "The time it took for the full run of 4001 epochs: 8.52726697921753 \n",
      "\n",
      "For epsilon 2  and d  65122 We have true:  27526 and false:  5035\n",
      "The time it took for the full run of 4001 epochs: 8.588981866836548 \n",
      "\n",
      "For epsilon 4  and d  65122 We have true:  28957 and false:  3604\n",
      "The time it took for the full run of 4001 epochs: 8.178104877471924 \n",
      "\n",
      "For epsilon 8  and d  65122 We have true:  29152 and false:  3409\n",
      "The time it took for the full run of 4001 epochs: 8.642784118652344 \n",
      "\n",
      "For epsilon 20  and d  65122 We have true:  29095 and false:  3466\n",
      "The time it took for the full run of 4001 epochs: 8.442152261734009 \n",
      "\n",
      "For epsilon 50  and d  65122 We have true:  29123 and false:  3438\n",
      "The time it took for the full run of 4001 epochs: 8.242480516433716 \n",
      "\n",
      "For epsilon 0.05  and d  65122 We have true:  20843 and false:  11718\n",
      "The time it took for the full run of 4001 epochs: 8.279974222183228 \n",
      "\n",
      "For epsilon 0.01  and d  65122 We have true:  20494 and false:  12067\n",
      "The time it took for the full run of 4001 epochs: 8.352711915969849 \n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "For epsilon 10  and d  6512 We have true:  22797 and false:  9764\n",
      "The time it took for the full run of 4001 epochs: 8.161235809326172 \n",
      "\n",
      "For epsilon 0.1  and d  6512 We have true:  20915 and false:  11646\n",
      "The time it took for the full run of 4001 epochs: 8.357994794845581 \n",
      "\n",
      "For epsilon 1  and d  6512 We have true:  22502 and false:  10059\n",
      "The time it took for the full run of 4001 epochs: 8.524494409561157 \n",
      "\n",
      "For epsilon 0.25  and d  6512 We have true:  21416 and false:  11145\n",
      "The time it took for the full run of 4001 epochs: 9.153127908706665 \n",
      "\n",
      "For epsilon 0.5  and d  6512 We have true:  21949 and false:  10612\n",
      "The time it took for the full run of 4001 epochs: 8.199840545654297 \n",
      "\n",
      "For epsilon 2  and d  6512 We have true:  22754 and false:  9807\n",
      "The time it took for the full run of 4001 epochs: 8.100493669509888 \n",
      "\n",
      "For epsilon 4  and d  6512 We have true:  22761 and false:  9800\n",
      "The time it took for the full run of 4001 epochs: 8.357839345932007 \n",
      "\n",
      "For epsilon 8  and d  6512 We have true:  22659 and false:  9902\n",
      "The time it took for the full run of 4001 epochs: 8.147159099578857 \n",
      "\n",
      "For epsilon 20  and d  6512 We have true:  22724 and false:  9837\n",
      "The time it took for the full run of 4001 epochs: 8.012393236160278 \n",
      "\n",
      "For epsilon 50  and d  6512 We have true:  22697 and false:  9864\n",
      "The time it took for the full run of 4001 epochs: 8.390901803970337 \n",
      "\n",
      "For epsilon 0.05  and d  6512 We have true:  20497 and false:  12064\n",
      "The time it took for the full run of 4001 epochs: 8.233459234237671 \n",
      "\n",
      "For epsilon 0.01  and d  6512 We have true:  20592 and false:  11969\n",
      "The time it took for the full run of 4001 epochs: 8.057369947433472 \n",
      "\n",
      "For epsilon 10  and d  3256 We have true:  21848 and false:  10713\n",
      "The time it took for the full run of 4001 epochs: 8.13281798362732 \n",
      "\n",
      "For epsilon 0.1  and d  3256 We have true:  20789 and false:  11772\n",
      "The time it took for the full run of 4001 epochs: 7.859421253204346 \n",
      "\n",
      "For epsilon 1  and d  3256 We have true:  21792 and false:  10769\n",
      "The time it took for the full run of 4001 epochs: 7.941359996795654 \n",
      "\n",
      "For epsilon 0.25  and d  3256 We have true:  21168 and false:  11393\n",
      "The time it took for the full run of 4001 epochs: 7.756322622299194 \n",
      "\n",
      "For epsilon 0.5  and d  3256 We have true:  21615 and false:  10946\n",
      "The time it took for the full run of 4001 epochs: 7.979085445404053 \n",
      "\n",
      "For epsilon 2  and d  3256 We have true:  21884 and false:  10677\n",
      "The time it took for the full run of 4001 epochs: 8.024093627929688 \n",
      "\n",
      "For epsilon 4  and d  3256 We have true:  21836 and false:  10725\n",
      "The time it took for the full run of 4001 epochs: 7.8992533683776855 \n",
      "\n",
      "For epsilon 8  and d  3256 We have true:  21860 and false:  10701\n",
      "The time it took for the full run of 4001 epochs: 8.2000892162323 \n",
      "\n",
      "For epsilon 20  and d  3256 We have true:  21931 and false:  10630\n",
      "The time it took for the full run of 4001 epochs: 8.158522129058838 \n",
      "\n",
      "For epsilon 50  and d  3256 We have true:  21945 and false:  10616\n",
      "The time it took for the full run of 4001 epochs: 8.209689378738403 \n",
      "\n",
      "For epsilon 0.05  and d  3256 We have true:  20582 and false:  11979\n",
      "The time it took for the full run of 4001 epochs: 8.091481685638428 \n",
      "\n",
      "For epsilon 0.01  and d  3256 We have true:  20584 and false:  11977\n",
      "The time it took for the full run of 4001 epochs: 8.081299781799316 \n",
      "\n",
      "For epsilon 10  and d  651 We have true:  20924 and false:  11637\n",
      "The time it took for the full run of 4001 epochs: 8.112709760665894 \n",
      "\n",
      "For epsilon 0.1  and d  651 We have true:  20740 and false:  11821\n",
      "The time it took for the full run of 4001 epochs: 8.36589002609253 \n",
      "\n",
      "For epsilon 1  and d  651 We have true:  21229 and false:  11332\n",
      "The time it took for the full run of 4001 epochs: 8.167472124099731 \n",
      "\n",
      "For epsilon 0.25  and d  651 We have true:  20977 and false:  11584\n",
      "The time it took for the full run of 4001 epochs: 8.471281051635742 \n",
      "\n",
      "For epsilon 0.5  and d  651 We have true:  20998 and false:  11563\n",
      "The time it took for the full run of 4001 epochs: 8.461328029632568 \n",
      "\n",
      "For epsilon 2  and d  651 We have true:  20998 and false:  11563\n",
      "The time it took for the full run of 4001 epochs: 8.297476291656494 \n",
      "\n",
      "For epsilon 4  and d  651 We have true:  21032 and false:  11529\n",
      "The time it took for the full run of 4001 epochs: 8.318461418151855 \n",
      "\n",
      "For epsilon 8  and d  651 We have true:  20896 and false:  11665\n",
      "The time it took for the full run of 4001 epochs: 8.249709606170654 \n",
      "\n",
      "For epsilon 20  and d  651 We have true:  21060 and false:  11501\n",
      "The time it took for the full run of 4001 epochs: 8.264955759048462 \n",
      "\n",
      "For epsilon 50  and d  651 We have true:  21019 and false:  11542\n",
      "The time it took for the full run of 4001 epochs: 8.07779836654663 \n",
      "\n",
      "For epsilon 0.05  and d  651 We have true:  20708 and false:  11853\n",
      "The time it took for the full run of 4001 epochs: 8.312705278396606 \n",
      "\n",
      "For epsilon 0.01  and d  651 We have true:  20369 and false:  12192\n",
      "The time it took for the full run of 4001 epochs: 8.222418308258057 \n",
      "\n",
      "For epsilon 10  and d  6512200 We have true:  32508 and false:  53\n",
      "The time it took for the full run of 4001 epochs: 8.458927631378174 \n",
      "\n",
      "For epsilon 0.1  and d  6512200 We have true:  21193 and false:  11368\n",
      "The time it took for the full run of 4001 epochs: 8.394045114517212 \n",
      "\n",
      "For epsilon 1  and d  6512200 We have true:  26260 and false:  6301\n",
      "The time it took for the full run of 4001 epochs: 7.913748741149902 \n",
      "\n",
      "For epsilon 0.25  and d  6512200 We have true:  21730 and false:  10831\n",
      "The time it took for the full run of 4001 epochs: 9.022627115249634 \n",
      "\n",
      "For epsilon 0.5  and d  6512200 We have true:  23220 and false:  9341\n",
      "The time it took for the full run of 4001 epochs: 8.625458478927612 \n",
      "\n",
      "For epsilon 2  and d  6512200 We have true:  30237 and false:  2324\n",
      "The time it took for the full run of 4001 epochs: 8.460537433624268 \n",
      "\n",
      "For epsilon 4  and d  6512200 We have true:  32208 and false:  353\n",
      "The time it took for the full run of 4001 epochs: 8.757287979125977 \n",
      "\n",
      "For epsilon 8  and d  6512200 We have true:  32522 and false:  39\n",
      "The time it took for the full run of 4001 epochs: 8.383890390396118 \n",
      "\n",
      "For epsilon 20  and d  6512200 We have true:  32524 and false:  37\n",
      "The time it took for the full run of 4001 epochs: 8.176410436630249 \n",
      "\n"
     ]
    }
   ],
   "source": [
    "for run in range(0, 10):\n",
    "    v = 2\n",
    "    n_ab = len(df)\n",
    "    for d in [n_ab*100*v,n_ab*10*v, n_ab*1*v, int(n_ab*0.1*v),int(n_ab*0.05*v),int(n_ab*0.01*v)]:\n",
    "        for eps in [10,  0.1, 1, 0.25, 0.5, 2, 4, 8, 20, 50, 0.05, 0.01]:\n",
    "      \n",
    "            t0 = time.time()\n",
    "            labels = []\n",
    "            hashes = []\n",
    "            vectors = []\n",
    "\n",
    "            salt = np.random.randint(low=65,high=90,size=20,dtype=\"int32\").view(f\"U{20}\")[0]\n",
    "            for i in range(n_ab):\n",
    "                labels.append(target_tensor[i])\n",
    "                s = str(i) + str(int(target_tensor[i].item())) + salt \n",
    "                hot = int(hashlib.sha256(s.encode(\"utf-8\")).hexdigest(),16)\n",
    "                hashes.append(hot)\n",
    "                vectors.append((hot // 2) % d)\n",
    "\n",
    "            vectors = np.array(vectors)   \n",
    "            one_hot_matrix_hash = {}      \n",
    "\n",
    "            for i in range(vectors.size):\n",
    "                hot = hashes[i]\n",
    "                sign = 2 * (hot % 2) - 1\n",
    "                one_hot_matrix_hash[i] = [vectors[i], sign]\n",
    "            \n",
    "            buckets = np.zeros(d)        \n",
    "\n",
    "            for i in range(vectors.size):\n",
    "                buckets[one_hot_matrix_hash[i][0]] += one_hot_matrix_hash[i][1]\n",
    "\n",
    "\n",
    "            alpha = np.exp(-eps)\n",
    "            buckets += np.random.geometric(1-alpha,size = (buckets.shape))-np.random.geometric(1-alpha,size = (buckets.shape))\n",
    "\n",
    "            ##============================================================================##\n",
    "            ##================== This marks the end of S's work ==========================##\n",
    "            ##============================================================================##\n",
    "            \n",
    "            # Now clip them\n",
    "            buckets[buckets >= 1] = 1\n",
    "            buckets[buckets <= -1] = -1\n",
    "            buckets[buckets == 0 ] = 0           \n",
    "\n",
    "            # The sum over i should be over the \"ids\" that party R is privy to. \n",
    "            out = []\n",
    "            rep_dict = {}\n",
    "            for i in range(vectors.size):\n",
    "                temp = []\n",
    "                for j in range(v):                                                \n",
    "                    s = str(i) + str(j) + salt \n",
    "                    hot = int(hashlib.sha256(s.encode(\"utf-8\")).hexdigest(),16)\n",
    "                    vec = (hot // 2) % d                        \n",
    "                    sign = 2 * (hot % 2) - 1                        \n",
    "                    if vec in rep_dict:\n",
    "                        rep_dict[vec] += 1\n",
    "                    else:\n",
    "                        rep_dict[vec] = 1                        \n",
    "                    temp.append(sign*buckets[vec]) \n",
    "                out.append([temp])\n",
    "\n",
    "            w = []    \n",
    "            for i in range(vectors.size):\n",
    "                temp = []\n",
    "                for j in range(v):                                                \n",
    "                    s = str(i) + str(j) + salt \n",
    "                    hot = int(hashlib.sha256(s.encode(\"utf-8\")).hexdigest(),16)\n",
    "                    vec = (hot // 2) % d                                            \n",
    "                    temp.append(1/rep_dict[vec])\n",
    "                w.append([temp])\n",
    "    \n",
    "            out = np.array(out).squeeze()\n",
    "            w = np.array(w).squeeze()\n",
    "          \n",
    "            # The lines below are just to get an estimate the number of labels that get flipped. \n",
    "            result = np.argmax(out,axis = 1)\n",
    "            tru = 0\n",
    "            fal = 0\n",
    "            for i in range(vectors.size):\n",
    "                if int(result[i]) == int(target_tensor[i]):\n",
    "                    tru  += 1\n",
    "                else:\n",
    "                    fal += 1\n",
    "            print(\"For epsilon\", eps,\" and d \", d, \"We have true: \", tru, \"and false: \", fal)\n",
    "#             input()\n",
    "            # Now party R starts training\n",
    "            \n",
    "            labels_raw = torch.tensor(out).cuda() \n",
    "            weights_raw = torch.tensor(w).cuda() \n",
    "            \n",
    "            image_data = features_tensor.cuda()\n",
    "            test_features_tensor = test_features_tensor.cuda()\n",
    "            test_target_tensor = test_target_tensor.cuda()\n",
    "#             batch_size = len(df)\n",
    "\n",
    "            input_size = features_tensor.shape[1]\n",
    "            output_size = 1\n",
    "        \n",
    "            model = LogisticRegression(input_size, output_size)\n",
    "\n",
    "            model = model.cuda()\n",
    "            num_epochs = 4001\n",
    "            optimizer_raw = torch.optim.Adam(model.parameters(), lr = 1e-3)\n",
    "\n",
    "            for epoch in range(num_epochs):\n",
    "\n",
    "                images = image_data.float()\n",
    "\n",
    "                labels_for_model = labels_raw\n",
    "                weights_for_model = weights_raw\n",
    "\n",
    "                outputs = model(images)   \n",
    "\n",
    "                stack_outputs = torch.stack([1-outputs,outputs]).squeeze().T\n",
    "#                     input()\n",
    "                labels_final = torch.mul(labels_for_model, weights_for_model) \n",
    "\n",
    "#                     out_norm = torch.nn.functional.softmax(outputs,dim=1)\n",
    "\n",
    "                out_clip = torch.where(stack_outputs > 0.0001, stack_outputs, 0.0001)                    \n",
    "\n",
    "                out_log = torch.log(stack_outputs)\n",
    "\n",
    "                l = - torch.mean( torch.sum(labels_final * out_log,dim=1) )\n",
    "\n",
    "                optimizer_raw.zero_grad()\n",
    "                l.backward()\n",
    "                optimizer_raw.step()\n",
    "\n",
    "                if epoch % 10 == 0:\n",
    "                    #print(epoch, l.item())\n",
    "                    #print(f\"For {epoch}, {eps}, {d} the test accuracy is: \")\n",
    "                    with torch.no_grad():\n",
    "                        outputs = model(test_features_tensor)\n",
    "                        outputs[outputs.squeeze() >= 0.5] = 1 \n",
    "                        outputs[outputs.squeeze() < 0.5] = 0\n",
    "\n",
    "                        accuracy = torch.sum(outputs.squeeze() == test_target_tensor) / len(df_test)\n",
    "                        true_poor_fake_rich = torch.sum(outputs.squeeze() - test_target_tensor == 1)  / len(df_test)\n",
    "                        fake_poor_true_rich = torch.sum(outputs.squeeze() - test_target_tensor == -1) / len(df_test)\n",
    "                        #print(accuracy.item(), true_poor_fake_rich.item(), fake_poor_true_rich.item())\n",
    "                        #print(\"\\n \\n\")\n",
    "                        \n",
    "                \n",
    "                    \n",
    "\n",
    "                    results_dict[d,eps,epoch,run] = [accuracy.item(), true_poor_fake_rich.item(), fake_poor_true_rich.item()]\n",
    "\n",
    "            f = open(\"perfect_join\",\"wb\")\n",
    "            pickle.dump(results_dict,f)\n",
    "            f.close()\n",
    "        \n",
    "            print(f\"The time it took for the full run of 4001 epochs: {time.time() - t0} \\n\")\n",
    "            t0 = time.time()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a4822d56",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a9fb3276",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8af260fe",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "446fad74",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b1edf67d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "e94d3c09",
   "metadata": {},
   "outputs": [],
   "source": [
    "res = {}\n",
    "n_ab = len(df)\n",
    "v = 2\n",
    "\n",
    "for run in range(10):\n",
    "    for eps in [0.1, 0.25, 0.5, 1, 2, 4, 8, 10, 20, 50, 0.05, 0.01]:\n",
    "        for d in [n_ab*10*v, n_ab*1*v, int(n_ab*0.1*v),int(n_ab*0.01*v)]:\n",
    "            arr = []\n",
    "            for i in results_dict.keys():\n",
    "                if i[1] == eps and i[0] == d and i[3] == run and i[2] == 1000:\n",
    "                    arr.append(results_dict[i][0])\n",
    "            if len(arr) > 0:\n",
    "                res[eps, d, run] = arr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "2a0792a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "res_avg = {}\n",
    "for eps in [0.1, 0.25, 0.5, 1, 2, 4, 8, 10, 20, 50, 0.05, 0.01]:\n",
    "    for b in [n_ab*10*v, n_ab*1*v, int(n_ab*0.1*v),int(n_ab*0.01*v)]:\n",
    "        arr = []\n",
    "        for i in res.keys():\n",
    "            for run in range(0,10):\n",
    "                if i[0] == eps and i[1] == b:\n",
    "                    arr.append( res[i][0] )\n",
    "        if len(arr) > 0:\n",
    "            res_avg[eps, b] = np.mean(arr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "cc344444",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{(0.1, 651220): 0.7770591795444488,\n",
       " (0.1, 65122): 0.7696947693824768,\n",
       " (0.1, 6512): 0.7794361889362336,\n",
       " (0.1, 651): 0.7625207662582397,\n",
       " (0.25, 651220): 0.8177815079689026,\n",
       " (0.25, 65122): 0.8180517494678498,\n",
       " (0.25, 6512): 0.8101775467395782,\n",
       " (0.25, 651): 0.7883361339569092,\n",
       " (0.5, 651220): 0.8277808904647828,\n",
       " (0.5, 65122): 0.8249739348888397,\n",
       " (0.5, 6512): 0.8189177930355072,\n",
       " (0.5, 651): 0.7901357889175415,\n",
       " (1, 651220): 0.829924488067627,\n",
       " (1, 65122): 0.8298077881336212,\n",
       " (1, 6512): 0.82470982670784,\n",
       " (1, 651): 0.7940605998039245,\n",
       " (2, 651220): 0.8303851544857025,\n",
       " (2, 65122): 0.830974793434143,\n",
       " (2, 6512): 0.8242430269718171,\n",
       " (2, 651): 0.7902524828910827,\n",
       " (4, 651220): 0.8305018484592438,\n",
       " (4, 65122): 0.8308212399482727,\n",
       " (4, 6512): 0.8257355570793152,\n",
       " (4, 651): 0.7939930260181427,\n",
       " (8, 651220): 0.8307721078395843,\n",
       " (8, 65122): 0.8304465651512146,\n",
       " (8, 6512): 0.8268165647983551,\n",
       " (8, 651): 0.7909711062908172,\n",
       " (10, 651220): 0.8308458030223846,\n",
       " (10, 65122): 0.8307905197143555,\n",
       " (10, 6512): 0.8251459121704101,\n",
       " (10, 651): 0.7923837959766388,\n",
       " (20, 651220): 0.831189775466919,\n",
       " (20, 65122): 0.8303482949733734,\n",
       " (20, 6512): 0.826945549249649,\n",
       " (20, 651): 0.7905595779418946,\n",
       " (50, 651220): 0.830931794643402,\n",
       " (50, 65122): 0.831060779094696,\n",
       " (50, 6512): 0.8253363132476806,\n",
       " (50, 651): 0.7883914172649383,\n",
       " (0.05, 651220): 0.7602113246917724,\n",
       " (0.05, 65122): 0.7312757551670075,\n",
       " (0.05, 6512): 0.7497328460216522,\n",
       " (0.05, 651): 0.7503286480903626,\n",
       " (0.01, 651220): 0.617670938372612,\n",
       " (0.01, 65122): 0.5863153591752053,\n",
       " (0.01, 6512): 0.5965113013982772,\n",
       " (0.01, 651): 0.5931208342313766}"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res_avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "e9727009",
   "metadata": {},
   "outputs": [],
   "source": [
    "res_eps = {}\n",
    "for eps in [ 0.01, 0.05, 0.1, 0.25, 0.5, 1, 2, 4, 8, 10, 20, 50]:\n",
    "    res_eps[eps] = []\n",
    "    for b in [n_ab*10*v, n_ab*1*v, int(n_ab*0.1*v),int(n_ab*0.01*v)]:\n",
    "        res_eps[eps].append(res_avg[eps,b])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "4a8fe331",
   "metadata": {},
   "outputs": [],
   "source": [
    "res_d = {}\n",
    "for d in [n_ab*10*v, n_ab*1*v, int(n_ab*0.1*v),int(n_ab*0.01*v)]:\n",
    "    res_d[d] = []\n",
    "    for eps in [0.01, 0.05, 0.1, 0.25, 0.5, 1, 2, 4, 8, 10, 20, 50]:    \n",
    "        res_d[d].append(res_avg[eps,d])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "2e33e977",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "32561"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "eps_vals = [0.01, 0.05, 0.1, 0.25, 0.5, 1, 2, 4, 8, 10, 20, 50]\n",
    "len(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "193bbaf9",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.ticker as ticker"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 127,
   "id": "79f2007e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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28JlOFcCH1QQUUREhqI0fSIiIiIiUqojw2U18YEoCC5GrR27LomIyHgK07mtzisaaTDqb8CevHWl6hsfZwJvAa4BtpVQfy9wBXCiu5+lQJSIiAxHI6NERERERKQSeoGPu/ul490REREZO+6eBWaMYv8+oLlyPZJyuHs78ONwwcz2Aw4B9iFIx1dHEDRsAx4A7nf3zPj0VkREJiMFo0REREREpBxOkJLvCeB64CJ3f2x8uyQiIiKVEI5y1khnERGpGAWjRERERESkJO5u490HERERERERmXw0Z5SIiIiIiIiIiIiIiIhUjbn7ePdBREREREREREREREREpiiNjBIREREREREREREREZGqUTBKREREREREREREREREqkbBKBEREREREREREREREakaBaNERERERERERERERESkalLj3QGRsWZmdcCqcHU7kBnH7oiIiIiIiIiIiIiITBRJYH74+H5376lEowpGyXS0CrhjvDshIiIiIiIiIiIiIjKBHQ/cWYmGlKZPREREREREREREREREqkYjo2Q62p57cPvtt7N48eLx7IuIiIiIiIiIiIiIyITw9NNP84xnPCO3un2ouiOhYJRMR/1zRC1evJhly5aNZ19ERERERERERERERCaizPBVSqM0fSIiIiIiIiIiIiIiIlI1CkaJiIiIiIiIiIiIiIhI1SgYJSIiIiIiIiIiIiIiIlWjYJSIiIiIiIiIiIiIiIhUjYJRIiIiIiIiIiIiIiIiUjUKRomIiIiIiIiIiIiIiEjVKBglIiIiIiIiIiIiIiIiVaNglIiIiIiIiIiIiIiIiFSNglEiIiIiIiIiIiIiIiJSNQpGiYiIiIiIiIiIiIiISNUoGCUiIiIiIiIiIiIiIiJVo2CUiIiIiIiIiIiIiIiIVI2CUSIiIiIiIiIiIiIiIlI1CkaJiIiIiIiIiIiIiIhI1SgYJSIiIiIiIiIiIiIiIlWjYJSIiIiIiIiIiIiIiIhUTWq8OyAynh577DHa29tHvN/ChQuZO3du7LZHHnmEbDZbVn/mzZvHggULYrc98cQT9Pb2ltVuc3MzS5Ysid321FNP0dnZWVa7M2bMYMWKFbHb1q9fz969e8tqt7GxkX322Sd22+bNm9m9e3dZ7dbW1nLAAQfEbtu2bRs7duwoq91EIsEhhxwSu62trY2tW7eW1S7AYYcdFlu+Z88e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xnra4edvhSeuL972/H+H554HZhXo9dSW3rmTtssvZ+ePryDb3j5ovbrDDqPl3e9i5otehCUV4BMREREREZHxo2CUiIiIiBRxd65ffz3n//N8NrRviK2T7ZvFc1vO5uuvfDu1qWE+VnZsgyteB0/fW1huSXjV1+GYt1So51NX35YttF16KTt/fhXe1TVovYajj6blPe9mxnOfiym4JyIiIiIiIhOAglEiIiIiUmDNjjV85c6vcMeWO2K3e7aG5J4XcP6LP8iLD1sxfIM7noAfnQa7niosr2mEMy6Dg18y+k5PYb1PPcWOS77Prmuvhb6+QevNOOkkWt79LhqOO05BKBEREREREZlQFIwSEREREQBau1r5xl3f4NrHr8UHmReqb9fRHFb3Rr5z9gtY1Fw/fKMb/wlXngGdkTmNGufBm66CZcdWoOdTU/cjj7Lj4ovZc911kM0OWm/mi17EvHe9i4ZVK8ewdyIiIiIiIiKlUzBKREREZJrryfTwo4d+xPfu+x6d6c7YOpnOfeje+kre/cyT+diLDiaVTAzf8KN/gqveBn2RNmfvA2/+BbQcWIHeTz1d99xD63cvpuOGGwavlEzS/MpXMu/cc6g7UL9HERERERERmdgUjBIRERGZptydP677Ixf88wI2790cWyfbO5uebS+jKXMs3zrzaJ5/yILSGr/rR/CbD4FnCssXHwlnXQ1NJbYzTbg7nbfeSut3L6bz1lsHrWe1tTS/9nTmvfMcapctHcMeioiIiIiIiJRPwSgRERGRaeiB1gf48h1f5u5td8du90wtvTueT2/bSRy7YgHfPPNolsxuGL5hd/jb/8INnyvetv/z4Q0/grqZo+z91OHZLB033EDrdy+m+777Bq2XaGxk9plvZO7b3kbNAgXyREREREREZHJRMEpERERkGtm6dytfv+vr/ObJ38Rudzf6dh9L7/YX4+lZvPu5+3PeSw6hppS0fNkM/P48uPMHxdtWvwFOvRBStaN8BlODp9Psue4P7Lj4Ynoee2zQesnmZua89S3MPesskrNnj10HRURERERERCpIwSgRERGRaaAr3cVlD1zGpQ9eSle6K7ZOeu9+9Gx9JdmepTQ31PDVs47khYctLO0AfV1wzTnw8G+Ltz37w3DKZ8Cs7P5PFdneXnb/8lp2XHIJfRs2DFovNX8+c9/+dua84fUkZswYwx6K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5oGWev369aNhw4Z+re3999+nQ4cOzJ8/3xH/5z//ybx580rd8datWzcWL17MRRdd5IhPnTqVE044wbE7qTzh+hl7F9Nee+01nn/+efbu3et3bqlaVIwSETkEhao9H8ALC19g1/6dXDs1n0ivWpSJiaHhffe5V/xaPg5WTHDGjr8Q2vRzZ34RERERERGRKmTAgAGOnSNjxowhNze3zGemTZvGypUrD1z37duXGjVquLIe78JErVq1ONLrbOj4+HgmTJjAscceeyB24403MnnyZFdyl7eemJgYv8/GWr58OV26dGHBggUHYq1bt+att94q87m0tLQDu9RK2xVlreXWW29lx44dNGjQ4MD5RxX1yCOPMGzYMNLSDp6XXadOHb766itefvn/2bvv8CirtI/j3yeVhAChhogoRQWkJghKESSoSFVZC65lLatrR0SR3gV0WcS2K9h2XX1R10oR6YSmtBhQSqQrSEKHQAgkM+f9IzDME1ImM5NMCL/Pdc3FnDPnOeeeh2xk555zn7cpV67gz3eio6P54osv+Ne//kVERISrf9++fXTr1q3Q93hWoO5x27ZtXfc2MzOTfv36UaNGDTp16sSoUaNYunQp2dnZRYpFAk/JKBGRMiav8nydGxZPeb51+9fxv1//R4dfDI1221+r+te/Eub2TRafZBzK2RXlLrIqdPu7f+YXERERERERKWViYmJ49NFHXe1t27YxYcKEfMdnZmbyzDPPuNqWZTF06FC/xeOemIiLizvvy6dVq1bl+++/d+0Acjgc3HXXXaxcudJvMZyVmppqKzl39dVXExoa6tG1e/bs4fHHHycuLo6dO3e6+uvVq8fs2bOJjo4u8PqffvrJVTLvqquu4vjx465HWloas2fP5sYbb+T999+nXbt2LF261LbTxxO//vqrrd2+fXuSk5O57bbbijTP448/zqpVq2jcuLGrzxjDli1bCr02kPc4LCyM6dOn06lTJ1dfVlYWixcvZuTIkXTo0IGYmBj69+9v23ElpZuSUSIiZUh+5fnG9fZ/eb5sZzZjfhhDRKaT+xY6ba+FXnopVR97NJ8rvfD9QDiR6x8XXV+F8tX8t4aIiIiIiIhIKTN48GAqVKjgao8YMYJJkybhdNr/f/j+/fvp2rUrGzdudPXdfffdxMXF+SUOYwzr1q1ztc+W6MutTp06zJo1i6ioKCCn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FQXnyvRVq1Yt33OKMjIyXCX1evToQc0iHnnw8ccfExcXx+rVq239Tz75JCtXrqRhw4Z5Xte2bVuSk5P505/+ZOufM2cOzZo1s+1OKkyg7rF7Mm3KlClMnjyZI0eOFHltufiUimTUWcaYzcaYwcaYlsaYGsaYcGNMjDEmwRjzD2NMehGn/BCIy/V4zd9xi8jFIxDl+QBeXf0q6VnpBDkNf51jr+0cFBVFjQEv5nOlh+YOgeO5DqC6ZQJU8OH8KREREREREREpMe7JiejoaOrVq+dqR0REMH36dBo0aODqe/zxx5k1a1axxxIWFkajRo2KdP2GDRu47rrrWLNmjauvYcOGfPDBBwVel56ezrZt24D8d0UZY3j22WfZv38/MTExrvOPPDVmzBjuv/9+0tPPfVRdpUoVvv76a95++23KlSv4M6Lo6Gi++OIL/vWvfxEREeHq37dvH926dSv0PZ4VqHvctm1b173NzMykX79+1KhRg06dOjFq1CiWLl1KdnZ2kWKRi0OpSkb5mzFmizFmXa7HscKvFBE534JN55fnu6EEyvOt2LOC2Ttyvq1zyxrD5fvtr1d/9hlCa9TwfoFtC+Gnj+19V9wIze/xfk4RERERERERKVHuyYm4uLjzKrhUrVqV77//3rULyOFwcNddd7Fy5Uq/xpGammorOXf11VcT6uGxAnv27OHxxx8nLi6OnTt3uvrr1avH7NmziY6OLvD6n376yVUy76qrruL48eOuR1paGrNnz+bGG2/k/fffp127dixdutS208cTv/76q63dvn17kpOTue2224o0z+OPP86qVato3Lixq88Yw5YtWwq9NpD3OCwsjOnTp9OpUydXX1ZWFosXL2bkyJF06NCBmJgY+vfvb9txJVKmk1EiIv5yNCOLQV/lVZ6vabGW58vMzmTsyrEAVE433LXUaXs9vEEDKv/5z94vcCodpve194VVgB6TVZ5PRERERERE5AJhjGHdunWu9tkSfbnVqVOHWbNmERUVBeSUq+vRo4dHCRBPeVo+7ujRo2zbto3ly5czYcIEEhISqFevHlOmTCErK8s1rn379ixbtow6deoUae2pU6dSoUIF16NmzZp069aNJUuWMGnSJJYtW8aVV17p3Zskp/zhsGHDWLx4MbVr1/ZqjiZNmrB69WoeffTRIl0XyHsMULduXRYuXEhycjKDBg0i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Z7v/9erVY/bs2URHRxd4/U8//eQqmXfVVVdx/Phx1yMtLY3Zs2dz44038v7779OuXTuWLl1q2+njiV9//dXWbt++PcnJydx2221Fmufxxx9n1apVNG7c2NVnjGHLli2FXhvIexwWFsb06dPp1KmTqy8rK4vFixczcuRIOnToQExMDP3797ftuJKSpWSUiARcaSjPN2/XPJbuWepq3/6Dk5gj9jE1XnyB4IoVizbxopfh8A57X+cRUKWud4GKiIiIiIiISKkxePBgKlSo4GqPGDGCSZMm4XTav+C6f/9+unbtysaNG119d999N3FxcSUWa0kzxrBu3TpX+2yJvtzq1KnDrFmziIqKAnLK1fXo0cOjBIinPC0fd/ToUbZt28by5cuZMGECCQkJ1KtXjylTpth2vbVv355ly5ZRp06dIq09depUKlSo4HrUrFmTbt26sWTJEiZNmsSyZcu48sorvXuT5JQ/HDZsGIsXL6Z2be8+V2vSpAmrV6+2JVo9Ech7DFC3bl0WLlxIcnIygwYNIj4+niC3YzYOHTrEpEmTaNasGZs3by7SexP/CAl0ACJycTuWGfjyfMdPH+eVVa+42jGHDLf+aC/PF3FNSyrlqgVdqN9Xww9v2/tqXwetH/M2VBEREREREREpRS655BKmTZtGr169cDqdGGPo378/77zzDp07d6ZKlSps3bqVGTNmcPLkSdd1V199NVOmTClgZu/t2rWL+vXr5/maw+GwjQsJyfvj4QULFtCxY0ef4ti6dautbFzLli3zHRsfH8///vc/evbsSXZ2NgcOHOCWW25hxYoV+Z6xVBS5EyUfffQRH3/8sa3PGHNeEjG3ypUrM3ToUPr27UtwcLBXa+clOzubAQMGEBcXxw033ODRvLnVqlWLTz75xOe/N8gpoTh16lRuuukmHn30UY4ePVroNYG8x+6aN29O8+bNGTduHIcPH2bRokV89tlnfPnllzgcDlJTU3nqqadYsGBBkecW32hnlIgE1NiZ55fnG1KC5fkA3kp+i30n9+U0jOHheU5CHW4DgoOpOWx40ZJjWZnw7VOAW1IrOBxufQuC9KtXREREREREpKzo3r07//73v4mMjHT1bdmyhXfeeYdx48bx+eef2xJRLVq0YNasWVQsavUVDxljcDgceT5yy2/c2bJyvsidnMhvZ9RZt9xyC1OnTnW1t2/f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EGhT2e5fwNjMYtGbOfo9Amxf+bgpcCjwUFUThxBakP59mh5jzDW/SuD5Gc8zdlr6m6bv9jqMjrf8gyUVFclYaNaMjX71q9xLfN97GN5/ND22/RGwzUFZu0uSJEmSJDVETZo0YeDAgTz22GNAonB0xRVX5Oyfqxh1wgknZO2/fPlyxo8fn2wPHVr90QepW/QNGzaMZs2a5ex73XXXccEFF6TFOnXqxAEHHMCmm27KwoULef3113nppZeSK5Vefvll9t57byZMmECHDh2qzaembrnlFq6//noAWrVqxbBhw9hqq62oqKhg0qRJPPXUU6xYsQKAr776iiFDhjBhwgR69crv9/6XLl3KEUcckSx09e7dm3333ZeNNtqI+fPn88477xS8AqxRo0accMIJyZ+BiRMn8u6777LjjjvmNf6BBx5g2bJlyXZqISeXjTfemB133JHevXvTvn17mjVrxrx583j//fd5/vnnk0Wkjz76iAMOOIA333yTDTao+pfFly9fzrBhw9Za+dWpUycGDx5Mz549admyJd988w2TJk3itddeY9GiRVnnOvPMM7n22muJMRJjZOTIkfzv//5vta8L4O233+aVV15Jtk899VSaNLGEsa7wT7J2PArczJrzn04LIVwbY1yRa0AIYTCwdUpoTIwx+9/wAsUYl4UQHgaOrwx9J4SwQ4xxUlXjQgjbAHunhL6IMWb/NQUYBfwypX0W1RSjgGOBDintv1fTX0WIMXLdxOvSYh2ad+DML7Zl/hv/SIt3PO00mvXsmX2ixXMTq6JSteoIB+b3j4wkSZIkSVJDMnTo0GQxauLEiXzzzTdZP+z/6quvmDQp8XFb48aNqaj8xd+nnnoq59wvv/xy2of8+RSjRo8enXxc1RZ9r7/+OhddtOaIhRACF198MRdffPFaBazXX3+d4447jo8++giADz/8kDPOOIMHH3yw2nxq6qc//SkAhx9+OH/605/W2obv008/5Yc//CEvvvgiAHPmzOHUU0/lmWeeyeuMpFGjRlFRUUGHDh24/fbbOfLII9fqs3z58oLzPvnkk9MKknfeeSfXXnttXmNTV1J169aN/fffP2u/zTbbjMsvv5wjjjiC7bbbLud8CxYs4Morr+QPf/gDMUamTZvGL3/5S2699dYq8/jJT36SVojacMMNufrqqznppJNo3LjxWv2XLl3KmDFj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M2/UqLRY22HDaLN3/+wDpr0Er45Mj23aH3Zz6awkSZIkSVq/DBkyJPl4zpw5ybOUJk6cmFyps/XWW9OjR49kv0GDBtG4cWMAJkyYkCyiZG7zlzp3NuPGjUt+gN+pUyf23HPPKvu3bds2+XjRokVV9s2UWehJnauUCskrs2+piyg1deKJJ6YVhO688861+qRu0de7d28GDBhQ5ZyXXXZZspjUqFEj/v73vzN27FjOOussdt99dzbeeGNat2691hlL+RTo2rVrV/CYQo0YMSL5+PXXX2fixIlpz48cueazxq222orBgweXPAfVDxajpPVUjJEvf3s5pPxmRGjViq6/+Hn2ASuWwCNnp8eatIRDbwIPFJQkSZIkSeuZ1MISrCkopa5Yylzh1K5dO/r16wckzhVavXJl7NixyT69evVis802q/LaqVv0HXjggWl5ZLPBBhskH3/55ZdV9s2U2T91rlIqZNvKWbNmpbXLlVOhunXrxn777ZdsZ66CWr1aarXqVkUtXryYp59+Otk+4YQTOPLII/PKJfN7lE3Hjh3T2p9//nlecxfi6KOPTrtO6vlQ48eP57333ku2Tz/99JJfX/WHnyBL66kQAl1/9Suapxze2HnEWTTNtW/ws1fC3P+mxwZfDB17lTFLSZIkSZKk+qlDhw707ds32V5dUMp1XlS22Oq+qQWH6rboizHy2GOPJdvVbdEHiRVaq3300Udp26JVJ7V4ArBNymdJpbR6ZVk+3n777bT2dtttV+Jsau6UlHPY586dm1Y4TF0p1ahRI0444YQq55o6dSrLli1LtocPH55XDrNmzWLGjBnV9ttxxx3T2q+88kpe8xeiRYsWaVvzPfDAA3z77bdAemGqRYsWnHTSSSW/vuoPi1HSeqzVrn3YfNTf6frLX9Jyl13YMNc/gJ9PhJduSo912w32OLP8SUqSJEmSJNVTqYWjF154gXnz5vHiiy8C0LhxYwYNGlTlmHHjxjFp0iRmzpyZ9flsXn311eRqpebNmzNs2LBq89xrr72SjysqKtKKWdV5+OGHk49btmzJLrvskvfYQhSSU2qBJ4SQXG1WHxx22GFp56utLkCtXLmS++67Lxnfb7/96N69e5VzzZs3L62d7wqwv/3tb3n122effdK293vggQfyGleoM844I3mdRYsWce+99/L111/zj3/8I9nn+9//ftnOpVP9YDFKWs+FJk3Y8IQfsukD9xOyHeS4chk8PALiqjWxxs3gsFugUdVLwCVJkiRJktZlqYWjJUuWcPXVV7N06VIA+vXrR/v27dcas+eee9K6dWsAJk2alFagaNSoUbVn5owePTr5eNCgQXmdl3TYYYelta+77rrkOURVefTRR5kyZUqyffDBB9M02+dHJTBq1Ki0olwuEydOTBb8IHG+Vrbvc11p3rw5xxxzTLL973//m5kzZ/L444+nbUWYuoIql8zzuaZOnVrtmEWLFnHdddfllWv79u056KCDku3XX3897eerVDbffPO0VV0jR47kzjvvTFv1dcYZZ5T8uqpfLEZJAhK/RZLV+Gtg9vvpsYE/gy7lWZItSZIkSZLUUOy11160bNky2b7hhhuSj3OtcGrWrBkDBgxItm+88cbk41122aXa1SGpq4IOOeSQvPLcaaedGDhwYLI9YcIErrnmmirHzJw5k7PPTj8//Nxzz83rejWxaNEizjjjDFatWlVlnx//+MdphbQzz6x/O/ekFpoqKiq4995707bo22CDDdYqEGbTu3dvmjdvnmzfcccdVX5/YoyceeaZfPrpp3nn+vOfp58ff+qpp/LBBx/kPT6foibAiBEjko/fffddfve73yXbO+20E3vuuWfe11TDZDFKUm5fTkoUo1JttCP0P69O0pEkSZIkSapPmjdvzt57751sp57FtN9+++Ucl1qoSh1T3RZ9U6dO5d1330228y1GAVxzzTVpq5p+9rOfcemll7JixYq1+r7xxhsMHjyY6dOnJ2NHH300/fv3z/t6hWrevDmPPvoo3//+9/n666/Xen7atGkMHz487QyrgQMHcvjhh5ctp5radddd2WmnnZLtW2+9lTFjxiTbxx57bFqRKZeWLVuy//77J9uvvPIKp556KkuWLFmr78yZMznyyCO59957AZKr76qz1157pRX0Zs+eTf/+/bnzzjupqKjIOmbZsmU8/PDD7Lvvvrzzzjt5XeeAAw6gV681Z8/Pnz8/+dhVUeuHJnWdgKR6qmIlPHIWrFq5JtaoCRz2R2hcnuXYkiRJkiRJDc3QoUMZO3ZsWqx169ZVrvTIVXSqrhiVuiqqT58+9OjRI+88+/bty1VXXcUFF1wAJFa0XHbZZfzxj39k+PDh9OzZk0WLFvHaa6/x4osvpq142XrrrbntttvyvlZNXHPNNZx99tn84x//4IknnuCAAw5gq622oqKigkmTJjFu3Li0wlmnTp244447cu/2U8dOPvlkzj//fGDt7fXy2aJvtd/85jc88cQTrFyZ+Izurrvu4rHHHuPAAw9k0003ZfHixUyePJmnnnqK5cuXA3D88cczffp0nnvuubyucf311/P+++/z7LPPAjB37lxOOeUULrroIgYPHkzPnj1p2bIl33zzDe+//z6vvvoq3377LZD/yqgQAmeeeSYXXnhhWrxNmzYcf/zxec2hhs1ilKTsXroRZr6dHut/Hmy8U9bukiRJkiRJ66NsBaR99tmnyrOVdtppJ7p06ZJ2hlDmKqtsUs/zOfTQQwvO9fzzz6dFixacc845yeLG7Nmzueeee3KO2WOPPRg9ejQdOnQo+HqFGDFiBFOmTOGGG25g8eLF/POf/8zZt3PnzowdOzZtpU19c/zxx3PRRRclC0Sr7bTTTuy66655z9O3b1/++Mc/pm1hOGfOnJx/Zocddhh//vOfGTZsWN7XaNasGf/+978544wz0rYTnD17Ng899FDe81TnlFNO4ZJLLklb2XXssceudTaW1k1u0ydpbbM/gmf/kB7rtHXirChJkiRJkiQl9enTh44dO6bFqlvhFEJgyJAhabH+/funnT+V6dtvv01b6VLIFn2pzjzzTN577z2OOuqoKreK23LLLbn99tt54YUX6NSpU42uVajrr7+eBx98kG22yX5WefPmzTnppJOYPHkyO++8c63kVFOdOnXi4IMPXit+8sknFzzXaaedxn/+8x922WWXnH223357Ro4cyT//+c+8tgDM1KxZM/7yl7/w4osvMmzYsCqLqY0aNWKPPfbg1ltvZdttt837GhtssAEHHnhgWswt+tYfId9ldNK6IoTQHZgOMH36dLp3717HGdUzqyrgLwfAjFfXxEIjOHUsdN+t7vKSJEmSJKkemTJlCitXrqRJkyZsueWWdZ2O1gMPPfQQP/jBDwDo1q0bM2bMKHrOxYsXM378eKZNm8bXX39Ny5Yt6dKlC7vtthtbbbVV0fNX5dJLL+Wyyy5LtjM/p544cSLvv/8+X3zxBc2bN6dnz54MGTKEdu3alTWv+m7SpEm8+uqrfPXVVzRv3pyNN96YHXbYgR122KGk11m4cCEvvPAC06dP5+uvvyaEQIcOHejduze77rorG2ywQcFz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\n",
      "text/plain": [
       "<Figure size 1920x960 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "figure(figsize=(8*1.2, 4*1.2), dpi = 200)\n",
    "for key,values in res_d.items():\n",
    "    if key != int(0.2*len(df)) and key != int(0.02*len(df)):\n",
    "        plt.plot(eps_vals, values[:14], label = str(int(key/ 65122)) +\"$ \\cdot k |D_R ⋈ D_S| $\")\n",
    "        plt.legend(loc=\"lower right\")\n",
    "    elif key == int(0.02*len(df)):\n",
    "        plt.plot(eps_vals, values[:14], label = \"0.01$ \\cdot k |D_R ⋈ D_S| $\" )\n",
    "        plt.legend(loc=\"lower right\")\n",
    "    elif key == int(0.2*len(df)):\n",
    "        plt.plot(eps_vals, values[:14], label = \"0.1$ \\cdot k |D_R ⋈ D_S| $\" )\n",
    "        plt.legend(loc=\"lower right\")\n",
    "plt.axhline(y=0.835, color='k', linestyle='--', label = \"w/o privacy\")\n",
    "# x_ticks = [ 0.05, 0.01, 0.1, 0.25, 0.5, 1, 2, 4, 8, 10, 20, 50,]    \n",
    "# x_labels = [ 0.05, 0.01, 0.1, 0.25, 0.5, 1, 2, 4, 8, 10, 20, 50]\n",
    "plt.xscale(\"log\")\n",
    "# plt.xticks(x_ticks, x_labels)    \n",
    "\n",
    "# Use LogLocator for major ticks and ScalarFormatter for tick labels\n",
    "plt.gca().xaxis.set_major_locator(ticker.LogLocator(base=10.0))\n",
    "custom_formatter = ticker.FuncFormatter(lambda x, pos: f'{x:.2g}')\n",
    "plt.gca().xaxis.set_major_formatter(custom_formatter)\n",
    "plt.legend(fontsize = 14)           \n",
    "\n",
    "plt.figtext(0.5, 0.9, r\"Adult test accuracy vs. $\\epsilon$. $k=2, |D_R ⋈ D_S| = 32$K.\", wrap=True, horizontalalignment='center', fontsize=18)\n",
    "plt.axhline(y=0.835, color='k', linestyle='--', label = \"w/o privacy\")\n",
    "plt.ylabel(\"Test accuracy\", size = 20)\n",
    "plt.xlabel(\"epsilon\", size = 20)\n",
    "# plt.rc('legend',fontsize = 12)\n",
    "plt.tick_params(axis='both', which='major', labelsize=14)\n",
    "plt.savefig('adult_with_eps.png',bbox_inches = \"tight\")\n",
    "plt.rc('xtick', labelsize=12) \n",
    "plt.rc('ytick', labelsize=12) \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e63cd849",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "68b523f7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7139d21c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b30be054",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7c78074c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7f3a8fdf",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "356f2e55",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c9dbff62",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6e9ff825",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f70d33a6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7a0fd39a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0c9b9db2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "976b8676",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "507d0855",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73d6a72f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a80f0343",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "651d6e81",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4e05a662",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2043de91",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b6f2a073",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
