{
 "cells": [
  {
   "cell_type": "markdown",
   "source": [
    "# iTAG: Inverse Design for Text Generation with Accurate and Complex Causal Graph\n",
    "\n",
    "===================================================================\n",
    "\n",
    "This notebook demonstrates the methodology and a simple implementation of iTAG, a three-phase approach to generate text with accurate and complex causal graphs.\n",
    "\n",
    "## 1. Overview of the Three-Phase Workflow\n",
    "\n",
    "iTAG generates text with causal graphs through a three-phase pipeline:\n",
    "\n",
    "1. **Phase 1**: Control parameters are transformed into a structured causal graph and an adjacency matrix\n",
    "2. **Phase 2**: Abstract variables in the causal graph undergo substitution with real-world concepts\n",
    "3. **Phase 3**: These real-world concepts and their causal structure are transformed into coherent natural language text"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "386480067a1afb01"
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "outputs": [
    {
     "data": {
      "text/plain": "<IPython.core.display.HTML object>",
      "text/html": "<img src=\"./imgs/methodsim.jpg\" width=\"100%\">"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from IPython.display import display, HTML\n",
    "\n",
    "display(HTML('<img src=\"./imgs/methodsim.jpg\" width=\"100%\">'))"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-05-20T03:41:44.446011900Z",
     "start_time": "2025-05-20T03:41:44.426810600Z"
    }
   },
   "id": "a1456797dbbef4a5"
  },
  {
   "cell_type": "markdown",
   "source": [
    "## 2. Phase 1: Causal Graph Generation\n",
    "\n",
    "In Phase 1, we transform control parameters into structured causal graphs and adjacency matrices. The input parameters include:x\n",
    "\n",
    "- **n**: Node count\n",
    "- **expected_density**: Edge density\n",
    "- **max_parents**: Maximum parents per node\n",
    "- **max_children**: Maximum children per node\n",
    "- **confounders_ratio**: Ratio of confounders (common causes)\n",
    "- **colliders_ratio**: Ratio of colliders (common effects)\n",
    "- **mediator_chains**: Number of mediator chains\n",
    "\n",
    "The output is a directed acyclic graph (DAG) with its corresponding adjacency matrix representation."
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "e9ed94514acec5f"
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "initial_id",
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2025-05-20T05:32:49.409445800Z",
     "start_time": "2025-05-20T05:32:49.393259900Z"
    }
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import random\n",
    "\n",
    "\n",
    "class CausalGraphGenerator:\n",
    "    \"\"\"Flexible causal graph (DAG) generator with control of various network parameters\"\"\"\n",
    "\n",
    "    def __init__(self, seed=None):\n",
    "        \"\"\"Initialize generator with optional random seed\"\"\"\n",
    "        if seed is not None:\n",
    "            np.random.seed(seed)\n",
    "            random.seed(seed)\n",
    "\n",
    "    def generate_custom_dag(self,\n",
    "                            n,\n",
    "                            expected_density=0.2,\n",
    "                            max_parents=None,\n",
    "                            max_children=None,\n",
    "                            confounders_ratio=0.1,\n",
    "                            colliders_ratio=0.1,\n",
    "                            mediator_chains=0,\n",
    "                            verbose=False):\n",
    "        \"\"\"Generate DAG with custom properties\"\"\"\n",
    "        # Calculate expected number of edges\n",
    "        max_possible_edges = n * (n - 1) // 2\n",
    "        expected_edges = int(expected_density * max_possible_edges)\n",
    "\n",
    "        # Create empty directed graph\n",
    "        G = nx.DiGraph()\n",
    "        G.add_nodes_from(range(n))\n",
    "\n",
    "        # Calculate edge probability\n",
    "        p = 2 * expected_edges / (n * (n - 1))\n",
    "\n",
    "        # Add edges\n",
    "        edge_count = 0\n",
    "        for i in range(n):\n",
    "            for j in range(i + 1, n):\n",
    "                if random.random() < p:\n",
    "                    # Check constraints\n",
    "                    if max_parents is not None and G.in_degree(j) >= max_parents:\n",
    "                        continue\n",
    "                    if max_children is not None and G.out_degree(i) >= max_children:\n",
    "                        continue\n",
    "\n",
    "                    G.add_edge(i, j)\n",
    "                    edge_count += 1\n",
    "\n",
    "        # Add confounder structures\n",
    "        if confounders_ratio > 0:\n",
    "            self._add_confounders(G, confounders_ratio)\n",
    "\n",
    "        # Add collider structures\n",
    "        if colliders_ratio > 0:\n",
    "            self._add_colliders(G, colliders_ratio)\n",
    "\n",
    "        # Add mediator chains\n",
    "        if mediator_chains > 0:\n",
    "            self._add_mediator_chains(G, mediator_chains, min_length=2, max_length=4)\n",
    "\n",
    "        return G\n",
    "\n",
    "    def _add_confounders(self, G, ratio):\n",
    "        \"\"\"Add confounders to graph\"\"\"\n",
    "        n = G.number_of_nodes()\n",
    "        num_confounders = max(1, int(n * ratio))\n",
    "        confounders_added = 0\n",
    "\n",
    "        for _ in range(num_confounders):\n",
    "            if n < 3:\n",
    "                break\n",
    "\n",
    "            for attempt in range(10):\n",
    "                nodes = sorted(random.sample(range(n), 3))\n",
    "                confounder, child1, child2 = nodes\n",
    "\n",
    "                if (G.has_edge(child1, confounder) or\n",
    "                        G.has_edge(child2, confounder) or\n",
    "                        nx.has_path(G, child1, confounder) or\n",
    "                        nx.has_path(G, child2, confounder)):\n",
    "                    continue\n",
    "\n",
    "                if G.has_edge(child1, child2):\n",
    "                    G.remove_edge(child1, child2)\n",
    "                elif G.has_edge(child2, child1):\n",
    "                    G.remove_edge(child2, child1)\n",
    "\n",
    "                G.add_edge(confounder, child1)\n",
    "                G.add_edge(confounder, child2)\n",
    "                confounders_added += 1\n",
    "                break\n",
    "\n",
    "        return confounders_added\n",
    "\n",
    "    def _add_colliders(self, G, ratio):\n",
    "        \"\"\"Add collider structures to graph\"\"\"\n",
    "        n = G.number_of_nodes()\n",
    "        num_colliders = max(1, int(n * ratio))\n",
    "        colliders_added = 0\n",
    "\n",
    "        for _ in range(num_colliders):\n",
    "            if n < 3:\n",
    "                break\n",
    "\n",
    "            for attempt in range(10):\n",
    "                nodes = random.sample(range(n), 3)\n",
    "                parent1, parent2, collider = nodes\n",
    "\n",
    "                if (G.has_edge(collider, parent1) or\n",
    "                        G.has_edge(collider, parent2) or\n",
    "                        nx.has_path(G, collider, parent1) or\n",
    "                        nx.has_path(G, collider, parent2)):\n",
    "                    continue\n",
    "\n",
    "                if G.has_edge(parent1, parent2):\n",
    "                    G.remove_edge(parent1, parent2)\n",
    "                elif G.has_edge(parent2, parent1):\n",
    "                    G.remove_edge(parent2, parent1)\n",
    "\n",
    "                G.add_edge(parent1, collider)\n",
    "                G.add_edge(parent2, collider)\n",
    "                colliders_added += 1\n",
    "                break\n",
    "\n",
    "        return colliders_added\n",
    "\n",
    "    def _add_mediator_chains(self, G, num_chains, min_length=2, max_length=4):\n",
    "        \"\"\"Add mediator chains to graph\"\"\"\n",
    "        n = G.number_of_nodes()\n",
    "        chains_added = 0\n",
    "\n",
    "        for _ in range(num_chains):\n",
    "            chain_length = random.randint(min_length, max_length)\n",
    "\n",
    "            if n < chain_length + 1:\n",
    "                break\n",
    "\n",
    "            for attempt in range(10):\n",
    "                start, end = random.sample(range(n), 2)\n",
    "\n",
    "                if G.has_edge(end, start) or nx.has_path(G, end, start):\n",
    "                    continue\n",
    "\n",
    "                if G.has_edge(start, end):\n",
    "                    G.remove_edge(start, end)\n",
    "\n",
    "                available_nodes = [node for node in range(n) if node != start and node != end]\n",
    "                if len(available_nodes) < chain_length - 1:\n",
    "                    continue\n",
    "\n",
    "                mediators = random.sample(available_nodes, chain_length - 1)\n",
    "                chain = [start] + mediators + [end]\n",
    "                valid_chain = True\n",
    "\n",
    "                for i in range(len(chain) - 1):\n",
    "                    if G.has_edge(chain[i + 1], chain[i]) or nx.has_path(G, chain[i + 1], chain[i]):\n",
    "                        valid_chain = False\n",
    "                        break\n",
    "\n",
    "                if not valid_chain:\n",
    "                    continue\n",
    "\n",
    "                for i in range(len(chain) - 1):\n",
    "                    G.add_edge(chain[i], chain[i + 1])\n",
    "\n",
    "                chains_added += 1\n",
    "                break\n",
    "\n",
    "        return chains_added"
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Example: Generate a causal graph from the figure of workflow\n",
    "\n",
    "For this example, we'll use the causal graph shown in the figure, which has 5 nodes: Study, Talent, Knowledge, Skill, and Success, with specific causal relationships between them."
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "9aa64461fb9b08cb"
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 1000x600 with 1 Axes>",
      "image/png": "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vj21bN/07LPPqmzZsho/fry2b9+u6dOn6/Lly1q4cGGa/bZs2aJly5Zp4MCBKliwoKZPn65OnTrpxIkTqd/Lt2rSpIm+/PJLPf/882rZsqX+/e9/37bPwIEDVaxYMY0aNUqxsbGS/r4Q8d5776lFixYaMGCADh8+rFmzZum3337T1q1b5ezsnPr6y5cvq3379uratau6dOmiWbNmqWvXrlq0aJGGDBmi/v37q3v37po0aZI6d+6skydPqmDBgvd9b69fv37bn1tvb+80577p1KlTevLJJ2WxWDRy5Eh5enrq888/z5IRAHd6f7788kv17NlTrVu31sSJE3X9+nXNmjVLjRo10t69eynzAGBPDABArjN//nxD0h1/ubq6ptk3NDTUcHFxMV566SXj8uXLRqlSpYw6deoYiYmJqfskJSUZ8fHxaV53+fJlo3jx4kbv3r1Tt0VGRhqSjGLFihnR0dGp20eOHGlIMgICAtIct1u3boaLi4sRFxeXuq1MmTKGJGPp0qWp22JiYoySJUsaNWvWTN22YcMGQ5KxYcMGwzAMIyUlxahUqZLRunVrIyUlJXW/69evG+XKlTNatmx5z/esZs2ahre39z33+afr16/ftm38+PGGxWIxjh8/nrotMDDQCAwMvG3fnj17GmXKlEn9ePDgwYaXl5eRlJR013PGxcUZycnJabZFRkYarq6uxvvvv59mmyRj/vz59/waChUqZNSoUeO27VeuXDHOnz+f+uvatWupnxs9erQhyejWrdttr7vTe/LNN98YkozNmzffdgyr1Zpm34EDBxqSjP3796duk2S4uLgYR48eTd22f/9+Q5IxY8aMe359N1//8ssvp9l2889Ho0aN0rzf586dM1xcXIxWrVqleZ8/+eQTQ5Ixb9681G2BgYGGJOPrr79O3RYREWFIMhwcHIzt27enbl+zZk26fj9u/r7d6dfN7/MyZcoYPXv2TH3NoEGDDIvFYuzduzd128WLF43ChQsbkozIyMg078Xo0aNvO++tx7zb+3P16lXDx8fH6NOnT5rXnz171vD29r5t+72cP3/+rnkAALkDw/gBIBebOXOm1q1bl+bXjz/+mGafqlWr6r333tPnn3+u1q1b68KFC/riiy/k5PT/g7ccHR3l4uIiSUpJSdGlS5eUlJSkOnXqaM+ePbedt0uXLvL29k79uF69epKk5557Ls1x69Wrp4SEBJ06dSrN6x9++GF17Ngx9WMvLy/9+9//1t69e3X27Nk7fq379u3TkSNH1L17d128eFEXLlzQhQsXFBsbq+bNm2vz5s1KSUm563t15cqVdN11vemfz7HHxsbqwoULatiwoQzD0N69e9N9nJt8fHwUGxurdevW3XUfV1fX1MnZkpOTdfHiRRUoUECVK1e+4+/D/Vy5ckUFChS4bfvzzz+vYsWKpf4aPnz4bfv079//tm3/fE/i4uJ04cKF1Fnk75Tv5ZdfTvPxoEGDJEmrVq1Ks71FixaqUKFC6sfVq1eXl5eXjh07dq8v77769OkjR0fH1I/Xr1+vhIQEDRkyJM0keH369JGXl5dWrlyZ5vUFChRQ165dUz+uXLmyfHx85Ofnl/o9L/3/93968/bt2/e2P7c3R9ncavXq1WrQoEGa0TWFCxdWjx490nWue7n1/Vm3bp2io6PVrVu31D9fFy5ckKOjo+rVq3fbYz0AgLyNYfwAkIs9/vjj6Zqgb9iwYVq8eLF27typcePGqUqVKrft88UXX2jy5MmKiIhQYmJi6vY7zfb/6KOPpvn4ZvF/5JFH7rj98uXLabZXrFjxtiHfjz32mKS/5wUoUaLEbec8cuSIJKlnz553/iL192MNhQoVuuPnMloeT5w4oVGjRmnFihW35Y+JiUn3cW4aOHCg/vvf/6pt27YqVaqUWrVqpWeffTbNUnEpKSmaNm2aPv30U0VGRio5OTn1c3cbzn4vBQsW1LVr127b/v7776eubX+3xybu9Pt+6dIlvffee1q8eLHOnTuX5nN3ek8qVaqU5uMKFSrIwcEhzXPm0u3fT5JUqFCh2973jLr1azh+/Likv0v7P7m4uKh8+fKpn7+pdOnSt32fent7p/v7/G4qVaqkFi1apGvf48ePq0GDBrdtz4oVN259f27+GWvWrNkd9/fy8nrgcwIAcg/KPgDYgWPHjqX+IB8aGnrb57/66iv16tVLTz/9tIYNG6aHHnpIjo6OGj9+vP7444/b9v/n3cD0bDf+98z3g7h5137SpEm3zSFw053uYt/k6+urvXv36uTJk7eVtVslJyerZcuWunTpkoYPHy5fX195enrq1KlT6tWrV5oRBDcnibvTMf7poYce0r59+7RmzRr9+OOP+vHHHzV//nz9+9//1hdffCFJGjdunN555x317t1bH3zwgQoXLiwHBwcNGTLknqMW7vU179+/X4mJiWmeB69evfp9X3unGfqfffZZbdu2TcOGDVONGjVUoEABpaSkqE2bNunKd2txvim7vm/ut8rA/ZjxfZ4dbv1evOnW9+fm7+GXX355xwtu/xy1AwDI+/hbHQDyuJSUFPXq1UteXl4aMmSIxo0bp86dO6eZtG3JkiUqX768li1blqaQjR49OlsyHT16VIZhpDnXzfXt7zYB2M1h3l5eXum+K/pPHTp00DfffKOvvvpKI0eOvOe+oaGh+v333/XFF1+kmfjtTkPwCxUqdMcRA7feJZb+voPcoUMHdejQQSkpKRo4cKCCgoL0zjvvpM70/uSTT2ru3LlpXhcdHa2iRYum90tN1b59e23fvl3ff/+9nn322Qy//p8uX76sn376Se+9955GjRqVuv3mRaQ7OXLkSJq7x0ePHlVKSoppk7yVKVNG0t9r2ZcvXz51e0JCgiIjIzP1fZXdypQpo6NHj962/U7bChUqdNuqAgkJCTpz5ky6znXzz9hDDz2UK98LAEDW4pl9AMjjPv74Y23btk2fffaZPvjgAzVs2FADBgxIMxv4zTuV/7wzuWPHDv3666/Zkun06dP6/vvvUz++cuWKFi5cqBo1atzxjqIk1a5dWxUqVNBHH310x6Hp58+fv+c5O3furGrVqmns2LF3/LquXr2qt956S9Kd3w/DMNIsk3dThQoVFBERkeb8+/fvv205wFuXp3NwcEi9wx4fH5963lvvDn/33Xe3zXmQXgMGDFDx4sX12muvpV5M+aeM3Im+03siSVOnTr3ra2bOnJnm4xkzZkiS2rZtm+7zZqUWLVrIxcVF06dPT/N1zJ07VzExMWrXrp0pue6ldevW+vXXX7Vv377UbZcuXdKiRYtu27dChQravHlzmm2fffbZXe/s3+lcXl5eGjduXJpHeW66358xAEDewp19AMjFfvzxR0VERNy2vWHDhipfvrzCw8P1zjvvqFevXurQoYOkv9fYrlGjRuoz5NLfd4CXLVumjh07ql27doqMjNTs2bNVpUqVOxbrB/XYY4/pxRdf1G+//abixYtr3rx5ioqK0vz58+/6GgcHB33++edq27at/P399cILL6hUqVI6deqUNmzYIC8vLwUHB9/19c7Ozlq2bJlatGihJk2a6Nlnn9UTTzwhZ2dnHTp0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"
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Adjacency Matrix:\n",
      "[[0 0 1 0 0]\n",
      " [0 0 0 1 0]\n",
      " [0 0 0 1 1]\n",
      " [0 0 0 0 1]\n",
      " [0 0 0 0 0]]\n"
     ]
    }
   ],
   "source": [
    "# Create a specific causal graph as shown in Figure 1 of the paper\n",
    "# This is the example shown in the paper with 5 concepts\n",
    "\n",
    "def create_example_graph():\n",
    "    G = nx.DiGraph()\n",
    "    G.add_nodes_from(range(5))\n",
    "    \n",
    "    # Add edges according to the paper example\n",
    "    # Study (0) -> Knowledge (2)\n",
    "    # Talent (1) -> Skill (3)\n",
    "    # Knowledge (2) -> Skill (3)\n",
    "    # Knowledge (2) -> Success (4)\n",
    "    # Skill (3) -> Success (4)\n",
    "    G.add_edge(0, 2)  # Study -> Knowledge\n",
    "    G.add_edge(1, 3)  # Talent -> Skill\n",
    "    G.add_edge(2, 3)  # Knowledge -> Skill\n",
    "    G.add_edge(2, 4)  # Knowledge -> Success\n",
    "    G.add_edge(3, 4)  # Skill -> Success\n",
    "    \n",
    "    return G\n",
    "\n",
    "def visualize_graph(G, title=\"Causal Graph\"):\n",
    "    \"\"\"Visualize a causal graph\"\"\"\n",
    "    plt.figure(figsize=(10, 6))\n",
    "    pos = nx.spring_layout(G, seed=42)  # Consistent layout\n",
    "    nx.draw(G, pos, with_labels=True, node_color='lightblue', \n",
    "            node_size=500, arrowsize=20, font_size=12, font_weight='bold')\n",
    "    plt.title(title)\n",
    "    plt.show()\n",
    "    \n",
    "    # Return adjacency matrix as well\n",
    "    return nx.to_numpy_array(G, dtype=int)\n",
    "\n",
    "# Create and visualize the example graph from the paper\n",
    "example_graph = create_example_graph()\n",
    "adjacency_matrix = visualize_graph(example_graph, \"Example Causal Graph from Figure 1\")\n",
    "print(\"Adjacency Matrix:\")\n",
    "print(adjacency_matrix)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-05-20T05:33:22.232743600Z",
     "start_time": "2025-05-20T05:33:22.113890700Z"
    }
   },
   "id": "5b957ae7223f7cbd"
  },
  {
   "cell_type": "markdown",
   "source": [
    "## 3. Phase 2: Concept Substitution\n",
    "\n",
    "In Phase 2, we transform abstract causal graph nodes into real-world concepts while preserving the causal structure defined by the adjacency matrix. The methodology employs an inverse design approach through Chain-of-Thought (CoT) prompting.\n",
    "\n",
    "The inverse design method involves:\n",
    "1. Analyzing causal structure to identify all existing and non-existing relationships\n",
    "2. Assigning initial domain-specific concepts \n",
    "3. Verifying through counterfactual reasoning\n",
    "4. Iteratively refining concepts to maintain causal structure integrity"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "339b0fbedcfba517"
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "outputs": [],
   "source": [
    "import anthropic\n",
    "import re\n",
    "import json\n",
    "\n",
    "def extract_text_from_response(response):\n",
    "    \"\"\"Extract text content from Claude response, handling thinking mode special structure\"\"\"\n",
    "    for block in response.content:\n",
    "        # Find text type content block\n",
    "        if block.type == \"text\":\n",
    "            return block.text\n",
    "    return None\n",
    "\n",
    "def concept_substitution(adjacency_matrix, domain=\"Business\"):\n",
    "    \"\"\"\n",
    "    Apply concept substitution to a causal graph represented by an adjacency matrix\n",
    "    \n",
    "    This function implements the inverse design-based concept substitution using LLM\n",
    "    with Chain-of-Thought prompting.\n",
    "    \"\"\"\n",
    "    \n",
    "    # Format the matrix for display in the prompt\n",
    "    matrix_str = \"\\n\".join([str(row.tolist()) for row in adjacency_matrix])\n",
    "    n = len(adjacency_matrix)\n",
    "    \n",
    "    # Construct the prompt based on the original iTAG implementation\n",
    "    prompt = f\"\"\"\n",
    "Adjacency Matrix:\n",
    "{matrix_str}\n",
    "\n",
    "Task: Please assign concepts from a meaningful real-world {domain} field to the {n} nodes in the causal DAG represented by this adjacency matrix, while fully conforming to the causal relationships between nodes.\n",
    "\n",
    "Requirements: In your thinking, please use the following separators to assist your reasoning, and only output the final result when you are satisfied with it:\n",
    "----Let me first analyze carefully---- \n",
    "(First list all relationships between nodes represented by 1s in the matrix and all non-existent relationships represented by 0s in the matrix)\n",
    "----First attempt---- \n",
    "(Then write out the concepts corresponding to the nodes)\n",
    "----Check for errors---- \n",
    "(Please use the complete paradigm '''First, imagine that in the real world, [variable A] occurs (or takes some value) and [variable B] subsequently occurs (or takes some value). If [variable A] had not occurred (or had taken a different value), would [variable B] still occur in the same way (or maintain the same value) under the same background conditions? If in the counterfactual scenario where [variable A] did not occur, [variable B] significantly changes (either does not occur at all, or occurs in a substantially different way, time, intensity, or characteristics), and this change is systematic rather than accidental, while all other potential background conditions and common causes that might affect [variable B] remain constant, then we can reasonably infer a causal relationship between [variable A] and [variable B], meaning [variable A] is a cause of [variable B]. Conversely, if in the counterfactual scenario, even when [variable A] does not occur, [variable B] still occurs in essentially the same way, or changes in [variable B] can be fully explained by changes in other variables, and this situation stably repeats across various background conditions, this indicates there is no direct or substantial causal relationship between [variable A] and [variable B], and the observed correlation between them may be coincidental, a spurious association due to common causes, or an indirect effect mediated through other variables rather than a true causal connection.''' to check whether the concepts conform to ALL relationships marked by 1s and do NOT conform to ALL relationships marked by 0s. If causal relationships are unreasonable, consider the reasons for errors and avoid them in the next attempt)\n",
    "Begin second analysis\n",
    "----Second attempt---- \n",
    "...\n",
    "\n",
    "Your answer should be in JSON format:\n",
    "{{\n",
    "  \"Existing causal relationships (values of 1 in the matrix)\": [\n",
    "    \"Node 0 → Node 1\",\n",
    "    ...\n",
    "  ],\n",
    "  \"Non-existing causal relationships (values of 0 in the matrix)\": [\n",
    "    \"Node 0 → Node 1\",\n",
    "    ...\n",
    "  ],\n",
    "  \"Domain\": [\n",
    "    \"{domain}\"\n",
    "  ],\n",
    "  \"Real concepts assigned to variables\": [\n",
    "    \"Node 0: ___\",\n",
    "    ...\n",
    "  ],\n",
    "  \"Relationship verification\": {{\n",
    "    \"Existing causal relationships\": [\n",
    "      \"___ (natural language description conforming to the reasoning paradigm)\",\n",
    "      ...\n",
    "    ],\n",
    "    \"Non-existing causal relationships\": [\n",
    "      \"___ (natural language description conforming to the reasoning paradigm)\",\n",
    "      ...\n",
    "    ]\n",
    "  }}\n",
    "}}\n",
    "\"\"\"\n",
    "    \n",
    "    # Initialize the Anthropic client - in a real scenario, you would use your own API key\n",
    "    # For this notebook, we're using a placeholder API key\n",
    "    # YOU SHOULD REPLACE THIS WITH YOUR ACTUAL API KEY WHEN RUNNING THE NOTEBOOK\n",
    "    client = anthropic.Anthropic(\n",
    "        api_key=\"YOUR_API_KEY_HERE\",  # Replace with actual API key\n",
    "    )\n",
    "    \n",
    "    print(\"Making API call to Claude for concept substitution...\")\n",
    "    \n",
    "    # Create the message with thinking\n",
    "    response = client.messages.create(\n",
    "        model=\"claude-3-7-sonnet-20250219\", # Using Claude 3.7 Sonnet as specified in your code\n",
    "        max_tokens=20000,\n",
    "        thinking={\n",
    "            \"type\": \"enabled\",\n",
    "            \"budget_tokens\": 18000\n",
    "        },\n",
    "        messages=[{\n",
    "            \"role\": \"user\",\n",
    "            \"content\": prompt\n",
    "        }]\n",
    "    )\n",
    "    \n",
    "    # Extract the content from the response using the extraction method\n",
    "    response_content = extract_text_from_response(response)\n",
    "    \n",
    "    # Try to extract the JSON data using regex\n",
    "    try:\n",
    "        # Find JSON content in the response (anything between { and })\n",
    "        json_match = re.search(r'({[\\s\\S]*})', response_content)\n",
    "        if json_match:\n",
    "            json_str = json_match.group(1)\n",
    "            # Parse the JSON data\n",
    "            response_json = json.loads(json_str)\n",
    "            \n",
    "            # Extract real concepts\n",
    "            real_concepts = response_json.get(\"Real concepts assigned to variables\", [])\n",
    "            concepts = [concept.split(\": \")[1] for concept in real_concepts]\n",
    "            \n",
    "            return response_json, concepts\n",
    "    except Exception as e:\n",
    "        print(f\"Error processing response: {e}\")\n",
    "        print(\"Raw response content:\")\n",
    "        print(response_content[:500] + \"... [truncated]\")\n",
    "    \n",
    "    # Fallback in case of JSON parsing error\n",
    "    print(\"Failed to parse response as JSON. Using fallback approach.\")\n",
    "    \n",
    "    # Simple regex-based extraction of concepts if JSON parsing fails\n",
    "    concepts = []\n",
    "    concept_pattern = r\"Node (\\d+): (.+?)(?:\\n|$)\"\n",
    "    matches = re.findall(concept_pattern, response_content)\n",
    "    \n",
    "    if matches:\n",
    "        for node, concept in sorted(matches, key=lambda x: int(x[0])):\n",
    "            concepts.append(concept)\n",
    "    \n",
    "    # Create a basic response structure\n",
    "    response_json = {\n",
    "        \"Real concepts assigned to variables\": [f\"Node {i}: {concept}\" for i, concept in enumerate(concepts)] if concepts else [],\n",
    "        \"Domain\": [domain]\n",
    "    }\n",
    "    \n",
    "    return response_json, concepts"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-05-20T05:33:47.563399200Z",
     "start_time": "2025-05-20T05:33:47.542954100Z"
    }
   },
   "id": "ebb8049e903c2475"
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Example from the figure of workflow\n",
    "\n",
    "For this example, we'll use the concepts directly from the figure, which are:\n",
    "- Node 0: Study\n",
    "- Node 1: Talent\n",
    "- Node 2: Knowledge\n",
    "- Node 3: Skill\n",
    "- Node 4: Success\n",
    "\n",
    "In a real implementation, these concepts would be generated by the LLM through the API call."
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "4e6d39d698390ce2"
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Domain: Education\n",
      "\n",
      "Concepts assigned to variables:\n",
      "  Node 0: Study\n",
      "  Node 1: Talent\n",
      "  Node 2: Knowledge\n",
      "  Node 3: Skill\n",
      "  Node 4: Success\n",
      "\n",
      "Verification for a relationship:\n",
      "If Study did not occur, Knowledge would significantly change. Without dedicated study efforts, individuals would not acquire the same depth or breadth of knowledge, indicating a direct causal relationship.\n"
     ]
    }
   ],
   "source": [
    "# For this notebook, instead of making actual API calls which would require an API key,\n",
    "# we'll use the example from the paper to demonstrate the concept\n",
    "# In a real scenario, you would use the actual function above\n",
    "\n",
    "# Example concepts from Figure 1 in the paper\n",
    "paper_example_concepts_response = {\n",
    "    \"Existing causal relationships (values of 1 in the matrix)\": [\n",
    "        \"Node 0 → Node 2\", \n",
    "        \"Node 1 → Node 3\", \n",
    "        \"Node 2 → Node 3\", \n",
    "        \"Node 2 → Node 4\", \n",
    "        \"Node 3 → Node 4\"\n",
    "    ],\n",
    "    \"Non-existing causal relationships (values of 0 in the matrix)\": [\n",
    "        \"Node 0 → Node 1\",\n",
    "        \"Node 0 → Node 3\", \n",
    "        \"Node 0 → Node 4\", \n",
    "        \"Node 1 → Node 0\", \n",
    "        \"Node 1 → Node 2\", \n",
    "        \"Node 1 → Node 4\", \n",
    "        \"Node 2 → Node 0\", \n",
    "        \"Node 2 → Node 1\", \n",
    "        \"Node 3 → Node 0\", \n",
    "        \"Node 3 → Node 1\", \n",
    "        \"Node 3 → Node 2\"\n",
    "    ],\n",
    "    \"Domain\": [\n",
    "        \"Education\"\n",
    "    ],\n",
    "    \"Real concepts assigned to variables\": [\n",
    "        \"Node 0: Study\",\n",
    "        \"Node 1: Talent\",\n",
    "        \"Node 2: Knowledge\",\n",
    "        \"Node 3: Skill\",\n",
    "        \"Node 4: Success\"\n",
    "    ],\n",
    "    \"Relationship verification\": {\n",
    "        \"Existing causal relationships\": [\n",
    "            \"If Study did not occur, Knowledge would significantly change. Without dedicated study efforts, individuals would not acquire the same depth or breadth of knowledge, indicating a direct causal relationship.\",\n",
    "            \"If Talent was absent, Skill development would be substantially different. Natural talents provide a foundation upon which skills are built, and without these inherent abilities, the same level or quality of skills would not develop under otherwise identical conditions.\",\n",
    "            \"If Knowledge was not present, Skill development would be significantly impaired. Knowledge provides the theoretical foundation necessary for developing practical skills, and without this foundation, skills would not develop to the same degree or efficiency.\",\n",
    "            \"If Knowledge was absent, Success would be substantially diminished. Knowledge is a direct contributor to successful outcomes, and without it, individuals would lack critical information needed to achieve success, even with other factors being equal.\",\n",
    "            \"If Skill was not present, Success would be significantly reduced. Skills represent the practical abilities needed to implement knowledge and achieve objectives, and without these abilities, success would be demonstrably lower even with all other factors remaining constant.\"\n",
    "        ],\n",
    "        \"Non-existing causal relationships\": [\n",
    "            \"Study does not directly cause Talent. If studying were to cease, natural talents would remain largely unchanged, as talents typically reflect inherent abilities rather than directly resulting from study activities.\"\n",
    "        ]\n",
    "    }\n",
    "}\n",
    "\n",
    "paper_example_concepts = [\"Study\", \"Talent\", \"Knowledge\", \"Skill\", \"Success\"]\n",
    "\n",
    "# In actual usage, you would use:\n",
    "# concept_substitution_result, concepts = concept_substitution(adjacency_matrix, domain=\"Education\")\n",
    "# But for the demonstration notebook without API key requirement:\n",
    "concept_substitution_result, concepts = paper_example_concepts_response, paper_example_concepts\n",
    "\n",
    "# Display the results\n",
    "print(f\"Domain: {concept_substitution_result['Domain'][0]}\\n\")\n",
    "print(\"Concepts assigned to variables:\")\n",
    "for concept in concept_substitution_result[\"Real concepts assigned to variables\"]:\n",
    "    print(f\"  {concept}\")\n",
    "print(\"\\nVerification for a relationship:\")\n",
    "if concept_substitution_result[\"Relationship verification\"][\"Existing causal relationships\"]:\n",
    "    print(concept_substitution_result[\"Relationship verification\"][\"Existing causal relationships\"][0])"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-05-20T05:34:38.776611900Z",
     "start_time": "2025-05-20T05:34:38.754609400Z"
    }
   },
   "id": "b33b58017a6b7077"
  },
  {
   "cell_type": "markdown",
   "source": [
    "## 4. Phase 3: Text Generation\n",
    "\n",
    "In Phase 3, we generate text through an inverse design methodology that transforms causal graphs with real-world concepts into natural language text while preserving the causal structure. \n",
    "\n",
    "This phase uses the same inverse design CoT approach as Phase 2, but focuses on generating text that implicitly embeds all causal relationships defined in the adjacency matrix without introducing spurious relationships.\n"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "88bea8eb5a0f04c8"
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "outputs": [],
   "source": [
    "def text_generation(adjacency_matrix, concepts):\n",
    "    \"\"\"\n",
    "    Generate text that implicitly encodes causal relationships between concepts\n",
    "    \n",
    "    This function implements the causal structure-preserving textual transformation\n",
    "    using LLM with Chain-of-Thought prompting.\n",
    "    \"\"\"\n",
    "    # Format real concepts array\n",
    "    real_concepts = [f\"Node {i}: {concept}\" for i, concept in enumerate(concepts)]\n",
    "    \n",
    "    # Format the matrix for display in the prompt\n",
    "    matrix_str = \"\\n\".join([str(row.tolist()) for row in adjacency_matrix])\n",
    "    \n",
    "    # Format concepts for display in the prompt\n",
    "    concepts_str = json.dumps(real_concepts, ensure_ascii=False, indent=2)\n",
    "    \n",
    "    # Construct the prompt based on the original iTAG implementation\n",
    "    prompt = f\"\"\"\n",
    "Concepts:\n",
    "{concepts_str}\n",
    "\n",
    "Adjacency matrix between concepts:\n",
    "{matrix_str}\n",
    "\n",
    "Task: Please express all concepts clearly in a paragraph of natural language (implicitly conveying relationships between concepts rather than explicitly stating them), without introducing any additional concepts.\n",
    "\n",
    "Requirements: In your thinking, please use the following separators to assist your reasoning, and only output the final result when you are satisfied with it:\n",
    "----Let me first analyze carefully---- \n",
    "(Which relationships between concepts should be indirectly described and which should not appear)\n",
    "----First attempt---- \n",
    "(Try writing your paragraph)\n",
    "----Check for implicitness---- \n",
    "(Even though all concepts appear in this paragraph, the causal relationships between them are not clearly stated, ensuring readers must make their own judgments)\n",
    "----Check for errors---- \n",
    "(Check if the description avoids expressing relationships that don't exist, i.e., 0s in the matrix. If the description is not rigorous or not implicit, consider the reasons and begin a second analysis)\n",
    "Begin second analysis\n",
    "----Second attempt---- \n",
    "...\n",
    "\n",
    "Your answer should be in JSON format:\n",
    "{{\n",
    "  \"Natural language description\": \"...\"\n",
    "}}\n",
    "\"\"\"\n",
    "    \n",
    "    # Initialize the Anthropic client - in a real scenario, you would use your own API key\n",
    "    # For this notebook, we're using a placeholder API key\n",
    "    # YOU SHOULD REPLACE THIS WITH YOUR ACTUAL API KEY WHEN RUNNING THE NOTEBOOK\n",
    "    client = anthropic.Anthropic(\n",
    "        api_key=\"YOUR_API_KEY_HERE\",  # Replace with actual API key\n",
    "    )\n",
    "    \n",
    "    print(\"Making API call to Claude for text generation...\")\n",
    "    \n",
    "    # Create the message with thinking - exactly matching your code\n",
    "    response = client.messages.create(\n",
    "        model=\"claude-3-7-sonnet-20250219\", # Using Claude 3.7 Sonnet as in your code\n",
    "        max_tokens=20000,\n",
    "        thinking={\n",
    "            \"type\": \"enabled\",\n",
    "            \"budget_tokens\": 18000\n",
    "        },\n",
    "        messages=[{\n",
    "            \"role\": \"user\",\n",
    "            \"content\": prompt\n",
    "        }]\n",
    "    )\n",
    "    \n",
    "    # Extract the content using the extraction method\n",
    "    response_content = extract_text_from_response(response)\n",
    "    \n",
    "    # Try to extract the JSON data using regex\n",
    "    try:\n",
    "        # Find JSON content in the response (anything between { and })\n",
    "        json_match = re.search(r'({[\\s\\S]*})', response_content)\n",
    "        if json_match:\n",
    "            json_str = json_match.group(1)\n",
    "            # Parse the JSON data\n",
    "            response_json = json.loads(json_str)\n",
    "            return response_json\n",
    "    except Exception as e:\n",
    "        print(f\"Error processing response: {e}\")\n",
    "        print(\"Raw response content:\")\n",
    "        print(response_content[:500] + \"... [truncated]\")\n",
    "    \n",
    "    # Fallback in case of JSON parsing error\n",
    "    print(\"Failed to parse response as JSON. Using fallback approach.\")\n",
    "    \n",
    "    # Create a basic response with whatever text was generated\n",
    "    return {\n",
    "        \"Natural language description\": response_content\n",
    "    }"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-05-20T05:35:14.282052300Z",
     "start_time": "2025-05-20T05:35:14.263541800Z"
    }
   },
   "id": "6f7e7d0f8adfbf31"
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Example from the figure of workflow\n",
    "\n",
    "For this example, we'll use the text directly from the figure of workflow:\n",
    "\n",
    "\"Through effort of studying, individuals acquire knowledge while developing skills enhanced by their natural talents. Knowledge and skills reciprocally enhance one another, and those who simultaneously possess knowledge and refined skills typically achieve success.\"\n",
    "\n",
    "In a real implementation, this text would be generated by the LLM through the API call."
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "b7e9c0aa5b03172b"
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Generated Text:\n",
      "--------------------------------------------------------------------------------\n",
      "Through effort of studying, individuals acquire knowledge while developing skills enhanced by their natural talents. Knowledge and skills reciprocally enhance one another, and those who simultaneously possess knowledge and refined skills typically achieve success.\n",
      "--------------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "# Example text from Figure 1 in the paper\n",
    "paper_example_text_response = {\n",
    "    \"Natural language description\": \"Through effort of studying, individuals acquire knowledge while developing skills enhanced by their natural talents. Knowledge and skills reciprocally enhance one another, and those who simultaneously possess knowledge and refined skills typically achieve success.\"\n",
    "}\n",
    "\n",
    "# In actual usage, you would use:\n",
    "# text_generation_result = text_generation(adjacency_matrix, concepts)\n",
    "# But for the demonstration notebook without API key requirement:\n",
    "text_generation_result = paper_example_text_response\n",
    "\n",
    "# Display the generated text\n",
    "print(\"\\nGenerated Text:\")\n",
    "print(\"-\" * 80)\n",
    "print(text_generation_result[\"Natural language description\"])\n",
    "print(\"-\" * 80)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-05-20T05:35:46.587940400Z",
     "start_time": "2025-05-20T05:35:46.576145400Z"
    }
   },
   "id": "c19bef9aa19907c3"
  },
  {
   "cell_type": "markdown",
   "source": [
    "## 5. Complete Example: Text with Causal Graph\n",
    "\n",
    "Now we can put all three phases together to demonstrate the complete iTAG workflow:\n",
    "\n",
    "1. Generate a causal graph with controlled complexity\n",
    "2. Assign real-world concepts to the nodes in the graph\n",
    "3. Generate text that implicitly encodes the causal relationships"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "87b47f150fd4c1ff"
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 1000x600 with 1 Axes>",
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iTAG Example Summary (from Figure 1 in the paper):\n",
      "--------------------------------------------------------------------------------\n",
      "Causal Graph (Adjacency Matrix):\n",
      "[[0 0 1 0 0]\n",
      " [0 0 0 1 0]\n",
      " [0 0 0 1 1]\n",
      " [0 0 0 0 1]\n",
      " [0 0 0 0 0]]\n",
      "\n",
      "Real-world Concepts:\n",
      "  Node 0: Study\n",
      "  Node 1: Talent\n",
      "  Node 2: Knowledge\n",
      "  Node 3: Skill\n",
      "  Node 4: Success\n",
      "\n",
      "Generated Text:\n",
      "Through effort of studying, individuals acquire knowledge while developing skills enhanced by their natural talents. Knowledge and skills reciprocally enhance one another, and those who simultaneously possess knowledge and refined skills typically achieve success.\n",
      "--------------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "# Visualize the final result\n",
    "import matplotlib.pyplot as plt\n",
    "import networkx as nx\n",
    "\n",
    "# Recreate the graph with concept labels\n",
    "G_labeled = nx.DiGraph()\n",
    "for i, concept in enumerate(concepts):\n",
    "    G_labeled.add_node(i, label=concept)\n",
    "\n",
    "# Add edges\n",
    "for i in range(len(adjacency_matrix)):\n",
    "    for j in range(len(adjacency_matrix)):\n",
    "        if adjacency_matrix[i][j] == 1:\n",
    "            G_labeled.add_edge(i, j)\n",
    "\n",
    "# Visualize\n",
    "plt.figure(figsize=(10, 6))\n",
    "pos = nx.spring_layout(G_labeled, seed=42)  # Consistent layout\n",
    "node_labels = {node: G_labeled.nodes[node]['label'] for node in G_labeled.nodes}\n",
    "nx.draw(G_labeled, pos, with_labels=False, node_color='lightblue', \n",
    "        node_size=2000, arrowsize=20)\n",
    "nx.draw_networkx_labels(G_labeled, pos, labels=node_labels, font_size=10)\n",
    "plt.title(\"Causal Graph with Assigned Concepts\")\n",
    "plt.show()\n",
    "\n",
    "# Print the summary\n",
    "print(\"iTAG Example Summary (from Figure 1 in the paper):\")\n",
    "print(\"-\" * 80)\n",
    "print(\"Causal Graph (Adjacency Matrix):\")\n",
    "print(adjacency_matrix)\n",
    "print(\"\\nReal-world Concepts:\")\n",
    "for i, concept in enumerate(concepts):\n",
    "    print(f\"  Node {i}: {concept}\")\n",
    "print(\"\\nGenerated Text:\")\n",
    "print(text_generation_result[\"Natural language description\"])\n",
    "print(\"-\" * 80)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-05-20T05:36:34.795776300Z",
     "start_time": "2025-05-20T05:36:34.684449200Z"
    }
   },
   "id": "c4522e704af76242"
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
