{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_graph = []\n",
    "test_fact = []\n",
    "G1 = set()\n",
    "G2 = set()\n",
    "#../../GraIL-BM_fb237_v2/test/\n",
    "dataset = '.'\n",
    "relations_TG1 = set()\n",
    "relations_TG2 = set()\n",
    "relations_G1 = set()\n",
    "relations_G2 = set()\n",
    "for line in open('{}/aux'.format(dataset)):\n",
    "    t = line.strip().split('\\t')\n",
    "    if t[1] != '<http://www.w3.org/1999/02/22-rdf-syntax-ns#type>':\n",
    "        test_graph.append(t)\n",
    "        if (t[0], t[1], t[2]) not in G1:\n",
    "            G1.add((t[0], t[1], t[2]))\n",
    "        if (t[0], t[1], t[2]) not in G2:\n",
    "            G2.add((t[0], t[1], t[2]))\n",
    "    if t[1] != '<http://www.w3.org/1999/02/22-rdf-syntax-ns#type>':\n",
    "        relations_TG1.add(t[1])\n",
    "        relations_G1.add(t[1])\n",
    "        relations_G2.add(t[1])\n",
    "for line in open('{}/test'.format(dataset)):\n",
    "    t = line.strip().split('\\t')\n",
    "    if t [-1] == '1':\n",
    "        if t[1] != '<http://www.w3.org/1999/02/22-rdf-syntax-ns#type>':\n",
    "            test_fact.append(t)\n",
    "            if (t[0], t[1], t[2]) not in G2:\n",
    "                G2.add((t[0], t[1], t[2]))\n",
    "        if t[1] != '<http://www.w3.org/1999/02/22-rdf-syntax-ns#type>':\n",
    "            relations_TG2.add(t[1])\n",
    "            relations_G2.add(t[1])\n",
    "relations_TG1 = list(relations_TG1)\n",
    "relations_TG2 = list(relations_TG2)\n",
    "relations_G1 = list(relations_G1)\n",
    "relations_G2 = list(relations_G2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "pairs_for_relation_G1 = dict([(i,set()) for i in relations_G1])\n",
    "pairs_for_relation_G2 = dict([(i,set()) for i in relations_G2])\n",
    "for t in G1:\n",
    "    pairs_for_relation_G1[t[1]].add((t[0],t[2]))\n",
    "for t in G2:\n",
    "    pairs_for_relation_G2[t[1]].add((t[0],t[2]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# subsumption of relations: R(x,y) --> S(x,y) confidence_subsumption[i][j] = j->i\n",
    "import numpy as np\n",
    "f = open('pattern1.txt',\"w+\")\n",
    "confidence_subsumption = np.zeros((len(relations_TG2), len(relations_TG1)))\n",
    "for i in range(len(relations_TG2)):\n",
    "    #print('\\rchecking {}-th relation'.format(str(i)),end='')\n",
    "    s = relations_TG2[i]\n",
    "    for j in range(len(relations_TG1)):\n",
    "        r = relations_TG1[j]\n",
    "        if s != r:\n",
    "            #computing N\n",
    "            N = len(pairs_for_relation_G1[r])\n",
    "            #print(pairs_for_relation_G1[r]) \n",
    "            M = 0\n",
    "            for pair in pairs_for_relation_G1[r]:\n",
    "                if pair in pairs_for_relation_G2[s]:\n",
    "                    M += 1\n",
    "\n",
    "            confidence_subsumption[i][j] = M / N\n",
    "            if confidence_subsumption[i][j] >= 0.2:\n",
    "                #print(r, s)\n",
    "                #print(M/N)\n",
    "                f.write('{}\\t{}\\t{}\\n'.format(str(M/N), r, s))\n",
    "f.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checking 11-th relation8.483896732330322\n"
     ]
    }
   ],
   "source": [
    "# transive relations: R(x,y), R(y,z) -> R(x,z) confidence_subsumption[i][i] = i -> i\n",
    "def compute_N(relation, G):\n",
    "    curr_N = 0\n",
    "    curr_XZ = set()\n",
    "    for p1 in pairs_for_relation_G1[relation]:\n",
    "        for p2 in pairs_for_relation_G1[relation]:\n",
    "            if p1 != p2:\n",
    "                if p1[1] == p2[0]:\n",
    "                    if (p1[0], p2[1]) not in curr_XZ:\n",
    "                        curr_N += 1\n",
    "                        curr_XZ.add((p1[0], p2[1]))\n",
    "    return curr_N, curr_XZ\n",
    "\n",
    "import time\n",
    "time1 = time.time()\n",
    "N_for_r = dict([(i,0) for i in relations_TG1])\n",
    "XZ_for_r = dict([(i,set()) for i in relations_TG1])\n",
    "i = 0 \n",
    "for r in relations_TG1:\n",
    "    i += 1\n",
    "    print('\\rchecking {}-th relation'.format(str(i)),end='')\n",
    "    N, XZ = compute_N(r, G1)\n",
    "    N_for_r[r] = N\n",
    "    XZ_for_r[r] = XZ\n",
    "print(time.time() - time1)\n",
    "\n",
    "# transive relations: R(x,y), R(y,z) -> R(x,z) confidence_subsumption[i][i] = i -> i\n",
    "import numpy as np\n",
    "f = open('pattern2.txt',\"w+\")\n",
    "confidence_subsumption = np.zeros((len(relations_TG2), len(relations_TG1)))\n",
    "for i in range(len(relations_TG2)):\n",
    "    #print('\\rchecking {}-th relation'.format(str(i)),end='')\n",
    "    s = relations_TG2[i]\n",
    "    for j in range(len(relations_TG1)):\n",
    "        r = relations_TG1[j]\n",
    "        if r == s:\n",
    "            #computing N\n",
    "            N = N_for_r[r]\n",
    "            XZ = XZ_for_r[r]\n",
    "            #print(pairs_for_relation_G1[r]) \n",
    "            M = 0\n",
    "            for pair in pairs_for_relation_G2[r]:\n",
    "                if pair in XZ:\n",
    "                    M += 1\n",
    "            if N == 0:\n",
    "                continue\n",
    "            confidence_subsumption[i][j] = M / N\n",
    "            \n",
    "            if confidence_subsumption[i][j] >= 0.5:\n",
    "                print(r, s)\n",
    "                print(M/N)\n",
    "                f.write('{}\\t{}\\t{}\\n'.format(str(M/N), r, s))\n",
    "f.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# R(x,y) -> R(y,x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7\n",
      "0.9090909090909091\n"
     ]
    }
   ],
   "source": [
    "f = open('pattern3.txt',\"w+\")\n",
    "for i in range(len(relations_TG2)):\n",
    "    #print('\\rchecking {}-th relation'.format(str(i)),end='')\n",
    "    s = relations_TG2[i]\n",
    "    for j in range(len(relations_TG1)):\n",
    "        r = relations_TG1[j]\n",
    "        if s == r:\n",
    "            N = len(pairs_for_relation_G1[r])\n",
    "            #print(pairs_for_relation_G1[r]) \n",
    "            M = 0\n",
    "            for pair in pairs_for_relation_G1[r]:\n",
    "                if (pair[1], pair[0]) in pairs_for_relation_G2[s]:\n",
    "                    M += 1\n",
    "\n",
    "            confidence = M / N\n",
    "            if confidence >= 0.5:\n",
    "                print(r)\n",
    "                print(M/N)\n",
    "                f.write('{}\\t{}\\n'.format(str(confidence), r))\n",
    "f.close()            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checking 11-th relation35.61106896400452\n"
     ]
    }
   ],
   "source": [
    "rs_list = []\n",
    "for r in relations_TG1:\n",
    "    for s in relations_TG1:\n",
    "        rs_list.append((r,s))\n",
    "def compute_N_for_rs(r, s, G):\n",
    "    curr_N = 0\n",
    "    curr_XZ = set()\n",
    "    for p1 in pairs_for_relation_G1[r]:\n",
    "        for p2 in pairs_for_relation_G1[s]:\n",
    "            if p1[1] == p2[0]:\n",
    "                if (p1[0], p2[1]) not in curr_XZ:\n",
    "                    curr_N += 1\n",
    "                    curr_XZ.add((p1[0], p2[1]))\n",
    "    return curr_N, curr_XZ\n",
    "\n",
    "import time\n",
    "time1 = time.time()\n",
    "N_for_rs = dict([(i,0) for i in rs_list])\n",
    "XZ_for_rs = dict([(i,set()) for i in rs_list])\n",
    "i = 0 \n",
    "for r in relations_TG1:\n",
    "    i += 1\n",
    "    print('\\rchecking {}-th relation'.format(str(i)),end='')\n",
    "    for s in relations_TG1:\n",
    "        N, XZ = compute_N_for_rs(r, s, G1)\n",
    "        N_for_rs[(r,s)] = N\n",
    "        XZ_for_rs[(r,s)] = XZ\n",
    "print(time.time() - time1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checking 10-th relation"
     ]
    }
   ],
   "source": [
    "# chains: R(x,y), S(y,z) -> T(x,z) \n",
    "import numpy as np\n",
    "f = open('pattern4.txt',\"w+\")\n",
    "#confidence_subsumption = np.zeros((len(relations_TG2), len(relations_TG1)))\n",
    "for i in range(len(relations_TG2)):\n",
    "    print('\\rchecking {}-th relation'.format(str(i)),end='')\n",
    "    t = relations_TG2[i]\n",
    "    for j in range(len(relations_TG1)):\n",
    "        r = relations_TG1[j]\n",
    "        for k in range(len(relations_TG1)):\n",
    "            s = relations_TG1[k]\n",
    "            \n",
    "            #computing N\n",
    "            N = N_for_rs[(r,s)]\n",
    "            XZ = XZ_for_rs[(r,s)]\n",
    "            #print(pairs_for_relation_G1[r]) \n",
    "            M = 0\n",
    "            for pair in pairs_for_relation_G2[t]:\n",
    "                if pair in XZ:\n",
    "                    M += 1\n",
    "            if N == 0:\n",
    "                continue\n",
    "            confidence_subsumption[i][j] = M / N\n",
    "\n",
    "            if confidence_subsumption[i][j] >= 0.5:\n",
    "                #print(s, r, t)\n",
    "                #print(M/N)\n",
    "                f.write('{}\\t{}\\t{}\\t{}\\n'.format(str(M/N), s,r,t))\n",
    "f.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checking 11-th relation35.94091176986694\n"
     ]
    }
   ],
   "source": [
    "rs_list = []\n",
    "for r in relations_TG1:\n",
    "    for s in relations_TG1:\n",
    "        rs_list.append((r,s))\n",
    "def compute_N_for_rs_same(r, s, G):\n",
    "    curr_N = 0\n",
    "    curr_XY = set()\n",
    "    for p1 in pairs_for_relation_G1[r]:\n",
    "        for p2 in pairs_for_relation_G1[s]:\n",
    "            if p1[0] == p2[0]:\n",
    "                if p1[1] == p2[1]:\n",
    "                    if (p1[0], p1[1]) not in curr_XY:\n",
    "                        curr_N += 1\n",
    "                        curr_XY.add((p1[0], p1[1]))\n",
    "    return curr_N, curr_XY\n",
    "\n",
    "import time\n",
    "time1 = time.time()\n",
    "N_for_rs_same = dict([(i,0) for i in rs_list])\n",
    "XY_for_rs_same = dict([(i,set()) for i in rs_list])\n",
    "i = 0 \n",
    "for r in relations_TG1:\n",
    "    i += 1\n",
    "    print('\\rchecking {}-th relation'.format(str(i)),end='')\n",
    "    for s in relations_TG1:\n",
    "        N, XY = compute_N_for_rs_same(r, s, G1)\n",
    "        N_for_rs_same[(r,s)] = N\n",
    "        XY_for_rs_same[(r,s)] = XY\n",
    "print(time.time() - time1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "#R(x,y) , S(x,y) -> T(x,y)\n",
    "f = open('pattern5.txt',\"w+\")\n",
    "#confidence_subsumption = np.zeros((len(relations_TG2), len(relations_TG1)))\n",
    "for i in range(len(relations_TG2)):\n",
    "    #print('\\rchecking {}-th relation'.format(str(i)),end='')\n",
    "    t = relations_TG2[i]\n",
    "    for j in range(len(relations_TG1)):\n",
    "        r = relations_TG1[j]\n",
    "        for k in range(len(relations_TG1)):\n",
    "            \n",
    "                s = relations_TG1[k]\n",
    "                if s !=r and s != t and r != t:\n",
    "                    N = N_for_rs_same[(r,s)]\n",
    "                    XY = XY_for_rs_same[(r,s)]\n",
    "                    M = 0\n",
    "                    for pair in pairs_for_relation_G2[t]:\n",
    "                        if pair in XY:\n",
    "                            M += 1\n",
    "                        #print(pair)\n",
    "                    if N == 0:\n",
    "                        continue\n",
    "                    confidence_subsumption[i][j] = M / N\n",
    "\n",
    "                    if confidence_subsumption[i][j] > 0.5:\n",
    "                        print(s, r, t)\n",
    "                        print(M/N)\n",
    "                        f.write('{}\\t{}\\t{}\\t{}\\n'.format(str(M/N), s,r,t))\n",
    "f.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: './test-graph.txt'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-15-93c9260b374b>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0mG1_type_triples\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mset\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      6\u001b[0m \u001b[0mG2_type_triples\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mset\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 7\u001b[0;31m \u001b[0;32mfor\u001b[0m \u001b[0mline\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mopen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'{}/test-graph.txt'\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      8\u001b[0m     \u001b[0mt\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mline\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstrip\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msplit\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'\\t'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      9\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mt\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;34m'<http://www.w3.org/1999/02/22-rdf-syntax-ns#type>'\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: './test-graph.txt'"
     ]
    }
   ],
   "source": [
    "types_G1 = set()\n",
    "types_G2 = set()\n",
    "types_TG1 = set()\n",
    "types_TG2 = set()\n",
    "G1_type_triples = set()\n",
    "G2_type_triples = set()\n",
    "for line in open('{}/aux'.format(dataset)):\n",
    "    t = line.strip().split('\\t')\n",
    "    if t[1] == '<http://www.w3.org/1999/02/22-rdf-syntax-ns#type>':\n",
    "        types_G1.add(t[2])\n",
    "        #types_G2.add(t[2])\n",
    "        types_TG1.add(t[2])\n",
    "        G1_type_triples.add((t[0], t[1], t[2]))\n",
    "        #G2_type_triples.add((t[0], t[1], t[2]))\n",
    "for line in open('{}/test'.format(dataset)):\n",
    "    t = line.strip().split('\\t')\n",
    "    if t[1] == '<http://www.w3.org/1999/02/22-rdf-syntax-ns#type>':\n",
    "        types_G2.add(t[2])\n",
    "        types_TG2.add(t[2])\n",
    "        G2_type_triples.add((t[0], t[1], t[2]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# A(x) -> B(x)\n",
    "#Type(a, A) -> Type(a, B)\n",
    "f = open('pattern6.txt',\"w+\")\n",
    "entities_for_type_G1 = dict([(i,set()) for i in types_G1])\n",
    "for t in G1_type_triples:\n",
    "    if t[1] == '<http://www.w3.org/1999/02/22-rdf-syntax-ns#type>':\n",
    "        entities_for_type_G1[t[2]].add(t[0])\n",
    "entities_for_type_G2 = dict([(i,set()) for i in types_G2])\n",
    "for t in G2_type_triples:\n",
    "    if t[1] == '<http://www.w3.org/1999/02/22-rdf-syntax-ns#type>':\n",
    "        entities_for_type_G2[t[2]].add(t[0])   \n",
    "for b in types_TG2:\n",
    "    \n",
    "    for a in types_TG1:\n",
    "        if a != b:\n",
    "            M = 0\n",
    "            N = len(entities_for_type_G1[a])\n",
    "            for entity in entities_for_type_G2[b]:\n",
    "                if entity in entities_for_type_G1[a]:\n",
    "                    M += 1\n",
    "            if N == 0:\n",
    "                    continue\n",
    "            if M/N > 0.5:\n",
    "                f.write('{}\\t{}\\t{}\\n'.format(str(M/N), a,b))\n",
    "f.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "# A1(x), A2(x) -> B(x)\n",
    "#Type(a, A) -> Type(a, B)\n",
    "f = open('pattern7.txt',\"w+\")\n",
    "entities_for_type_G1 = dict([(i,set()) for i in types_G1])\n",
    "for t in G1_type_triples:\n",
    "    if t[1] == '<http://www.w3.org/1999/02/22-rdf-syntax-ns#type>':\n",
    "        entities_for_type_G1[t[2]].add(t[0])\n",
    "entities_for_type_G2 = dict([(i,set()) for i in types_G2])\n",
    "for t in G2_type_triples:\n",
    "    if t[1] == '<http://www.w3.org/1999/02/22-rdf-syntax-ns#type>':\n",
    "        entities_for_type_G2[t[2]].add(t[0])   \n",
    "for b in types_TG2:\n",
    "    \n",
    "    for a1 in types_TG1:\n",
    "        for a2 in types_TG1:\n",
    "            if a1 != a2 and a1 != b and a2!=b:\n",
    "                M = 0\n",
    "                entities_a1_a2 = entities_for_type_G1[a1] & entities_for_type_G1[a2]\n",
    "                N = len(entities_a1_a2)\n",
    "                for entity in entities_for_type_G2[b]:\n",
    "                    if entity in entities_a1_a2:\n",
    "                        M += 1\n",
    "                if N == 0:\n",
    "                        continue\n",
    "                if M/N > 0.5:\n",
    "\n",
    "                    #print(a1, a2, b)\n",
    "                    #print(M/N)\n",
    "                    f.write('{}\\t{}\\t{}\\t{}\\n'.format(str(M/N), a1, a2, b))\n",
    "f.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "# R(x,y) -> A(x)\n",
    "f = open('pattern8.txt',\"w+\")\n",
    "for a in types_TG2:\n",
    "    for r in relations_TG1:\n",
    "        N = len(pairs_for_relation_G1[r])\n",
    "        print(N)\n",
    "        M = 0\n",
    "        for p in pairs_for_relation_G1[r]:\n",
    "            \n",
    "            if p[0] in entities_for_type_G2[a]:\n",
    "                M += 1\n",
    "                #print(a, r, p[0])\n",
    "        if M/N >= 0.1:\n",
    "            f.write('{}\\t{}\\n'.format(str(M/N), r,a))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "# R(x,y) -> A(y)\n",
    "f = open('pattern9.txt',\"w+\")\n",
    "for a in types_TG2:\n",
    "    for r in relations_TG1:\n",
    "        N = len(pairs_for_relation_G1[r])\n",
    "        #print(N)\n",
    "        M = 0\n",
    "        for p in pairs_for_relation_G1[r]:\n",
    "            \n",
    "            if p[1] in entities_for_type_G2[a]:\n",
    "                M += 1\n",
    "                #print(a, r, p[0])\n",
    "        if M/N >= 0.1:\n",
    "\n",
    "            print(r, a)\n",
    "            print(M/N)\n",
    "            f.write('{}\\t{}\\n'.format(str(M/N), r,a))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "# R(x,y) -> A(x)\n",
    "f = open('pattern10.txt',\"w+\")\n",
    "for a in types_TG2:\n",
    "    for r in relations_TG1:\n",
    "        N = len(pairs_for_relation_G1[r])\n",
    "        #print(N)\n",
    "        M = 0\n",
    "        for p in pairs_for_relation_G1[r]:\n",
    "            \n",
    "            if p[0] in entities_for_type_G2[a]:\n",
    "                M += 1\n",
    "                #print(a, r, p[0])\n",
    "        #if M != 0:\n",
    "            #print(M)\n",
    "        if M/N >= 0.05:\n",
    "\n",
    "            print(r, a)\n",
    "            print(M/N)\n",
    "            f.write('{}\\t{}\\n'.format(str(M/N), r,a))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
