{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "8da83a1e-c256-4c2f-821e-4c707ab40a2b",
   "metadata": {},
   "source": [
    "### This code creates the results used in Section 6.3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "17be799c-863e-4106-b4fd-3bb0569aac68",
   "metadata": {},
   "outputs": [],
   "source": [
    "### Some initializations\n",
    "import numpy as np\n",
    "import random\n",
    "import loli\n",
    "import pickle\n",
    "from scipy.stats import binomtest\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4a76c559",
   "metadata": {},
   "outputs": [],
   "source": [
    "# The function that generates the dynamical data\n",
    "\n",
    "def lordata_gen(size):\n",
    "    X=np.zeros((size+1,6))\n",
    "    X[0,:]=[2,0.97,0.99,1,0.97,1]\n",
    "    \n",
    "    \n",
    "    for t in range(size):\n",
    "        e=np.random.multivariate_normal(np.zeros(6),np.eye(6))\n",
    "        x_new=[X[t,0]*0.9+0.1*X[t,1]+e[0],\\\n",
    "               0.28*X[t,0]-0.01*X[t,0]*X[t,2]+0.99*X[t,1]+e[1],\\\n",
    "               0.01*X[t,0]*X[t,1]-0.01*X[t,0]*X[t,3]+0.9733*X[t,2]+e[2],\\\n",
    "               0.01*X[t,0]*X[t,2]-0.02*X[t,0]*X[t,4]+0.9366*X[t,3]+e[3],\\\n",
    "               0.02*X[t,0]*X[t,3]+0.96*X[t,4]+e[4],\n",
    "                  X[t,5]+e[5]]\n",
    "        X[t+1,:]=x_new\n",
    "\n",
    "    return(X)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dc6fce18-9bda-437d-a798-d7b4f3f2a398",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 453 out of 500\n",
      "Run 454 out of 500\n",
      "Run 455 out of 500\n",
      "Run 456 out of 500\n",
      "Run 457 out of 500\n",
      "Run 458 out of 500\n",
      "Run 459 out of 500\n",
      "Run 460 out of 500\n",
      "Run 461 out of 500\n",
      "Run 462 out of 500\n",
      "Run 463 out of 500\n",
      "Run 464 out of 500\n",
      "Run 465 out of 500\n",
      "Run 466 out of 500\n",
      "Run 467 out of 500\n",
      "Run 468 out of 500\n",
      "Run 469 out of 500\n",
      "Run 470 out of 500\n",
      "Run 471 out of 500\n",
      "Run 472 out of 500\n",
      "Run 473 out of 500\n",
      "Run 474 out of 500\n",
      "Run 475 out of 500\n",
      "Run 476 out of 500\n",
      "Run 477 out of 500\n",
      "Run 478 out of 500\n",
      "Run 479 out of 500\n",
      "Run 480 out of 500\n",
      "Run 481 out of 500\n",
      "Run 482 out of 500\n",
      "Run 483 out of 500\n",
      "Run 484 out of 500\n",
      "Run 485 out of 500\n",
      "Run 486 out of 500\n",
      "Run 487 out of 500\n",
      "Run 488 out of 500\n",
      "Run 489 out of 500\n",
      "Run 490 out of 500\n",
      "Run 491 out of 500\n",
      "Run 492 out of 500\n",
      "Run 493 out of 500\n",
      "Run 494 out of 500\n",
      "Run 495 out of 500\n",
      "Run 496 out of 500\n",
      "Run 497 out of 500\n",
      "Run 498 out of 500\n",
      "Run 499 out of 500\n",
      "Run 0 out of 500\n",
      "Run 1 out of 500\n",
      "Run 2 out of 500\n",
      "Run 3 out of 500\n",
      "Run 4 out of 500\n",
      "Run 5 out of 500\n",
      "Run 6 out of 500\n",
      "Run 7 out of 500\n",
      "Run 8 out of 500\n",
      "Run 9 out of 500\n",
      "Run 10 out of 500\n",
      "Run 11 out of 500\n",
      "Run 12 out of 500\n",
      "Run 13 out of 500\n",
      "Run 14 out of 500\n",
      "Run 15 out of 500\n",
      "Run 16 out of 500\n",
      "Run 17 out of 500\n",
      "Run 18 out of 500\n",
      "Run 19 out of 500\n",
      "Run 20 out of 500\n",
      "Run 21 out of 500\n",
      "Run 22 out of 500\n",
      "Run 23 out of 500\n",
      "Run 24 out of 500\n",
      "Run 25 out of 500\n",
      "Run 26 out of 500\n",
      "Run 27 out of 500\n",
      "Run 28 out of 500\n",
      "Run 29 out of 500\n",
      "Run 30 out of 500\n",
      "Run 31 out of 500\n",
      "Run 32 out of 500\n",
      "Run 33 out of 500\n",
      "Run 34 out of 500\n",
      "Run 35 out of 500\n",
      "Run 36 out of 500\n",
      "Run 37 out of 500\n",
      "Run 38 out of 500\n",
      "Run 39 out of 500\n",
      "Run 40 out of 500\n",
      "Run 41 out of 500\n",
      "Run 42 out of 500\n",
      "Run 43 out of 500\n",
      "Run 44 out of 500\n",
      "Run 45 out of 500\n",
      "Run 46 out of 500\n",
      "Run 47 out of 500\n",
      "Run 48 out of 500\n",
      "Run 49 out of 500\n",
      "Run 50 out of 500\n",
      "Run 51 out of 500\n",
      "Run 52 out of 500\n",
      "Run 53 out of 500\n",
      "Run 54 out of 500\n",
      "Run 55 out of 500\n",
      "Run 56 out of 500\n",
      "Run 57 out of 500\n",
      "Run 58 out of 500\n",
      "Run 59 out of 500\n",
      "Run 60 out of 500\n",
      "Run 61 out of 500\n",
      "Run 62 out of 500\n",
      "Run 63 out of 500\n",
      "Run 64 out of 500\n",
      "Run 65 out of 500\n",
      "Run 66 out of 500\n",
      "Run 67 out of 500\n",
      "Run 68 out of 500\n",
      "Run 69 out of 500\n",
      "Run 70 out of 500\n",
      "Run 71 out of 500\n",
      "Run 72 out of 500\n",
      "Run 73 out of 500\n",
      "Run 74 out of 500\n",
      "Run 75 out of 500\n",
      "Run 76 out of 500\n",
      "Run 77 out of 500\n",
      "Run 78 out of 500\n",
      "Run 79 out of 500\n",
      "Run 80 out of 500\n",
      "Run 81 out of 500\n",
      "Run 82 out of 500\n",
      "Run 83 out of 500\n",
      "Run 84 out of 500\n",
      "Run 85 out of 500\n",
      "Run 86 out of 500\n",
      "Run 87 out of 500\n",
      "Run 88 out of 500\n",
      "Run 89 out of 500\n",
      "Run 90 out of 500\n",
      "Run 91 out of 500\n",
      "Run 92 out of 500\n",
      "Run 93 out of 500\n",
      "Run 94 out of 500\n",
      "Run 95 out of 500\n",
      "Run 96 out of 500\n",
      "Run 97 out of 500\n",
      "Run 98 out of 500\n",
      "Run 99 out of 500\n",
      "Run 100 out of 500\n",
      "Run 101 out of 500\n",
      "Run 102 out of 500\n",
      "Run 103 out of 500\n",
      "Run 104 out of 500\n",
      "Run 105 out of 500\n",
      "Run 106 out of 500\n",
      "Run 107 out of 500\n",
      "Run 108 out of 500\n",
      "Run 109 out of 500\n",
      "Run 110 out of 500\n",
      "Run 111 out of 500\n",
      "Run 112 out of 500\n",
      "Run 113 out of 500\n",
      "Run 114 out of 500\n",
      "Run 115 out of 500\n",
      "Run 116 out of 500\n",
      "Run 117 out of 500\n",
      "Run 118 out of 500\n",
      "Run 119 out of 500\n",
      "Run 120 out of 500\n",
      "Run 121 out of 500\n",
      "Run 122 out of 500\n",
      "Run 123 out of 500\n",
      "Run 124 out of 500\n",
      "Run 125 out of 500\n",
      "Run 126 out of 500\n",
      "Run 127 out of 500\n",
      "Run 128 out of 500\n",
      "Run 129 out of 500\n",
      "Run 130 out of 500\n",
      "Run 131 out of 500\n",
      "Run 132 out of 500\n",
      "Run 133 out of 500\n",
      "Run 134 out of 500\n",
      "Run 135 out of 500\n",
      "Run 136 out of 500\n",
      "Run 137 out of 500\n",
      "Run 138 out of 500\n",
      "Run 139 out of 500\n",
      "Run 140 out of 500\n",
      "Run 141 out of 500\n",
      "Run 142 out of 500\n",
      "Run 143 out of 500\n",
      "Run 144 out of 500\n",
      "Run 145 out of 500\n",
      "Run 146 out of 500\n",
      "Run 147 out of 500\n",
      "Run 148 out of 500\n",
      "Run 149 out of 500\n",
      "Run 150 out of 500\n",
      "Run 151 out of 500\n",
      "Run 152 out of 500\n",
      "Run 153 out of 500\n",
      "Run 154 out of 500\n",
      "Run 155 out of 500\n",
      "Run 156 out of 500\n",
      "Run 157 out of 500\n",
      "Run 158 out of 500\n",
      "Run 159 out of 500\n",
      "Run 160 out of 500\n",
      "Run 161 out of 500\n",
      "Run 162 out of 500\n",
      "Run 163 out of 500\n",
      "Run 164 out of 500\n",
      "Run 165 out of 500\n",
      "Run 166 out of 500\n",
      "Run 167 out of 500\n",
      "Run 168 out of 500\n",
      "Run 169 out of 500\n",
      "Run 170 out of 500\n",
      "Run 171 out of 500\n",
      "Run 172 out of 500\n",
      "Run 173 out of 500\n",
      "Run 174 out of 500\n",
      "Run 175 out of 500\n",
      "Run 176 out of 500\n",
      "Run 177 out of 500\n",
      "Run 178 out of 500\n",
      "Run 179 out of 500\n",
      "Run 180 out of 500\n",
      "Run 181 out of 500\n",
      "Run 182 out of 500\n",
      "Run 183 out of 500\n",
      "Run 184 out of 500\n",
      "Run 185 out of 500\n",
      "Run 186 out of 500\n",
      "Run 187 out of 500\n",
      "Run 188 out of 500\n",
      "Run 189 out of 500\n",
      "Run 190 out of 500\n",
      "Run 191 out of 500\n",
      "Run 192 out of 500\n",
      "Run 193 out of 500\n",
      "Run 194 out of 500\n",
      "Run 195 out of 500\n",
      "Run 196 out of 500\n",
      "Run 197 out of 500\n",
      "Run 198 out of 500\n",
      "Run 199 out of 500\n",
      "Run 200 out of 500\n",
      "Run 201 out of 500\n",
      "Run 202 out of 500\n",
      "Run 203 out of 500\n",
      "Run 204 out of 500\n",
      "Run 205 out of 500\n",
      "Run 206 out of 500\n",
      "Run 207 out of 500\n",
      "Run 208 out of 500\n",
      "Run 209 out of 500\n",
      "Run 210 out of 500\n",
      "Run 211 out of 500\n",
      "Run 212 out of 500\n",
      "Run 213 out of 500\n",
      "Run 214 out of 500\n",
      "Run 215 out of 500\n",
      "Run 216 out of 500\n",
      "Run 217 out of 500\n",
      "Run 218 out of 500\n",
      "Run 219 out of 500\n",
      "Run 220 out of 500\n",
      "Run 221 out of 500\n",
      "Run 222 out of 500\n",
      "Run 223 out of 500\n",
      "Run 224 out of 500\n",
      "Run 225 out of 500\n",
      "Run 226 out of 500\n",
      "Run 227 out of 500\n",
      "Run 228 out of 500\n",
      "Run 229 out of 500\n",
      "Run 230 out of 500\n",
      "Run 231 out of 500\n",
      "Run 232 out of 500\n",
      "Run 233 out of 500\n",
      "Run 234 out of 500\n",
      "Run 235 out of 500\n",
      "Run 236 out of 500\n",
      "Run 237 out of 500\n",
      "Run 238 out of 500\n",
      "Run 239 out of 500\n",
      "Run 240 out of 500\n",
      "Run 241 out of 500\n",
      "Run 242 out of 500\n",
      "Run 243 out of 500\n",
      "Run 244 out of 500\n",
      "Run 245 out of 500\n",
      "Run 246 out of 500\n",
      "Run 247 out of 500\n",
      "Run 248 out of 500\n",
      "Run 249 out of 500\n",
      "Run 250 out of 500\n",
      "Run 251 out of 500\n",
      "Run 252 out of 500\n",
      "Run 253 out of 500\n",
      "Run 254 out of 500\n",
      "Run 255 out of 500\n",
      "Run 256 out of 500\n",
      "Run 257 out of 500\n",
      "Run 258 out of 500\n",
      "Run 259 out of 500\n",
      "Run 260 out of 500\n",
      "Run 261 out of 500\n",
      "Run 262 out of 500\n",
      "Run 263 out of 500\n",
      "Run 264 out of 500\n",
      "Run 265 out of 500\n",
      "Run 266 out of 500\n",
      "Run 267 out of 500\n",
      "Run 268 out of 500\n",
      "Run 269 out of 500\n",
      "Run 270 out of 500\n",
      "Run 271 out of 500\n",
      "Run 272 out of 500\n",
      "Run 273 out of 500\n",
      "Run 274 out of 500\n",
      "Run 275 out of 500\n",
      "Run 276 out of 500\n",
      "Run 277 out of 500\n",
      "Run 278 out of 500\n",
      "Run 279 out of 500\n",
      "Run 280 out of 500\n",
      "Run 281 out of 500\n",
      "Run 282 out of 500\n",
      "Run 283 out of 500\n",
      "Run 284 out of 500\n",
      "Run 285 out of 500\n",
      "Run 286 out of 500\n",
      "Run 287 out of 500\n",
      "Run 288 out of 500\n",
      "Run 289 out of 500\n",
      "Run 290 out of 500\n",
      "Run 291 out of 500\n",
      "Run 292 out of 500\n",
      "Run 293 out of 500\n",
      "Run 294 out of 500\n",
      "Run 295 out of 500\n",
      "Run 296 out of 500\n",
      "Run 297 out of 500\n",
      "Run 298 out of 500\n",
      "Run 299 out of 500\n",
      "Run 300 out of 500\n",
      "Run 301 out of 500\n",
      "Run 302 out of 500\n",
      "Run 303 out of 500\n",
      "Run 304 out of 500\n",
      "Run 305 out of 500\n",
      "Run 306 out of 500\n",
      "Run 307 out of 500\n",
      "Run 308 out of 500\n",
      "Run 309 out of 500\n",
      "Run 310 out of 500\n",
      "Run 311 out of 500\n",
      "Run 312 out of 500\n",
      "Run 313 out of 500\n",
      "Run 314 out of 500\n",
      "Run 315 out of 500\n",
      "Run 316 out of 500\n",
      "Run 317 out of 500\n",
      "Run 318 out of 500\n",
      "Run 319 out of 500\n",
      "Run 320 out of 500\n",
      "Run 321 out of 500\n",
      "Run 322 out of 500\n",
      "Run 323 out of 500\n",
      "Run 324 out of 500\n",
      "Run 325 out of 500\n",
      "Run 326 out of 500\n",
      "Run 327 out of 500\n",
      "Run 328 out of 500\n",
      "Run 329 out of 500\n",
      "Run 330 out of 500\n",
      "Run 331 out of 500\n",
      "Run 332 out of 500\n",
      "Run 333 out of 500\n",
      "Run 334 out of 500\n",
      "Run 335 out of 500\n",
      "Run 336 out of 500\n",
      "Run 337 out of 500\n",
      "Run 338 out of 500\n",
      "Run 339 out of 500\n",
      "Run 340 out of 500\n",
      "Run 341 out of 500\n",
      "Run 342 out of 500\n",
      "Run 343 out of 500\n",
      "Run 344 out of 500\n",
      "Run 345 out of 500\n",
      "Run 346 out of 500\n",
      "Run 347 out of 500\n",
      "Run 348 out of 500\n",
      "Run 349 out of 500\n",
      "Run 350 out of 500\n",
      "Run 351 out of 500\n",
      "Run 352 out of 500\n",
      "Run 353 out of 500\n",
      "Run 354 out of 500\n",
      "Run 355 out of 500\n",
      "Run 356 out of 500\n",
      "Run 357 out of 500\n",
      "Run 358 out of 500\n",
      "Run 359 out of 500\n",
      "Run 360 out of 500\n",
      "Run 361 out of 500\n",
      "Run 362 out of 500\n",
      "Run 363 out of 500\n",
      "Run 364 out of 500\n",
      "Run 365 out of 500\n",
      "Run 366 out of 500\n",
      "Run 367 out of 500\n",
      "Run 368 out of 500\n",
      "Run 369 out of 500\n",
      "Run 370 out of 500\n",
      "Run 371 out of 500\n",
      "Run 372 out of 500\n",
      "Run 373 out of 500\n",
      "Run 374 out of 500\n",
      "Run 375 out of 500\n",
      "Run 376 out of 500\n",
      "Run 377 out of 500\n",
      "Run 378 out of 500\n",
      "Run 379 out of 500\n",
      "Run 380 out of 500\n",
      "Run 381 out of 500\n",
      "Run 382 out of 500\n",
      "Run 383 out of 500\n",
      "Run 384 out of 500\n",
      "Run 385 out of 500\n",
      "Run 386 out of 500\n",
      "Run 387 out of 500\n",
      "Run 388 out of 500\n",
      "Run 389 out of 500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 390 out of 500\n",
      "Run 391 out of 500\n",
      "Run 392 out of 500\n",
      "Run 393 out of 500\n",
      "Run 394 out of 500\n",
      "Run 395 out of 500\n",
      "Run 396 out of 500\n",
      "Run 397 out of 500\n",
      "Run 398 out of 500\n",
      "Run 399 out of 500\n",
      "Run 400 out of 500\n",
      "Run 401 out of 500\n",
      "Run 402 out of 500\n",
      "Run 403 out of 500\n",
      "Run 404 out of 500\n",
      "Run 405 out of 500\n",
      "Run 406 out of 500\n",
      "Run 407 out of 500\n",
      "Run 408 out of 500\n",
      "Run 409 out of 500\n",
      "Run 410 out of 500\n",
      "Run 411 out of 500\n",
      "Run 412 out of 500\n",
      "Run 413 out of 500\n",
      "Run 414 out of 500\n",
      "Run 415 out of 500\n",
      "Run 416 out of 500\n",
      "Run 417 out of 500\n",
      "Run 418 out of 500\n",
      "Run 419 out of 500\n",
      "Run 420 out of 500\n",
      "Run 421 out of 500\n",
      "Run 422 out of 500\n",
      "Run 423 out of 500\n",
      "Run 424 out of 500\n",
      "Run 425 out of 500\n",
      "Run 426 out of 500\n",
      "Run 427 out of 500\n",
      "Run 428 out of 500\n",
      "Run 429 out of 500\n",
      "Run 430 out of 500\n",
      "Run 431 out of 500\n",
      "Run 432 out of 500\n",
      "Run 433 out of 500\n",
      "Run 434 out of 500\n",
      "Run 435 out of 500\n",
      "Run 436 out of 500\n",
      "Run 437 out of 500\n",
      "Run 438 out of 500\n",
      "Run 439 out of 500\n",
      "Run 440 out of 500\n",
      "Run 441 out of 500\n",
      "Run 442 out of 500\n",
      "Run 443 out of 500\n",
      "Run 444 out of 500\n",
      "Run 445 out of 500\n",
      "Run 446 out of 500\n",
      "Run 447 out of 500\n",
      "Run 448 out of 500\n",
      "Run 449 out of 500\n",
      "Run 450 out of 500\n",
      "Run 451 out of 500\n",
      "Run 452 out of 500\n",
      "Run 453 out of 500\n",
      "Run 454 out of 500\n",
      "Run 455 out of 500\n",
      "Run 456 out of 500\n",
      "Run 457 out of 500\n",
      "Run 458 out of 500\n",
      "Run 459 out of 500\n",
      "Run 460 out of 500\n",
      "Run 461 out of 500\n",
      "Run 462 out of 500\n",
      "Run 463 out of 500\n",
      "Run 464 out of 500\n",
      "Run 465 out of 500\n",
      "Run 466 out of 500\n",
      "Run 467 out of 500\n",
      "Run 468 out of 500\n",
      "Run 469 out of 500\n",
      "Run 470 out of 500\n",
      "Run 471 out of 500\n",
      "Run 472 out of 500\n",
      "Run 473 out of 500\n",
      "Run 474 out of 500\n",
      "Run 475 out of 500\n",
      "Run 476 out of 500\n",
      "Run 477 out of 500\n",
      "Run 478 out of 500\n",
      "Run 479 out of 500\n",
      "Run 480 out of 500\n",
      "Run 481 out of 500\n",
      "Run 482 out of 500\n",
      "Run 483 out of 500\n",
      "Run 484 out of 500\n",
      "Run 485 out of 500\n",
      "Run 486 out of 500\n",
      "Run 487 out of 500\n",
      "Run 488 out of 500\n",
      "Run 489 out of 500\n",
      "Run 490 out of 500\n",
      "Run 491 out of 500\n",
      "Run 492 out of 500\n",
      "Run 493 out of 500\n",
      "Run 494 out of 500\n",
      "Run 495 out of 500\n",
      "Run 496 out of 500\n",
      "Run 497 out of 500\n",
      "Run 498 out of 500\n",
      "Run 499 out of 500\n",
      "Run 0 out of 500\n"
     ]
    },
    {
     "ename": "ValueError",
     "evalue": "df <= 0",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[3], line 18\u001b[0m\n\u001b[0;32m     16\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m tar \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;241m6\u001b[39m):\n\u001b[0;32m     17\u001b[0m     dataY\u001b[38;5;241m=\u001b[39m[X[\u001b[38;5;241m499\u001b[39m\u001b[38;5;241m+\u001b[39mi\u001b[38;5;241m*\u001b[39mn\u001b[38;5;241m+\u001b[39m\u001b[38;5;241m1\u001b[39m:\u001b[38;5;241m499\u001b[39m\u001b[38;5;241m+\u001b[39m(i\u001b[38;5;241m+\u001b[39m\u001b[38;5;241m1\u001b[39m)\u001b[38;5;241m*\u001b[39mn\u001b[38;5;241m+\u001b[39m\u001b[38;5;241m1\u001b[39m,tar] \u001b[38;5;28;01mfor\u001b[39;00m i \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(E)]\n\u001b[1;32m---> 18\u001b[0m     plausibleS\u001b[38;5;241m=\u001b[39mloli\u001b[38;5;241m.\u001b[39mgauss(dataX,dataY,alpha\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0.1\u001b[39m,B\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m500\u001b[39m)\n\u001b[0;32m     19\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mlen\u001b[39m(plausibleS)\u001b[38;5;241m==\u001b[39m\u001b[38;5;241m0\u001b[39m:\n\u001b[0;32m     20\u001b[0m         supphat\u001b[38;5;241m=\u001b[39m\u001b[38;5;28mset\u001b[39m()\n",
      "File \u001b[1;32m~\\OneDrive - TU Eindhoven\\Documents\\Github\\causal-local-linear\\MainAlgo\\loli.py:31\u001b[0m, in \u001b[0;36mgauss\u001b[1;34m(x, y, B, l, alpha, lam, rs, intercept, pvalues)\u001b[0m\n\u001b[0;32m     29\u001b[0m m\u001b[38;5;241m=\u001b[39m\u001b[38;5;28mlen\u001b[39m(ind)\u001b[38;5;241m+\u001b[39mintercept\n\u001b[0;32m     30\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m (n,\u001b[38;5;241m0\u001b[39m) \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;129;01min\u001b[39;00m Simulations:\n\u001b[1;32m---> 31\u001b[0m     Simulations[(i,n,intercept\u001b[38;5;241m+\u001b[39md)]\u001b[38;5;241m=\u001b[39m(np\u001b[38;5;241m.\u001b[39mrandom\u001b[38;5;241m.\u001b[39mchisquare(n\u001b[38;5;241m-\u001b[39md\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,B))\n\u001b[0;32m     32\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m q \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;241m1\u001b[39m,intercept\u001b[38;5;241m+\u001b[39md):\n\u001b[0;32m     33\u001b[0m         Simulations[(i,n,intercept\u001b[38;5;241m+\u001b[39md\u001b[38;5;241m-\u001b[39mq)]\u001b[38;5;241m=\u001b[39mSimulations[(i,n,intercept\u001b[38;5;241m+\u001b[39md\u001b[38;5;241m-\u001b[39mq\u001b[38;5;241m+\u001b[39m\u001b[38;5;241m1\u001b[39m)]\u001b[38;5;241m+\u001b[39m(np\u001b[38;5;241m.\u001b[39mrandom\u001b[38;5;241m.\u001b[39mnormal(size\u001b[38;5;241m=\u001b[39m(B)))\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m2\u001b[39m\n",
      "File \u001b[1;32mmtrand.pyx:1964\u001b[0m, in \u001b[0;36mnumpy.random.mtrand.RandomState.chisquare\u001b[1;34m()\u001b[0m\n",
      "File \u001b[1;32m_common.pyx:612\u001b[0m, in \u001b[0;36mnumpy.random._common.cont\u001b[1;34m()\u001b[0m\n",
      "File \u001b[1;32m_common.pyx:427\u001b[0m, in \u001b[0;36mnumpy.random._common.check_constraint\u001b[1;34m()\u001b[0m\n",
      "\u001b[1;31mValueError\u001b[0m: df <= 0"
     ]
    }
   ],
   "source": [
    "# Running our algorithm on the Lorenz data\n",
    "\n",
    "rs=1\n",
    "np.random.seed(rs)\n",
    "size=8500 # The size of the generated dataset\n",
    "E=300 # The number of environments\n",
    "runs=500 # How often we repeat the experiment \n",
    "results={}\n",
    "for n in [20,25]:  # n is the sample size (length of the interval)\n",
    "    for tar in range(6):\n",
    "        results[tar]={}\n",
    "    for j in range(runs):\n",
    "        print('Run',j,'out of',runs)\n",
    "        X=lordata_gen(size)\n",
    "        dataX=[X[499+i*n:499+(i+1)*n,:] for i in range(E)]\n",
    "        for tar in range(6):\n",
    "            dataY=[X[499+i*n+1:499+(i+1)*n+1,tar] for i in range(E)]\n",
    "            plausibleS=loli.gauss(dataX,dataY,alpha=0.1,B=500)\n",
    "            if len(plausibleS)==0:\n",
    "                supphat=set()\n",
    "            else:\n",
    "                supphat=set.intersection(*plausibleS)\n",
    "            if tuple(supphat) in results[tar]:\n",
    "                results[tar][tuple(supphat)]+=1\n",
    "            else:\n",
    "                results[tar][tuple(supphat)]=1\n",
    "\n",
    "    with open('LorenzGenResultsE='+str(E)+'N='+str(n)+'.pkl','wb') as f:\n",
    "        pickle.dump(results, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c621550c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Showing the results, different rows correspond to different targets and different columns to the potential causal parents\n",
    "\n",
    "E=300\n",
    "for n in [20,25]:\n",
    "    with open('LorenzGenResultsE='+str(E)+'N='+str(n)+'.pkl','rb') as f:\n",
    "        Lorenz=pickle.load(f)\n",
    "    \n",
    "    \n",
    "    final=np.zeros((6,6))\n",
    "    for tar in range(6):\n",
    "        for key in Lorenz[tar]:\n",
    "            for var in range(6):\n",
    "                if var in key:\n",
    "                    final[tar,var]+=Lorenz[tar][key]\n",
    "    print('Raw counts for n=',n)\n",
    "    print(final)\n",
    "    pvals=np.zeros((6,6))\n",
    "    for i in range(6):\n",
    "        for j in range(6):\n",
    "            test=binomtest(np.int32(final[i,j]),500,0.1,alternative='greater')\n",
    "            pvals[i,j]=test.pvalue\n",
    "    print('Maxtrix of causal parents for n=',n)\n",
    "    print(pvals<0.05)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c1115c8d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Alternatively we can directly load the results from the saved file\n",
    "\n",
    "E=300\n",
    "for n in [20,25]:\n",
    "    with open('SavedResults/LorenzData/LorenzGenResultsE='+str(E)+'N='+str(n)+'.pkl','rb') as f:\n",
    "        Lorenz=pickle.load(f)\n",
    "    \n",
    "    \n",
    "    final=np.zeros((6,6))\n",
    "    for tar in range(6):\n",
    "        for key in Lorenz[tar]:\n",
    "            for var in range(6):\n",
    "                if var in key:\n",
    "                    final[tar,var]+=Lorenz[tar][key]\n",
    "    print('Raw counts for n=',n)\n",
    "    print(final)\n",
    "    pvals=np.zeros((6,6))\n",
    "    for i in range(6):\n",
    "        for j in range(6):\n",
    "            test=binomtest(np.int32(final[i,j]),500,0.1,alternative='greater')\n",
    "            pvals[i,j]=test.pvalue\n",
    "    print('Maxtrix of causal parents for n=',n)\n",
    "    print(pvals<0.05)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5e32a9e4",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
