{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 173,
   "id": "3594b3d1",
   "metadata": {},
   "outputs": [],
   "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\n",
    "from abc import abstractmethod, ABC\n",
    "import pickle\n",
    "import copy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "id": "0e88117b",
   "metadata": {},
   "outputs": [],
   "source": [
    "#parameter \n",
    "\n",
    "extract_fol = \"extracted\"\n",
    "dataset_loc = os.path.join(extract_fol,\"observations.rules.json\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 174,
   "id": "eaec6427",
   "metadata": {},
   "outputs": [],
   "source": [
    "def save_json(data:dict, loc:str) -> None:\n",
    "    with open(loc, \"w\") as f0:\n",
    "        json.dump(data, f0)\n",
    "\n",
    "\n",
    "def text_write(text, filename= \"debug.test\"):\n",
    "    with open(filename, \"w\") as f0:\n",
    "        f0.write(text)\n",
    "\n",
    "def dict_value_string_function(d:dict, func:Callable[[Optional[Any]], Optional[Any]]) -> dict:\n",
    "    r_dict = {}\n",
    "    for k,v in d.items():\n",
    "        if isinstance(v, dict):\n",
    "            r_dict[k] = dict_value_string_function(v,func)\n",
    "        else:\n",
    "            r_dict[k] = func(v)\n",
    "\n",
    "    return r_dict\n",
    "\n",
    "'''\n",
    "class ops:\n",
    "    _OPS = None\n",
    "    def __init__(self, statement) -> None:\n",
    "        self.subject = None\n",
    "        self.value = None\n",
    "        ops._process_statement(statement)\n",
    "\n",
    "    @abstractmethod\n",
    "    def _create_subject_value(self, statement:str):\n",
    "        raise NotImplementedError\n",
    "\n",
    "    @staticmethod\n",
    "    def _process_statement(statement:str):\n",
    "\n",
    "        pass\n",
    "        \n",
    "class OR(ops):\n",
    "    _OPS = \"OR\"\n",
    "    def __init__(self, statement) -> None:\n",
    "        super().__init__(statement)\n",
    "\n",
    "    def _create_subject_value(self, statement: str):\n",
    "        pass\n",
    "'''\n",
    "\n",
    "class OPS:\n",
    "    ops = [\"OR\", \"AND\"]\n",
    "\n",
    "    def __init__(self) -> None:\n",
    "        for o in self.ops:\n",
    "            setattr(self,o,o)\n",
    "\n",
    "\n",
    "    \n",
    "'''\n",
    "def print_tree(root, level=0, prefix=\"Root: \"):\n",
    "    if root is not None:\n",
    "        print_tree(root.right, level+1, \"R---- \")\n",
    "        print(\"    \"*level + prefix + root.val)\n",
    "        print_tree(root.left, level+1, \"L---- \")\n",
    "\n",
    "\n",
    "class Node:\n",
    "    def __init__(self, ops:str, statement:str) -> None:\n",
    "        self.left = None\n",
    "        self.val = None\n",
    "        self.right = None\n",
    "        self.ops = ops\n",
    "        self.statement = statement\n",
    "        self.build_graph()\n",
    "\n",
    "    def build_graph(self):\n",
    "        split = self.statement.split(self.ops)\n",
    "        if len(split)>=2:\n",
    "            self.left = Node(self.ops,split[0])\n",
    "            self.val = self.ops\n",
    "            self.right = Node(self.ops, self.ops.join(split[1:]))\n",
    "        else:\n",
    "            self.val = self.statement\n",
    "\n",
    "\n",
    "    @staticmethod\n",
    "    def generate_graph(statement:str) -> Node:\n",
    "        root = None\n",
    "\n",
    "        for oi, o in enumerate(OPS.ops):\n",
    "            if oi == 0:\n",
    "                root = Node(o,statement)\n",
    "\n",
    "                return root\n",
    "            \n",
    "'''\n",
    "\n",
    "def print_tree(root, level=0, prefix=\"Root: \"):\n",
    "    if root is not None:\n",
    "        print(\"    \"*level + prefix + root.val)\n",
    "        for x in root.children:\n",
    "            print_tree(x, level+1, \"L---- \")\n",
    "\n",
    "\n",
    "class Node:\n",
    "    def __init__(self, ops:str, statement:Optional[str], manual=False) -> None:\n",
    "        self.children = []\n",
    "        self.val = None\n",
    "        self.ops = ops\n",
    "        self.statement = statement\n",
    "\n",
    "        if not manual:\n",
    "            self.build_graph()\n",
    "\n",
    "    def build_graph(self):\n",
    "        split = self.statement.split(self.ops)\n",
    "        if len(split)>=2:\n",
    "            self.children = [Node(self.ops,split[0]), Node(self.ops, self.ops.join(split[1:]))]\n",
    "            self.val = self.ops\n",
    "        else:\n",
    "            self.val = self.statement\n",
    "\n",
    "\n",
    "    @staticmethod\n",
    "    def generate_graph(statement:str) -> Node:\n",
    "        root = None\n",
    "\n",
    "        for oi, o in enumerate(OPS.ops):\n",
    "            if oi == 0:\n",
    "                root = Node(o,statement)\n",
    "\n",
    "                return root\n",
    "\n",
    "\n",
    "def common_string_replace(string:str):\n",
    "    return string.replace(\"\\n\", \" \").replace(\"AND/OR\", \"OR\")\n",
    "\n",
    "\n",
    "def process_rule(rule_str:str) -> Node:\n",
    "    # break rule list\n",
    "    individual_rules = list(map(lambda x: x.strip(),rule_str.split(\"\\n -\")))\n",
    "    individual_rules[0] = individual_rules[0].replace(\"- \", \"\")\n",
    "\n",
    "    #print(individual_rules)\n",
    "\n",
    "    #extract conditionals\n",
    "    cond_info_rules = []\n",
    "    for i in range(1,len(individual_rules)):\n",
    "        r1 = common_string_replace(individual_rules[i-1])\n",
    "        r2 = common_string_replace(individual_rules[i])\n",
    "\n",
    "        #print(r1,\"$$$\")\n",
    "        #print(r2, \"$$$$\")\n",
    "\n",
    "        try:\n",
    "            _cond_r1 = \"OR\" in r1[:4]\n",
    "        except IndexError:\n",
    "            _cond_r1 = False\n",
    "\n",
    "        try:\n",
    "            _cond_r2 = \"OR\" in r2[:4]\n",
    "        except IndexError:\n",
    "            _cond_r2 = False\n",
    "            \n",
    "\n",
    "        if  _cond_r1 and _cond_r2:\n",
    "            cond_info_rules[-1].append(r1[2:].strip())\n",
    "        elif _cond_r2:\n",
    "            #cond_info_rules.append([r1,r2[2:].strip()])\n",
    "            cond_info_rules.append([r1])\n",
    "        elif _cond_r1:\n",
    "            cond_info_rules[-1].append(r1[2:].strip())\n",
    "        else:\n",
    "            cond_info_rules.append(r1)\n",
    "\n",
    "        if i == len(individual_rules) - 1 :\n",
    "            if _cond_r2:\n",
    "                cond_info_rules[-1].append(r2[2:].strip())\n",
    "            else:\n",
    "                cond_info_rules.append(r2)\n",
    "\n",
    "        #print(cond_info_rules, \"****\")\n",
    "\n",
    "    \n",
    "    full_root = Node('AND', rule_str, True)\n",
    "    full_root.children = []\n",
    "    full_root.val = \"root\"\n",
    "    for c in cond_info_rules:\n",
    "        if isinstance(c,str):\n",
    "            full_root.children.append(Node.generate_graph(c))\n",
    "        else:\n",
    "            _temp = Node('OR', None, True)\n",
    "            _temp.children = [Node.generate_graph(x) for x in c]\n",
    "            _s = \" OR \".join([x.statement for x in _temp.children])\n",
    "            _temp.statement = _s\n",
    "            _temp.val = 'OR'\n",
    "            full_root.children.append(_temp)\n",
    "\n",
    "    return full_root\n",
    "\n",
    "\n",
    "def save_pickle(obj:Any, loc:str)->None:\n",
    "    with open(loc, \"wb\") as f0:\n",
    "        pickle.dump(obj,f0)\n",
    "\n",
    "def load_pickle(loc:str) -> Any:\n",
    "    with open(loc, \"rb\") as f0:\n",
    "        return pickle.load(f0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 175,
   "id": "7daac76e",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(dataset_loc, \"r\") as f0:\n",
    "    data = json.load(f0)\n",
    "\n",
    "processed_data = copy.deepcopy(data)\n",
    "for pd, d in zip(processed_data[\"rule_set\"],data[\"rule_set\"]):\n",
    "    pd[\"display_text\"][\"rules\"] = process_rule(d[\"display_text\"][\"rules\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 177,
   "id": "fadc3aee",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Asset:Air Compressor\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- OR\n",
      "        L---- (ABS[Pressure Pressure Setpoint] > 10 PSI\n",
      "        L---- (Pressure > 130 PSI IF Pressure Setpoint Not Reporting))\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Too many or too few compressors are running', 'Pressure sensors need calibration', 'Leaks in air lines']\n",
      "\n",
      "\n",
      "Asset:Air Compressor\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- The date is NOT a Monday\n",
      "    L---- Air Flow > (Previous Day's Average Air Flow * 20%)\n",
      "    L---- Austin using 60 CFM\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Too many or too few compressors are running', 'A new leak in the air lines', 'Pressure sensors need calibration']\n",
      "\n",
      "\n",
      "Asset:Air Compressor\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- VFD Speed % > 95%\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Filters clogged', 'Unit bypassing or blowing off too much air']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Cooling Valve % >= 5%\n",
      "    L---- OR\n",
      "        L---- (Heating Valve % >= 5% \n",
      "        L----  Preheat Valve % >= 5%)\n",
      "    L---- Heating Drained Flag = 1 IF Reporting\n",
      "    L---- Cooling Drained Flag = 1 IF Reporting\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Check Building Control System is set for either heating or cooling but not both', 'Check for correct operation of the cooling and heating valves', 'Lost signal to valve, Check pneumatic lines or electricity to valve is operating properly', 'Over ride in place']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- OR\n",
      "        L---- (OAT - Supply Air Temperature Setpoint > 5 °F\n",
      "        L---- OAT - Supply Air Temperature > 5 °F AND Supply Air Temperature  Setpoint Not Reporting)\n",
      "    L---- OR\n",
      "        L---- (Heating Valve % > 10% \n",
      "        L----  Preheat Valve % > 10%)\n",
      "    L---- Heating Drained Flag = 1 IF Reporting\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['BMS sequence of operation for heating valve is incorrect', 'Command to valve, but valve is not responding,', 'Lost signal to valve', 'Valve Hunting']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running (IF VAV, Check Parent AHU Running)\n",
      "    L---- OR\n",
      "        L---- (Zone Temperature >= 79 °F  \n",
      "        L----  Return Air Temperature >= 79 °F IF Zone Temperature Not Reporting)\n",
      "    L---- Cooling Drained Flag = 1 IF Reporting\n",
      "    L---- Met for 3 Hours\n",
      "    L---- Southbury: No Zone Temperature Check\n",
      "Observations:\n",
      "['Cooling issues with the AHU because Zone Temperature OR Return Temperature greater than 79 F / 26.1 C', 'Hot water or steam valve leaks']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running (IF VAV, Check Parent AHU Running)\n",
      "    L---- OR\n",
      "        L---- (Zone Temperature <= 65 °F  \n",
      "        L----  Return Air Temperature <= 65 °F IF Zone Temperature Not Reporting)\n",
      "    L---- POK: OAT < 75 °F\n",
      "    L---- Heating Drained Flag = 1 IF Reporting\n",
      "    L---- Met for 2 Hours\n",
      "    L---- Tucson: Zone/Return Air Temperature of 68 °F\n",
      "    L---- Southbury: No Zone Temperature Check\n",
      "Observations:\n",
      "['Heating issues with the AHU because the Zone Temperature OR Return Temperature less than 65 F / 18.3 C', 'Economizer Issues']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running (IF VAV, Check Parent AHU Running)\n",
      "    L---- OR\n",
      "        L---- (Zone Temperature <= 65 °F  \n",
      "        L----  Return Air Temperature <= 65 °F IF Zone Temperature Not Reporting)\n",
      "    L---- POK: OAT < 75 °F\n",
      "    L---- Heating Drained Flag = 1 IF Reporting\n",
      "    L---- Met for 2 Hours\n",
      "    L---- Tucson: Zone/Return Air Temperature of 68 °F\n",
      "    L---- Southbury: No Zone Temperature Check\n",
      "Observations:\n",
      "['Heating issues with the AHU because the Zone Temperature OR Return Temperature less than 65 F / 18.3 C', 'Economizer Issues']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Occupied = 0\n",
      "    L---- 55 °F < Zone Temperature < 85 °F IF Reporting\n",
      "    L---- OR\n",
      "        L---- (Heating System Drained Flag = 0 IF Reporting \n",
      "        L----  Cooling System  Drained Flag = 0 IF Reporting)\n",
      "    L---- Humidification System Drained Flag = 0 IF Reporting\n",
      "    L---- Unoccupied Heating = 0 IF reporting\n",
      "    L---- Unoccupied Cooling = 0 IF reporting\n",
      "    L---- Dehumidification Mode = 0 IF reporting\n",
      "    L---- Met for 2 Hours\n",
      "    L---- Poughkeepsie: Using 68 °F < Zone Temperature < 75 °F IF Reporting\n",
      "Observations:\n",
      "['Fan in Hand or Manual Mode or over ridden on', 'VFD Issue']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Schedule = 0\n",
      "    L---- 55 °F < Zone Temperature < 85 °F IF Reporting\n",
      "    L---- OAT > 35 °F\n",
      "    L---- OR\n",
      "        L---- (Heating System Drained Flag = 0 IF Reporting  \n",
      "        L----  Cooling System Drained Flag = 0 IF Reporting)\n",
      "    L---- Humidification System Drained Flag = 0 IF Reporting\n",
      "    L---- Unoccupied Heating = 0 IF reporting\n",
      "    L---- Unoccupied Cooling = 0 IF reporting\n",
      "    L---- Dehumidification Mode = 0 IF reporting\n",
      "    L---- Met for 2 Hours\n",
      "    L---- Poughkeepsie: Using 68 °F < Zone Temperature < 75 °F IF Reporting (take  out?)\n",
      "    L---- Rochester: 3 Hours\n",
      "    L---- Tucson: 3 Hours\n",
      "    L---- Austin: Web Command = 0 IF Reporting,  - Using POK Zone Temps\n",
      "Observations:\n",
      "['BMS schedule has been changed', 'Opportunity to reduce schedule', 'Processor or controller problem']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Supply Fan Output % > 97%\n",
      "    L---- Duct Static Pressure < (Static Pressure Setpoint - 0.1 \"H2O) IF Reporting\n",
      "    L---- OAT < 95 °F\n",
      "    L---- Met for 2 Hours\n",
      "    L---- Littleton: Met for 4 Hours\n",
      "    L---- WRL: Met for 4 hours (2016-08-16)\n",
      "    L---- SVL: Met for 4 hours (2016-08-17)\n",
      "Observations:\n",
      "['Filters need changing', 'Undersized system for load', 'VFD issues, signal to fan set correctly?', 'Bad motor, bearings', 'Fan blades at incorrect pitch', 'VAV box issues like broken duct work, dampers always at 100%', 'Static pressure sensors need calibration, repair or replacement']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Return Fan Output % > 97%\n",
      "    L---- OAT < 95 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['VAV boxes stuck or broken open', 'Incorrect zone temp setpoints causing VAV boxes to be full open', 'VFD issues', 'Bad motor', 'Fan blades at incorrect pitch']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- SubType NOT FCU or OAU\n",
      "    L---- Outside Air Damper % < 95%\n",
      "    L---- Economizer Mode = 1 IF Reporting\n",
      "    L---- Enthalpy < 28 IF Reporting\n",
      "    L---- 37 °F < OAT < (Return Air Temperature - 4 °F)\n",
      "    L---- Cooling Valve % > 5%\n",
      "    L---- OR\n",
      "        L---- (Heating Drained Flag = 1 IF Reporting\n",
      "        L---- Cooling Drained Flag = 1 IF Reporting)\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['BMS is commanding cooling valve on when it should not', 'Check the logic in the BMS for economizer mode']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- OR\n",
      "        L---- (Filter Differential Pressure > Supply Filter Static Pressure Setpoint  \n",
      "        L----  (Post Filter Bank Pressure - Pre Filter Bank Pressure) > Supply Filter Static  Pressure Setpoint IF Filter Differential Pressure NOT Reporting)\n",
      "    L---- Supply Fan Output % > 50%\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Check condition of the filters']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU NOT Running\n",
      "    L---- SubType NOT MULTI or PU\n",
      "    L---- Duct Static Pressure < 0.1 in H2O IF Reporting\n",
      "    L---- 35 °F < OAT < 80 °F\n",
      "    L---- (Mixed Air Temperature - Supply Air Temperature) > 10 °F\n",
      "    L---- Heating Drained Flag = 1 IF Reporting\n",
      "    L---- Cooling Drained Flag = 1 IF Reporting\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Temperature sensors need calibration or replacement', 'Chilled water valve is leaking', 'Dampers are not properly closed', 'Freeze protect issues', 'Leaking preheat or hot water valve']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU NOT Running\n",
      "    L---- SubType NOT MULTI\n",
      "    L---- (Supply Air Temperature - Mixed Air Temperature) > 20 °F\n",
      "    L---- OAT > 35 °F\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Temperature sensors need calibration or replacement', 'Heating valve is leaking', 'Dampers are not properly closed']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- SubType NOT OAU, RAS, RAU\n",
      "    L---- Economizer Mode = 0 IF Economizer Mode Reporting\n",
      "    L---- OAT > Return Air Temperature\n",
      "    L---- Return Air CO2 < 1000 IF Return Air CO2 Reporting\n",
      "    L---- OR\n",
      "        L---- (Outside Air Damper % > (Outside Air Damper Minimum % + 2%)  \n",
      "        L----  Outside Air Damper % > 15% AND Outside Air Damper Minimum % Not  Reporting)\n",
      "    L---- Enthalpy > Reutrn Enthalpy IF Reporting\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Damper is commanded open greater than it needs to be - check the BMS logic']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- SubType NOT OAU or FCU\n",
      "    L---- OR\n",
      "        L---- (OAT > Setpoint Temperature \n",
      "        L----  OAT > Supply Air Temperature AND  Setpoint Temperature Not Reporting)\n",
      "    L---- OR\n",
      "        L---- (OAT < Return Air Temperature \n",
      "        L----  OAT < 75 °F AND Return Air  Temperature Not Reporting)\n",
      "    L---- Bromont: Return Air Damper % = 0%\n",
      "    L---- Everyone Else: Outside Air Damper % = 100%\n",
      "    L---- (Mixed Air Temperature - OAT) > 5 °F\n",
      "    L---- Met for 2 Hours\n",
      "    L---- Southbury: (Mixed Air Temperature - OAT) > 8 °F\n",
      "Observations:\n",
      "['Check if the Return Air Damper is closing tightly enough', 'Check for temperature sensor calibration issues']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- OR\n",
      "        L---- (10 °F < OAT < Setpoint Temperature  \n",
      "        L----  10 °F < OAT < Supply Air Temperature AND Setpoint Temperature Not  Reporting)\n",
      "    L---- OR\n",
      "        L---- (Heating AND Preheat AND Reheat Valve % < 5%  \n",
      "        L---- OR\n",
      "            L----  Heating AND Preheat Valve % < 5% AND Reheat Valve % Not Reporting  \n",
      "            L---- OR\n",
      "                L----  Heating AND Reheat Valve % < 5% AND Preheat Valve % Not Reporting  \n",
      "                L---- OR\n",
      "                    L----  Heating Valve % < 5% AND Preheat AND Reheat Valve % Not Reporting  \n",
      "                    L---- OR\n",
      "                        L----  Preheat AND Reheat Valve % < 5% AND Heating Valve % Not Reporting  \n",
      "                        L---- OR\n",
      "                            L----  Preheat Valve % < 5% AND Heating AND Reheat Valve % Not Reporting  \n",
      "                            L---- OR\n",
      "                                L----  Reheat Valve % < 5% AND Heating AND Preheat Valve % Not Reporting  \n",
      "                                L----  Heating AND Preheat AND Reheat Valve % Not Reporting)\n",
      "    L---- Cooling Valve % < 2%\n",
      "    L---- (Mixed Air Temperature - Supply Air Temperature) > 7 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Flow through valve should be zero', 'Verify Actuator, Valve and Dampers are working correctly and not stuck', 'Check Temperature sensors']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- SubType NOT OAU, RAS, RAU\n",
      "    L---- OAT > 37 °F\n",
      "    L---- OR\n",
      "        L---- (Economizer Mode = 1  \n",
      "        L---- OR\n",
      "            L----  Supply Relative Humidity % > 35% AND Economizer Mode Not Reporting  \n",
      "            L----  Economizer Mode AND Supply Relative Humidity % Not Reporting)\n",
      "    L---- OR\n",
      "        L---- (OAT < Setpoint Temperature  \n",
      "        L----  OAT < Supply Air Temperature AND Setpoint Temperature Not Reporting)\n",
      "    L---- OR\n",
      "        L---- (Outside Air Damper % < Outside Air Damper Minimum %  \n",
      "        L----  Outside Air Damper % < 15% AND Outside Air Damper Minimum % Not  Reporting)\n",
      "    L---- Outside Air Damper % Does NOT = Daily Average\n",
      "    L---- Outside Air Damper %\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Control system sent the wrong command', 'Validate damper is not stuck closed or open or in between']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- SubType NOT OAU, RAS, RAU\n",
      "    L---- OR\n",
      "        L---- (Economizer Mode = 1  \n",
      "        L---- OR\n",
      "            L----  Enthalpy < Return Enthalpy if Economizer not reporting  \n",
      "            L----  Enthalpy < 26 IF Economizer Mode and Return Enthalpy Not Reporting)\n",
      "    L---- OR\n",
      "        L---- (OAT > Setpoint Temperature  \n",
      "        L----  OAT > Supply Air Temperature AND Setpoint Temperature Not Reporting)\n",
      "    L---- OR\n",
      "        L---- (OAT < (Return Air Temperature - 3 °F)  \n",
      "        L----  OAT < 75 °F AND Return Air Temperature Not Reporting)\n",
      "    L---- Outside Air Damper % < 90%\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Validate BMS command to outside air damper is correct', 'Verify physical operation of damper to control signal']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running for 4 hours\n",
      "    L---- OR\n",
      "        L---- SubType NOT MULTI \n",
      "        L----  VAV\n",
      "    L---- ABS(Setpoint Temperature - Supply Air Temperature) > 7 °F\n",
      "    L---- OR\n",
      "        L---- (Cooling Drained Flag = 1 IF Reporting  \n",
      "        L----  Heating Drained Flag = 1 IF Reporting)\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Check dampers', 'Chilled water control valve', 'Actuators', 'Temperature sensors', 'Heating valves']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU NOT Running\n",
      "    L---- 35 °F < OAT < 70 °F\n",
      "    L---- OR\n",
      "        L---- ((Heating Valve % = 0% \n",
      "        L---- OR\n",
      "            L----  Preheat Valve % = 0%)  \n",
      "            L----  (Heating Valve % = 0% AND Preheat Valve % = 0% IF Both Reporting))\n",
      "    L---- OR\n",
      "        L---- (Supply Air Temperature > 90 °F \n",
      "        L----  Mixed Air Temperature > 90 °F)\n",
      "    L---- Heating Drained Flag = 1 IF Reporting\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['The Heating Valve is leaking when closed', 'Lost signal to valve, check pneumatic or electrical inputs', 'The outside air damper is not closing securely', 'Check Temp Sensors', 'Check the command from the BMS']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running for 6 hours\n",
      "    L---- Outside Air Damper % Reporting\n",
      "    L---- OAT > 35 °F\n",
      "    L---- Heating Valve % > 97%\n",
      "    L---- Heating Drained Flag = 1 IF Reporting\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['BMS control logic', 'Valve issues - broken or clogged valve', 'Cooling coil maybe passing water. Check air line on chilled water valve', 'Discharge temperature sensor failure']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- OAT > 35 °F\n",
      "    L---- Preheat Valve % > 97%\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['BMS control logic', 'Preheat Valve issues - broken or clogged valve', 'Broken air line', 'Actuator issue', 'Damper may be stuck open on a cold day']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- OAT > 35 °F\n",
      "    L---- Reheat Valve % > 97%\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['BMS control logic', 'Valve issues - broken or clogged valve', 'Cooling coil maybe passing water. Check air line on chilled water valve', 'Discharge temperature sensor failure']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- OAT < 80 °F\n",
      "    L---- Cooling Valve % > 97%\n",
      "    L---- ABS(Supply Air Temperature Setpoint - Supply Air Temperature) > 3 IF  Setpoint Reporting\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['BMS control logic', 'Valve issues - broken or clogged valve', 'Heating coil maybe passing water. Check air line on hot water valve', 'Discharge temperature too low or sensor failure', 'Room Temp setpoint too low']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Supply Fan Output % < 95%\n",
      "    L---- Supply Fan Output % = Daily Average Supply Fan Output %\n",
      "    L---- Supply Fan Output % = Prev. Daily Average Supply Fan Output %\n",
      "    L---- Abs(Duct Static Pressure - Static Pressure Setpoint) > 0.2 in H2O IF  Reporting\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['VFD issues', 'Bad motor', 'Fan blades at incorrect pitch', 'Broken duct work', 'Static pressure sensors need calibration', 'System overridden to a specific speed', 'VFD minimum speed may be set too high']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Humidifier Valve % > 97%\n",
      "    L---- Met for 2 Hours\n",
      "    L---- Poughkeepsie & Warden: Met for 4 Hours\n",
      "Observations:\n",
      "['Command from BMS issue', 'Bad Valve', 'Blocked Valve']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Heating Valve % > 5%\n",
      "    L---- Cooling Valve % = 0%\n",
      "    L---- (Mixed Air Temperature - Supply Air Temperature) > 5 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['SAT or MAT Sensor Error', 'Leaking or Stuck Cooling or Heating Valve', 'Undersized or Fouled Heating Coil', 'Hot Water Supply temp too low', 'Problem with hot water circulating pump']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- OR\n",
      "        L---- SubType NOT OAU  (Outside Air Damper % > Outside Air Damper Minimum %  \n",
      "        L----  Outside Air Damper % > 15% AND Outside Air Damper Minimum % Not  Reporting)\n",
      "    L---- Outside Air Damper % NOT = 100%\n",
      "    L---- Preheat Valve % > 5%\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Command from BMS to Preheat Valve needs to be adjusted']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- OR\n",
      "        L---- SubType NOT OAU \n",
      "        L----  RAS\n",
      "    L---- Enthalpy > 29 BTU/lb\n",
      "    L---- OR\n",
      "        L---- (Economizer Mode = 1  \n",
      "        L---- OR\n",
      "            L----  Outside Air Damper % > Outside Air Damper Minimum % AND Economizer  Mode Not Reporting  \n",
      "            L----  Outside Air Damper % > 15% AND Outside Air Damper Minimum % Not  Reporting AND Economizer Mode Not Reporting)\n",
      "    L---- Return Air CO2 Not Reporting\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Damper is open when it is humid outside']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Heating Valve % = 0%\n",
      "    L---- (Supply Air Temperature - Mixed Air Temperature) > 5 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['The Heating Valve is leaking when closed', 'Outside air damper not closing securely', 'Temperature sensors may need calibration or replacement', 'Check the command from the BMS']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Enthalpy > 29 BTU/lb\n",
      "    L---- Humidification Valve % > 2%\n",
      "    L---- Met for 1 Hour\n",
      "Observations:\n",
      "['BMS control logic', 'Valve issues - broken or clogged valve', 'Cooling coil maybe passing water. Check air line on chilled water valve', 'Discharge temperature sensor failure']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Enthalpy < 15 BTU/lb\n",
      "    L---- Low Temp Chilled Water Valve % > 2%\n",
      "    L---- Met for 1 Hour\n",
      "Observations:\n",
      "['BMS command', 'Valve Broken', 'Valve blocked', 'Isolation valve closed', 'Dehumidification flow issue']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Enthalpy > 29 BTU/lb\n",
      "    L---- Low Temp Chilled Water Valve % < 5%\n",
      "    L---- Met for 1 Hour\n",
      "Observations:\n",
      "['BMS command issue', 'Dehumidification Flow Issue', 'Isolation Valve Closed']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Enthalpy < 15 BTU/lb\n",
      "    L---- Humidification Valve % < 5%\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['BMS command issue', 'Humidification valve Issue', 'Isolation Valve Closed']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Enthalpy < 15 BTU/lb\n",
      "    L---- OR\n",
      "        L---- ((Zone Relative Humidity % - Supply Relative Humidity Setpoint %) > 10%  \n",
      "        L----  (Supply Relative Humidity % - Supply Relative Humidity Setpoint %) >  10%)\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Humidifier is not turning off', 'Humidity sensor needs calibration or replacement']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Enthalpy < 29 BTU/lb\n",
      "    L---- OAT < 80 °F\n",
      "    L---- Low Temp Chilled Water Valve % > 97%\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['BMS command issue', 'Dehumidification Flow Issue', 'Isolation Valve Closed']\n",
      "\n",
      "\n",
      "Asset:AHU Humidity\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Humidification Valve % > 5%\n",
      "    L---- Low Temp Chilled Water Valve % > 5%\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['BMS command issue']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Exhaust Fan Running\n",
      "    L---- Schedule = 0\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['BMS schedule has been changed', 'Processor or controller problem']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- ABS(Static Pressure Setpoint – Static Pressure) > 0.2 in H2O\n",
      "    L---- Static Pressure Setpoint > 0\n",
      "    L---- Supply Fan Output % < 95%\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Check duct integrity', 'Static pressure sensor', 'VFD operation', 'Broken belt or loose belt on Motor', 'Minimum VFD speed set too high']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- SubType NOT RAS or OAU\n",
      "    L---- OAT > 25 °F\n",
      "    L---- (Heating Drained Flag = 0 IF Reporting)\n",
      "    L---- OR\n",
      "        L---- (Return Air Temperature > Setpoint Temperature  \n",
      "        L----  Return Air Temperature > Supply Air Temperature IF Setpoint  Temperature Not Reporting)\n",
      "    L---- OR\n",
      "        L---- (Outside Air Damper % - Outside Air Damper Minimum % > 10%  \n",
      "        L----  Outside Air Damper > 10% IF Outside Air Damper Minimum % Not  Reporting)\n",
      "    L---- OR\n",
      "        L---- Heating Valve % > 5% \n",
      "        L----  Preheat Valve % > 5%\n",
      "    L---- CO2 < 1000 ppm IF Reporting\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['BMS is commanding heating valve ON when it should not']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Subtype NOT VAV or MULTI\n",
      "    L---- Supply Fan Efficiency > (Asset Efficiency Parameter)\n",
      "    L---- Supply Fan Efficiency is calculated: Air Flow (CFM) divided by Power Usage  (KW)\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Belt slipping or off', 'Vanes at wrong angle', 'Motor issue', 'Dampers not working correctly']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- SubType NOT RAS or OAU or VAV\n",
      "    L---- Day NOT Monday\n",
      "    L---- 55 °F < OAT < 80 °F\n",
      "    L---- Setpoint Temperature = Setpoint Temperature 1 Hour Ago\n",
      "    L---- Setpoint Temperature = Setpoint Temperature 2 Hours Ago\n",
      "    L---- Setpoint Temperature = Daily Average Setpoint Temperature 1 Day in the  Past\n",
      "    L---- Setpoint Temperature = Daily Average Setpoint Temperature 2 Days in the  Past\n",
      "    L---- OR\n",
      "        L---- (Dew Point < 55)  \n",
      "        L---- OR\n",
      "            L----  Outside Air Enthalpy < Return Air Enthalpy IF Dew Point NOT Reporting  \n",
      "            L---- OR\n",
      "                L----  Outside Air Enthalpy < 26 IF Return Air Enthalpy IF Dew Point \n",
      "                L---- OR\n",
      "                    L----  Return  Air Enthalpy NOT Reporting  \n",
      "                    L----  None Reporting)\n",
      "Observations:\n",
      "['BMS maybe over ridden to a constant value.', 'Check the logic in the BMS to see how it is set up', 'Opportunity for additional savings. Reset temperature to outside conditions']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- OR\n",
      "        L---- Day NOT Monday \n",
      "        L----  A Site Holiday\n",
      "    L---- Duct Static Pressure Setpoint = Previous Hour Duct Static Pressure Setpoint\n",
      "    L---- Duct Static Pressure Setpoint = Previous Daily Duct Static Pressure Setpoint\n",
      "    L---- 55 °F < OAT < 80 °F\n",
      "    L---- Met for 3 Hours checking previous 2 days daily average\n",
      "Observations:\n",
      "['BMS maybe over ridden to a constant value.', 'Check the logic in the BMS to see how it is set up', 'If unit resets based on VAV damper position exempt from this rule.']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Supply Fan Status = 0\n",
      "    L---- Subtype NOT MULTI or VAV\n",
      "    L---- Duct Static Pressure > 0.2 in H2O\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Relay from BMS to fan is broken', 'System is in a manual mode']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- OAT < 68 °F\n",
      "    L---- OR\n",
      "        L---- (Enthalpy < Return Enthalpy IF Reporting  \n",
      "        L---- OR\n",
      "            L----  Enthalpy < 26 IF Reporting  \n",
      "            L----  Neither reporting)\n",
      "    L---- Economizer Mode = 0\n",
      "    L---- Met for 2 Hours\n",
      "    L---- POK:OAT > 38 °F and OAT < 68 °F\n",
      "    L---- ARC:OAT > 40 °F and OAT < 68 °F\n",
      "    L---- RTP:OAT > 40 °F and OAT < 68 °F\n",
      "    L---- BMT:OAH% between 27 and 55\n",
      "    L---- AUS: Enthalpy < 24\n",
      "Observations:\n",
      "['Is the system overridden', 'Are the dampers operating correctly', 'Is the BMS logic set up correctly']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Subtype NOT VAV\n",
      "    L---- Day = Sat or Sun or local time overnight (after 8pm and before 5am)\n",
      "    L---- Economizer Mode = 0\n",
      "    L---- Outside Air Damper % > 5%\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Damper command should be zero', 'Check logic on building control system', 'Exempt asset if space is occupied overnight']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Supply Fan Status = 1\n",
      "    L---- Subtype NOT MULTI or VAV\n",
      "    L---- Duct Static Pressure < 0.01 inH2O\n",
      "    L---- Air Flow < 100 CFM IF Reporting\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Relay from BMS to fan is broken']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Supply Fan Status = 1\n",
      "    L---- Subtype NOT VAV\n",
      "    L---- Supply Fan Current < 1 amp\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Belts are loose or broken']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Economizer Mode = 0\n",
      "    L---- Subtype NOT VAV or OAU or RAU\n",
      "    L---- Outside Air Flow >/< Outside Air Flow Setpoint * 1.10%\n",
      "    L---- OAT < 90 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Check AHU operation', 'Actuators', 'Flow sensors', 'Blade pitch', 'Motor control']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- OR\n",
      "        L---- Supply Air Temp Setpoint > 75 °F  \n",
      "        L----  Supply Air Temp Setpoint < 53 °F\n",
      "    L---- Met for 3 Hours and Prev. 3 Days Average\n",
      "    L---- NOTE: Hot Deck units will be checking < 80 °F and > 95 °F\n",
      "Observations:\n",
      "['BMS maybe set too high or too low', 'Check the logic in the BMS to see how it is set up']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU Running\n",
      "    L---- Economizer Mode =1\n",
      "    L---- Preheat Valve % > 5%\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Command from BMS to Preheat Valve needs to be adjusted']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- AHU NOT Running\n",
      "    L---- Return Fan Status = 1\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['Return fans in manual', 'Hand or overridden on when the supply fan is off', 'This works for constant speed or VFD return fans']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU Running\n",
      "    L---- Subtype is VAV\n",
      "    L---- Supply Air Flow is Not Changing (+/-) 2% Prev. Day Average\n",
      "    L---- VAV Damper > 20 %\n",
      "    L---- ABS(Supply Air Flow - Previous Day Average) < 1\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Check VAV box operation', 'Actuators', 'Flow sensors']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU Running\n",
      "    L---- Subtype is VAV\n",
      "    L---- Supply Air Flow < 10 cfm\n",
      "    L---- VAV Damper > 20 %\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Check VAV box operation', 'Actuators', 'Flow sensors']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU Running\n",
      "    L---- Subtype is VAV or FCU\n",
      "    L---- Heating Valve = 0%\n",
      "    L---- Discharge Air Temp (supply) - Parent Discharge Air Temp (supply) > 10 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Check VAV box operation', 'Actuators', 'Heating valve operation']\n",
      "\n",
      "\n",
      "Asset:AHU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU Running\n",
      "    L---- Subtype is VAV\n",
      "    L---- OR\n",
      "        L---- Zone Temperature Setpoint > 75  \n",
      "        L----  Zone Temperature Setpoint < 68\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Thermostat in room maybe set too high or too low', 'Check the logic in the BMS to see how it is set up', 'User maybe too cold or too hot and trying to fix a broken condition']\n",
      "\n",
      "\n",
      "Asset:Boiler\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Boiler Running\n",
      "    L---- OR\n",
      "        L---- (Natural Gas Flow > 5 AND Flue Gas Oxygen % > 3%  \n",
      "        L---- OR\n",
      "            L----  Fuel Oil Flow > 5 AND Flue Gas Oxygen % > 5%  \n",
      "            L----  Propane Flow > 5 AND Flue Gas Oxygen % > 5%)\n",
      "    L---- Met for 2 hours\n",
      "Observations:\n",
      "['Check the BMS command for inlet air control', 'Boiler command to intake Damper Issue', 'Boiler needs tuning']\n",
      "\n",
      "\n",
      "Asset:Boiler\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Boiler Running\n",
      "    L---- OR\n",
      "        L---- (Name = B3010080 AND Flue Gas Temperature < 360 °F  \n",
      "        L---- OR\n",
      "            L----  Name = B3010091 AND Flue Gas Temperature < 260 °F  \n",
      "            L---- OR\n",
      "                L----  Flue Gas Temperature < Flue Gas Temperature Setpoint AND (Name NOT =  B3010080 \n",
      "                L----  B3010091))\n",
      "    L---- Met for 2 hours\n",
      "Observations:\n",
      "['Review of Boiler operation', 'Fouling of stack and heat transfer surfaces']\n",
      "\n",
      "\n",
      "Asset:Boiler\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Boiler Running\n",
      "    L---- Supply Temperature < Supply Temperature Setpoint\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Review of Boiler Operation', 'Boiler needs turning', 'Air Flow Problems', 'Water Feed Problem']\n",
      "\n",
      "\n",
      "Asset:Boiler\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Boiler Running\n",
      "    L---- Supply Temperature - Return Temperature < 5 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Temperature sensor accuracy', 'Heating valves', 'Flow rate is too high', 'Load is low', 'Bad staging of heat systems', 'Bypassing excessive amounts of fluid']\n",
      "\n",
      "\n",
      "Asset:Boiler\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Boiler Running\n",
      "    L---- Conductivity < 3000 umho (0.003 S)\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['Review of Boiler operation', 'Fouling of heat transfer surfaces']\n",
      "\n",
      "\n",
      "Asset:Boiler\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Boiler Running\n",
      "    L---- Conductivity > 4000 umho (0.004 S)\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['Review of Boiler operation', 'Fouling of heat transfer surfaces']\n",
      "\n",
      "\n",
      "Asset:CRAC\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- CRAC Unit Running (Not used right now)\n",
      "    L---- Return Air Temperature <= (Supply Air Temperature + 3 °F)\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['Return air temp setpoint too high', 'Side-by-side units that are not balanced', 'Chilled water valve stuck closed']\n",
      "\n",
      "\n",
      "Asset:CRAC\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Temperature Setpoint > 68 °F\n",
      "    L---- Temperature Setpoint - Return Air Temperature > 2 °F\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Broken Belt', 'Unit shutdown for some reason', 'Too much equipment in the local area', 'Chilled water valve not actuating well']\n",
      "\n",
      "\n",
      "Asset:CRAC\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- CRAC Unit Running (Not used right now)\n",
      "    L---- 3 °F < (Return Air Temperature - Supply Air   Temperature) < 10 °F\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['CRAC units that can be turned off to provide energy savings']\n",
      "\n",
      "\n",
      "Asset:CRAC\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- CRAC Running\n",
      "    L---- Setpoint Temperature < 72 °F)\n",
      "    L---- Met for 3 Hours\n",
      "    L---- Boulder: Using 60 °F\n",
      "    L---- Rochester: Using 67 °F\n",
      "Observations:\n",
      "['Controls on CRAC are set too low']\n",
      "\n",
      "\n",
      "Asset:CRAC\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- CRAC NOT Running\n",
      "    L---- Schedule = 1 (Currently not implemented; CRACs run 24/7)\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Broken Belt', 'Unit shutdown for some reason']\n",
      "\n",
      "\n",
      "Asset:CRAC\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- PUE > Floor Threshold\n",
      "    L---- Met for 8 Hours\n",
      "Observations:\n",
      "['Too many CRAC units are running for the amount of load', 'Too much equipment in the local area']\n",
      "\n",
      "\n",
      "Asset:CRAC\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- CRAC Running IF Reporting, Otherwise Assume ON\n",
      "    L---- Chilled Water Valve % < 5%\n",
      "    L---- Met for 8 Hours\n",
      "Observations:\n",
      "['CRAC units with the chilled water valve is closed indicates a problem with controls wires from the valve to CRAC unit could be off', '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', 'Chilled water valve could be stuck closed or stuck open or stuck some where in between']\n",
      "\n",
      "\n",
      "Asset:CRAC\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Temperature Setpoint > 68 °F\n",
      "    L---- Return Air Temperature - Temperature Setpoint > 10 °F\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Broken Belt', 'Unit shutdown for some reason', 'Too much equipment in the local area', 'Chilled water valve not actuating well']\n",
      "\n",
      "\n",
      "Asset:CRAC\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Temperature Setpoint < 65 °F\n",
      "    L---- Supply Air Temperature - Temperature Setpoint > 3 °F\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Broken Belt', 'Unit shutdown for some reason', 'Too much equipment in the local area', 'Chilled water valve not actuating well']\n",
      "\n",
      "\n",
      "Asset:CRAC\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Temperature Setpoint < 65 °F\n",
      "    L---- Temperature Setpoint - Supply Air Temperature > 4 °F\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Broken Belt', 'Unit shutdown for some reason', 'Too much equipment in the local area', 'Chilled water valve not actuating well']\n",
      "\n",
      "\n",
      "Asset:Chiller\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Chiller Running\n",
      "    L---- Supply Temperature - Setpoint Temperature > 5 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Chiller cannot keep up with the load']\n",
      "\n",
      "\n",
      "Asset:Chiller\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Chiller Running\n",
      "    L---- (Setpoint Temperature - Supply Temperature) > 3 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Chiller operation needs to be investigated']\n",
      "\n",
      "\n",
      "Asset:Chiller\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Chiller Running\n",
      "    L---- ALL P&F at that site's building run status = 0\n",
      "    L---- (Return Temperature - Supply Temperature) < 7 °F\n",
      "    L---- OAT > 37 °F\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['Low Temperature Delta Syndrome', 'Leaking or Broken chilled water valves', '3-way valves']\n",
      "\n",
      "\n",
      "Asset:Chiller\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Chiller Running\n",
      "    L---- Chiller Efficiency > Asset Chiller Efficiency Parameter\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Fouled Tubes', 'Variable Frequency Drive speeds incorrect on pumps', 'Pressure issues']\n",
      "\n",
      "\n",
      "Asset:Chiller\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Chiller NOT Running\n",
      "    L---- Condenser Water Flow > 50 Gallons/Minute (189 l/m)\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Excess equipment is on', 'Verify pump is not needed and turn off', 'The condenser water pumps are flowing water through a chiller that is off', 'Cooling tower has excessive flow']\n",
      "\n",
      "\n",
      "Asset:Chiller\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Chiller Running\n",
      "    L---- OR\n",
      "        L---- (Chiller % Loaded < 30%  \n",
      "        L----  Actual Amps / Full Load Amps < 30% IF Chiller % Loaded NOT Available)\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Too many chillers are running', 'Overridden on or logic could be updated to turn off chiller appropriately', 'System is not designed well for part loads on the chiller']\n",
      "\n",
      "\n",
      "Asset:Chiller\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Chiller Running\n",
      "    L---- Supply Temperature - Liquid Refrigerant Evaporator\n",
      "    L---- Temperature > 4 °F\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Low refrigerant levels', 'Variable orifice problems']\n",
      "\n",
      "\n",
      "Asset:Chiller\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Chiller Running\n",
      "    L---- Condenser Water Return To Tower Temperature - Condenser Liquid  Refrigerant Temperature > 4 °F\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Clean the tubes', 'Gas in liquid refrigerant', 'Chiller at part load']\n",
      "\n",
      "\n",
      "Asset:Chiller\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Chiller Running\n",
      "    L---- OR\n",
      "        L---- ABS(Coolant Pressure Difference - Coolant Pressure Difference Setpoint) > 4  PSI  \n",
      "        L----  ABS((Supply Coolant Pressure - Return Coolant Pressure) - Coolant  Pressure Difference Setpoint) > 4 PSI IF Coolant Pressure Difference NOT  Reporting\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Bad pressure sensor', 'Pump problems (VFD problems)']\n",
      "\n",
      "\n",
      "Asset:Chiller\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Run Status = 0\n",
      "    L---- Power Input > 5 KW\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Could be oil heater', 'Bad CT']\n",
      "\n",
      "\n",
      "Asset:Chiller\n",
      "Rules:\n",
      "Root: root\n",
      "Observations:\n",
      "['Mis-sized equipment', 'Logic that is working too quickly not allowing the system to stabilized', 'Load is too low or fluctuates']\n",
      "\n",
      "\n",
      "Asset:Cooling Tower\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- ABS(Condenser Water Pressure Difference Condenser Water Pressure  Difference Setpoint) > 5 PSI\n",
      "    L---- OAT < 95 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Pump is overridden', 'VFD issues', 'bad motor', 'pressure sensors need calibration']\n",
      "\n",
      "\n",
      "Asset:Cooling Tower\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Run Status = 1\n",
      "    L---- (Condenser Water Return To Tower Temperature - Condenser Water Supply  To Chiller Temperature) < 5 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Problems with the cooling tower', 'Check fans and condenser water pumps']\n",
      "\n",
      "\n",
      "Asset:Cooling Tower\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- (Condenser Water Supply To Chiller Temperature Condenser Water  Temperature Setpoint) > 6 °F\n",
      "    L---- OAT < 80 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Fan is overridden', 'Logic issues for the cooling tower', 'Fans are off']\n",
      "\n",
      "\n",
      "Asset:Cooling Tower\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Cooling Tower – Condenser Water is too cold\n",
      "    L---- Cooling Tower Running\n",
      "    L---- OR\n",
      "        L---- (Condenser Water Supply Temperature to Chiller < Condenser Water Temperature Setpoint - 4 °F\n",
      "        L---- Condenser Water Supply Temperature to Chiller < 55 °F IF Condenser Water Temperature Setpoint NOT Reporting)\n",
      "    L---- OAT > 43 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Fan is overridden', 'Logic issues for the cooling tower', 'Fans are off']\n",
      "\n",
      "\n",
      "Asset:Fan\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Fan Running\n",
      "    L---- VFD Speed % > 97%\n",
      "    L---- OAT < 80 °F\n",
      "    L---- Met for 2 Hours\n",
      "    L---- Littleton: OAT > 40 °F\n",
      "Observations:\n",
      "['Undersized system for load', 'VFD issues', 'Bad motor', 'Pressure sensors need calibration']\n",
      "\n",
      "\n",
      "Asset:HXU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Heating Valve % > 0%\n",
      "    L---- OAT > 55 °F\n",
      "    L---- Met for 2 Hours\n",
      "    L---- Yorktown: Using 61 °F\n",
      "Observations:\n",
      "['Check the BMS. It has commanded the heat on when it should be off']\n",
      "\n",
      "\n",
      "Asset:HXU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Heating Valve > 15%\n",
      "    L---- ABS(Hot Water Temperature Setpoint - Hot Water Temperature) > 5 °F\n",
      "    L---- Heating System Drained Flag = 1\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Check temperature sensors', 'Heating valves']\n",
      "\n",
      "\n",
      "Asset:HXU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Heating Valve > 50%\n",
      "    L---- ABS(Hot Water Temperature - Hot Water Return Temperature) < 4 °F\n",
      "    L---- Heating System Drained Flag = 0\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Check temperature sensors', 'Heating valves', 'Faulty bypass valves']\n",
      "\n",
      "\n",
      "Asset:HXU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Heating Valve < 5%\n",
      "    L---- Hot Water Temperature > 90 °F\n",
      "    L---- Heating System Drained Flag = 0\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Check temperature sensors', 'Heating valves', 'Faulty bypass valves']\n",
      "\n",
      "\n",
      "Asset:None\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Heating System Drained Flag = 0\n",
      "    L---- Heating System Status On\n",
      "    L---- OAT > 65 °F\n",
      "    L---- Heating Valve < 5%\n",
      "    L---- Hot Water Temperature > 90 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Check temperature sensors', 'Heating valves', 'Faulty bypass valves']\n",
      "\n",
      "\n",
      "Asset:Lighting\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- OR\n",
      "        L---- Lighting Mode = 1 AND Occupied Mode = 0\n",
      "        L---- Lighting Mode = 0 AND Occupied Mode = 1\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Electrical system problems', 'Lighting relay schedule over written']\n",
      "\n",
      "\n",
      "Asset:Meter\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Meter > 20 kw\n",
      "    L---- Voltage < 5% of Meter Voltage Rating\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Electrical system problems']\n",
      "\n",
      "\n",
      "Asset:Meter\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Meter > 5 kw (power real)\n",
      "    L---- OR\n",
      "        L---- Saturday or Sunday \n",
      "        L----  Sunday (for Identified Assets)\n",
      "    L---- Power > Previous Daily Average Friday Supply Power * 0.8\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['New energy use or equipment that has been removed']\n",
      "\n",
      "\n",
      "Asset:Meter\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- PUE > Previous Weeks Average PUE + 20%\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Excessive Cooling', 'Turn off CRAC units']\n",
      "\n",
      "\n",
      "Asset:PDU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- 50% of 650 KW < Power Input <  80% of 650 KW\n",
      "    L---- Using custom Segrate Values of 38, 47.5, 608, 950 KVA\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['PDU is overloaded']\n",
      "\n",
      "\n",
      "Asset:PDU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Power Input > 0.1 KW\n",
      "    L---- Power Input < 5% of 650 KW\n",
      "    L---- Using custom Segrate Values of 38, 47.5, 608, 950 KVA\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['PDU is under utilized']\n",
      "\n",
      "\n",
      "Asset:PDU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Power Input > 80% of 650 KW\n",
      "    L---- Using custom Segrate Values of 38, 47.5, 608, 950 KVA\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['PDU unit is overloaded']\n",
      "\n",
      "\n",
      "Asset:Plate & Frame\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Heat Exchanger Off (plate and frame status = 0)\n",
      "    L---- BLD Building 91: Alert if PF status off for > 1 units NOT POK\n",
      "    L---- OR\n",
      "        L---- (OAT (wetbulb) < 38 °F\n",
      "        L---- Enthalpy < 14)\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['May be using mechanical cooling ie chiller', 'Verify plate and frame is available and if chiller is not needed, turn off', 'Manual Operation override may be in place wasting energy', 'Short Term Weather Condition']\n",
      "\n",
      "\n",
      "Asset:Pump\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Pump Running\n",
      "    L---- Pump VFD Speed % > 97%\n",
      "    L---- OAT < 95 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Undersized system for load', 'VFD issues', 'Bad motor', 'Pressure sensors need calibration']\n",
      "\n",
      "\n",
      "Asset:Pump\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Pump Running\n",
      "    L---- SubType NOT HW\n",
      "    L---- Pump Motor VFD Output % > 35%\n",
      "    L---- Pump Motor VFD Output % = Daily Average Pump Motor VFD Output %\n",
      "    L---- OAT < 95 °F\n",
      "    L---- ABS(Pump Differential Pressure - Pump Differential Pressure Setpoint) > 4psi IF Reporting\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Pump is overridden', 'VFD issues', 'Bad motor', 'Pressure sensors need calibration']\n",
      "\n",
      "\n",
      "Asset:Pump\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- OR\n",
      "        L---- Pump Running [Pump Status = 1 \n",
      "        L----  Pump Current In Amps >= 1]\n",
      "    L---- Pump Occupied = 0\n",
      "    L---- OAT > 55 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Pump is overridden', 'VFD issues', 'Bad motor', 'Pressure sensors need calibration', 'Controls not set up correctly', 'Relay issue']\n",
      "\n",
      "\n",
      "Asset:Pump\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Pump Running\n",
      "    L---- Pump VFD Speed Reporting\n",
      "    L---- OAT < 95 °F\n",
      "    L---- ABS(Pump Differential Pressure - Pump Differential Pressure Setpoint) >  4  IF Reporting\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Pump is overridden', 'VFD issues', 'Bad motor', 'Pressure sensors need calibration']\n",
      "\n",
      "\n",
      "Asset:Pump\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Pump Running\n",
      "    L---- SubType Is HW\n",
      "    L---- Outside Air Temperature > 70 °F\n",
      "    L---- Met for 2 hours\n",
      "Observations:\n",
      "['Pump is overridden', 'VFD issues', 'Control issues', 'Temperature sensor calibration']\n",
      "\n",
      "\n",
      "Asset:VAV\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU Running\n",
      "    L---- OR\n",
      "        L---- (Supply Air Flow outside > Supply Air Flow Setpoint + 25%\n",
      "        L---- Supply Air Flow outside < Supply Air Flow Setpoint - 25%)\n",
      "    L---- OAT < 90 °F\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Check VAV box operation', 'Actuators', 'Flow sensors']\n",
      "\n",
      "\n",
      "Asset:VAV\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU Running\n",
      "    L---- Supply Air Flow is Not Changing (+/-) 2% Prev. Day Average\n",
      "    L---- VAV Damper > 20 %\n",
      "    L---- ABS(Supply Air Flow - Previous Day Average) < 1\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Check VAV box operation', 'Actuators', 'Flow sensors']\n",
      "\n",
      "\n",
      "Asset:VAV\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU Running\n",
      "    L---- Zone Temperature >= 79 °F\n",
      "    L---- Cooling Drained Flag = 1 IF Reporting\n",
      "    L---- Met for 3 Hours\n",
      "    L---- Southbury: No Zone Temperature Check\n",
      "Observations:\n",
      "['Cooling issues with the AHU because Zone Temperature OR Return Temperature greater than 79 F / 26.1 C']\n",
      "\n",
      "\n",
      "Asset:VAV\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU Running\n",
      "    L---- Zone Temperature <= 65 °F\n",
      "    L---- POK: OAT < 75 °F\n",
      "    L---- Heating Drained Flag = 1 IF Reporting\n",
      "    L---- Met for 2 Hours\n",
      "    L---- Southbury: No Zone Temperature Check\n",
      "Observations:\n",
      "['Heating issues with the AHU because the Zone Temperature OR Return Temperature less than 65 F / 18.3 C']\n",
      "\n",
      "\n",
      "Asset:VAV\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU Running\n",
      "    L---- Supply Air Flow < 10 cfm\n",
      "    L---- VAV Damper > 20 %\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Check VAV box operation', 'Actuators', 'Flow sensors']\n",
      "\n",
      "\n",
      "Asset:VAV\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU Running\n",
      "    L---- OR\n",
      "        L---- (Heating Valve = 0%\n",
      "        L---- Hot Deck Damper % = 0%) (one or the other, can't have both)\n",
      "    L---- Discharge Air Temp (supply) - Parent Discharge Air Temp (supply) > 10 °F\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Check VAV box operation', 'Actuators', 'Heating valve operation']\n",
      "\n",
      "\n",
      "Asset:VAV\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU Running\n",
      "    L---- OR\n",
      "        L---- Zone Temperature Setpoint > 75\n",
      "        L---- Zone Temperature Setpoint < 68\n",
      "    L---- Met for 3 Hours\n",
      "Observations:\n",
      "['Thermostat in room maybe set too high or too low', 'Check the logic in the BMS to see how it is set up', 'User maybe too cold or too hot and trying to fix a broken condition']\n",
      "\n",
      "\n",
      "Asset:VAV\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU NOT Running\n",
      "    L---- SubType NOT FCU\n",
      "    L---- Supply Air Flow > 80 CFM\n",
      "    L---- Met for 2 Hours\n",
      "Observations:\n",
      "['Check VAV box flow sensors']\n",
      "\n",
      "\n",
      "Asset:PIU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU Running\n",
      "    L---- ABS(Supply Air Temperature - Supply Air Temperature Setpoint) > 4 °F\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['Unit controls are not working correctly']\n",
      "\n",
      "\n",
      "Asset:PIU\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- Parent AHU Running\n",
      "    L---- OR\n",
      "        L---- Zone Temp < Zone Temp Heating Setpoint - 4 °F\n",
      "        L---- Zone Temp > Zone Temp Cooling Setpoint + 4 °F\n",
      "    L---- Met for 4 Hours\n",
      "Observations:\n",
      "['Unit controls are not working correctly', 'Thermostat out of calibration', 'Box Damper not working', 'Larger AHU problem']\n",
      "\n",
      "\n",
      "Asset:UPS\n",
      "Rules:\n",
      "Root: root\n",
      "    L---- OR\n",
      "        L---- (Name = 201A980 AND Power Output > 85% of 3MW  \n",
      "        L----  Name NOT = 201A980 AND Power Output > 85% of 4MW)\n",
      "    L---- Met for 4 hours\n",
      "Observations:\n",
      "['UPS unit is overloaded']\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for i,pd in enumerate(processed_data[\"rule_set\"]):\n",
    "    print(f\"Asset:{pd['asset']}\")\n",
    "    print(\"Rules:\")\n",
    "    print_tree(pd[\"display_text\"][\"rules\"])\n",
    "    print(\"Observations:\")\n",
    "    print(pd[\"display_text\"][\"observations\"])\n",
    "    print(\"\\n\")\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "id": "ef7b1a08",
   "metadata": {},
   "outputs": [],
   "source": [
    "save_pickle(\n",
    "    processed_data,\n",
    "    os.path.join(extract_fol, \"TreeStruct.pkl\")\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "02b6eeeb",
   "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.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
