{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "b9f558f5",
   "metadata": {},
   "source": [
    "### This code unifies all results (R-PCMCI, P-PCMCI, B-PCMCI, SAC-PCMCI, PAC-PCMCI)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2576124c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy\n",
    "\n",
    "import os\n",
    "import numpy as np\n",
    "import dill as pickle\n",
    "import os\n",
    "from tigramite.toymodels import structural_causal_processes as toys"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d1c3a8ce-b862-49a1-98a7-b59e94f00d8d",
   "metadata": {},
   "outputs": [],
   "source": [
    "naive_path = './../final_no_cycles_naive/'\n",
    "non_naive_path = './../final_no_cycles/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43a696ad-74b1-42c1-b380-e2c1cf22ea48",
   "metadata": {},
   "outputs": [],
   "source": [
    "new_save = './../new_results_combined/'\n",
    "os.mkdir(new_save)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "adaa66a8-85a7-4507-baef-6ffaef515890",
   "metadata": {},
   "outputs": [],
   "source": [
    "naive_path = './../final_no_cycles_naive/'\n",
    "non_naive_path = './../final_no_cycles/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b748af21-a92d-417f-a0cc-010a9d437daa",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# all_dirs_naive = []\n",
    "# all_dirs_non_naive = []\n",
    "dir_failed_count = []\n",
    "for directory in os.listdir(naive_path):\n",
    "    if '-' in directory:\n",
    "        failed_count = 0\n",
    "        non_naive_files = [file for file in os.listdir(non_naive_path + directory) if '.dat' in file]\n",
    "        results_non_naive = [pickle.load(open(non_naive_path + directory + '/' + filename, 'rb'), encoding='latin1') for filename in non_naive_files]\n",
    "        if len(results_non_naive) > 0:\n",
    "            save_to = new_save + directory + '/'\n",
    "            if not os.path.isdir(save_to):\n",
    "                os.mkdir(save_to)\n",
    "            naive_files = [file for file in os.listdir(naive_path + directory) if '.dat' in file]\n",
    "            results_naive = [pickle.load(open(naive_path + directory + '/' + filename, 'rb'), encoding='latin1') for filename in naive_files]\n",
    "            for i in range(len(results_naive)):\n",
    "                filename = save_to + non_naive_files[i]\n",
    "                if results_naive[i] is not None and 'str' not in str(type(results_naive[i])) and results_non_naive[i] is not None and  'str' not in str(type(results_non_naive[i])):\n",
    "                    new_dict = copy.deepcopy(results_non_naive[i])\n",
    "                    new_dict['graphs_ymask_naive'] = copy.deepcopy(results_naive[i]['graphs_ymask'])\n",
    "                    new_dict['union_graph_ymask_naive'] = copy.deepcopy(results_naive[i]['union_graph_ymask'])\n",
    "                    new_dict['computation_time_ymask_naive'] = copy.deepcopy(results_naive[i]['computation_time_ymask'])\n",
    "                    file = open(filename, 'wb')\n",
    "                    pickle.dump(new_dict, file, protocol=-1)\n",
    "                    file.close()\n",
    "                else:\n",
    "                    file = open(filename, 'wb')\n",
    "                    pickle.dump(None, file, protocol=-1)\n",
    "                    file.close()\n",
    "                    failed_count += 1\n",
    "        dir_failed_count.append(failed_count)\n",
    "                \n",
    "                "
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
