{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "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",
    "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",
    "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 = ord('A')\n",
    "                tail = head + 1\n",
    "                for rel in lst[1:-1]:\n",
    "                    # replace predicate with others\n",
    "                    if \"inverse_\" in rel:\n",
    "\n",
    "                        \n",
    "                        new_rel = rel2sym[rel[8:]]\n",
    "                    # rule +=  rel + ' \\\\land '\n",
    "                        rule += new_rel + '(' + chr(tail) + ', ' + chr(head) + ') \\\\land '\n",
    "                    else:\n",
    "                        new_rel = rel2sym[rel]\n",
    "                        rule += new_rel + '(' + chr(head) + ', ' + chr(tail) + ') \\\\land '\n",
    "                    head = tail\n",
    "                    tail = head + 1\n",
    "                rel = rel2sym[lst[-1]]\n",
    "                rh = rel2sym[lst[0]]\n",
    "                rule += rel + '(A) \\\\rightarrow ' + rh + '(A,' + chr(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": 4,
   "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",
    "        if 'Of' in sym:\n",
    "\n",
    "            rel2sym[rel] = sym[:-2]\n",
    "        else:\n",
    "            rel2sym[rel] = sym\n",
    "\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",
    "                t = h + 1\n",
    "                for rel in lst[1:-1]:\n",
    "                    # replace predicate with others\n",
    "                    if \"inverse_\" in rel:\n",
    "                        new_rel = rel2sym[rel[8:]]\n",
    "                        rule +=  chr(t) + ' is ' + new_rel + ' of ' + chr(h) + ' and '\n",
    "                    else:\n",
    "                        new_rel = rel2sym[rel]\n",
    "                        rule +=  chr(h) + ' is ' + new_rel + ' of ' + chr(t) + ' and '\n",
    "                    h = t\n",
    "                    t = h + 1\n",
    "                rel = rel2sym[lst[-1]]\n",
    "                rh = rel2sym[lst[0]]\n",
    "                rule += 'A is ' + rel2sym[lst[-1]] + ', then A is ' + rel2sym[lst[0]] + ' of ' + chr(t-1) + '.'\n",
    "                    \n",
    "                fw.writelines(rh + '\\t' + rule + '\\n')\n",
    "\n",
    "raw_to_latex('rule_tab.txt', 'natural_rules.txt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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
}
