{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d079838e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_1158049/195145940.py:15: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from tqdm.autonotebook import tqdm\n",
      "[nltk_data] Downloading package stopwords to /root/nltk_data...\n",
      "[nltk_data]   Package stopwords is already up-to-date!\n"
     ]
    }
   ],
   "source": [
    "import os, sys\n",
    "import fitz\n",
    "import re\n",
    "import json\n",
    "from datetime import datetime\n",
    "from typing import Optional, List, Callable, Any, Tuple, Dict, Self, Union, TypedDict\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",
    "from tqdm.autonotebook import tqdm\n",
    "import itertools\n",
    "from dotenv import load_dotenv\n",
    "import string\n",
    "\n",
    "sys.path.append(\"../\")\n",
    "\n",
    "load_dotenv(dotenv_path=\"../.env\")\n",
    "nltk.download('stopwords')\n",
    "\n",
    "random.seed(42)\n",
    "np.random.seed(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "d715496a",
   "metadata": {},
   "outputs": [],
   "source": [
    "rule_list = [\"AC00003B?\", \"AH00059\", \"BR00007\", \"BR00008\", \"BR00009\", \n",
    "             \"BR00010\", \"BR00011\", \"BR00012\",\"CR00013\", \"CR00014\",\n",
    "             \"CR00015\", \"CR00016\",\"CR00017\",\"CR00018\",\"CR00019\",\n",
    "             \"CR00020\", \"CT00004\", \"CT00006\",\"PD00004\"\n",
    "             ]\n",
    "data = pd.read_csv(\"RulesLogicTest.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ee34a06c",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = data.loc[data[\"Rule\"].isin(rule_list)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "b213d348",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = data[[\"Rule\", \"Rule Name\", \"Testing Logic\",\"What to look for\"]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "8544f377",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = data.dropna()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "7407db75",
   "metadata": {},
   "outputs": [],
   "source": [
    "data[\"conditions\"] = data[\"Testing Logic\"].str.split(\"\\n\")\n",
    "data[\"observations\"] = data[\"What to look for\"].str.split(\"\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "905223ef",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3      [Dryer not functioning, Air to air heat exhang...\n",
       "68     [Temperature sensor calibration, Humididty sen...\n",
       "82     [Excessive load, Makeup water level issue, Fue...\n",
       "83     [Outside air temperature sensor failure, Seque...\n",
       "84                           [Setpoint manual override ]\n",
       "85     [Boiler tube fouling, Fuel supply issue, Econo...\n",
       "86     [System leak, Make up water valve issue, Level...\n",
       "87     [System leak, Pressure/tempurture sensor failu...\n",
       "113    [Pressure sensor calibration, VFD communicatio...\n",
       "114    [Pressure sensor calibration, VFD communicatio...\n",
       "115    [Temperature sensor calibration, Chiller refri...\n",
       "116                [System leak, Make up sensor failure]\n",
       "117    [Setpoint manual override , Control system com...\n",
       "118    [Chilled water valve failure, Chilled water va...\n",
       "119    [Chiller running outside of design parameters,...\n",
       "123    [Too many cnodenser pumps running, Condenser p...\n",
       "125    [Outside air temperature sensor failure, Cooli...\n",
       "140    [Power Meter Current Transformer issue, Increa...\n",
       "Name: observations, dtype: object"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[\"observations\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "3d7282d1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Rule</th>\n",
       "      <th>Rule Name</th>\n",
       "      <th>Testing Logic</th>\n",
       "      <th>What to look for</th>\n",
       "      <th>conditions</th>\n",
       "      <th>observations</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>AC00003B?</td>\n",
       "      <td>Air Compressor - Clogged Filters</td>\n",
       "      <td>Air Compressor Running\\nDischarge Air Temperat...</td>\n",
       "      <td>Dryer not functioning\\nAir to air heat exhange...</td>\n",
       "      <td>[Air Compressor Running, Discharge Air Tempera...</td>\n",
       "      <td>[Dryer not functioning, Air to air heat exhang...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>82</th>\n",
       "      <td>BR00007</td>\n",
       "      <td>Boiler – Steam Pressure Attainment</td>\n",
       "      <td>Boiler Running\\n(ABS(Steam Pressure - Steam Pr...</td>\n",
       "      <td>Excessive load\\nMakeup water level issue\\nFuel...</td>\n",
       "      <td>[Boiler Running, (ABS(Steam Pressure - Steam P...</td>\n",
       "      <td>[Excessive load, Makeup water level issue, Fue...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>85</th>\n",
       "      <td>BR00010</td>\n",
       "      <td>Boiler - Efficiency</td>\n",
       "      <td>Boiler Running\\nFire Rate &gt; 20%\\nSteam Boiler ...</td>\n",
       "      <td>Boiler tube fouling\\nFuel supply issue\\nEconom...</td>\n",
       "      <td>[Boiler Running, Fire Rate &gt; 20%, Steam Boiler...</td>\n",
       "      <td>[Boiler tube fouling, Fuel supply issue, Econo...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>86</th>\n",
       "      <td>BR00011</td>\n",
       "      <td>Boiler - Makeup Water High</td>\n",
       "      <td>Humidification System Mode (AHU Point) = 0 IF ...</td>\n",
       "      <td>System leak\\nMake up water valve issue\\nLevel ...</td>\n",
       "      <td>[Humidification System Mode (AHU Point) = 0 IF...</td>\n",
       "      <td>[System leak, Make up water valve issue, Level...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>113</th>\n",
       "      <td>CR00014</td>\n",
       "      <td>Chiller – VFD Speed is Low</td>\n",
       "      <td>Chiller Running\\nNumber of Chillers Running is...</td>\n",
       "      <td>Pressure sensor calibration\\nVFD communication...</td>\n",
       "      <td>[Chiller Running, Number of Chillers Running i...</td>\n",
       "      <td>[Pressure sensor calibration, VFD communicatio...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>114</th>\n",
       "      <td>CR00015</td>\n",
       "      <td>Chiller – VFD Speed is High</td>\n",
       "      <td>Chiller Running\\nVFD Speed % &gt; 97%\\n(Chilled W...</td>\n",
       "      <td>Pressure sensor calibration\\nVFD communication...</td>\n",
       "      <td>[Chiller Running, VFD Speed % &gt; 97%, (Chilled ...</td>\n",
       "      <td>[Pressure sensor calibration, VFD communicatio...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>115</th>\n",
       "      <td>CR00016</td>\n",
       "      <td>Chiller – Amperage is High</td>\n",
       "      <td>Chiller Running\\nChiller % Loaded&gt; 97%\\n(Chill...</td>\n",
       "      <td>Temperature sensor calibration\\nChiller refrig...</td>\n",
       "      <td>[Chiller Running, Chiller % Loaded&gt; 97%, (Chil...</td>\n",
       "      <td>[Temperature sensor calibration, Chiller refri...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>118</th>\n",
       "      <td>CR00019</td>\n",
       "      <td>Chiller - Chiller Off and running chilled water</td>\n",
       "      <td>Chiller NOT Running\\nCoolant Flow &gt; 50 g/m\\nMe...</td>\n",
       "      <td>Chilled water valve failure\\nChilled water val...</td>\n",
       "      <td>[Chiller NOT Running, Coolant Flow &gt; 50 g/m, M...</td>\n",
       "      <td>[Chilled water valve failure, Chilled water va...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>123</th>\n",
       "      <td>CT00004</td>\n",
       "      <td>Cooling Tower - Efficiency</td>\n",
       "      <td>Condenser Water Flow &gt; 50 gallon/minute\\n(Sum ...</td>\n",
       "      <td>Too many cnodenser pumps running\\nCondenser pu...</td>\n",
       "      <td>[Condenser Water Flow &gt; 50 gallon/minute, (Sum...</td>\n",
       "      <td>[Too many cnodenser pumps running, Condenser p...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125</th>\n",
       "      <td>CT00006</td>\n",
       "      <td>Cooling Tower - Discharge Temperature Setpoint...</td>\n",
       "      <td>Cooling Tower Running\\n55 degF &lt; Outside Air T...</td>\n",
       "      <td>Outside air temperature sensor failure\\nCoolin...</td>\n",
       "      <td>[Cooling Tower Running, 55 degF &lt; Outside Air ...</td>\n",
       "      <td>[Outside air temperature sensor failure, Cooli...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>140</th>\n",
       "      <td>PD00004</td>\n",
       "      <td>PDU - Standard Deviation One</td>\n",
       "      <td>Power Input &gt; 0.1KW\\nPower Input &gt; 5 Standard ...</td>\n",
       "      <td>Power Meter Current Transformer issue\\nIncreas...</td>\n",
       "      <td>[Power Input &gt; 0.1KW, Power Input &gt; 5 Standard...</td>\n",
       "      <td>[Power Meter Current Transformer issue, Increa...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          Rule                                          Rule Name  \\\n",
       "3    AC00003B?                   Air Compressor - Clogged Filters   \n",
       "82     BR00007                 Boiler – Steam Pressure Attainment   \n",
       "85     BR00010                                Boiler - Efficiency   \n",
       "86     BR00011                         Boiler - Makeup Water High   \n",
       "113    CR00014                         Chiller – VFD Speed is Low   \n",
       "114    CR00015                        Chiller – VFD Speed is High   \n",
       "115    CR00016                         Chiller – Amperage is High   \n",
       "118    CR00019    Chiller - Chiller Off and running chilled water   \n",
       "123    CT00004                         Cooling Tower - Efficiency   \n",
       "125    CT00006  Cooling Tower - Discharge Temperature Setpoint...   \n",
       "140    PD00004                       PDU - Standard Deviation One   \n",
       "\n",
       "                                         Testing Logic  \\\n",
       "3    Air Compressor Running\\nDischarge Air Temperat...   \n",
       "82   Boiler Running\\n(ABS(Steam Pressure - Steam Pr...   \n",
       "85   Boiler Running\\nFire Rate > 20%\\nSteam Boiler ...   \n",
       "86   Humidification System Mode (AHU Point) = 0 IF ...   \n",
       "113  Chiller Running\\nNumber of Chillers Running is...   \n",
       "114  Chiller Running\\nVFD Speed % > 97%\\n(Chilled W...   \n",
       "115  Chiller Running\\nChiller % Loaded> 97%\\n(Chill...   \n",
       "118  Chiller NOT Running\\nCoolant Flow > 50 g/m\\nMe...   \n",
       "123  Condenser Water Flow > 50 gallon/minute\\n(Sum ...   \n",
       "125  Cooling Tower Running\\n55 degF < Outside Air T...   \n",
       "140  Power Input > 0.1KW\\nPower Input > 5 Standard ...   \n",
       "\n",
       "                                      What to look for  \\\n",
       "3    Dryer not functioning\\nAir to air heat exhange...   \n",
       "82   Excessive load\\nMakeup water level issue\\nFuel...   \n",
       "85   Boiler tube fouling\\nFuel supply issue\\nEconom...   \n",
       "86   System leak\\nMake up water valve issue\\nLevel ...   \n",
       "113  Pressure sensor calibration\\nVFD communication...   \n",
       "114  Pressure sensor calibration\\nVFD communication...   \n",
       "115  Temperature sensor calibration\\nChiller refrig...   \n",
       "118  Chilled water valve failure\\nChilled water val...   \n",
       "123  Too many cnodenser pumps running\\nCondenser pu...   \n",
       "125  Outside air temperature sensor failure\\nCoolin...   \n",
       "140  Power Meter Current Transformer issue\\nIncreas...   \n",
       "\n",
       "                                            conditions  \\\n",
       "3    [Air Compressor Running, Discharge Air Tempera...   \n",
       "82   [Boiler Running, (ABS(Steam Pressure - Steam P...   \n",
       "85   [Boiler Running, Fire Rate > 20%, Steam Boiler...   \n",
       "86   [Humidification System Mode (AHU Point) = 0 IF...   \n",
       "113  [Chiller Running, Number of Chillers Running i...   \n",
       "114  [Chiller Running, VFD Speed % > 97%, (Chilled ...   \n",
       "115  [Chiller Running, Chiller % Loaded> 97%, (Chil...   \n",
       "118  [Chiller NOT Running, Coolant Flow > 50 g/m, M...   \n",
       "123  [Condenser Water Flow > 50 gallon/minute, (Sum...   \n",
       "125  [Cooling Tower Running, 55 degF < Outside Air ...   \n",
       "140  [Power Input > 0.1KW, Power Input > 5 Standard...   \n",
       "\n",
       "                                          observations  \n",
       "3    [Dryer not functioning, Air to air heat exhang...  \n",
       "82   [Excessive load, Makeup water level issue, Fue...  \n",
       "85   [Boiler tube fouling, Fuel supply issue, Econo...  \n",
       "86   [System leak, Make up water valve issue, Level...  \n",
       "113  [Pressure sensor calibration, VFD communicatio...  \n",
       "114  [Pressure sensor calibration, VFD communicatio...  \n",
       "115  [Temperature sensor calibration, Chiller refri...  \n",
       "118  [Chilled water valve failure, Chilled water va...  \n",
       "123  [Too many cnodenser pumps running, Condenser p...  \n",
       "125  [Outside air temperature sensor failure, Cooli...  \n",
       "140  [Power Meter Current Transformer issue, Increa...  "
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = data.loc[(data[\"conditions\"].apply(lambda x: len(x))>2)&(data[\"observations\"].apply(lambda x: len(x))>2)]\n",
    "data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "99174822",
   "metadata": {},
   "outputs": [],
   "source": [
    "json_data = {}\n",
    "\n",
    "for _, d in data.to_dict(orient='index').items():\n",
    "    asset_data = d['Rule Name'].replace(\"–\", \"-\").split(\"-\")\n",
    "    asset = asset_data[0].strip()\n",
    "    temporal = [x for x in d['conditions'] if \"Met\" in x]\n",
    "    json_data[d['Rule']] = {\n",
    "        \"asset\":asset,\n",
    "        \"temporal\": temporal[0] if len(temporal) == 1 else \"None\",\n",
    "        \"rule_name\":d['Rule Name'],\n",
    "        \"conditions\": [x for x in d['conditions'] if \"Met\" not in x],\n",
    "        'observations':d['observations']\n",
    "\n",
    "    }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6aa6e475",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "d0dd0020",
   "metadata": {},
   "outputs": [],
   "source": [
    "from dataset.utils import file_handle\n",
    "\n",
    "file_handle.save_json(json_data, \"rule_logic_test2.json\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "082f2149",
   "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
}
