{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "rel2sym = dict()\n",
    "letters = ['X','Y','Z','W','V','U','T']\n",
    "with open(\"rel2sym.txt\",\"r\") as fr:\n",
    "    for line in fr:\n",
    "        rel, sym = line.strip().split()\n",
    "        rel2sym[rel] = sym \n",
    "\n",
    "def prefix_add(length):\n",
    "    # \"\\forall A \\forall B\"\n",
    "    prefix = \"$\\\\forall X\"\n",
    "    # tail = chr(ord('A') + length-2)\n",
    "    \n",
    "    for i in range(length-2):\n",
    "        prefix += \",\" + letters[i+1]\n",
    "    prefix += ': '\n",
    "    # prefix += chr(ord('A') + length - 1)\n",
    "    return prefix\n",
    "\n",
    "def replace_symbolic(predicate, rel2sym):\n",
    "    for i in range(len(list(rel2sym.keys()))-1, -1, -1):\n",
    "        rel = list(rel2sym.keys())[i]\n",
    "        if rel in predicate:\n",
    "            predicate = predicate.replace(rel, rel2sym[rel])\n",
    "            return predicate\n",
    "        \n",
    "import re\n",
    "def raw_to_latex(rfile, wfile):\n",
    "    with open(wfile, 'w') as fw:\n",
    "        with open(rfile, 'r') as f:\n",
    "            for line in f:\n",
    "                rule = ''\n",
    "                lst = line.strip().split('\\t')\n",
    "                length = len(lst)\n",
    "                rule = prefix_add(length)\n",
    "                # if 'Z' in line:\n",
    "                #     rule = '$\\\\forall A \\\\forall B \\\\exists C ('\n",
    "                # else:\n",
    "                #     rule = '$\\\\forall A \\\\forall Y ('\n",
    "                head = 0\n",
    "                tail = 1\n",
    "                for rel in lst[1:-1]:\n",
    "                    # replace predicate with others\n",
    "                    \n",
    "                    rel = replace_symbolic(rel, rel2sym)\n",
    "                    # rule +=  rel + ' \\\\land '\n",
    "                    rule += rel + '(' + letters[head] + ', ' + letters[tail] + ') \\\\land '\n",
    "                    head = tail\n",
    "                    tail = head + 1\n",
    "                rel = replace_symbolic(lst[-1], rel2sym)\n",
    "                rh = replace_symbolic(lst[0], rel2sym)\n",
    "                rule += rel + '(X) \\\\rightarrow ' + rh + '(X, ' + letters[tail-1] + ')$'\n",
    "\n",
    "                fw.writelines(rel2sym[lst[0]] + '\\t' + rule + '\\n')\n",
    "raw_to_latex('rule_tab.txt', 'latex_rules.txt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "rel2sym = dict()\n",
    "with open(\"rel2sym.txt\",\"r\") as fr:\n",
    "    for line in fr:\n",
    "        \n",
    "        rel, sym = line.strip().split()\n",
    "        if 'Of' in sym:\n",
    "\n",
    "            rel2sym[rel] = sym[:-2]\n",
    "        else:\n",
    "            rel2sym[rel] = sym\n",
    "\n",
    "def prefix_add(length):\n",
    "    # \"\\forall A \\forall B\"\n",
    "    prefix = \"$\\\\forall A\"\n",
    "    # tail = chr(ord('A') + length-2)\n",
    "    \n",
    "    for i in range(length-2):\n",
    "        prefix += \",\" + chr(ord('B') + i)\n",
    "    prefix += ': '\n",
    "    # prefix += chr(ord('A') + length - 1)\n",
    "    return prefix\n",
    "\n",
    "def replace_symbolic(predicate, rel2sym):\n",
    "    for i in range(len(list(rel2sym.keys()))-1, -1, -1):\n",
    "        rel = list(rel2sym.keys())[i]\n",
    "        if rel in predicate:\n",
    "            predicate = predicate.replace(rel, rel2sym[rel])\n",
    "            return predicate\n",
    "        \n",
    "\n",
    "def raw_to_latex(rfile, wfile):\n",
    "    with open(wfile, 'w') as fw:\n",
    "        with open(rfile, 'r') as f:\n",
    "            for line in f:\n",
    "                rule = 'If '\n",
    "                lst = line.strip().split('\\t')\n",
    "                length = len(lst)\n",
    "                h = ord('A')\n",
    "\n",
    "                for rel in lst[1:-1]:\n",
    "                    # replace predicate with others\n",
    "                    rel = replace_symbolic(rel, rel2sym)\n",
    "                    t = h + 1\n",
    "                    rule +=  chr(h) + ' is ' + rel + ' of ' + chr(t) + ' and '\n",
    "                    h = t\n",
    "                rel = replace_symbolic(lst[-1], rel2sym)\n",
    "                rh = replace_symbolic(lst[0], rel2sym)\n",
    "                rule += 'A is ' + rel2sym[lst[-1]] + ', then A is ' + rel2sym[lst[0]] + ' of ' + chr(t) + '.'\n",
    "                    \n",
    "                fw.writelines(rh + '\\t' + rule + '\\n')\n",
    "\n",
    "raw_to_latex('rule_tab.txt', 'natural_rules.txt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "rel2sym = dict()\n",
    "with open('rel2sym.txt', 'r') as fr:\n",
    "    for line in fr:\n",
    "        rel, sym = line.strip().split()\n",
    "        rel2sym[rel] = sym\n",
    "\n",
    "with open('rel2sym_2.txt', 'w') as fw:\n",
    "    for rel in rel2sym.keys():\n",
    "        fw.writelines(rel + '\\t' + rel2sym[rel] + '\\n')\n",
    "    \n",
    "    for rel in rel2sym.keys():\n",
    "        fw.writelines('inverse_' + rel + '\\t' + 'inverse_' + rel2sym[rel] + '\\n')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "family-tree-data-gen",
   "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.9"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
