{"cells":[{"cell_type":"code","source":["from google.colab import drive\n","drive.mount('/content/drive', force_remount = True)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"TTNgD-nsc312","executionInfo":{"status":"ok","timestamp":1732473267098,"user_tz":300,"elapsed":20064,"user":{"displayName":"Randy Kim","userId":"05763597803675787034"}},"outputId":"5da63cbd-da87-4c4c-9c63-8804dd86dc5e"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Mounted at /content/drive\n"]}]},{"cell_type":"code","execution_count":null,"metadata":{"id":"v8kiZN_SC_fi"},"outputs":[],"source":["import sys\n","sys.path.append('drive/MyDrive/WDHA')\n","from WDHA1D import *\n","\n","def MCsimulation(n):\n","  length = 100\n","  support = np.linspace(0.5/length, 1-0.5/length, length)\n","  WP_w2_list, WOP_w2_list = [], []\n","  WP_l2_list, WOP_l2_list = [], []\n","  for k in range(n):\n","    mean = np.random.uniform(0.3, 0.7, size=3)\n","    sigma = np.random.uniform(0, 1, size=3)\n","    mu, mu_qf = np.zeros((len(mean), length)), np.zeros((len(mean), length))\n","\n","    for i in range(len(mu)):\n","        mu[i] = stats.norm.pdf(support,mean[i],sigma[i])\n","        if np.sum(mu[i])>0:\n","            mu[i] *= len(mu[i]) / sum(mu[i])\n","        else:\n","            mu[i] = stats.norm.pdf(support,mean[i],sigma[i])\n","            mu[i] *= len(mu[i]) / sum(mu[i])\n","        mu_qf[i] = cdf_to_qf(pdf_to_cdf(mu[i]))\n","    label_qf = np.mean(mu_qf, axis = 0)\n","    label_cdf = qf_to_cdf(label_qf)\n","    label_pdf = np.gradient(label_cdf, 1/length)\n","\n","    wproj = gaussian1d(mean, sigma, length, proj_option = True, plot_option = False)\n","    woproj = gaussian1d(mean, sigma, length, proj_option = False, plot_option = False)\n","\n","    wproj_cdf, woproj_cdf = pdf_to_cdf(wproj), pdf_to_cdf(woproj)\n","    wproj_qf, woproj_qf = cdf_to_qf(wproj_cdf), cdf_to_qf(woproj_cdf)\n","\n","    WP_w2_list.append(w2dist(wproj_qf,label_qf))\n","    WOP_w2_list.append(w2dist(woproj_qf,label_qf))\n","\n","    WP_l2_list.append(l2dist(wproj,label_pdf))\n","    WOP_l2_list.append(l2dist(woproj,label_pdf))\n","    print(\"num_iter : \",k+1)\n","  w2list = [WP_w2_list,WOP_w2_list]\n","  l2list = [WP_l2_list,WOP_l2_list]\n","\n","  return w2list, l2list\n","\n","w2list, l2list = MCsimulation(300)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"cZWLRIYqZYQ3"},"outputs":[],"source":["import pandas as pd\n","\n","df = pd.DataFrame(w2list, index=['with_proj', 'without_proj'])\n","\n","summary = df.T.describe()\n","print(summary)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"ifIGMT4f9kL0"},"outputs":[],"source":["import pandas as pd\n","\n","df = pd.DataFrame(l2list, index=['with_proj', 'without_proj'])\n","\n","summary = df.T.describe()\n","\n","print(summary)"]}],"metadata":{"colab":{"provenance":[]},"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.11.2"}},"nbformat":4,"nbformat_minor":0}