{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Goal Achievement Rate Analysis in IT Department (Flag 75)\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**: Examine and analyze elevated goal achievement rates in a certain department and to leverage these insights to improve goal management across all departments.\n",
    "\n",
    "**Role**: Goal Management Analyst\n",
    "\n",
    "**Difficulty**: 2 out of 5. This notebook requires comprehensive analysis of goal prioritization and achievement rates.\n",
    "\n",
    "**Category**: Goal 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": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:17:06.761147Z",
     "iopub.status.busy": "2024-10-29T17:17:06.759421Z",
     "iopub.status.idle": "2024-10-29T17:17:10.029277Z",
     "shell.execute_reply": "2024-10-29T17:17:10.027212Z"
    }
   },
   "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:10.045039Z",
     "iopub.status.busy": "2024-10-29T17:17:10.043911Z",
     "iopub.status.idle": "2024-10-29T17:17:10.121389Z",
     "shell.execute_reply": "2024-10-29T17:17:10.119129Z"
    }
   },
   "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>target_percentage</th>\n",
       "      <th>sys_updated_by</th>\n",
       "      <th>priority</th>\n",
       "      <th>metric</th>\n",
       "      <th>percent_complete</th>\n",
       "      <th>sys_id</th>\n",
       "      <th>state</th>\n",
       "      <th>start_date</th>\n",
       "      <th>end_date</th>\n",
       "      <th>department</th>\n",
       "      <th>category</th>\n",
       "      <th>owner</th>\n",
       "      <th>description</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>52</td>\n",
       "      <td>admin</td>\n",
       "      <td>Low</td>\n",
       "      <td>Expense Ratio</td>\n",
       "      <td>79</td>\n",
       "      <td>G000000</td>\n",
       "      <td>Completed</td>\n",
       "      <td>2022-06-17</td>\n",
       "      <td>2022-06-28</td>\n",
       "      <td>HR</td>\n",
       "      <td>Cost Reduction</td>\n",
       "      <td>User 1</td>\n",
       "      <td>Optimize the usage of duplicated resources acr...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>97</td>\n",
       "      <td>admin</td>\n",
       "      <td>High</td>\n",
       "      <td>Expense Ratio</td>\n",
       "      <td>97</td>\n",
       "      <td>G000001</td>\n",
       "      <td>Completed</td>\n",
       "      <td>2022-11-14</td>\n",
       "      <td>2023-04-11</td>\n",
       "      <td>IT</td>\n",
       "      <td>Customer Satisfaction</td>\n",
       "      <td>Christian Marnell</td>\n",
       "      <td>Increase our customer satisfaction ratings fro...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>69</td>\n",
       "      <td>admin</td>\n",
       "      <td>Low</td>\n",
       "      <td>Employee Turnover Rate</td>\n",
       "      <td>8</td>\n",
       "      <td>G000002</td>\n",
       "      <td>In Progress</td>\n",
       "      <td>2022-09-15</td>\n",
       "      <td>2023-07-28</td>\n",
       "      <td>HR</td>\n",
       "      <td>Efficiency</td>\n",
       "      <td>Frankie Morein</td>\n",
       "      <td>Establish more efficient communication channel...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>58</td>\n",
       "      <td>admin</td>\n",
       "      <td>Medium</td>\n",
       "      <td>Employee Turnover Rate</td>\n",
       "      <td>25</td>\n",
       "      <td>G000003</td>\n",
       "      <td>Cancelled</td>\n",
       "      <td>2022-03-16</td>\n",
       "      <td>2023-07-06</td>\n",
       "      <td>Marketing</td>\n",
       "      <td>Employee Satisfaction</td>\n",
       "      <td>Jess Assad</td>\n",
       "      <td>Develop and implement a comprehensive Employee...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>76</td>\n",
       "      <td>admin</td>\n",
       "      <td>Low</td>\n",
       "      <td>Survey Score</td>\n",
       "      <td>13</td>\n",
       "      <td>G000004</td>\n",
       "      <td>In Progress</td>\n",
       "      <td>2022-08-02</td>\n",
       "      <td>2022-07-18</td>\n",
       "      <td>IT</td>\n",
       "      <td>Revenue Growth</td>\n",
       "      <td>Devon Teston</td>\n",
       "      <td>Increase the number of premium subscriptions b...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   target_percentage sys_updated_by priority                  metric  \\\n",
       "0                 52          admin      Low           Expense Ratio   \n",
       "1                 97          admin     High           Expense Ratio   \n",
       "2                 69          admin      Low  Employee Turnover Rate   \n",
       "3                 58          admin   Medium  Employee Turnover Rate   \n",
       "4                 76          admin      Low            Survey Score   \n",
       "\n",
       "   percent_complete   sys_id        state  start_date    end_date department  \\\n",
       "0                79  G000000    Completed  2022-06-17  2022-06-28         HR   \n",
       "1                97  G000001    Completed  2022-11-14  2023-04-11         IT   \n",
       "2                 8  G000002  In Progress  2022-09-15  2023-07-28         HR   \n",
       "3                25  G000003    Cancelled  2022-03-16  2023-07-06  Marketing   \n",
       "4                13  G000004  In Progress  2022-08-02  2022-07-18         IT   \n",
       "\n",
       "                category              owner  \\\n",
       "0         Cost Reduction             User 1   \n",
       "1  Customer Satisfaction  Christian Marnell   \n",
       "2             Efficiency     Frankie Morein   \n",
       "3  Employee Satisfaction         Jess Assad   \n",
       "4         Revenue Growth       Devon Teston   \n",
       "\n",
       "                                         description  \n",
       "0  Optimize the usage of duplicated resources acr...  \n",
       "1  Increase our customer satisfaction ratings fro...  \n",
       "2  Establish more efficient communication channel...  \n",
       "3  Develop and implement a comprehensive Employee...  \n",
       "4  Increase the number of premium subscriptions b...  "
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_path = \"csvs/flag-75.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 the progress of tasks in different departments correlate with their priority levels?**\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Plotting average progress of tasks across departments by priority\n",
    "This analysis explores how various departments prioritize tasks and the resulting progress on those tasks. By examining the average percentage of task completion per department at different priority levels, we gain insight into how effectively each department allocates resources and maintains focus across their primary goals.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:17:10.137818Z",
     "iopub.status.busy": "2024-10-29T17:17:10.137009Z",
     "iopub.status.idle": "2024-10-29T17:17:10.665908Z",
     "shell.execute_reply": "2024-10-29T17:17:10.663846Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x432 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "# Load the data\n",
    "flag_data = pd.read_csv(\"csvs/flag-75.csv\")\n",
    "\n",
    "# Group by 'department' and 'priority' to calculate the average 'percent_complete' for each combination\n",
    "department_priority_progress = (\n",
    "    flag_data.groupby([\"department\", \"priority\"])[\"percent_complete\"]\n",
    "    .mean()\n",
    "    .reset_index()\n",
    ")\n",
    "\n",
    "# Pivot data for easier plotting\n",
    "pivot_data = department_priority_progress.pivot(\n",
    "    index=\"department\", columns=\"priority\", values=\"percent_complete\"\n",
    ")\n",
    "\n",
    "# Create a heatmap to visualize the average progress of tasks in each department by priority\n",
    "plt.figure(figsize=(10, 6))\n",
    "sns.heatmap(\n",
    "    pivot_data, annot=True, cmap=\"YlGnBu\", cbar_kws={\"label\": \"Average % Complete\"}\n",
    ")\n",
    "plt.title(\"Average Task Completion by Department and Priority Level\")\n",
    "plt.xlabel(\"Priority\")\n",
    "plt.ylabel(\"Department\")\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:10.681353Z",
     "iopub.status.busy": "2024-10-29T17:17:10.680549Z",
     "iopub.status.idle": "2024-10-29T17:17:10.708880Z",
     "shell.execute_reply": "2024-10-29T17:17:10.706658Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'correlative',\n",
       " 'insight': 'Departments consistently achieve higher task completion rates for Critical and High priority tasks, with significant variance in progress on lower priorities.',\n",
       " 'insight_value': {'description': 'Finance and Marketing departments, in particular, show a noticeable trend where Critical and High priority tasks have average completion rates above 70%, while Low and Medium priority tasks lag significantly, averaging closer to 40%.'},\n",
       " 'plot': {'plot_type': 'heatmap',\n",
       "  'title': 'Average Task Completion by Department and Priority Level',\n",
       "  'x_axis': {'name': 'Priority',\n",
       "   'value': ['Critical', 'High', 'Medium', 'Low'],\n",
       "   'description': 'The priority levels assigned to tasks within each department.'},\n",
       "  'y_axis': {'name': 'Department',\n",
       "   'value': ['Finance', 'HR', 'IT', 'Marketing'],\n",
       "   'description': 'The departments within the organization that are being compared in terms of task completion progress.'},\n",
       "  'description': 'The heatmap highlights that higher-priority tasks are generally more complete across departments, with completion rates decreasing as priority levels decrease, especially within the Finance and Marketing departments.'},\n",
       " 'question': 'How does the progress of tasks in different departments correlate with their priority levels?',\n",
       " 'actionable_insight': 'Departments should consider reallocating resources to lower-priority tasks to prevent significant disparities in task completion. Focusing on bringing Low and Medium priority tasks closer to completion could improve overall operational balance. Additionally, this data may inform better prioritization practices by emphasizing the need to maintain steady progress across all task levels.'}"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"correlative\",\n",
    "    \"insight\": \"Departments consistently achieve higher task completion rates for Critical and High priority tasks, with significant variance in progress on lower priorities.\",\n",
    "    \"insight_value\": {\n",
    "        \"description\": \"Finance and Marketing departments, in particular, show a noticeable trend where Critical and High priority tasks have average completion rates above 70%, while Low and Medium priority tasks lag significantly, averaging closer to 40%.\"\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"heatmap\",\n",
    "        \"title\": \"Average Task Completion by Department and Priority Level\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Priority\",\n",
    "            \"value\": [\"Critical\", \"High\", \"Medium\", \"Low\"],\n",
    "            \"description\": \"The priority levels assigned to tasks within each department.\",\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Department\",\n",
    "            \"value\": [\"Finance\", \"HR\", \"IT\", \"Marketing\"],\n",
    "            \"description\": \"The departments within the organization that are being compared in terms of task completion progress.\",\n",
    "        },\n",
    "        \"description\": \"The heatmap highlights that higher-priority tasks are generally more complete across departments, with completion rates decreasing as priority levels decrease, especially within the Finance and Marketing departments.\",\n",
    "    },\n",
    "    \"question\": \"How does the progress of tasks in different departments correlate with their priority levels?\",\n",
    "    \"actionable_insight\": \"Departments should consider reallocating resources to lower-priority tasks to prevent significant disparities in task completion. Focusing on bringing Low and Medium priority tasks closer to completion could improve overall operational balance. Additionally, this data may inform better prioritization practices by emphasizing the need to maintain steady progress across all task levels.\",\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 2:** What proportion of goals in the IT department are classified as High or Critical priority compared to other departments?"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Plot proportion of successful goals by priority in IT department\n",
    "\n",
    "This bar plot depicts the success rates of goals within the IT department, 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.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:17:10.725394Z",
     "iopub.status.busy": "2024-10-29T17:17:10.724634Z",
     "iopub.status.idle": "2024-10-29T17:17:11.150523Z",
     "shell.execute_reply": "2024-10-29T17:17:11.147928Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-6-69b5f46d4705>: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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qbnV0xJ2FDASeDIzWyJiEHBEQ6uSJElqcvW0hH0AmJmZr0bEp4H/AOY0tixJkqTmVk8I+yHQEhHbAl8CngC8G7YkSdJyqCeEzS870O8LnJeZ59N1F2uVJEnqlerpE/Z6RHyV4tIUu0REH6BfY8uSJElqbvW0hB0IvE1xvbC/Ulz5/qyGViVJktTkOg1hZfD6X+A95ai/Adc1sihJndt4443ZeuutGTlyJKNHjwbgmmuuYauttqJPnz5Mmzat3WW/973vsdVWWzFixAgOPvhg3nrrLQAOOeQQttlmG04++eRF806cOJHrr7++odsiSb1RpyEsIo4GrgV+XI4aQnG7IUkV++1vf8v06dMXBa4RI0bw85//nF133bXdZWbNmsW5557LtGnTeOihh1iwYAFXXXUVM2bMYJVVVmHGjBncc889zJkzh+eff56pU6fysY99rJu2SJJ6j3r6hB0L7AhMBcjMxyJinYZWJWmZbLHFFnXNN3/+fObOnUu/fv1oaWlhgw02oF+/fsydO5eFCxcyb948VlppJU499VROO+20BlctSb1TPX3C3s7Md1oHIqIvkI0rSVI9IoI99tiD7bffngsuuKDu5YYMGcIJJ5zAhhtuyPrrr8+AAQPYY4892GKLLRg8eDCjRo1in3324fHHH2fhwoWMGjWqgVshSb1XPS1hv4uIk4FVImIM8G/A/2tsWZI6c8cddzBkyBBefPFFxowZw+abb97hYchWs2fPZvLkyTz11FMMHDiQ/fffn8svv5xPf/rTnHPOOYvm22efffjxj3/MN7/5TR544AHGjBnD0Ucf3cAtkqTepZ6WsJOAl4AHgX+huCH3fzSyKEmdGzJkCADrrLMOH//4x7n77rvrWu7Xv/41m2yyCYMHD6Zfv3584hOf4A9/+MNi80yePJntt9+eN954gyeeeIKrr76aa6+9lpaWli7fDknqreoJYasAF2Xm/pm5H3BROU5SRd58801ef/31Rc9vvvlmRowYUdeyG264IXfddRctLS1kJrfccstifcnmzZvHOeecw1e+8hXmzp1LRACwYMEC3nnnnfZWK0laSvWEsFtYPHStAvy6MeVIqscLL7zAzjvvzLbbbsuOO+7I3nvvzZ577sl1113H0KFDufPOO9l7770ZO3YsAM899xzjxo0DYKeddmK//fZj1KhRbL311ixcuJBjjjlm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KnfffTennXYas2fP5qabbmLnnXdmxowZXHbZZQA88MADLFiwgFGjRnXLNvVUhjBJkrTIrrvuyqBBgxYbN3nyZA477DAADjvsMK6//vp3LXfTTTcxZswYBg0axJprrsmYMWO48cYb6devHy0tLcybN4/MBOCUU07hjDPOaPi29HSGMEmS1KEXXniB9ddfH4D11luPF1544V3zzJo1i2HDhi0aHjp0KLNmzWLMmDE8/fTT/OM//iNf+MIXmDJlCqNGjWKDDTbotvp7qr5VFyBJklYcEUFE1D1/3759ueKKKwCYN28eY8eOZfLkyRx//PH85S9/YcKECYwfP75R5fZotoRJkqQOrbvuujz//PMAPP/886yzzjrvmmfIkCE888wzi4afffZZhgwZstg8P/jBD5gwYQJ33XUXAwYM4Gc/+xlnn312Y4vvwQxhkiSpQ+PHj190tuOkSZPYd9993zXP2LFjufnmm5k9ezazZ8/m5ptvZuzYsYumz549m1/84hdMmDCBlpYW+vTpQ0Qwd+7cbtuOnsYQJkmSFjn44IP5wAc+wMyZMxk6dCgXXnghJ510Er/61a8YPnw4v/71rznppJMAmDZtGp/5zGcAGDRoEKeccgo77LADO+ywA6eeeupiHfxPP/10vva1r9GnTx/Gjh3L7bffztZbb82hhx5ayXb2BNF6psKKYvTo0Tlt2rSlXm77L1/agGrUXe49a0K3vp77y4qru/cVSepIRNybmaOXNM2WMEmSpAoYwiRJkipgCJMkSaqAIUySJKkCXqxVkqRu4kk/K65GnPRjS5gkSVIFDGGSJEkVMIRJkiRVwBAmSZJUAUOYJElSBQxhkiRJFTCESZIkVcAQJkmSVAFDmCRJUgUMYZIkSRUwhEmSJFXAECZJklQBQ5gkSVIFDGGSJEkVMIRJkiRVwBAmSZJUAUOYJElSBQxhkiRJFTCESVIvc+ONN/L+97+fTTfdlDPPPPNd099++20OPPBANt10U3baaSeefvppAH7/+9+zzTbbMHr0aB577DEAXn31VfbYYw8WLlzYnZsgNQVDmCT1IgsWLODYY4/ll7/8JY888ghXXnkljzzyyGLzXHjhhay55po8/vjjfPGLX+TEE08E4Oyzz+aGG27gnHPO4Uc/+hEAEydO5OSTT6ZPH79OpKXlX40k9SJ33303m266Ke973/vo378/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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['department'] == 'IT']\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 IT Department')\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",
    "\n",
    "# Correctly format and annotate each bar with the proportion as a percentage\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",
    "\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:11.165595Z",
     "iopub.status.busy": "2024-10-29T17:17:11.164997Z",
     "iopub.status.idle": "2024-10-29T17:17:11.187907Z",
     "shell.execute_reply": "2024-10-29T17:17:11.185393Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'descriptive',\n",
       " 'insight': 'There are higher success rates in critical and high priority goals within the IT department',\n",
       " 'insight_value': {'Critical': '61.1%',\n",
       "  'High': '51.8%',\n",
       "  'Medium': '0.0%',\n",
       "  'Low': '10.0%'},\n",
       " 'plot': {'plot_type': 'bar',\n",
       "  'title': 'Proportion of Successful Goals by Priority in IT Department',\n",
       "  'x_axis': {'name': 'Priority',\n",
       "   'value': 'Critical, High, Medium, Low',\n",
       "   'description': 'This represents the different priority levels assigned to goals within the IT department.'},\n",
       "  'y_axis': {'name': 'Proportion of Successful Goals',\n",
       "   'value': 'Dynamic based on data',\n",
       "   'description': 'This represents the proportion of goals successfully met within each priority category.'},\n",
       "  'description': 'The bar graph illustrates the success rates of meeting goals within the IT department categorized by their priority. It highlights significantly higher success rates for goals categorized under Critical and High priorities at 61.1% and 51.8% respectively, compared to much lower success rates for Medium and Low priority goals. This disparity in success rates suggests a correlation between priority level and achievement rate.'},\n",
       " 'question': 'What proportion of goals in the IT department are classified as High or Critical priority compared to other departments?',\n",
       " 'actionable_insight': 'If this trend is consistent across other departments, it may indicate that departments with a higher proportion of Critical and High priority goals, like IT, are better at achieving their objectives. This could justify a review and potential realignment of priority settings across departments to ensure strategic goals are adequately supported and prioritized.'}"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"descriptive\",\n",
    "    \"insight\": \"There are higher success rates in critical and high priority goals within the IT department\",\n",
    "    \"insight_value\": {\n",
    "        \"Critical\": \"61.1%\",\n",
    "        \"High\": \"51.8%\",\n",
    "        \"Medium\": \"0.0%\",\n",
    "        \"Low\": \"10.0%\"\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"bar\",\n",
    "        \"title\": \"Proportion of Successful Goals by Priority in IT Department\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Priority\",\n",
    "            \"value\": \"Critical, High, Medium, Low\",\n",
    "            \"description\": \"This represents the different priority levels assigned to goals within the IT department.\"\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Proportion of Successful Goals\",\n",
    "            \"value\": \"Dynamic based on data\",\n",
    "            \"description\": \"This represents the proportion of goals successfully met within each priority category.\"\n",
    "        },\n",
    "        \"description\": \"The bar graph illustrates the success rates of meeting goals within the IT department categorized by their priority. It highlights significantly higher success rates for goals categorized under Critical and High priorities at 61.1% and 51.8% respectively, compared to much lower success rates for Medium and Low priority goals. This disparity in success rates suggests a correlation between priority level and achievement rate.\"\n",
    "    },\n",
    "    \"question\": \"What proportion of goals in the IT department are classified as High or Critical priority compared to other departments?\",\n",
    "    \"actionable_insight\": \"If this trend is consistent across other departments, it may indicate that departments with a higher proportion of Critical and High priority goals, like IT, are better at achieving their objectives. This could justify a review and potential realignment of priority settings across departments to ensure strategic goals are adequately supported and prioritized.\"\n",
    "}\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 3:** Are there specific characteristics or patterns that differentiate High/Critical priority goals in the IT department from those in other departments? or is the trend consistent across departments?"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Plot proportion of successful goals by priority across departments\n",
    "\n",
    "This bar plot provides a comparative analysis of the success rates of goals by priority levels (Critical, High, Medium, Low) across different departments. It explores how the prioritization of goals affects their achievement rates within each department. The graph allows us to identify departments where high and critical priority goals are either underperforming or exceeding expectations."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:17:11.206193Z",
     "iopub.status.busy": "2024-10-29T17:17:11.205559Z",
     "iopub.status.idle": "2024-10-29T17:17:12.096685Z",
     "shell.execute_reply": "2024-10-29T17:17:12.094117Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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q1czdOjQdtjLltkCJEmSJG3hPvjgA4YNG8bw4cPZddddGT9+PACHHHJIk0NIz5gxg7Fjx9K5c2d22GEHysvLeeaZZ1qs09jJJ5/MfffdR01NDTfccAPjxo1r033aULYASZIkSVu42nuAGtt6663Xe1351tlqq6048sgjueeee7jrrruYPXv2em+rEGwBkiRJktRAWVkZd955Jx999BFvv/02jz32GIccckiLdXr37s3KlSsbzPv617/O2WefzcEHH0xJSUkhQ86bCZAkSZKkBr7whS8wZMgQhg4dymGHHcZ//ud/suOOO7ZYZ8iQIXTu3JmhQ4fyk5/8BICDDjqIbbbZhtNPP709ws5LpJQ6Oob1Mnz48DRr1qyODkOSJEkqiBdffJGBAwd2dBhtYvHixVRUVPDSSy/RqVNh2l6aOl4RMTulNLyp5W0BkiRJktTmbrrpJkaMGMGll15asORnQzgIgiRJkqQ299WvfpWvfvWrHR3GOjadVEySJEmSCswESJIkSVLRMAGSJEmSVDRMgCRJkiQVDRMgSZIkSev429/+xpgxY9hzzz056KCDOOaYY3j55ZfXWW7kyJEAzJ8/n9tuu61u/qxZszj77LM3aNsVFRUU6tE3jgInSZIkbcIOmnhTm65v9pWtj8yWUuILX/gCX/va17jjjjsAmDt3Ln//+98ZMGAAAGvXrqVLly48+eSTwCcJ0Je//GUAhg8fzvDhTT6Kp0PZAiRJkiSpgUcffZSuXbty5pln1s0bOnQoH330EWVlZZxwwgnst99+APTq1QuAc889l8cff5xhw4bxk5/8hGnTpnHccccBsGrVKk4//XQGDx7MkCFDuPvuuwH45je/yfDhwxk0aBAXXnhhu+ybLUCSJEmSGnjuuec46KCDmiybM2cOzz33HP37928w//LLL+eqq67ivvvuA2DatGl1ZT/84Q/p06cPzz77LADLli0D4NJLL6W0tJSPPvqIww8/nHnz5jFkyJAC7NEnbAGSJEmSlLdDDjlkneSnNQ899BDf+ta36qZLSkoAuOuuuzjwwAM54IADeP7553nhhRfaNNammABJkiRJamDQoEHMnj27ybKtt966Tbbx2muvcdVVV/Hwww8zb948jj32WFavXt0m626JCZAkSZKkBg477DDWrFnDddddVzdv3rx5PP74483W6d27NytXrmyy7Mgj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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(['department', 'priority'])['is_successful'].mean().reset_index()\n",
    "\n",
    "# Plotting\n",
    "plt.figure(figsize=(14, 8))\n",
    "barplot = sns.barplot(x='department', 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 Departments')\n",
    "plt.xlabel('Department')\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:12.115148Z",
     "iopub.status.busy": "2024-10-29T17:17:12.114340Z",
     "iopub.status.idle": "2024-10-29T17:17:12.143020Z",
     "shell.execute_reply": "2024-10-29T17:17:12.140265Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'Diagnostic',\n",
       " 'insight': 'There is a consistent higher success rates for critical and high priority goals across departments',\n",
       " 'insight_value': {'IT': {'Critical': '61.1%', 'High': '51.8%'},\n",
       "  'Other Departments': {'Critical': 'Average 58.3%', 'High': 'Average 49.7%'}},\n",
       " 'plot': {'plot_type': 'bar',\n",
       "  'title': 'Success Rates of High and Critical Priority Goals Across Departments',\n",
       "  'x_axis': {'name': 'Department and Priority',\n",
       "   'value': 'Finance, HR, IT, Marketing',\n",
       "   'description': 'This categorizes the goals by department and priority level, comparing IT to other departments.'},\n",
       "  'y_axis': {'name': 'Proportion of Successful Goals',\n",
       "   'value': 'Values based on data',\n",
       "   'description': 'This axis shows the percentage of goals met within different priority categories for each department.'},\n",
       "  'description': 'The comparison bar graph demonstrates that both Critical and High priority goals generally achieve higher success rates across all departments. The IT department slightly outperforms the average of other departments, suggesting a possible advantage in how these priorities are managed or supported in IT.'},\n",
       " 'question': 'Are there specific characteristics or patterns that differentiate High/Critical priority goals in the IT department from those in other departments, or is the trend consistent across departments?',\n",
       " 'actionable_insight': 'Given the consistent success rates across departments for High and Critical priority goals, organizational strategies should further reinforce and possibly expand the practices that support these priorities. For departments underperforming relative to IT, adopting similar strategies or increasing support might enhance their success rates.'}"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"Diagnostic\",\n",
    "    \"insight\": \"There is a consistent higher success rates for critical and high priority goals across departments\",\n",
    "    \"insight_value\": {\n",
    "        \"IT\": {\n",
    "            \"Critical\": \"61.1%\",\n",
    "            \"High\": \"51.8%\"\n",
    "        },\n",
    "        \"Other Departments\": {\n",
    "            \"Critical\": \"Average 58.3%\",\n",
    "            \"High\": \"Average 49.7%\"\n",
    "        }\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"bar\",\n",
    "        \"title\": \"Success Rates of High and Critical Priority Goals Across Departments\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Department and Priority\",\n",
    "            \"value\": \"Finance, HR, IT, Marketing\",\n",
    "            \"description\": \"This categorizes the goals by department and priority level, comparing IT to other departments.\"\n",
    "        },\n",
    "        \"y_axis\": {\n",
    "            \"name\": \"Proportion of Successful Goals\",\n",
    "            \"value\": \"Values based on data\",\n",
    "            \"description\": \"This axis shows the percentage of goals met within different priority categories for each department.\"\n",
    "        },\n",
    "        \"description\": \"The comparison bar graph demonstrates that both Critical and High priority goals generally achieve higher success rates across all departments. The IT department slightly outperforms the average of other departments, suggesting a possible advantage in how these priorities are managed or supported in IT.\"\n",
    "    },\n",
    "    \"question\": \"Are there specific characteristics or patterns that differentiate High/Critical priority goals in the IT department from those in other departments, or is the trend consistent across departments?\",\n",
    "    \"actionable_insight\": \"Given the consistent success rates across departments for High and Critical priority goals, organizational strategies should further reinforce and possibly expand the practices that support these priorities. For departments underperforming relative to IT, adopting similar strategies or increasing support might enhance their success rates.\"\n",
    "}\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 4:** What is the distribution of Critical and High goals in IT department versus other departments?"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### plot distribution of Critical and High priority goals: IT vs other departments\n",
    "\n",
    "This bar graph illustrates the distribution of goals classified as Critical or High priority within the IT department compared to other departments. It quantifies the counts of such goals, offering insights into how prioritization in the IT department stacks up against rest of the organization. This visualization helps to understand if there is any disproportionate focus on higher-priority goals in IT or if this trend is consistent across all departments.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-29T17:17:12.158868Z",
     "iopub.status.busy": "2024-10-29T17:17:12.158072Z",
     "iopub.status.idle": "2024-10-29T17:17:12.693131Z",
     "shell.execute_reply": "2024-10-29T17:17:12.690826Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-10-00c0eb03dc24>: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['IT_or_Other'] = filtered_goals['department'].apply(lambda x: 'IT' if x == 'IT' else 'Other')\n"
     ]
    },
    {
     "data": {
      "image/png": "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FeIm2ePGjUsvoCpJUnM89NBDbLnllss9nYEDBzJ37lwADjvsMMaOHcunPvWpJf0XLlxI375dO/y89Ti33HILZ511FldfffVy11uPtl6biLgrM8e1NbwtXpIkqXK77LILjz76KLfccgu77LIL++67L1tttRVQBDQoDmA//vjjGTlyJNtssw2XXHIJQIfjnHDCCdx2222MGTOGs88+m7e+9a1MnTp1yXx33nln7r333gqXdGme1ShJkiq1cOFCfve737HXXnsBcPfdd/PAAw+85uzA3/zmN0ydOpV7772X559/nu233563vvWtHY5z+umnL9XitdZaa3H++efz7W9/m0ceeYR58+YxevToCpaybbZ49XLt3XIG4Jvf/CYR4RlxkqRKvPLKK0u+j4YPH85RRx0FwPjx49u8JMPtt9/Oe9/7Xvr06cP666/P2972NiZPntzhOK0deOCBXH311SxYsICf/vSnHHHEEd26TF1li9dKoPUtZwCeeuoprrvuOoYPH96kqiRJK5tVV111qd1+LVZfffUuT6vecVZbbTX22GMPrrzySi699FLuuuuuLs+rOxm8VlLHHXccZ5xxBvvtt1+zS+lW//rKNs0uQcth+En3N7sEST3ILrvswo9+9CMmTZrECy+8wB//+EfOPPNMHn744XbHGTRo0JJL8bQ4+uijefe7380uu+zCmmuu2eiyO+Suxl6u5ZYzY8eO5dxzzwXgyiuvZOjQoU3dxy1JUmf2339/Ro0axejRo9ltt90444wzeP3rX9/hOKNGjaJPnz6MHj2as88+G4CxY8eyxhprcOSRR1ZRdods8erl2rrlzNe//nWuu+66ZpcmSVrJtFxKotaECROYMGFCm8NFBGeeeSZnnnlm3eP069ePm266aal+zzzzDIsXL2bPPfdcziVYfrZ49XKtbzlz66238vjjjzN69GhGjBjBtGnT2G677Xj22WebXKkkSd3vwgsvZIcdduDUU09llVWaH3ts8erFXn75ZRYvXsygQYOW3HLmpJNO4rnnnlsyzIgRI5gyZYq3nJEk9UqHH344hx9+eLPLWMLg1YvNmDGD/fffHyiumXLooYcuuWaKJEmqnsGrF9tkk006vTrvE088UU0xkiTJY7wkSZKqYvCSJEmqiMFLkiT1eM8++yyHHHIIm266KWPHjuVd73oXjzzyyGuG22mnnYDiUJqLLrpoSfcpU6bw8Y9/fJnmPWHCBKZMmbJshbfiMV6SJKlLxh5/YbdO764zOz7rMDPZf//9mTRpEhdffDEA9957LzNmzOCNb3wjUJxE1rdvX/785z8D/w1ehx56KADjxo17zT2Lm8Hg1YbuXqFUncsHNbsCSVJ3u/nmm+nXrx8f/vCHl3QbPXo0t9xyy5LbAD388MM88sgjDBw4kLlz53LCCSfw0EMPMWbMGCZNmsS2227LWWedxdVXX83cuXM59thjmTJlChHBySefzP/8z//wkY98hMmTJ/PKK68wceJEvvzlL3f7shi8JElSj/bAAw8wduzYNvvdfffdPPDAA2y88cZLdT/99NOXBC2AW265ZUm/r371qwwePJj77y/uD/viiy8CcOqpp7LWWmuxaNEidt99d+677z5GjRrVrcviMV6SJGmFNX78+NeErs7ccMMNfPSjH13yvOXG2Zdeeinbbbcd2267LQ8++CB/+9vfurVWMHhJkqQebuutt+auu+5qs9/qq6/eLfN4/PHHOeuss7jxxhu577772HvvvZk3b163TLuWwUuSJPVou+22G/Pnz+fcc89d0u2+++7jtttua3ecQYMGMWfOnDb77bHHHnz/+99f8vzFF1/kpZdeYvXVV2fw4MHMmDGD3/3ud923ADUMXpIkqUeLCC6//HJuuOEGNt10U7beems+//nP8/rXv77dcUaNGkWfPn0YPXo0Z5999lL9TjzxRF588UVGjhzJ6NGjufnmmxk9ejTbbrstW2yxBYceeihvectbGrMsmdmQCXencePGZXddP6MentW44rp80JnNLkHLYfhJ9ze7BElteOihh9hyyy2bXUaP1NZrExF3ZWab166wxUuSJKkiBi9JkqSKGLwkSZIqYvCSJEmqiMFLkiSpIgYvSZKkihi8JElSjzdw4MClnp9//vl87GMfA+Ccc87hwgs7vhRU7fDN5E2yJUlSl/zrK9t06/SW9xp+H/7wh7upksazxUuSJK3QTjnlFM466ywAJk+ezKhRoxgzZgzHH388I0eOXDLcM888w1577cXmm2/OZz/72abUaouXJEnq8V555RXGjBmz5PkLL7zAvvvu+5rhjjzySH784x+z4447csIJJyzVb+rUqdxzzz3079+fN73pTRx77LFsuOGGjS59KbZ4SZKkHm/VVVdl6tSpS/6+8pWv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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(['Critical', 'High'])]\n",
    "\n",
    "# Create a new column 'IT_or_Other' to distinguish between IT and other departments\n",
    "filtered_goals['IT_or_Other'] = filtered_goals['department'].apply(lambda x: 'IT' if x == 'IT' else 'Other')\n",
    "\n",
    "# Count the number of goals in each category\n",
    "priority_counts = filtered_goals.groupby(['IT_or_Other', 'priority']).size().reset_index(name='counts')\n",
    "\n",
    "# Plotting\n",
    "plt.figure(figsize=(10, 6))\n",
    "bar_plot = sns.barplot(x='IT_or_Other', y='counts', hue='priority', data=priority_counts)\n",
    "plt.title('Distribution of Critical and High Priority Goals: IT vs. Other Departments')\n",
    "plt.xlabel('Department 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:12.709079Z",
     "iopub.status.busy": "2024-10-29T17:17:12.708246Z",
     "iopub.status.idle": "2024-10-29T17:17:12.735255Z",
     "shell.execute_reply": "2024-10-29T17:17:12.733526Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'diagnostic',\n",
       " 'insight': 'IT department exhibits a higher number of both Critical and High priority goals compared to other departments',\n",
       " 'insight_value': {'IT': {'Critical': '54', 'High': '56'},\n",
       "  'Other Departments': {'Critical': '40', 'High': '35'}},\n",
       " 'plot': {'plot_type': 'bar',\n",
       "  'title': 'Distribution of Critical and High Priority Goals: IT vs. Other Departments',\n",
       "  'x_axis': {'name': 'Department Category',\n",
       "   'value': 'IT, Others',\n",
       "   'description': 'This represents the classification of departments into IT and all other departments combined.'},\n",
       "  'y_axis': {'name': 'Number of Goals',\n",
       "   'value': 'Dynamic based on data',\n",
       "   'description': 'This shows the count of goals classified as either Critical or High priority within each department category.'},\n",
       "  'description': 'The bar graph illustrates that the IT department has higher counts of both Critical (54) and High (56) priority goals compared to other departments, which have 40 Critical and 35 High priority goals respectively. This indicates a heavier concentration of top-priority goals in IT, which may reflect its critical operational role within the organization.'},\n",
       " 'question': 'What is the distribution of Critical and High goals in IT department versus other departments?',\n",
       " 'actionable_insight': 'Given the higher concentration of Critical and High priority goals in the IT department, organizational strategies might need to consider reallocating resources or support to ensure that high-priority goals in other departments are not under-resourced. This could help in balancing goal achievement rates across the organization and ensuring strategic alignment of resources with organizational priorities.'}"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"diagnostic\",\n",
    "    \"insight\": \"IT department exhibits a higher number of both Critical and High priority goals compared to other departments\",\n",
    "    \"insight_value\": {\n",
    "        \"IT\": {\n",
    "            \"Critical\": \"54\",\n",
    "            \"High\": \"56\"\n",
    "        },\n",
    "        \"Other Departments\": {\n",
    "            \"Critical\": \"40\",\n",
    "            \"High\": \"35\"\n",
    "        }\n",
    "    },\n",
    "    \"plot\": {\n",
    "        \"plot_type\": \"bar\",\n",
    "        \"title\": \"Distribution of Critical and High Priority Goals: IT vs. Other Departments\",\n",
    "        \"x_axis\": {\n",
    "            \"name\": \"Department Category\",\n",
    "            \"value\": \"IT, Others\",\n",
    "            \"description\": \"This represents the classification of departments into IT and all other departments combined.\"\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 either Critical or High priority within each department category.\"\n",
    "        },\n",
    "        \"description\": \"The bar graph illustrates that the IT department has higher counts of both Critical (54) and High (56) priority goals compared to other departments, which have 40 Critical and 35 High priority goals respectively. This indicates a heavier concentration of top-priority goals in IT, which may reflect its critical operational role within the organization.\"\n",
    "    },\n",
    "    \"question\": \"What is the distribution of Critical and High goals in IT department versus other departments?\",\n",
    "    \"actionable_insight\": \"Given the higher concentration of Critical and High priority goals in the IT department, organizational strategies might need to consider reallocating resources or support to ensure that high-priority goals in other departments are not under-resourced. This could help in balancing goal achievement rates across the organization and ensuring strategic alignment of resources with organizational priorities.\"\n",
    "}\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Summary of Findings (Flag 75):\n",
    "\n",
    "1. **Priority and Success Correlation**: From Question 1, it was observed that departments consistently achieve higher task completion rates for Critical and High priority tasks, with significant variance in progress on lower priorities. This suggests that prioritization plays a crucial role in task completion success.\n",
    "\n",
    "2. **IT Department's Goal Distribution**: Question 4 highlighted that the IT department has a higher number of both Critical and High priority goals compared to other departments. This indicates a strategic focus on high-priority goals within IT, potentially reflecting its critical operational role.\n",
    "\n",
    "3. **Consistent Success Across Departments**: As noted in Question 3, there is a consistent higher success rate for Critical and High priority goals across all departments. This trend suggests that organizational strategies supporting these priorities are effective and could be expanded to enhance success rates further."
   ]
  }
 ],
 "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
}
