{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Regression"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Train model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<>:28: SyntaxWarning: \"is\" with a literal. Did you mean \"==\"?\n",
      "<>:28: SyntaxWarning: \"is\" with a literal. Did you mean \"==\"?\n",
      "<ipython-input-1-36e87a054ba9>:28: SyntaxWarning: \"is\" with a literal. Did you mean \"==\"?\n",
      "  if tasktype is 'regression':\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task: regression\n",
      "Net(\n",
      "  (hidden1): Linear(in_features=10, out_features=400, bias=True)\n",
      "  (hidden2): Linear(in_features=400, out_features=400, bias=True)\n",
      "  (hidden3): Linear(in_features=400, out_features=400, bias=True)\n",
      "  (predict): Linear(in_features=400, out_features=1, bias=True)\n",
      ")\n",
      "0 training loss: tensor(21.8620, grad_fn=<MseLossBackward>) test loss: tensor(19.6877, grad_fn=<MseLossBackward>)\n",
      "10 training loss: tensor(6.4311, grad_fn=<MseLossBackward>) test loss: tensor(5.1118, grad_fn=<MseLossBackward>)\n",
      "20 training loss: tensor(1.8502, grad_fn=<MseLossBackward>) test loss: tensor(1.3755, grad_fn=<MseLossBackward>)\n",
      "30 training loss: tensor(0.5939, grad_fn=<MseLossBackward>) test loss: tensor(0.5410, grad_fn=<MseLossBackward>)\n",
      "40 training loss: tensor(0.5125, grad_fn=<MseLossBackward>) test loss: tensor(0.5418, grad_fn=<MseLossBackward>)\n",
      "50 training loss: tensor(0.4310, grad_fn=<MseLossBackward>) test loss: tensor(0.4055, grad_fn=<MseLossBackward>)\n",
      "60 training loss: tensor(0.2948, grad_fn=<MseLossBackward>) test loss: tensor(0.2869, grad_fn=<MseLossBackward>)\n",
      "70 training loss: tensor(0.2303, grad_fn=<MseLossBackward>) test loss: tensor(0.2224, grad_fn=<MseLossBackward>)\n",
      "80 training loss: tensor(0.1678, grad_fn=<MseLossBackward>) test loss: tensor(0.1665, grad_fn=<MseLossBackward>)\n",
      "90 training loss: tensor(0.1272, grad_fn=<MseLossBackward>) test loss: tensor(0.1284, grad_fn=<MseLossBackward>)\n",
      "100 training loss: tensor(0.1007, grad_fn=<MseLossBackward>) test loss: tensor(0.1034, grad_fn=<MseLossBackward>)\n",
      "110 training loss: tensor(0.0824, grad_fn=<MseLossBackward>) test loss: tensor(0.0858, grad_fn=<MseLossBackward>)\n",
      "120 training loss: tensor(0.0675, grad_fn=<MseLossBackward>) test loss: tensor(0.0712, grad_fn=<MseLossBackward>)\n",
      "130 training loss: tensor(0.0555, grad_fn=<MseLossBackward>) test loss: tensor(0.0595, grad_fn=<MseLossBackward>)\n",
      "140 training loss: tensor(0.0464, grad_fn=<MseLossBackward>) test loss: tensor(0.0504, grad_fn=<MseLossBackward>)\n",
      "150 training loss: tensor(0.0394, grad_fn=<MseLossBackward>) test loss: tensor(0.0435, grad_fn=<MseLossBackward>)\n",
      "160 training loss: tensor(0.0343, grad_fn=<MseLossBackward>) test loss: tensor(0.0385, grad_fn=<MseLossBackward>)\n",
      "170 training loss: tensor(0.0304, grad_fn=<MseLossBackward>) test loss: tensor(0.0347, grad_fn=<MseLossBackward>)\n",
      "180 training loss: tensor(0.0273, grad_fn=<MseLossBackward>) test loss: tensor(0.0315, grad_fn=<MseLossBackward>)\n",
      "190 training loss: tensor(0.0246, grad_fn=<MseLossBackward>) test loss: tensor(0.0288, grad_fn=<MseLossBackward>)\n",
      "200 training loss: tensor(0.0224, grad_fn=<MseLossBackward>) test loss: tensor(0.0265, grad_fn=<MseLossBackward>)\n",
      "210 training loss: tensor(0.0204, grad_fn=<MseLossBackward>) test loss: tensor(0.0245, grad_fn=<MseLossBackward>)\n",
      "220 training loss: tensor(0.0188, grad_fn=<MseLossBackward>) test loss: tensor(0.0228, grad_fn=<MseLossBackward>)\n",
      "230 training loss: tensor(0.0173, grad_fn=<MseLossBackward>) test loss: tensor(0.0213, grad_fn=<MseLossBackward>)\n",
      "240 training loss: tensor(0.0161, grad_fn=<MseLossBackward>) test loss: tensor(0.0200, grad_fn=<MseLossBackward>)\n",
      "250 training loss: tensor(0.0150, grad_fn=<MseLossBackward>) test loss: tensor(0.0189, grad_fn=<MseLossBackward>)\n",
      "260 training loss: tensor(0.0141, grad_fn=<MseLossBackward>) test loss: tensor(0.0179, grad_fn=<MseLossBackward>)\n",
      "270 training loss: tensor(0.0133, grad_fn=<MseLossBackward>) test loss: tensor(0.0170, grad_fn=<MseLossBackward>)\n",
      "280 training loss: tensor(0.0125, grad_fn=<MseLossBackward>) test loss: tensor(0.0162, grad_fn=<MseLossBackward>)\n",
      "290 training loss: tensor(0.0118, grad_fn=<MseLossBackward>) test loss: tensor(0.0155, grad_fn=<MseLossBackward>)\n",
      "300 training loss: tensor(0.0112, grad_fn=<MseLossBackward>) test loss: tensor(0.0148, grad_fn=<MseLossBackward>)\n",
      "310 training loss: tensor(0.0106, grad_fn=<MseLossBackward>) test loss: tensor(0.0142, grad_fn=<MseLossBackward>)\n",
      "320 training loss: tensor(0.0100, grad_fn=<MseLossBackward>) test loss: tensor(0.0136, grad_fn=<MseLossBackward>)\n",
      "330 training loss: tensor(0.0095, grad_fn=<MseLossBackward>) test loss: tensor(0.0131, grad_fn=<MseLossBackward>)\n",
      "340 training loss: tensor(0.0090, grad_fn=<MseLossBackward>) test loss: tensor(0.0125, grad_fn=<MseLossBackward>)\n",
      "350 training loss: tensor(0.0086, grad_fn=<MseLossBackward>) test loss: tensor(0.0121, grad_fn=<MseLossBackward>)\n",
      "360 training loss: tensor(0.0081, grad_fn=<MseLossBackward>) test loss: tensor(0.0117, grad_fn=<MseLossBackward>)\n",
      "370 training loss: tensor(0.0077, grad_fn=<MseLossBackward>) test loss: tensor(0.0112, grad_fn=<MseLossBackward>)\n",
      "380 training loss: tensor(0.0073, grad_fn=<MseLossBackward>) test loss: tensor(0.0108, grad_fn=<MseLossBackward>)\n",
      "390 training loss: tensor(0.0070, grad_fn=<MseLossBackward>) test loss: tensor(0.0105, grad_fn=<MseLossBackward>)\n",
      "400 training loss: tensor(0.0066, grad_fn=<MseLossBackward>) test loss: tensor(0.0101, grad_fn=<MseLossBackward>)\n",
      "410 training loss: tensor(0.0063, grad_fn=<MseLossBackward>) test loss: tensor(0.0098, grad_fn=<MseLossBackward>)\n",
      "420 training loss: tensor(0.0060, grad_fn=<MseLossBackward>) test loss: tensor(0.0095, grad_fn=<MseLossBackward>)\n",
      "430 training loss: tensor(0.0058, grad_fn=<MseLossBackward>) test loss: tensor(0.0092, grad_fn=<MseLossBackward>)\n",
      "440 training loss: tensor(0.0055, grad_fn=<MseLossBackward>) test loss: tensor(0.0089, grad_fn=<MseLossBackward>)\n",
      "450 training loss: tensor(0.0053, grad_fn=<MseLossBackward>) test loss: tensor(0.0086, grad_fn=<MseLossBackward>)\n",
      "460 training loss: tensor(0.0051, grad_fn=<MseLossBackward>) test loss: tensor(0.0084, grad_fn=<MseLossBackward>)\n",
      "470 training loss: tensor(0.0049, grad_fn=<MseLossBackward>) test loss: tensor(0.0082, grad_fn=<MseLossBackward>)\n",
      "480 training loss: tensor(0.0048, grad_fn=<MseLossBackward>) test loss: tensor(0.0082, grad_fn=<MseLossBackward>)\n",
      "490 training loss: tensor(0.0044, grad_fn=<MseLossBackward>) test loss: tensor(0.0077, grad_fn=<MseLossBackward>)\n",
      "500 training loss: tensor(0.0043, grad_fn=<MseLossBackward>) test loss: tensor(0.0076, grad_fn=<MseLossBackward>)\n",
      "510 training loss: tensor(0.0041, grad_fn=<MseLossBackward>) test loss: tensor(0.0073, grad_fn=<MseLossBackward>)\n",
      "520 training loss: tensor(0.0058, grad_fn=<MseLossBackward>) test loss: tensor(0.0088, grad_fn=<MseLossBackward>)\n",
      "530 training loss: tensor(0.0039, grad_fn=<MseLossBackward>) test loss: tensor(0.0074, grad_fn=<MseLossBackward>)\n",
      "540 training loss: tensor(0.0038, grad_fn=<MseLossBackward>) test loss: tensor(0.0068, grad_fn=<MseLossBackward>)\n",
      "550 training loss: tensor(0.0035, grad_fn=<MseLossBackward>) test loss: tensor(0.0067, grad_fn=<MseLossBackward>)\n",
      "560 training loss: tensor(0.0045, grad_fn=<MseLossBackward>) test loss: tensor(0.0081, grad_fn=<MseLossBackward>)\n",
      "570 training loss: tensor(0.0045, grad_fn=<MseLossBackward>) test loss: tensor(0.0079, grad_fn=<MseLossBackward>)\n",
      "580 training loss: tensor(0.0038, grad_fn=<MseLossBackward>) test loss: tensor(0.0066, grad_fn=<MseLossBackward>)\n",
      "590 training loss: tensor(0.0039, grad_fn=<MseLossBackward>) test loss: tensor(0.0070, grad_fn=<MseLossBackward>)\n",
      "600 training loss: tensor(0.0032, grad_fn=<MseLossBackward>) test loss: tensor(0.0063, grad_fn=<MseLossBackward>)\n",
      "610 training loss: tensor(0.0080, grad_fn=<MseLossBackward>) test loss: tensor(0.0119, grad_fn=<MseLossBackward>)\n",
      "620 training loss: tensor(0.0028, grad_fn=<MseLossBackward>) test loss: tensor(0.0063, grad_fn=<MseLossBackward>)\n",
      "630 training loss: tensor(0.0033, grad_fn=<MseLossBackward>) test loss: tensor(0.0058, grad_fn=<MseLossBackward>)\n",
      "640 training loss: tensor(0.0028, grad_fn=<MseLossBackward>) test loss: tensor(0.0060, grad_fn=<MseLossBackward>)\n",
      "650 training loss: tensor(0.0026, grad_fn=<MseLossBackward>) test loss: tensor(0.0056, grad_fn=<MseLossBackward>)\n",
      "660 training loss: tensor(0.0093, grad_fn=<MseLossBackward>) test loss: tensor(0.0141, grad_fn=<MseLossBackward>)\n",
      "670 training loss: tensor(0.0031, grad_fn=<MseLossBackward>) test loss: tensor(0.0080, grad_fn=<MseLossBackward>)\n",
      "680 training loss: tensor(0.0032, grad_fn=<MseLossBackward>) test loss: tensor(0.0067, grad_fn=<MseLossBackward>)\n",
      "690 training loss: tensor(0.0026, grad_fn=<MseLossBackward>) test loss: tensor(0.0058, grad_fn=<MseLossBackward>)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "700 training loss: tensor(0.0025, grad_fn=<MseLossBackward>) test loss: tensor(0.0053, grad_fn=<MseLossBackward>)\n",
      "710 training loss: tensor(0.0027, grad_fn=<MseLossBackward>) test loss: tensor(0.0058, grad_fn=<MseLossBackward>)\n",
      "720 training loss: tensor(0.0058, grad_fn=<MseLossBackward>) test loss: tensor(0.0074, grad_fn=<MseLossBackward>)\n",
      "730 training loss: tensor(0.0025, grad_fn=<MseLossBackward>) test loss: tensor(0.0051, grad_fn=<MseLossBackward>)\n",
      "740 training loss: tensor(0.0021, grad_fn=<MseLossBackward>) test loss: tensor(0.0050, grad_fn=<MseLossBackward>)\n",
      "750 training loss: tensor(0.0041, grad_fn=<MseLossBackward>) test loss: tensor(0.0070, grad_fn=<MseLossBackward>)\n",
      "760 training loss: tensor(0.0023, grad_fn=<MseLossBackward>) test loss: tensor(0.0056, grad_fn=<MseLossBackward>)\n",
      "770 training loss: tensor(0.0033, grad_fn=<MseLossBackward>) test loss: tensor(0.0052, grad_fn=<MseLossBackward>)\n",
      "780 training loss: tensor(0.0021, grad_fn=<MseLossBackward>) test loss: tensor(0.0049, grad_fn=<MseLossBackward>)\n",
      "790 training loss: tensor(0.0025, grad_fn=<MseLossBackward>) test loss: tensor(0.0052, grad_fn=<MseLossBackward>)\n",
      "800 training loss: tensor(0.0026, grad_fn=<MseLossBackward>) test loss: tensor(0.0061, grad_fn=<MseLossBackward>)\n",
      "810 training loss: tensor(0.0051, grad_fn=<MseLossBackward>) test loss: tensor(0.0093, grad_fn=<MseLossBackward>)\n",
      "820 training loss: tensor(0.0035, grad_fn=<MseLossBackward>) test loss: tensor(0.0064, grad_fn=<MseLossBackward>)\n",
      "830 training loss: tensor(0.0025, grad_fn=<MseLossBackward>) test loss: tensor(0.0054, grad_fn=<MseLossBackward>)\n",
      "840 training loss: tensor(0.0017, grad_fn=<MseLossBackward>) test loss: tensor(0.0047, grad_fn=<MseLossBackward>)\n",
      "850 training loss: tensor(0.0017, grad_fn=<MseLossBackward>) test loss: tensor(0.0046, grad_fn=<MseLossBackward>)\n",
      "860 training loss: tensor(0.0053, grad_fn=<MseLossBackward>) test loss: tensor(0.0107, grad_fn=<MseLossBackward>)\n",
      "870 training loss: tensor(0.0022, grad_fn=<MseLossBackward>) test loss: tensor(0.0048, grad_fn=<MseLossBackward>)\n",
      "880 training loss: tensor(0.0016, grad_fn=<MseLossBackward>) test loss: tensor(0.0052, grad_fn=<MseLossBackward>)\n",
      "890 training loss: tensor(0.0016, grad_fn=<MseLossBackward>) test loss: tensor(0.0047, grad_fn=<MseLossBackward>)\n",
      "900 training loss: tensor(0.0019, grad_fn=<MseLossBackward>) test loss: tensor(0.0046, grad_fn=<MseLossBackward>)\n",
      "910 training loss: tensor(0.0020, grad_fn=<MseLossBackward>) test loss: tensor(0.0049, grad_fn=<MseLossBackward>)\n",
      "920 training loss: tensor(0.0051, grad_fn=<MseLossBackward>) test loss: tensor(0.0078, grad_fn=<MseLossBackward>)\n",
      "930 training loss: tensor(0.0031, grad_fn=<MseLossBackward>) test loss: tensor(0.0053, grad_fn=<MseLossBackward>)\n",
      "940 training loss: tensor(0.0027, grad_fn=<MseLossBackward>) test loss: tensor(0.0053, grad_fn=<MseLossBackward>)\n",
      "950 training loss: tensor(0.0020, grad_fn=<MseLossBackward>) test loss: tensor(0.0052, grad_fn=<MseLossBackward>)\n",
      "960 training loss: tensor(0.0014, grad_fn=<MseLossBackward>) test loss: tensor(0.0054, grad_fn=<MseLossBackward>)\n",
      "970 training loss: tensor(0.0022, grad_fn=<MseLossBackward>) test loss: tensor(0.0043, grad_fn=<MseLossBackward>)\n",
      "980 training loss: tensor(0.0019, grad_fn=<MseLossBackward>) test loss: tensor(0.0049, grad_fn=<MseLossBackward>)\n",
      "990 training loss: tensor(0.0019, grad_fn=<MseLossBackward>) test loss: tensor(0.0048, grad_fn=<MseLossBackward>)\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch.utils.data as Data\n",
    "import itertools\n",
    "import pickle\n",
    "\n",
    "fo = open(\"log.txt\", \"w\")\n",
    "\n",
    "tasktype='regression'# classification\n",
    "torch.manual_seed(1)    # reproducible\n",
    "p=10\n",
    "x=torch.rand(20000,p)*2-1\n",
    "X=x.numpy()\n",
    "\n",
    "### you may select the following groundtruth as you like\n",
    "# multi 1\n",
    "# y = X[:,0]*X[:,1] + X[:,2]*X[:,3]*X[:,4]+X[:,5]*X[:,6]*X[:,7]+ X[:,8]*X[:,9] \n",
    "# multi 2\n",
    "# y = np.exp(np.abs(X[:,0]-X[:,1]))*X[:,9]+np.abs(X[:,2]*X[:,3])-(X[:,4]**2)*np.abs(X[:,5])+(X[:,6]*X[:,7])**2+X[:,8]\n",
    "# multi 3\n",
    "# y = X[:,0]*X[:,1] + np.abs(X[:,1]+X[:,2]*X[:,3])+X[:,4]*X[:,5]-X[:,5]**2*X[:,6]-np.exp(X[:,7]+ X[:,8]*X[:,9]) \n",
    "# F8 (example of node overlapping)\n",
    "y=X[:,0]*X[:,1]+2**(X[:,2]+X[:,4]+X[:,5])+2**(X[:,2]+X[:,3]+X[:,4]+X[:,6])+np.sin(X[:,6]*np.sin(X[:,7]+X[:,8]))+np.arccos(0.9*X[:,9])\n",
    "\n",
    "y=torch.from_numpy(y)\n",
    "if tasktype is 'regression':\n",
    "    print('task:',tasktype)\n",
    "    loss_func = torch.nn.MSELoss()  # this is for regression mean squared loss\n",
    "\n",
    "\n",
    "y=y.reshape(len(y),1)\n",
    "x_tr,y_tr,x_te,y_te=x[:10000,:],y[:10000,:],x[10000:,:],y[10000:,:]\n",
    "torch_dataset = Data.TensorDataset(x, y)\n",
    "BATCH_SIZE=400\n",
    "loader = Data.DataLoader(\n",
    "    dataset=torch_dataset,      \n",
    "    batch_size=BATCH_SIZE,      \n",
    "    shuffle=True,               \n",
    "    num_workers=2,              \n",
    ")\n",
    "\n",
    "\n",
    "class Net(torch.nn.Module):\n",
    "    def __init__(self, n_feature, n_hidden, n_output):\n",
    "        super(Net, self).__init__()\n",
    "        self.hidden1 = torch.nn.Linear(n_feature, n_hidden)   # hidden layer\n",
    "        self.hidden2 = torch.nn.Linear(n_hidden, n_hidden)\n",
    "        self.hidden3 = torch.nn.Linear(n_hidden, n_hidden)\n",
    "        self.predict = torch.nn.Linear(n_hidden, n_output)   # output layer\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = F.relu(self.hidden1(x))      # activation function for hidden layer sigmoid\n",
    "        x = F.relu(self.hidden2(x))\n",
    "        x = F.relu(self.hidden3(x))\n",
    "        x = self.predict(x)             # linear output\n",
    "        return x\n",
    "\n",
    "net = Net(n_feature=p, n_hidden=400, n_output=1)     # define the network #400 1200\n",
    "print(net)  # net architecture\n",
    "\n",
    "optimizer= torch.optim.Adam(net.parameters(), betas=(0.9, 0.99))\n",
    "for t in range(1000):\n",
    "    prediction = net(x_tr)     # input x and predict based on x\n",
    "    loss = loss_func(prediction, y_tr)     # must be (1. nn output, 2. target)\n",
    "\n",
    "    optimizer.zero_grad()   # clear gradients for next train\n",
    "    loss.backward()         # backpropagation, compute gradients\n",
    "    optimizer.step()        # apply gradients\n",
    "    #print(t,'loss:',loss)\n",
    "\n",
    "    if t % 10 == 0:\n",
    "        teloss = loss_func(net(x_te), y_te)\n",
    "        print(t,'training loss:',loss,'test loss:',teloss)\n",
    "        #torch.save(net.state_dict(), 'models/net_params_'+str(t)+'.pkl') \n",
    "        string='epoch:'+str(t)+'training loss:'+str(loss)+'test loss:'+str(teloss)+'\\n'\n",
    "        fo.write(string)\n",
    "\n",
    "fo.close()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Detect interactions analytically. (Hessian matrix is a zero matrix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "detection time: 4.417632579803467\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f880b5382e8>"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAPoAAAECCAYAAADXWsr9AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAJUElEQVR4nO3dzYtdBx2H8edrJk2aVFTQjUkxWYhSCpIyaG3BRePCl9JuXFRoQTfZqH2hINaN/0ApuhAhtLqx6CJ2ISK+YNuFm2CaFNomCtLWNm2kcaGVgklKfy5mxDSJvWfMOTl3+ns+EMjcnEy+hHk4557cuUlVIend7T1zD5A0PUOXGjB0qQFDlxowdKkBQ5camC30JJ9L8qckf07yrbl2DJXk2iRPJDme5Lkk98y9aYgkW5IcS/KLubcMkeT9SQ4l+WOSE0k+PfemRZLct/418WySnyTZPvemC80SepItwPeBzwPXAV9Oct0cWzbgTeD+qroOuBH42ibYDHAPcGLuERvwPeBXVfVx4BMs+fYku4C7gdWquh7YAtwx76qLzXVG/yTw56p6vqrOAj8Fbp9pyyBVdaqqjq7//J+sfQHumnfVO0uyG/gi8PDcW4ZI8j7gM8AjAFV1tqr+Pu+qQVaAq5OsADuAV2fec5G5Qt8FvHzexydZ8mjOl2QPsA84PO+Shb4LfBN4a+4hA+0FTgM/Wn+68XCSnXOPeidV9QrwIPAScAr4R1X9Zt5VF/Nm3AYluQb4GXBvVb0+957/JcmtwGtV9dTcWzZgBbgB+EFV7QPeAJb6/k2SD7B2NboX+DCwM8md86662FyhvwJce97Hu9cfW2pJtrIW+aNV9djcexa4GbgtyYusPTW6JcmP55200EngZFX950rpEGvhL7PPAi9U1emqOgc8Btw086aLzBX6H4CPJtmb5CrWbl78fKYtgyQJa88dT1TVQ3PvWaSqHqiq3VW1h7W/38eraunONOerqr8CLyf52PpD+4HjM04a4iXgxiQ71r9G9rOENxBX5vhDq+rNJF8Hfs3aXcofVtVzc2zZgJuBu4Bnkjy9/ti3q+qXM256N/oG8Oj6CeB54Ksz73lHVXU4ySHgKGv/MnMMODjvqovFb1OV3v28GSc1YOhSA4YuNWDoUgOGLjUwe+hJDsy9YSM2215w85Ww7HtnDx1Y6r+gS9hse8HNV8JS712G0CVNbJIXzFyVbbWdYd90dI4zbGXb6Bumstn2gpuvhGXZ+y/e4GydyYWPT/IS2O3s5FPZP8WnlvQODtfvLvm4l+5SA4YuNWDoUgOGLjVg6FIDg0LfbO/BLuntFoa+Sd+DXdJ5hpzRN917sEt6uyGhb+r3YJc04ivj1r975wDAdnaM9WkljWDIGX3Qe7BX1cGqWq2q1WV4za+k/xoS+qZ7D3ZJb7fw0n2Tvge7pPMMeo6+/p8U+B8VSJuUr4yTGjB0qQFDlxowdKkBQ5caMHSpAUOXGjB0qQFDlxowdKkBQ5caMHSpAUOXGjB0qQFDlxowdKkBQ5caMHSpAUOXGjB0qQFDlxowdKkBQ5caMHSpAUOXGjB0qQFDlxowdKkBQ5caMHSpAUOXGjB0qQFDlxowdKkBQ5caMHSpgYWhJ7k2yRNJjid5Lsk9V2KYpPGsDDjmTeD+qjqa5L3AU0l+W1XHJ94maSQLz+hVdaqqjq7//J/ACWDX1MMkjWdDz9GT7AH2AYenGCNpGkMu3QFIcg3wM+Deqnr9Er9+ADgAsJ0dow2UdPkGndGTbGUt8ker6rFLHVNVB6tqtapWt7JtzI2SLtOQu+4BHgFOVNVD00+SNLYhZ/SbgbuAW5I8vf7jCxPvkjSihc/Rq+r3QK7AFkkT8ZVxUgOGLjVg6FIDhi41YOhSA4YuNWDoUgOGLjVg6FIDhi41YOhSA4YuNWDoUgOGLjVg6FIDhi41YOhSA4YuNWDoUgOGLjVg6FIDhi41YOhSA4YuNWDoUgOGLjVg6FIDhi41YOhSA4YuNWDoUgOGLjVg6FIDhi41YOhSA4YuNTA49CRbkhxL8ospB0ka30bO6PcAJ6YaImk6g0JPshv4IvDwtHMkTWHoGf27wDeBtybcImkiC0NPcivwWlU9teC4A0mOJDlyjjOjDZR0+Yac0W8GbkvyIvBT4JYkP77woKo6WFWrVbW6lW0jz5R0ORaGXlUPVNXuqtoD3AE8XlV3Tr5M0mj8d3SpgZWNHFxVTwJPTrJE0mQ8o0sNGLrUgKFLDRi61IChSw0YutSAoUsNGLrUgKFLDRi61IChSw0YutSAoUsNGLrUgKFLDRi61IChSw0YutSAoUsNGLrUgKFLDRi61IChSw0YutSAoUsNGLrUgKFLDRi61IChSw0YutSAoUsNGLrUgKFLDRi61IChSw0MCj3J+5McSvLHJCeSfHrqYZLGszLwuO8Bv6qqLyW5Ctgx4SZJI1sYepL3AZ8BvgJQVWeBs9POkjSmIZfue4HTwI+SHEvycJKdE++SNKIhoa8ANwA/qKp9wBvAty48KMmBJEeSHDnHmZFnSrocQ0I/CZysqsPrHx9iLfy3qaqDVbVaVatb2TbmRkmXaWHoVfVX4OUkH1t/aD9wfNJVkkY19K77N4BH1++4Pw98dbpJksY2KPSqehpYnXiLpIn4yjipAUOXGjB0qQFDlxowdKkBQ5caMHSpAUOXGjB0qQFDlxowdKkBQ5caMHSpAUOXGjB0qQFDlxowdKkBQ5caMHSpAUOXGjB0qQFDlxowdKkBQ5caMHSpAUOXGjB0qQFDlxowdKkBQ5caMHSpAUOXGjB0qQFDlxowdKkBQ5caGBR6kvuSPJfk2SQ/SbJ96mGSxrMw9CS7gLuB1aq6HtgC3DH1MEnjGXrpvgJcnWQF2AG8Ot0kSWNbGHpVvQI8CLwEnAL+UVW/mXqYpPEMuXT/AHA7sBf4MLAzyZ2XOO5AkiNJjpzjzPhLJf3fhly6fxZ4oapOV9U54DHgpgsPqqqDVbVaVatb2Tb2TkmXYUjoLwE3JtmRJMB+4MS0sySNachz9MPAIeAo8Mz67zk48S5JI1oZclBVfQf4zsRbJE3EV8ZJDRi61IChSw0YutSAoUsNGLrUgKFLDRi61IChSw0YutSAoUsNGLrUgKFLDRi61IChSw0YutSAoUsNGLrUgKFLDRi61IChSw0YutSAoUsNGLrUgKFLDRi61IChSw0YutRAqmr8T5qcBv4y8PAPAn8bfcR0NttecPOVsCx7P1JVH7rwwUlC34gkR6pqddYRG7DZ9oKbr4Rl3+ulu9SAoUsNLEPoB+cesEGbbS+4+UpY6r2zP0eXNL1lOKNLmpihSw0YutSAoUsNGLrUwL8BkEcId3KLkngAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 288x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "import torch\n",
    "from torch import Tensor\n",
    "from torch.autograd import Variable\n",
    "from torch.autograd import grad\n",
    "from torch import nn\n",
    "import time\n",
    "st=time.time()\n",
    "torch.manual_seed(623)\n",
    "cnt=0\n",
    "aa=0\n",
    "Hessian=torch.zeros(p,p)\n",
    "grad1=torch.zeros(1,p)\n",
    "\n",
    "for j in range(100):\n",
    "        xeval = Variable(x_tr[j,:], requires_grad=True)\n",
    "        xeval=xeval.reshape(1,p)\n",
    "        f = net(xeval)\n",
    "        x_1grad, = grad(f, xeval, create_graph=True)\n",
    "        grad1=grad1+(x_1grad)**2\n",
    "        x_2grad0, = grad(x_1grad[0,0], xeval, create_graph=True)\n",
    "\n",
    "        for i in range(p-1):\n",
    "            x_2grad1, = grad(x_1grad[0,i+1], xeval, create_graph=True)\n",
    "            x_2grad0 = torch.cat((x_2grad0, x_2grad1), dim=0)\n",
    "            cnt=cnt+1\n",
    "        Hessian=Hessian+torch.abs(x_2grad0) \n",
    "        aa=Hessian/cnt\n",
    "\n",
    "print('detection time:',time.time()-st)\n",
    "plt.matshow(np.abs(aa.detach().numpy()))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Detect interactions Numerically (brute force, pull each arm 100 times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "def one_hot(i,p):\n",
    "    '''\n",
    "    generate a p-dimensional one_hot vector, i-th element is 1\n",
    "    '''\n",
    "    \n",
    "    batch_size=1\n",
    "    # Dummy input that HAS to be 2D for the scatter (you can use view(-1,1) if needed)\n",
    "    y = torch.LongTensor([[i]])\n",
    "    # One hot encoding buffer that you create out of the loop and just keep reusing\n",
    "    y_onehot = torch.FloatTensor(batch_size, p)\n",
    "    #print(y_onehot)\n",
    "    # In your for loop\n",
    "    y_onehot.zero_()\n",
    "    y_onehot.scatter_(1, y, 1)\n",
    "    return y_onehot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6.915963888168335\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f880ae016a0>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import torch\n",
    "from torch import Tensor\n",
    "from torch.autograd import Variable\n",
    "from torch.autograd import grad\n",
    "from torch import nn\n",
    "import time\n",
    "st=time.time()\n",
    "torch.manual_seed(623)\n",
    "cnt=0\n",
    "aa=0\n",
    "Hessian=torch.zeros(p,p)\n",
    "Firstorder=torch.zeros(1,p)\n",
    "Firstordertemp=torch.zeros(1,p)\n",
    "Hessiantemp=torch.zeros(p,p)\n",
    "grad1=torch.zeros(1,p)\n",
    "delta=1 # h=k=1 \n",
    "\n",
    "for j in range(100):\n",
    "\n",
    "        xeval = Variable(x_tr[j,:], requires_grad=True)\n",
    "        xeval=xeval.reshape(1,p)\n",
    "\n",
    "        \n",
    "        for i in range(p):                        \n",
    "            for k in range(i):\n",
    "                f0 = net(xeval-one_hot(i,p)*delta-one_hot(k,p)*delta)\n",
    "                fi =net(xeval+one_hot(i,p)*delta-one_hot(k,p)*delta)\n",
    "                fik =net(xeval+one_hot(i,p)*delta+one_hot(k,p)*delta)\n",
    "                fk=net(xeval+one_hot(k,p)*delta-one_hot(i,p)*delta)\n",
    "                \n",
    "                Hessiantemp[i,k]=((fik-fi-fk+f0)/delta**2/4)**2\n",
    "                Hessiantemp[k,i]=Hessiantemp[i,k]\n",
    "\n",
    "        cnt=cnt+1\n",
    "        Hessian=Hessian+torch.abs(Hessiantemp) \n",
    "        aa=Hessian/cnt\n",
    "\n",
    "print(time.time()-st)\n",
    "plt.matshow(np.abs(aa.detach().numpy()))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    " # Graph and spectral clustering"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/opttransformation/python/.conda/envs/python/lib/python3.7/site-packages/networkx/drawing/nx_pylab.py:579: MatplotlibDeprecationWarning: \n",
      "The iterable function was deprecated in Matplotlib 3.1 and will be removed in 3.3. Use np.iterable instead.\n",
      "  if not cb.iterable(width):\n",
      "/home/opttransformation/python/.conda/envs/python/lib/python3.7/site-packages/networkx/drawing/nx_pylab.py:585: MatplotlibDeprecationWarning: \n",
      "The iterable function was deprecated in Matplotlib 3.1 and will be removed in 3.3. Use np.iterable instead.\n",
      "  and cb.iterable(edge_color) \\\n",
      "/home/opttransformation/python/.conda/envs/python/lib/python3.7/site-packages/networkx/drawing/nx_pylab.py:595: MatplotlibDeprecationWarning: \n",
      "The iterable function was deprecated in Matplotlib 3.1 and will be removed in 3.3. Use np.iterable instead.\n",
      "  for c in edge_color]):\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/opttransformation/python/.conda/envs/python/lib/python3.7/site-packages/networkx/drawing/nx_pylab.py:579: MatplotlibDeprecationWarning: \n",
      "The iterable function was deprecated in Matplotlib 3.1 and will be removed in 3.3. Use np.iterable instead.\n",
      "  if not cb.iterable(width):\n",
      "/home/opttransformation/python/.conda/envs/python/lib/python3.7/site-packages/networkx/drawing/nx_pylab.py:585: MatplotlibDeprecationWarning: \n",
      "The iterable function was deprecated in Matplotlib 3.1 and will be removed in 3.3. Use np.iterable instead.\n",
      "  and cb.iterable(edge_color) \\\n",
      "/home/opttransformation/python/.conda/envs/python/lib/python3.7/site-packages/networkx/drawing/nx_pylab.py:595: MatplotlibDeprecationWarning: \n",
      "The iterable function was deprecated in Matplotlib 3.1 and will be removed in 3.3. Use np.iterable instead.\n",
      "  for c in edge_color]):\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import networkx as nx\n",
    "score=np.abs(aa.detach().numpy())\n",
    "G=nx.from_numpy_matrix(score)\n",
    "color=[]\n",
    "for i in G.edges:\n",
    "    color.append(score[i[0],i[1]])\n",
    "plt.figure(1)\n",
    "nx.draw(G, \n",
    "        with_labels=True,\n",
    "        node_size=400, \n",
    "        edge_color=color,        \n",
    "        width=3, \n",
    "        cmap=plt.cm.Dark2, \n",
    "        edge_cmap=plt.cm.Blues\n",
    "       )  \n",
    "plt.show()\n",
    "\n",
    "\n",
    "#np.max(score)*0.1\n",
    "#score[score<np.max(score)*0.1]=0\n",
    "adMatrix=score\n",
    "\n",
    "\n",
    "from sklearn.cluster import KMeans\n",
    "p=10\n",
    "k=3\n",
    "\n",
    "#score[score<np.max(score)*0.1]=0\n",
    "adMatrix=score\n",
    "aaaa=np.any(adMatrix,axis=1)\n",
    "def calLaplacianMatrix(adjacentMatrix):\n",
    "\n",
    "    # compute the Degree Matrix: D=sum(A)\n",
    "    degreeMatrix = np.sum(adjacentMatrix, axis=1)\n",
    "\n",
    "    # compute the Laplacian Matrix: L=D-A\n",
    "    laplacianMatrix = np.diag(degreeMatrix) - adjacentMatrix\n",
    "\n",
    "    # normailze\n",
    "    # D^(-1/2) L D^(-1/2)\n",
    "    sqrtDegreeMatrix = np.diag(1.0 / (degreeMatrix ** (0.5)))\n",
    "    return np.dot(np.dot(sqrtDegreeMatrix, laplacianMatrix), sqrtDegreeMatrix)\n",
    "\n",
    "def spKmeans(H,k):\n",
    "    sp_kmeans = KMeans(n_clusters=k).fit(H)\n",
    "    return sp_kmeans.labels_\n",
    "\n",
    "Laplacian=calLaplacianMatrix(adMatrix[aaaa][:,aaaa])\n",
    "x, V = np.linalg.eig(Laplacian)\n",
    "\n",
    "x = zip(x, range(len(x)))\n",
    "x = sorted(x, key=lambda x:x[0])\n",
    "\n",
    "H = np.vstack([V[:,i] for (v, i) in x[:k]]).T\n",
    "\n",
    "label111=spKmeans(H,k)\n",
    "\n",
    "nodecolormap=np.ones(p)\n",
    "nodecolormap[np.where(aaaa==False)]=range(k,k+len(np.where(aaaa==False)[0])) #nodes with degree=1\n",
    "nodecolormap[np.where(aaaa==True)]=label111\n",
    "#\n",
    "plt.figure(2)\n",
    "nx.draw(G, \n",
    "        with_labels=True,\n",
    "        node_size=400, \n",
    "        node_color=nodecolormap,\n",
    "        edge_color=color,        \n",
    "        width=3, \n",
    "        cmap=plt.cm.Dark2, \n",
    "        edge_cmap=plt.cm.Blues\n",
    "       )  \n",
    "plt.savefig('figure_name.pdf',bbox_inches='tight',dpi='figure',pad_inches=0.1) # figure_name could be multi_1,2,3\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Detecting 2-way/3-way/4-way interactions via UCB"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0]\n",
      "[1]\n",
      "[2]\n",
      "[3]\n",
      "[4]\n",
      "[5]\n",
      "[6]\n",
      "[7]\n",
      "[8]\n",
      "[9]\n",
      "[0, 1]\n",
      "[0, 3]\n",
      "[0, 4]\n",
      "[0, 6]\n",
      "[1, 6]\n",
      "[1, 9]\n",
      "[2, 3]\n",
      "[2, 4]\n",
      "[2, 5]\n",
      "[2, 6]\n",
      "[3, 4]\n",
      "[3, 5]\n",
      "[3, 6]\n",
      "[4, 5]\n",
      "[4, 6]\n",
      "[5, 6]\n",
      "[6, 7]\n",
      "[6, 8]\n",
      "[6, 9]\n",
      "[7, 8]\n",
      "[0, 1, 6]\n",
      "[0, 3, 4]\n",
      "[0, 3, 6]\n",
      "[0, 4, 6]\n",
      "[1, 6, 9]\n",
      "[2, 3, 4]\n",
      "[2, 3, 5]\n",
      "[2, 3, 6]\n",
      "[2, 4, 5]\n",
      "[2, 4, 6]\n",
      "[2, 5, 6]\n",
      "[3, 4, 5]\n",
      "[3, 4, 6]\n",
      "[3, 5, 6]\n",
      "[4, 5, 6]\n",
      "[6, 7, 8]\n",
      "[0, 3, 4, 6]\n",
      "[2, 3, 4, 5]\n",
      "[2, 3, 4, 6]\n",
      "[2, 3, 5, 6]\n",
      "[2, 4, 5, 6]\n",
      "[3, 4, 5, 6]\n",
      "[2, 3, 4, 5, 6]\n",
      "All 3-cliques:  [[0, 1, 6], [0, 3, 4], [0, 3, 6], [0, 4, 6], [1, 6, 9], [2, 3, 4], [2, 3, 5], [2, 3, 6], [2, 4, 5], [2, 4, 6], [2, 5, 6], [3, 4, 5], [3, 4, 6], [3, 5, 6], [4, 5, 6], [6, 7, 8]]\n",
      "All 4-cliques:  [[0, 3, 4, 6], [2, 3, 4, 5], [2, 3, 4, 6], [2, 3, 5, 6], [2, 4, 5, 6], [3, 4, 5, 6]]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/opttransformation/python/.conda/envs/python/lib/python3.7/site-packages/networkx/drawing/nx_pylab.py:579: MatplotlibDeprecationWarning: \n",
      "The iterable function was deprecated in Matplotlib 3.1 and will be removed in 3.3. Use np.iterable instead.\n",
      "  if not cb.iterable(width):\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "adMatrix # cut off\n",
    "def cutoff(adj,k):\n",
    "    adjflatten=adj.flatten()\n",
    "    return adj>=adjflatten[np.argsort(adjflatten)[-k*2]]\n",
    "Gcut=nx.from_numpy_matrix(cutoff(adMatrix,20))\n",
    "pos=nx.shell_layout(Gcut)\n",
    "nx.draw(Gcut,pos,with_labels=True,node_size=800,node_color='g',alpha=0.8,font_size=20)\n",
    "enum=nx.enumerate_all_cliques(Gcut)\n",
    "\n",
    "Tway_candid=[]  # save all 3-cliques\n",
    "Fway_candid=[]  # save all 4-cliques\n",
    "for i in enum:\n",
    "    print(i)\n",
    "    if len(i)==3:\n",
    "        Tway_candid.append(i)\n",
    "    if len(i)==4:\n",
    "        Fway_candid.append(i)\n",
    "print('All 3-cliques: ', Tway_candid) \n",
    "print('All 4-cliques: ', Fway_candid)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "start dectecting\n",
      "Initialization done! initial try3times\n",
      "chosen arm: 18 strength: 23.8314685857296 iteration: 99\n",
      "chosen arm: 0 strength: 8.828184634844456 iteration: 284\n",
      "chosen arm: 24 strength: 7.985350188488759 iteration: 335\n",
      "chosen arm: 26 strength: 11.366435130437216 iteration: 339\n",
      "chosen arm: 17 strength: 8.588672622789941 iteration: 414\n",
      "chosen arm: 31 strength: 7.909448023661971 iteration: 499\n",
      "chosen arm: 30 strength: 5.359010447233399 iteration: 601\n",
      "chosen arm: 19 strength: 5.5043056514859225 iteration: 696\n",
      "chosen arm: 20 strength: 7.734651757611169 iteration: 755\n",
      "chosen arm: 40 strength: 3.4157516837120054 iteration: 814\n",
      "chosen arm: 39 strength: 3.215168506491418 iteration: 814\n",
      "chosen arm: 9 strength: 0.06201729339628062 iteration: 1089\n",
      "chosen arm: 35 strength: 0.04852316525344937 iteration: 1146\n",
      "chosen arm: 34 strength: 0.05302536546438812 iteration: 1201\n",
      "chosen arm: 25 strength: 0.0720619109844726 iteration: 1287\n",
      "chosen arm: 13 strength: 0.11329553582306419 iteration: 1308\n",
      "chosen arm: 11 strength: 0.045015392418605776 iteration: 1551\n",
      "chosen arm: 8 strength: 0.06054443367148368 iteration: 1602\n",
      "chosen arm: 28 strength: 0.069748407540222 iteration: 1673\n",
      "chosen arm: 22 strength: 0.03955255645847783 iteration: 1702\n",
      "time: 3.1439054012298584\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "([array([2, 4]),\n",
       "  array([0, 1]),\n",
       "  array([3, 4]),\n",
       "  array([3, 6]),\n",
       "  array([2, 3]),\n",
       "  array([4, 6]),\n",
       "  array([4, 5]),\n",
       "  array([2, 5]),\n",
       "  array([2, 6]),\n",
       "  array([6, 8]),\n",
       "  array([6, 7]),\n",
       "  array([1, 2]),\n",
       "  array([5, 6]),\n",
       "  array([4, 9]),\n",
       "  array([3, 5]),\n",
       "  array([1, 6]),\n",
       "  array([1, 4]),\n",
       "  array([0, 9]),\n",
       "  array([3, 8]),\n",
       "  array([2, 8])],\n",
       " 3.1439054012298584)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from UCBtools import *\n",
    "detect_Hessian_UCB(net,x_tr,20) # detected top 20 pairwise (2-way) interactions sorted in order of detection"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "start dectecting\n",
      "Initialization done! initial try3times\n",
      "chosen arm: 7 strength: 0.04844298498889353 iteration: 102\n",
      "chosen arm: 9 strength: 0.04610058035080632 iteration: 121\n",
      "chosen arm: 12 strength: 0.04535550818157693 iteration: 133\n",
      "chosen arm: 5 strength: 0.0473004181144966 iteration: 134\n",
      "chosen arm: 8 strength: 0.030845310849448047 iteration: 135\n",
      "chosen arm: 15 strength: 0.008177579301506437 iteration: 139\n",
      "time: 0.6796438694000244\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "([array([2, 3, 6]),\n",
       "  array([2, 4, 6]),\n",
       "  array([3, 4, 6]),\n",
       "  array([2, 3, 4]),\n",
       "  array([2, 4, 5]),\n",
       "  array([6, 7, 8])],\n",
       " 0.6796438694000244)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Then we check if those candidates are 3-way interactions\n",
    "detect_3rd_UCB(net,x_tr,Tway_candid,6)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[[0, 3, 4, 6],\n",
       " [2, 3, 4, 5],\n",
       " [2, 3, 4, 6],\n",
       " [2, 3, 5, 6],\n",
       " [2, 4, 5, 6],\n",
       " [3, 4, 5, 6]]"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Fway_candid"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### You may see {2,3,4,6} is the only 4-clique such that {2,3,6},{2,4,6},{3,4,6},{2,3,4} all exist."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "start dectecting\n",
      "Initialization done! initial try3times\n",
      "chosen arm: 2 strength: 0.778795273475504 iteration: 176\n",
      "chosen arm: 1 strength: 0.7750469018842765 iteration: 204\n",
      "chosen arm: 4 strength: 0.562188702635467 iteration: 204\n",
      "chosen arm: 3 strength: 0.07031184770554925 iteration: 208\n",
      "time: 1.5191569328308105\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "([array([2, 3, 4, 6]),\n",
       "  array([2, 3, 4, 5]),\n",
       "  array([2, 4, 5, 6]),\n",
       "  array([2, 3, 5, 6])],\n",
       " 1.5191569328308105)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "detect_4th_UCB(net,x_tr,Fway_candid,4)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ml",
   "language": "python",
   "name": "ml"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
