{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-04-04T10:23:49.363926Z",
     "start_time": "2025-04-04T10:23:46.207738Z"
    }
   },
   "outputs": [],
   "source": [
    "from ar import ActivationReasoning\n",
    "import os\n",
    "from ar import LogicConfig\n",
    "\n",
    "rules = {\n",
    "    (\"Tower\", \"Paris\", \"France\"): \"Eiffel Tower\",\n",
    "    (\"Mausoleum\", \"Agra\", \"India\"): \"Taj Mahal\",\n",
    "    (\"Skyscraper\", \"Dubai\", \"United Arab Emirates\"): \"Burj Khalifa\",\n",
    "    (\"Opera\", \"Sydney\", \"Australia\"): \"Sydney Opera House\",\n",
    "    (\"Skyscraper\", \"New York\", \"United States\"): \"Empire State Building\",\n",
    "    (\"Church\", \"Barcelona\", \"Spain\"): \"Sagrada Familia\",\n",
    "    (\"Temple\", \"Athens\", \"Greece\"): \"Parthenon\",\n",
    "    (\"Tower\", \"Pisa\", \"Italy\"): \"Leaning Tower of Pisa\",\n",
    "    (\"Tower\", \"Toronto\", \"Canada\"): \"CN Tower\",\n",
    "    (\"Bridge\", \"San Francisco\", \"United States\"): \"Golden Gate Bridge\",\n",
    "}\n",
    "concepts = sorted( list(set([k for key in rules.keys() for k in key]))) \n",
    "data = [\n",
    "    \"The Eiffel Tower, designed by Gustave Eiffel, was completed in 1889 as the entrance arch for the World's Fair in Paris, France.\",\n",
    "    \"Standing at 330 meters tall, the Eiffel Tower was the world's tallest man-made structure for 41 years until the Chrysler Building was constructed in New York, United States.\",\n",
    "    \"The Eiffel Tower attracts nearly 7 million visitors annually, making it the most-visited paid monument in the world.\",\n",
    "    \"The Tokyo Tower is a communications and observation tower in Tokyo, Japan.\"\n",
    "    \"The Chrysler Building is an Art Deco skyscraper located in Midtown Manhattan, New York, United States.\",\n",
    "    ]\n",
    "\n",
    "\n",
    "# Wikipedia data\n",
    "_path = f'data/eiffel_tower_wikipedia.txt'\n",
    "with open(_path, 'r') as f:\n",
    "    _txt = f.read()\n",
    "# remove empty sentences\n",
    "wikipedia = [s.strip() for s in _txt.split('.') if s.strip()]\n",
    "# remove sentences that are too long\n",
    "wikipedia = [s for s in wikipedia if len(s.split()) < 500 and len(s.split()) > 10]\n",
    "\n",
    "# Replicas data\n",
    "_path = f'data/eiffel_tower_replicas.txt'\n",
    "with open(_path, 'r') as f:\n",
    "    _txt = f.read()\n",
    "    \n",
    "# split the text into eifel_sentences\n",
    "replicas = {e_t.split('\\n')[0].strip(): e_t.split('\\n')[1].strip() for e_t in _txt.split('• ')[1:] if 'france' not in e_t.lower() and 'paris' not in e_t.lower()}\n",
    "\n",
    "# Replicas data 2\n",
    "_path = f'data/eiffel_tower_replicas2.txt'\n",
    "with open(_path, 'r') as f:\n",
    "    _txt = f.read()\n",
    "\n",
    "replicas2 = []\n",
    "# split the text into eifel_sentences\n",
    "for s in _txt.split('\\n'):\n",
    "    s = s.strip()\n",
    "    if len(s) > 100:\n",
    "        replicas2.append(s)\n",
    "\n",
    "# most_famous_buildings data\n",
    "most_famous_buildings_path = f'data/most_famous_buildings.txt'\n",
    "with open(most_famous_buildings_path, 'r') as f:\n",
    "    most_famous_buildings = f.read()\n",
    "    \n",
    "# split the text into eifel_sentences\n",
    "most_famous_buildings = [s.strip() for s in most_famous_buildings.split('\\n') if s.strip()]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------------Activation Logic--------------------\n",
      "--- Activation Logic Configuration ---\n",
      "AL-SEARCH:    type=word, token=last, strategy=top_k, top_k_order=original_order, top_k=10, (tree_depth=15)\n",
      "AL-DETECTION: top_k_output=2, top_k_concepts=1, allow_multi=False, threshold=1e-08\n",
      "AL-STEERING:  factor=0.5, weighting=log_decay, top_k_rule=10, norm=2, methodology=sum_shift\n",
      "AL-REASONER:  rule_checking=legacy\n",
      "--------------------Loading model and SAE--------------------\n",
      "Loading model meta-llama/Meta-Llama-3.1-8B and SAE EleutherAI/sae-llama-3.1-8b-64x\n",
      "AL Cache directory: output/experiments/eiffeltower/v1.0/sae_latents/sae-llama-3.1-8b-64x\n",
      "Eleuther Sparsify Engine is used\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Fetching 2 files: 100%|██████████| 2/2 [00:00<00:00, 52.88it/s]\n",
      "Loading checkpoint shards: 100%|██████████| 4/4 [00:13<00:00,  3.35s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------------Logic Component:--------------------\n",
      "Rules:\n",
      "  (Tower ∧ (Paris ∧ France))\n",
      "  (Mausoleum ∧ (Agra ∧ India))\n",
      "  (Skyscraper ∧ (Dubai ∧ United Arab Emirates))\n",
      "  (Opera ∧ (Sydney ∧ Australia))\n",
      "  (Skyscraper ∧ (New York ∧ United States))\n",
      "  (Church ∧ (Barcelona ∧ Spain))\n",
      "  (Temple ∧ (Athens ∧ Greece))\n",
      "  (Tower ∧ (Pisa ∧ Italy))\n",
      "  (Tower ∧ (Toronto ∧ Canada))\n",
      "  (Bridge ∧ (San Francisco ∧ United States))\n",
      "Concepts: ['Agra', 'Athens', 'Australia', 'Barcelona', 'Bridge', 'Canada', 'Church', 'Dubai', 'France', 'Greece', 'India', 'Italy', 'Mausoleum', 'New York', 'Opera', 'Paris', 'Pisa', 'San Francisco', 'Skyscraper', 'Spain', 'Sydney', 'Temple', 'Toronto', 'Tower', 'United Arab Emirates', 'United States']\n",
      "--------------------AL-Reasoner Component:--------------------\n",
      "The reasoner uses 'legacy' config for rule checking.\n",
      "  (Tower ∧ (Paris ∧ France))\n",
      "  (Mausoleum ∧ (Agra ∧ India))\n",
      "  (Skyscraper ∧ (Dubai ∧ United Arab Emirates))\n",
      "  (Opera ∧ (Sydney ∧ Australia))\n",
      "  (Skyscraper ∧ (New York ∧ United States))\n",
      "  (Church ∧ (Barcelona ∧ Spain))\n",
      "  (Temple ∧ (Athens ∧ Greece))\n",
      "  (Tower ∧ (Pisa ∧ Italy))\n",
      "  (Tower ∧ (Toronto ∧ Canada))\n",
      "  (Bridge ∧ (San Francisco ∧ United States))\n",
      "--------------------End of AL-Reasoner Component--------------------\n",
      "Cache for concepts found. Loading detector...\n",
      "Greedy concept search (top-k concepts =10, original_order)\n",
      "original_order\n",
      "--------------------AL Gready Concepts--------------------\n",
      "Concept Overview (strategy: original_order):\n",
      "Agra                      \u001b[92m 65797\u001b[0m, \u001b[92m 55002\u001b[0m, \u001b[38;5;208m 46923\u001b[0m, \u001b[92m 13721\u001b[0m, \u001b[38;5;208m 62355\u001b[0m, \u001b[92m 81031\u001b[0m, \u001b[38;5;208m  4937\u001b[0m, \u001b[38;5;208m257875\u001b[0m, \u001b[38;5;208m187029\u001b[0m, \u001b[92m172221\u001b[0m\n",
      "Athens                    \u001b[92m202253\u001b[0m, \u001b[92m116894\u001b[0m, \u001b[92m228144\u001b[0m, \u001b[38;5;208m  4606\u001b[0m, \u001b[38;5;208m257875\u001b[0m, \u001b[92m231282\u001b[0m, \u001b[92m157460\u001b[0m, \u001b[38;5;208m 77805\u001b[0m, \u001b[38;5;208m114466\u001b[0m, \u001b[38;5;208m182978\u001b[0m\n",
      "Australia                 \u001b[92m 26525\u001b[0m, \u001b[38;5;208m233989\u001b[0m, \u001b[38;5;208m217691\u001b[0m, \u001b[92m164745\u001b[0m, \u001b[38;5;208m190687\u001b[0m, \u001b[92m228944\u001b[0m, \u001b[92m247012\u001b[0m, \u001b[92m182896\u001b[0m, \u001b[92m 68821\u001b[0m, \u001b[38;5;208m 42972\u001b[0m\n",
      "Barcelona                 \u001b[92m 87485\u001b[0m, \u001b[92m 76767\u001b[0m, \u001b[38;5;208m 97954\u001b[0m, \u001b[92m189961\u001b[0m, \u001b[38;5;208m  4606\u001b[0m, \u001b[38;5;208m257875\u001b[0m, \u001b[38;5;208m217691\u001b[0m, \u001b[92m219419\u001b[0m, \u001b[92m119063\u001b[0m, \u001b[38;5;208m182978\u001b[0m\n",
      "Bridge                    \u001b[92m152595\u001b[0m, \u001b[92m 76437\u001b[0m, \u001b[38;5;208m100697\u001b[0m, \u001b[38;5;208m117397\u001b[0m, \u001b[92m222518\u001b[0m, \u001b[38;5;208m 98480\u001b[0m, \u001b[92m125722\u001b[0m, \u001b[92m132889\u001b[0m, \u001b[92m127990\u001b[0m, \u001b[92m 77348\u001b[0m\n",
      "Canada                    \u001b[92m173179\u001b[0m, \u001b[38;5;208m233989\u001b[0m, \u001b[92m 24625\u001b[0m, \u001b[92m112066\u001b[0m, \u001b[38;5;208m187029\u001b[0m, \u001b[38;5;208m241611\u001b[0m, \u001b[38;5;208m241809\u001b[0m, \u001b[38;5;208m     7\u001b[0m, \u001b[38;5;208m     3\u001b[0m, \u001b[38;5;208m     8\u001b[0m\n",
      "Church                    \u001b[38;5;208m     8\u001b[0m, \u001b[38;5;208m     9\u001b[0m, \u001b[38;5;208m     4\u001b[0m, \u001b[38;5;208m     7\u001b[0m, \u001b[38;5;208m     5\u001b[0m, \u001b[38;5;208m     3\u001b[0m, \u001b[38;5;208m     1\u001b[0m, \u001b[38;5;208m     0\u001b[0m, \u001b[38;5;208m     2\u001b[0m, \u001b[38;5;208m     6\u001b[0m\n",
      "Dubai                     \u001b[92m 72339\u001b[0m, \u001b[92m160625\u001b[0m, \u001b[92m100065\u001b[0m, \u001b[92m 29236\u001b[0m, \u001b[92m135239\u001b[0m, \u001b[38;5;208m 97954\u001b[0m, \u001b[92m189306\u001b[0m, \u001b[38;5;208m257875\u001b[0m, \u001b[92m  3549\u001b[0m, \u001b[38;5;208m 88724\u001b[0m\n",
      "France                    \u001b[92m 57497\u001b[0m, \u001b[92m216925\u001b[0m, \u001b[38;5;208m233989\u001b[0m, \u001b[38;5;208m250419\u001b[0m, \u001b[38;5;208m190687\u001b[0m, \u001b[38;5;208m217691\u001b[0m, \u001b[38;5;208m142430\u001b[0m, \u001b[38;5;208m 42972\u001b[0m, \u001b[92m148111\u001b[0m, \u001b[38;5;208m112638\u001b[0m\n",
      "Greece                    \u001b[92m 89046\u001b[0m, \u001b[92m204608\u001b[0m, \u001b[38;5;208m233989\u001b[0m, \u001b[38;5;208m112638\u001b[0m, \u001b[38;5;208m217691\u001b[0m, \u001b[38;5;208m190687\u001b[0m, \u001b[38;5;208m250419\u001b[0m, \u001b[38;5;208m242704\u001b[0m, \u001b[92m 16889\u001b[0m, \u001b[38;5;208m 77805\u001b[0m\n",
      "India                     \u001b[92m185336\u001b[0m, \u001b[38;5;208m233989\u001b[0m, \u001b[38;5;208m242704\u001b[0m, \u001b[38;5;208m241611\u001b[0m, \u001b[38;5;208m 42972\u001b[0m, \u001b[38;5;208m187029\u001b[0m, \u001b[92m 12116\u001b[0m, \u001b[38;5;208m112638\u001b[0m, \u001b[38;5;208m190687\u001b[0m, \u001b[92m249581\u001b[0m\n",
      "Italy                     \u001b[92m 96387\u001b[0m, \u001b[38;5;208m233989\u001b[0m, \u001b[92m211866\u001b[0m, \u001b[38;5;208m 42972\u001b[0m, \u001b[38;5;208m190687\u001b[0m, \u001b[38;5;208m112638\u001b[0m, \u001b[38;5;208m 70098\u001b[0m, \u001b[38;5;208m242704\u001b[0m, \u001b[38;5;208m250419\u001b[0m, \u001b[92m191270\u001b[0m\n",
      "Mausoleum                 \u001b[38;5;208m100697\u001b[0m, \u001b[92m210334\u001b[0m, \u001b[92m203539\u001b[0m, \u001b[92m173920\u001b[0m, \u001b[38;5;208m 16394\u001b[0m, \u001b[92m 71783\u001b[0m, \u001b[38;5;208m     7\u001b[0m, \u001b[38;5;208m     3\u001b[0m, \u001b[38;5;208m     8\u001b[0m, \u001b[38;5;208m     1\u001b[0m\n",
      "New York                  \u001b[92m163968\u001b[0m, \u001b[92m166404\u001b[0m, \u001b[92m 44326\u001b[0m, \u001b[92m 10599\u001b[0m, \u001b[38;5;208m114466\u001b[0m, \u001b[38;5;208m212294\u001b[0m, \u001b[38;5;208m242704\u001b[0m, \u001b[92m179873\u001b[0m, \u001b[38;5;208m257875\u001b[0m, \u001b[38;5;208m236211\u001b[0m\n",
      "Opera                     \u001b[92m 47740\u001b[0m, \u001b[92m120030\u001b[0m, \u001b[92m192223\u001b[0m, \u001b[92m225951\u001b[0m, \u001b[92m 88374\u001b[0m, \u001b[38;5;208m135362\u001b[0m, \u001b[92m 56288\u001b[0m, \u001b[92m 19068\u001b[0m, \u001b[38;5;208m183851\u001b[0m, \u001b[92m  8029\u001b[0m\n",
      "Paris                     \u001b[92m179833\u001b[0m, \u001b[92m 43005\u001b[0m, \u001b[92m141509\u001b[0m, \u001b[38;5;208m114466\u001b[0m, \u001b[38;5;208m257875\u001b[0m, \u001b[38;5;208m  4606\u001b[0m, \u001b[38;5;208m182978\u001b[0m, \u001b[92m 43025\u001b[0m, \u001b[92m129508\u001b[0m, \u001b[92m103258\u001b[0m\n",
      "Pisa                      \u001b[92m112355\u001b[0m, \u001b[38;5;208m 62355\u001b[0m, \u001b[92m149250\u001b[0m, \u001b[38;5;208m 46923\u001b[0m, \u001b[92m151248\u001b[0m, \u001b[92m 14954\u001b[0m, \u001b[92m147384\u001b[0m, \u001b[92m225021\u001b[0m, \u001b[92m 34169\u001b[0m, \u001b[38;5;208m187029\u001b[0m\n",
      "San Francisco             \u001b[92m 89060\u001b[0m, \u001b[92m 14740\u001b[0m, \u001b[92m227514\u001b[0m, \u001b[38;5;208m 62355\u001b[0m, \u001b[38;5;208m114466\u001b[0m, \u001b[38;5;208m257875\u001b[0m, \u001b[38;5;208m  4937\u001b[0m, \u001b[92m 11009\u001b[0m, \u001b[92m 22683\u001b[0m, \u001b[38;5;208m140946\u001b[0m\n",
      "Skyscraper                \u001b[38;5;208m241809\u001b[0m, \u001b[92m 68324\u001b[0m, \u001b[92m115774\u001b[0m, \u001b[38;5;208m100697\u001b[0m, \u001b[38;5;208m140946\u001b[0m, \u001b[92m 19900\u001b[0m, \u001b[38;5;208m 97212\u001b[0m, \u001b[38;5;208m     7\u001b[0m, \u001b[38;5;208m     3\u001b[0m, \u001b[38;5;208m     8\u001b[0m\n",
      "Spain                     \u001b[92m 64231\u001b[0m, \u001b[38;5;208m233989\u001b[0m, \u001b[92m106551\u001b[0m, \u001b[38;5;208m 70098\u001b[0m, \u001b[38;5;208m190687\u001b[0m, \u001b[38;5;208m250419\u001b[0m, \u001b[38;5;208m217691\u001b[0m, \u001b[38;5;208m142430\u001b[0m, \u001b[38;5;208m 10764\u001b[0m, \u001b[38;5;208m112638\u001b[0m\n",
      "Sydney                    \u001b[92m243037\u001b[0m, \u001b[92m 99652\u001b[0m, \u001b[38;5;208m135362\u001b[0m, \u001b[38;5;208m183851\u001b[0m, \u001b[92m109501\u001b[0m, \u001b[92m 63035\u001b[0m, \u001b[38;5;208m 62355\u001b[0m, \u001b[38;5;208m257875\u001b[0m, \u001b[92m 27879\u001b[0m, \u001b[38;5;208m114466\u001b[0m\n",
      "Temple                    \u001b[38;5;208m     8\u001b[0m, \u001b[38;5;208m     9\u001b[0m, \u001b[38;5;208m     4\u001b[0m, \u001b[38;5;208m     7\u001b[0m, \u001b[38;5;208m     5\u001b[0m, \u001b[38;5;208m     3\u001b[0m, \u001b[38;5;208m     1\u001b[0m, \u001b[38;5;208m     0\u001b[0m, \u001b[38;5;208m     2\u001b[0m, \u001b[38;5;208m     6\u001b[0m\n",
      "Toronto                   \u001b[92m 29116\u001b[0m, \u001b[92m 75649\u001b[0m, \u001b[92m 49231\u001b[0m, \u001b[92m236411\u001b[0m, \u001b[92m 12900\u001b[0m, \u001b[38;5;208m 88724\u001b[0m, \u001b[38;5;208m212294\u001b[0m, \u001b[38;5;208m 62355\u001b[0m, \u001b[38;5;208m187029\u001b[0m, \u001b[92m 92928\u001b[0m\n",
      "Tower                     \u001b[38;5;208m 97212\u001b[0m, \u001b[38;5;208m100697\u001b[0m, \u001b[38;5;208m117397\u001b[0m, \u001b[38;5;208m 16394\u001b[0m, \u001b[92m150223\u001b[0m, \u001b[92m 38624\u001b[0m, \u001b[92m225929\u001b[0m, \u001b[38;5;208m 98480\u001b[0m, \u001b[92m  4481\u001b[0m, \u001b[38;5;208m140946\u001b[0m\n",
      "United Arab Emirates      \u001b[92m 15753\u001b[0m, \u001b[38;5;208m233989\u001b[0m, \u001b[38;5;208m142430\u001b[0m, \u001b[38;5;208m 70098\u001b[0m, \u001b[38;5;208m250419\u001b[0m, \u001b[38;5;208m190687\u001b[0m, \u001b[92m189757\u001b[0m, \u001b[38;5;208m 10764\u001b[0m, \u001b[92m245000\u001b[0m, \u001b[92m232006\u001b[0m\n",
      "United States             \u001b[92m117887\u001b[0m, \u001b[92m 98350\u001b[0m, \u001b[38;5;208m250419\u001b[0m, \u001b[38;5;208m233989\u001b[0m, \u001b[38;5;208m190687\u001b[0m, \u001b[38;5;208m 70098\u001b[0m, \u001b[38;5;208m142430\u001b[0m, \u001b[38;5;208m236211\u001b[0m, \u001b[92m 96522\u001b[0m, \u001b[92m 30664\u001b[0m\n",
      "Color legend: \u001b[92m■\u001b[0m unique, \u001b[38;5;208m■\u001b[0m duplicate\n",
      "--------------------End of AL initalization--------------------\n"
     ]
    }
   ],
   "source": [
    "llama3_1 = {\n",
    "'model_name': \"meta-llama/Meta-Llama-3.1-8B\",\n",
    "'sae_name': \"EleutherAI/sae-llama-3.1-8b-64x\",\n",
    "'layer': 23,\n",
    "'hookpoint': 'layers.23'\n",
    "}\n",
    "\n",
    "experiment_dir = 'output/experiments/eiffeltower/v1.0'\n",
    "os.makedirs(experiment_dir, exist_ok=True)\n",
    "ar_model = ActivationReasoning(\n",
    "    rules=rules,\n",
    "    concepts=concepts,\n",
    "    cache_dir=f\"{experiment_dir}/sae_latents\",\n",
    "    **llama3_1,\n",
    "    config=LogicConfig(search_top_k_order='original_order'),\n",
    "    verbose=True,\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cached concepts already exist. If you want to reset the cache, set 'reset_cache=False'.\n",
      "  -> Cached Concepts: ['Agra', 'Athens', 'Australia', 'Barcelona', 'Bridge', 'Canada', 'Church', 'Dubai', 'France', 'Greece', 'India', 'Italy', 'Mausoleum', 'New York', 'Opera', 'Paris', 'Pisa', 'San Francisco', 'Skyscraper', 'Spain', 'Sydney', 'Temple', 'Toronto', 'Tower', 'United Arab Emirates', 'United States']\n"
     ]
    }
   ],
   "source": [
    "ar_model.search(most_famous_buildings, reset_cache=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Batch processing:   0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Setting steering_factor to 0 for detection only!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Batch processing: 100%|██████████| 1/1 [00:00<00:00,  4.71it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\u001b[1m=== Output 1 ===\u001b[0m\n",
      "\n",
      "\u001b[1mDetected concepts with confidence scores:\u001b[0m\n",
      "The Golden Gate\u001b[92m\u001b[4m Bridge\u001b[0m, an iconic suspension\u001b[92m\u001b[4m bridge\u001b[0m in San\u001b[93m\u001b[4m Francisco\u001b[0m, United\u001b[91m\u001b[4m States\u001b[0m, spans approximately 1.7 miles across the Golden Gate Strait, the entrance to San\u001b[93m\u001b[4m Francisco\u001b[0m Bay from the Pacific Ocean. Completed in 1937, it was the longest and tallest suspension\u001b[92m\u001b[4m bridge\u001b[0m in the world at the time. The\u001b[92m\u001b[4m bridge\u001b[0m's Art Deco\u001b[94m\u001b[4m design\u001b[0m and striking International Orange color make it a beloved symbol of San\u001b[93m\u001b[4m Francisco\u001b[0m and a popular subject for photographers and artists alike. The Golden Gate\u001b[92m\u001b[4m Bridge\u001b[0m is not only a vital transportation link but also a testament to human ingenuity and engineering excellence.\n",
      "                  \u001b[92m9\u001b[0m                            \u001b[92m5\u001b[0m              \u001b[93m6\u001b[0m                \u001b[91m6\u001b[0m                                                                                         \u001b[93m8\u001b[0m                                                                                                 \u001b[92m5\u001b[0m                                    \u001b[92m9\u001b[0m                 \u001b[94m3\u001b[0m                                                                               \u001b[93m6\u001b[0m                                                                                   \u001b[92m9\u001b[0m                                                                                                               \n",
      "\n",
      "\u001b[1mConcept Legend:\u001b[0m\n",
      "\u001b[91m■\u001b[0m United States\n",
      "\u001b[92m■\u001b[0m Bridge\n",
      "\u001b[93m■\u001b[0m San Francisco\n",
      "\u001b[94m■\u001b[0m Mausoleum\n",
      "\n",
      "\u001b[1mRules activated:\u001b[0m\n",
      "\u001b[92m✓\u001b[0m Golden Gate Bridge\n",
      "\n",
      "\u001b[1mSteering applied:\u001b[0m \u001b[91mNone\u001b[0m\n",
      "\n",
      "\u001b[1m============================================================\u001b[0m\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "golden_gate_test = \"The Golden Gate Bridge, an iconic suspension bridge in San Francisco, United States, spans approximately 1.7 miles across the Golden Gate Strait, the entrance to San Francisco Bay from the Pacific Ocean. Completed in 1937, it was the longest and tallest suspension bridge in the world at the time. The bridge's Art Deco design and striking International Orange color make it a beloved symbol of San Francisco and a popular subject for photographers and artists alike. The Golden Gate Bridge is not only a vital transportation link but also a testament to human ingenuity and engineering excellence.\"\n",
    "o = ar_model.detect([golden_gate_test], verbose=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Batch processing: 100%|██████████| 1/1 [00:00<00:00,  4.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\u001b[1m=== Output 1 ===\u001b[0m\n",
      "\n",
      "\u001b[1mDetected concepts with confidence scores:\u001b[0m\n",
      "The Eiffel\u001b[93m\u001b[4m Tower\u001b[0m, located in\u001b[91m\u001b[4m Paris\u001b[0m,\u001b[92m\u001b[4m France\u001b[0m, is one of the most recognizable landmarks in the world. Built in 1889 as the entrance arch for the Exposition Universelle (World’s Fair), it was originally criticized by some of the leading artists and intellectuals of\u001b[92m\u001b[4m France\u001b[0m for its unique iron lattice design. However, over time it has become an enduring symbol of\u001b[92m\u001b[4m French\u001b[0m art, culture, and engineering prowess. Standing at 324 meters tall, the Eiffel\u001b[93m\u001b[4m Tower\u001b[0m draws millions of visitors each year, who ascend its three observation levels to experience breathtaking views of\u001b[91m\u001b[4m Paris\u001b[0m and the River Seine.\n",
      "            \u001b[93m8\u001b[0m                 \u001b[91m8\u001b[0m       \u001b[92m5\u001b[0m                                                                                                                                                                                                                                  \u001b[92m5\u001b[0m                                                                                                 \u001b[92m6\u001b[0m                                                                                    \u001b[93m7\u001b[0m                                                                                                                       \u001b[91m7\u001b[0m                        \n",
      "\n",
      "\u001b[1mConcept Legend:\u001b[0m\n",
      "\u001b[91m■\u001b[0m Paris\n",
      "\u001b[92m■\u001b[0m France\n",
      "\u001b[93m■\u001b[0m Tower\n",
      "\n",
      "\u001b[1mRules activated:\u001b[0m\n",
      "\u001b[92m✓\u001b[0m Eiffel Tower\n",
      "\n",
      "\u001b[1mSteering applied:\u001b[0m \u001b[91mNone\u001b[0m\n",
      "\n",
      "\u001b[1m============================================================\u001b[0m\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "\n",
    "eiffel_test = \"The Eiffel Tower, located in Paris, France, is one of the most recognizable landmarks in the world. Built in 1889 as the entrance arch for the Exposition Universelle (World’s Fair), it was originally criticized by some of the leading artists and intellectuals of France for its unique iron lattice design. However, over time it has become an enduring symbol of French art, culture, and engineering prowess. Standing at 324 meters tall, the Eiffel Tower draws millions of visitors each year, who ascend its three observation levels to experience breathtaking views of Paris and the River Seine.\"\n",
    "\n",
    "o = ar_model.detect([eiffel_test], verbose=True)\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "AL",
   "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.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
