{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "c24cef86",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import os\n",
    "import glob # Used to find multiple time series files\n",
    "\n",
    "PROCESSED_DATA_BASE_DIR = './'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "3792768f",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.metrics import precision_recall_curve, roc_curve, auc\n",
    "def get_result_matrix(solve: np.ndarray,\n",
    "                      gt: np.ndarray,\n",
    "                      WA: np.array,\n",
    "                      data_loss,\n",
    "                      exist_edges_mask: np.ndarray,\n",
    "                      w_threshold: float,\n",
    "                      p: int, # Added p\n",
    "                      d_vars: int # Added d_vars\n",
    "                     ):\n",
    "    num_timestep_rows = solve.shape[0]\n",
    "    result_matrix = np.zeros((1, 8)) # Now 8 columns\n",
    "\n",
    "    gt_any = gt\n",
    "    solve_any = np.any(solve, axis=0) # Shape (d_vars, d_vars) - True if any lag connects i->j\n",
    "    path_recovery_denom = np.sum(exist_edges_mask)\n",
    "    path_recovery = np.sum(solve_any.astype(bool) & exist_edges_mask.astype(bool)) / path_recovery_denom if path_recovery_denom > 0 else 0\n",
    "    shd_any = np.sum(solve_any != gt_any)\n",
    "    edge_num_correct_any = np.sum(np.logical_and(solve_any, gt_any))\n",
    "    solve_any_sum = np.sum(solve_any)\n",
    "    gt_any_sum = np.sum(gt_any)\n",
    "    edge_num_accuracy_any = edge_num_correct_any / solve_any_sum if solve_any_sum > 0 else 0\n",
    "    edge_num_recall_any = edge_num_correct_any / gt_any_sum if gt_any_sum > 0 else 0\n",
    "    edge_num_f1_any = 2 * edge_num_recall_any * edge_num_accuracy_any / (edge_num_recall_any + edge_num_accuracy_any) if (edge_num_recall_any + edge_num_accuracy_any) != 0 else 0\n",
    "    num_genes = gt.shape[0] # Number of genes\n",
    "    true_labels = []\n",
    "    predicted_scores = []\n",
    "    for i in range(num_genes):\n",
    "        for j in range(num_genes):\n",
    "            true_labels.append(gt[i, j])\n",
    "            predicted_score=np.abs(np.sum(WA,axis=0))\n",
    "            predicted_scores.append(predicted_score[i,j])\n",
    "    precision, recall, _ = precision_recall_curve(true_labels, predicted_scores)\n",
    "    aupr = auc(recall, precision)\n",
    "    fpr, tpr, _ = roc_curve(true_labels, predicted_scores)\n",
    "    auroc = auc(fpr, tpr)\n",
    "    result_matrix[0] = [edge_num_accuracy_any, edge_num_recall_any, edge_num_f1_any, shd_any, path_recovery, data_loss, aupr, auroc]\n",
    "\n",
    "    return result_matrix\n",
    "\n",
    "def get_result_matrix_notears(solve: np.ndarray,\n",
    "                      gt: np.ndarray,\n",
    "                      WA: np.array,\n",
    "                      data_loss,\n",
    "                      exist_edges_mask: np.ndarray,\n",
    "                      w_threshold: float,\n",
    "                      p: int, # Added p\n",
    "                      d_vars: int # Added d_vars\n",
    "                     ):\n",
    "    num_timestep_rows = solve.shape[0]\n",
    "    result_matrix = np.zeros((1, 8)) # Now 8 columns\n",
    "\n",
    "    gt_any = gt\n",
    "    solve_any = solve # Shape (d_vars, d_vars) - True if any lag connects i->j\n",
    "    path_recovery_denom = np.sum(exist_edges_mask)\n",
    "    path_recovery = np.sum(solve_any.astype(bool) & exist_edges_mask.astype(bool)) / path_recovery_denom if path_recovery_denom > 0 else 0\n",
    "    shd_any = np.sum(solve_any != gt_any)\n",
    "    edge_num_correct_any = np.sum(np.logical_and(solve_any, gt_any))\n",
    "    solve_any_sum = np.sum(solve_any)\n",
    "    gt_any_sum = np.sum(gt_any)\n",
    "    edge_num_accuracy_any = edge_num_correct_any / solve_any_sum if solve_any_sum > 0 else 0\n",
    "    edge_num_recall_any = edge_num_correct_any / gt_any_sum if gt_any_sum > 0 else 0\n",
    "    edge_num_f1_any = 2 * edge_num_recall_any * edge_num_accuracy_any / (edge_num_recall_any + edge_num_accuracy_any) if (edge_num_recall_any + edge_num_accuracy_any) != 0 else 0\n",
    "    num_genes = gt.shape[0] # Number of genes\n",
    "    true_labels = []\n",
    "    predicted_scores = []\n",
    "    for i in range(num_genes):\n",
    "        for j in range(num_genes):\n",
    "            true_labels.append(gt[i, j])\n",
    "            predicted_score=np.abs(WA)\n",
    "            predicted_scores.append(predicted_score[i,j])\n",
    "    precision, recall, _ = precision_recall_curve(true_labels, predicted_scores)\n",
    "    aupr = auc(recall, precision)\n",
    "    fpr, tpr, _ = roc_curve(true_labels, predicted_scores)\n",
    "    auroc = auc(fpr, tpr)\n",
    "    result_matrix[0] = [edge_num_accuracy_any, edge_num_recall_any, edge_num_f1_any, shd_any, path_recovery, data_loss, aupr, auroc]\n",
    "\n",
    "    return result_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "b21aa750",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1_3_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.15990110106607705, edge loss: 0.0\n",
      "       accuracy  recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.578947  0.3125  0.405904  161.0            1.0  6.240437  0.351068   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.747237  dynotears_abs& (init 0)        0.25          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.1277040856508135, edge loss: 6.708831973939281\n",
      "data loss: 0.1287308380146922, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "1_3_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.16598591893966122, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.711111  0.545455  0.617363  119.0            1.0  5.621853  0.572552   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.818842  dynotears_abs& (init 0)         0.5          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.1277040856508135, edge loss: 13.817245682817202\n",
      "data loss: 0.13169406644968457, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "1_3_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2041697392021522, edge loss: 0.0\n",
      "       accuracy    recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total   0.87013  0.761364  0.812121  62.0            1.0  4.947254  0.805874   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.913494  dynotears_abs& (init 0)        0.75          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.1277040856508135, edge loss: 20.679916697523492\n",
      "data loss: 0.13406703879070156, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "1_3_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:77: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_h = E.T * W * 2\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.21808103879630428, edge loss: 0.0\n",
      "       accuracy  recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.921466     1.0  0.959128  15.0            1.0  4.860376  0.995985   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.999928  dynotears_abs& (init 0)         1.0          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.1277040856508135, edge loss: 27.22573629466466\n",
      "data loss: 0.13954092967297244, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "1_6_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.19433179900713227, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.496124  0.363636  0.419672  177.0            1.0  5.292979  0.319549   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.781414  dynotears_abs& (init 0)        0.25          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.16677952908441587, edge loss: 6.933271718196734\n",
      "data loss: 0.1674884032279144, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "1_6_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:77: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_h = E.T * W * 2\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2143368585190481, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.636943  0.568182  0.600601  133.0            1.0  5.029378  0.562558   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.847823  dynotears_abs& (init 0)         0.5          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.16677952908441587, edge loss: 12.806188624811856\n",
      "data loss: 0.16923685072113417, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "1_6_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: overflow encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: overflow encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:77: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_h = E.T * W * 2\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.23442744793525483, edge loss: 0.0\n",
      "       accuracy    recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.769663  0.778409  0.774011  80.0            1.0  4.317803  0.794753   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.923081  dynotears_abs& (init 0)        0.75          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.16677952908441587, edge loss: 19.52331870396409\n",
      "data loss: 0.17339293252703192, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "1_6_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.24805137445378178, edge loss: 0.0\n",
      "       accuracy  recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.875622     1.0  0.933687  25.0            1.0  4.311436  0.964608   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.999573  dynotears_abs& (init 0)         1.0          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.16677952908441587, edge loss: 25.42009798839356\n",
      "data loss: 0.1727567018202467, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "1_9_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:77: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_h = E.T * W * 2\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.20969556870010733, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.377551  0.420455  0.397849  224.0            1.0  4.497053  0.297634   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.818511  dynotears_abs& (init 0)        0.25          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.18625603626146725, edge loss: 6.878617948095938\n",
      "data loss: 0.18705993016248643, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "1_9_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.23952562732161045, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.573864  0.573864  0.573864  150.0            1.0  4.394137  0.543828   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.873526  dynotears_abs& (init 0)         0.5          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.18625603626146725, edge loss: 12.404072378987749\n",
      "data loss: 0.1902508733252955, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "1_9_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: overflow encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: overflow encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/numpy/core/fromnumeric.py:1748: RuntimeWarning: invalid value encountered in reduce\n",
      "  return asanyarray(a).trace(offset=offset, axis1=axis1, axis2=axis2, dtype=dtype, out=out)\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:77: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_h = E.T * W * 2\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2766999621175642, edge loss: 0.10946757694386995\n",
      "       accuracy    recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.768362  0.772727  0.770538  81.0       0.992424  3.752326  0.776009   \n",
      "\n",
      "          roc                      alg  prior_rate  data_size  \n",
      "total  0.9441  dynotears_abs& (init 0)        0.75          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.18625603626146725, edge loss: 18.74245922069608\n",
      "data loss: 0.19135436447579393, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "1_9_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: overflow encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: overflow encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2917926300485977, edge loss: 0.0\n",
      "       accuracy  recall       f1   shd  edge_recovery  dataloss      pr  \\\n",
      "total  0.850242     1.0  0.91906  31.0            1.0  3.611421  0.9585   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.999524  dynotears_abs& (init 0)         1.0          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.18625603626146725, edge loss: 24.008209295500517\n",
      "data loss: 0.19312551227232863, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "2_3_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2274440108482138, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.711111  0.257028  0.377581  211.0            1.0  6.995622  0.317546   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.690469  dynotears_abs& (init 0)        0.25          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.16165618779698543, edge loss: 11.557787924674582\n",
      "data loss: 0.16297118601968, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "2_3_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: overflow encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: overflow encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2520060787398135, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.912409  0.502008  0.647668  136.0            1.0  6.191758  0.566101   \n",
      "\n",
      "           roc                      alg  prior_rate  data_size  \n",
      "total  0.79916  dynotears_abs& (init 0)         0.5          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.16165618779698543, edge loss: 23.014442526662904\n",
      "data loss: 0.1662314117032438, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "2_3_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.26009248503598154, edge loss: 0.0\n",
      "       accuracy    recall        f1   shd  edge_recovery  dataloss       pr  \\\n",
      "total  0.939698  0.751004  0.834821  74.0            1.0  5.794522  0.79053   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.898105  dynotears_abs& (init 0)        0.75          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.16165618779698543, edge loss: 33.34307969500519\n",
      "data loss: 0.16930627023326925, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "2_3_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:77: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_h = E.T * W * 2\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.28508303155109715, edge loss: 0.0\n",
      "       accuracy  recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total   0.96139     1.0  0.980315  10.0            1.0   5.19368  0.999241   \n",
      "\n",
      "           roc                      alg  prior_rate  data_size  \n",
      "total  0.99998  dynotears_abs& (init 0)         1.0          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.16165618779698543, edge loss: 44.241466030848336\n",
      "data loss: 0.17409104856167945, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "2_6_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.23458884147613993, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss       pr  \\\n",
      "total   0.52518  0.293173  0.376289  242.0            1.0  6.425393  0.31732   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.691217  dynotears_abs& (init 0)        0.25          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.19998902334253343, edge loss: 11.10667078038807\n",
      "data loss: 0.20186223001440606, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "2_6_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.24470540378697528, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.642157  0.526104  0.578366  191.0            1.0  5.830418  0.546853   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.802807  dynotears_abs& (init 0)         0.5          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.19998902334253343, edge loss: 21.967247542256292\n",
      "data loss: 0.20375379466295462, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "2_6_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2822890873242157, edge loss: 0.0\n",
      "       accuracy    recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.883178  0.759036  0.816415  85.0            1.0   5.59111  0.792607   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.916372  dynotears_abs& (init 0)        0.75          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.19998902334253343, edge loss: 32.1157471295559\n",
      "data loss: 0.20886356495278552, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "2_6_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.33764265864194193, edge loss: 0.0\n",
      "       accuracy  recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.957692     1.0  0.978389  11.0            1.0  4.891027  0.997101   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.999928  dynotears_abs& (init 0)         1.0          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.19998902334253343, edge loss: 42.74398153113596\n",
      "data loss: 0.21937242012877564, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "2_9_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2432739906011399, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.391753  0.305221  0.343115  291.0            1.0  5.339256  0.274844   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.685385  dynotears_abs& (init 0)        0.25          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.22305503825991957, edge loss: 10.566354243954784\n",
      "data loss: 0.2251116479925211, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "2_9_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.28615797556270484, edge loss: 0.0\n",
      "       accuracy   recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.686486  0.51004  0.585253  180.0            1.0  5.286954  0.550933   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.809199  dynotears_abs& (init 0)         0.5          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.22305503825991957, edge loss: 21.7574756660284\n",
      "data loss: 0.23140263673609296, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "2_9_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.3261928087439389, edge loss: 0.0\n",
      "       accuracy   recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.846847  0.75502  0.798301  95.0            1.0  5.227825  0.785869   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.913674  dynotears_abs& (init 0)        0.75          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.22305503825991957, edge loss: 31.934483320785723\n",
      "data loss: 0.23055483192345885, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "2_9_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:77: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_h = E.T * W * 2\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.3965847026460676, edge loss: 0.0\n",
      "       accuracy  recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.946768     1.0  0.972656  14.0            1.0  4.298074  0.996836   \n",
      "\n",
      "           roc                      alg  prior_rate  data_size  \n",
      "total  0.99992  dynotears_abs& (init 0)         1.0          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.22305503825991957, edge loss: 41.86269264384716\n",
      "data loss: 0.2387610828812492, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "3_3_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.18528987116823475, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.475806  0.302564  0.369906  201.0            1.0  7.261379  0.272897   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.724281  dynotears_abs& (init 0)        0.25          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.1402761837226789, edge loss: 7.966926001669246\n",
      "data loss: 0.1409595425468254, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "3_3_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:77: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_h = E.T * W * 2\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2261197645123828, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.662338  0.523077  0.584527  145.0            1.0  6.206323  0.558137   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.813126  dynotears_abs& (init 0)         0.5          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.1402761837226789, edge loss: 16.019672174551957\n",
      "data loss: 0.14322616305557145, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "3_3_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2452071529570052, edge loss: 0.10119453154338925\n",
      "       accuracy    recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total       0.8  0.758974  0.778947  84.0       0.993197  5.867294  0.770994   \n",
      "\n",
      "           roc                      alg  prior_rate  data_size  \n",
      "total  0.90153  dynotears_abs& (init 0)        0.75          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.1402761837226789, edge loss: 23.799662789608103\n",
      "data loss: 0.14604401532661423, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "3_3_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.27123424062967333, edge loss: 0.22347198899514525\n",
      "       accuracy    recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.861607  0.989744  0.921241  33.0       0.989744  5.632678  0.990327   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.999791  dynotears_abs& (init 0)         1.0          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.1402761837226789, edge loss: 31.769353898456203\n",
      "data loss: 0.14903436134400383, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "3_6_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: overflow encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: overflow encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.22709586301492193, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.433333  0.333333  0.376812  215.0            1.0  6.686803  0.328663   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.726167  dynotears_abs& (init 0)        0.25          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.17666902826898834, edge loss: 7.8821984300609484\n",
      "data loss: 0.17825210353865742, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "3_6_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2368043763501768, edge loss: 0.0\n",
      "       accuracy   recall    f1    shd  edge_recovery  dataloss       pr  \\\n",
      "total  0.517073  0.54359  0.53  188.0            1.0  5.537174  0.55334   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.810351  dynotears_abs& (init 0)         0.5          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.17666902826898834, edge loss: 15.696693024416048\n",
      "data loss: 0.18315897656903485, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "3_6_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: overflow encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: overflow encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.27993540490453733, edge loss: 0.10923782066989864\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss     pr  \\\n",
      "total   0.72549  0.758974  0.741855  103.0       0.993197  5.316955  0.774   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.902647  dynotears_abs& (init 0)        0.75          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.17666902826898834, edge loss: 23.344917837784937\n",
      "data loss: 0.1838592563211404, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "3_6_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2771704853883505, edge loss: 0.21863799749677626\n",
      "       accuracy    recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total   0.73384  0.989744  0.842795  72.0       0.989744  5.203238  0.966604   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.999268  dynotears_abs& (init 0)         1.0          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.17666902826898834, edge loss: 30.57317506135294\n",
      "data loss: 0.18700573679090451, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "3_9_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.23820755648757974, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.418182  0.353846  0.383333  222.0            1.0  5.659241  0.298502   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.754088  dynotears_abs& (init 0)        0.25          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.19629725756824137, edge loss: 7.89014859232757\n",
      "data loss: 0.19800567912430167, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "3_9_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2526825760004545, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.497696  0.553846  0.524272  196.0            1.0  4.770474  0.532201   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.830396  dynotears_abs& (init 0)         0.5          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.19629725756824137, edge loss: 15.11703972551\n",
      "data loss: 0.20526986498095498, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "3_9_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.27598600057483336, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.641026  0.769231  0.699301  129.0            1.0  4.614835  0.718061   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.904697  dynotears_abs& (init 0)        0.75          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.19629725756824137, edge loss: 23.035786186734676\n",
      "data loss: 0.20337251486161181, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "3_9_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:77: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_h = E.T * W * 2\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2863746733208643, edge loss: 0.10675252537876198\n",
      "       accuracy    recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.702899  0.994872  0.823779  83.0       0.994872  4.386853  0.882123   \n",
      "\n",
      "          roc                      alg  prior_rate  data_size  \n",
      "total  0.9983  dynotears_abs& (init 0)         1.0          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.19629725756824137, edge loss: 29.64935963895344\n",
      "data loss: 0.20563043300255904, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "4_3_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.20975423096799717, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.753425  0.260664  0.387324  174.0            1.0  6.664611  0.310829   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.712246  dynotears_abs& (init 0)        0.25          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.15191100407866942, edge loss: 8.580519758162305\n",
      "data loss: 0.15203191323362608, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "4_3_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.19166567121511374, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.736486  0.516588  0.607242  141.0            1.0  5.803742  0.547678   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.799837  dynotears_abs& (init 0)         0.5          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.15191100407866942, edge loss: 18.042128300076993\n",
      "data loss: 0.1521694381063376, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "4_3_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: overflow encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: overflow encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2324455673056632, edge loss: 0.0\n",
      "       accuracy    recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.935294  0.753555  0.834646  63.0            1.0  5.082654  0.788215   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.909392  dynotears_abs& (init 0)        0.75          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.15191100407866942, edge loss: 27.742146349854394\n",
      "data loss: 0.157904494567359, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "4_3_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.21814763499886644, edge loss: 0.0\n",
      "       accuracy  recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.921397     1.0  0.959091  18.0            1.0  4.803165  0.995282   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.999897  dynotears_abs& (init 0)         1.0          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.15191100407866942, edge loss: 35.876209301561325\n",
      "data loss: 0.15450137900179683, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "4_6_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2118043796836045, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.374269  0.303318  0.335079  254.0            1.0  5.224999  0.307298   \n",
      "\n",
      "           roc                      alg  prior_rate  data_size  \n",
      "total  0.75546  dynotears_abs& (init 0)        0.25          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.1899439266183554, edge loss: 8.153267156655247\n",
      "data loss: 0.19216090430812888, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "4_6_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: overflow encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: overflow encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2221854310207363, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.535211  0.540284  0.537736  196.0            1.0  4.563931  0.549096   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.815529  dynotears_abs& (init 0)         0.5          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.1899439266183554, edge loss: 16.68451618617254\n",
      "data loss: 0.19370293456908938, edge loss: 0.10349461234144192\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "4_6_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2857832162728321, edge loss: 0.0\n",
      "       accuracy    recall       f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.859459  0.753555  0.80303  78.0            1.0   4.21075  0.790133   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.921964  dynotears_abs& (init 0)        0.75          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.1899439266183554, edge loss: 26.260210223717976\n",
      "data loss: 0.19345096246468513, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "4_6_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: overflow encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: overflow encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2642259728100178, edge loss: 0.0\n",
      "       accuracy  recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total   0.84739     1.0  0.917391  38.0            1.0  4.028963  0.989429   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.999766  dynotears_abs& (init 0)         1.0          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.1899439266183554, edge loss: 34.09936842141616\n",
      "data loss: 0.1996780174801673, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "4_9_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: overflow encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: overflow encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:77: RuntimeWarning: overflow encountered in multiply\n",
      "  G_h = E.T * W * 2\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:77: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_h = E.T * W * 2\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: invalid value encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2219869667846265, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.346734  0.327014  0.336585  272.0            1.0  4.793587  0.279763   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.770017  dynotears_abs& (init 0)        0.25          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.20589057370576078, edge loss: 8.165089434374464\n",
      "data loss: 0.20789650890215097, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "4_9_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.23771442483236627, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.472803  0.535545  0.502222  224.0            1.0  4.277617  0.533334   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.830872  dynotears_abs& (init 0)         0.5          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.20589057370576078, edge loss: 15.407179568314998\n",
      "data loss: 0.2077618688684677, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "4_9_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.29776279600063, edge loss: 0.12672318238742392\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.760766  0.753555  0.757143  102.0       0.993711  4.105081  0.786822   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.917319  dynotears_abs& (init 0)        0.75          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.20589057370576078, edge loss: 25.187928821492626\n",
      "data loss: 0.2123177001293115, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "4_9_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2891376146715288, edge loss: 0.0\n",
      "       accuracy  recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.796226     1.0  0.886555  54.0            1.0  3.999975  0.972797   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.999417  dynotears_abs& (init 0)         1.0          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.20589057370576078, edge loss: 32.12004351244979\n",
      "data loss: 0.2103668106368214, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "5_3_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.18352977751899938, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss       pr  \\\n",
      "total       0.5  0.259067  0.341297  193.0            1.0  5.844393  0.29105   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.703404  dynotears_abs& (init 0)        0.25          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.14054518745030448, edge loss: 8.148331738367826\n",
      "data loss: 0.14088044790167228, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "5_3_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.19217296640216183, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.702128  0.512953  0.592814  136.0            1.0  4.925439  0.541704   \n",
      "\n",
      "           roc                      alg  prior_rate  data_size  \n",
      "total  0.80901  dynotears_abs& (init 0)         0.5          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.14054518745030448, edge loss: 16.12035860841214\n",
      "data loss: 0.1408752228682602, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "5_3_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.18696493063606578, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.726368  0.756477  0.741117  102.0            1.0  4.528763  0.751102   \n",
      "\n",
      "          roc                      alg  prior_rate  data_size  \n",
      "total  0.9051  dynotears_abs& (init 0)        0.75          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.14054518745030448, edge loss: 24.630982315436857\n",
      "data loss: 0.14326282052695913, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "5_3_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2069466832185227, edge loss: 0.0\n",
      "       accuracy  recall        f1   shd  edge_recovery  dataloss       pr  \\\n",
      "total  0.865471     1.0  0.927885  30.0            1.0  4.084818  0.99334   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.999881  dynotears_abs& (init 0)         1.0          3  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.14054518745030448, edge loss: 32.73902649421971\n",
      "data loss: 0.14403203832387987, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "5_6_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: overflow encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: overflow encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.21820063612647214, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.426357  0.284974  0.341615  212.0            1.0  5.337078  0.312352   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.755085  dynotears_abs& (init 0)        0.25          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.18200825905862103, edge loss: 7.821000818275105\n",
      "data loss: 0.183151948468602, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "5_6_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: overflow encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: overflow encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.23837988543696775, edge loss: 0.11509360019816502\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.540541  0.518135  0.529101  178.0       0.989691  4.472929  0.535429   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.821697  dynotears_abs& (init 0)         0.5          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.18200825905862103, edge loss: 14.235141366269481\n",
      "data loss: 0.18395088282752087, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "5_6_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.23450953210003153, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.690141  0.761658  0.724138  112.0            1.0  4.086365  0.748832   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.911958  dynotears_abs& (init 0)        0.75          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.18200825905862103, edge loss: 22.689404135171603\n",
      "data loss: 0.18798924325662947, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "5_6_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.24367395483127435, edge loss: 0.0\n",
      "       accuracy  recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.742308     1.0  0.852097  67.0            1.0   3.64399  0.956688   \n",
      "\n",
      "          roc                      alg  prior_rate  data_size  \n",
      "total  0.9994  dynotears_abs& (init 0)         1.0          6  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.18200825905862103, edge loss: 30.30617922470104\n",
      "data loss: 0.18923163030196932, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "5_9_0.25 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:106: RuntimeWarning: overflow encountered in double_scalars\n",
      "  obj = loss + 0.5 * rho * h * h + alpha * h + lambda1 * w.sum() +  ee_loss\n",
      "/home/wxy/rcx/dynotears_edge/processed_dream4_size100_csv/../notears/linear_edge.py:107: RuntimeWarning: overflow encountered in multiply\n",
      "  G_smooth = G_loss + (rho * h + alpha) * G_h\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.2200771216359536, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.319149  0.310881  0.314961  261.0            1.0  4.667622  0.260739   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.745581  dynotears_abs& (init 0)        0.25          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.197208849375704, edge loss: 7.69272884338767\n",
      "data loss: 0.19732736250194524, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "5_9_0.5 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: overflow encountered in matmul\n",
      "  eAw = eAw @ eAw\n",
      "/home/wxy/anaconda3/envs/ldr310/lib/python3.10/site-packages/scipy/linalg/_matfuncs.py:378: RuntimeWarning: invalid value encountered in matmul\n",
      "  eAw = eAw @ eAw\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.23952412454106636, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.481132  0.528497  0.503704  201.0            1.0  4.095385  0.511791   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.826538  dynotears_abs& (init 0)         0.5          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.197208849375704, edge loss: 13.906575185587924\n",
      "data loss: 0.19786200366578416, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "5_9_0.75 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.24245640346934366, edge loss: 0.0\n",
      "       accuracy    recall        f1    shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.604082  0.766839  0.675799  142.0            1.0  3.737072  0.679271   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.907183  dynotears_abs& (init 0)        0.75          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.197208849375704, edge loss: 22.063659276122305\n",
      "data loss: 0.2018331410961802, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n",
      "5_9_1.0 ing ...\n",
      " total    notears\n",
      "Name: alg, dtype: object done!\n",
      " total    notears_edge\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.26860455000356276, edge loss: 0.0\n",
      "       accuracy  recall        f1   shd  edge_recovery  dataloss        pr  \\\n",
      "total  0.725564     1.0  0.840959  73.0            1.0  3.529564  0.921828   \n",
      "\n",
      "            roc                      alg  prior_rate  data_size  \n",
      "total  0.999079  dynotears_abs& (init 0)         1.0          9  \n",
      " total    dynotears_abs& (init 0)\n",
      "Name: alg, dtype: object done!\n",
      "data loss: 0.197208849375704, edge loss: 29.62167546095653\n",
      "data loss: 0.19784490112060604, edge loss: 0.0\n",
      " total    dynotears_abs& (init data)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init 0)\n",
      "Name: alg, dtype: object done!\n",
      " total    dynotears_abs* (init data)\n",
      "Name: alg, dtype: object done!\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "import os\n",
    "\n",
    "current_working_dir = os.getcwd()\n",
    "parent_dir = os.path.join(current_working_dir, '..')\n",
    "sys.path.append(parent_dir)\n",
    "from dynotears import from_pandas_dynamic as from_pandas_dynamic\n",
    "from dynotears_and import from_pandas_dynamic as from_pandas_dynamic_and_abs\n",
    "from dynotears_and_init import from_pandas_dynamic as from_pandas_dynamic_and_abs_initdata\n",
    "from dynotears_multiply import from_pandas_dynamic as from_pandas_dynamic_multiply_abs\n",
    "from dynotears_multiply_init import from_pandas_dynamic as from_pandas_dynamic_multiply_abs_initdata\n",
    "from notears.linear_edge import from_pandas_dynamic as from_pandas_notears_edge\n",
    "from notears.linear_ import from_pandas_dynamic as from_pandas_notears\n",
    "\n",
    "from utils import get_gt_matrix, read_markdown_table\n",
    "from causalnex.structure.structuremodel import StructureModel\n",
    "from causalnex.structure.transformers import DynamicDataTransformer\n",
    "\n",
    "def get_solve_matrix(sm: StructureModel, gene_to_index, p: int, d_vars: int):\n",
    "    solve = np.zeros((p + 1, d_vars, d_vars))\n",
    "    for edge in sm.edges():\n",
    "        start_node = edge[0].split('_lag')[0]\n",
    "        end_node = edge[1].split('_lag')[0]\n",
    "        lag = int(edge[0].split('_lag')[1])\n",
    "        solve[lag, int(gene_to_index[start_node]), int(gene_to_index[end_node])] = 1\n",
    "    return solve\n",
    "\n",
    "def get_result_matrix_df(result_matrix):\n",
    "    return pd.DataFrame(result_matrix, index=[\"total\"], columns=[\"accuracy\", \"recall\", \"f1\", \"shd\", \"edge_recovery\", \"dataloss\", \"pr\", \"roc\"])\n",
    "\n",
    "def solve(instance_dir, alg, LAMBDA_E = 0.1,INSTANCE_NUM_TO_LOAD = 1,P_ORDER = 1,W_THRESHOLD = 0.1,prior_rate=0.8,datasize=3):\n",
    "    instance_dir = os.path.join(PROCESSED_DATA_BASE_DIR, f'instance_{INSTANCE_NUM_TO_LOAD}')\n",
    "    gt_filepath = os.path.join(instance_dir, 'ground_truth_matrix.csv')\n",
    "    timeseries_files = sorted(glob.glob(os.path.join(instance_dir, 'timeseries_data_*.csv')))\n",
    "    gene_names_filepath = os.path.join(instance_dir, 'gene_names.txt')\n",
    "    ground_truth_matrix = pd.read_csv(gt_filepath, index_col=0)\n",
    "    ground_truth_np = ground_truth_matrix.values.astype(int)\n",
    "\n",
    "    train = [] # List to hold DataFrame for each experiment\n",
    "    for i, ts_file in enumerate(timeseries_files):\n",
    "        df_experiment = pd.read_csv(ts_file)\n",
    "        train.append(df_experiment)\n",
    "    \n",
    "    test=train[len(timeseries_files)-1]\n",
    "    train=train[:datasize]\n",
    "    \n",
    "    gene_names = None\n",
    "    with open(gene_names_filepath, 'r') as f:\n",
    "        gene_names = [line.strip() for line in f if line.strip()]\n",
    "\n",
    "    d_vars = len(gene_names)\n",
    "\n",
    "    possible_edge_indices = np.where(ground_truth_np) # Get indices (row, col) of possible edges\n",
    "    num_possible_edges = len(possible_edge_indices[0])\n",
    "    num_edges_to_select = int(np.ceil(prior_rate * num_possible_edges))\n",
    "    exist_edges_mask = np.zeros((d_vars, d_vars))\n",
    "    rng = np.random.default_rng(seed=42)\n",
    "    selected_indices_flat = rng.choice(np.arange(num_possible_edges), size=num_edges_to_select, replace=False)\n",
    "    selected_rows = possible_edge_indices[0][selected_indices_flat]\n",
    "    selected_cols = possible_edge_indices[1][selected_indices_flat]\n",
    "    exist_edges_mask[selected_rows, selected_cols] = 1\n",
    "    \n",
    "    estimated_sm_matrix, estimated_loss, (w_est, a_est) = alg(\n",
    "        train,\n",
    "        p=P_ORDER,\n",
    "        lambda_e=LAMBDA_E,\n",
    "        lambda_a = 1e-3,\n",
    "        lambda_w = 1,\n",
    "        w_threshold=W_THRESHOLD, # This threshold might not affect the returned weights, but the final adjacency matrix estimation within dynotears\n",
    "        exist_edges_mask=exist_edges_mask # We are doing de novo discovery, no prior edges\n",
    "    )\n",
    "    X, Xlags = DynamicDataTransformer(p=P_ORDER).fit_transform([test], return_df=False)\n",
    "    n, d_vars = X.shape\n",
    "    data_loss = 0.5 / n * np.square(np.linalg.norm(X.dot(np.eye(d_vars, d_vars) - w_est) - Xlags.dot(a_est), \"fro\"))\n",
    "    WA = np.concatenate((w_est[None],a_est.reshape(-1,d_vars,d_vars)),axis=0)\n",
    "    gene_to_index = {name: i for i, name in enumerate(gene_names)}\n",
    "    solve_baseline = get_solve_matrix(sm=estimated_sm_matrix, gene_to_index=gene_to_index, p=P_ORDER, d_vars=d_vars)\n",
    "    result_matrix_baseline = get_result_matrix_df(get_result_matrix(solve_baseline ,ground_truth_np, WA, data_loss, exist_edges_mask, W_THRESHOLD, P_ORDER, d_vars))\n",
    "    return result_matrix_baseline\n",
    "    \n",
    "def solve_notears(instance_dir , alg, lambda_w = 0.1, LAMBDA_E = 0.1,INSTANCE_NUM_TO_LOAD = 1,P_ORDER = 1,W_THRESHOLD = 0.1,prior_rate=0.8,datasize=3):\n",
    "    instance_dir = os.path.join(PROCESSED_DATA_BASE_DIR, f'instance_{INSTANCE_NUM_TO_LOAD}')\n",
    "    gt_filepath = os.path.join(instance_dir, 'ground_truth_matrix.csv')\n",
    "    timeseries_files = sorted(glob.glob(os.path.join(instance_dir, 'timeseries_data_*.csv')))\n",
    "    gene_names_filepath = os.path.join(instance_dir, 'gene_names.txt')\n",
    "    ground_truth_matrix = pd.read_csv(gt_filepath, index_col=0)\n",
    "    ground_truth_np = ground_truth_matrix.values.astype(int)\n",
    "\n",
    "    train = [] # List to hold DataFrame for each experiment\n",
    "    for i, ts_file in enumerate(timeseries_files):\n",
    "        df_experiment = pd.read_csv(ts_file)\n",
    "        train.append(df_experiment.values)\n",
    "    \n",
    "    test=train[len(timeseries_files)-1]\n",
    "    train=train[:datasize]\n",
    "    \n",
    "    gene_names = None\n",
    "    with open(gene_names_filepath, 'r') as f:\n",
    "        gene_names = [line.strip() for line in f if line.strip()]\n",
    "\n",
    "    d_vars = len(gene_names)\n",
    "\n",
    "    possible_edge_indices = np.where(ground_truth_np) # Get indices (row, col) of possible edges\n",
    "    num_possible_edges = len(possible_edge_indices[0])\n",
    "    num_edges_to_select = int(np.ceil(prior_rate * num_possible_edges))\n",
    "    exist_edges_mask = np.zeros((d_vars, d_vars))\n",
    "    rng = np.random.default_rng(seed=42)\n",
    "    selected_indices_flat = rng.choice(np.arange(num_possible_edges), size=num_edges_to_select, replace=False)\n",
    "    selected_rows = possible_edge_indices[0][selected_indices_flat]\n",
    "    selected_cols = possible_edge_indices[1][selected_indices_flat]\n",
    "    exist_edges_mask[selected_rows, selected_cols] = 1\n",
    "    train = np.concatenate(train)\n",
    "    estimated_loss, w_est = alg(\n",
    "        train,\n",
    "        p=P_ORDER,\n",
    "        lambda_e=LAMBDA_E,\n",
    "        lambda_w=lambda_w,\n",
    "        w_threshold=W_THRESHOLD, # This threshold might not affect the returned weights, but the final adjacency matrix estimation within dynotears\n",
    "        exist_edges_mask=exist_edges_mask # We are doing de novo discovery, no prior edges\n",
    "    )\n",
    "    X = test\n",
    "    n, d_vars = X.shape\n",
    "    data_loss = 0.5 / X.shape[0] * ((X - X @ w_est) ** 2).sum()\n",
    "    gene_to_index = {name: i for i, name in enumerate(gene_names)}\n",
    "    solve_baseline = w_est > W_THRESHOLD\n",
    "    result_matrix_baseline = get_result_matrix_df(get_result_matrix_notears(solve_baseline ,ground_truth_np, w_est, data_loss, exist_edges_mask, W_THRESHOLD, P_ORDER, d_vars))\n",
    "    return result_matrix_baseline\n",
    "\n",
    "for INSTANCE_NUM_TO_LOAD in [1,2,3,4,5]:\n",
    "    result_df=[]\n",
    "    for datasize in [3,6,9]:\n",
    "        for prior_rate in [0.25,0.5,0.75,1.0]:  \n",
    "            instance_dir = os.path.join(PROCESSED_DATA_BASE_DIR, f'instance_{INSTANCE_NUM_TO_LOAD}')\n",
    "            print(f'{INSTANCE_NUM_TO_LOAD}_{datasize}_{prior_rate} ing ...')\n",
    "            solve_df=solve_notears(instance_dir,from_pandas_notears,lambda_w=0.01,LAMBDA_E=0.5,INSTANCE_NUM_TO_LOAD=INSTANCE_NUM_TO_LOAD,prior_rate=prior_rate,datasize=datasize)  \n",
    "            solve_df['alg']='notears' \n",
    "            solve_df['prior_rate']=prior_rate\n",
    "            solve_df['data_size']=datasize\n",
    "            result_df.append(solve_df)\n",
    "            print(f\" {solve_df['alg']} done!\")  \n",
    "            solve_df=solve_notears(instance_dir,from_pandas_notears_edge,lambda_w=0.01,LAMBDA_E=0.5,INSTANCE_NUM_TO_LOAD=INSTANCE_NUM_TO_LOAD,prior_rate=prior_rate,datasize=datasize)  \n",
    "            solve_df['alg']='notears_edge' \n",
    "            solve_df['prior_rate']=prior_rate\n",
    "            solve_df['data_size']=datasize\n",
    "            result_df.append(solve_df)\n",
    "            print(f\" {solve_df['alg']} done!\")\n",
    "            solve_df=solve(instance_dir,from_pandas_dynamic,INSTANCE_NUM_TO_LOAD=INSTANCE_NUM_TO_LOAD,prior_rate=prior_rate,datasize=datasize)  \n",
    "            solve_df['alg']='dynotears' \n",
    "            solve_df['prior_rate']=prior_rate\n",
    "            solve_df['data_size']=datasize\n",
    "            result_df.append(solve_df)\n",
    "            print(f\" {solve_df['alg']} done!\")        \n",
    "            solve_df=solve(instance_dir,from_pandas_dynamic_and_abs,INSTANCE_NUM_TO_LOAD=INSTANCE_NUM_TO_LOAD,prior_rate=prior_rate,datasize=datasize) \n",
    "            solve_df['alg']='dynotears_abs& (init 0)' \n",
    "            solve_df['prior_rate']=prior_rate\n",
    "            solve_df['data_size']=datasize\n",
    "            result_df.append(solve_df)         \n",
    "            print(f\" {solve_df['alg']} done!\")\n",
    "            solve_df=solve(instance_dir,from_pandas_dynamic_and_abs_initdata,INSTANCE_NUM_TO_LOAD=INSTANCE_NUM_TO_LOAD,prior_rate=prior_rate,datasize=datasize) \n",
    "            solve_df['alg']='dynotears_abs& (init data)'\n",
    "            solve_df['prior_rate']=prior_rate\n",
    "            solve_df['data_size']=datasize \n",
    "            result_df.append(solve_df)  \n",
    "            print(f\" {solve_df['alg']} done!\")\n",
    "            solve_df=solve(instance_dir,from_pandas_dynamic_multiply_abs, LAMBDA_E=0.5,INSTANCE_NUM_TO_LOAD=INSTANCE_NUM_TO_LOAD,prior_rate=prior_rate,datasize=datasize)\n",
    "            solve_df['alg']='dynotears_abs* (init 0)' \n",
    "            solve_df['prior_rate']=prior_rate\n",
    "            solve_df['data_size']=datasize\n",
    "            result_df.append(solve_df)  \n",
    "            print(f\" {solve_df['alg']} done!\")\n",
    "            solve_df=solve(instance_dir,from_pandas_dynamic_multiply_abs_initdata, LAMBDA_E=0.5,INSTANCE_NUM_TO_LOAD=INSTANCE_NUM_TO_LOAD,prior_rate=prior_rate,datasize=datasize)\n",
    "            solve_df['alg']='dynotears_abs* (init data)' \n",
    "            solve_df['prior_rate']=prior_rate\n",
    "            solve_df['data_size']=datasize\n",
    "            result_df.append(solve_df)  \n",
    "            print(f\" {solve_df['alg']} done!\")\n",
    "    combined_df = pd.concat(result_df, ignore_index=False)\n",
    "\n",
    "    output_filename = f\"results_{INSTANCE_NUM_TO_LOAD}.md\"\n",
    "    output_filepath = os.path.join(instance_dir, output_filename)\n",
    "\n",
    "    with open(output_filepath, \"w\", encoding=\"utf-8\") as f:\n",
    "        combined_df.to_markdown(f, index=False)\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ldr310",
   "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.10.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
