{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.5/dist-packages/tensorflow/python/framework/dtypes.py:519: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint8 = np.dtype([(\"qint8\", np.int8, 1)])\n",
      "/usr/local/lib/python3.5/dist-packages/tensorflow/python/framework/dtypes.py:520: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_quint8 = np.dtype([(\"quint8\", np.uint8, 1)])\n",
      "/usr/local/lib/python3.5/dist-packages/tensorflow/python/framework/dtypes.py:521: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint16 = np.dtype([(\"qint16\", np.int16, 1)])\n",
      "/usr/local/lib/python3.5/dist-packages/tensorflow/python/framework/dtypes.py:522: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_quint16 = np.dtype([(\"quint16\", np.uint16, 1)])\n",
      "/usr/local/lib/python3.5/dist-packages/tensorflow/python/framework/dtypes.py:523: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint32 = np.dtype([(\"qint32\", np.int32, 1)])\n",
      "/usr/local/lib/python3.5/dist-packages/tensorflow/python/framework/dtypes.py:528: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  np_resource = np.dtype([(\"resource\", np.ubyte, 1)])\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "from modelFS import *\n",
    "\n",
    "from sklearn import svm\n",
    "from sklearn.metrics import accuracy_score\n",
    "\n",
    "import scipy\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Thu Feb 11 04:39:06 2021       \n",
      "+-----------------------------------------------------------------------------+\n",
      "| NVIDIA-SMI 384.130                Driver Version: 384.130                   |\n",
      "|-------------------------------+----------------------+----------------------+\n",
      "| GPU  Name        Persistence-M| Bus-Id        Disp.A | Volatile Uncorr. ECC |\n",
      "| Fan  Temp  Perf  Pwr:Usage/Cap|         Memory-Usage | GPU-Util  Compute M. |\n",
      "|===============================+======================+======================|\n",
      "|   0  GeForce GTX 1080    Off  | 00000000:04:00.0 Off |                  N/A |\n",
      "| 24%   32C    P0    42W / 180W |      0MiB /  8114MiB |      0%      Default |\n",
      "+-------------------------------+----------------------+----------------------+\n",
      "|   1  GeForce GTX 1080    Off  | 00000000:05:00.0 Off |                  N/A |\n",
      "| 24%   34C    P0    42W / 180W |      0MiB /  8114MiB |      0%      Default |\n",
      "+-------------------------------+----------------------+----------------------+\n",
      "|   2  GeForce GTX 1080    Off  | 00000000:08:00.0 Off |                  N/A |\n",
      "| 24%   26C    P8     6W / 180W |   7781MiB /  8114MiB |      0%      Default |\n",
      "+-------------------------------+----------------------+----------------------+\n",
      "|   3  GeForce GTX 1080    Off  | 00000000:09:00.0 Off |                  N/A |\n",
      "| 24%   33C    P0    41W / 180W |      0MiB /  8114MiB |      0%      Default |\n",
      "+-------------------------------+----------------------+----------------------+\n",
      "|   4  GeForce GTX 1080    Off  | 00000000:85:00.0 Off |                  N/A |\n",
      "| 24%   30C    P0    41W / 180W |      0MiB /  8114MiB |      0%      Default |\n",
      "+-------------------------------+----------------------+----------------------+\n",
      "|   5  GeForce GTX 1080    Off  | 00000000:86:00.0 Off |                  N/A |\n",
      "| 24%   33C    P0    42W / 180W |      0MiB /  8114MiB |      0%      Default |\n",
      "+-------------------------------+----------------------+----------------------+\n",
      "|   6  GeForce GTX 1080    Off  | 00000000:89:00.0 Off |                  N/A |\n",
      "| 24%   34C    P0    42W / 180W |      0MiB /  8114MiB |      2%      Default |\n",
      "+-------------------------------+----------------------+----------------------+\n",
      "|   7  GeForce GTX 1080    Off  | 00000000:8A:00.0 Off |                  N/A |\n",
      "| 24%   27C    P8     7W / 180W |   7751MiB /  8114MiB |      0%      Default |\n",
      "+-------------------------------+----------------------+----------------------+\n",
      "                                                                               \n",
      "+-----------------------------------------------------------------------------+\n",
      "| Processes:                                                       GPU Memory |\n",
      "|  GPU       PID   Type   Process name                             Usage      |\n",
      "|=============================================================================|\n",
      "|    2     16902      C   /usr/bin/python3                            7771MiB |\n",
      "|    7      4873      C   /usr/bin/python3                            7741MiB |\n",
      "+-----------------------------------------------------------------------------+\n"
     ]
    }
   ],
   "source": [
    "!nvidia-smi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "os.environ['CUDA_VISIBLE_DEVICES'] = '1'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def gen_data(n=400,p=800,q=800,rho=0.9,flag=0,fac=1):\n",
    "    Sigma_x=1*np.eye(p)\n",
    "    Sigma_y=1*np.eye(q)\n",
    "    Sigma_0=1*np.eye(p)\n",
    "    if flag==1:\n",
    "        for i in range(p):\n",
    "            for j in range(p):\n",
    "                Sigma_x[i,j]=0.9**(abs(i-j))\n",
    "    elif flag==2:\n",
    "        for i in range(p):\n",
    "            for j in range(p):\n",
    "                if np.abs(i-j)==1:\n",
    "                    Sigma_0[i,j]=0.5\n",
    "                elif np.abs(i-j)==2:\n",
    "                    Sigma_0[i,j]=0.4\n",
    "        Sigma_1=np.copy(np.linalg.inv(Sigma_0))\n",
    "        Sigma_x=np.copy(Sigma_1)\n",
    "        for i in range(p):\n",
    "            for j in range(p):\n",
    "                Sigma_x[i,j]=Sigma_1[i,j]/(np.sqrt(Sigma_1[i,i]*Sigma_1[j,j]))\n",
    "    \n",
    "    Sigma_y=Sigma_x\n",
    "\n",
    "    k=5\n",
    "    not_valid=True\n",
    "    while not_valid:\n",
    "        u=np.zeros((p,1))\n",
    "        v=np.zeros((q,1))\n",
    "        ind1=np.random.choice(np.arange(p),k)\n",
    "        ind2=np.random.choice(np.arange(q),k)\n",
    "        u[ind1]=fac/np.sqrt(k)\n",
    "        v[ind2]=fac/np.sqrt(k)\n",
    "        Sigma_xy=rho*Sigma_x@u@v.T@Sigma_y\n",
    "        Sigma1=np.hstack((Sigma_x,Sigma_xy))\n",
    "        Sigma2=np.hstack((Sigma_xy.T,Sigma_y))\n",
    "        Sigma=np.vstack((Sigma1,Sigma2))\n",
    "    #    pos_def=is_pos_def(Sigma)\n",
    "     #   if pos_def:\n",
    "        not_valid=False\n",
    "        try:\n",
    "            xy=np.random.multivariate_normal(np.zeros(Sigma.shape[0]),Sigma,n,check_valid='raise')\n",
    "        except:\n",
    "            print('Cov not valid')\n",
    "            not_valid=True\n",
    "\n",
    "    x=xy[:,:p]\n",
    "    y=xy[:,p:]\n",
    "    return x,y,u,v,Sigma_xy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def initial_guess(x,y,k=5):\n",
    "\n",
    "    n=x.shape[0]\n",
    "    C_xy=(x.T@y)/(n-1)\n",
    "    s_xy=C_xy\n",
    "    thresh=np.percentile(np.abs(C_xy.reshape(-1)),100*(1-k/x.shape[1]))\n",
    "    C_xy[np.abs(C_xy)<thresh]=0\n",
    "    [U0,s,V0]=np.linalg.svd(C_xy)\n",
    "    uu=np.abs(U0[:,0])\n",
    "    uu[uu<1*thresh]=-0.5\n",
    "    vv=np.abs(V0[0,:])\n",
    "    vv[vv<1*thresh]=-0.5\n",
    "    return uu,vv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "x,y,u,v,Sigma_xy=gen_data(n=500,p=600,q=600,rho=0.9,flag=0,fac=1)\n",
    "uu,vv=initial_guess(x,y,k=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "params={'feature_selection': True, 'param_search': False, 'learning_rate': 0.01, 'activation': 'none', 'output_node':1,  'sigma': 0.25, 'display_step': 2000, 'hidden_layers_node': [1]}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "params['lam1'] = 40\n",
    "params['lam2'] = 40\n",
    "params['learning_rate'] = 0.005\n",
    "params['input_node1'] = x.shape[1]\n",
    "params['input_node2'] = y.shape[1]\n",
    "params['batch_size'] = x.shape[0]\n",
    "params['u']=uu\n",
    "params['v']=vv\n",
    "params['initilize']=False\n",
    "num_epoch=1000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 1 train loss=-0.004020972 valid loss= -0.213086247\n",
      "train reg_fs: 1.008285403251648\n",
      "Epoch: 2001 train loss=-0.884146333 valid loss= -0.906780899\n",
      "train reg_fs: 0.07097114622592926\n",
      "Epoch: 4001 train loss=-0.893402100 valid loss= -0.906805277\n",
      "train reg_fs: 0.03702719509601593\n",
      "Epoch: 6001 train loss=-0.894915223 valid loss= -0.906757236\n",
      "train reg_fs: 0.028771255165338516\n",
      "Epoch: 8001 train loss=-0.902386189 valid loss= -0.905534863\n",
      "train reg_fs: 0.02428974211215973\n",
      "Optimization Finished!\n"
     ]
    }
   ],
   "source": [
    "model = Model(**params)\n",
    "x,y,u,v,Sigma_xy=gen_data(n=500,p=600,q=600,rho=0.9,flag=0)\n",
    "uu,vv=initial_guess(x,y,k=10)\n",
    "params['u']=uu\n",
    "params['v']=vv\n",
    "params['input_node1'] = x.shape[1]\n",
    "params['input_node2'] = y.shape[1]\n",
    "params['batch_size'] = x.shape[0]\n",
    "model = Model(**params)\n",
    "array_out=model.train(x,y,x,y,  num_epoch=10000)\n",
    "[out1,out2]=model.test(x,y)\n",
    "tt=model.get_raw_weights()\n",
    "u_hat=model.get_prob_alpha()[0].reshape(-1)*tt[0][0].reshape(-1)\n",
    "v_hat=model.get_prob_alpha()[1].reshape(-1)*tt[0][1].reshape(-1)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fa5e99d2cc0>]"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "p=600\n",
    "plt.plot(np.arange(p),np.abs(u_hat),c='k')\n",
    "plt.plot(np.arange(p),u)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.5.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
