{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "39b8268c",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/yugui/opt/anaconda3/lib/python3.9/site-packages/tqdm/auto.py:22: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import random\n",
    "import scipy.stats\n",
    "from scipy.stats import norm\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from tqdm.auto import tqdm\n",
    "import time\n",
    "import scipy.linalg as scilinalg\n",
    "import seaborn as sns\n",
    "from scipy.stats import ortho_group\n",
    "import pandas as pd\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "import multiprocessing as mp\n",
    "from joblib import Parallel, delayed\n",
    "from utils import *\n",
    "\n",
    "from conf_simu import *\n",
    "\n",
    "np.random.seed(1234)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "0185f5c7",
   "metadata": {},
   "outputs": [],
   "source": [
    "def simu_synthetic(d1,d2,alpha,het,sd,tail,pr,k_star,rk,M_mean,mis_set,plot=False,full_exp=False):\n",
    "    M_star, A, P, S = gen_(d1,d2,het,sd,tail,pr,M_mean,mis_set,k_star)\n",
    "    return cfmc_simu(alpha,rk,A,S,M_star,P,het,plot,full_exp=full_exp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "e1c6d4c8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "coverage rate: \n",
      "\t cmc-als 0.8976351148401049\n",
      "\t cmc-cvx 0.8970343819459741\n",
      "\t als 0.7839364024109413\n",
      "\t cvx 0.9384449027813933\n",
      "Average length: \n",
      "\t cmc-als 4.1944\n",
      "\t cmc-cvx 3.8953\n",
      "\t als 2.994\n",
      "\t cvx 4.2216\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAloAAAGYCAYAAACak0zIAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAACe60lEQVR4nOy9eZxcVZn//z731trVXb1n7ayEBAQCYRWQRQQFR2Z0foAwAoKjooLLON8Z5iuOuzh+ZxwHxwXUQRCHGVEUZVMQkDXsW0hIQtZekk56r+7a773n98etqt6qt3RVdXX38369IMnd6nR19ac/5znPeR6ltdYIgiAIgiAIBceY6QEIgiAIgiDMVcRoCYIgCIIgFAkxWoIgCIIgCEVCjJYgCIIgCEKREKMlCIIgCIJQJMRoCYIgCIIgFAkxWoIgCIIgCEVCjJYgCIIgCEKREKMlCIIgCIJQJMRoCfOK//zP/2TdunXccMMNMz0UQRAE0aR5gBgtQRAEQRCEIiFGSxAEQRAEoUiI0RIEQRAEQSgSnpkegCBMF8uy+N3vfscDDzzAm2++SSQSwefzsXz5cs4991w+8pGPUFFRMe4zWltbufnmm3n55Zdpa2vD4/GwatUq3v3ud3PFFVcQDAZL9NUIgjDbEU0ShiJGS5jV2LbNNddcw1NPPUUgEOCEE06gsrKS/fv38/rrr/Pmm2+yceNGfvGLX6CUyvuM5uZmLr74Ynp7e1m9ejVnnnkm8Xicl156ie985zs8+uij/Pd//zemaZb4qxMEYbYhmiSMRIyWMKu5++67eeqpp1i6dCm//OUvaWxszJ178cUX+fCHP8yLL77Ipk2bWL9+fd5n/PSnP6W3t5ePfvSj/MM//EPu+MGDB/ngBz/IK6+8wmOPPca5555b9K9HEITZjWiSMBIxWsKs59xzz+WCCy4YJmgAJ554IuvWrWPz5s20tLSMKWrt7e0ArFy5ctjxBQsW8I1vfIP29nYOP/zwooxdEIS5h2iSMBQxWsKs5pJLLuGSSy4ZdiydTtPc3Mwbb7xBb28vAKlUasxnnHrqqTz++ON89atf5fnnn+ess87i1FNPpb6+ntNPP72YwxcEYY4hmiSMRIyWMOvp6+vj17/+NU899RS7d+/mwIEDOI4DkMuB0FqPef+VV17J7t27ueuuu/j973/P73//e5RSrFu3jnPOOYdLLrmExYsXl+RrEQRh9iOaJAxFjJYwq3n11Vf52Mc+RiQSIRQKcfTRR3POOeewZs0ajj/+eL71rW/x7LPPjvsM0zT52te+xjXXXMMjjzzCM888w8svv8zWrVvZunUrt956KzfffDOnnnpqib4qQRBmK6JJwkjEaAmzmn/6p38iEolw4YUX8s1vfhO/3z/sfCQSmfSzli5dypVXXsmVV16J4zhs2rSJ7373u2zcuJEbb7yRe++9t9DDFwRhjiGaJIxECpYKs5bOzk52794NwDXXXDNK0A4cOMD27dsBcmH7kTiOw1VXXcUpp5zC/v37c8cNw+DYY4/l+uuvB2Dfvn3F+BIEQZhDiCYJ+RCjJcxaKisr8fl8ADz88MPDzrW2tnLttddiWRYAyWQy7zMMw6Curo7e3l5uvPFGEolE7pzjONxzzz0AHHfccYX/AgRBmFOIJgn5kKVDYdYSCAS4/PLLufXWW7npppt46KGHWL58OZ2dnbz66quAuz16z549dHd3j/mc66+/npdeeomHHnqIF154gfXr1+P1etm2bRstLS3U1NTwT//0TyX6qgRBmK2IJgn5kIiWMKv5h3/4B2688UaOOeYY2traePTRR9m/fz8XXHABd911F5///OcBeOyxx8Z8xsKFC7nrrrv40Ic+RHV1NRs3buTJJ5/ENE0+/OEPc++990rNGkEQJoVokjASpcfbYyoIgiAIgiAcMhLREgRBEARBKBJitARBEARBEIqEGC1BEARBEIQiIUZLEARBEAShSIjREgRBEARBKBJitARBEARBEIqEGC1BEARBEIQiIZXhp4HWGscpTBkyw1AFe5YwPvJel5ZCvd+GoVBKFWBEc5dCaZL8jJQeec9LSyHe78lqUtkbrQcffJDbbruNHTt2YJomGzZs4Nprr2X9+vWH9Lznn3+eD3/4w7zzne/khz/84bTG5jia7u7otJ4B4PEY1NaGiERiWFb+RqNCYZD3urQU8v2uqwthmjNvtOa6JsnPSOmR97y0FOr9nqwmlfXS4Y9+9CM+97nP0dnZySWXXMJ5553Hc889x2WXXcaTTz455ef19/dz/fXXj9k1XRAEYTxEkwRBmCplG9HasWMH3/ve91i7di2//OUvqaioAODyyy/nsssu44YbbuChhx4iEAhM+plf+9rX2LdvX7GGLAjCHEY0SRCEQ6FsI1q33347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\n",
      "text/plain": [
       "<Figure size 600x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "d1 = d2 = 500\n",
    "alpha = 0.1\n",
    "sd = 1\n",
    "het = 'homo' # 'homo' | 'logis' | 'rank1'\n",
    "pr = 0.8\n",
    "rk = 40\n",
    "k_star = 6\n",
    "M_mean = 2\n",
    "mis_set = 2\n",
    "full_exp=True\n",
    "tail = 'gaussian'\n",
    "if full_exp:\n",
    "    coverage_cmc_cvx, coverage_cmc_als, coverage_cvx, coverage_als, length_cmc_cvx, length_cmc_als, length_cvx, length_als = simu_synthetic(d1,d2,alpha,het,sd,tail,pr,k_star,rk,M_mean,mis_set,plot=True,full_exp=full_exp)\n",
    "    print('coverage rate: \\n\\t cmc-als {}\\n\\t cmc-cvx {}\\n\\t als {}\\n\\t cvx {}'.format(coverage_cmc_als, coverage_cmc_cvx, coverage_als, coverage_cvx))\n",
    "    print('Average length: \\n\\t cmc-als {}\\n\\t cmc-cvx {}\\n\\t als {}\\n\\t cvx {}'.format(length_cmc_als, length_cmc_cvx, length_als, length_cvx))\n",
    "else:\n",
    "    coverage_cmc_als, coverage_als, length_cmc_als, length_als = simu_synthetic(d1,d2,alpha,het,sd,tail,pr,k_star,rk,M_mean,mis_set,plot=True,full_exp=full_exp)\n",
    "    print('coverage rate: \\n\\t cmc-als {}\\n\\t als {}'.format(coverage_cmc_als, coverage_als))\n",
    "    print('Average length: \\n\\t cmc-als {}\\n\\t als {}'.format(length_cmc_als, length_als))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "cdf22178",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[1, 'gaussian', 1]\n"
     ]
    }
   ],
   "source": [
    "# repeated\n",
    "# remember to disable plotting\n",
    "alpha = 0.1\n",
    "sd0 = 1\n",
    "het = 'homo' # 'homo' | 'logis' | 'rank1'\n",
    "base1 = 'cvx'\n",
    "base2 = base = 'als'\n",
    "repN = 100\n",
    "M_mean = 2\n",
    "k_star = 8\n",
    "sigma_true=False\n",
    "num_cores = mp.cpu_count()\n",
    "\n",
    "\n",
    "for d in [500]:\n",
    "    d1 = d2 = d\n",
    "    for full_exp in [True]:\n",
    "        if full_exp:\n",
    "            rk_seq = range(4,25,4)\n",
    "        else:\n",
    "            rk_seq = range(2,41,2)\n",
    "        for pr in [0.8]:\n",
    "            for tail in ['gaussian']:\n",
    "                for mis_set in [1]:\n",
    "                    for rk in rk_seq:\n",
    "                        if mis_set==2:\n",
    "                            pr = 0.2\n",
    "                        else:\n",
    "                            pr = 0.8\n",
    "                        if mis_set==3:\n",
    "                            tail='t'\n",
    "                            sd = 0.2\n",
    "                        else:\n",
    "                            tail='gaussian'\n",
    "                            sd = sd0\n",
    "                        print([mis_set, tail, sd])\n",
    "                        if __name__ == \"__main__\":\n",
    "                            results = Parallel(n_jobs=num_cores)(delayed(simu_synthetic)(d1,d2,alpha,het,sd,tail,pr,k_star,rk,M_mean,mis_set,full_exp=full_exp) for i in range(repN))\n",
    "                        results = np.array(results)\n",
    "\n",
    "                        if full_exp:\n",
    "                            res_mat = results.reshape(repN,8)\n",
    "                            cov_rt_cf_cvx = res_mat[:,0]\n",
    "                            cov_rt_cf_als = res_mat[:,1]\n",
    "                            cov_rt_cvx = res_mat[:,2]\n",
    "                            cov_rt_als = res_mat[:,3]\n",
    "                            cov_ = np.hstack((cov_rt_cf_cvx, cov_rt_cf_als))\n",
    "                            cov_ = np.hstack((cov_,cov_rt_cvx))\n",
    "                            cov_ = np.hstack((cov_,cov_rt_als))\n",
    "                            len_ave_cf_cvx = res_mat[:,4]\n",
    "                            len_ave_cf_als = res_mat[:,5]\n",
    "                            len_ave_cvx = res_mat[:,6]\n",
    "                            len_ave_als = res_mat[:,7]\n",
    "                            len_ = np.hstack((len_ave_cf_cvx, len_ave_cf_als))\n",
    "                            len_ = np.hstack((len_,len_ave_cvx))\n",
    "                            len_ = np.hstack((len_,len_ave_als))\n",
    "\n",
    "                            label1 = 'cf-'+base1\n",
    "                            label2 = 'cf-'+base2\n",
    "                            label3 = 'cvx'\n",
    "                            label4 = 'als'\n",
    "                            nam_ = [label1]*repN + [label2]*repN + [label3]*repN + [label4]*repN \n",
    "                            cov_df = pd.DataFrame(cov_, columns=['coverage'])\n",
    "                            len_df = pd.DataFrame(len_, columns=['length'])\n",
    "                            cov_df['approach'] = nam_\n",
    "                            len_df['approach'] = nam_\n",
    "\n",
    "                        else:\n",
    "                            res_mat = results.reshape(repN,4)\n",
    "                            cov_rt_cf_als = res_mat[:,0]\n",
    "                            cov_rt_als = res_mat[:,1]\n",
    "                            cov_ = np.hstack((cov_rt_cf_als,cov_rt_als))\n",
    "                            len_ave_cf_als = res_mat[:,2]\n",
    "                            len_ave_als = res_mat[:,3]\n",
    "                            len_ = np.hstack((len_ave_cf_als,len_ave_als))\n",
    "\n",
    "                            label1 = 'cf-'+base2\n",
    "                            label2 = 'als'\n",
    "                            nam_ = [label1]*repN + [label2]*repN\n",
    "                            cov_df = pd.DataFrame(cov_, columns=['coverage'])\n",
    "                            len_df = pd.DataFrame(len_, columns=['length'])\n",
    "                            cov_df['approach'] = nam_\n",
    "                            len_df['approach'] = nam_\n",
    "\n",
    "                        file_dir1 = '../results/cov_'+str(d1)+'_'+str(mis_set)+'_'+str(k_star)+'_'+str(rk)+'_'+het+'_'+str(sd)+'_'+tail+'_'+str(pr)+'_'+str(full_exp)+'.csv'\n",
    "                        file_dir2 = '../results/len_'+str(d1)+'_'+str(mis_set)+'_'+str(k_star)+'_'+str(rk)+'_'+het+'_'+str(sd)+'_'+tail+'_'+str(pr)+'_'+str(full_exp)+'.csv'\n",
    "                        cov_df.to_csv(file_dir1, index=False)\n",
    "                        len_df.to_csv(file_dir2, index=False)\n",
    "\n"
   ]
  }
 ],
 "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
