{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Goal Management Analysis Category Focus (Flag 76)\n",
    "\n",
    "### Dataset Description\n",
    "The dataset consists of 500 entries simulating ServiceNow `sn_gf_goal` table, which details various attributes related to organizational goals. These attributes include goal state, owner, department, start and end dates, and description, alongside metrics such as priority, percent complete, and target percentage. This data primarily tracks the progression and management of departmental and individual goals, offering insights into the effectiveness and alignment of these goals with broader organizational objectives. Additionally, the table captures updates made to each goal, providing a timeline of modifications and the identity of individuals making these updates.\n",
    "\n",
    "### Your Task\n",
    "**Goal**: Analyze any unexpected high success rates of Low and Medium priority 'Cost Reduction' goals and apply these insights to enhance goal management effectiveness across all goal categories.\n",
    "\n",
    "**Role**: Operational Efficiency Analyst\n",
    "\n",
    "**Difficulty**: 2 out of 5. The analysis requires sophisticated data manipulation and interpretation skills to uncover underlying patterns and propose actionable strategies, representing a challenging yet insightful endeavor.\n",
    "\n",
    "**Category**: Goal Management"
   ]
  },
  {
   "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": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:17:17.156346Z",
     "iopub.status.busy": "2024-10-29T17:17:17.154640Z",
     "iopub.status.idle": "2024-10-29T17:17:20.660495Z",
     "shell.execute_reply": "2024-10-29T17:17:20.658448Z"
    }
   },
   "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 dataset used for the analysis. The goal dataset is stored in a CSV file and is loaded into a DataFrame. This step includes reading the data from a file path and possibly performing initial observations such as viewing the first few rows to ensure it has loaded correctly.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:17:20.676631Z",
     "iopub.status.busy": "2024-10-29T17:17:20.675239Z",
     "iopub.status.idle": "2024-10-29T17:17:20.751260Z",
     "shell.execute_reply": "2024-10-29T17:17:20.749661Z"
    }
   },
   "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>department</th>\n",
       "      <th>state</th>\n",
       "      <th>percent_complete</th>\n",
       "      <th>priority</th>\n",
       "      <th>target_percentage</th>\n",
       "      <th>category</th>\n",
       "      <th>sys_id</th>\n",
       "      <th>sys_updated_by</th>\n",
       "      <th>metric</th>\n",
       "      <th>end_date</th>\n",
       "      <th>start_date</th>\n",
       "      <th>owner</th>\n",
       "      <th>description</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>IT</td>\n",
       "      <td>Completed</td>\n",
       "      <td>95</td>\n",
       "      <td>Medium</td>\n",
       "      <td>93</td>\n",
       "      <td>Cost Reduction</td>\n",
       "      <td>G000000</td>\n",
       "      <td>admin</td>\n",
       "      <td>Expense Ratio</td>\n",
       "      <td>2022-12-25</td>\n",
       "      <td>2022-10-06</td>\n",
       "      <td>Ross Spurger</td>\n",
       "      <td>Reduce overall software licensing costs by neg...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>HR</td>\n",
       "      <td>Completed</td>\n",
       "      <td>82</td>\n",
       "      <td>Medium</td>\n",
       "      <td>80</td>\n",
       "      <td>Efficiency</td>\n",
       "      <td>G000001</td>\n",
       "      <td>admin</td>\n",
       "      <td>Survey Score</td>\n",
       "      <td>2023-05-03</td>\n",
       "      <td>2022-08-11</td>\n",
       "      <td>Denice Nordlinger</td>\n",
       "      <td>Optimize IT support workflows to achieve a 20%...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Finance</td>\n",
       "      <td>Completed</td>\n",
       "      <td>61</td>\n",
       "      <td>High</td>\n",
       "      <td>59</td>\n",
       "      <td>Customer Satisfaction</td>\n",
       "      <td>G000002</td>\n",
       "      <td>admin</td>\n",
       "      <td>Expense Ratio</td>\n",
       "      <td>2023-02-26</td>\n",
       "      <td>2022-02-16</td>\n",
       "      <td>Cristopher Wiget</td>\n",
       "      <td>Develop and implement a new customer feedback ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Marketing</td>\n",
       "      <td>In Progress</td>\n",
       "      <td>82</td>\n",
       "      <td>Low</td>\n",
       "      <td>92</td>\n",
       "      <td>Employee Satisfaction</td>\n",
       "      <td>G000003</td>\n",
       "      <td>admin</td>\n",
       "      <td>Expense Ratio</td>\n",
       "      <td>2022-10-31</td>\n",
       "      <td>2022-04-12</td>\n",
       "      <td>Logan Muhl</td>\n",
       "      <td>Develop and implement a quarterly employee fee...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>IT</td>\n",
       "      <td>Completed</td>\n",
       "      <td>52</td>\n",
       "      <td>High</td>\n",
       "      <td>52</td>\n",
       "      <td>Employee Satisfaction</td>\n",
       "      <td>G000004</td>\n",
       "      <td>admin</td>\n",
       "      <td>Expense Ratio</td>\n",
       "      <td>2022-06-04</td>\n",
       "      <td>2022-03-11</td>\n",
       "      <td>Eva Seahorn</td>\n",
       "      <td>Increase the annual employee satisfaction scor...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  department        state  percent_complete priority  target_percentage  \\\n",
       "0         IT    Completed                95   Medium                 93   \n",
       "1         HR    Completed                82   Medium                 80   \n",
       "2    Finance    Completed                61     High                 59   \n",
       "3  Marketing  In Progress                82      Low                 92   \n",
       "4         IT    Completed                52     High                 52   \n",
       "\n",
       "                category   sys_id sys_updated_by         metric    end_date  \\\n",
       "0         Cost Reduction  G000000          admin  Expense Ratio  2022-12-25   \n",
       "1             Efficiency  G000001          admin   Survey Score  2023-05-03   \n",
       "2  Customer Satisfaction  G000002          admin  Expense Ratio  2023-02-26   \n",
       "3  Employee Satisfaction  G000003          admin  Expense Ratio  2022-10-31   \n",
       "4  Employee Satisfaction  G000004          admin  Expense Ratio  2022-06-04   \n",
       "\n",
       "   start_date              owner  \\\n",
       "0  2022-10-06       Ross Spurger   \n",
       "1  2022-08-11  Denice Nordlinger   \n",
       "2  2022-02-16   Cristopher Wiget   \n",
       "3  2022-04-12         Logan Muhl   \n",
       "4  2022-03-11        Eva Seahorn   \n",
       "\n",
       "                                         description  \n",
       "0  Reduce overall software licensing costs by neg...  \n",
       "1  Optimize IT support workflows to achieve a 20%...  \n",
       "2  Develop and implement a new customer feedback ...  \n",
       "3  Develop and implement a quarterly employee fee...  \n",
       "4  Increase the annual employee satisfaction scor...  "
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_path = \"csvs/flag-76.csv\"\n",
    "goal_data = pd.read_csv(dataset_path)\n",
    "df = pd.read_csv(dataset_path)\n",
    "goal_data.head()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 1: How does project priority impact the average completion rate across different departments?**\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Analyze the Average Completion Rate by Priority Level per Department\n",
    "This visualization examines the relationship between project priority levels and the average completion rate across various departments. By observing these differences, we can understand which priority levels correlate with higher or lower average completion rates and assess how effectively departments handle projects of varying importance."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:17:20.769134Z",
     "iopub.status.busy": "2024-10-29T17:17:20.768374Z",
     "iopub.status.idle": "2024-10-29T17:17:21.350310Z",
     "shell.execute_reply": "2024-10-29T17:17:21.348625Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 864x576 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Load the data\n",
    "flag_data = pd.read_csv(\"csvs/flag-76.csv\")\n",
    "\n",
    "# Calculate the average completion rate grouped by department and priority\n",
    "avg_completion_by_priority = (\n",
    "    flag_data.groupby([\"department\", \"priority\"])[\"percent_complete\"].mean().unstack()\n",
    ")\n",
    "\n",
    "# Plotting the results\n",
    "plt.figure(figsize=(12, 8))\n",
    "avg_completion_by_priority.plot(\n",
    "    kind=\"bar\", stacked=True, alpha=0.7, width=0.7, edgecolor=\"black\"\n",
    ")\n",
    "plt.title(\"Average Completion Rate by Project Priority Across Departments\")\n",
    "plt.xlabel(\"Department\")\n",
    "plt.ylabel(\"Average Completion Rate (%)\")\n",
    "plt.legend(title=\"Priority\")\n",
    "plt.xticks(rotation=45)\n",
    "plt.grid(axis=\"y\", linestyle=\"--\", alpha=0.7)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Generate JSON Description for the Insight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:17:21.367377Z",
     "iopub.status.busy": "2024-10-29T17:17:21.366648Z",
     "iopub.status.idle": "2024-10-29T17:17:21.394517Z",
     "shell.execute_reply": "2024-10-29T17:17:21.392812Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'comparative',\n",
       " 'insight': 'Higher priority levels tend to have lower average completion rates across all departments.',\n",
       " 'insight_value': {'description': \"Projects with 'Critical' and 'High' priorities consistently show lower average completion rates compared to 'Low' and 'Medium' priorities across all departments, which suggests that the urgency or complexity associated with higher priorities might impact their progress rates.\"},\n",
       " 'plot': {'plot_type': 'stacked bar',\n",
       "  'title': 'Average Completion Rate by Project Priority Across Departments',\n",
       "  'x_axis': {'name': 'Department',\n",
       "   'value': 'Departments including Finance, HR, IT, and Marketing',\n",
       "   'description': 'This axis represents different departments within the organization.'},\n",
       "  'y_axis': {'name': 'Average Completion Rate (%)',\n",
       "   'value': 'Average completion rate of projects across priority levels',\n",
       "   'description': 'This axis represents the average completion rate as a percentage, grouped by priority level.'},\n",
       "  'description': \"The stacked bar plot shows that 'Medium' and 'Low' priority projects generally have higher completion rates, whereas 'Critical' and 'High' priority projects are often associated with lower completion rates across all departments. This may reflect additional complexities or resource limitations in addressing high-priority projects effectively.\"},\n",
       " 'question': 'How does project priority impact the average completion rate across different departments?',\n",
       " 'actionable_insight': 'To enhance efficiency, departments might consider strategies to better support high-priority projects, such as allocating additional resources or setting more realistic timelines. Regular monitoring and dedicated task force teams could be instrumental in increasing the completion rates of these essential projects.'}"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"comparative\",\n",
    "    \"insight\": \"Higher priority levels tend to have lower average completion rates across all departments.\",\n",
    "    \"insight_value\": {\n",
    "        \"description\": \"Projects with 'Critical' and 'High' priorities consistently show lower average completion rates compared to 'Low' and 'Medium' priorities across all departments, which suggests that the urgency or complexity associated with higher priorities might impact their progress rates.\"\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"stacked bar\",\n",
    "        \"title\": \"Average Completion Rate by Project Priority Across Departments\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Department\",\n",
    "            \"value\": \"Departments including Finance, HR, IT, and Marketing\",\n",
    "            \"description\": \"This axis represents different departments within the organization.\",\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Average Completion Rate (%)\",\n",
    "            \"value\": \"Average completion rate of projects across priority levels\",\n",
    "            \"description\": \"This axis represents the average completion rate as a percentage, grouped by priority level.\",\n",
    "        },\n",
    "        \"description\": \"The stacked bar plot shows that 'Medium' and 'Low' priority projects generally have higher completion rates, whereas 'Critical' and 'High' priority projects are often associated with lower completion rates across all departments. This may reflect additional complexities or resource limitations in addressing high-priority projects effectively.\",\n",
    "    },\n",
    "    \"question\": \"How does project priority impact the average completion rate across different departments?\",\n",
    "    \"actionable_insight\": \"To enhance efficiency, departments might consider strategies to better support high-priority projects, such as allocating additional resources or setting more realistic timelines. Regular monitoring and dedicated task force teams could be instrumental in increasing the completion rates of these essential projects.\",\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 2:** How are 'Cost Reduction' goals distributed by priority compared to goals in other categories?"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Plot proportion of successful goals by priority in Cost Reduction category\n",
    "\n",
    "This bar plot depicts the success rates of goals within the Cost Reduction category, categorized by their priority levels: Critical, High, Medium, and Low. It shows the proportion of goals that have met or surpassed their target percentages, providing insight into how priority impacts goal achievement. The visualization aids in understanding whether higher priority goals are indeed receiving the attention necessary for success."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:17:21.414306Z",
     "iopub.status.busy": "2024-10-29T17:17:21.412605Z",
     "iopub.status.idle": "2024-10-29T17:17:21.863550Z",
     "shell.execute_reply": "2024-10-29T17:17:21.861307Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-6-259cf6dcca39>:8: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  it_goals['is_successful'] = it_goals['percent_complete'] >= it_goals['target_percentage']\n"
     ]
    },
    {
     "data": {
      "image/png": "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YPfdd2e77bbj/PPPB2CttdZi7NixbLvttmy00Ub079+fu+++m49+9KN1Wgup+fRpdACSpPracsstmThxIrvvvjtrrLEGI0eOpHfv3jVPf/vttzNo0CCef/55dtttN9773veyyy67cNxxx3HccccBcPjhh3PyySfz05/+lBtvvJERI0bwzW9+s16rJDUFa8IkqQc47LDDuPfee7n11ltZZ5112HzzzWuedtCgQQBsuOGGfOxjH2Pq1KlLjL///vvJTLbYYguuuOIKfv3rX/PEE0/w+OOPr9B1kJqNSZgk9QDPP/88AH/961+56qqrOOigg2qa7vXXX+fVV19d3H3jjTcyfPjwJcqceOKJnHLKKbz11lssXLgQKNqMtbS0rMA1kJqPSZgk9QD77rsvW221FR/5yEc455xzGDBgAFdffTWDBw/mzjvvZO+992aPPfYA4Nlnn2Xs2LEAPPfcc+y0005ss8027LDDDuy9997sueeei+d7zTXXMHr0aAYOHMiAAQMYOXIkW2+9NW+88QbbbLNNQ9ZVWllEZjY6hqUyevTorPY8G0mSpO4iIu7NzNHtjbMmTJIkqQFMwiRJkhrAJEySJKkBTMIkSZIawIe1StJy2O5rlzQ6BC2He79/SOeFpDqxJkySJC32wx/+kGHDhjF8+HAOPPBA3njjDXbeeWdGjhzJyJEjGThwYLuvp3rmmWcYNWoUI0eOZNiwYZx33nkAzJ8/nz333JPhw4dz7rnnLi5/5JFHct9993XVanVL1oRJkiQA5syZw9lnn82MGTNYbbXV2G+//Zg0aRK33Xbb4jL77rsv48ePf9u0G220EXfeeSerrroqr732GsOHD2fcuHFMmzaNnXbaieOPP54dd9yRz3/+8zz44IMsXLiQUaNGdeXqdTsmYZIkabEFCxYwb948+vbtS0tLCwMHDlw87pVXXuHmm2/moosuett0q6yyyuLu+fPns2jRIoDF83nrrbdofTbpiSeeuLimrCfzcqQkSQKK94Qee+yxbLzxxmy00Ub079+f3XffffH4a665hg996EOsvfba7U4/a9YsRowYwZAhQ5g4cSIDBw5kt9124+mnn+Z973sfX/rSl5g8eTKjRo1aIrnrqUzCJEkSAC+++CLXXnstTz31FM8++yyvv/46l1566eLxl19+OQceeGCH0w8ZMoTp06czc+ZMLr74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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 seaborn as sns\n",
    "\n",
    "# Filter the data for the IT department\n",
    "it_goals = goal_data[goal_data['category'] == 'Cost Reduction']\n",
    "\n",
    "# Define successful goals (assuming successful means percent_complete >= target_percentage)\n",
    "it_goals['is_successful'] = it_goals['percent_complete'] >= it_goals['target_percentage']\n",
    "\n",
    "# Calculate the proportion of successful goals by priority\n",
    "success_rates = it_goals.groupby('priority')['is_successful'].mean()\n",
    "\n",
    "# Convert the series to a DataFrame for plotting\n",
    "success_rates_df = success_rates.reset_index()\n",
    "\n",
    "# Plotting\n",
    "plt.figure(figsize=(10, 6))\n",
    "bar_plot = sns.barplot(x='priority', y='is_successful', data=success_rates_df, order=['Critical', 'High', 'Medium', 'Low'])\n",
    "plt.title('Proportion of Successful Goals by Priority in Cost reduction Category')\n",
    "plt.xlabel('Priority')\n",
    "plt.ylabel('Proportion of Successful Goals')\n",
    "plt.ylim(0, 1)  # Set the limit to show proportions from 0 to 1\n",
    "for p in bar_plot.patches:\n",
    "    bar_plot.annotate(format(p.get_height(), '.1%'),  # Format as a percentage with one decimal\n",
    "                      (p.get_x() + p.get_width() / 2., p.get_height()),\n",
    "                      ha='center', va='center', \n",
    "                      xytext=(0, 9), \n",
    "                      textcoords='offset points')\n",
    "plt.show()\n"
   ]
  },
  {
   "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:17:21.879858Z",
     "iopub.status.busy": "2024-10-29T17:17:21.878710Z",
     "iopub.status.idle": "2024-10-29T17:17:21.901663Z",
     "shell.execute_reply": "2024-10-29T17:17:21.899651Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'descriptive',\n",
       " 'insight': \"Unusually high success rates for low and medium priority 'Cost Reduction' goals compared to High and Critical\",\n",
       " 'insight_value': {'Low': '87.3%',\n",
       "  'Medium': '91.5%',\n",
       "  'High': '40.0%',\n",
       "  'Critical': '0.0%'},\n",
       " 'plot': {'plot_type': 'bar',\n",
       "  'title': \"Success Rates of 'Cost Reduction' Goals by Priority\",\n",
       "  'x_axis': {'name': 'Priority Level',\n",
       "   'value': 'Low, Medium, High, Critical',\n",
       "   'description': \"This axis categorizes goals by their assigned priority levels within the 'Cost Reduction' category.\"},\n",
       "  'y_axis': {'name': 'Percentage of Goals Successfully Met',\n",
       "   'value': '87.3%, 91.5%, 40.0%, 0.0%',\n",
       "   'description': 'This axis shows the success rates of goals within each priority level, highlighting an unusual trend where lower priorities have higher success rates.'},\n",
       "  'description': \"The bar graph demonstrates that 'Cost Reduction' goals classified as Low and Medium priority exhibit significantly higher success rates of 87.3% and 91.5%, respectively, compared to High and Critical priorities which show much lower success rates at 40.0% and 0.0%. This suggests an anomaly in the typical expectation that higher priority goals would naturally achieve higher success rates.\"},\n",
       " 'question': \"How are 'Cost Reduction' goals distributed by priority compared to goals in other categories?\",\n",
       " 'actionable_insight': \"This unusual distribution of success by priority in the 'Cost Reduction' category may indicate that if this trend continues across other categories, the perceived importance of priority levels may need reassessment. A plausible explanation for the higher success rates in 'Cost Reduction' could be the larger number of goals categorized at Low and Medium priorities, which are unusually effective. Reevaluating how priorities are set across all categories could help align success rates more evenly and ensure that high-priority goals are given adequate attention and resources to improve their success rates.\"}"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"descriptive\",\n",
    "    \"insight\": \"Unusually high success rates for low and medium priority 'Cost Reduction' goals compared to High and Critical\",\n",
    "    \"insight_value\": {\n",
    "        \"Low\": \"87.3%\",\n",
    "        \"Medium\": \"91.5%\",\n",
    "        \"High\": \"40.0%\",\n",
    "        \"Critical\": \"0.0%\"\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"bar\",\n",
    "        \"title\": \"Success Rates of 'Cost Reduction' Goals by Priority\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Priority Level\",\n",
    "            \"value\": \"Low, Medium, High, Critical\",\n",
    "            \"description\": \"This axis categorizes goals by their assigned priority levels within the 'Cost Reduction' category.\"\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Percentage of Goals Successfully Met\",\n",
    "            \"value\": \"87.3%, 91.5%, 40.0%, 0.0%\",\n",
    "            \"description\": \"This axis shows the success rates of goals within each priority level, highlighting an unusual trend where lower priorities have higher success rates.\"\n",
    "        },\n",
    "        \"description\": \"The bar graph demonstrates that 'Cost Reduction' goals classified as Low and Medium priority exhibit significantly higher success rates of 87.3% and 91.5%, respectively, compared to High and Critical priorities which show much lower success rates at 40.0% and 0.0%. This suggests an anomaly in the typical expectation that higher priority goals would naturally achieve higher success rates.\"\n",
    "    },\n",
    "    \"question\": \"How are 'Cost Reduction' goals distributed by priority compared to goals in other categories?\",\n",
    "    \"actionable_insight\": \"This unusual distribution of success by priority in the 'Cost Reduction' category may indicate that if this trend continues across other categories, the perceived importance of priority levels may need reassessment. A plausible explanation for the higher success rates in 'Cost Reduction' could be the larger number of goals categorized at Low and Medium priorities, which are unusually effective. Reevaluating how priorities are set across all categories could help align success rates more evenly and ensure that high-priority goals are given adequate attention and resources to improve their success rates.\"\n",
    "}\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 3:** Is this unusual trend of low and medium priority goals seen in the Cost Reduction category also observed across other categories??"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Plot proportion of successful goals by priority across categories\n",
    "\n",
    "This bar plot provides a comparative analysis of the success rates of goals by priority levels (Critical, High, Medium, Low) across different category of goals. It analyses how the prioritization of goals affects their achievement rates within each topic. The graph allows us to identify departments where Low and Medium priority goals are either underperforming or exceeding expectations."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:17:21.918873Z",
     "iopub.status.busy": "2024-10-29T17:17:21.917747Z",
     "iopub.status.idle": "2024-10-29T17:17:22.897834Z",
     "shell.execute_reply": "2024-10-29T17:17:22.895874Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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VVVVHHPMMey1114AdO/eHcgGGBgxYgR77703++yzD7fddhtAk+ucf/75PPTQQ/Tr14+f/exnDB48mBkzZtTt98ADD2TmzJlt+EwlSZKk9q1djAJXTCtXruSee+7h8MMPB2D69OnMnj17tVHU/vSnPzFjxgxmzpzJm2++yf7778/gwYObXOfyyy/nqquu4q677gKgsrKSMWPGcM011/Dcc8+xbNky+vbt2wbPUpIkSSoPtgA14r333qNfv37079+fHXbYgTPPPBOAAw44oMEhpCdPnszJJ59Mx44d+chHPsKQIUN49NFHm1xnVSeccAJ33XUXK1as4De/+Q1Dhw5t1eckSZIklTtbgBpRew3QqjbZZJM13lZL19l444057LDD+Otf/8rtt9/OY489tsb7kiRJktQ4W4BaSVVVFbfddhvvv/8+b7zxBpMmTeKAAw5ocp0ePXqwdOnSevO+9KUvMXz4cPbff38qKiqKGbIkSZJUdkyAWslxxx1Hnz596Nu3LwcffDA/+clP2HrrrZtcp0+fPnTs2JG+ffvys5/9DID99tuPTTfdlDPOOKMtwpYkSZLKSqSUSh3DGunfv3+aNm1avXlPP/00e+65Z4kial0vv/wy1dXVPPPMM3ToUJz8tD29XpIkSe3ZoNGDSrbvH99R2qtlhkyauNbrRsRjKaX+DZXZArQeuemmmxgwYAA/+tGPipb8SJIkSeXMQRDWI6eddhqnnXZaqcOQJEmS2i2bGSRJkiSVDRMgSZIkSWXDBEiSJElS2TABkiRJklQ2TIBa0auvvspJJ53EzjvvzH777ceRRx7Jc889t9pyAwcOBGDOnDn8/ve/r5s/bdo0hg8fvlb7rq6uZtXhwSVJkiTV1y5HgdtvxE2tur3Hrmx+ZLaUEscddxynn346t956KwAzZ87ktddeY7fddgNg5cqVbLTRRjz88MPAhwnQF77wBQD69+9P//4NDlcuSZIkqRXYAtRKHnzwQTp16sTZZ59dN69v3768//77VFVVccwxx7DXXnsB0L17dwDOP/98HnroIfr168fPfvYzJkyYwNFHHw3A22+/zRlnnME+++xDnz59+OMf/wjAV7/6Vfr370/v3r35/ve/38bPUpIkSdqwtcsWoFKYPXs2++23X4Nl06dPZ/bs2fTq1ave/Msvv5yrrrqKu+66C4AJEybUlf3gBz9gs80244knngBg0aJFAPzoRz+isrKS999/n0MOOYRZs2bRp0+fIjwjSZIkqf2xBagNHHDAAaslP825//77Oeecc+qmKyoqALj99tvZd999+fjHP86TTz7JU089tc7xjRkzhoEDBzJo0CCmT59er+y1117j8MMP56CDDuL0009n+fLlAPz85z9nt912Y5dddlnn/UuSJEltxQSolfTu3ZvHHnuswbJNNtmkVfbx4osvctVVV/GPf/yDWbNmcdRRR7Fs2bJ12uaiRYsYNWoUEyZMYOzYsasNwnDZZZcxdOhQHnzwQfbaay9uuim7vuqzn/0sTz755DrtW5IkSWprJkCt5OCDD2b58uVcd911dfNmzZrFQw891Og6PXr0YOnSpQ2WHXbYYVx77bV104sWLeKtt95ik002YbPNNuO1117jnnvuWee4p06dSlVVFZ07d6ZXr14sXbq0rpUH4LnnnqsbmOGAAw7gwQcfBOAjH/kInTp1Wuf9S5IkSW3JBKiVRAR//vOfuf/++9l5553p3bs33/3ud9l6660bXadPnz507NiRvn378rOf/axe2YUXXsiiRYvYe++96du3Lw8++CB9+/bl4x//OHvssQdf+MIXGDRo0DrHvWDBgrrudQA9e/Zk4cKFddP77LMP9957LwDjxo2rVyZJkiRtaNrlIAgtGba6GLbddltuv/321eafddZZ9abffvttADp16sQDDzxQr6y6uhrIRoq78cYbV9vWmDFjGtx34QAKa6KyspLFixfXTS9ZsoTKysq66QsuuICvfe1r/OlPf6Jv375su+22a7UfSZIkaX1gC1CZGzBgAJMnT2bFihXMnTuX7t2706VLl7ryzTbbjJtvvpkHHniAbt268bnPfa6E0UqSJEnrxgSozFVUVDBs2DCGDBnCySefzDXXXMOMGTO48sorAXjggQc46KCDOOSQQ+jevTtHHnkkAHfccQeHHnooL7/8MoceemjdzV0lSZKk9VmklEodwxrp379/mjZtWr15Tz/9NHvuuWeJItrw+HpJkiRtGAaNXvdrvtfWj+8o7dUyQyZNXOt1I+KxlFL/hspsAZIkSZJUNtrlIAha3TOvPVP3+NW3XuVLo7/UZvuecu6UNtuXJEmS1BRbgCRJkiSVDROgVtK9e/d602PGjOFrX/saAL/85S+56aabmly/cHlJxTNmzBgGDhzIoEGDmD59er2yF154gcGDB1NdXc1BBx3EvHnzAPjnP//JwIEDGTx4cN0AIVJLWN8kaf3TLrvAzb10n1bd3g4XPbFO65999tmtFImkdbFo0SJGjRrFI488wvz58zn11FOZPHlyXfnPf/5zzjzzTE4//XTGjBnD6NGjueKKKxg+fDh//OMf2WGHHTjqqKM49thj2W233Ur4TLQhsL5J0vrJFqA2cPHFF3PVVVcB8Oijj9KnTx/69evHiBEj2HvvveuWe/nllzn88MPZdddd+fa3v12qcKV2a+rUqVRVVdG5c2d69erF0qVLWb58eV157969624MvGjRIrbaaisgu0HwDjvsAED//v3X+sbDKi/WN0laP7XLFqBSeO+99+jXr1/d9MKFCznmmGNWW+6MM87g17/+NZ/85Cc5//zz65XNmDGDxx9/nC5durD77rtz7rnn8tGPfrTYoUtlY8GCBVRUVNRN9+zZk4ULF7LNNtsAcOihh/LpT3+aG264geXLlzN16lQAtthiC2bOnMmee+7J/fffz2c+85mSxK8Ni/VNktZPtgC1km7dujFjxoy6v0svvXS1ZRYvXszSpUv55Cc/CcAXvvCFeuWHHHIIm222GV27dmWvvfbi3//+d5vELpWLysrKujPukJ1pr6ysrJv+zne+ww9/+ENmzZrFxRdfzAUXXADAr3/9a77zne9wzDHHsNNOO7Htttu2dejaAFnfJGn9ZAK0HunSpUvd444dO7Jy5coSRiO1PwMGDGDy5MmsWLGCuXPn0r1793qfu5QSW2yxBQBbbbUVCxcuBLKuSvfeey933nknCxcu5IgjjihJ/NqwWN8kaf1kF7g21LNnT3r06MG//vUvBgwYwK233lrqkKSyUlFRwbBhwxgyZAgRwciRI5kxYwbjx49nxIgRXHjhhXzlK19ho402YsWKFfzqV78C4Oqrr+Zvf/sbACNGjGDLLbcs5dPQBsL6JknrJxOgNnbDDTdw1lln0aFDB4YMGcJmm21W6pBKbsyYMVx33XVEBKNHj2bfffetK3vhhRcYOnQoHTp0ICK4+eab2X777TnttNOYO3cuADNnzuSmm26yn7xapKamhpqamnrzaq/f6927d71Rumqdd955nHfeeW0RntoZ65skrX8ipVTqGNZI//7907Rp0+rNe/rpp9lzzz1LFNGaefvtt+vuGXT55ZfzyiuvMHLkyKLv95nXnql7/MqcV7hw6oVF32etKedOabRs0aJFHHLIIY0OE/utb32LffbZp26Y2Keffporrriirnz58uXssccePPPMM/W6lkiSJLUHg0YPKtm+f3xHadtKhkyauNbrRsRjKaX+DZXZAtTG7r77bi677DJWrlzJxz72McaMGVPqkEqqsWFia5OZxoaJrXX33XdzyCGHmPyonomDh5Rs3+vyZa0Nk/VNkjYsJkBt7MQTT+TEE08sdRjrjbUdJrbW2LFjOffcc9s0ZkmSJG24HAVOJbW2w8RCNqz4E088QXV1dRtGLEmSpA2ZCZBKam2HiQW4/fbbOf7444mINo9bkiRJGya7wKmk1naYWMi6v1177bUljF6SJEkbGhMgldzaDBMLMGnSpGKHJkmSpHbGLnCtJCL44he/WDe9cuVKttxyS44++ug12k51dTW1w3wfeeSR9a6PkSRJkrRu2mULUGuPl97UfWxqbbLJJsyePZv33nuPbt26MX78eLbbbrt12u+4cePWaf31RSmHiAWHiZUkSdKHbAFqRUceeSR33303ALfccgsnn3xyXdk777xDTU0NBxxwAB//+Mf561//CsB7773HSSedxJ577slxxx3He++9V7fOjjvuyJtvvsmcOXPYe++96+ZfddVVXHzxxUDWYvTf//3f9O/fnz333JNHH32U448/nl133ZULL2y7m51KkiRJGwIToFZ00kknceutt7Js2TJmzZrFgAED6sp+9KMfcfDBBzN16lQefPBBRowYwTvvvMMvfvELNt54Y55++mkuueQSHnvssTXeb+fOnZk2bRpnn302xx57LNdeey2zZ89mzJgxLFiwoDWfoiRJkrRBa5dd4EqlT58+zJkzh1tuuYUjjzyyXtnf//537rzzTq666ioAli1bxty5c5k0aRLDhw+vW79Pnz5rvN9jjjkGgH322YfevXvX3UR0p5124qWXXmLzzTdfl6clSZIktRsmQK3smGOO4Vvf+hYTJkyo1/qSUuKPf/wju++++xpvc6ONNuKDDz6om162bFm98tr75nTo0KHePXQ6dOjAypUr13h/kiRJUntlF7hWVlNTw/e//3322WefevM//elPM3r0aFJKADz++OMADB48mN///vcAzJ49m1mzZq22zY985CO8/vrrLFiwgOXLl3PXXXcV+VlIkiRJ7ZMJUCvbfvvt67q0Ffre977HihUr6NOnD7179+Z73/seAF/96ld5++232XPPPbnooovYb7/9Vlu3U6dOXHTRRRxwwAEcdthh7LHHHkV/HpIkSVJ71C67wLVk2OrW9vbbb682r7q6murqagC6devGr371q9WW6datG7feemuD25wzZ07d4+HDhzeYWE2YMKHB/a1aJkmSJMkWIEmSJEllxARIkiRJUtkwAZIkSZJUNkyAJEmSJJUNEyBJkiRJZcMESJIkSVLZMAFqJd27dy91CJIkSZKa0S7vAzRx8JBW3d6QSRNbdXuSJEmSSsMWoCKaMWMGn/jEJ+jTpw/HHXccixYt4vXXX2e//fYDYObMmUQEc+fOBWDnnXfm3XffLWXIkiRJUrtmAlREp512GldccQWzZs1in3324ZJLLmGrrbZi2bJlvPXWWzz00EP079+fhx56iH//+99stdVWbLzxxqUOW5IkSWq32mUXuPXBkiVLWLx4MUOGZN3xTj/9dE444QQABg4cyJQpU5g0aRIXXHAB9957LyklqqqqShmyJEmS1O7ZAlQCgwcPrmv1OfbYY5k5cyaTJ082AZIkSZKKzASoSDbbbDMqKip46KGHALj55pvrWoOqqqoYO3Ysu+66Kx06dKCyspJx48Zx4IEHljJkSZIkqd2zC1wreffdd9l+++3rps877zxuvPFGzj77bN5991122mknfvvb3wKw4447klJi8ODBABx44IHMmzePioqKksQuSZIklYt2mQCVYtjqDz74oMH5jzzySIPzX3rppbrHF1xwARdccEFR4pIkSZL0IbvASZIktZIxY8YwcOBABg0axPTp0+uVvfDCCwwePJjq6moOOugg5s2bB8CcOXM4+OCDGTRoED/+8Y9LEbZUVkyAJEmSWsGiRYsYNWoUEyZMYOzYsQwfPrxe+c9//nPOPPNMJkyYwOmnn87o0aMBOP/887nkkkuYMmUKDzzwAM8880wpwpfKhgmQJElSK5g6dSpVVVV07tyZXr16sXTpUpYvX15X3rt3bxYvXgxkydJWW20FZDdOrx0J9qijjmLixLbvyi+Vk3ZzDVBKiYgodRjrvZQSiVTqMCRJancWLFhQb0Cjnj17snDhQrbZZhsADj30UD796U9zww03sHz5cqZOnQrUv464Z8+evPrqq20buFRm2kULUNeuXVmwYAEpeWDf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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",
    "\n",
    "# Define successful goals (assuming successful means percent_complete >= target_percentage)\n",
    "goal_data['is_successful'] = goal_data['percent_complete'] >= goal_data['target_percentage']\n",
    "\n",
    "# Calculate the proportion of successful goals by priority and department\n",
    "success_rates = goal_data.groupby(['category', 'priority'])['is_successful'].mean().reset_index()\n",
    "\n",
    "# Plotting\n",
    "plt.figure(figsize=(14, 8))\n",
    "barplot = sns.barplot(x='category', y='is_successful', hue='priority', data=success_rates, hue_order=['Critical', 'High', 'Medium', 'Low'])\n",
    "\n",
    "# Annotate each bar\n",
    "for p in barplot.patches:\n",
    "    barplot.annotate(format(p.get_height(), '.2f'),  # format as a percentage\n",
    "                     (p.get_x() + p.get_width() / 2., p.get_height()),\n",
    "                     ha = 'center', va = 'center',\n",
    "                     size=9,\n",
    "                     xytext = (0, 5),\n",
    "                     textcoords = 'offset points')\n",
    "\n",
    "plt.title('Proportion of Successful Goals by Priority Across categoriess')\n",
    "plt.xlabel('Category')\n",
    "plt.ylabel('Proportion of Successful Goals')\n",
    "plt.ylim(0, 1)  # Set the limit to show proportions from 0 to 1\n",
    "plt.legend(title='Priority')\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:17:22.912341Z",
     "iopub.status.busy": "2024-10-29T17:17:22.911646Z",
     "iopub.status.idle": "2024-10-29T17:17:22.937361Z",
     "shell.execute_reply": "2024-10-29T17:17:22.935263Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'diagnostic',\n",
       " 'insight': 'Widespread high success rates for Low and Medium priority goals across all categories',\n",
       " 'insight_value': {'Low': 'Average 85%',\n",
       "  'Medium': 'Average 80%',\n",
       "  'High': 'Average 12%',\n",
       "  'Critical': 'Average 14%'},\n",
       " 'plot': {'plot_type': 'bar',\n",
       "  'title': 'Success Rates by Priority Across All Categories',\n",
       "  'x_axis': {'name': 'Priority Level',\n",
       "   'value': 'Low, Medium, High, Critical',\n",
       "   'description': 'This represents the different priority levels for goals across all categories.'},\n",
       "  'y_axis': {'name': 'Percentage of Goals Successfully Met',\n",
       "   'value': 'significantly high for low/medium categories, low for high/critical categories',\n",
       "   'description': 'This shows the success rates for goals within each priority level across all categories, illustrating a trend where lower priorities unexpectedly have higher success rates.'},\n",
       "  'description': 'The bar graph indicates that Low and Medium priority goals across all categories consistently achieve higher success rates (75% and 70% respectively) compared to High and Critical priority goals (45% and 30% respectively). This trend challenges the conventional expectation that higher priority goals would typically have better success rates.'},\n",
       " 'question': 'Is this unusual trend of low and medium priority goals seen in the Cost Reduction category also observed across other categories?',\n",
       " 'actionable_insight': 'Given that lower priority goals are achieving higher success rates across various categories, this may suggest a need for a thorough review of how goals are prioritized and managed. Organizations might consider reassessing priority assignment processes to ensure that resources are aligned with the actual requirements for achieving success, potentially leading to strategic adjustments in goal setting and resource allocation.'}"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"diagnostic\",\n",
    "    \"insight\": \"Widespread high success rates for Low and Medium priority goals across all categories\",\n",
    "    \"insight_value\": {\n",
    "        \"Low\": \"Average 85%\",\n",
    "        \"Medium\": \"Average 80%\",\n",
    "        \"High\": \"Average 12%\",\n",
    "        \"Critical\": \"Average 14%\"\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"bar\",\n",
    "        \"title\": \"Success Rates by Priority Across All Categories\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Priority Level\",\n",
    "            \"value\": \"Low, Medium, High, Critical\",\n",
    "            \"description\": \"This represents the different priority levels for goals across all categories.\"\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Percentage of Goals Successfully Met\",\n",
    "            \"value\": \"significantly high for low/medium categories, low for high/critical categories\",\n",
    "            \"description\": \"This shows the success rates for goals within each priority level across all categories, illustrating a trend where lower priorities unexpectedly have higher success rates.\"\n",
    "        },\n",
    "        \"description\": \"The bar graph indicates that Low and Medium priority goals across all categories consistently achieve higher success rates (75% and 70% respectively) compared to High and Critical priority goals (45% and 30% respectively). This trend challenges the conventional expectation that higher priority goals would typically have better success rates.\"\n",
    "    },\n",
    "    \"question\": \"Is this unusual trend of low and medium priority goals seen in the Cost Reduction category also observed across other categories?\",\n",
    "    \"actionable_insight\": \"Given that lower priority goals are achieving higher success rates across various categories, this may suggest a need for a thorough review of how goals are prioritized and managed. Organizations might consider reassessing priority assignment processes to ensure that resources are aligned with the actual requirements for achieving success, potentially leading to strategic adjustments in goal setting and resource allocation.\"\n",
    "}\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 4:** What is the distribution of Low and Medium priority goals in Cost Reduction versus other categories?"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Plot distribution of Low and Medium priority goals in Cost Reduction vs other categories\n",
    "\n",
    "This bar graph illustrates the distribution of goals classified as Low or Medium priority within the Cost Reduction categories compared to other categories. It quantifies the counts of such goals, offering insights into how prioritization influences. This visualization helps to understand if there is any disproportionate focus on lower-priority goals consistent across all categories."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:17:22.951507Z",
     "iopub.status.busy": "2024-10-29T17:17:22.950347Z",
     "iopub.status.idle": "2024-10-29T17:17:23.435040Z",
     "shell.execute_reply": "2024-10-29T17:17:23.432851Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-10-5b3aa7f40e5c>:11: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  filtered_goals['CR_or_Other'] = filtered_goals['category'].apply(lambda x: 'Cost Reduction' if x == 'Cost Reduction' else 'Other')\n"
     ]
    },
    {
     "data": {
      "image/png": "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jB49mmOPPXbh+AULFrDSSr173q/zPJMmTeJrX/saEydOXD5BN6mrz8s2XpIkqV8YN24cDzzwAJMmTWLcuHHsvffebL311kCVoEHVcP24445j2223ZbvttuOSSy4B6HGeE044gZtuuolRo0Zx5plnsssuu3DXXXctXO7OO+/M1KlTa1zTrvk6CUmSVIsFCxbw61//mt133x2AO+64g2nTpi32VOAvf/lL7rrrLqZOncqTTz7JG97wBnbZZZce5znjjDMWqfFab731OPfcc/nGN77BX/7yF+bNm8f2229fw1r2zBovSZLUUi+88MLCn67bdNNN+fCHPwzA2LFjF0ugAG6++WYOOuggBg4cyEYbbcRb3vIWbr/99h7n6eyAAw5g4sSJzJ8/n3POOYcPfehDy3WdlpY1XpIkqaVWW221RW77dVhjjTV6XVaz86y++urstttuXHnllVx66aVMmTKl18tqBROvLow+7vy+DkFLacpXD+3rECRJy2jcuHH84Ac/4LDDDuOpp57ixhtv5Ktf/Sr33Xdft/OstdZaC1+h1OHII4/k3e9+N+PGjes3v9DirUZJktSv7LfffowcOZLtt9+eXXfdla985Su86lWv6nGekSNHMnDgQLbffvuFr0kaPXo0a6+9NocffngdYTfF10l0wRqvFZc1XpK0bFrxOom+8thjjzF+/Hjuu+8+BgxoTV2Tr5OQJEmveOeffz5vfOMb+dKXvtSypGtp2MZLkiS1nUMPPZRDD+1/d0H6TwooSZLU5ky8JEmSamLiJUmSVBMTL0mSpJqYeEmSpH6l44ev25FPNUqSpG4t73dbvtLft2iNlyRJ6vfuuusudtxxR0aOHMl+++3H008/zaxZsxg9ejQAU6dOJSJ4+OGHAXjNa17D888/35chd8nES5Ik9XuHHnooX/7yl7n77rvZbrvtOP300xkyZAjz5s3j2Wef5aabbmLMmDHcdNNNPPTQQwwZMoTVV1+9r8NejLcaJUlSv/aPf/yDZ555hre85S0AHHbYYRxwwAEA7LTTTtxyyy3ceOONnHjiifzP//wPmcm4ceP6MuRuWeMlSZJWWLvsssvCWq599tmHqVOncvPNN5t4SZIkLY111lmHwYMHc9NNNwFwwQUXLKz9GjduHBdeeCFbbbUVAwYMYL311uOaa65h55137suQu+WtRkmS1K88//zzDBs2bGH/sccey3nnncfRRx/N888/zxZbbMFPfvITAIYPH05msssuuwCw8847M2PGDAYPHtwnsS+JiZckSepWX7z+4eWXX+5y+K233trl8EceeWRh94knnsiJJ57YkriWB281SpIk1cTES5IkqSYmXpIkSTUx8ZIkSaqJiZckSVJNTLwkSZJqYuIlSZL6lYjgkEMOWdi/YMECNtxwQ/baa69elTN+/HgmT54MwB577MEzzzyzPMNcKi19j1dETAfmAC8BCzJzTESsB1wCDAemA+/LzKdbGYckSVo6D39+u+Va3qan/HGJ06yxxhpMmzaNF154gdVWW43f/OY3DB06dJmWe8011yzT/MtLHTVeb83MUZk5pvSfAPwuM7cCflf6JUmSFtpjjz24+uqrAbjooos46KCDFo577rnnOOKIIxg7diw77LADV155JQAvvPACBx54ICNGjGC//fbjhRdeWDjP8OHDefLJJ5k+fTrbbrvtwuFf+9rXOO2004CqhuxTn/oUY8aMYcSIEdx+++3sv//+bLXVVpx00knLZb364lbjPsB5pfs8YN8+iEGSJPVjBx54IBdffDHz5s3j7rvv5o1vfOPCcV/60pfYddddue2227j++us57rjjeO655/je977H6quvzr333svpp5/OlClTer3cVVZZhcmTJ3P00Uezzz778J3vfIdp06Zx7rnnMnv27GVer1YnXglcGxFTIuKoMmyjzJxZuv8ObNTVjBFxVERMjojJTzzxRIvDlCRJ/cnIkSOZPn06F110EXvsscci46699lrOOOMMRo0axfjx45k3bx4PP/wwN95448K2YSNHjmTkyJG9Xu7ee+8NwHbbbcc222zDxhtvzKqrrsoWW2yxyE8TLa1W/1bjzpn5aEQMAX4TEfc1jszMjIjsasbMPBs4G2DMmDFdTiNJktrX3nvvzWc+8xkmTZq0SG1TZvKLX/yC173udb0uc6WVVlrktyDnzZu3yPhVV10VgAEDBizs7uhfsGBBr5fXWUtrvDLz0fJ/FnA5MBZ4PCI2Bij/Z7UyBkmStGI64ogjOPXUU9luu0Ub+L/zne/kW9/6FplVvcydd94JwC677MLPfvYzAKZNm8bdd9+9WJkbbbQRs2bNYvbs2bz44otMnDixxWuxqJYlXhGxRkSs1dENvAOYBlwFHFYmOwy4slUxSJKkFdewYcM45phjFht+8sknM3/+fEaOHMk222zDySefDMDHPvYx5s6dy4gRIzjllFMYPXr0YvOuvPLKnHLKKYwdO5bddtuN17/+9S1fj0bRkS0u94IjtqCq5YLqlubPMvNLEbE+cCmwKfAQ1esknuqprDFjxmTHezjqMPq482tblpavKV89tK9DWK5eeuklxowZw9ChQ5k4cSLjxo1jzpw5AMyaNYuxY8dyxRVX9G2QktrKvffey4gRI/o6jBVGV59XRExpeJvDIlrWxiszHwS272L4bOBtrVqu1E7OOussRowYwbPPPgvATTfdtHDce97zHvbZZ5++Ck2StBR8c73UT82YMYOrr76aI488crFxzz77LNdddx377rtv/YFJkpaaiZfUT33yk5/kK1/5CgMGLH6YXnHFFbztbW9j7bXX7oPIJElLy8RL6ocmTpzIkCFDumwYCou/xVmSlqdWtf9uN0vzOZl4Sf3QLbfcwlVXXcXw4cM58MADue666xa+FPDJJ5/ktttuY8899+zjKCW1o0GDBjF79myTryXITGbPns2gQYN6NV+rX6AqaSlMmDCBCRMmADBp0iS+9rWvceGFFwJw2WWXsddee/X6YJekDp2fmM5MTjrpJH7+858zePBgJkyYwMYbb9zXYfZ7gwYNYtiwYb2ax8RLWsFcfPHFnHCCvy0vael1fmL63HPP5ZFHHuG+++5jwIABzJo1iyFDhvRxlO3JW41SPzd+/PhF3qw8adIkdt999z6MSNKKrKsnpr/3ve9xyimnLHyYx6SrdUy8JEl6Benqiem//vWvXHLJJYwZM4Z3vetd3H///X0YYXsz8ZIk6RWiuyemX3zxRQYNGsTkyZP5yEc+whFHHNFHEbY/23hJkvQK0fHE9DXXXMO8efN49tlnOeSQQxg2bBj7778/APvttx+HH354H0favqzxkiTpFWLChAnMmDGD6dOnc/HFF7Prrrty4YUXsu+++3L99dcDcMMNN/Da1762jyNtX9Z4qa08/Pnt+joELYNNT/ljX4cgvSKdcMIJHHzwwZx55pmsueaa/OhHP+rrkNqWiZckSa9A48ePZ/z48QCsu+66XH311X0b0CuEtxolSZJqYuIlSZJUExMvSZKkmph4SZIk1cTG9ZIkLYFPTK/Y+tMT09Z4SZIk1cTES5IkqSYmXpIkSTUx8ZIkSaqJiZckSVJN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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 seaborn as sns\n",
    "import pandas as pd\n",
    "\n",
    "# Assume 'goal_data' is your DataFrame and already loaded\n",
    "\n",
    "# Filter the data to include only Critical and High priority goals\n",
    "filtered_goals = goal_data[goal_data['priority'].isin(['Low', 'Medium'])]\n",
    "\n",
    "# Create a new column 'IT_or_Other' to distinguish between IT and other departments\n",
    "filtered_goals['CR_or_Other'] = filtered_goals['category'].apply(lambda x: 'Cost Reduction' if x == 'Cost Reduction' else 'Other')\n",
    "\n",
    "# Count the number of goals in each category\n",
    "priority_counts = filtered_goals.groupby(['CR_or_Other', 'priority']).size().reset_index(name='counts')\n",
    "\n",
    "# Plotting\n",
    "plt.figure(figsize=(10, 6))\n",
    "bar_plot = sns.barplot(x='CR_or_Other', y='counts', hue='priority', data=priority_counts)\n",
    "plt.title('Distribution of Low and Medium Priority Goals: Cost Reduction vs. Other Categories')\n",
    "plt.xlabel('Category')\n",
    "plt.ylabel('Number of Goals')\n",
    "plt.legend(title='Priority')\n",
    "\n",
    "# Annotate bars with the count of goals\n",
    "for p in bar_plot.patches:\n",
    "    bar_plot.annotate(format(p.get_height(), '.0f'), \n",
    "                      (p.get_x() + p.get_width() / 2., p.get_height()), \n",
    "                      ha='center', va='center', \n",
    "                      xytext=(0, 9), \n",
    "                      textcoords='offset points')\n",
    "\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:17:23.449893Z",
     "iopub.status.busy": "2024-10-29T17:17:23.448893Z",
     "iopub.status.idle": "2024-10-29T17:17:23.473761Z",
     "shell.execute_reply": "2024-10-29T17:17:23.471872Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'diagnostic',\n",
       " 'insight': \"Higher number of Low and Medium priority goals in 'Cost Reduction' compared to other categories\",\n",
       " 'insight_value': {'Cost Reduction': {'Low': '55', 'Medium': '47'},\n",
       "  'Other Categories': {'Low': '41', 'Medium': '46'}},\n",
       " 'plot': {'plot_type': 'bar',\n",
       "  'title': 'Distribution of Low and Medium Priority Goals in Cost Reduction vs. Other Categories',\n",
       "  'x_axis': {'name': 'Category and Priority',\n",
       "   'value': 'Cost Reduction, Other Categories',\n",
       "   'description': \"This categorizes goals by priority level within 'Cost Reduction' and combines all other categories for comparison.\"},\n",
       "  'y_axis': {'name': 'Number of Goals',\n",
       "   'value': 'Dynamic based on data',\n",
       "   'description': 'This shows the count of goals classified as Low and Medium priority within each category group.'},\n",
       "  'description': \"The bar graph shows that the 'Cost Reduction' category has a higher number of Low (55) and Medium (47) priority goals compared to other categories, which have 41 Low and 46 Medium priority goals respectively. This distribution underlines why the 'Cost Reduction' category might exhibit higher success rates, as it has more goals in categories typically associated with higher success rates.\"},\n",
       " 'question': 'What is the distribution of Low and Medium priority goals in Cost Reduction versus other categories?',\n",
       " 'actionable_insight': \"The disproportionate number of Low and Medium priority goals in 'Cost Reduction' suggests a strategic focus that effectively leverages these levels for success. Other categories might benefit from a realignment of priorities or a review of goal setting practices to enhance their own success rates, potentially adopting some of the effective strategies used in 'Cost Reduction'.\"}"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"diagnostic\",\n",
    "    \"insight\": \"Higher number of Low and Medium priority goals in 'Cost Reduction' compared to other categories\",\n",
    "    \"insight_value\": {\n",
    "        \"Cost Reduction\": {\n",
    "            \"Low\": \"55\",\n",
    "            \"Medium\": \"47\"\n",
    "        },\n",
    "        \"Other Categories\": {\n",
    "            \"Low\": \"41\",\n",
    "            \"Medium\": \"46\"\n",
    "        }\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"bar\",\n",
    "        \"title\": \"Distribution of Low and Medium Priority Goals in Cost Reduction vs. Other Categories\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Category and Priority\",\n",
    "            \"value\": \"Cost Reduction, Other Categories\",\n",
    "            \"description\": \"This categorizes goals by priority level within 'Cost Reduction' and combines all other categories for comparison.\"\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Number of Goals\",\n",
    "            \"value\": \"Dynamic based on data\",\n",
    "            \"description\": \"This shows the count of goals classified as Low and Medium priority within each category group.\"\n",
    "        },\n",
    "        \"description\": \"The bar graph shows that the 'Cost Reduction' category has a higher number of Low (55) and Medium (47) priority goals compared to other categories, which have 41 Low and 46 Medium priority goals respectively. This distribution underlines why the 'Cost Reduction' category might exhibit higher success rates, as it has more goals in categories typically associated with higher success rates.\"\n",
    "    },\n",
    "    \"question\": \"What is the distribution of Low and Medium priority goals in Cost Reduction versus other categories?\",\n",
    "    \"actionable_insight\": \"The disproportionate number of Low and Medium priority goals in 'Cost Reduction' suggests a strategic focus that effectively leverages these levels for success. Other categories might benefit from a realignment of priorities or a review of goal setting practices to enhance their own success rates, potentially adopting some of the effective strategies used in 'Cost Reduction'.\"\n",
    "}\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 5:** Are there identifiable trends or patterns in resource allocation for 'Cost Reduction' goals that could explain their higher success rates?"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Insufficient data to identify trends in resource allocation for 'Cost Reduction' goals\n",
    "\n",
    "To better understand the impact of resource allocation on the success rates of 'Cost Reduction' goals, it is recommended that future datasets include detailed resource allocation metrics. This additional data would enable a more targeted analysis and could potentially reveal strategic insights that are currently obscured due to data limitations."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Summary of Findings (Flag 76):\n",
    "\n",
    "1. **Priority vs. Success Rate Anomaly**: From Question 2, it was observed that 'Cost Reduction' goals with Low and Medium priorities have significantly higher success rates compared to High and Critical priorities. This suggests a potential misalignment in how priority levels are perceived and managed within this category.\n",
    "\n",
    "2. **Consistent Success Across Categories**: As highlighted in Question 3, the trend of higher success rates for Low and Medium priority goals is not limited to 'Cost Reduction' but is prevalent across all categories. This indicates a broader organizational pattern that may require a reevaluation of priority setting and resource allocation strategies.\n",
    "\n",
    "3. **Disproportionate Focus on Lower Priorities**: Question 4 reveals that the 'Cost Reduction' category has a higher number of Low and Medium priority goals compared to other categories. This distribution may contribute to the higher success rates observed, suggesting that strategic focus on these priorities could be a key factor in their effectiveness."
   ]
  }
 ],
 "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
}
