{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "3e949259",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{0: array([[2., 1., 0.],\n",
      "       [0., 2., 1.],\n",
      "       [1., 0., 2.]]), 1: array([[0. , 1.1, 2.2],\n",
      "       [2.4, 0. , 1.2],\n",
      "       [1.3, 2.6, 0. ]])}\n",
      "True\n",
      "True\n",
      "True\n",
      "True\n",
      "True\n",
      "True\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[0.11940298507462677, 0.08142493638676862, 0.13231552162849863]"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "# Input Probability Table\n",
    "def prob_table(alphas, betas, gammas):\n",
    "    greeks = [alphas, betas, gammas]\n",
    "    p = dict()\n",
    "    p[0] = np.zeros((3,3))\n",
    "    p[1] = np.zeros((3,3))\n",
    "    t=0\n",
    "    for x in range(3):\n",
    "        for y in range(3):\n",
    "            p[t][x, y] = greeks[x][t] * ((2 - y + x) % 3)\n",
    "    t=1\n",
    "    for x in range(3):\n",
    "        for y in range(3):\n",
    "            p[t][x, y] = greeks[x][t] * ((y - x) % 3)\n",
    "    return p\n",
    "\n",
    "\n",
    "def ACEs(p):\n",
    "    results = []\n",
    "    for y in range(3):\n",
    "        # Compute causal effect for y and y+1 mod 3\n",
    "        y2 = (y + 1) % 3\n",
    "        total = 0\n",
    "        sumx = []\n",
    "        for x in range(3):\n",
    "            sumx.append(sum([p[0][x, y] for y in [y, y2]]) + sum([p[1][x, y] for y in [y, y2]]))\n",
    "            total += sumx[x]\n",
    "        do_t_0 = 0\n",
    "        do_t_1 = 0\n",
    "        for x in range(3):\n",
    "            probx = sumx[x]/total\n",
    "            do_t_0 += probx * (p[0][x, y] / (p[0][x, y] + p[0][x, y2]))\n",
    "            do_t_1 += probx * (p[1][x, y] / (p[1][x, y] + p[1][x, y2]))\n",
    "        ACE = do_t_0 - do_t_1\n",
    "        results.append(ACE)\n",
    "    return results\n",
    "\n",
    "# T not independent of Y\n",
    "def Condition1(p):\n",
    "    result = False\n",
    "    for y in range(3):\n",
    "        condition = sum([p[0][x, y] for x in range(3)]) != sum([p[1][x, y] for x in range(3)])\n",
    "        result = result or condition\n",
    "    return result\n",
    "\n",
    "# X not independent of Y\n",
    "def Condition2(p):\n",
    "    result = False\n",
    "    for y in range(3):\n",
    "        condition = (sum([p[t][0, y] for t in range(2)]) != sum([p[t][1, y] for t in range(2)])) or (sum([p[t][1, y] for t in range(2)]) != sum([p[t][2, y] for t in range(2)]))\n",
    "        result = result or condition\n",
    "    return result\n",
    "\n",
    "# T not independent of X\n",
    "def Condition3(p):\n",
    "    result = False\n",
    "    for x in range(3):\n",
    "        condition = sum([p[0][x, y] for y in range(3)]) != sum([p[1][x, y] for y in range(3)])\n",
    "        result = result or condition\n",
    "    return result\n",
    "\n",
    "# T not independent of Y given X\n",
    "def Condition4(p):\n",
    "    result = False\n",
    "    for y in range(3):\n",
    "        for x in range(3):\n",
    "            condition = p[0][x, y] != p[1][x, y]\n",
    "            result = result or condition\n",
    "    return result\n",
    "\n",
    "# X not independent of Y given T\n",
    "def Condition5(p):\n",
    "    result = False\n",
    "    for y in range(3):\n",
    "        for t in range(2):\n",
    "            condition = p[t][0, y] != p[t][1, y] or p[t][1, y] != p[t][2, y]\n",
    "            result = result or condition\n",
    "    return result\n",
    "\n",
    "# T not independent of X given Y\n",
    "def Condition6(p):\n",
    "    result = False\n",
    "    for x in range(3):\n",
    "        for y in range(3):\n",
    "            condition = p[0][x, y] != p[1][x, y]\n",
    "            result = result or condition\n",
    "    return result\n",
    "\n",
    "p = prob_table([1, 1.1], [1, 1.2], [1, 1.3])\n",
    "print(p)\n",
    "print(Condition1(p))\n",
    "print(Condition2(p))\n",
    "print(Condition3(p))\n",
    "print(Condition4(p))\n",
    "print(Condition5(p))\n",
    "print(Condition6(p))\n",
    "ACEs(p)\n",
    "            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bbfc2791",
   "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.9.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
