{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Expense Management Discrepancies (Flag 66)\n",
    "\n",
    "### Dataset Description\n",
    "The dataset consists of 500 entries simulating ServiceNow fm_expense_line table, which records various attributes of financial expenses. Key fields include 'number', 'opened_at', 'amount', 'state', 'short_description', 'ci', 'user', 'department', 'category', 'process_date', 'source_id', and 'type'. This table documents the flow of financial transactions by detailing the amount, departmental allocation, and the nature of each expense. Provides a clear view of organizational expenditures across different categories, highlighting both the timing and the approval state of each financial entry.\n",
    "\n",
    "### Your Task\n",
    "**Goal**: To uncover and address the reasons behind the varying rates of expense rejections across departments to improve overall financial management within the organization.\n",
    "\n",
    "**Role**: Financial Compliance Analyst\n",
    "\n",
    "**Difficulty**: 3 out of 5.\n",
    "\n",
    "**Category**: Financial Management\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Import Necessary Libraries\n",
    "This cell imports all necessary libraries required for the analysis. This includes libraries for data manipulation, data visualization, and any specific utilities needed for the tasks. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:15:24.678516Z",
     "iopub.status.busy": "2024-10-29T17:15:24.676790Z",
     "iopub.status.idle": "2024-10-29T17:15:28.304307Z",
     "shell.execute_reply": "2024-10-29T17:15:28.302295Z"
    }
   },
   "outputs": [],
   "source": [
    "import argparse\n",
    "import pandas as pd\n",
    "import json\n",
    "import requests\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "from pandas import date_range"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load Dataset\n",
    "This cell loads the expense dataset from a CSV file into a DataFrame. It involves specifying the path to the dataset, using pandas to read the file, and confirming its successful load by displaying the first few entries."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:15:28.319824Z",
     "iopub.status.busy": "2024-10-29T17:15:28.318744Z",
     "iopub.status.idle": "2024-10-29T17:15:28.425897Z",
     "shell.execute_reply": "2024-10-29T17:15:28.421835Z"
    }
   },
   "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>number</th>\n",
       "      <th>source_id</th>\n",
       "      <th>user</th>\n",
       "      <th>amount</th>\n",
       "      <th>processed_date</th>\n",
       "      <th>opened_at</th>\n",
       "      <th>department</th>\n",
       "      <th>state</th>\n",
       "      <th>category</th>\n",
       "      <th>short_description</th>\n",
       "      <th>ci</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>EXP00000000</td>\n",
       "      <td>UTY-46750817</td>\n",
       "      <td>Carolina Kinlaw</td>\n",
       "      <td>584</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2024-04-26 18:11:00</td>\n",
       "      <td>Sales</td>\n",
       "      <td>Pending</td>\n",
       "      <td>Services</td>\n",
       "      <td>Provision of Services for iPod touch</td>\n",
       "      <td>ISP Services</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>EXP00000001</td>\n",
       "      <td>CKX-70446459</td>\n",
       "      <td>Mamie Mcintee</td>\n",
       "      <td>3178</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2023-10-03 08:08:00</td>\n",
       "      <td>Product Management</td>\n",
       "      <td>Submitted</td>\n",
       "      <td>Assets</td>\n",
       "      <td>Asset assignment for new Dell Laptop</td>\n",
       "      <td>Dell XPS 13</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>EXP00000002</td>\n",
       "      <td>NaN</td>\n",
       "      <td>Cristina Sharper</td>\n",
       "      <td>3278</td>\n",
       "      <td>2024-03-14 10:18:00.000000000</td>\n",
       "      <td>2024-03-13 10:18:00</td>\n",
       "      <td>Sales</td>\n",
       "      <td>Processed</td>\n",
       "      <td>Miscellaneous</td>\n",
       "      <td>Miscellaneous hardware component</td>\n",
       "      <td>Random Access Memory Component</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>EXP00000003</td>\n",
       "      <td>SRP-53496117</td>\n",
       "      <td>Raphael Bickel</td>\n",
       "      <td>8712</td>\n",
       "      <td>2023-06-20 17:32:56.784775309</td>\n",
       "      <td>2023-06-18 17:21:00</td>\n",
       "      <td>Sales</td>\n",
       "      <td>Processed</td>\n",
       "      <td>Assets</td>\n",
       "      <td>Dell OptiPlex 7050 Desktop Asset</td>\n",
       "      <td>OptiPlex 7050</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>EXP00000004</td>\n",
       "      <td>EAN-07942806</td>\n",
       "      <td>Helena Suermann</td>\n",
       "      <td>1307</td>\n",
       "      <td>2023-10-06 04:31:00.000000000</td>\n",
       "      <td>2023-10-05 04:31:00</td>\n",
       "      <td>Customer Support</td>\n",
       "      <td>Processed</td>\n",
       "      <td>Services</td>\n",
       "      <td>Deployed service-related asset</td>\n",
       "      <td>Cloud Database Service</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        number     source_id              user  amount  \\\n",
       "0  EXP00000000  UTY-46750817   Carolina Kinlaw     584   \n",
       "1  EXP00000001  CKX-70446459     Mamie Mcintee    3178   \n",
       "2  EXP00000002           NaN  Cristina Sharper    3278   \n",
       "3  EXP00000003  SRP-53496117    Raphael Bickel    8712   \n",
       "4  EXP00000004  EAN-07942806   Helena Suermann    1307   \n",
       "\n",
       "                  processed_date            opened_at          department  \\\n",
       "0                            NaN  2024-04-26 18:11:00               Sales   \n",
       "1                            NaN  2023-10-03 08:08:00  Product Management   \n",
       "2  2024-03-14 10:18:00.000000000  2024-03-13 10:18:00               Sales   \n",
       "3  2023-06-20 17:32:56.784775309  2023-06-18 17:21:00               Sales   \n",
       "4  2023-10-06 04:31:00.000000000  2023-10-05 04:31:00    Customer Support   \n",
       "\n",
       "       state       category                     short_description  \\\n",
       "0    Pending       Services  Provision of Services for iPod touch   \n",
       "1  Submitted         Assets  Asset assignment for new Dell Laptop   \n",
       "2  Processed  Miscellaneous      Miscellaneous hardware component   \n",
       "3  Processed         Assets      Dell OptiPlex 7050 Desktop Asset   \n",
       "4  Processed       Services        Deployed service-related asset   \n",
       "\n",
       "                               ci  \n",
       "0                    ISP Services  \n",
       "1                     Dell XPS 13  \n",
       "2  Random Access Memory Component  \n",
       "3                   OptiPlex 7050  \n",
       "4          Cloud Database Service  "
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_path = \"csvs/flag-66.csv\"\n",
    "flag_data = pd.read_csv(dataset_path)\n",
    "df = pd.read_csv(dataset_path)\n",
    "flag_data.head()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 1: How does the processing delay (in days) vary across different departments and categories?**\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Analyze processing delay by department and category\n",
    "This analysis examines the difference in days between the date each request was opened and the date it was processed. By aggregating this data by department and category, we can identify areas that may have slower or more efficient processing workflows, revealing potential bottlenecks or high-efficiency areas within specific departments or asset categories."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:15:28.442374Z",
     "iopub.status.busy": "2024-10-29T17:15:28.440954Z",
     "iopub.status.idle": "2024-10-29T17:15:29.088039Z",
     "shell.execute_reply": "2024-10-29T17:15:29.086395Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABDEAAAHwCAYAAAC/hvQ7AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAAsTAAALEwEAmpwYAABaMklEQVR4nO3deZxVdf3H8fcbBlkEWQRRAcFkB0EDNUwFXEoLNUNTwRA1NXPJ3X5mWla/9FcumZVb5oZ7aWrm7oDhjsoqiAuIggKiLLLOzOf3xzmj13FmuCgz9x7n9Xw87mPO/Z7tc87nzsD53O/5HkeEAAAAAAAAil2jQgcAAAAAAACQD4oYAAAAAAAgEyhiAAAAAACATKCIAQAAAAAAMoEiBgAAAAAAyASKGAAAAAAAIBMoYgAAMsP2CttfK3Qc1bE9x/bedbTt22x/L50ebfuRjbTdYbbf2RjbqmUfz9vuV8v8sbb/W5cxoH7Y/qXtWwodBwDgq40iBgDkyXap7Q9tNy10LF9WerGxLi0KfGT7adtDCh3X+kREy4h4c2NvN+d8LE9fr9m+0vZWG3tfXyC2AZIGSvqXJEXEuIj4VmGj2iB/kHRhfewo/R1dneZwme1Jtn9WyN9Z22G7e4H2XVRFBdub2b7c9tvp35430vft81iXYhcAQBJFDADIi+1uknaXFJIOqIPtl2zsbebhjohoKamDpP9K+qdtV13IduN6j6ww7oiIVpLaSTpI0paSJhVBIeN4SeMiIgocxxd1n6Thtresp/2dlOZxK0lnSDpM0oPVfbbrUoF+p4uW7U0kPS6pn6R9JW0maYikDyTtXMDQ1otcAkBxoYgBAPkZI+lZSTdIOlKSbDdNezH0r1zIdgfbq2xvkb4fYfuVnN4OA3KWnWP7HNtTJH1suyT91viN9JvkGbYPylm+se1LbC+2/Zbtk9JveUvS+a1t/832Atvv2v5NPgWIiFgn6UYlF+2b277B9l9tP2j7YyUXoH3Sb7k/sj3d9ieFHNvN07jm2l5q+7+2m6fzvpEe90e2J9selrPeWNtvpsf6lu3RaXt32+PTbS22fUfOOp98q53G+Wfb/0638Zzt7XKW/ZbtWel2/pJu80f5nI+ImC7pUEmLlFwIV26zxnzmsr2z7WfS5RY46dWxSTrvz7YvqbL8fbZPqyGk/SSNr3Le/pvzPmz/2PbsdH9/rumCPc3VDU56FM2QtFOV+dV+/mxvYnuJ7e1zlt3C9sr0M9/e9gPp/pfYfsp2o/R8rpY0SdK3azi+dHO+Ms3VTNt7pY2H2J5UZcHTbf+rlm0p3e/HEVGqpOg4RNJ30/Ub5RznB7bvtN0undctPZ/H2Z6f5u7MnH3XmNecXJxoe7ak2bYnpLMmO+l5cKjTW3hsn217Ybqd79n+jpMeQEtsn5uzzXziPdJJ74bFtn+ezttX0rmSDk33PbmGE1/b35yxTn6f/5B+Zt6yvV/O/G3T36vlth+VVFuPijGStpF0UETMiIiKiFgYEb+OiAdri8V2H0lXSRqSHstHaXvTNLa3bb9v+yqnf3vS+Wen53e+7R/5s38/Wtu+yfYiJ3+7zqv8zKbHPdH2ZbY/kHRhbZ//Wo4ZAFAXIoIXL168eK3nJel1ST+RNEjSOkkd0/brJf02Z7kTJT2UTu8oaaGkXSQ1VlL8mCOpaTp/jqRXJHWR1DxtO0TS1kqKzIdK+ljSVum8H0uaIamzpLaSHlPSM6QknX+PpKslbSppC0nPSzq+huP5paRb0ummkn4v6e30/Q2Slkr6ZhpHq/T4z5W0iaQ9JS2X1Ctd/s+SSiV1So9z13SbnZR8y/qddDv7pO87pDEuy9nGVpL6pdO3Sfp5uk4zSbvlxB2SuufEWfktbomkcZJuT+e1T7f//XTeT9O8/Wh956NK+4WSntuAfO6dTg+S9I10390kvSrp1HTezpLmS2qUE+tKpZ+pKvvfND3mDjltYyX9t8o5eUBSGyUXiYsk7VvDcV4k6SklvU26SJom6Z2c+bV9/v4i6eKcZX8q6f50+ndKLjKbpK/dJTln2SskXVpDTGMllUk6LV33UCWfv3ZKPkdLJPXJWf5lSSNr2FZpdTmWNKEy9jTuZ5X8HjVV8jtzWzqvW3o+b0vP/fbp+VxvXnNy8Wgae/Octu45ywxLj/f89HiPTfdxq5LftX6SVknadgPivVZScyW3Ha2pPF+q4XNd5dzUlvOxSn5vjlXymT9ByWfX6fxnJF2axrWHkr8L1e5P0u2SbvySsfy3yvKXKenp0y49d/dL+l06b19J76Xns4WkW/TZvx83KblFq1V6Hl+TdEyVz+TJaa6bq5bPPy9evHjxqt9XwQPgxYsXr2J/Sdot/Y98+/T9TEmnpdN7S3ojZ9mJksak03+V9Osq25olaWg6PUfS0evZ9yuSDkynn1BOUSLdd6T/ye6YXrw0z5l/uKQna9juLyWtlfSRkgvzJyQNSufdIOmmnGV3Ty8GGuW03ZZuo5GSC66B1ezjHEk3V2l7WMnF/6bpvkfmxpwuc5OkayR1rmabVYsY1+XM+46kmen0GEnP5MyzpHna8CLGjyXN3oB87l3D9k+VdE/O+1cl7ZNOnyTpwRrW65Qec7OctrH6fBEjt9Bzp6Sf1bC9N5VT4JB0nHKKGOv5/O0i6W19egH7oqQfpNMXKrkg7F7Ddn4r6foa5o1VzoVx2va8pB/mnPffptP9JH2otHBUzbZKq8uxkgvoa3PO/V4587ZS8vtdWZgISb1z5v+fpL/lmdeQtGdNn9n0/TAlvzON0/et0mV2yVlmkqTvbUC8nXPmPy/psNo+17W9quR8rKTXc+a1SPe3pZKCWZmkTXPm31rT/pQUdy76krHkfu6tpMixXU7bEElvpdPXKy1opO+7V+ZCSUFmraS+OfOPl1Sas6+3q8RS4+efFy9evHjV74vbSQBg/Y6U9EhELE7f35q2SdKTklrY3sXJuBk7KOkRIUldJZ2Rdj3/KO0C3UXJN42V5uXuyPYYf3q7wkeS+uvTLtpbV1k+d7qrkm91F+Sse7WSHhk1uTMi2kTEFhGxZ0TkdtvP3fbWkuZFREVO21wlF9jtlfSWeKOa7XeVdEiV499NyTerHyv5pvXHacz/tt07Xe9sJRcozzu5deXoWo7hvZzplZJa5sZcOSMiQtIXeQpHJyU9ASqPZ335lCTZ7unk9or3bC+T9L/6bFf7GyUdkU4fIenmGvb/Ufqz1XrirOk8VFX1MzS3Stw1fv4i4rl028PSXHVX8i24lPTkeV3SI05uEfpZlf22yjmW6ryb5ig3rsrzeqOkUbYt6YdKPrdratlWdarm8Z6cY3xVUrmSQmClqudoaymvvFZdtyYfRER5Or0q/fl+zvxV+jSH+cSbb/4/Zz1/cz6z7YhYmU62VHJOPkx/lyt95vNUxQdKCjBfJpZcHZQUVSblLP9Q2i7V/veyvZK/l7nxVv5Nq2759X3+AQD1iCIGANQivb/6B5KGphcu7ynp9j7Q9sD0QuROJb0eDpf0QEQsT1efp+Qb5DY5rxYRcVvOLiJnX12VdAs/SdLmEdFGSXf/yvENFijpUl6pS870PCU9Mdrn7GuziKjx0ZbrkXtBOV9Sl8r7xVPbSHpX0mJJqyVtp8+bp6QnRu7xbxoRF0lSRDwcEfsoubCZqeTYFRHvRcSxEbG1km9H/+INf7rDZ85VegHcuebFPy893v2V3H5ReTzry2elv6bH1CMiNlNyK07uOBW3SDrQ9kBJfSTdW10M6QXiG5J6bkjstVigz35utqmcyOPzJ31afPmhpLsjGe9CEbE8Is6IiK8pGYPidKfjWqT6SKp2TIZUpzRHuXHNT7f9rJJvzXeXNEo1F3yqZbuLkttAcvO4X5U8NouId3NWq3qO5qfT68ur9NnfnY0hn3hrUmsseea8JgsktbW9aU7bNjUtrOT2t29XWX5DYql6LIuVFHv65ZyX1pEMVlwZX01/Lxcr6c3StUrsuee0unNX7ecfAFC/KGIAQO2+p+Rbz75KelnsoOSC7CkltyxISc+MQyWNTqcrXSvpx2kvDdve1PZ3bdf0rXrl+AeLJMn2UUq+iax0p6Sf2u5ku42S2zUkSRGxQNIjki5x8hjDRra3sz30ix54jspvIM+23cTJ4Jz7Kxl/okJJt+1LbW/tZPDRIU4eaXmLpP1tfzttb+ZkUMPOtjvaPjC9oFkjaYWkivS4D7FdefHxYXpOcnuB5OPfkrZ3MmBiiZKxSvJ6OoaTAVb7KLllZksl9/xLG5bPVkrG5FiRfmt7Qu7MiHhH0gtKLsj/ERGrPr+JTzwoaWPkUUo+Q/9ju216jk/Ombe+z5+U5PQgJRdyN1U2OhnwtHtaiFiq5HemMp/NlBQRHq0lri0knZJ+vg5R8jv2YM78myRdKWldROT1mE3bLdLP/7+U3GJRub2rJP02vWiuHIz3wCqr/yJdv5+koyRVDi5ba15r8L6kr+UTcw3yibe2fXerUoDMlU/OqxURc5XcUvErJwO/7qbk70JNblZSkPmH7d7p36jNbZ9r+zt5xPK+pM5OB1JN//ZcK+kyfzqQcifblQPI3inpKCeDEreQ9Iuc2CuLz7+13So9t6cr+XzXptrPPwCgflHEAIDaHSnp7xHxdtpD4L2IeE/JBdVo2yVpN+OPlXRf/k/lihHxopIB8a5UcjH+upJ7rasVETMkXaJksLz3lQwqODFnkWuVFCqmKBnc8EEl96RXdksfo2TgzRnp/u7Werpv5yMi1iq5ONlPyTeYf1Ey7sfMdJEzJU1VclG+RNLFSsbPmCfpQCXfVi9ScgFzlpJ/exopuWiYn64zVJ9eEO4k6TnbK5R01/5pRLy5gTEvVjJI4P8p6cbeV8kFV223IRya7nNput8PlIwTUtkjYEPyeaaSXgPLleTtjmqWuVFJjtfXs+AaJZ+1jfGI0F8p6Tb/lpLP0if7zuPzpzSnLym52HwqZ1YPJd+0r0jX/0tEPJnO21/JWAPzVbPn0m0sVjJ+xsER8UHO/JuVXNCu7yJTkq60vTw9hssl/UPJOCCVhbA/KsnvI+lyzyoZ7yDXeCX5fVzSHyLikbQ9n7xW9UtJN6a3PPwgj+WryifemtyV/vzA9ktVZ+aT8/UYlcayRNIFquXCPr0FaG8lPVkeVVIMel7JrR3P5RHLE5KmS3rPduWtfecoydOzTm7veUxSr3R//1EyoOyTlcuk61T+DThZyd/tN5U8YvpWJQXZGtXy+QcA1KPKwYkAABnj5FGHV0VE1/Uu3MCl30S/I2l0zsV1QdneQ8lFeddYzz/Gtm9VMhbEvfUR23piuV7S/Ig4L8/ln1Py1IdpX2KfzZUMQPv1iJj9RbeTx366KSnwNImIsrraD+pf2rtqmpJBYb9wbjf08w8A2PhKCh0AACA/6YXccCXfoHdU8s3nPbWu1ICl3cqfU3Lf/FlK7q1/ttaV6ontJkoe0Xjd+goYkhQRo+o+qvVLL/K/r+Rxs3mJiHx7DdTmBEkv1GUBA189tg9S0mOthZIeYvd/yQJGN23g5x8AsPFxOwkAZIeV3A7woZLbSV6VdH5BIypuQ5QMirlYyS0N31vP2BP1Iv1G+CMlt/pcXtBgNoDtXyv5Jvv3EfFWPe53jpKCzxn1tU98ZRyvpAfPG0puu8tnDJNqFerzDwD4PG4nAQAAAAAAmUBPDAAAAAAAkAkUMQAAAAAAQCYwsCdq1KZNm+jevXuhw4Ckjz/+WJtuummhw4DIRbEhH8WDXBQPclE8yEXxIBd1Z9KkSYsjokOh40DDQREDNerYsaNefPHFQocBSaWlpRo2bFihw4DIRbEhH8WDXBQPclE8yEXxIBd1x/bcQseAhoXbSQAAAAAAQCZQxAAAAAAAAJlAEQMAAAAAAGQCY2IAAAAAABqESZMmbVFSUnKdpP7iS/1iVSFpWllZ2Y8GDRq0sOpMihioUcXq1Rq/x9BChwFJK0aP0vjzLyh0GFDx5uLcQ8q0+u3jCx1GvfvRwE11xlk3rXe5Sb8fUw/RAACAYldSUnLdlltu2adDhw4fNmrUKAodDz6voqLCixYt6vvee+9dJ+mAqvOpPAEAAAAAGor+HTp0WEYBo3g1atQoOnTosFRJb5nPz6/neAAAAAAAKJRGFDCKX5qjausVFDEAAAAAAKgHb7/9dsmIESO+1qVLl/79+vXrM3To0O5TpkxpWt2yixcvbnzRRRd1qO8Yix1FDAAAAAAA6lhFRYUOOOCA7nvsscfyefPmTZs+ffqrF1100bvz589vUt3yH3zwQeO//e1vW9R1XOvWravrXWxUFDEAAAAAAKhjDzzwQKuSkpI4++yzF1W2DRkyZNWQIUNWDhkypGffvn379OzZs+8tt9zSRpLOOOOMzvPmzWvau3fvvscff3xnSfrFL37RsX///n169uzZ97TTTtu6cjtnnXXWVt26des/aNCgXvvvv/+2559/fkdJevrpp5sPHDiwd8+ePfvus88+2y1atKixJO288869jj766C79+/fv87Of/WyrTp06bb9mzRpL0pIlSxrlvi82PJ0EAAAAAIA6NmXKlOYDBw5cWbW9RYsWFf/+979fb9euXcWCBQtKdtlll96jRo366JJLLnlnxIgRzWfOnDlDkv75z39u9vrrrzebMmXKqxGhvffeu/t//vOfli1atKi4//77286YMWP6mjVrvMMOO/TdcccdV0rS2LFjt73sssve/u53v7vi1FNP3fqcc87Z+vrrr58nSWvXrvW0adNelaS5c+c2vfPOO1v/8Ic//Oj6669v953vfOfDpk2bFuXYIRQxAAAAAAAokIqKCp966qmdn3322ZaNGjXSwoULN3nnnXc+d63+0EMPbTZhwoTN+vbt21eSVq5c2WjmzJnNli9f3mi//fb7qEWLFtGiRYvYZ599PpKS21GWL1/e+Lvf/e4KSTr22GM/OOSQQ75Wub3DDz98SeX0cccdt+jiiy/e8oc//OFHt9xyS/trr712Tl0f9xfF7SQAAAAAANSx7bffftXkyZNbVG2/+uqr233wwQclU6dOfXXmzJkzNt9883WrVq363LV6ROjUU09dMHPmzBkzZ86c8fbbb0877bTTFn/ReFq1alVROf2tb33r43feeafpAw880Kq8vNw77bTT6i+63bpGEQMAAAAAgDq2//77L1+7dq3/8Ic/tK9se+6555rPnTt3k/bt269r2rRp3H///a3mz5+/iSS1bt26/OOPP/7kmn2//fZbdvPNN7dfunRpI0l66623mrz77rslQ4cOXfHwww+3XrlypZcuXdroscceayNJm2++eflmm21W/tBDD7WUpL/97W+bDxkyZEVN8R122GEfHH300dseccQRX7gwUh+4nQQAAAAAgDrWqFEj3XfffW/85Cc/6fLHP/5xy6ZNm0bnzp3X/OpXv5r/05/+dJuePXv2HTBgwMptt912tSRtueWW5YMGDVrRo0ePfnvuuefSq6+++p3p06c322mnnXpLyVga48aNe2vo0KEr991336V9+/btt/nmm6/r1avXqtatW5dL0t///ve3TjjhhK6nnHJKo2222WbNbbfdNqem+I455pgPLr744k7HHHPMkpqWKQYUMQAAAAAAqAfdunVb9+CDD75Ztf2VV16ZWd3y999//1u573/xi18s/MUvfrGw6nIXXHDBe5deeun85cuXNxoyZEivXXbZZaUk7brrrqsmT578uW0///zzs6q2Pf7446323XffD9u3b1++IcdU3yhiAAAAAACQYUcccUTX2bNnN1+zZo0PO+ywD3bbbbfPPQWlNkceeWSXJ598svUDDzwwu65i3FgoYgAAAAAAkGFVe2xsqBtvvHGepHkbKZw6xcCeAAAAAAAgEyhiAAAAAACATKCIAQAAAAAAMoEiBgAAAAAAyASKGAAAAAAA1KObb765je1BL7/8crONuc1JkyZttO0VK55OAgAAAABokAadddOgjbm9Sb8fMymf5W6//fZ2X//611fcdNNN7Xbcccf5G2Pf9957b5uysrKlgwYNWr0xtles6IkBAAAAAEA9Wbp0aaMXXnih5d///vc599xzTztJmjt3bpPBgwf36t27d98ePXr0e+ihh1qWlZVp5MiR3Xr06NGvZ8+efX/1q19tIUnTp09vuvvuu/fo169fn0GDBvV6+eWXmz366KObPvbYY23OO++8zr179+47ffr0pr/5zW+22G677fr17Nmz74gRI75W2KPeeIq2J4btLSVdLmknSR9Jel/SqRHx2gZu53uSXouIGRs5xA2J4RuS/iipafq6IyJ+WaBYhklaGxFPF2L/AAAAANCQ3XrrrW2GDRu2dMCAAWvatm1b9tRTT7V47LHHWu21115LL7744vfKysq0fPnyRs8880yLBQsW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Y6u8f03SgJpiBQAAAACgWBVlTwwAAAAAAICqirYnRkMWEXOUPNq1unnd6jUYAAAAAACKBD0xAAAAAABAJlDEAAAAAACgntgedOCBB37yZMp169apbdu2A4cPH95dksaNG9f63HPP3XJj7W/kyJHd/v73v7eVpJ133rnXhAkTWmysbRcCt5MAAAAAABqkty/cftDG3N4250+dtL5lmjdvXjFr1qzmK1ascMuWLeOee+7ZrGPHjusq548ePXqppKUbM66vEnpiAAAAAABQj/bee++ld911VxtJuu2229qNHDlySeW8K664YvMxY8ZsI0nXX3992x49evTr1atX38GDB/eSpLKyMh133HGde/To0a9nz559f/vb324hSU899VSLnXbaqVe/fv367Lbbbj3mzp3bpLYYRo8evU3//v37dO/evd9pp522dWV7p06dtj/ttNO27tu3b5+ePXv2ffnll5tJ0rJlyxodcsgh3bbffvs+ffr06XvLLbe0kaSVK1f64IMP7tazZ8++ffr06Xv//fe3qnockjR8+PDuDzzwQKuysjKNHDmyW2X8v/rVr7bYkHNHTwwAAAAAAOrRD3/4wyUXXHDBVoceeuhHr776aotjjjnmg6effrpl1eUuuuiirR555JHXtt1223WLFy9uLEmXXHJJh7fffnuTGTNmTG/SpInef//9xmvWrPEpp5yyzb///e/Xt95667Jrr7227ZlnntnprrvumlNTDJdeeum7HTt2LC8rK9Ouu+7a67nnnmu+yy67rJKk9u3bl82YMePViy66qMNFF13U8Y477ph77rnnbjV8+PBld91115zFixc3Hjx4cJ8DDjhg2SWXXNLBtl577bUZL7/8crPvfOc7Pd54441pNe33mWeeabFgwYIms2fPni5JlceVL4oYAAAAAADUo1122WXVO++80/Taa69tt/fee9d468jgwYNXjB49utvIkSM/HD169IeS9MQTT2z24x//eFGTJklHi44dO5a/8MILzWbPnt18zz337ClJFRUV6tChw7qatitJN954Y7sbbrihfVlZmRctWtRk8uTJzSqLGKNGjfpQknbeeeeV9913X1tJKi0t3ezhhx9uc8UVV2wpSWvWrPHrr7++ydNPP93y5JNPXihJO+644+qtt9567dSpU5vVtN/evXuvmTdvXtMjjzyyy/7777/0oIMOWrYBp44iBgAAAAAA9W3ffff96IILLujyyCOPzFq4cGG11+a33nrr20888cSm9913X+tBgwb1nTRp0ozqlosId+/efdUrr7wyM599z5w5c5Mrr7yy46RJk17t0KFD+ciRI7utXr36k+EmmjVrFpJUUlISZWVlTvehu++++/WBAweuyWcfJSUlUVFR8cn7NWvWNJKkDh06lE+bNm3GPffcs9lVV13V4Y477mhXW4+RqhgTAwAAAACAenbCCScsPvPMM+fvvPPOq2paZvr06U333HPPjy+//PL5bdu2LXvzzTc32WuvvZZdffXV7detSzpavP/++40HDBiwesmSJSWPPfbYplLSS+LFF1+ssTfEhx9+2Lh58+YV7dq1K583b15JaWlp6/XFO3z48GWXXHJJx8rCxMSJE5tL0je/+c0Vt9xySztJmjJlStMFCxZsMmDAgNXbbbfd2unTp7coLy/X66+/3mTKlCmbStKCBQtKysvLNXbs2I9+97vfvTt16tQNeloKPTEAAAAAAKhn22233brzzjtvYW3LnHbaaZ3nzJnTNCK82267LfvGN76xaqeddlr12muvNe3du3e/kpKSOPLIIxede+65i26//fY3TjnllG2WL1/euLy83CeccML7gwcPXl3ddocMGbKqf//+K7fbbrv+W2211dpBgwatWF+8F1100fzjjjtum969e/etqKhwly5d1jz55JOvn3322QvHjBnTtWfPnn0bN26sq6++ek7z5s1jn332WfHnP/95Tffu3ft17959dd++fVdK0pw5c5occ8wx3SoqKixJF1544Tsbct4cERuyPBqQHl27xnVduxU6DEhaPnqUWo27tdBhQMWbi3MPKdPqt48vdBj17kcDN9V1kz9e73KTfj+mHqJp2EpLSzVs2LBChwGRi2JCLooHuag7tidFxOBCx5GvyZMnzxk4cODiQseB9Zs8eXL7gQMHdqvazu0kAAAAAAAgEyhiAAAAAACATKCIAQAAAAAAMoEiBgAAAAAAyASKGAAAAAAAIBMoYgAAAAAAgEygiAEAAAAAQD0655xztuzevXu/nj179u3du3ffJ554YtMvu81TTz1163vvvbfVxoivmJUUOgAAAAAAAArhm3/65qCNub2JJ0+ctL5lHnvssU0ffvjhNlOnTp3RvHnzWLBgQcmaNWucz/bXrVunJk2aVDvv8ssvn7+B4WYSRQzUqFGzZho6YXyhw4Ck0tJSclEkijUXEwsdQIGUlpZq0hEjCx0GAABA3t59990m7dq1K2vevHlI0lZbbVUmSU899VSL008/vcvKlSsbtW3btmzcuHFzunbtum7nnXfu1b9//5XPP/98y29/+9sf3Xbbbe3nzZs3tXHjxlq2bFmjnj179p87d+7UUaNGdR0xYsTSo4466sPx48e3OPXUU7dZuXJlo0022SQmTJgwq1WrVhUnnnhi54kTJ7Zau3atjz322IVnnXXW4rlz5zYZOXLk11asWNG4vLzcf/rTn+buu+++Kwp7lmrG7SQAAAAAANST733ve8vmz5+/Sbdu3fofccQR2/z73/9uuWbNGp9yyinb/Otf/3pj+vTprx555JGLzzzzzE6V66xdu9bTpk179ZJLLlnQp0+flQ8++GArSbrjjjtaDx06dGnTpk2jctnVq1d79OjR211++eVvz5o1a8b48eNntWzZsuLyyy9v37p16/Jp06a9Onny5FdvvPHGDjNnztzk+uuvb7fXXnstnTlz5oxXX311+i677LKyEOclX/TEAAAAAACgnrRu3bpi2rRpMx566KFWjz/+eKsjjzxyu9NPP33+7Nmzm++55549JamiokIdOnRYV7nO4YcfvqRy+pBDDvnwtttua7v//vsvv/POO9v95Cc/WZS7/SlTpjTbYost1g0dOnSlJLVr165Ckh577LHNZs6c2eK+++5rK0nLly9vPGPGjGbf+MY3Pj7++OO7rVu3rtHBBx/84a677rqqPs7DF0URAwAAAACAelRSUqIRI0YsHzFixPIBAwasuuqqqzp079591SuvvDKzuuVbtWpVUTl9+OGHf/TrX/+60/vvv9942rRpLfbff/9l+ewzInzJJZe8PXLkyM8tP2HChFn/+Mc/Wh999NHbnnTSSe+fdNJJH3zxo6tb3E4CAAAAAEA9mTx5ctOpU6c2rXz/8ssvN+/Ro8fqJUuWlDz22GObStKaNWv84osvNqtu/datW1cMGDDg4+OPP36bvfbaa2lJyWf7JgwYMGD1woULm4wfP76FJH344YeN1q1bp3322WfpX//61w6Vg4hOmTKl6bJlyxq99tprm3Tu3HndGWecsXjMmDGLXnrppRZ1dvAbAT0xAAAAAACoJ8uWLWt8yimnbLNs2bLGjRs3jm7duq258cYb57711luLTjnllG2WL1/euLy83CeccML7gwcPXl3dNn7wgx98ePTRR3/tgQcemFV1XrNmzWLcuHFvnHLKKdusXr26UbNmzSomTJjw2mmnnbZ4zpw5Tbfffvs+EeF27dqte/DBB994+OGHW11xxRVblpSURIsWLcrHjRv3Vt2fhS+OIgYAAAAAoEHK55GoG9vuu+++8uWXX/7cbSNbbbVV2Ysvvvi5osTzzz//ubajjjrqw6OOOuozsf/jH/+YUzk9dOjQlZMnT/7cPq688sp3Jb2b23byySd/cPLJJxft7SNVcTsJAAAAAADIBIoYAAAAAAAgEyhiAAAAAACATKCIAQAAAAAAMoEiBgAAAAAAyASeToIarS5brW/+6ZuFDgOSxnQco5//6eeFDgMiF8WGfCQmnjyx0CEAAADUC3piAAAAAABQD957773GvXv37tu7d+++7du3H7jFFlsMqHy/evVqb8x9PfDAA62GDx/efWNusxjQEwMAAAAA0CCN32PooI25vaETxk+qbf6WW25ZPnPmzBmSdPrpp2/dsmXL8gsvvPD9yvnr1q1TkyZNNmZIXzn0xAAAAAAAoEBGjhzZbdSoUdsMGDCg9wknnND5ySefbLHDDjv07tOnT98dd9yx9+TJk5tK0sCBA3u/+OKLzSrX23nnnXtNmDChxbJlyxodcsgh3bbffvs+ffr06XvLLbe0KdjB1AN6YgAAAAAAUEALFizY5KWXXppZUlKiJUuWNHrhhRdmNmnSRPfee2+rs88+u/PDDz/8xve///0l48aNazd48OD5c+fObbJw4cIme+yxx8qTTjqp0/Dhw5fdddddcxYvXtx48ODBfQ444IBlhT6mukIRAwAAAACAAvr+97//YUlJcnm+ZMmSxoceeui2c+bMaWY71q1bZ0kaM2bMh/vss0/Pyy67bP5NN93Udv/99/9QkkpLSzd7+OGH21xxxRVbStKaNWv8+uuvb1Kwg6ljFDEAAAAAACigli1bVlROn3POOZ2GDh26/NFHH31j1qxZm+y55569JGnbbbdd16ZNm7Lnnnuu+T//+c92V1111VxJigjdfffdrw8cOHBN7jbnz5//lRxcgzExAAAAAAAoEsuWLWvcuXPntZJ09dVXt8+dN3LkyCX/+7//u+Xy5csb77LLLqskafjw4csuueSSjhUVSR1k4sSJzes9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",
      "text/plain": [
       "<Figure size 1008x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "# Load and process the data\n",
    "flag_data = pd.read_csv(\"csvs/flag-66.csv\")\n",
    "\n",
    "# Convert date columns to datetime format\n",
    "flag_data[\"opened_at\"] = pd.to_datetime(flag_data[\"opened_at\"], errors=\"coerce\")\n",
    "flag_data[\"processed_date\"] = pd.to_datetime(\n",
    "    flag_data[\"processed_date\"], errors=\"coerce\"\n",
    ")\n",
    "\n",
    "# Calculate processing delay in days and remove rows with missing dates\n",
    "flag_data[\"processing_delay\"] = (\n",
    "    flag_data[\"processed_date\"] - flag_data[\"opened_at\"]\n",
    ").dt.days\n",
    "flag_data = flag_data.dropna(subset=[\"processing_delay\", \"department\", \"category\"])\n",
    "\n",
    "# Aggregate mean processing delay by department and category\n",
    "delay_by_dept_category = (\n",
    "    flag_data.groupby([\"department\", \"category\"])[\"processing_delay\"]\n",
    "    .mean()\n",
    "    .reset_index()\n",
    ")\n",
    "\n",
    "# Plotting\n",
    "plt.figure(figsize=(14, 8))\n",
    "sns.barplot(\n",
    "    data=delay_by_dept_category,\n",
    "    x=\"processing_delay\",\n",
    "    y=\"department\",\n",
    "    hue=\"category\",\n",
    "    dodge=False,\n",
    ")\n",
    "plt.title(\"Average Processing Delay (in days) by Department and Category\")\n",
    "plt.xlabel(\"Average Processing Delay (days)\")\n",
    "plt.ylabel(\"Department\")\n",
    "plt.legend(title=\"Category\", bbox_to_anchor=(1.05, 1), loc=\"upper left\")\n",
    "plt.grid(True)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Generate JSON Description for the Insight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:15:29.101777Z",
     "iopub.status.busy": "2024-10-29T17:15:29.101195Z",
     "iopub.status.idle": "2024-10-29T17:15:29.129571Z",
     "shell.execute_reply": "2024-10-29T17:15:29.127993Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'descriptive',\n",
       " 'insight': 'There is a significant variance in Expense Rejection Rates across departments',\n",
       " 'insight_value': {'description': 'The IT department exhibits a notably higher proportion of expense rejections compared to other departments with 44%, indicating potential issues with budget compliance or policy understanding.'},\n",
       " 'plot': {'plot_type': 'bar',\n",
       "  'title': 'Proportion of Declined Expenses by Department',\n",
       "  'x_axis': {'name': 'Department',\n",
       "   'value': ['IT',\n",
       "    'HR',\n",
       "    'Finance',\n",
       "    'Customer Support',\n",
       "    'Development',\n",
       "    'Sales',\n",
       "    'Product Management'],\n",
       "   'description': 'This axis categorizes expenses based on department affiliation.'},\n",
       "  'y_axis': {'name': 'Proportion of Declined',\n",
       "   'value': {'IT': '0.44',\n",
       "    'HR': '0.14',\n",
       "    'Finance': '0.09',\n",
       "    'Customer Support': '0.06',\n",
       "    'Development': '0.05',\n",
       "    'Sales': '0.05',\n",
       "    'Product Management': '0.00'},\n",
       "   'description': 'This axis displays the proportion of expenses declined within each department, highlighting the higher rejection rates particularly in the IT department.'},\n",
       "  'description': \"The bar chart illustrates the discrepancies in expense rejection rates among departments, with IT facing the highest rejection rate at 44%. This outlier suggests a specific challenge within the IT department's expense management process that requires immediate attention to improve compliance and understanding of financial policies.\"},\n",
       " 'question': 'Which departments have higher proportions of expense rejections compared to the organizational average?',\n",
       " 'actionable_insight': \"Given the high rejection rates in the IT department, a targeted review of expense submission procedures and training on policy compliance is recommended. This action should aim to align IT's expense management practices with organizational standards and reduce the high rate of declined expenses. Additionally, understanding the root causes of these rejections could inform broader improvements in expense processing protocols across the organization.\"}"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"aggregated\",\n",
    "    \"insight\": \"Certain departments, notably Product Management and HR, exhibit notably longer processing delays in specific categories such as Services and Travel, indicating potential workflow bottlenecks.\",\n",
    "    \"insight_value\": {\n",
    "        \"description\": \"Departments such as Product Management and HR have average delays of up to 15 days in processing travel-related requests, which is significantly higher than in other departments and categories, pointing to a resource allocation or prioritization issue.\"\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"bar\",\n",
    "        \"title\": \"Average Processing Delay (in days) by Department and Category\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Average Processing Delay (days)\",\n",
    "            \"value\": \"Range of delays from 1 to 15 days\",\n",
    "            \"description\": \"This axis represents the average time in days it takes to process requests within each department and category.\",\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Department\",\n",
    "            \"value\": \"Various departments in the organization\",\n",
    "            \"description\": \"This axis lists departments such as HR, IT, Finance, and Product Management.\",\n",
    "        },\n",
    "        \"description\": \"The bar plot highlights processing delays across departments, with a marked delay in specific categories for departments like Product Management and HR, especially in Services and Travel requests, indicating potential bottlenecks in these workflows.\",\n",
    "    },\n",
    "    \"question\": \"How does the processing delay (in days) vary across different departments and categories?\",\n",
    "    \"actionable_insight\": \"The extended processing delays in departments such as HR and Product Management, especially in Travel and Services, suggest that these areas may benefit from a review of workflow efficiency or resource allocation. Addressing these bottlenecks could streamline operations, particularly in high-delay categories, improving overall organizational efficiency.\",\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 2:  What is the distribution of Expense Reports by Department?**\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Plot number of expense reports by department\n",
    "This cell visualizes the distribution of expense reports across different departments using a bar plot. Each blue bar represents the total number of expense reports submitted by a particular department. This plot is essential for assessing the volume of financial transactions handled by each department and identifying which departments are more active in submitting expenses."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:15:29.146300Z",
     "iopub.status.busy": "2024-10-29T17:15:29.145482Z",
     "iopub.status.idle": "2024-10-29T17:15:29.665286Z",
     "shell.execute_reply": "2024-10-29T17:15:29.663337Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Count the number of expense reports per department\n",
    "department_counts = flag_data['department'].value_counts()\n",
    "\n",
    "# Plot the data\n",
    "fig, ax = plt.subplots(figsize=(12, 8))\n",
    "department_counts.plot(kind='bar', color='skyblue', ax=ax)\n",
    "\n",
    "# Add titles and labels\n",
    "ax.set_title('Number of Expense Reports by Department', fontsize=16)\n",
    "ax.set_xlabel('Department', fontsize=14)\n",
    "ax.set_ylabel('Number of Expense Reports', fontsize=14)\n",
    "\n",
    "# Show grid\n",
    "ax.grid(axis='y')  # Only horizontal grid lines for readability\n",
    "\n",
    "# Rotate the x-axis labels for better readability\n",
    "plt.xticks(rotation=45)\n",
    "plt.tight_layout()  # Adjust layout to not cut off labels\n",
    "\n",
    "# Adding numeric labels on top of the bars for clarity\n",
    "for p in ax.patches:\n",
    "    ax.annotate(f\"{int(p.get_height())}\", (p.get_x() + p.get_width() / 2., p.get_height()),\n",
    "                ha='center', va='bottom', xytext=(0, 10), textcoords='offset points')\n",
    "\n",
    "# Show the plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Generate JSON Description for the Insight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:15:29.679900Z",
     "iopub.status.busy": "2024-10-29T17:15:29.679109Z",
     "iopub.status.idle": "2024-10-29T17:15:29.711651Z",
     "shell.execute_reply": "2024-10-29T17:15:29.706888Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'descriptive',\n",
       " 'insight': 'There is no correlation between the number of expense reports submitted and rejection rates',\n",
       " 'insight_value': {'description': 'Despite having a lower volume of expense submissions, the IT department has the highest rejection rate, while departments with higher submission volumes like Customer Support exhibit lower rejection rates.'},\n",
       " 'plot': {'plot_type': 'bar',\n",
       "  'title': 'Distribution of Expense Reports by Department',\n",
       "  'x_axis': {'name': 'Department',\n",
       "   'value': ['Customer Support',\n",
       "    'Sales',\n",
       "    'IT',\n",
       "    'Finance',\n",
       "    'Development',\n",
       "    'HR',\n",
       "    'Product Management'],\n",
       "   'description': 'This axis categorizes expenses based on department affiliation.'},\n",
       "  'y_axis': {'name': 'Number of Expense Reports',\n",
       "   'value': {'Customer Support': '267',\n",
       "    'Sales': '122',\n",
       "    'IT': '43',\n",
       "    'Finance': '22',\n",
       "    'Development': '20',\n",
       "    'HR': '14',\n",
       "    'Product Management': '12'},\n",
       "   'description': 'This axis displays the number of expense reports submitted by each department, revealing that Customer Support submits the most, while IT, despite its high rejection rate, submits far fewer.'},\n",
       "  'description': 'The bar chart vividly illustrates the number of expense reports submitted by each department. The data highlight that the volume of submissions does not correlate with the proportion of rejections, as seen with the IT department, which submits fewer reports but faces a high rate of rejections.'},\n",
       " 'question': 'What is the distribution of Expense Reports by Department?',\n",
       " 'actionable_insight': \"This discrepancy in rejection rates despite lower submission volumes suggests underlying issues in IT’s expense reporting process or stricter scrutiny of their reports. It would be prudent to conduct a detailed review of the IT department's submissions to understand the reasons behind the high rejection rates. Efforts should be focused on aligning IT’s expense reporting practices with those departments exhibiting high compliance and low rejection rates, like Customer Support, to reduce unnecessary financial discrepancies and improve procedural compliance.\"}"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"descriptive\",\n",
    "    \"insight\": \"There is no correlation between the number of expense reports submitted and rejection rates\",\n",
    "    \"insight_value\": {\n",
    "        \"description\": \"Despite having a lower volume of expense submissions, the IT department has the highest rejection rate, while departments with higher submission volumes like Customer Support exhibit lower rejection rates.\"\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"bar\",\n",
    "        \"title\": \"Distribution of Expense Reports by Department\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Department\",\n",
    "            \"value\": [\"Customer Support\", \"Sales\", \"IT\", \"Finance\", \"Development\", \"HR\", \"Product Management\"],\n",
    "            \"description\": \"This axis categorizes expenses based on department affiliation.\"\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Number of Expense Reports\",\n",
    "            \"value\": {\n",
    "                \"Customer Support\": \"267\",\n",
    "                \"Sales\": \"122\",\n",
    "                \"IT\": \"43\",\n",
    "                \"Finance\": \"22\",\n",
    "                \"Development\": \"20\",\n",
    "                \"HR\": \"14\",\n",
    "                \"Product Management\": \"12\"\n",
    "            },\n",
    "            \"description\": \"This axis displays the number of expense reports submitted by each department, revealing that Customer Support submits the most, while IT, despite its high rejection rate, submits far fewer.\"\n",
    "        },\n",
    "        \"description\": \"The bar chart vividly illustrates the number of expense reports submitted by each department. The data highlight that the volume of submissions does not correlate with the proportion of rejections, as seen with the IT department, which submits fewer reports but faces a high rate of rejections.\"\n",
    "    },\n",
    "    \"question\": \"What is the distribution of Expense Reports by Department?\",\n",
    "    \"actionable_insight\": \"This discrepancy in rejection rates despite lower submission volumes suggests underlying issues in IT’s expense reporting process or stricter scrutiny of their reports. It would be prudent to conduct a detailed review of the IT department's submissions to understand the reasons behind the high rejection rates. Efforts should be focused on aligning IT’s expense reporting practices with those departments exhibiting high compliance and low rejection rates, like Customer Support, to reduce unnecessary financial discrepancies and improve procedural compliance.\"\n",
    "}\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 3: How do expense amounts vary across different departments, and what is the distribution of these expenses?**\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Plot expense amount across different departments\n",
    "This analysis focuses on understanding how expense amounts are distributed across various departments. By examining the distribution of expenses within each department, we can identify departments with higher spending variability and those with consistent expense patterns. This insight can help in budgeting and financial planning by highlighting areas where expenses are more unpredictable or particularly high."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:15:29.727704Z",
     "iopub.status.busy": "2024-10-29T17:15:29.726194Z",
     "iopub.status.idle": "2024-10-29T17:15:30.202261Z",
     "shell.execute_reply": "2024-10-29T17:15:30.200160Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1008x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "\n",
    "# Load the dataset\n",
    "flag_data = pd.read_csv(\"csvs/flag-66.csv\")\n",
    "\n",
    "# Drop rows with missing department or amount values\n",
    "flag_data_cleaned = flag_data.dropna(subset=[\"department\", \"amount\"])\n",
    "\n",
    "# Convert the amount column to numeric if it's not already\n",
    "flag_data_cleaned[\"amount\"] = pd.to_numeric(\n",
    "    flag_data_cleaned[\"amount\"], errors=\"coerce\"\n",
    ")\n",
    "\n",
    "# Drop rows where amount conversion failed (if any)\n",
    "flag_data_cleaned = flag_data_cleaned.dropna(subset=[\"amount\"])\n",
    "\n",
    "# Group the data by department and calculate the total and mean amounts\n",
    "department_expenses = (\n",
    "    flag_data_cleaned.groupby(\"department\")[\"amount\"]\n",
    "    .agg([\"sum\", \"mean\", \"count\"])\n",
    "    .reset_index()\n",
    ")\n",
    "\n",
    "# Sort by total amount for better visualization\n",
    "department_expenses_sorted = department_expenses.sort_values(by=\"sum\", ascending=False)\n",
    "\n",
    "# Plot the distribution of expense amounts for each department\n",
    "plt.figure(figsize=(14, 8))\n",
    "sns.boxplot(\n",
    "    x=\"department\",\n",
    "    y=\"amount\",\n",
    "    data=flag_data_cleaned,\n",
    "    order=department_expenses_sorted[\"department\"],\n",
    ")\n",
    "plt.xticks(rotation=45, ha=\"right\")\n",
    "plt.title(\"Distribution of Expense Amounts Across Departments\")\n",
    "plt.xlabel(\"Department\")\n",
    "plt.ylabel(\"Expense Amount\")\n",
    "plt.grid(True, axis=\"y\")\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Generate JSON Description for the Insight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:15:30.215960Z",
     "iopub.status.busy": "2024-10-29T17:15:30.215267Z",
     "iopub.status.idle": "2024-10-29T17:15:30.237061Z",
     "shell.execute_reply": "2024-10-29T17:15:30.235401Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'comparative',\n",
       " 'insight': 'The Customer Support and Sales departments have the highest total expenses, with Customer Support leading significantly in total spending and count of expense instances.',\n",
       " 'insight_value': {'description': 'Customer Support exhibits the highest overall expenses, suggesting a high volume of spending likely due to operational demands or asset provisioning, as evidenced by the sum of expenses. Sales also shows substantial total expenditure, though with fewer instances compared to Customer Support, indicating potentially larger one-time purchases or higher per-instance costs.'},\n",
       " 'plot': {'plot_type': 'boxplot',\n",
       "  'title': 'Distribution of Expense Amounts Across Departments',\n",
       "  'x_axis': {'name': 'Department',\n",
       "   'value': 'Various departments within the organization',\n",
       "   'description': 'This axis represents different departments, showcasing the variability in their expense distributions.'},\n",
       "  'y_axis': {'name': 'Expense Amount',\n",
       "   'value': 'Range of expenses in monetary units',\n",
       "   'description': 'This axis displays the monetary values associated with expenses, highlighting both the spread and central tendency for each department.'},\n",
       "  'description': 'The boxplot highlights significant variability in expense distributions, with Customer Support not only having the highest number of expense records but also a broad range of expenses. Product Management shows the highest average expense amount, while HR has the lowest overall expenses and narrower spending distribution.'},\n",
       " 'question': 'How do expense amounts vary across different departments, and what is the distribution of these expenses?',\n",
       " 'actionable_insight': 'Given the high spending volume in Customer Support, it would be beneficial to evaluate operational spending needs closely for potential optimizations. Additionally, monitoring the large average expenses in Product Management could help identify opportunities for cost-saving in high-value procurements. A review of spending patterns in these departments could reveal ways to enhance budgeting efficiency and control expense variability.'}"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"comparative\",\n",
    "    \"insight\": \"The Customer Support and Sales departments have the highest total expenses, with Customer Support leading significantly in total spending and count of expense instances.\",\n",
    "    \"insight_value\": {\n",
    "        \"description\": \"Customer Support exhibits the highest overall expenses, suggesting a high volume of spending likely due to operational demands or asset provisioning, as evidenced by the sum of expenses. Sales also shows substantial total expenditure, though with fewer instances compared to Customer Support, indicating potentially larger one-time purchases or higher per-instance costs.\"\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"boxplot\",\n",
    "        \"title\": \"Distribution of Expense Amounts Across Departments\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Department\",\n",
    "            \"value\": \"Various departments within the organization\",\n",
    "            \"description\": \"This axis represents different departments, showcasing the variability in their expense distributions.\",\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Expense Amount\",\n",
    "            \"value\": \"Range of expenses in monetary units\",\n",
    "            \"description\": \"This axis displays the monetary values associated with expenses, highlighting both the spread and central tendency for each department.\",\n",
    "        },\n",
    "        \"description\": \"The boxplot highlights significant variability in expense distributions, with Customer Support not only having the highest number of expense records but also a broad range of expenses. Product Management shows the highest average expense amount, while HR has the lowest overall expenses and narrower spending distribution.\",\n",
    "    },\n",
    "    \"question\": \"How do expense amounts vary across different departments, and what is the distribution of these expenses?\",\n",
    "    \"actionable_insight\": \"Given the high spending volume in Customer Support, it would be beneficial to evaluate operational spending needs closely for potential optimizations. Additionally, monitoring the large average expenses in Product Management could help identify opportunities for cost-saving in high-value procurements. A review of spending patterns in these departments could reveal ways to enhance budgeting efficiency and control expense variability.\",\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 4: How to prevent or avoid future declinations in this scenario?**\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "\"Immediate Training\": \"Organize targeted training sessions for all IT department employees, with a special focus on those who have had high rejection rates. These sessions should cover best practices for expense report submissions, including detailed explanations of allowable expenses and required documentation.\"\n",
    "\n",
    "\"Enhanced Review Process\": \"Implement a pre-submission review process where expense reports, particularly those from individuals with past declinations, are preliminarily reviewed by a finance team member or a designated mentor within the IT department before official submission.\"\n",
    "\n",
    "\"Policy Updates and Communication\": \"Regularly update and communicate any changes in expense policies to all employees. Ensure that these updates are clearly understood by conducting interactive Q&A sessions and providing accessible reference materials.\""
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Summary of Findings (Flag 66):\n",
    "\n",
    "1. **Processing Delays**: From Question 1, it was found that departments like Product Management and HR experience significant processing delays, particularly in categories such as Services and Travel. This suggests potential workflow bottlenecks that could be addressed to improve efficiency.\n",
    "\n",
    "2. **Expense Report Distribution**: Question 2 revealed that there is no direct correlation between the number of expense reports submitted and their rejection rates. Notably, the IT department, despite submitting fewer reports, has a higher rejection rate, indicating possible issues in their reporting process.\n",
    "\n",
    "3. **Expense Amount Variability**: According to Question 3, Customer Support and Sales departments have the highest total expenses, with Customer Support leading in both spending and the number of expense instances. This highlights the need for closer evaluation of operational spending to identify potential cost-saving opportunities."
   ]
  }
 ],
 "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
