{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": [],
      "collapsed_sections": [
        "LGIbpGv-bCb4"
      ]
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "source": [
        "# !rm -rf candc; git clone https://github.com/chrzyki/candc.git\n",
        "# !tar -C candc/candc/ -xvf candc/models/models-1.02.tgz >/dev/null\n",
        "# !sudo apt-get install swi-prolog swi-prolog-nox >/dev/null\n",
        "\n",
        "# !wget http://launchpadlibrarian.net/238314914/swi-prolog-nox_7.2.3-2_amd64.deb >/dev/null\n",
        "# !dpkg -i swi-prolog-nox_7.2.3-2_amd64.deb >/dev/null\n",
        "# !wget http://ftp.debian.org/debian/pool/main/r/readline6/libreadline6_6.3-8+b3_amd64.deb >/dev/null\n",
        "# !dpkg -i ./libreadline6_6.3-8+b3_amd64.deb >/dev/null\n",
        "# !sudo apt --fix-broken install libreadline6 >/dev/null\n",
        "\n",
        "# !mv /usr/lib/libswipl.so.7.2* /tmp\n",
        "# !sudo apt install swi-prolog-nox swi-prolog >/dev/null\n",
        "# !sudo apt install prover9 >/dev/null\n",
        "# !cp /tmp/libswipl.so.7.2* /usr/lib >/dev/null\n",
        "# !ls /usr/lib |grep pl\n",
        "\n",
        "# !rm -rf nltk; git clone https://github.com/cestwc/nltk.git\n"
      ],
      "metadata": {
        "id": "-xT8QByLAlzW"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "#Book"
      ],
      "metadata": {
        "id": "LGIbpGv-bCb4"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "sentence = 'Angus gives a bone to every dog'\n"
      ],
      "metadata": {
        "id": "TwVc51c5bVmF"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "import nltk\n",
        "nltk.download('book_grammars')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "fmgVo86EJEgP",
        "outputId": "6836dab9-72d3-4931-8eba-1dbca19d0785"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "[nltk_data] Downloading package book_grammars to /root/nltk_data...\n",
            "[nltk_data]   Package book_grammars is already up-to-date!\n"
          ]
        },
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "True"
            ]
          },
          "metadata": {},
          "execution_count": 3
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "parser = nltk.load_parser('grammars/book_grammars/simple-sem.fcfg', trace=0)\n",
        "fol_book = next(parser.parse(sentence.split())).label()['SEM']\n",
        "print(type(fol_book), fol_book)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "D3uvtTW0IoMx",
        "outputId": "1ea1a6a2-27c6-4aa0-dbcf-356b61273897"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "<class 'nltk.sem.logic.AllExpression'> all z2.(dog(z2) -> exists z1.(bone(z1) & give(angus,z1,z2)))\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "CNDz0xP8InH_",
        "outputId": "d9f1e858-369d-42bf-a218-558064118b9f"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "([x,y],[angus(x), dog(y), own(x,y)])\n",
            "exists x y.(angus(x) & dog(y) & own(x,y))\n",
            "([E1,T1,T2,X1,X2,X3],[man(X1,X2), sleep(E1,X3), Agent(E1,X3), now(T1), Temp_included(E1,X2), Equ(T2,X2)])\n",
            "exists E1 T1 T2 X1 X2 X3.(man(X1,X2) & sleep(E1,X3) & Agent(E1,X3) & now(T1) & Temp_included(E1,X2) & Equ(T2,X2))\n"
          ]
        }
      ],
      "source": [
        "import nltk\n",
        "\n",
        "read_dexpr = nltk.sem.DrtExpression.fromstring\n",
        "drs1 = read_dexpr('([x, y], [angus(x), dog(y), own(x, y)])')\n",
        "drs2 = read_dexpr('([X1, X2, E1, X3, T1, T2], [man(X1, X2), sleep(E1, X3), Agent(E1, X3), now(T1), Temp_included( E1, X2 ), Equ( T2, X2)] )')\n",
        "drs3 = read_dexpr('([x, z], [angus(x), dog(z), own(x, z)])')\n",
        "print(drs1)\n",
        "print(drs1.fol())\n",
        "print(drs2)\n",
        "print(drs2.fol())"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "#Bos"
      ],
      "metadata": {
        "id": "F1dNobvYb6M_"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "import sys\n",
        "sys.path.append('nltk/nltk/sem')\n",
        "from boxer import Boxer\n",
        "from skolemize import richardize\n",
        "from nd import to_sorted, conjunctive_form, conj_elim, get_basic_assumptions\n",
        "sys.path.pop()"
      ],
      "metadata": {
        "id": "lnyIgObd-Phx",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 35
        },
        "outputId": "1ed0302c-c1b4-454c-8f71-5be67534d385"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "'nltk/nltk/sem'"
            ],
            "application/vnd.google.colaboratory.intrinsic+json": {
              "type": "string"
            }
          },
          "metadata": {},
          "execution_count": 6
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import nltk\n",
        "\n",
        "read_expr = nltk.sem.logic.Expression.fromstring\n",
        "simplify = lambda x: to_sorted(richardize(x))\n",
        "interpret = Boxer(bin_dir='candc/candc/bin').interpret\n"
      ],
      "metadata": {
        "id": "wLrwkQ8elp9A"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "sentence = 'Angus gives a bone to every dog'\n",
        "\n",
        "fol_bos = interpret(sentence).fol()\n",
        "print(type(fol_bos), fol_bos)\n"
      ],
      "metadata": {
        "id": "zWG-Z11Q-avS",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "b3309b6f-92d8-4859-f49a-8b76876da090"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "<class 'nltk.sem.logic.ExistsExpression'> exists e1 x1 x2.(ne_per_angus(x1) & all x3.(n_dog(x3) -> to(e1,x3)) & Theme(e1,x2) & Actor(e1,x1) & v_give(e1) & n_bone(x2))\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "#Prover"
      ],
      "metadata": {
        "id": "uoGkLwDwcqaJ"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "prover = nltk.Prover9()"
      ],
      "metadata": {
        "id": "Ke9F_3RkOaBp"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# entails\n",
        "premise = interpret('A turtle danced').fol()\n",
        "hypothesis = interpret('A turtle moved').fol()\n",
        "\n",
        "print(premise)\n",
        "print(hypothesis)\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "BSR83g3KfZVO",
        "outputId": "1f12fba9-28c9-45f0-96d3-b56ab656bac1"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "exists e1 x1.(Actor(e1,x1) & v_dance(e1) & n_turtle(x1))\n",
            "exists e1 x1.(Actor(e1,x1) & v_move(e1) & n_turtle(x1))\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "prover.prove(hypothesis, [premise]) # False"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "m7zcCjzwOaks",
        "outputId": "79228697-32de-4482-8d72-a067f68447a3"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "False"
            ]
          },
          "metadata": {},
          "execution_count": 11
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "read_expr = nltk.sem.Expression.fromstring\n",
        "\n",
        "assumption = read_expr('(all x. (v_dance(x) -> v_move(x)))')\n",
        "print(assumption)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "5CUi6-hhUpej",
        "outputId": "7c07547e-8748-4938-b5be-f9c9786801cc"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "all x.(v_dance(x) -> v_move(x))\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# a1 = read_expr('(exists e1 x1.v_move(e1) | all e1 x1.(-v_dance(e1) | -n_turtle(x1) | -Actor(e1,x1)))')\n",
        "nltk.ResolutionProver().prove(-assumption, [simplify(premise & -hypothesis)], verbose=True)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "BkIYxca5r864",
        "outputId": "a907c9b9-7a37-4859-d193-ee2ac3067857"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[ 1] {-v_dance(z4), v_move(z4)}                        A \n",
            "[ 2] {v_dance(z9)}                                     A \n",
            "[ 3] {n_turtle(z10)}                                   A \n",
            "[ 4] {Actor(z12,z11)}                                  A \n",
            "[ 5] {-v_move(z13), -n_turtle(z14), -Actor(z13,z14)}   A \n",
            "[ 6] {v_move(z9)}                                      (1, 2) \n",
            "[ 7] {-n_turtle(z14), -Actor(z13,z14), -v_dance(z13)}  (1, 5) \n",
            "[ 8] {-n_turtle(z14), -Actor(z13,z14)}                 (2, 7) \n",
            "[ 9] {-Actor(z13,z14), -v_move(z13)}                   (3, 5) \n",
            "[10] {-Actor(z13,z14), -v_dance(z13)}                  (1, 9) \n",
            "[11] {-Actor(z13,z14)}                                 (2, 10) \n",
            "[12] {-Actor(z13,z14), -v_dance(z13)}                  (3, 7) \n",
            "[13] {-Actor(z13,z14)}                                 (2, 12) \n",
            "[14] {-Actor(z13,z14)}                                 (3, 8) \n",
            "[15] {-v_move(z13), -n_turtle(z14)}                    (4, 5) \n",
            "[16] {-n_turtle(z14), -v_dance(z13)}                   (1, 15) \n",
            "[17] {-n_turtle(z14)}                                  (2, 16) \n",
            "[18] {-v_move(z13)}                                    (3, 15) \n",
            "[19] {-v_dance(z13)}                                   (1, 18) \n",
            "[20] {}                                                (2, 19) \n",
            "\n"
          ]
        },
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "True"
            ]
          },
          "metadata": {},
          "execution_count": 13
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# contradicts\n",
        "premise = interpret('Some turtles walk').fol()\n",
        "hypothesis = interpret('No turtles move').fol()\n",
        "\n",
        "print(premise)\n",
        "print(hypothesis)\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "b98523ea-46bd-48c7-d21a-4a1093546463",
        "id": "zwh7buNYhlRU"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "exists e1 x1.(Actor(e1,x1) & v_walk(e1) & n_turtle(x1))\n",
            "-exists e1 x1.(Actor(e1,x1) & v_move(e1) & n_turtle(x1))\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "prover.prove(hypothesis, [premise])"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "2198f861-6796-4d85-b09a-3300acd939f6",
        "id": "oo0fSNo_hlRW"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "False"
            ]
          },
          "metadata": {},
          "execution_count": 16
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "joined = (hypothesis & premise).normalize()\n",
        "print(joined)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "HCTD-eRp-HYZ",
        "outputId": "93fbf544-be13-402c-cb5f-ea08321475ed"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "(-exists e01 z2.(Actor(e01,z2) & v_move(e01) & n_turtle(z2)) & exists e01 z2.(Actor(e01,z2) & v_walk(e01) & n_turtle(z2)))\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "assumption = - read_expr('(-exists e01 .(Actor(e01,z2) & v_move(e01) ) & exists e01 .( v_walk(e01) ))')\n",
        "print(nltk.sem.skolemize(assumption).normalize())"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "2oHhUeHIkEw-",
        "outputId": "f18da0fb-547c-4d22-c631-684c8640d993"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "(-v_walk(z1) & v_walk(z2))\n",
            "(-exists e01.v_walk(e01) & exists e01.v_walk(e01))\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "print('(premise & assumption) |= - hypothesis: ', prover.prove(-hypothesis, [premise, assumption]))\n",
        "print('premise |X assumption: \\t\\t\\t', not prover.prove(assumption, [premise]))\n",
        "print('premise |X - assumption: \\t\\t', not prover.prove(-assumption, [premise]))\n",
        "print('assumption) |X premise: \\t\\t', not prover.prove(premise, [assumption]))\n",
        "print('assumption) |X - premise: \\t\\t', not prover.prove(-premise, [assumption]))\n",
        "print('assumption) |X hypothesis: \\t\\t', not prover.prove(hypothesis, [assumption]))\n",
        "print('assumption) |X - hypothesis: \\t\\t', not prover.prove(-hypothesis, [assumption]))\n",
        "print('hypothesis) |X assumption: \\t\\t', not prover.prove(assumption, [hypothesis]))\n",
        "print('hypothesis) |X - assumption: \\t\\t', not prover.prove(-assumption, [hypothesis]))\n",
        "\n",
        "# print('(premise & assumption) |= - hypothesis: ', prover.prove(-hypothesis, [premise, assumption]))\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "btfhOe0bD9XA",
        "outputId": "9da9dec8-4091-41db-eb13-1472de3f4c6d"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "(premise & assumption) |= - hypothesis:  True\n",
            "premise |X assumption: \t\t\t True\n",
            "premise |X - assumption: \t\t False\n",
            "assumption) |X premise: \t\t False\n",
            "assumption) |X - premise: \t\t False\n",
            "assumption) |X hypothesis: \t\t False\n",
            "assumption) |X - hypothesis: \t\t False\n",
            "hypothesis) |X assumption: \t\t True\n",
            "hypothesis) |X - assumption: \t\t False\n"
          ]
        }
      ]
    }
  ]
}