{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Expense Claim Patterns and Fraud Analysis (Flag 70)\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 detect and investigate instances of repeated identical expense claims by individual users, determining whether these repetitions are fraudulent or due to misunderstandings of the expense policy.\n",
    "\n",
    "**Role**: Compliance and Audit Analyst\n",
    "\n",
    "**Difficulty**: 3 out of 5.\n",
    "\n",
    "**Category**: Finance 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": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:16:08.043509Z",
     "iopub.status.busy": "2024-10-29T17:16:08.041855Z",
     "iopub.status.idle": "2024-10-29T17:16:13.972295Z",
     "shell.execute_reply": "2024-10-29T17:16:13.968706Z"
    }
   },
   "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",
    "\n",
    "from openai import OpenAI\n",
    "from pandas import date_range\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load Dataset\n",
    "This cell loads the expense dataset to be analyzed. The data is orginally saved in the from a CSV file, and is here imported into a DataFrame. The steps involve specifying the path to the dataset, using pandas to read the file, and confirming its successful load by inspecting the first few table entries."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:16:13.990946Z",
     "iopub.status.busy": "2024-10-29T17:16:13.988964Z",
     "iopub.status.idle": "2024-10-29T17:16:14.068497Z",
     "shell.execute_reply": "2024-10-29T17:16:14.066827Z"
    }
   },
   "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>source_id</th>\n",
       "      <th>department</th>\n",
       "      <th>number</th>\n",
       "      <th>amount</th>\n",
       "      <th>category</th>\n",
       "      <th>state</th>\n",
       "      <th>processed_date</th>\n",
       "      <th>type</th>\n",
       "      <th>user</th>\n",
       "      <th>opened_at</th>\n",
       "      <th>short_description</th>\n",
       "      <th>ci</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>QPK-03664835</td>\n",
       "      <td>Customer Support</td>\n",
       "      <td>EXP00000000</td>\n",
       "      <td>6240</td>\n",
       "      <td>Assets</td>\n",
       "      <td>Processed</td>\n",
       "      <td>2023-07-18 12:03:00.000000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>Helena Suermann</td>\n",
       "      <td>2023-07-17 12:03:00</td>\n",
       "      <td>Acquisition of new server hardware</td>\n",
       "      <td>IBM System x3550 M5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>NaN</td>\n",
       "      <td>IT</td>\n",
       "      <td>EXP00000001</td>\n",
       "      <td>5947</td>\n",
       "      <td>Travel</td>\n",
       "      <td>Declined</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>Sadie Rowlett</td>\n",
       "      <td>2023-04-25 19:51:00</td>\n",
       "      <td>Travel equipment asset registration</td>\n",
       "      <td>Travel Kit 01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>NaN</td>\n",
       "      <td>Sales</td>\n",
       "      <td>EXP00000002</td>\n",
       "      <td>2253</td>\n",
       "      <td>Miscellaneous</td>\n",
       "      <td>Declined</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>Nadia Wilshire</td>\n",
       "      <td>2023-05-03 02:19:00</td>\n",
       "      <td>Miscellaneous asset configuration item</td>\n",
       "      <td>Firewall FortiGate 50E</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>NaN</td>\n",
       "      <td>Sales</td>\n",
       "      <td>EXP00000003</td>\n",
       "      <td>2336</td>\n",
       "      <td>Miscellaneous</td>\n",
       "      <td>Processed</td>\n",
       "      <td>2023-04-22 07:45:28.895988932</td>\n",
       "      <td>NaN</td>\n",
       "      <td>Savannah Loffier</td>\n",
       "      <td>2023-04-11 04:45:00</td>\n",
       "      <td>Miscellaneous hardware asset creation</td>\n",
       "      <td>Desktop PC Dell Optiplex 3060</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>RKY-84503313</td>\n",
       "      <td>Finance</td>\n",
       "      <td>EXP00000004</td>\n",
       "      <td>6348</td>\n",
       "      <td>Assets</td>\n",
       "      <td>Declined</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>Germaine Bruski</td>\n",
       "      <td>2023-08-01 11:06:00</td>\n",
       "      <td>Asset Registration for New Hardware</td>\n",
       "      <td>Dell Latitude Laptop 5500</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      source_id        department       number  amount       category  \\\n",
       "0  QPK-03664835  Customer Support  EXP00000000    6240         Assets   \n",
       "1           NaN                IT  EXP00000001    5947         Travel   \n",
       "2           NaN             Sales  EXP00000002    2253  Miscellaneous   \n",
       "3           NaN             Sales  EXP00000003    2336  Miscellaneous   \n",
       "4  RKY-84503313           Finance  EXP00000004    6348         Assets   \n",
       "\n",
       "       state                 processed_date  type              user  \\\n",
       "0  Processed  2023-07-18 12:03:00.000000000   NaN   Helena Suermann   \n",
       "1   Declined                            NaN   NaN     Sadie Rowlett   \n",
       "2   Declined                            NaN   NaN    Nadia Wilshire   \n",
       "3  Processed  2023-04-22 07:45:28.895988932   NaN  Savannah Loffier   \n",
       "4   Declined                            NaN   NaN   Germaine Bruski   \n",
       "\n",
       "             opened_at                       short_description  \\\n",
       "0  2023-07-17 12:03:00      Acquisition of new server hardware   \n",
       "1  2023-04-25 19:51:00     Travel equipment asset registration   \n",
       "2  2023-05-03 02:19:00  Miscellaneous asset configuration item   \n",
       "3  2023-04-11 04:45:00   Miscellaneous hardware asset creation   \n",
       "4  2023-08-01 11:06:00     Asset Registration for New Hardware   \n",
       "\n",
       "                              ci  \n",
       "0            IBM System x3550 M5  \n",
       "1                  Travel Kit 01  \n",
       "2         Firewall FortiGate 50E  \n",
       "3  Desktop PC Dell Optiplex 3060  \n",
       "4      Dell Latitude Laptop 5500  "
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_path = \"csvs/flag-70.csv\"\n",
    "flag_data = pd.read_csv(dataset_path)\n",
    "df = pd.read_csv(dataset_path)\n",
    "flag_data.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 1:How does the processing delay (time between \"opened_at\" and \"processed_date\") vary across different departments?**"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Plot processing delay across departments\n",
    "This analysis explores the efficiency of different departments in handling asset-related requests by examining the time delay between the request initiation (opened_at) and the processing completion (processed_date). Understanding this delay can highlight departments that might benefit from improved workflows for faster processing of requests or asset approvals."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:16:14.084652Z",
     "iopub.status.busy": "2024-10-29T17:16:14.084030Z",
     "iopub.status.idle": "2024-10-29T17:16:14.663589Z",
     "shell.execute_reply": "2024-10-29T17:16:14.661974Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "\n",
    "# Load and prepare data\n",
    "data = pd.read_csv(\"csvs/flag-70.csv\")\n",
    "data[\"opened_at\"] = pd.to_datetime(data[\"opened_at\"], errors=\"coerce\")\n",
    "data[\"processed_date\"] = pd.to_datetime(data[\"processed_date\"], errors=\"coerce\")\n",
    "\n",
    "# Calculate the processing delay in days\n",
    "data[\"processing_delay\"] = (data[\"processed_date\"] - data[\"opened_at\"]).dt.days\n",
    "\n",
    "# Drop rows with missing values in 'processing_delay' for better analysis\n",
    "processed_data = data.dropna(subset=[\"processing_delay\"])\n",
    "\n",
    "# Group by department and calculate average processing delay\n",
    "department_delay = (\n",
    "    processed_data.groupby(\"department\")[\"processing_delay\"].mean().sort_values()\n",
    ")\n",
    "\n",
    "# Plotting\n",
    "plt.figure(figsize=(10, 6))\n",
    "department_delay.plot(kind=\"barh\", color=\"skyblue\", edgecolor=\"black\")\n",
    "plt.title(\"Average Processing Delay by Department\")\n",
    "plt.xlabel(\"Average Processing Delay (days)\")\n",
    "plt.ylabel(\"Department\")\n",
    "plt.grid(axis=\"x\", linestyle=\"--\", alpha=0.7)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Generate JSON Description for the Insight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:16:14.680272Z",
     "iopub.status.busy": "2024-10-29T17:16:14.679669Z",
     "iopub.status.idle": "2024-10-29T17:16:14.707198Z",
     "shell.execute_reply": "2024-10-29T17:16:14.705644Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'comparative',\n",
       " 'insight': 'Processing delays vary significantly across departments, with some departments handling requests faster on average than others.',\n",
       " 'insight_value': {'description': \"IT processes requests the fastest with an average delay of approximately 5.2 days, whereas Finance shows the longest delay, averaging around 8.6 days. This variation highlights potential inefficiencies and areas for improvement in Finance's request handling workflow.\"},\n",
       " 'plot': {'plot_type': 'horizontal bar chart',\n",
       "  'title': 'Average Processing Delay by Department',\n",
       "  'x_axis': {'name': 'Average Processing Delay (days)',\n",
       "   'value': 'Average delay in days ranging from around 5 to 9 days across departments',\n",
       "   'description': 'This axis represents the average time taken to process requests across different departments.'},\n",
       "  'y_axis': {'name': 'Department',\n",
       "   'value': 'Departments such as IT, Sales, Development, Finance, etc.',\n",
       "   'description': 'This axis lists the departments involved in handling requests or processing assets.'},\n",
       "  'description': 'The bar chart reveals differences in processing efficiency among departments, with IT displaying the shortest average delay and Finance showing the longest. This trend could suggest differences in resource allocation, priority, or process efficiency.'},\n",
       " 'question': 'How does the processing delay vary across different departments?',\n",
       " 'actionable_insight': 'To improve overall request processing efficiency, departments like Finance could benefit from reviewing and streamlining their workflows. Departments with faster processing times, like IT, might serve as models for process improvements. Cross-departmental process standardization could be a valuable approach to reduce delays and increase overall efficiency in request handling.'}"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"comparative\",\n",
    "    \"insight\": \"Processing delays vary significantly across departments, with some departments handling requests faster on average than others.\",\n",
    "    \"insight_value\": {\n",
    "        \"description\": \"IT processes requests the fastest with an average delay of approximately 5.2 days, whereas Finance shows the longest delay, averaging around 8.6 days. This variation highlights potential inefficiencies and areas for improvement in Finance's request handling workflow.\"\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"horizontal bar chart\",\n",
    "        \"title\": \"Average Processing Delay by Department\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Average Processing Delay (days)\",\n",
    "            \"value\": \"Average delay in days ranging from around 5 to 9 days across departments\",\n",
    "            \"description\": \"This axis represents the average time taken to process requests across different departments.\",\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Department\",\n",
    "            \"value\": \"Departments such as IT, Sales, Development, Finance, etc.\",\n",
    "            \"description\": \"This axis lists the departments involved in handling requests or processing assets.\",\n",
    "        },\n",
    "        \"description\": \"The bar chart reveals differences in processing efficiency among departments, with IT displaying the shortest average delay and Finance showing the longest. This trend could suggest differences in resource allocation, priority, or process efficiency.\",\n",
    "    },\n",
    "    \"question\": \"How does the processing delay vary across different departments?\",\n",
    "    \"actionable_insight\": \"To improve overall request processing efficiency, departments like Finance could benefit from reviewing and streamlining their workflows. Departments with faster processing times, like IT, might serve as models for process improvements. Cross-departmental process standardization could be a valuable approach to reduce delays and increase overall efficiency in request handling.\",\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 2:How many instances of any repeated identical expense claims are there?**\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Frequency Distribution of Repeated Expense Claims\n",
    "\n",
    "This chart analyzes frequency of repeated identical expense claims, highlighting potential anomalies. It focuses on claims submitted by the same user, within the same category, and for the same amount. The histogram displays the distribution of these frequencies, using red bars to highlight any unusual nature of repeated claims.\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:16:14.722468Z",
     "iopub.status.busy": "2024-10-29T17:16:14.721683Z",
     "iopub.status.idle": "2024-10-29T17:16:15.182377Z",
     "shell.execute_reply": "2024-10-29T17:16:15.180758Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "\n",
    "# Group by user, category, and amount to count occurrences\n",
    "grouped_data = flag_data.groupby(['user', 'category', 'amount']).size().reset_index(name='frequency')\n",
    "\n",
    "# Filter out normal entries to focus on potential anomalies\n",
    "potential_fraud = grouped_data[grouped_data['frequency'] > 3]  # Arbitrary threshold, adjust based on your data\n",
    "\n",
    "# Plot histogram of frequencies\n",
    "plt.figure(figsize=(10, 6))\n",
    "plt.hist(potential_fraud['frequency'], bins=30, color='red', alpha=0.7)\n",
    "plt.title('Distribution of Repeated Claims Frequency')\n",
    "plt.xlabel('Frequency of Same Amount Claims by Same User in Same Category')\n",
    "plt.ylabel('Count of Such Incidents')\n",
    "plt.grid(True)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Generate JSON Description for the Insight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:16:15.199770Z",
     "iopub.status.busy": "2024-10-29T17:16:15.199173Z",
     "iopub.status.idle": "2024-10-29T17:16:15.220426Z",
     "shell.execute_reply": "2024-10-29T17:16:15.218757Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'diagnostic',\n",
       " 'insight': 'There is a high incidence of repeated identical expense claims',\n",
       " 'insight_value': {'description': 'There are 100 instances where a single user has submitted identical claims with the same amount and category more than three times, which may indicate potential fraud or policy abuse within the expense management process.'},\n",
       " 'plot': {'plot_type': 'histogram',\n",
       "  'title': 'Distribution of Repeated Claims Frequency',\n",
       "  'x_axis': {'name': 'Frequency of Same Amount Claims by Same User in Same Category',\n",
       "   'value': 'Frequency ranges',\n",
       "   'description': 'This axis represents the number of times the same expense claim has been submitted by the same user for the same amount in the same category.'},\n",
       "  'y_axis': {'name': 'Count of Such Incidents',\n",
       "   'value': 'Number of occurrences',\n",
       "   'description': 'This axis counts the number of instances where repeated claims have occurred, highlighting the scale of potential repetitive claim submissions.'},\n",
       "  'description': 'The histogram illustrates the frequency distribution of repeated expense claims, with a notable peak indicating 100 instances where claims have been repeatedly filed by the same user. This suggests a possible oversight or exploitation of the expense reporting system that warrants further investigation.'},\n",
       " 'question': 'How many instances of repeated identical expense claims are there?',\n",
       " 'actionable_insight': {'description': 'Given the significant number of repeated claims, it is crucial for the organization to undertake a thorough review of these incidents to confirm their legitimacy and to determine if they reflect a pattern of fraud or abuse. Enhancing monitoring mechanisms, such as implementing automated flags for duplicate entries and conducting regular audits, could help prevent such behaviors. Training sessions emphasizing ethical practices and the consequences of policy violations should also be conducted to reinforce the seriousness of such actions. If fraudulent activities are confirmed, appropriate disciplinary measures should be enforced to maintain the integrity of the expense management system.'}}"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"diagnostic\",\n",
    "    \"insight\": \"There is a high incidence of repeated identical expense claims\",\n",
    "    \"insight_value\": {\n",
    "        \"description\": \"There are 100 instances where a single user has submitted identical claims with the same amount and category more than three times, which may indicate potential fraud or policy abuse within the expense management process.\"\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"histogram\",\n",
    "        \"title\": \"Distribution of Repeated Claims Frequency\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Frequency of Same Amount Claims by Same User in Same Category\",\n",
    "            \"value\": \"Frequency ranges\",\n",
    "            \"description\": \"This axis represents the number of times the same expense claim has been submitted by the same user for the same amount in the same category.\"\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Count of Such Incidents\",\n",
    "            \"value\": \"Number of occurrences\",\n",
    "            \"description\": \"This axis counts the number of instances where repeated claims have occurred, highlighting the scale of potential repetitive claim submissions.\"\n",
    "        },\n",
    "        \"description\": \"The histogram illustrates the frequency distribution of repeated expense claims, with a notable peak indicating 100 instances where claims have been repeatedly filed by the same user. This suggests a possible oversight or exploitation of the expense reporting system that warrants further investigation.\"\n",
    "    },\n",
    "    \"question\": \"How many instances of repeated identical expense claims are there?\",\n",
    "    \"actionable_insight\": {\n",
    "        \"description\": \"Given the significant number of repeated claims, it is crucial for the organization to undertake a thorough review of these incidents to confirm their legitimacy and to determine if they reflect a pattern of fraud or abuse. Enhancing monitoring mechanisms, such as implementing automated flags for duplicate entries and conducting regular audits, could help prevent such behaviors. Training sessions emphasizing ethical practices and the consequences of policy violations should also be conducted to reinforce the seriousness of such actions. If fraudulent activities are confirmed, appropriate disciplinary measures should be enforced to maintain the integrity of the expense management system.\"\n",
    "    }\n",
    "}\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 3:  Which users are involved in the frequent cases?**\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Plot repeated expense claims by user and category\n",
    "\n",
    "This plot visualizes repeated expense claims across various categories, highlighting users involved in frequent submissions. Each dot represents a unique combination of user, category, and expense amount, with the size of the dot proportional to the frequency of claims.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:16:15.237132Z",
     "iopub.status.busy": "2024-10-29T17:16:15.236195Z",
     "iopub.status.idle": "2024-10-29T17:16:15.683150Z",
     "shell.execute_reply": "2024-10-29T17:16:15.681537Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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4osvZv/995/QImlkZIR58+blXiCBRZIkqUTYkyQVj1/+Eioqinfh2KGhQX76059y4okvoqGhgd/97rfMmzefffbZh29/+9vsvffeLF68mJqaGo477jhmzpxJT083f/zjnxgYWE15eTkveMELaGho5LrrrqWiopL29nZWr+7n0EMP4xnPeAb9/X389re/Y2hoiJRGef7zj2THHXdk8eInWLToVtasWUN9fT1HH330P8zo9te//pVTTjmFyspKAKqqKtlllwVcdRVceulH+cUvfsHq1as54ogj+PrXv84VV1zBokWL+Od//mdmzpzJjTfeyL333sv5559Pb28vLS0tXHzxxey4447ccsstnHPOOZSVlfHCF76QX//619x9990MDAzw5je/mUWLFlFeXs5nP/tZjjnmGC6++GJ+8pOf0Nvby5o1a/jud7/LySefzN13382aNWt43/vex3XXXcfg4CBvfetbeeMb38iyZcs444wz6OnpYWRkhK9+9asceeSR2/U99J4kSVJJGBoayjuCpHFYtQquvRZaW/NOMj4jIyNcfvnl6x4PP/wwlZVVPO95z+e6667j4YcfYnBwiH322adw/DCtra288pWvZMcdd+TWW28F4A9/uIHnPe95vPzlr+Cwww7jj3/847rX6O/v59RTT+VFL3oxN9/8FwAeeughFixYwGmnncZpp51GS0szAwOrue22v3LSSSfxile8gtbWVu68886n5R0aGmJ4ePgf/nA0Z0523c86623ccsst3H333axevZpf/vKXnHbaaSxcuJD//d//5fbbb6e8vJy3v/3tXH755dx6662cffbZfPCDHwTg9a9/PV//+te5/fbbmTFjxrrzf/nLXyYiuOuuu7jkkks466yz1k2kcNttt3H55Zdz/fXXPy3TRRddxOzZs7nlllu45ZZb+OY3v8nf//53fvjDH3LiiSdy++23c8cdd3DQQQdth3fy6exJkiSVhC2Z1UhSfu66C0ZHKZp1ezY23G7BggU88sgj/PGPf1xvf/DMZz4TgD322INrrrmG4eFhli9/kt/85jfrjhodfWp9pl133ZWIoLGxkf7+1QC0ts7h+uuvY3R0lN1225Xm5haWLn2Mzs5Ofv7znxfOMcrcueNb/qC8PFuX6gc/uIMrr3wf/f39dHR0sN9++3HKKac87dj777+fu+++mxe+8IUArFmzhh133JGuri5WrVrF4YcfDsCrX/1qfvnLXwLwxz/+kbe//e0A7L333uyyyy488MADALzwhS/c4Dp211xzDXfeeee64Xfd3d08+OCDHHzwwZx99tkMDw/z0pe+1CJJkqSt5TpJUnH4wx+yoXbFLqVEV1cn5eXlDA4OUlu74Wn6IrJjKyurNnpv09gembV23HFHTjnlJTz++ONce+11HHjggVRVVbFgwXyOO+74jeaqrKykoqKcnp6ef+hNKi8f4ROfuIH77rucnXbaiQsuuGCDf2BKKbHffvtx4403Pm17V1fXRl93U2praze4PaXEl770JU488cR/2PeHP/yBq666ite97nWcf/75vPa1r92q194Yh9tJkkqC6yRJU9/wMNx0U35rI21Pd911Jw0NjRx77HFcd931Y3qGEn//+yNANmRuhx12oLKyklmzZvHIIw9nRxQWP92UVatWUVMzk3322Yd99tmbFStWMGfOHJ58cjnd3d0ADA8P093d9Q/PPeigZ/PHP/5x3TDk4eFhHnjgAWbNWsPw8EJmz26ht7f3aRMozJo1i1WrVgGw11570d7evq5IGh4e5p577qGhoYFZs2bxl79kQwIvvfTSdc8/8sgj+d///V8AHnjgAR5//HH22muvTbbxxBNP5Ktf/SrDw8PrntfX18djjz3G3LlzecMb3sC5557LbbfdtsnzbI0J7UmKiHcB5wIJuAt4fUppoLDvi8DZKaW6wvdVwPeA5wIrgTNSSo8W9r0fOAdYA7wjpXT1ROaWJE0/69+4LGnquf/+rFAqpn+ua+9JWmunnXZir7324m9/+xsve9nLqKioZMcdd+S22/7KwoULKS+voK2tndtuu42ZM2eu6/U57rhjueGGP3LbbX9ldHSUZz7zmTQ3N2/0dZctW8odd9xBWVkZFRUVHHPMMcycOZOjjz6a3/3ud+uKsoMPPpjZsxue9tx9992X4eFhfvrTn1BWVkZZWRkHHvgs6uqq2HnnZ7Dffi9n5517OPjgg9c953Wvex1vetOb1k3ccPnll/OOd7yD7u5uRkZGeOc738l+++3HRRddxBve8AbKyso46qijmD17NgBvectbePOb38wBBxxAeXk5F198MVVVVZu8tueeey6PPvooz3nOc0gp0drays9+9jOuu+46Pv3pT1NRUUFdXR3f+973tug9G49IKW33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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",
    "\n",
    "# Assume flag_data includes 'user', 'amount', 'category' columns\n",
    "# Group data by user, category, and amount to count frequencies\n",
    "grouped_data = flag_data.groupby(['user', 'category', 'amount']).size().reset_index(name='count')\n",
    "\n",
    "# Filter to only include cases with more than one claim (to highlight potential fraud)\n",
    "repeated_claims = grouped_data[grouped_data['count'] > 1]\n",
    "\n",
    "# Create a scatter plot with sizes proportional to the count of claims\n",
    "plt.figure(figsize=(14, 8))\n",
    "colors = {'Travel': 'blue', 'Meals': 'green', 'Accommodation': 'red', 'Miscellaneous': 'purple'}  # Add more categories as needed\n",
    "for ct in repeated_claims['category'].unique():\n",
    "    subset = repeated_claims[repeated_claims['category'] == ct]\n",
    "    plt.scatter(subset['user'], subset['amount'], s=subset['count'] * 100,  # Increased size factor for better visibility\n",
    "                color=colors.get(ct, 'gray'), label=f'Category: {ct}', alpha=0.6)\n",
    "\n",
    "# Customizing the plot\n",
    "plt.title('Repeated Expense Claims by User and Category')\n",
    "plt.xlabel('User')\n",
    "plt.ylabel('Amount ($)')\n",
    "plt.legend(title='Expense Categories')\n",
    "plt.xticks(rotation=45)  # Rotate x-axis labels for better readability\n",
    "plt.grid(True, which='both', linestyle='--', linewidth=0.5, alpha=0.7)\n",
    "\n",
    "# Highlighting significant cases\n",
    "# Let's annotate the specific user found in your description\n",
    "for i, row in repeated_claims.iterrows():\n",
    "    if row['user'] == 'Mamie Mcintee' and row['amount'] == 8000:\n",
    "        plt.annotate(f\"{row['user']} (${row['amount']})\", (row['user'], row['amount']),\n",
    "                     textcoords=\"offset points\", xytext=(0,10), ha='center', fontsize=9, color='darkred')\n",
    "\n",
    "# Show plot\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Generate JSON Description for the Insight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:16:15.700437Z",
     "iopub.status.busy": "2024-10-29T17:16:15.699622Z",
     "iopub.status.idle": "2024-10-29T17:16:15.723290Z",
     "shell.execute_reply": "2024-10-29T17:16:15.721701Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'diagnostic',\n",
       " 'insight': 'There is a significant repetition in expense claims by a single user',\n",
       " 'insight_value': {'description': 'A user named Mamie Mcintee has repeatedly submitted identical claims for $8000, suggesting potential issues of policy abuse or fraudulent behavior.'},\n",
       " 'plot': {'plot_type': 'scatter',\n",
       "  'title': 'Repeated Expense Claims by User and Category',\n",
       "  'x_axis': {'name': 'User',\n",
       "   'value': 'Unique user identifiers',\n",
       "   'description': 'This axis represents the users who have submitted expense claims.'},\n",
       "  'y_axis': {'name': 'Amount ($)',\n",
       "   'value': 'Amount of each expense claim',\n",
       "   'description': 'This axis displays the monetary amount of the claims, highlighting repeated identical submissions by certain users.'},\n",
       "  'description': 'The scatter plot visualizes the frequency and distribution of repeated expense claims, with emphasis on specific users like Mamie Mcintee who have submitted multiple identical claims. The use of different colors for categories and the annotations provide a clear visual indication of the problematic patterns that may require further investigation.'},\n",
       " 'question': 'Which users are involved in the frequent cases?',\n",
       " 'actionable_insight': {'description': 'The consistent pattern of repeated identical high-value claims by a particular user warrants a thorough investigation to determine the legitimacy of these submissions. The organization should review the related documents and approval processes involved with these claims. Enhanced monitoring mechanisms and possibly revising the expense submission guidelines or training could prevent such potentially abusive practices. If fraudulent activity is confirmed, appropriate disciplinary actions should be taken to deter such behavior and uphold the integrity of the expense management process.'}}"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"diagnostic\",\n",
    "    \"insight\": \"There is a significant repetition in expense claims by a single user\",\n",
    "    \"insight_value\": {\n",
    "        \"description\": \"A user named Mamie Mcintee has repeatedly submitted identical claims for $8000, suggesting potential issues of policy abuse or fraudulent behavior.\"\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"scatter\",\n",
    "        \"title\": \"Repeated Expense Claims by User and Category\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"User\",\n",
    "            \"value\": \"Unique user identifiers\",\n",
    "            \"description\": \"This axis represents the users who have submitted expense claims.\"\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Amount ($)\",\n",
    "            \"value\": \"Amount of each expense claim\",\n",
    "            \"description\": \"This axis displays the monetary amount of the claims, highlighting repeated identical submissions by certain users.\"\n",
    "        },\n",
    "        \"description\": \"The scatter plot visualizes the frequency and distribution of repeated expense claims, with emphasis on specific users like Mamie Mcintee who have submitted multiple identical claims. The use of different colors for categories and the annotations provide a clear visual indication of the problematic patterns that may require further investigation.\"\n",
    "    },\n",
    "    \"question\": \"Which users are involved in the frequent cases?\",\n",
    "    \"actionable_insight\": {\n",
    "        \"description\": \"The consistent pattern of repeated identical high-value claims by a particular user warrants a thorough investigation to determine the legitimacy of these submissions. The organization should review the related documents and approval processes involved with these claims. Enhanced monitoring mechanisms and possibly revising the expense submission guidelines or training could prevent such potentially abusive practices. If fraudulent activity is confirmed, appropriate disciplinary actions should be taken to deter such behavior and uphold the integrity of the expense management process.\"\n",
    "    }\n",
    "}\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 4:  What department and categories are most commonly involved in these repeated claims?**\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Plot distribution of expense claims by department and category for Mamie Mcintee\n",
    "\n",
    "This bar graph displays the distribution of Mamie Mcintee's expense claims across different departments and categories, illustrating the specific areas where repeated claims are most frequent. One color represents a different expense category, allowing for a clear view of which combinations are most problematic.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:16:15.738159Z",
     "iopub.status.busy": "2024-10-29T17:16:15.737545Z",
     "iopub.status.idle": "2024-10-29T17:16:16.120171Z",
     "shell.execute_reply": "2024-10-29T17:16:16.118546Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 864x504 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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EK2RmdkUYIFzbh//vd45l5tQ/pFzbhczWwBc55x7znd/Gviuc67P96TOnDnT6VWqQ+P448OOIFrGjatn/frcsMNIiksvfZtJk/bcotv06VksW7bldf+mpgZmzdqfW299lN1224P//u9TOPDAw5k9+yymT8/i5JPP4rnnniI/fyI333wveXnjqaxcwdVXn0dd3TpisUzmzv0dpaVl/PjHc8jOzmbx4sWsWbOG66+/nlmzZlFdXc3s2bNpbGykvb2dW2+9lUMOOYSnnnqKH/7wh2zatInS0lL+8Ic/kJWVtUV8xcXFLFy4kN12222rebzmmmt47LHH2LhxIwcffDC33XYbDz74IHPmzGHy5MmMGTOGF154gbfeeouLL76Y5uZm8vPzmTdvHoWFhSxatIgzzzyTtLQ0jjrqKJ588kneeOMN4vE455xzDosXLyY9PZ2bbrqJww47jHnz5vHQQw/R3NzM5s2bufPOOznuuON444032Lx5M5dddhkLFy5k06ZNnHfeeXzzm9/sdd67e/vtt9lzzy1/LzNb4pybua3rwI4u8qfQe1HTeWrc/1/ru68Cdk3or8h3E0lJJSVrwg5hWMXjGznhhOldf48/fh9jx+bwgx/8kssum8OCBffS2PgRs2efBUBLywb22WcmTzzxJvvv/3luueVqAK644myuvPIWHn54CZdddgNXX31u1zSqq6t57rnnWLBgAZddFtw+8+c//5mjjz6aZcuW8eqrrzJ9+nRqa2uZO3cuf//731m6dCkzZ87kpptu2iLexsZGmpqaekzeAOeffz6LFi3ijTfeYOPGjSxYsIBZs2Yxc+ZM7r77bpYtW0Z6ejoXXHAB8+fPZ8mSJZxxxhl8//vfB+D000/ntttuY9myZYwaNaprvL/61a8wM15//XXuueceTjvttK67xJcuXcr8+fN59tlnt4jl9ttvJycnh0WLFrFo0SJ+97vfsXLlyh7nXYbHjnoK/VHgNOA6//+RhO7nm9m9wAFAQ8KpdpGUU1U1IewQhlUsNoZHH122VffPfvYonnzyAa655jweffTVru5paWkcc8xsAE444aucf/5/smFDM6+88jzf/vaXu/prbd3U9fmkk04iLS2Nvfbai5qaGgD2228/zjjjDNra2jjppJOYPn06zz77LG+99Raf/exn/ThaOeiggwY1P8888wzXX389LS0t1NXVsffee3N8t9NU77zzDm+88QZHHXUUAJs3b6awsJD6+nqampq6pnnqqaeyYMECAJ577jkuuOACAMrKyigpKWH58uUAHHXUUeTl5W0Vy1NPPcVrr73G/PnzAWhoaODdd9/tcd5leEQ+gZvZPcChQL6ZVQE/JEjc95vZmUAFcLLv/QngGOA9oAU4fdgDFhlCOTnNrF279c54R9PR0cGKFW8Ti2XS0PAREycW9difmeFcB9nZuT0eCADstNNOXZ87L0F+7nOf4x//+AePP/44c+bM4eKLL2aXXXbhqKOO4p577uk1ruzsbLKysnj//fe3qoXH43HOPfdcFi9ezK677spVV13V47PUzjn23ntvXnjhhS2619fX9zrdvuy88849dnfOccstt3D00UdvVdZ93r/+9a9v07RlcCJ/Ct05d4pzrtA5l+GcK3LO3e6cW++cO8I5t7tz7kjnXJ3v1znnznPOlTrnPtnftW+RkW7s2JawQxgR/vCHn1Fauic33vhnvve902lrawOCxP7XvwY1ygUL/sxnPvNvZGVlU1Q0lSeffAAIEtfbb7/a67ghuNu/oKCAs846i2984xssXbqUAw88kH/961+89957AGzYsKGrlpvoe9/7Hueddx6NjY1A8Oz+XXfd1ZWs8/PzaW5u7qr5AowdO5ampiYA9thjD9atW9eVwNva2njzzTfJzc1l7NixvPTSSwDce++9XcMfcsgh3H333QAsX76cyspK9thjjz7n8eijj+bWW2/tWnbLly9nw4YNPc67DI/I18BFdmTl5TvWc+Cd18A7HXLIv/OlL53OAw/8nvnzXyYraywzZ36OX/96LhdeeDWZmTvz2msvc+utcxk3bgI333wfADfccDdXXXUOv/71XNrb2zj22P9izz0/1et0Fy5cyE9/+lMyMjLIysrirrvuYvz48cybN49TTjmFTZuCU/Bz585l2rRpWwx7zjnn0NzczH777UdGRgYZGRlccskl5ObmctZZZ7HPPvswceJE9ttvv65h5syZw7e+9a2um9jmz5/Pt7/9bRoaGmhvb+eiiy5i77335vbbb+ess84iLS2Nz3/+8+Tk5ABw7rnncs455/DJT36S9PR05s2bt8WZhZ584xvf4IMPPmDGjBk45xg/fjx/+ctfepx3GR47xF3oyaa70IeO7kIfWjNmlLN0aVnYYSRFT3eh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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "\n",
    "# Assuming 'flag_data' includes 'user', 'department', 'amount', 'category' columns\n",
    "# and it's already loaded with the data\n",
    "\n",
    "# Filter for the specific user\n",
    "user_data = flag_data[flag_data['user'] == 'Mamie Mcintee']\n",
    "\n",
    "# Group data by department and category to count frequencies\n",
    "department_category_counts = user_data.groupby(['department', 'category']).size().unstack(fill_value=0)\n",
    "\n",
    "# Plotting\n",
    "plt.figure(figsize=(12, 7))\n",
    "department_category_counts.plot(kind='bar', stacked=True, color=['blue', 'green', 'red', 'purple', 'orange'], alpha=0.7)\n",
    "plt.title('Distribution of Expense Claims by Department and Category for Mamie Mcintee')\n",
    "plt.xlabel('Department')\n",
    "plt.ylabel('Number of Claims')\n",
    "plt.xticks(rotation=0)  # Keep the department names horizontal for better readability\n",
    "plt.legend(title='Expense Categories')\n",
    "plt.grid(True, which='both', linestyle='--', linewidth=0.5)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Generate JSON Description for the Insight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:16:16.137518Z",
     "iopub.status.busy": "2024-10-29T17:16:16.136934Z",
     "iopub.status.idle": "2024-10-29T17:16:16.158569Z",
     "shell.execute_reply": "2024-10-29T17:16:16.156546Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'Descriptive',\n",
       " 'insight': 'There is a concentration of repeated claims in the Travel category',\n",
       " 'insight_value': {'description': 'Mamie Mcintee’s repeated identical expense claims are not only submitted under her department but are specifically concentrated in the Travel category, raising concerns about potential policy abuse or fraudulent activities within this particular expense category.'},\n",
       " 'plot': {'plot_type': 'bar',\n",
       "  'title': 'Expense Claims by Department and Category for Mamie Mcintee',\n",
       "  'x_axis': {'name': 'Department',\n",
       "   'value': 'Identified department(s)',\n",
       "   'description': 'This axis displays the department under which Mamie Mcintee has submitted her claims, with a focus on the Travel category.'},\n",
       "  'y_axis': {'name': 'Number of Claims',\n",
       "   'value': 'Total claims segmented by category, highlighting Travel',\n",
       "   'description': 'This axis counts the claims, specifically highlighting the frequency of claims within the Travel category, demonstrating a significant focus in this area.'},\n",
       "  'description': \"The stacked bar chart clearly illustrates that Mamie Mcintee's repeated expense claims are primarily within the Travel category. This specific concentration suggests a pattern that may require further investigation to ensure these claims are legitimate and within company policies.\"},\n",
       " 'question': 'Confirm that these expenses are submitted under the department?',\n",
       " 'actionable_insight': {'description': 'Given the concentration of repeated claims in the Travel category, it is advisable for the organization to conduct an in-depth review of all Travel-related expense submissions by Mamie Mcintee. This review should include verifying the authenticity of the claims and assessing compliance with the travel expense policies. Implementing more stringent controls and possibly providing additional training on appropriate expense reporting for travel could help mitigate the risk of fraud and ensure that such patterns do not indicate policy abuse. Regular audits and real-time monitoring of expense submissions in high-risk categories like Travel are also recommended to maintain the integrity of the expense management system.'}}"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"Descriptive\",\n",
    "    \"insight\": \"There is a concentration of repeated claims in the Travel category\",\n",
    "    \"insight_value\": {\n",
    "        \"description\": \"Mamie Mcintee’s repeated identical expense claims are not only submitted under her department but are specifically concentrated in the Travel category, raising concerns about potential policy abuse or fraudulent activities within this particular expense category.\"\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"bar\",\n",
    "        \"title\": \"Expense Claims by Department and Category for Mamie Mcintee\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Department\",\n",
    "            \"value\": \"Identified department(s)\",\n",
    "            \"description\": \"This axis displays the department under which Mamie Mcintee has submitted her claims, with a focus on the Travel category.\"\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Number of Claims\",\n",
    "            \"value\": \"Total claims segmented by category, highlighting Travel\",\n",
    "            \"description\": \"This axis counts the claims, specifically highlighting the frequency of claims within the Travel category, demonstrating a significant focus in this area.\"\n",
    "        },\n",
    "        \"description\": \"The stacked bar chart clearly illustrates that Mamie Mcintee's repeated expense claims are primarily within the Travel category. This specific concentration suggests a pattern that may require further investigation to ensure these claims are legitimate and within company policies.\"\n",
    "    },\n",
    "    \"question\": \"Confirm that these expenses are submitted under the department?\",\n",
    "    \"actionable_insight\": {\n",
    "        \"description\": \"Given the concentration of repeated claims in the Travel category, it is advisable for the organization to conduct an in-depth review of all Travel-related expense submissions by Mamie Mcintee. This review should include verifying the authenticity of the claims and assessing compliance with the travel expense policies. Implementing more stringent controls and possibly providing additional training on appropriate expense reporting for travel could help mitigate the risk of fraud and ensure that such patterns do not indicate policy abuse. Regular audits and real-time monitoring of expense submissions in high-risk categories like Travel are also recommended to maintain the integrity of the expense management system.\"\n",
    "    }\n",
    "}\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Summary of Findings (Flag 70):\n",
    "\n",
    "1. **Processing Delays Across Departments**: From Question 1, it was found that processing delays vary significantly across departments. IT processes requests the fastest, while Finance shows the longest delays, indicating potential inefficiencies in Finance's workflow.\n",
    "\n",
    "2. **Repeated Identical Claims**: Question 2 highlighted a high incidence of repeated identical expense claims, with 100 instances where a single user submitted identical claims more than three times. This suggests potential fraud or policy abuse.\n",
    "\n",
    "3. **User-Specific Anomalies**: Question 3 revealed that a user named Mamie Mcintee has repeatedly submitted identical claims for $8000, particularly in the Travel category. This pattern suggests possible policy abuse or fraudulent behavior that requires further investigation."
   ]
  }
 ],
 "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
}
