{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "03ccece4",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[nltk_data] Downloading package stopwords to /root/nltk_data...\n",
      "[nltk_data]   Package stopwords is already up-to-date!\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import os\n",
    "import fitz\n",
    "import re\n",
    "import json\n",
    "from datetime import datetime\n",
    "from typing import Optional, List, Callable, Any, Tuple, Dict\n",
    "from abc import abstractmethod, ABC\n",
    "import random\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import copy\n",
    "import nltk\n",
    "from nltk.corpus import stopwords\n",
    "import pickle\n",
    "import itertools\n",
    "\n",
    "nltk.download('stopwords')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ce7b2c0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils import file_handle, grouping\n",
    "from utils.tree import Node"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "42a6c1a4",
   "metadata": {},
   "outputs": [],
   "source": [
    "extract_fol = \"extracted\"\n",
    "equipment_info_loc = os.path.join(extract_fol, \"equipment_info\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "dd5da751",
   "metadata": {},
   "outputs": [],
   "source": [
    "rule_information = file_handle.load_pickle(\n",
    "    os.path.join(extract_fol, \"TreeStruct.pkl\")\n",
    ")\n",
    "\n",
    "asset_descriptions = file_handle.load_json(\n",
    "    os.path.join(equipment_info_loc, \"gre_desc.json\")\n",
    ")\n",
    "\n",
    "asset_descriptions[\"NONE\"] = {\"desc\":\"Decription not available\",\"detailed_desc\":\"NONE\"}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fd9cf727",
   "metadata": {},
   "source": [
    "# Observation stats "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c5d1811c",
   "metadata": {},
   "outputs": [],
   "source": [
    "total_obs = list()\n",
    "unq_obs = set()\n",
    "for d in rule_information[\"rule_set\"]:\n",
    "    unq_obs = unq_obs.union(set(d[\"display_text\"][\"observations\"]))\n",
    "    total_obs.extend(d[\"display_text\"][\"observations\"])\n",
    "\n",
    "len(total_obs), len(unq_obs)\n",
    "\n",
    "unq_obs = list(unq_obs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "18c039c2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 : Cooling coil maybe passing water. Check air line on chilled water valve\n",
      "1 : Static pressure sensors need calibration, repair or replacement\n",
      "2 : System is in a manual mode\n",
      "3 : Lost signal to valve, check pneumatic or electrical inputs\n",
      "4 : Damper is open when it is humid outside\n",
      "5 : Heating valve operation\n",
      "6 : Low refrigerant levels\n",
      "7 : CRAC units with the chilled water valve is closed indicates a problem with controls wires from the valve to CRAC unit could be off\n",
      "8 : System is not designed well for part loads on the chiller\n",
      "9 : Pressure issues\n",
      "10 : Opportunity for additional savings. Reset temperature to outside conditions\n",
      "11 : Electrical system problems\n",
      "12 : Broken belt or loose belt on Motor\n",
      "13 : Motor issue\n",
      "14 : Temperature sensors may need calibration or replacement\n",
      "15 : Check logic on building control system\n",
      "16 : Hand or overridden on when the supply fan is off\n",
      "17 : Temperature sensors\n",
      "18 : Dampers not working correctly\n",
      "19 : Verify pump is not needed and turn off\n",
      "20 : The Heating Valve is leaking when closed\n",
      "21 : Review of Boiler operation\n",
      "22 : Verify Actuator, Valve and Dampers are working correctly and not stuck\n",
      "23 : Belt slipping or off\n",
      "24 : Valve issues - broken or clogged valve\n",
      "25 : BMS maybe set too high or too low\n",
      "26 : Air Flow Problems\n",
      "27 : Too many or too few compressors are running\n",
      "28 : BMS sequence of operation for heating valve is incorrect\n",
      "29 : Chiller operation needs to be investigated\n",
      "30 : Chilled water valve not actuating well\n",
      "31 : The outside air damper is not closing securely\n",
      "32 : Relay from BMS to fan is broken\n",
      "33 : Control issues\n",
      "34 : Is the system overridden\n",
      "35 : UPS unit is overloaded\n",
      "36 : Control system sent the wrong command\n",
      "37 : Dehumidification flow issue\n",
      "38 : This works for constant speed or VFD return fans\n",
      "39 : Flow rate is too high\n",
      "40 : Chilled water valve could be stuck closed or stuck open or stuck some where in between\n",
      "41 : Unit controls are not working correctly\n",
      "42 : Flow through valve should be zero\n",
      "43 : Room Temp setpoint too low\n",
      "44 : Too many CRAC units are running for the amount of load\n",
      "45 : Thermostat in room maybe set too high or too low\n",
      "46 : Fouling of heat transfer surfaces\n",
      "47 : Gas in liquid refrigerant\n",
      "48 : Could be oil heater\n",
      "49 : Fans are off\n",
      "50 : Damper may be stuck open on a cold day\n",
      "51 : Heating coil maybe passing water. Check air line on hot water valve\n",
      "52 : VFD minimum speed may be set too high\n",
      "53 : Pump problems (VFD problems)\n",
      "54 : Command to valve, but valve is not responding,\n",
      "55 : Broken air line\n",
      "56 : Controls not set up correctly\n",
      "57 : Dampers are not properly closed\n",
      "58 : Check for correct operation of the cooling and heating valves\n",
      "59 : Static pressure sensors need calibration\n",
      "60 : BMS is commanding heating valve ON when it should not\n",
      "61 : Box Damper not working\n",
      "62 : Chilled water control valve\n",
      "63 : Chiller cannot keep up with the load\n",
      "64 : bad motor\n",
      "65 : Command from BMS issue\n",
      "66 : Actuators\n",
      "67 : Boiler command to intake Damper Issue\n",
      "68 : Excess equipment is on\n",
      "69 : New energy use or equipment that has been removed\n",
      "70 : Manual Operation override may be in place wasting energy\n",
      "71 : Thermostat out of calibration\n",
      "72 : Check VAV box operation\n",
      "73 : Check Building Control System is set for either heating or cooling but not both\n",
      "74 : Too many chillers are running\n",
      "75 : PDU is overloaded\n",
      "76 : Overridden on or logic could be updated to turn off chiller appropriately\n",
      "77 : BMS command issue\n",
      "78 : Verify plate and frame is available and if chiller is not needed, turn off\n",
      "79 : Verify physical operation of damper to control signal\n",
      "80 : Too much equipment in the local area\n",
      "81 : Load is too low or fluctuates\n",
      "82 : BMS maybe over ridden to a constant value.\n",
      "83 : Check condition of the filters\n",
      "84 : Check duct integrity\n",
      "85 : pressure sensors need calibration\n",
      "86 : VAV boxes stuck or broken open\n",
      "87 : System overridden to a specific speed\n",
      "88 : Check fans and condenser water pumps\n",
      "89 : Bad staging of heat systems\n",
      "90 : Fan is overridden\n",
      "91 : Check AHU operation\n",
      "92 : Discharge temperature sensor failure\n",
      "93 : Boiler needs tuning\n",
      "94 : Dehumidification Flow Issue\n",
      "95 : Clean the tubes\n",
      "96 : Temperature sensor accuracy\n",
      "97 : The condenser water pumps are flowing water through a chiller that is off\n",
      "98 : Return fans in manual\n",
      "99 : Variable orifice problems\n",
      "100 : Check VAV box flow sensors\n",
      "101 : Load is low\n",
      "102 : Leaks in air lines\n",
      "103 : BMS is commanding cooling valve on when it should not\n",
      "104 : Bad motor, bearings\n",
      "105 : Logic that is working too quickly not allowing the system to stabilized\n",
      "106 : Problems with the cooling tower\n",
      "107 : Humidifier is not turning off\n",
      "108 : Command from BMS to Preheat Valve needs to be adjusted\n",
      "109 : Freeze protect issues\n",
      "110 : Temperature sensor calibration\n",
      "111 : Exempt asset if space is occupied overnight\n",
      "112 : Broken duct work\n",
      "113 : CRAC units that can be turned off to provide energy savings\n",
      "114 : Cooling issues with the AHU because Zone Temperature OR Return Temperature greater than 79 F / 26.1 C\n",
      "115 : Check if the Return Air Damper is closing tightly enough\n",
      "116 : Fouled Tubes\n",
      "117 : Heating valve is leaking\n",
      "118 : Check Temp Sensors\n",
      "119 : Lost signal to valve\n",
      "120 : Isolation Valve Closed\n",
      "121 : Bad Valve\n",
      "122 : Filters clogged\n",
      "123 : Chiller at part load\n",
      "124 : PDU is under utilized\n",
      "125 : Check the logic in the BMS for economizer mode\n",
      "126 : Belts are loose or broken\n",
      "127 : Preheat Valve issues - broken or clogged valve\n",
      "128 : Leaking or Stuck Cooling or Heating Valve\n",
      "129 : SAT or MAT Sensor Error\n",
      "130 : Side-by-side units that are not balanced\n",
      "131 : Leaking or Broken chilled water valves\n",
      "132 : Check Temperature sensors\n",
      "133 : Minimum VFD speed set too high\n",
      "134 : Undersized or Fouled Heating Coil\n",
      "135 : Outside air damper not closing securely\n",
      "136 : Turn off CRAC units\n",
      "137 : Fouling of stack and heat transfer surfaces\n",
      "138 : Pump is overridden\n",
      "139 : Heating issues with the AHU because the Zone Temperature OR Return Temperature less than 65 F / 18.3 C\n",
      "140 : Incorrect zone temp setpoints causing VAV boxes to be full open\n",
      "141 : Leaking preheat or hot water valve\n",
      "142 : Relay issue\n",
      "143 : Discharge temperature too low or sensor failure\n",
      "144 : Check for temperature sensor calibration issues\n",
      "145 : Fan in Hand or Manual Mode or over ridden on\n",
      "146 : Damper is commanded open greater than it needs to be - check the BMS logic\n",
      "147 : Broken Belt\n",
      "148 : Hot water or steam valve leaks\n",
      "149 : Opportunity to reduce schedule\n",
      "150 : Mis-sized equipment\n",
      "151 : VFD issues\n",
      "152 : Variable Frequency Drive speeds incorrect on pumps\n",
      "153 : Humidification valve Issue\n",
      "154 : Check temperature sensors\n",
      "155 : Over ride in place\n",
      "156 : Low Temperature Delta Syndrome\n",
      "157 : Valve blocked\n",
      "158 : Side by side units where one was turned off and the other picked up the load. They may not have rebalanced when the second unit was turned back on\n",
      "159 : Validate BMS command to outside air damper is correct\n",
      "160 : BMS command\n",
      "161 : Review of Boiler Operation\n",
      "162 : PDU unit is overloaded\n",
      "163 : Lost signal to valve, Check pneumatic lines or electricity to valve is operating properly\n",
      "164 : Humidity sensor needs calibration or replacement\n",
      "165 : Logic issues for the cooling tower\n",
      "166 : Valve Hunting\n",
      "167 : Temperature sensors need calibration or replacement\n",
      "168 : Check the logic in the BMS to see how it is set up\n",
      "169 : Filters need changing\n",
      "170 : VAV box issues like broken duct work, dampers always at 100%\n",
      "171 : Motor control\n",
      "172 : Lighting relay schedule over written\n",
      "173 : Validate damper is not stuck closed or open or in between\n",
      "174 : Water Feed Problem\n",
      "175 : Blade pitch\n",
      "176 : A new leak in the air lines\n",
      "177 : Bad motor\n",
      "178 : Processor or controller problem\n",
      "179 : Static pressure sensor\n",
      "180 : Chilled water valve stuck closed\n",
      "181 : Undersized system for load\n",
      "182 : Controls on CRAC are set too low\n",
      "183 : Faulty bypass valves\n",
      "184 : Short Term Weather Condition\n",
      "185 : Isolation valve closed\n",
      "186 : May be using mechanical cooling ie chiller\n",
      "187 : Larger AHU problem\n",
      "188 : VFD Issue\n",
      "189 : User maybe too cold or too hot and trying to fix a broken condition\n",
      "190 : Check the BMS. It has commanded the heat on when it should be off\n",
      "191 : Pressure sensors need calibration\n",
      "192 : Actuator issue\n",
      "193 : Unit shutdown for some reason\n",
      "194 : BMS schedule has been changed\n",
      "195 : Vanes at wrong angle\n",
      "196 : Check dampers\n",
      "197 : Flow sensors\n",
      "198 : Bypassing excessive amounts of fluid\n",
      "199 : Bad pressure sensor\n",
      "200 : Valve Broken\n",
      "201 : Bad CT\n",
      "202 : Chilled water valve is leaking\n",
      "203 : VFD operation\n",
      "204 : 3-way valves\n",
      "205 : If unit resets based on VAV damper position exempt from this rule.\n",
      "206 : Excessive Cooling\n",
      "207 : VFD issues, signal to fan set correctly?\n",
      "208 : Boiler needs turning\n",
      "209 : Is the BMS logic set up correctly\n",
      "210 : BMS control logic\n",
      "211 : Return air temp setpoint too high\n",
      "212 : Hot Water Supply temp too low\n",
      "213 : Heating valves\n",
      "214 : Economizer Issues\n",
      "215 : Damper command should be zero\n",
      "216 : Check the command from the BMS\n",
      "217 : Blocked Valve\n",
      "218 : Check the BMS command for inlet air control\n",
      "219 : Cooling tower has excessive flow\n",
      "220 : Are the dampers operating correctly\n",
      "221 : Fan blades at incorrect pitch\n",
      "222 : Problem with hot water circulating pump\n",
      "223 : Unit bypassing or blowing off too much air\n"
     ]
    }
   ],
   "source": [
    "for i, unq in enumerate(unq_obs):\n",
    "    print(\"{} : {}\".format(i,unq))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "647b83fe",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/root/projects/AssetDiagnosisIQ/.conda/lib/python3.11/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "from sentence_transformers import SentenceTransformer\n",
    "\n",
    "# 1. Load a pretrained Sentence Transformer model\n",
    "model = SentenceTransformer(\"all-MiniLM-L6-v2\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "87c78365",
   "metadata": {},
   "outputs": [],
   "source": [
    "enc = model.encode(unq_obs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "c609468a",
   "metadata": {},
   "outputs": [],
   "source": [
    "norm = np.linalg.norm(enc, axis=1)\n",
    "norm = np.outer(norm,norm) + 1e-6"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "b5f886a4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.756036\n"
     ]
    }
   ],
   "source": [
    "_thresh = 0.992\n",
    "cosine_sim = (enc @ enc.T)/norm\n",
    "cosine_sim = np.abs(cosine_sim)\n",
    "\n",
    "thresh = np.quantile(cosine_sim.flatten(),_thresh)\n",
    "print(thresh)\n",
    "for i in range(cosine_sim.shape[0]):\n",
    "    for j in range(i, cosine_sim.shape[0]):\n",
    "        cosine_sim[i,j] = 0\n",
    "\n",
    "ind = np.where(cosine_sim>thresh)\n",
    "\n",
    "observation_map = {}\n",
    "\n",
    "edges = []\n",
    "for x,y in zip(ind[0], ind[1]):\n",
    "    edges.append((x,y))\n",
    "    \n",
    "res = grouping.getComponents(cosine_sim.shape[0], edges)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "c5fe8758",
   "metadata": {},
   "outputs": [],
   "source": [
    "obs_mapping = {}\n",
    "for r in res:\n",
    "    if len(r)>1:\n",
    "        major = np.argmax([len(unq_obs[x]) for x in r])\n",
    "        major = unq_obs[r[major]]\n",
    "        \n",
    "        for r0 in r:\n",
    "            obs_mapping[unq_obs[r0]] = major \n",
    "    else:\n",
    "        obs_mapping[unq_obs[r[0]]] = unq_obs[r[0]]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0237c89e",
   "metadata": {},
   "source": [
    "# Rule stats "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "10842de7",
   "metadata": {},
   "outputs": [],
   "source": [
    "rule_information = file_handle.load_json(\n",
    "    os.path.join(\"extracted/observations.rules.json\")\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "e374cc36",
   "metadata": {},
   "outputs": [],
   "source": [
    "total_rules = list()\n",
    "unq_rules = set()\n",
    "for d in rule_information[\"rule_set\"]: \n",
    "    s = (d[\"display_text\"][\"rules\"].replace(\"-\",\"\").replace(\"OR\", \"\").replace(\"(\", \"\").replace(\")\", \"\")).split(\"\\n\")\n",
    "    s = [x.strip() for x in s]\n",
    "    unq_rules = unq_rules.union(set(s))\n",
    "    total_rules.extend(s)\n",
    "\n",
    "unq_rules = list(unq_rules)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "1c893968",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(633, 363)"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(total_rules), len(unq_rules)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "26908fc6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['Preheat Valve % > 97%',\n",
       " 'Outside Air Flow >/< Outside Air Flow Setpoint * 1.10%',\n",
       " 'Supply Air Temperature > 90 °F  Mixed Air Temperature > 90 °F',\n",
       " 'PSI',\n",
       " 'Air Flow < 100 CFM IF Reporting',\n",
       " 'Natural Gas Flow > 5 AND Flue Gas Oxygen % > 3%',\n",
       " 'AHU Running',\n",
       " 'Conductivity > 4000 umho 0.004 S',\n",
       " 'Cooling Valve % > 5%',\n",
       " 'SubType NOT RAS or OAU',\n",
       " 'VAV Damper > 20 %',\n",
       " 'Name = B3010080 AND Flue Gas Temperature < 360 °F',\n",
       " 'Power > Previous Daily Average Friday Supply Power * 0.8',\n",
       " 'OAT < 80 °F',\n",
       " 'Subtype NOT VAV or OAU or RAU',\n",
       " 'Heating Valve % > 0%',\n",
       " 'Economizer Mode AND Supply Relative Humidity % Not Reporting',\n",
       " 'Power Input > 0.1 KW',\n",
       " 'Return Air Temperature > Setpoint Temperature',\n",
       " 'Cooling Valve % > 97%',\n",
       " 'OAT < 95 °F',\n",
       " 'IF Reporting',\n",
       " 'Poughkeepsie & Warden: Met for 4 Hours',\n",
       " 'Cooling Valve % >= 5%',\n",
       " 'OAT > Setpoint Temperature  OAT > Supply Air Temperature AND',\n",
       " 'Propane Flow > 5 AND Flue Gas Oxygen % > 5%',\n",
       " 'Schedule = 0',\n",
       " 'Reporting',\n",
       " 'OAT < 90 °F',\n",
       " 'Cooling Valve % < 2%',\n",
       " 'OAT > 37 °F',\n",
       " 'ABSStatic Pressure Setpoint – Static Pressure > 0.2 in H2O',\n",
       " 'Preheat Valve % < 5% AND Heating AND Reheat Valve % Not Reporting',\n",
       " 'Condenser Water Supply Temperature to Chiller < Condenser Water Temperature Setpoint  4 °F',\n",
       " 'Setpoint Temperature < 72 °F',\n",
       " 'Zone Temp < Zone Temp Heating Setpoint  4 °F',\n",
       " 'AHU Running IF VAV, Check Parent AHU Running',\n",
       " 'Meter > 5 kw power real',\n",
       " 'None Reporting',\n",
       " 'Return Fan Status = 1',\n",
       " 'Setpoint Temperature Not Reporting',\n",
       " 'Heating Valve % > 10%  Preheat Valve % > 10%',\n",
       " 'Economizer Mode = 0',\n",
       " 'Littleton: Met for 4 Hours',\n",
       " 'Heating AND Reheat Valve % < 5% AND Preheat Valve % Not Reporting',\n",
       " 'Heating Valve % < 5% AND Preheat AND Reheat Valve % Not Reporting',\n",
       " 'Parent AHU NOT Running',\n",
       " 'VFD Speed % > 95%',\n",
       " 'OAT > 55 °F',\n",
       " 'Southbury: Mixed Air Temperature  OAT > 8 °F',\n",
       " 'Chiller Running',\n",
       " 'Enthalpy > Reutrn Enthalpy IF Reporting',\n",
       " 'Unoccupied Heating = 0 IF reporting',\n",
       " '55 °F < OAT < 80 °F',\n",
       " 'Fuel Oil Flow > 5 AND Flue Gas Oxygen % > 5%',\n",
       " 'OAT < Supply Air Temperature AND Setpoint Temperature Not Reporting',\n",
       " 'The date is NOT a Monday',\n",
       " 'Supply Temperature  Return Temperature < 5 °F',\n",
       " 'Outside Air Damper % > Outside Air Damper Minimum % AND Economizer',\n",
       " 'Duct Static Pressure < 0.01 inH2O',\n",
       " 'Heating Valve > 50%',\n",
       " 'Pump Running',\n",
       " 'Enthalpy < 28 IF Reporting',\n",
       " 'Chiller NOT Running',\n",
       " 'Low Temp Chilled Water Valve % > 97%',\n",
       " 'Supply Relative Humidity % > 35% AND Economizer Mode Not Reporting',\n",
       " 'ABSCondenser Water Pressure Difference  Condenser Water Pressure',\n",
       " 'Met for 2 Hours',\n",
       " 'Heating AND Preheat Valve % < 5% AND Reheat Valve % Not Reporting',\n",
       " 'Boulder: Using 60 °F',\n",
       " 'SubType NOT FCU or OAU',\n",
       " 'Met for 3 Hours',\n",
       " 'Duct Static Pressure < 0.1 in H2O IF Reporting',\n",
       " 'Heating Drained Flag = 1 IF Reporting',\n",
       " 'Mixed Air Temperature  Supply Air Temperature > 10 °F',\n",
       " 'Heating Valve % = 0%  Preheat Valve % = 0%',\n",
       " 'Heating Valve < 5%',\n",
       " 'Enthalpy > 29 BTU/lb',\n",
       " 'KW',\n",
       " 'Heating AND Preheat AND Reheat Valve % Not Reporting',\n",
       " '10%',\n",
       " 'Temperature Setpoint > 6 °F',\n",
       " 'Supply Fan Efficiency > Asset Efficiency Parameter',\n",
       " 'Supply Fan Output % > 50%',\n",
       " 'Outside Air Damper % < Outside Air Damper Minimum %',\n",
       " 'ABSHot Water Temperature  Hot Water Return Temperature < 4 °F',\n",
       " 'Duct Static Pressure Setpoint = Previous Daily Duct Static Pressure Setpoint',\n",
       " 'Return Air Temperature <= Supply Air Temperature + 3 °F',\n",
       " 'Supply Fan Output % < 95%',\n",
       " 'Rochester: Using 67 °F',\n",
       " 'Tucson: Zone/Return Air Temperature of 68 °F',\n",
       " 'out?',\n",
       " '10 °F < OAT < Setpoint Temperature',\n",
       " '50% of 650 KW < Power Input <  80% of 650 KW',\n",
       " 'Enthalpy < 14',\n",
       " 'CO2 < 1000 ppm IF Reporting',\n",
       " 'OAT > 43 °F',\n",
       " 'WRL: Met for 4 hours 20160816',\n",
       " 'Pump Occupied = 0',\n",
       " 'Temperature Setpoint > 68 °F',\n",
       " 'Outside Air Damper % < 90%',\n",
       " 'ABSSetpoint Temperature  Supply Air Temperature > 7 °F',\n",
       " 'Met for 2 hours',\n",
       " 'Supply Air Temp Setpoint < 53 °F',\n",
       " 'Outside Air Enthalpy < 26 IF Return Air Enthalpy IF Dew Point  Return',\n",
       " 'Neither reporting',\n",
       " 'Return Air Temperature > Supply Air Temperature IF Setpoint',\n",
       " 'Cooling Tower Running',\n",
       " 'Heating Valve % > 5% AND/ Preheat Valve % > 5%',\n",
       " 'Setpoint Temperature = Setpoint Temperature 1 Hour Ago',\n",
       " 'Setpoint Temperature = Setpoint Temperature 2 Hours Ago',\n",
       " 'Subtype is VAV',\n",
       " 'Temperature Setpoint < 65 °F',\n",
       " 'AND/ Cooling System Drained Flag = 0 IF Reporting',\n",
       " 'Subtype NOT VAV or MULTI',\n",
       " 'Heat Exchanger Off plate and frame status = 0',\n",
       " '37 °F < OAT < Return Air Temperature  4 °F',\n",
       " 'Tucson: 3 Hours',\n",
       " 'Condenser Water Return To Tower Temperature  Condenser Liquid',\n",
       " 'Subtype NOT VAV',\n",
       " 'Enthalpy < 26 IF Reporting',\n",
       " 'Supply Air Temp Setpoint > 75 °F',\n",
       " 'Cooling Drained Flag = 1 IF Reporting',\n",
       " 'Heating System Drained Flag = 0 IF Reporting AND/ Cooling System',\n",
       " 'Supply Air Flow outside > Supply Air Flow Setpoint + 25%',\n",
       " 'Austin using 60 CFM',\n",
       " 'Difference Setpoint > 5 PSI',\n",
       " 'Return Air Temperature >= 79 °F IF Zone Temperature Not Reporting',\n",
       " 'Reheat Valve % < 5% AND Heating AND Preheat Valve % Not Reporting',\n",
       " 'Bromont: Return Air Damper % = 0%',\n",
       " 'OAT > Return Air Temperature',\n",
       " 'Outside Air Damper % > Outside Air Damper Minimum % + 2%',\n",
       " 'Day = Sat or Sun or local time overnight after 8pm and before 5am',\n",
       " 'OAT > Setpoint Temperature',\n",
       " 'Supply Fan Status = 1',\n",
       " 'RTP:OAT > 40 °F and OAT < 68 °F',\n",
       " 'Run Status Changed >= 4 Times Within 8 hours',\n",
       " 'Rochester: 3 Hours',\n",
       " \"Hot Deck Damper % = 0% one or the other, can't have both\",\n",
       " 'Zone Relative Humidity %  Supply Relative Humidity Setpoint % > 10%',\n",
       " 'Outside Air Damper > 10% IF Outside Air Damper Minimum % Not',\n",
       " 'Past',\n",
       " 'Supply Air Temperature  Mixed Air Temperature > 5 °F',\n",
       " 'Outside Air Damper % Reporting',\n",
       " 'NOTE: Hot Deck units will be checking < 80 °F and > 95 °F',\n",
       " 'Flue Gas Temperature < Flue Gas Temperature Setpoint AND Name NOT =',\n",
       " 'SubType NOT FCU',\n",
       " 'CRAC Unit Running Not used right now',\n",
       " 'Economizer Mode =1',\n",
       " 'Pump Running [Pump Status = 1  Pump Current In Amps >= 1]',\n",
       " 'OAT  Supply Air Temperature Setpoint > 5 °F',\n",
       " 'Supply Fan Status = 0',\n",
       " 'Low Temp Chilled Water Valve % > 5%',\n",
       " 'Using custom Segrate Values of 38, 47.5, 608, 950 KVA',\n",
       " 'Pump VFD Speed % > 97%',\n",
       " 'Supply Fan Output % = Prev. Daily Average Supply Fan Output %',\n",
       " 'Enthalpy < 15 BTU/lb',\n",
       " 'Reheat Valve % > 97%',\n",
       " 'SubType NOT MULTI or PU',\n",
       " 'Day NOT Monday  A Site Holiday',\n",
       " 'SVL: Met for 4 hours 20160817',\n",
       " 'Heating System Drained Flag = 1',\n",
       " 'Enthalpy < 26 IF Economizer Mode and Return Enthalpy Not Reporting',\n",
       " \"ALL P&F at that site's building run status = 0\",\n",
       " 'Duct Static Pressure < Static Pressure Setpoint  0.1 \"H2O IF Reporting',\n",
       " 'Dehumidification Mode = 0 IF reporting',\n",
       " 'AND/ Cooling Drained Flag = 1 IF Reporting',\n",
       " 'Low Temp Chilled Water Valve % > 2%',\n",
       " 'ABSSupply Air Temperature  Supply Air Temperature Setpoint > 4 °F',\n",
       " 'Outside Air Damper %',\n",
       " 'ABS[Pressure  Pressure Setpoint] > 10 PSI',\n",
       " 'AHU NOT Running',\n",
       " 'AND/ Heating Drained Flag = 1 IF Reporting',\n",
       " 'Exhaust Fan Running',\n",
       " 'Temperature Setpoint  Return Air Temperature > 2 °F',\n",
       " 'PUE > Floor Threshold',\n",
       " 'Zone Temperature Setpoint < 68',\n",
       " 'Pump Motor VFD Output % = Daily Average Pump Motor VFD Output %',\n",
       " 'OAT < 75 °F AND Return Air Temperature Not Reporting',\n",
       " 'ABSSupply Air Temperature Setpoint  Supply Air Temperature > 3 IF',\n",
       " 'Met for 3 Hours checking previous 2 days daily average',\n",
       " 'Condenser Water Return To Tower Temperature  Condenser Water Supply',\n",
       " 'Supply Air Flow < 10 cfm',\n",
       " 'OAT > 25 °F',\n",
       " 'Economizer Mode = 1 IF Reporting',\n",
       " 'Supply Temperature  Liquid Refrigerant Evaporator',\n",
       " 'Pump VFD Speed Reporting',\n",
       " 'Air Enthalpy NOT Reporting',\n",
       " 'Filter Differential Pressure > Supply Filter Static Pressure Setpoint',\n",
       " 'Zone Temperature <= 65 °F',\n",
       " 'Refrigerant Temperature > 4 °F',\n",
       " 'Supply Air Flow outside < Supply Air Flow Setpoint  25%',\n",
       " 'ARC:OAT > 40 °F and OAT < 68 °F',\n",
       " 'ABSPump Differential Pressure  Pump Differential Pressure Setpoint >  4',\n",
       " 'Supply Fan Current < 1 amp',\n",
       " 'CRAC Running IF Reporting, Otherwise Assume ON',\n",
       " 'Enthalpy < Return Enthalpy if Economizer not reporting',\n",
       " '35 °F < OAT < 70 °F',\n",
       " 'CRAC Running',\n",
       " 'ABSPump Differential Pressure  Pump Differential Pressure Setpoint > 4psi IF Reporting',\n",
       " 'Low Temp Chilled Water Valve % < 5%',\n",
       " 'OAT < Return Air Temperature  OAT < 75 °F AND Return Air',\n",
       " '3 °F < Return Air Temperature  Supply Air',\n",
       " 'SubType NOT OAU, RAS, RAU',\n",
       " 'Lighting Mode = 0 AND Occupied Mode = 1',\n",
       " 'Heating Valve % = 0% AND Preheat Valve % = 0% IF Both Reporting',\n",
       " 'Supply Fan Output % = Daily Average Supply Fan Output %',\n",
       " 'Conductivity < 3000 umho 0.003 S',\n",
       " 'Lighting Mode = 1 AND Occupied Mode = 0',\n",
       " 'OAT wetbulb < 38 °F',\n",
       " 'Yorktown: Using 61 °F',\n",
       " 'Subtype NOT MULTI or VAV',\n",
       " 'ABSCoolant Pressure Difference  Coolant Pressure Difference Setpoint > 4',\n",
       " 'ABSSupply Air Flow  Previous Day Average < 1',\n",
       " 'Duct Static Pressure Setpoint = Previous Hour Duct Static Pressure Setpoint',\n",
       " 'Reporting AND Economizer Mode Not Reporting',\n",
       " 'Heating Valve % = 0%',\n",
       " 'Voltage < 5% of Meter Voltage Rating',\n",
       " 'OAT > 65 °F',\n",
       " 'Mode Not Reporting',\n",
       " 'PUE > Previous Weeks Average PUE + 20%',\n",
       " 'OAT > Supply Air Temperature AND Setpoint Temperature Not Reporting',\n",
       " 'Outside Air Enthalpy < Return Air Enthalpy IF Dew Point NOT Reporting',\n",
       " 'Cooling Tower – Condenser Water is too cold',\n",
       " 'Return Fan Output % > 97%',\n",
       " 'POK:OAT > 38 °F and OAT < 68 °F',\n",
       " 'Zone Temperature Setpoint > 75',\n",
       " 'Name = B3010091 AND Flue Gas Temperature < 260 °F',\n",
       " 'Post Filter Bank Pressure  Pre Filter Bank Pressure > Supply Filter Static',\n",
       " 'Actual Amps / Full Load Amps < 30% IF Chiller % Loaded NOT Available',\n",
       " 'Heating Drained Flag = 0 IF Reporting',\n",
       " 'ABSSupply Coolant Pressure  Return Coolant Pressure  Coolant',\n",
       " 'Heating Valve % > 97%',\n",
       " 'Humidification Valve % > 5%',\n",
       " 'Outside Air Damper % < 95%',\n",
       " 'AHU Running for 4 hours',\n",
       " 'Setpoint Temperature = Daily Average Setpoint Temperature 2 Days in the',\n",
       " 'Zone Temp > Zone Temp Cooling Setpoint + 4 °F',\n",
       " 'Power Input > 5 KW',\n",
       " 'Preheat Valve % > 5%',\n",
       " 'Met for 4 hours',\n",
       " 'Zone Temperature >= 79 °F',\n",
       " 'BMT:OAH% between 27 and 55',\n",
       " 'Setpoint Reporting',\n",
       " 'Met for 8 Hours',\n",
       " 'POK: OAT < 75 °F',\n",
       " 'Meter > 20 kw',\n",
       " 'Temperature Setpoint  Supply Air Temperature > 4 °F',\n",
       " 'Return Temperature  Supply Temperature < 7 °F',\n",
       " 'Chiller Efficiency > Asset Chiller Efficiency Parameter',\n",
       " 'Poughkeepsie: Using 68 °F < Zone Temperature < 75 °F IF Reporting',\n",
       " 'SubType NOT OAU',\n",
       " 'Return Air Temperature  Temperature Setpoint > 10 °F',\n",
       " 'Condenser Water Supply To Chiller Temperature  Condenser Water',\n",
       " 'Everyone Else: Outside Air Damper % = 100%',\n",
       " 'Humidification System Drained Flag = 0 IF Reporting',\n",
       " 'Return Air CO2 Not Reporting',\n",
       " 'Run Status = 0',\n",
       " 'Temperature > 4 °F',\n",
       " 'Day NOT Monday',\n",
       " 'Drained Flag = 0 IF Reporting',\n",
       " 'Hot Water Temperature > 90 °F',\n",
       " 'Met for 1 Hour',\n",
       " 'Humidification Valve % > 2%',\n",
       " 'Outside Air Temperature > 70 °F',\n",
       " 'Outside Air Damper % > 15% AND Outside Air Damper Minimum % Not',\n",
       " 'Parent AHU Running',\n",
       " 'Return Air Temperature <= 65 °F IF Zone Temperature Not Reporting',\n",
       " 'Mixed Air Temperature  OAT > 5 °F',\n",
       " 'Supply Temperature < Supply Temperature Setpoint',\n",
       " 'Boiler Running',\n",
       " 'OAT > 35 °F',\n",
       " 'Pump Motor VFD Output % > 35%',\n",
       " 'Enthalpy < 29 BTU/lb',\n",
       " 'Mixed Air Temperature  Supply Air Temperature > 7 °F',\n",
       " 'Outside Air Damper % < 15% AND Outside Air Damper Minimum % Not',\n",
       " 'Power Input < 5% of 650 KW',\n",
       " 'Subtype is VAV or FCU',\n",
       " 'Cooling Valve % = 0%',\n",
       " '10 °F < OAT < Supply Air Temperature AND Setpoint Temperature Not',\n",
       " 'Pressure > 130 PSI IF Pressure Setpoint Not Reporting',\n",
       " 'Setpoint Temperature  Supply Temperature > 3 °F',\n",
       " 'Run Status = 1',\n",
       " 'Pressure Setpoint IF Filter Differential Pressure NOT Reporting',\n",
       " 'OAT < Setpoint Temperature',\n",
       " 'Outside Air Damper % > Outside Air Damper Minimum %',\n",
       " 'Duct Static Pressure > 0.2 in H2O',\n",
       " 'AHU Running for 6 hours',\n",
       " 'Heating Valve % > 5%',\n",
       " 'CRAC NOT Running',\n",
       " 'Preheat AND Reheat Valve % < 5% AND Heating Valve % Not Reporting',\n",
       " 'Supply Air Temperature  Temperature Setpoint > 3 °F',\n",
       " 'Outside Air Damper % > 5%',\n",
       " 'Static Pressure Setpoint > 0',\n",
       " 'Supply Temperature  Setpoint Temperature > 5 °F',\n",
       " 'Chiller % Loaded < 30%',\n",
       " 'Condenser Water Supply Temperature to Chiller < 55 °F IF Condenser Water Temperature Setpoint NOT Reporting',\n",
       " 'SubType NOT HW',\n",
       " 'Supply Air Flow > 80 CFM',\n",
       " '55 °F < Zone Temperature < 85 °F IF Reporting',\n",
       " 'Mixed Air Temperature  Supply Air Temperature > 5 °F',\n",
       " 'Met for 3 Hours and Prev. 3 Days Average',\n",
       " 'SubType Is HW',\n",
       " 'Name = 201A980 AND Power Output > 85% of 3MW',\n",
       " 'Humidification Valve % < 5%',\n",
       " 'Littleton: OAT > 40 °F',\n",
       " 'SubType NOT MULTI',\n",
       " 'Economizer Mode = 1',\n",
       " 'Outside Air Damper %  Outside Air Damper Minimum % > 10%',\n",
       " 'AbsDuct Static Pressure  Static Pressure Setpoint > 0.2 in H2O IF',\n",
       " 'Met for 4 Hours',\n",
       " 'Chilled Water Valve % < 5%',\n",
       " 'Power Input > 80% of 650 KW',\n",
       " 'Condenser Water Flow > 50 Gallons/Minute 189 l/m',\n",
       " 'Setpoint Not Reporting',\n",
       " 'Dew Point < 55',\n",
       " 'Economizer Mode = 0 IF Economizer Mode Reporting',\n",
       " 'SubType NOT MULTI  VAV',\n",
       " 'Supply Air Temperature  Mixed Air Temperature > 20 °F',\n",
       " 'Discharge Air Temp supply  Parent Discharge Air Temp supply > 10 °F',\n",
       " 'BLD Building 91: Alert if PF status off for > 1 units NOT POK',\n",
       " 'Supply Relative Humidity %  Supply Relative Humidity Setpoint % >',\n",
       " 'Occupied = 0',\n",
       " 'Supply Air Flow is Not Changing +/ 2% Prev. Day Average',\n",
       " 'Supply Fan Efficiency is calculated: Air Flow CFM divided by Power Usage',\n",
       " 'SubType NOT OAU or FCU',\n",
       " 'Southbury: No Zone Temperature Check',\n",
       " 'Heating AND Preheat AND Reheat Valve % < 5%',\n",
       " 'OAT < 68 °F',\n",
       " 'Heating System Drained Flag = 0 IF Reporting',\n",
       " 'SubType NOT RAS or OAU or VAV',\n",
       " 'ABSHot Water Temperature Setpoint  Hot Water Temperature > 5 °F',\n",
       " 'SubType NOT OAU  RAS',\n",
       " 'Temperature < 10 °F',\n",
       " 'B3010080  B3010091',\n",
       " 'Fan Running',\n",
       " 'AUS: Enthalpy < 24',\n",
       " 'Temperature Not Reporting',\n",
       " 'Heating Valve = 0%',\n",
       " 'Outside Air Damper % NOT = 100%',\n",
       " 'Outside Air Damper % Does NOT = Daily Average',\n",
       " 'To Chiller Temperature < 5 °F',\n",
       " 'Austin: Web Command = 0 IF Reporting,   Using POK Zone Temps',\n",
       " \"Air Flow > Previous Day's Average Air Flow * 20%\",\n",
       " 'Pressure Difference Setpoint > 4 PSI IF Coolant Pressure Difference NOT',\n",
       " 'Name NOT = 201A980 AND Power Output > 85% of 4MW',\n",
       " 'VFD Speed % > 97%',\n",
       " 'Heating Valve % >= 5%  Preheat Valve % >= 5%',\n",
       " 'Enthalpy < Return Enthalpy IF Reporting',\n",
       " 'Saturday or Sunday  Sunday for Identified Assets',\n",
       " 'Heating System Status On',\n",
       " 'OAT < Return Air Temperature  3 °F',\n",
       " 'Heating Valve > 15%',\n",
       " 'Schedule = 1 Currently not implemented; CRACs run 24/7',\n",
       " 'OAT  Supply Air Temperature > 5 °F AND Supply Air Temperature',\n",
       " 'Heating System Drained Flag = 0',\n",
       " 'Poughkeepsie: Using 68 °F < Zone Temperature < 75 °F IF Reporting take',\n",
       " 'Return Air CO2 < 1000 IF Return Air CO2 Reporting',\n",
       " '35 °F < OAT < 80 °F',\n",
       " 'Humidifier Valve % > 97%',\n",
       " 'Unoccupied Cooling = 0 IF reporting',\n",
       " 'Setpoint Temperature = Daily Average Setpoint Temperature 1 Day in the',\n",
       " 'Supply Fan Output % > 97%']"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "unq_rules"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "62a85d9b",
   "metadata": {},
   "outputs": [],
   "source": [
    "enc = model.encode(unq_rules)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "ac52ce72",
   "metadata": {},
   "outputs": [],
   "source": [
    "norm = np.linalg.norm(enc, axis=1)\n",
    "norm = np.outer(norm,norm) + 1e-6"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "fe8af469",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.9928105\n"
     ]
    }
   ],
   "source": [
    "_thresh = 0.997\n",
    "cosine_sim = (enc @ enc.T)/norm\n",
    "cosine_sim = np.abs(cosine_sim)\n",
    "\n",
    "thresh = np.quantile(cosine_sim.flatten(),_thresh)\n",
    "print(thresh)\n",
    "for i in range(cosine_sim.shape[0]):\n",
    "    for j in range(i, cosine_sim.shape[0]):\n",
    "        cosine_sim[i,j] = 0\n",
    "\n",
    "ind = np.where(cosine_sim>thresh)\n",
    "\n",
    "edges = []\n",
    "for x,y in zip(ind[0], ind[1]):\n",
    "    edges.append((x,y))\n",
    "    \n",
    "res = grouping.getComponents(cosine_sim.shape[0], edges)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "7c877cda",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Major: \n",
      "Preheat Valve % < 5% AND Heating AND Reheat Valve % Not Reporting\n",
      "Preheat Valve % < 5% AND Heating AND Reheat Valve % Not Reporting\n",
      "Heating AND Reheat Valve % < 5% AND Preheat Valve % Not Reporting\n",
      "Heating Valve % < 5% AND Preheat AND Reheat Valve % Not Reporting\n",
      "Heating AND Preheat Valve % < 5% AND Reheat Valve % Not Reporting\n",
      "Reheat Valve % < 5% AND Heating AND Preheat Valve % Not Reporting\n",
      "Preheat AND Reheat Valve % < 5% AND Heating Valve % Not Reporting\n",
      "\n",
      "\n",
      "Major: \n",
      "Met for 2 Hours\n",
      "Met for 2 Hours\n",
      "Met for 2 hours\n",
      "\n",
      "\n",
      "Major: \n",
      "Economizer Mode = 1\n",
      "Economizer Mode =1\n",
      "Economizer Mode = 1\n",
      "\n",
      "\n",
      "Major: \n",
      "Low Temp Chilled Water Valve % > 5%\n",
      "Low Temp Chilled Water Valve % > 5%\n",
      "Low Temp Chilled Water Valve % < 5%\n",
      "\n",
      "\n",
      "Major: \n",
      "35 °F < OAT < 70 °F\n",
      "35 °F < OAT < 70 °F\n",
      "35 °F < OAT < 80 °F\n",
      "\n",
      "\n",
      "Major: \n",
      "Lighting Mode = 0 AND Occupied Mode = 1\n",
      "Lighting Mode = 0 AND Occupied Mode = 1\n",
      "Lighting Mode = 1 AND Occupied Mode = 0\n",
      "\n",
      "\n",
      "Major: \n",
      "Met for 4 hours\n",
      "Met for 4 hours\n",
      "Met for 4 Hours\n",
      "\n",
      "\n",
      "Major: \n",
      "Outside Air Damper % > 15% AND Outside Air Damper Minimum % Not\n",
      "Outside Air Damper % > 15% AND Outside Air Damper Minimum % Not\n",
      "Outside Air Damper % < 15% AND Outside Air Damper Minimum % Not\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "rules_mapping = {}\n",
    "for r in res:\n",
    "    if len(r)>1:\n",
    "        major = np.argmax([len(unq_rules[x]) for x in r])\n",
    "        major = unq_rules[r[major]]\n",
    "\n",
    "        print(\"Major: \\n{}\".format(major))\n",
    "        \n",
    "        for r0 in r:\n",
    "            print(unq_rules[r0])\n",
    "            rules_mapping[unq_rules[r0]] = major \n",
    "\n",
    "        print(\"\\n\")\n",
    "    else:\n",
    "        rules_mapping[unq_rules[r[0]]] = unq_rules[r[0]]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "edf11b6b",
   "metadata": {},
   "source": [
    "# Rule Grouping with semantic understanding"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "f4e28c25",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sentence_transformers import SentenceTransformer, util\n",
    "\n",
    "\n",
    "model = SentenceTransformer(\"all-mpnet-base-v2\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "97eddd7c",
   "metadata": {},
   "outputs": [],
   "source": [
    "rule_repr_dict:Dict[str,str] = {x[\"id\"]:x[\"display_text\"][\"rules\"] for x in rule_information[\"rule_set\"]}\n",
    "enc = model.encode(list(rule_repr_dict.values()))\n",
    "rule_index_map = {k:v for v,k in enumerate(rule_repr_dict.keys())}\n",
    "index_rule_map = {k:v for v,k in rule_index_map.items()}\n",
    "\n",
    "norm = np.linalg.norm(enc, axis=1)\n",
    "norm = np.outer(norm,norm) + 1e-6\n",
    "\n",
    "cosine_sim = (enc @ enc.T)/norm\n",
    "cosine_sim = np.abs(cosine_sim)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "020fa435",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "sns.heatmap(cosine_sim)\n",
    "\n",
    "plt.savefig('RRSim_heatmap.png', dpi=600, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "9f47d1fc",
   "metadata": {},
   "outputs": [],
   "source": [
    "rule_codition_similarity = np.argsort(cosine_sim, axis=-1)\n",
    "\n",
    "rule_id_similarity_map = {}\n",
    "for k,v in rule_index_map.items():\n",
    "    rule_id_similarity_map[k] = [index_rule_map[x] for x in rule_codition_similarity[v]]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3aa49c3b",
   "metadata": {},
   "source": [
    "# Dataset Creation "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "0bf54815",
   "metadata": {},
   "outputs": [],
   "source": [
    "extract_fol = \"extracted\"\n",
    "equipment_info_loc = os.path.join(extract_fol, \"equipment_info\")\n",
    "\n",
    "random.seed(420)\n",
    "np.random.seed(420)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "bc998796",
   "metadata": {},
   "outputs": [],
   "source": [
    "rule_information = file_handle.load_pickle(\n",
    "    os.path.join(extract_fol, \"TreeStruct.pkl\")\n",
    ")\n",
    "\n",
    "asset_descriptions = file_handle.load_json(\n",
    "    os.path.join(equipment_info_loc, \"gre_desc.json\")\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "e9f593bb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<utils.tree.Node object at 0x7fdc3c579990>\n"
     ]
    }
   ],
   "source": [
    "for  x in rule_information[\"rule_set\"]:\n",
    "    if x[\"id\"] == \"CT00001\":\n",
    "        print(x[\"display_text\"][\"rules\"])"
   ]
  },
  {
   "cell_type": "raw",
   "id": "5d069246",
   "metadata": {},
   "source": [
    "question_id: <unique_id>  # e.g., WTWQ-001\n",
    "date_detected: <MM/DD/YYYY>\n",
    "asset_type: <Asset Type>  # e.g., AHU, Chiller, VAV\n",
    "condition_description: |\n",
    "  - <Condition 1>\n",
    "  - <Condition 2>\n",
    "  - <Condition 3>\n",
    "  - ...\n",
    "  - Condition met for <duration>\n",
    "question_prompt: |\n",
    "  Given the above detected condition, what should the operator look for?\n",
    "options:\n",
    "  - A) <Correct action>\n",
    "  - B) <Distractor 1>\n",
    "  - C) <Distractor 2>\n",
    "  - D) <Distractor 3>\n",
    "answer: A\n",
    "rationale: |\n",
    "  The condition suggests <explanation>. Therefore, the correct response is to <action>.\n",
    "tags:\n",
    "  - condition_type: <e.g., sensor-stuck, flow-imbalance>\n",
    "  - asset_zone: <e.g., VAV zone, hot deck, chilled loop>\n",
    "  - response_type: <e.g., investigate, recalibrate, replace, tune BMS logic>\n",
    "difficulty: <Entry-level | Intermediate | Advanced>"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "eab0676c",
   "metadata": {},
   "outputs": [],
   "source": [
    "from dataset_utils import creation, config\n",
    "\n",
    "\n",
    "dataset_config = config.DatasetCreationConfig({\n",
    "    \"num_options\":4,\n",
    "    \"question_template_mode\":config.QuestionTemplateMode.random,\n",
    "    \"question_template_random_count\" : 1\n",
    "})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "86902eae",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = creation.create_dataset(\n",
    "    rule_information,\n",
    "    obs_mapping,\n",
    "    {k:v[\"desc\"] for k,v in asset_descriptions.items()},\n",
    "    rule_id_similarity_map,\n",
    "    dataset_config\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "076fc822",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "9065"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(dataset[\"questions\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4d12ecd4",
   "metadata": {},
   "outputs": [],
   "source": [
    "#creation.save_dataset(\n",
    "#    dataset,\n",
    "#    \"simpleV5\",\n",
    "#    \"datasets\"\n",
    "#)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "id": "ed742837",
   "metadata": {},
   "outputs": [],
   "source": [
    "from dataset_utils.reader import ADIQDataset\n",
    "from dataset_utils.outputs import to_basic_prompt\n",
    "\n",
    "ds = ADIQDataset(\"datasets/simpleV5\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "b2eb100b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "9065"
      ]
     },
     "execution_count": 106,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(ds.questions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "id": "3ae7edad",
   "metadata": {},
   "outputs": [],
   "source": [
    "question_template = \"\"\"\n",
    "## Asset Description:\n",
    "{asset_type}: {asset_description}\n",
    "\n",
    "## Conditions:\n",
    "{conditions}\n",
    "\n",
    "## How long the conditions were met:\n",
    "{temporal_condition}\n",
    "\n",
    "{question_prompt}\n",
    "{options}\n",
    "\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "id": "ef5372cf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "## Asset Description:\n",
      "AHU: Air Handling Unit: A device used to condition and circulate air as part of a heating, ventilating, and air-conditioning (HVAC) system.\n",
      "\n",
      "## Conditions:\n",
      "- AHU Running\n",
      "- Enthalpy > 29 BTU/lb\n",
      "- Humidification Valve % > 2%\n",
      "\n",
      "## How long the conditions were met:\n",
      "Met for 1 Hour\n",
      "\n",
      "From the given options, which one MOST likely corresponds to the observed asset behavior?\n",
      "A). Pump problems (VFD problems)\n",
      "B). Check the logic in the BMS to see how it is set up\n",
      "C). Static pressure sensors need calibration, repair or replacement\n",
      "D). Too many CRAC units are running for the amount of load\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(to_basic_prompt(ds.questions[2000],question_template, ds.asset_descriptions))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "1a3aece2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(44, [False, True, False, False])"
      ]
     },
     "execution_count": 109,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ds.questions[2000].rule_id, ds.questions[2000].correct"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "id": "78beb78f",
   "metadata": {},
   "outputs": [],
   "source": [
    "q_type_stats = {\"p\":0,\"n\":0}\n",
    "for q in ds.questions:\n",
    "    if q.question_type == \"positive\":\n",
    "        q_type_stats[\"p\"] += 1\n",
    "    else:\n",
    "        q_type_stats[\"n\"] += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "id": "77b54638",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'p': 5240, 'n': 3825}"
      ]
     },
     "execution_count": 111,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "q_type_stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "id": "1a205402",
   "metadata": {},
   "outputs": [],
   "source": [
    "opt_comp = {}\n",
    "for q in ds.questions:\n",
    "    try:\n",
    "        opt_comp[len(q.options)] += 1\n",
    "    except KeyError as er:\n",
    "        opt_comp[len(q.options)] = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "id": "84eb84c7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{3: 3825, 4: 5240}"
      ]
     },
     "execution_count": 113,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "opt_comp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "28b72099",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.11.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
