{
  "domain": "project_management",
  "databases": [
    {
      "table_name": "project",
      "description": "Stores project information including basic details, dates, budget, and status",
      "schema": {
        "columns": [
          {
            "name": "project_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the project",
            "optional": false
          },
          {
            "name": "name",
            "type": "VARCHAR(255)",
            "description": "Name of the project",
            "optional": false
          },
          {
            "name": "description",
            "type": "TEXT",
            "description": "Detailed description of the project",
            "optional": false
          },
          {
            "name": "start_date",
            "type": "DATE",
            "description": "Project start date",
            "optional": false
          },
          {
            "name": "end_date",
            "type": "DATE",
            "description": "Project planned end date",
            "optional": false
          },
          {
            "name": "budget",
            "type": "DECIMAL(15,2)",
            "description": "Total project budget in currency units",
            "optional": true
          },
          {
            "name": "project_manager",
            "type": "VARCHAR(255)",
            "description": "Name of the project manager",
            "optional": true
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Current project status",
            "default": "planning",
            "optional": false,
            "enum": [
              "planning",
              "active",
              "on_hold",
              "completed",
              "cancelled"
            ]
          },
          {
            "name": "completion_percentage",
            "type": "DECIMAL(5,2)",
            "description": "Current completion percentage",
            "default": "0.00",
            "optional": false
          },
          {
            "name": "creation_timestamp",
            "type": "TIMESTAMP",
            "description": "Timestamp when project was created",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          },
          {
            "name": "updated_timestamp",
            "type": "TIMESTAMP",
            "description": "Timestamp when project was last updated",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          }
        ],
        "primary_key": "project_id"
      }
    },
    {
      "table_name": "task",
      "description": "Stores task information including assignment, status, progress, and scheduling details",
      "schema": {
        "columns": [
          {
            "name": "task_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the task",
            "optional": false
          },
          {
            "name": "project_id",
            "type": "VARCHAR(10)",
            "description": "Reference to parent project",
            "optional": false,
            "references": "project.project_id"
          },
          {
            "name": "task_name",
            "type": "VARCHAR(255)",
            "description": "Name of the task",
            "optional": false
          },
          {
            "name": "description",
            "type": "TEXT",
            "description": "Detailed description of the task",
            "optional": true
          },
          {
            "name": "assigned_to",
            "type": "VARCHAR(255)",
            "description": "Name or ID of the person assigned to the task",
            "optional": false
          },
          {
            "name": "due_date",
            "type": "DATE",
            "description": "Task due date",
            "optional": false
          },
          {
            "name": "estimated_hours",
            "type": "DECIMAL(10,2)",
            "description": "Estimated hours to complete the task",
            "optional": true
          },
          {
            "name": "priority",
            "type": "VARCHAR(20)",
            "description": "Task priority level",
            "default": "medium",
            "optional": false,
            "enum": [
              "low",
              "medium",
              "high",
              "critical"
            ]
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Current task status",
            "default": "not_started",
            "optional": false,
            "enum": [
              "not_started",
              "in_progress",
              "blocked",
              "completed",
              "cancelled"
            ]
          },
          {
            "name": "completion_percentage",
            "type": "DECIMAL(5,2)",
            "description": "Task completion percentage",
            "default": "0.00",
            "optional": false
          },
          {
            "name": "creation_timestamp",
            "type": "TIMESTAMP",
            "description": "Timestamp when task was created",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          },
          {
            "name": "updated_timestamp",
            "type": "TIMESTAMP",
            "description": "Timestamp when task was last updated",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          }
        ],
        "primary_key": "task_id"
      }
    },
    {
      "table_name": "milestone",
      "description": "Stores project milestone information including target dates and completion status",
      "schema": {
        "columns": [
          {
            "name": "milestone_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the milestone",
            "optional": false
          },
          {
            "name": "project_id",
            "type": "VARCHAR(10)",
            "description": "Reference to parent project",
            "optional": false,
            "references": "project.project_id"
          },
          {
            "name": "milestone_name",
            "type": "VARCHAR(255)",
            "description": "Name of the milestone",
            "optional": false
          },
          {
            "name": "target_date",
            "type": "DATE",
            "description": "Target completion date",
            "optional": false
          },
          {
            "name": "is_completed",
            "type": "BOOLEAN",
            "description": "Whether the milestone is completed",
            "default": "false",
            "optional": false
          },
          {
            "name": "actual_completion_date",
            "type": "DATE",
            "description": "Actual completion date",
            "optional": true
          },
          {
            "name": "completion_notes",
            "type": "TEXT",
            "description": "Notes about milestone completion",
            "optional": true
          },
          {
            "name": "creation_timestamp",
            "type": "TIMESTAMP",
            "description": "Timestamp when milestone was created",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          },
          {
            "name": "updated_timestamp",
            "type": "TIMESTAMP",
            "description": "Timestamp when milestone was last updated",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          }
        ],
        "primary_key": "milestone_id"
      }
    },
    {
      "table_name": "milestone_deliverable",
      "description": "Stores deliverables associated with milestones",
      "schema": {
        "columns": [
          {
            "name": "deliverable_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the deliverable",
            "optional": false
          },
          {
            "name": "milestone_id",
            "type": "VARCHAR(10)",
            "description": "Reference to parent milestone",
            "optional": false,
            "references": "milestone.milestone_id"
          },
          {
            "name": "deliverable_description",
            "type": "TEXT",
            "description": "Description of the deliverable",
            "optional": false
          }
        ],
        "primary_key": "deliverable_id"
      }
    },
    {
      "table_name": "risk",
      "description": "Stores project risk information including assessment, status, and mitigation details",
      "schema": {
        "columns": [
          {
            "name": "risk_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the risk",
            "optional": false
          },
          {
            "name": "project_id",
            "type": "VARCHAR(10)",
            "description": "Reference to parent project",
            "optional": false,
            "references": "project.project_id"
          },
          {
            "name": "risk_name",
            "type": "VARCHAR(255)",
            "description": "Name of the risk",
            "optional": false
          },
          {
            "name": "description",
            "type": "TEXT",
            "description": "Detailed description of the risk",
            "optional": true
          },
          {
            "name": "probability",
            "type": "DECIMAL(3,2)",
            "description": "Probability of risk occurrence (0-1)",
            "optional": false
          },
          {
            "name": "impact",
            "type": "INTEGER",
            "description": "Impact level if risk occurs (1-5)",
            "optional": false
          },
          {
            "name": "category",
            "type": "VARCHAR(20)",
            "description": "Risk category",
            "optional": false,
            "enum": [
              "technical",
              "resource",
              "schedule",
              "budget",
              "external",
              "quality"
            ]
          },
          {
            "name": "owner",
            "type": "VARCHAR(255)",
            "description": "Name or ID of risk owner",
            "optional": false
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Current risk status",
            "default": "identified",
            "optional": false,
            "enum": [
              "identified",
              "assessed",
              "mitigated",
              "accepted",
              "occurred",
              "closed"
            ]
          },
          {
            "name": "risk_score",
            "type": "DECIMAL(5,2)",
            "description": "Calculated risk score (probability × impact)",
            "optional": false
          },
          {
            "name": "priority",
            "type": "VARCHAR(20)",
            "description": "Risk priority level",
            "optional": false,
            "enum": [
              "low",
              "medium",
              "high",
              "critical"
            ]
          },
          {
            "name": "creation_timestamp",
            "type": "TIMESTAMP",
            "description": "Timestamp when risk was created",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          },
          {
            "name": "updated_timestamp",
            "type": "TIMESTAMP",
            "description": "Timestamp when risk was last updated",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          }
        ],
        "primary_key": "risk_id"
      }
    },
    {
      "table_name": "risk_mitigation_action",
      "description": "Stores mitigation actions taken for risks",
      "schema": {
        "columns": [
          {
            "name": "action_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the mitigation action",
            "optional": false
          },
          {
            "name": "risk_id",
            "type": "VARCHAR(10)",
            "description": "Reference to parent risk",
            "optional": false,
            "references": "risk.risk_id"
          },
          {
            "name": "action_description",
            "type": "TEXT",
            "description": "Description of the mitigation action",
            "optional": false
          },
          {
            "name": "action_date",
            "type": "TIMESTAMP",
            "description": "When the action was taken",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          }
        ],
        "primary_key": "action_id"
      }
    },
    {
      "table_name": "resource_allocation",
      "description": "Stores resource allocation information for tasks including hours and time periods",
      "schema": {
        "columns": [
          {
            "name": "allocation_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the resource allocation",
            "optional": false
          },
          {
            "name": "task_id",
            "type": "VARCHAR(10)",
            "description": "Reference to task",
            "optional": false,
            "references": "task.task_id"
          },
          {
            "name": "resource_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the resource",
            "optional": false
          },
          {
            "name": "allocated_hours",
            "type": "DECIMAL(10,2)",
            "description": "Number of hours allocated",
            "optional": false
          },
          {
            "name": "start_date",
            "type": "DATE",
            "description": "Allocation start date",
            "optional": false
          },
          {
            "name": "end_date",
            "type": "DATE",
            "description": "Allocation end date",
            "optional": false
          },
          {
            "name": "creation_timestamp",
            "type": "TIMESTAMP",
            "description": "Timestamp when allocation was created",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          }
        ],
        "primary_key": "allocation_id"
      }
    }
  ],
  "tools": [
    {
      "name": "update_task_progress",
      "description": "Update the progress percentage and status of a task",
      "group": "project_management",
      "object_category": "task_management",
      "action_category": "data_modification",
      "pre_condition": "Task must exist in the system",
      "post_condition": "Task progress is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "task_id": {
            "description": "Unique identifier of the task",
            "type": "string",
            "examples": [
              "TSK-2024-001"
            ]
          },
          "progress_percentage": {
            "description": "New progress percentage (0-100)",
            "type": "number",
            "examples": [
              75
            ]
          },
          "status": {
            "description": "New task status",
            "type": "string",
            "enum": [
              "not_started",
              "in_progress",
              "blocked",
              "completed",
              "cancelled"
            ],
            "examples": [
              "in_progress"
            ]
          },
          "notes": {
            "description": "Progress update notes",
            "type": "string",
            "examples": [
              "Completed initial mockups, awaiting feedback"
            ]
          }
        },
        "required": [
          "task_id",
          "progress_percentage"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the progress update was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_timestamp": {
            "description": "Timestamp when progress was updated in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-10 15:45:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "task"
      ]
    },
    {
      "name": "assess_project_health",
      "description": "Assess overall project health by analyzing schedule, budget, scope, quality, and risk indicators",
      "group": "project_management",
      "object_category": "performance_management",
      "action_category": "data_analysis",
      "pre_condition": "Project metrics and indicators must be provided",
      "post_condition": "Project health assessment is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "schedule_performance_index": {
            "description": "Schedule performance index (SPI) value",
            "type": "number",
            "examples": [
              0.95
            ]
          },
          "cost_performance_index": {
            "description": "Cost performance index (CPI) value",
            "type": "number",
            "examples": [
              1.05
            ]
          },
          "scope_change_count": {
            "description": "Number of scope changes since baseline",
            "type": "integer",
            "examples": [
              3
            ]
          },
          "quality_defect_rate": {
            "description": "Percentage of deliverables with quality defects",
            "type": "number",
            "examples": [
              5.0
            ]
          },
          "high_risk_count": {
            "description": "Number of high-priority active risks",
            "type": "integer",
            "examples": [
              2
            ]
          }
        },
        "required": [
          "schedule_performance_index",
          "cost_performance_index",
          "scope_change_count",
          "quality_defect_rate",
          "high_risk_count"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "health_status": {
            "description": "Overall project health status",
            "type": "string",
            "enum": [
              "healthy",
              "at_risk",
              "critical"
            ],
            "examples": [
              "at_risk"
            ]
          },
          "health_score": {
            "description": "Numerical health score from 0-100",
            "type": "number",
            "examples": [
              72.5
            ]
          },
          "key_concerns": {
            "description": "List of primary concerns affecting project health",
            "type": "array",
            "examples": [
              [
                "Schedule delay",
                "Multiple scope changes"
              ]
            ]
          },
          "recommendations": {
            "description": "List of recommended actions to improve project health",
            "type": "array",
            "examples": [
              [
                "Accelerate critical path tasks",
                "Implement change control process"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "create_task",
      "description": "Create a new task within a project with details including name, assignee, and due date",
      "group": "project_management",
      "object_category": "task_management",
      "action_category": "data_creation",
      "pre_condition": "Project must exist in the system",
      "post_condition": "New task is created and assigned to project",
      "parameters": {
        "type": "object",
        "properties": {
          "project_id": {
            "description": "Unique identifier of the parent project",
            "type": "string",
            "examples": [
              "PRJ-2024-001"
            ]
          },
          "task_name": {
            "description": "Name of the task",
            "type": "string",
            "examples": [
              "Design homepage mockup"
            ]
          },
          "description": {
            "description": "Detailed description of the task",
            "type": "string",
            "examples": [
              "Create wireframes and high-fidelity mockups for homepage"
            ]
          },
          "assigned_to": {
            "description": "Name or ID of the person assigned to the task",
            "type": "string",
            "examples": [
              "jane_smith"
            ]
          },
          "due_date": {
            "description": "Task due date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-15"
            ]
          },
          "estimated_hours": {
            "description": "Estimated hours to complete the task",
            "type": "number",
            "examples": [
              16
            ]
          },
          "priority": {
            "description": "Task priority level",
            "type": "string",
            "enum": [
              "low",
              "medium",
              "high",
              "critical"
            ],
            "examples": [
              "high"
            ]
          }
        },
        "required": [
          "project_id",
          "task_name",
          "assigned_to",
          "due_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "task_id": {
            "description": "Unique identifier for the created task",
            "type": "string",
            "examples": [
              "TSK-2024-001"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when task was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-01 10:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "task",
        "project"
      ]
    },
    {
      "name": "calculate_productivity_metrics",
      "description": "Calculate team productivity metrics including throughput, cycle time, and lead time",
      "group": "project_management",
      "object_category": "performance_management",
      "action_category": "computation",
      "pre_condition": "Work item completion data must be provided",
      "post_condition": "Productivity metrics are calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "completed_items": {
            "description": "List of completed item dictionaries containing name, start_date (yyyy-mm-dd HH:MM:SS), commit_date (yyyy-mm-dd HH:MM:SS), and completion_date (yyyy-mm-dd HH:MM:SS)",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "name": "task1",
                  "start_date": "2024-01-01 09:00:00",
                  "commit_date": "2024-01-05 09:00:00",
                  "completion_date": "2024-01-10 17:00:00"
                }
              ]
            ]
          },
          "time_period_days": {
            "description": "Time period for throughput calculation in days",
            "type": "integer",
            "examples": [
              30
            ]
          }
        },
        "required": [
          "completed_items",
          "time_period_days"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "throughput": {
            "description": "Number of items completed per day",
            "type": "number",
            "examples": [
              2.5
            ]
          },
          "average_cycle_time_days": {
            "description": "Average time from commit to completion in days",
            "type": "number",
            "examples": [
              5.5
            ]
          },
          "average_lead_time_days": {
            "description": "Average time from start to completion in days",
            "type": "number",
            "examples": [
              9.5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "validate_project_closure_readiness",
      "description": "Validate that all project closure criteria are met including deliverable acceptance, documentation, and lessons learned",
      "group": "project_management",
      "object_category": "closure_management",
      "action_category": "validation",
      "pre_condition": "Project closure data must be provided",
      "post_condition": "Closure readiness assessment is completed",
      "parameters": {
        "type": "object",
        "properties": {
          "deliverables_accepted": {
            "description": "Whether all deliverables have been formally accepted",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "documentation_complete": {
            "description": "Whether all project documentation is complete",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "lessons_learned_captured": {
            "description": "Whether lessons learned have been documented",
            "type": "boolean",
            "examples": [
              false
            ]
          },
          "resources_released": {
            "description": "Whether all project resources have been released",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "financials_closed": {
            "description": "Whether all financial accounts have been closed",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "stakeholder_signoff": {
            "description": "Whether final stakeholder sign-off has been obtained",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        },
        "required": [
          "deliverables_accepted",
          "documentation_complete",
          "lessons_learned_captured",
          "resources_released",
          "financials_closed",
          "stakeholder_signoff"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "ready_for_closure": {
            "description": "Whether project is ready for formal closure",
            "type": "boolean",
            "examples": [
              false
            ]
          },
          "pending_items": {
            "description": "List of items that need to be completed before closure",
            "type": "array",
            "examples": [
              [
                "Complete lessons learned documentation"
              ]
            ]
          },
          "closure_checklist": {
            "description": "Dictionary showing completion status of all closure criteria",
            "type": "object",
            "examples": [
              {
                "deliverables_accepted": true,
                "lessons_learned_captured": false
              }
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "generate_gantt_chart_data",
      "description": "Generate data structure for Gantt chart visualization including task bars, dependencies, and milestones",
      "group": "project_management",
      "object_category": "communication_management",
      "action_category": "data_modification",
      "pre_condition": "Task schedule and dependency data must be provided",
      "post_condition": "Gantt chart data structure is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "tasks": {
            "description": "List of task dictionaries containing name, start_date (yyyy-mm-dd), end_date (yyyy-mm-dd), and progress percentage",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "name": "design",
                  "start_date": "2024-01-01",
                  "end_date": "2024-01-10",
                  "progress": 100
                }
              ]
            ]
          },
          "dependencies": {
            "description": "List of task dependencies where each dependency is [predecessor, successor]",
            "type": "array",
            "items": {
              "type": "array"
            },
            "examples": [
              [
                [
                  "design",
                  "development"
                ]
              ]
            ]
          },
          "milestones": {
            "description": "List of milestone dictionaries containing name and date (yyyy-mm-dd)",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "name": "Design Complete",
                  "date": "2024-01-10"
                }
              ]
            ]
          }
        },
        "required": [
          "tasks",
          "dependencies"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "gantt_data": {
            "description": "Structured data for Gantt chart rendering including task bars and dependency lines",
            "type": "object",
            "examples": [
              {
                "tasks": [],
                "dependencies": [],
                "milestones": [],
                "timeline": {}
              }
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_milestone_completion_percentage",
      "description": "Calculate the completion percentage of project milestones based on completed versus total milestones",
      "group": "project_management",
      "object_category": "schedule_management",
      "action_category": "computation",
      "pre_condition": "Milestone status data must be provided",
      "post_condition": "Milestone completion percentage is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "total_milestones": {
            "description": "Total number of milestones in the project",
            "type": "integer",
            "examples": [
              10
            ]
          },
          "completed_milestones": {
            "description": "Number of completed milestones",
            "type": "integer",
            "examples": [
              7
            ]
          }
        },
        "required": [
          "total_milestones",
          "completed_milestones"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "completion_percentage": {
            "description": "Milestone completion percentage",
            "type": "number",
            "examples": [
              70.0
            ]
          },
          "remaining_milestones": {
            "description": "Number of remaining milestones",
            "type": "integer",
            "examples": [
              3
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_resource_leveling",
      "description": "Calculate resource leveling adjustments to resolve resource over-allocations while minimizing schedule impact",
      "group": "project_management",
      "object_category": "resource_management",
      "action_category": "optimization",
      "pre_condition": "Task schedule and resource allocation data must be provided",
      "post_condition": "Resource leveling plan is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "tasks": {
            "description": "List of task dictionaries containing name, start_date (yyyy-mm-dd), duration_days, assigned_resources, and is_on_critical_path",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "name": "task1",
                  "start_date": "2024-01-01",
                  "duration_days": 5,
                  "assigned_resources": [
                    "john"
                  ],
                  "is_on_critical_path": false
                }
              ]
            ]
          },
          "resource_capacity": {
            "description": "Dictionary mapping resource names to daily capacity hours",
            "type": "object",
            "examples": [
              {
                "john": 8,
                "jane": 8
              }
            ]
          }
        },
        "required": [
          "tasks",
          "resource_capacity"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "leveled_schedule": {
            "description": "List of tasks with adjusted start dates after leveling",
            "type": "array",
            "examples": [
              [
                {
                  "name": "task1",
                  "new_start_date": "2024-01-03",
                  "delay_days": 2
                }
              ]
            ]
          },
          "schedule_impact_days": {
            "description": "Total schedule delay caused by leveling in days",
            "type": "integer",
            "examples": [
              3
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "generate_status_report",
      "description": "Generate comprehensive project status report including progress, issues, risks, and upcoming activities",
      "group": "project_management",
      "object_category": "performance_management",
      "action_category": "data_creation",
      "pre_condition": "Project status data must be provided",
      "post_condition": "Status report is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "name": {
            "description": "Name of the project",
            "type": "string",
            "examples": [
              "Mobile App Development"
            ]
          },
          "reporting_period": {
            "description": "Reporting period description",
            "type": "string",
            "examples": [
              "Week of 2024-01-15"
            ]
          },
          "status": {
            "description": "Overall project status",
            "type": "string",
            "enum": [
              "on_track",
              "at_risk",
              "off_track"
            ],
            "examples": [
              "on_track"
            ]
          },
          "completed_milestones": {
            "description": "List of milestones completed during period",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Design Phase Complete",
                "Development Sprint 1 Complete"
              ]
            ]
          },
          "active_issues": {
            "description": "List of active issue descriptions",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "API integration delay",
                "Resource availability concern"
              ]
            ]
          },
          "top_risks": {
            "description": "List of top risk descriptions",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Third-party dependency delay",
                "Budget overrun risk"
              ]
            ]
          },
          "upcoming_activities": {
            "description": "List of planned activities for next period",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Begin testing phase",
                "Stakeholder demo"
              ]
            ]
          }
        },
        "required": [
          "name",
          "reporting_period",
          "status",
          "completed_milestones",
          "active_issues",
          "top_risks",
          "upcoming_activities"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "status_report": {
            "description": "Structured status report document",
            "type": "object",
            "examples": [
              {
                "header": {},
                "executive_summary": "",
                "detailed_sections": {}
              }
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_task_details",
      "description": "Retrieve complete details of a specific task including status, progress, and metadata",
      "group": "project_management",
      "object_category": "task_management",
      "action_category": "data_retrieval",
      "pre_condition": "Task must exist in the system",
      "post_condition": "Task details are retrieved",
      "parameters": {
        "type": "object",
        "properties": {
          "task_id": {
            "description": "Unique identifier of the task",
            "type": "string",
            "examples": [
              "TSK-2024-001"
            ]
          }
        },
        "required": [
          "task_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "task_id": {
            "description": "Unique identifier of the task",
            "type": "string",
            "examples": [
              "TSK-2024-001"
            ]
          },
          "task_name": {
            "description": "Name of the task",
            "type": "string",
            "examples": [
              "Design homepage mockup"
            ]
          },
          "project_id": {
            "description": "Unique identifier of the parent project",
            "type": "string",
            "examples": [
              "PRJ-2024-001"
            ]
          },
          "assigned_to": {
            "description": "Name or ID of the person assigned to the task",
            "type": "string",
            "examples": [
              "jane_smith"
            ]
          },
          "status": {
            "description": "Current task status",
            "type": "string",
            "enum": [
              "not_started",
              "in_progress",
              "blocked",
              "completed",
              "cancelled"
            ],
            "examples": [
              "in_progress"
            ]
          },
          "completion_percentage": {
            "description": "Task completion percentage",
            "type": "number",
            "examples": [
              60
            ]
          },
          "due_date": {
            "description": "Task due date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-15"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "task"
      ]
    },
    {
      "name": "calculate_team_velocity",
      "description": "Calculate team velocity based on completed story points over multiple sprints",
      "group": "project_management",
      "object_category": "performance_management",
      "action_category": "computation",
      "pre_condition": "Sprint completion data must be provided",
      "post_condition": "Team velocity metrics are calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "sprint_story_points": {
            "description": "List of story points completed in each sprint",
            "type": "array",
            "items": {
              "type": "integer"
            },
            "examples": [
              [
                25,
                30,
                28,
                32,
                27
              ]
            ]
          }
        },
        "required": [
          "sprint_story_points"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "average_velocity": {
            "description": "Average story points completed per sprint",
            "type": "number",
            "examples": [
              28.4
            ]
          },
          "velocity_trend": {
            "description": "Velocity trend indicator",
            "type": "string",
            "enum": [
              "increasing",
              "stable",
              "decreasing"
            ],
            "examples": [
              "stable"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "allocate_resource_to_task",
      "description": "Allocate a resource to a specific task with defined hours and time period",
      "group": "project_management",
      "object_category": "resource_management",
      "action_category": "data_creation",
      "pre_condition": "Task and resource must exist in the system",
      "post_condition": "Resource is allocated to task",
      "parameters": {
        "type": "object",
        "properties": {
          "task_id": {
            "description": "Unique identifier of the task",
            "type": "string",
            "examples": [
              "TSK-2024-001"
            ]
          },
          "resource_id": {
            "description": "Unique identifier of the resource",
            "type": "string",
            "examples": [
              "RES-001"
            ]
          },
          "allocated_hours": {
            "description": "Number of hours to allocate",
            "type": "number",
            "examples": [
              40
            ]
          },
          "start_date": {
            "description": "Allocation start date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-10"
            ]
          },
          "end_date": {
            "description": "Allocation end date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-15"
            ]
          }
        },
        "required": [
          "task_id",
          "resource_id",
          "allocated_hours",
          "start_date",
          "end_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "allocation_id": {
            "description": "Unique identifier for the resource allocation",
            "type": "string",
            "examples": [
              "ALLOC-2024-001"
            ]
          },
          "utilization_impact": {
            "description": "Impact on resource utilization percentage",
            "type": "number",
            "examples": [
              25.0
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "resource_allocation",
        "task"
      ]
    },
    {
      "name": "calculate_project_buffer",
      "description": "Calculate project buffer size using critical chain methodology based on task uncertainties",
      "group": "project_management",
      "object_category": "schedule_management",
      "action_category": "computation",
      "pre_condition": "Task duration estimates must be provided",
      "post_condition": "Project buffer is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "tasks": {
            "description": "List of task dictionaries containing name, optimistic_duration, most_likely_duration, and pessimistic_duration",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "name": "development",
                  "optimistic_duration": 15,
                  "most_likely_duration": 20,
                  "pessimistic_duration": 30
                }
              ]
            ]
          },
          "buffer_percentage": {
            "description": "Percentage of safety time to allocate as buffer (typically 50%)",
            "type": "number",
            "examples": [
              50
            ]
          }
        },
        "required": [
          "tasks",
          "buffer_percentage"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "project_buffer_days": {
            "description": "Calculated project buffer in days",
            "type": "number",
            "examples": [
              12.5
            ]
          },
          "total_aggressive_duration": {
            "description": "Total project duration using aggressive estimates in days",
            "type": "number",
            "examples": [
              50
            ]
          },
          "buffered_project_duration": {
            "description": "Total project duration including buffer in days",
            "type": "number",
            "examples": [
              62.5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "generate_work_breakdown_structure",
      "description": "Generate a hierarchical work breakdown structure from project scope by decomposing deliverables into manageable work packages",
      "group": "project_management",
      "object_category": "scope_management",
      "action_category": "data_creation",
      "pre_condition": "Project scope and deliverables must be provided",
      "post_condition": "WBS hierarchy is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "name": {
            "description": "Name of the project",
            "type": "string",
            "examples": [
              "Website Redesign Project"
            ]
          },
          "deliverables": {
            "description": "List of major project deliverables",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "New Website Design",
                "Content Migration",
                "User Training"
              ]
            ]
          },
          "decomposition_levels": {
            "description": "Number of hierarchical levels to decompose (1-5)",
            "type": "integer",
            "examples": [
              3
            ]
          }
        },
        "required": [
          "name",
          "deliverables",
          "decomposition_levels"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "wbs_structure": {
            "description": "Hierarchical dictionary representing the WBS with nested work packages",
            "type": "object",
            "examples": [
              {
                "1": {
                  "name": "Website Redesign Project",
                  "1.1": {
                    "name": "New Website Design"
                  }
                }
              }
            ]
          },
          "total_work_packages": {
            "description": "Total number of work packages generated",
            "type": "integer",
            "examples": [
              15
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "update_risk_status",
      "description": "Update the status and details of an existing risk",
      "group": "project_management",
      "object_category": "risk_management",
      "action_category": "data_modification",
      "pre_condition": "Risk must exist in the system",
      "post_condition": "Risk status is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "risk_id": {
            "description": "Unique identifier of the risk",
            "type": "string",
            "examples": [
              "RSK-2024-001"
            ]
          },
          "status": {
            "description": "Current risk status",
            "type": "string",
            "enum": [
              "identified",
              "assessed",
              "mitigated",
              "accepted",
              "occurred",
              "closed"
            ],
            "examples": [
              "mitigated"
            ]
          },
          "mitigation_actions": {
            "description": "List of mitigation actions taken",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Implemented fallback API",
                "Added monitoring alerts"
              ]
            ]
          },
          "probability": {
            "description": "Updated probability after mitigation (0-1)",
            "type": "number",
            "examples": [
              0.3
            ]
          }
        },
        "required": [
          "risk_id",
          "status"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the status update was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_risk_score": {
            "description": "Updated risk score after changes",
            "type": "number",
            "examples": [
              1.2
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "risk",
        "risk_mitigation_action"
      ]
    },
    {
      "name": "create_risk",
      "description": "Create and register a new risk for a project with assessment details",
      "group": "project_management",
      "object_category": "risk_management",
      "action_category": "data_creation",
      "pre_condition": "Project must exist in the system",
      "post_condition": "New risk is registered",
      "parameters": {
        "type": "object",
        "properties": {
          "project_id": {
            "description": "Unique identifier of the project",
            "type": "string",
            "examples": [
              "PRJ-2024-001"
            ]
          },
          "risk_name": {
            "description": "Name of the risk",
            "type": "string",
            "examples": [
              "Third-party API dependency"
            ]
          },
          "description": {
            "description": "Detailed description of the risk",
            "type": "string",
            "examples": [
              "Project depends on external API that may have downtime"
            ]
          },
          "probability": {
            "description": "Probability of risk occurrence (0-1)",
            "type": "number",
            "examples": [
              0.6
            ]
          },
          "impact": {
            "description": "Impact level if risk occurs (1-5)",
            "type": "integer",
            "examples": [
              4
            ]
          },
          "category": {
            "description": "Risk category",
            "type": "string",
            "enum": [
              "technical",
              "resource",
              "schedule",
              "budget",
              "external",
              "quality"
            ],
            "examples": [
              "external"
            ]
          },
          "owner": {
            "description": "Name or ID of risk owner",
            "type": "string",
            "examples": [
              "tech_lead"
            ]
          }
        },
        "required": [
          "project_id",
          "risk_name",
          "probability",
          "impact",
          "category",
          "owner"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "risk_id": {
            "description": "Unique identifier for the created risk",
            "type": "string",
            "examples": [
              "RSK-2024-001"
            ]
          },
          "risk_score": {
            "description": "Calculated risk score (probability × impact)",
            "type": "number",
            "examples": [
              2.4
            ]
          },
          "priority": {
            "description": "Risk priority level",
            "type": "string",
            "enum": [
              "low",
              "medium",
              "high",
              "critical"
            ],
            "examples": [
              "high"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "risk",
        "project"
      ]
    },
    {
      "name": "calculate_budget_variance",
      "description": "Calculate budget variance by comparing planned budget against actual spending for budget categories",
      "group": "project_management",
      "object_category": "financial_management",
      "action_category": "computation",
      "pre_condition": "Planned and actual budget data must be provided",
      "post_condition": "Budget variances are calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "planned_budget": {
            "description": "Dictionary mapping budget categories to planned amounts in currency units",
            "type": "object",
            "examples": [
              {
                "labor": 50000,
                "materials": 30000,
                "equipment": 20000
              }
            ]
          },
          "actual_spending": {
            "description": "Dictionary mapping budget categories to actual spending amounts in currency units",
            "type": "object",
            "examples": [
              {
                "labor": 55000,
                "materials": 28000,
                "equipment": 22000
              }
            ]
          }
        },
        "required": [
          "planned_budget",
          "actual_spending"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "variances": {
            "description": "Dictionary mapping categories to variance amounts (negative means over budget)",
            "type": "object",
            "examples": [
              {
                "labor": -5000,
                "materials": 2000,
                "equipment": -2000
              }
            ]
          },
          "total_variance": {
            "description": "Total budget variance across all categories in currency units",
            "type": "number",
            "examples": [
              -5000
            ]
          },
          "variance_percentage": {
            "description": "Overall variance as percentage of total planned budget",
            "type": "number",
            "examples": [
              -5.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "generate_communication_plan",
      "description": "Generate project communication plan defining stakeholder communication needs, frequency, and channels",
      "group": "project_management",
      "object_category": "communication_management",
      "action_category": "data_creation",
      "pre_condition": "Stakeholder and project data must be provided",
      "post_condition": "Communication plan is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "stakeholders": {
            "description": "List of stakeholder dictionaries containing name, role, and information_needs",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "name": "Project Sponsor",
                  "role": "executive",
                  "information_needs": [
                    "status",
                    "budget",
                    "risks"
                  ]
                }
              ]
            ]
          },
          "project_phase": {
            "description": "Current project phase",
            "type": "string",
            "enum": [
              "initiation",
              "planning",
              "execution",
              "monitoring",
              "closing"
            ],
            "examples": [
              "execution"
            ]
          }
        },
        "required": [
          "stakeholders",
          "project_phase"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "communication_plan": {
            "description": "List of communication items with stakeholder, frequency, channel, and content",
            "type": "array",
            "examples": [
              [
                {
                  "stakeholder": "Project Sponsor",
                  "frequency": "weekly",
                  "channel": "email",
                  "content": "status report"
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "update_project_status",
      "description": "Update the status of a project to reflect current state",
      "group": "project_management",
      "object_category": "project_management",
      "action_category": "data_modification",
      "pre_condition": "Project must exist in the system",
      "post_condition": "Project status is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "project_id": {
            "description": "Unique identifier of the project",
            "type": "string",
            "examples": [
              "PRJ-2024-001"
            ]
          },
          "status": {
            "description": "New status for the project",
            "type": "string",
            "enum": [
              "planning",
              "active",
              "on_hold",
              "completed",
              "cancelled"
            ],
            "examples": [
              "on_hold"
            ]
          },
          "status_reason": {
            "description": "Reason for the status change",
            "type": "string",
            "examples": [
              "Waiting for budget approval"
            ]
          }
        },
        "required": [
          "project_id",
          "status"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the status update was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_timestamp": {
            "description": "Timestamp when status was updated in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-15 14:30:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "project"
      ]
    },
    {
      "name": "calculate_contingency_reserve",
      "description": "Calculate appropriate contingency reserve for project budget based on risk assessment and uncertainty",
      "group": "project_management",
      "object_category": "financial_management",
      "action_category": "computation",
      "pre_condition": "Budget and risk data must be provided",
      "post_condition": "Contingency reserve is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "budget": {
            "description": "Base project budget in currency units",
            "type": "number",
            "examples": [
              500000
            ]
          },
          "risk_exposure": {
            "description": "Total risk exposure amount in currency units",
            "type": "number",
            "examples": [
              75000
            ]
          },
          "project_complexity": {
            "description": "Project complexity level",
            "type": "string",
            "enum": [
              "low",
              "medium",
              "high"
            ],
            "examples": [
              "medium"
            ]
          },
          "historical_variance_percentage": {
            "description": "Historical budget variance percentage from similar projects",
            "type": "number",
            "examples": [
              12.5
            ]
          }
        },
        "required": [
          "budget",
          "risk_exposure",
          "project_complexity"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "recommended_contingency": {
            "description": "Recommended contingency reserve in currency units",
            "type": "number",
            "examples": [
              62500
            ]
          },
          "contingency_percentage": {
            "description": "Contingency as percentage of base budget",
            "type": "number",
            "examples": [
              12.5
            ]
          },
          "total_budget_with_contingency": {
            "description": "Total budget including contingency in currency units",
            "type": "number",
            "examples": [
              562500
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_earned_value_metrics",
      "description": "Calculate earned value management metrics including CPI, SPI, EAC, and ETC for project performance analysis",
      "group": "project_management",
      "object_category": "performance_management",
      "action_category": "computation",
      "pre_condition": "Planned value, earned value, and actual cost must be provided",
      "post_condition": "EVM metrics are calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "planned_value": {
            "description": "Planned value (PV) or budgeted cost of work scheduled in currency units",
            "type": "number",
            "examples": [
              100000
            ]
          },
          "earned_value": {
            "description": "Earned value (EV) or budgeted cost of work performed in currency units",
            "type": "number",
            "examples": [
              80000
            ]
          },
          "actual_cost": {
            "description": "Actual cost (AC) or actual cost of work performed in currency units",
            "type": "number",
            "examples": [
              90000
            ]
          },
          "budget": {
            "description": "Total planned budget for the project in currency units",
            "type": "number",
            "examples": [
              200000
            ]
          }
        },
        "required": [
          "planned_value",
          "earned_value",
          "actual_cost",
          "budget"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "cost_variance": {
            "description": "Cost variance (CV = EV - AC) in currency units",
            "type": "number",
            "examples": [
              -10000
            ]
          },
          "schedule_variance": {
            "description": "Schedule variance (SV = EV - PV) in currency units",
            "type": "number",
            "examples": [
              -20000
            ]
          },
          "cost_performance_index": {
            "description": "Cost performance index (CPI = EV / AC)",
            "type": "number",
            "examples": [
              0.89
            ]
          },
          "schedule_performance_index": {
            "description": "Schedule performance index (SPI = EV / PV)",
            "type": "number",
            "examples": [
              0.8
            ]
          },
          "estimate_at_completion": {
            "description": "Estimate at completion (EAC = BAC / CPI) in currency units",
            "type": "number",
            "examples": [
              224719
            ]
          },
          "estimate_to_complete": {
            "description": "Estimate to complete (ETC = EAC - AC) in currency units",
            "type": "number",
            "examples": [
              134719
            ]
          }
        }
      },
      "raises": "ZeroDivisionError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_project_details",
      "description": "Retrieve complete details of a specific project including all metadata, status, and key metrics",
      "group": "project_management",
      "object_category": "project_management",
      "action_category": "data_retrieval",
      "pre_condition": "Project must exist in the system",
      "post_condition": "Project details are retrieved",
      "parameters": {
        "type": "object",
        "properties": {
          "project_id": {
            "description": "Unique identifier of the project",
            "type": "string",
            "examples": [
              "PRJ-2024-001"
            ]
          }
        },
        "required": [
          "project_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "project_id": {
            "description": "Unique identifier of the project",
            "type": "string",
            "examples": [
              "PRJ-2024-001"
            ]
          },
          "name": {
            "description": "Name of the project",
            "type": "string",
            "examples": [
              "Website Redesign"
            ]
          },
          "description": {
            "description": "Detailed description of the project",
            "type": "string",
            "examples": [
              "Complete redesign of company website"
            ]
          },
          "status": {
            "description": "Current project status",
            "type": "string",
            "enum": [
              "planning",
              "active",
              "on_hold",
              "completed",
              "cancelled"
            ],
            "examples": [
              "active"
            ]
          },
          "start_date": {
            "description": "Project start date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-01"
            ]
          },
          "end_date": {
            "description": "Project planned end date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-06-30"
            ]
          },
          "budget": {
            "description": "Total project budget in currency units",
            "type": "number",
            "examples": [
              500000
            ]
          },
          "completion_percentage": {
            "description": "Current completion percentage",
            "type": "number",
            "examples": [
              45.5
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "project"
      ]
    },
    {
      "name": "calculate_team_capacity",
      "description": "Calculate total team capacity based on team member availability, working hours, and planned time off",
      "group": "project_management",
      "object_category": "resource_management",
      "action_category": "computation",
      "pre_condition": "Team member data must be provided",
      "post_condition": "Team capacity is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "team_members": {
            "description": "List of team member dictionaries containing name, weekly_hours, and planned_time_off_days",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "name": "john_doe",
                  "weekly_hours": 40,
                  "planned_time_off_days": 5
                }
              ]
            ]
          },
          "planning_period_weeks": {
            "description": "Number of weeks in the planning period",
            "type": "integer",
            "examples": [
              4
            ]
          },
          "capacity_buffer_percentage": {
            "description": "Percentage to reduce capacity for buffer (0-100)",
            "type": "number",
            "examples": [
              20
            ]
          }
        },
        "required": [
          "team_members",
          "planning_period_weeks"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_capacity_hours": {
            "description": "Total team capacity in hours for the planning period",
            "type": "number",
            "examples": [
              512
            ]
          },
          "available_capacity_hours": {
            "description": "Available capacity after applying buffer in hours",
            "type": "number",
            "examples": [
              409.6
            ]
          },
          "individual_capacities": {
            "description": "Dictionary mapping team member names to their individual capacity hours",
            "type": "object",
            "examples": [
              {
                "john_doe": 120,
                "jane_smith": 160
              }
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "prioritize_tasks_by_dependencies",
      "description": "Prioritize tasks based on their dependencies using topological sorting to determine execution order",
      "group": "project_management",
      "object_category": "task_management",
      "action_category": "optimization",
      "pre_condition": "Task list and dependencies must be provided",
      "post_condition": "Tasks are prioritized in dependency order",
      "parameters": {
        "type": "object",
        "properties": {
          "tasks": {
            "description": "List of task names",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "requirements",
                "design",
                "development",
                "testing"
              ]
            ]
          },
          "dependencies": {
            "description": "List of task dependencies where each dependency is [predecessor, successor]",
            "type": "array",
            "items": {
              "type": "array"
            },
            "examples": [
              [
                [
                  "requirements",
                  "design"
                ],
                [
                  "design",
                  "development"
                ],
                [
                  "development",
                  "testing"
                ]
              ]
            ]
          }
        },
        "required": [
          "tasks",
          "dependencies"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "prioritized_tasks": {
            "description": "List of tasks in execution order based on dependencies",
            "type": "array",
            "examples": [
              [
                "requirements",
                "design",
                "development",
                "testing"
              ]
            ]
          },
          "has_circular_dependency": {
            "description": "Whether circular dependencies were detected",
            "type": "boolean",
            "examples": [
              false
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_sprint_burndown",
      "description": "Calculate sprint burndown data showing remaining work over time for agile sprint tracking",
      "group": "project_management",
      "object_category": "agile_management",
      "action_category": "computation",
      "pre_condition": "Sprint work data must be provided",
      "post_condition": "Burndown data is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "total_story_points": {
            "description": "Total story points committed for the sprint",
            "type": "integer",
            "examples": [
              50
            ]
          },
          "daily_completed_points": {
            "description": "List of story points completed each day of the sprint",
            "type": "array",
            "items": {
              "type": "integer"
            },
            "examples": [
              [
                5,
                7,
                6,
                8,
                5,
                7,
                6,
                0,
                0,
                6
              ]
            ]
          },
          "sprint_length_days": {
            "description": "Total length of the sprint in days",
            "type": "integer",
            "examples": [
              10
            ]
          }
        },
        "required": [
          "total_story_points",
          "daily_completed_points",
          "sprint_length_days"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "burndown_data": {
            "description": "List of remaining story points for each day",
            "type": "array",
            "examples": [
              [
                50,
                45,
                38,
                32,
                24,
                19,
                12,
                6,
                6,
                6,
                0
              ]
            ]
          },
          "ideal_burndown": {
            "description": "List of ideal remaining story points for each day",
            "type": "array",
            "examples": [
              [
                50,
                45,
                40,
                35,
                30,
                25,
                20,
                15,
                10,
                5,
                0
              ]
            ]
          },
          "is_on_track": {
            "description": "Whether sprint is on track to complete all work",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "create_project",
      "description": "Create a new project with basic information including name, description, start date, and end date",
      "group": "project_management",
      "object_category": "project_management",
      "action_category": "data_creation",
      "pre_condition": "Project details must be provided",
      "post_condition": "New project is created in the system",
      "parameters": {
        "type": "object",
        "properties": {
          "name": {
            "description": "Name of the project",
            "type": "string",
            "examples": [
              "Website Redesign"
            ]
          },
          "description": {
            "description": "Detailed description of the project",
            "type": "string",
            "examples": [
              "Complete redesign of company website"
            ]
          },
          "start_date": {
            "description": "Project start date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-01"
            ]
          },
          "end_date": {
            "description": "Project planned end date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-06-30"
            ]
          },
          "budget": {
            "description": "Total project budget in currency units",
            "type": "number",
            "examples": [
              500000
            ]
          },
          "project_manager": {
            "description": "Name of the project manager",
            "type": "string",
            "examples": [
              "John Smith"
            ]
          }
        },
        "required": [
          "name",
          "description",
          "start_date",
          "end_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "project_id": {
            "description": "Unique identifier for the created project",
            "type": "string",
            "examples": [
              "PRJ-2024-001"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when project was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-01 09:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "project"
      ]
    },
    {
      "name": "validate_resource_availability",
      "description": "Validate that resource assignments do not exceed available capacity and identify over-allocations",
      "group": "project_management",
      "object_category": "resource_management",
      "action_category": "validation",
      "pre_condition": "Resource capacity and assignment data must be provided",
      "post_condition": "Resource availability validation results are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "resource_capacity": {
            "description": "Dictionary mapping resource names to their available hours per time period",
            "type": "object",
            "examples": [
              {
                "john_doe": 160,
                "jane_smith": 160
              }
            ]
          },
          "assignments": {
            "description": "Dictionary mapping resource names to their assigned hours per time period",
            "type": "object",
            "examples": [
              {
                "john_doe": 180,
                "jane_smith": 140
              }
            ]
          }
        },
        "required": [
          "resource_capacity",
          "assignments"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Whether all resource assignments are within capacity",
            "type": "boolean",
            "examples": [
              false
            ]
          },
          "over_allocated_resources": {
            "description": "List of resource names that are over-allocated",
            "type": "array",
            "examples": [
              [
                "john_doe"
              ]
            ]
          },
          "allocation_details": {
            "description": "Dictionary mapping resources to their allocation status",
            "type": "object",
            "examples": [
              {
                "john_doe": {
                  "capacity": 160,
                  "assigned": 180,
                  "over_allocation": 20
                }
              }
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "generate_risk_register",
      "description": "Generate comprehensive risk register documenting identified risks with assessment and response plans",
      "group": "project_management",
      "object_category": "risk_management",
      "action_category": "data_creation",
      "pre_condition": "Risk identification data must be provided",
      "post_condition": "Risk register is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "risks": {
            "description": "List of risk dictionaries containing name, description, category, probability, impact, and owner",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "name": "technical_risk",
                  "description": "New technology adoption",
                  "category": "technical",
                  "probability": 0.6,
                  "impact": 4,
                  "owner": "tech_lead"
                }
              ]
            ]
          }
        },
        "required": [
          "risks"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "risk_register": {
            "description": "Structured risk register with all risks and their details",
            "type": "array",
            "examples": [
              [
                {
                  "risk_id": "R001",
                  "name": "technical_risk",
                  "priority": "high",
                  "response_strategy": "mitigate"
                }
              ]
            ]
          },
          "risk_summary": {
            "description": "Summary statistics of risks by category and priority",
            "type": "object",
            "examples": [
              {
                "total_risks": 5,
                "high_priority": 2,
                "medium_priority": 2,
                "low_priority": 1
              }
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_task_slack_time",
      "description": "Calculate the slack time (float) for each task based on early start, early finish, late start, and late finish times",
      "group": "project_management",
      "object_category": "schedule_management",
      "action_category": "computation",
      "pre_condition": "Task scheduling information must be provided",
      "post_condition": "Slack times are calculated for all tasks",
      "parameters": {
        "type": "object",
        "properties": {
          "task_schedules": {
            "description": "Dictionary mapping task names to their scheduling information including early_start, early_finish, late_start, late_finish",
            "type": "object",
            "examples": [
              {
                "design": {
                  "early_start": 0,
                  "early_finish": 10,
                  "late_start": 0,
                  "late_finish": 10
                }
              }
            ]
          }
        },
        "required": [
          "task_schedules"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "slack_times": {
            "description": "Dictionary mapping task names to their slack time in days",
            "type": "object",
            "examples": [
              {
                "design": 0,
                "documentation": 5
              }
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "update_milestone_status",
      "description": "Update the completion status of a milestone",
      "group": "project_management",
      "object_category": "schedule_management",
      "action_category": "data_modification",
      "pre_condition": "Milestone must exist in the system",
      "post_condition": "Milestone status is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "milestone_id": {
            "description": "Unique identifier of the milestone",
            "type": "string",
            "examples": [
              "MLS-2024-001"
            ]
          },
          "is_completed": {
            "description": "Whether the milestone is completed",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "actual_completion_date": {
            "description": "Actual completion date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-02-14"
            ]
          },
          "completion_notes": {
            "description": "Notes about milestone completion",
            "type": "string",
            "examples": [
              "All deliverables completed on schedule"
            ]
          }
        },
        "required": [
          "milestone_id",
          "is_completed"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the status update was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_timestamp": {
            "description": "Timestamp when status was updated in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-02-14 16:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "milestone"
      ]
    },
    {
      "name": "validate_budget_allocation",
      "description": "Validate that budget allocations do not exceed total budget and all categories are properly allocated",
      "group": "project_management",
      "object_category": "financial_management",
      "action_category": "validation",
      "pre_condition": "Budget allocation data must be provided",
      "post_condition": "Budget allocation validation results are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "budget": {
            "description": "Total project budget in currency units",
            "type": "number",
            "examples": [
              100000
            ]
          },
          "allocations": {
            "description": "Dictionary mapping budget categories to allocated amounts in currency units",
            "type": "object",
            "examples": [
              {
                "labor": 50000,
                "materials": 30000,
                "equipment": 15000
              }
            ]
          }
        },
        "required": [
          "budget",
          "allocations"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Whether the budget allocation is valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "total_allocated": {
            "description": "Total amount allocated across all categories in currency units",
            "type": "number",
            "examples": [
              95000
            ]
          },
          "remaining_budget": {
            "description": "Remaining unallocated budget in currency units",
            "type": "number",
            "examples": [
              5000
            ]
          },
          "validation_errors": {
            "description": "List of validation error messages",
            "type": "array",
            "examples": []
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "create_milestone",
      "description": "Create a new milestone for a project with target date and deliverables",
      "group": "project_management",
      "object_category": "schedule_management",
      "action_category": "data_creation",
      "pre_condition": "Project must exist in the system",
      "post_condition": "New milestone is created",
      "parameters": {
        "type": "object",
        "properties": {
          "project_id": {
            "description": "Unique identifier of the project",
            "type": "string",
            "examples": [
              "PRJ-2024-001"
            ]
          },
          "milestone_name": {
            "description": "Name of the milestone",
            "type": "string",
            "examples": [
              "Design Phase Complete"
            ]
          },
          "target_date": {
            "description": "Target completion date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-02-15"
            ]
          },
          "deliverables": {
            "description": "List of deliverable descriptions",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "All mockups approved",
                "Design system documented"
              ]
            ]
          }
        },
        "required": [
          "project_id",
          "milestone_name",
          "target_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "milestone_id": {
            "description": "Unique identifier for the created milestone",
            "type": "string",
            "examples": [
              "MLS-2024-001"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when milestone was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-01 11:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "milestone",
        "milestone_deliverable",
        "project"
      ]
    },
    {
      "name": "analyze_project_dependencies",
      "description": "Analyze project dependencies to identify mandatory, discretionary, external, and internal dependencies",
      "group": "project_management",
      "object_category": "task_management",
      "action_category": "data_analysis",
      "pre_condition": "Dependency data with types must be provided",
      "post_condition": "Dependency analysis is completed",
      "parameters": {
        "type": "object",
        "properties": {
          "dependencies": {
            "description": "List of dependency dictionaries containing predecessor, successor, type (mandatory/discretionary/external/internal), and lead_lag_days",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "predecessor": "design",
                  "successor": "development",
                  "type": "mandatory",
                  "lead_lag_days": 0
                }
              ]
            ]
          }
        },
        "required": [
          "dependencies"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "dependency_summary": {
            "description": "Summary count of each dependency type",
            "type": "object",
            "examples": [
              {
                "mandatory": 5,
                "discretionary": 2,
                "external": 1,
                "internal": 4
              }
            ]
          },
          "critical_dependencies": {
            "description": "List of dependencies that are on the critical path",
            "type": "array",
            "examples": [
              [
                {
                  "predecessor": "design",
                  "successor": "development"
                }
              ]
            ]
          },
          "external_risks": {
            "description": "List of external dependencies that pose scheduling risks",
            "type": "array",
            "examples": [
              [
                {
                  "predecessor": "vendor_delivery",
                  "successor": "integration"
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_float_time_distribution",
      "description": "Calculate the distribution of float time across all project tasks to identify scheduling flexibility",
      "group": "project_management",
      "object_category": "schedule_management",
      "action_category": "data_analysis",
      "pre_condition": "Task float time data must be provided",
      "post_condition": "Float time distribution is analyzed",
      "parameters": {
        "type": "object",
        "properties": {
          "task_float_times": {
            "description": "Dictionary mapping task names to their total float time in days",
            "type": "object",
            "examples": [
              {
                "task1": 0,
                "task2": 5,
                "task3": 10,
                "task4": 3
              }
            ]
          }
        },
        "required": [
          "task_float_times"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "critical_path": {
            "description": "List of tasks with zero float (critical path)",
            "type": "array",
            "examples": [
              [
                "task1"
              ]
            ]
          },
          "near_critical_tasks": {
            "description": "List of tasks with float less than 5 days",
            "type": "array",
            "examples": [
              [
                "task4"
              ]
            ]
          },
          "average_float": {
            "description": "Average float time across all tasks in days",
            "type": "number",
            "examples": [
              4.5
            ]
          },
          "scheduling_flexibility": {
            "description": "Overall scheduling flexibility assessment",
            "type": "string",
            "enum": [
              "low",
              "medium",
              "high"
            ],
            "examples": [
              "medium"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_project_risk_score",
      "description": "Calculate overall project risk score based on individual risk assessments using probability and impact values",
      "group": "project_management",
      "object_category": "risk_management",
      "action_category": "computation",
      "pre_condition": "Risk assessments with probability and impact must be provided",
      "post_condition": "Overall risk score is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "risks": {
            "description": "List of risk dictionaries containing probability (0-1) and impact (1-5) values",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "name": "technical_risk",
                  "probability": 0.7,
                  "impact": 4
                },
                {
                  "name": "resource_risk",
                  "probability": 0.3,
                  "impact": 3
                }
              ]
            ]
          }
        },
        "required": [
          "risks"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "overall_risk_score": {
            "description": "Calculated overall risk score on scale of 0-5",
            "type": "number",
            "examples": [
              3.7
            ]
          },
          "risk_level": {
            "description": "Risk level classification based on score",
            "type": "string",
            "enum": [
              "low",
              "medium",
              "high",
              "critical"
            ],
            "examples": [
              "high"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_resource_utilization_rate",
      "description": "Calculate the utilization rate of resources based on allocated hours versus available hours",
      "group": "project_management",
      "object_category": "resource_management",
      "action_category": "computation",
      "pre_condition": "Resource allocation and availability data must be provided",
      "post_condition": "Utilization rates are calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "allocated_hours": {
            "description": "Dictionary mapping resource names to their allocated hours",
            "type": "object",
            "examples": [
              {
                "john_doe": 160,
                "jane_smith": 140
              }
            ]
          },
          "available_hours": {
            "description": "Dictionary mapping resource names to their available hours",
            "type": "object",
            "examples": [
              {
                "john_doe": 160,
                "jane_smith": 160
              }
            ]
          }
        },
        "required": [
          "allocated_hours",
          "available_hours"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "utilization_rates": {
            "description": "Dictionary mapping resource names to their utilization rates as percentages",
            "type": "object",
            "examples": [
              {
                "john_doe": 100.0,
                "jane_smith": 87.5
              }
            ]
          },
          "average_utilization": {
            "description": "Average utilization rate across all resources as percentage",
            "type": "number",
            "examples": [
              93.75
            ]
          }
        }
      },
      "raises": "ZeroDivisionError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "generate_project_charter",
      "description": "Generate project charter document with key project information including objectives, scope, stakeholders, and success criteria",
      "group": "project_management",
      "object_category": "initiation_management",
      "action_category": "data_creation",
      "pre_condition": "Project definition data must be provided",
      "post_condition": "Project charter is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "name": {
            "description": "Name of the project",
            "type": "string",
            "examples": [
              "Customer Portal Development"
            ]
          },
          "business_case": {
            "description": "Business justification for the project",
            "type": "string",
            "examples": [
              "Improve customer self-service capabilities"
            ]
          },
          "objectives": {
            "description": "List of project objectives",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Reduce support calls by 30%",
                "Increase customer satisfaction"
              ]
            ]
          },
          "high_level_scope": {
            "description": "High-level description of project scope",
            "type": "string",
            "examples": [
              "Develop web portal with account management and support features"
            ]
          },
          "key_stakeholders": {
            "description": "List of key stakeholder names and roles",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "John Smith - Project Sponsor",
                "Jane Doe - Product Owner"
              ]
            ]
          },
          "success_criteria": {
            "description": "List of measurable success criteria",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Portal launches by Q2 2024",
                "Achieve 80% user adoption"
              ]
            ]
          }
        },
        "required": [
          "name",
          "business_case",
          "objectives",
          "high_level_scope",
          "key_stakeholders",
          "success_criteria"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "charter_document": {
            "description": "Structured project charter with all sections",
            "type": "object",
            "examples": [
              {
                "project_name": "Customer Portal Development",
                "sections": {}
              }
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_cost_benefit_ratio",
      "description": "Calculate cost-benefit ratio and benefit-cost ratio for project investment analysis",
      "group": "project_management",
      "object_category": "financial_management",
      "action_category": "computation",
      "pre_condition": "Cost and benefit data must be provided",
      "post_condition": "Cost-benefit ratios are calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "total_costs": {
            "description": "Total project costs in currency units",
            "type": "number",
            "examples": [
              500000
            ]
          },
          "total_benefits": {
            "description": "Total expected benefits in currency units",
            "type": "number",
            "examples": [
              750000
            ]
          },
          "discount_rate": {
            "description": "Annual discount rate as decimal for NPV calculation",
            "type": "number",
            "examples": [
              0.1
            ]
          },
          "analysis_period_years": {
            "description": "Number of years for benefit realization",
            "type": "integer",
            "examples": [
              3
            ]
          }
        },
        "required": [
          "total_costs",
          "total_benefits"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "benefit_cost_ratio": {
            "description": "Benefit-cost ratio (benefits divided by costs)",
            "type": "number",
            "examples": [
              1.5,
              0.67
            ]
          },
          "net_benefit": {
            "description": "Net benefit amount in currency units",
            "type": "number",
            "examples": [
              250000
            ]
          },
          "investment_decision": {
            "description": "Investment recommendation based on ratio",
            "type": "string",
            "enum": [
              "proceed",
              "reconsider",
              "reject"
            ],
            "examples": [
              "proceed"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_return_on_investment",
      "description": "Calculate project ROI based on project costs and expected benefits over time",
      "group": "project_management",
      "object_category": "financial_management",
      "action_category": "computation",
      "pre_condition": "Project costs and benefits must be provided",
      "post_condition": "ROI metrics are calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "total_costs": {
            "description": "Total project investment cost in currency units",
            "type": "number",
            "examples": [
              500000
            ]
          },
          "annual_benefits": {
            "description": "List of expected annual benefits in currency units for each year",
            "type": "array",
            "items": {
              "type": "number"
            },
            "examples": [
              [
                100000,
                150000,
                200000
              ]
            ]
          },
          "discount_rate": {
            "description": "Annual discount rate as decimal (e.g., 0.1 for 10%)",
            "type": "number",
            "examples": [
              0.1
            ]
          }
        },
        "required": [
          "total_costs",
          "annual_benefits",
          "discount_rate"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "roi_percentage": {
            "description": "Return on investment as percentage",
            "type": "number",
            "examples": [
              45.2
            ]
          },
          "net_present_value": {
            "description": "Net present value of the project in currency units",
            "type": "number",
            "examples": [
              226000
            ]
          },
          "payback_period_years": {
            "description": "Number of years to recover initial investment",
            "type": "number",
            "examples": [
              2.5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "list_project_tasks",
      "description": "Retrieve list of all tasks belonging to a specific project with optional filtering",
      "group": "project_management",
      "object_category": "task_management",
      "action_category": "data_retrieval",
      "pre_condition": "Project must exist in the system",
      "post_condition": "Task list is retrieved",
      "parameters": {
        "type": "object",
        "properties": {
          "project_id": {
            "description": "Unique identifier of the project",
            "type": "string",
            "examples": [
              "PRJ-2024-001"
            ]
          },
          "status": {
            "description": "Filter tasks by status",
            "type": "string",
            "enum": [
              "not_started",
              "in_progress",
              "blocked",
              "completed",
              "cancelled",
              "all"
            ],
            "examples": [
              "in_progress"
            ]
          },
          "assigned_to": {
            "description": "Filter tasks by assignee name or ID",
            "type": "string",
            "examples": [
              "jane_smith"
            ]
          }
        },
        "required": [
          "project_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "tasks": {
            "description": "List of task summary objects",
            "type": "array",
            "examples": [
              [
                {
                  "task_id": "TSK-2024-001",
                  "task_name": "Design homepage",
                  "status": "in_progress"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of tasks matching criteria",
            "type": "integer",
            "examples": [
              15
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "task",
        "project"
      ]
    },
    {
      "name": "calculate_quality_metrics",
      "description": "Calculate quality metrics including defect density, defect removal efficiency, and customer satisfaction scores",
      "group": "project_management",
      "object_category": "quality_management",
      "action_category": "computation",
      "pre_condition": "Quality data must be provided",
      "post_condition": "Quality metrics are calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "total_defects_found": {
            "description": "Total number of defects found during project",
            "type": "integer",
            "examples": [
              45
            ]
          },
          "defects_found_before_release": {
            "description": "Number of defects found before release",
            "type": "integer",
            "examples": [
              40
            ]
          },
          "project_size": {
            "description": "Project size in lines of code or function points",
            "type": "integer",
            "examples": [
              50000
            ]
          },
          "customer_satisfaction_ratings": {
            "description": "List of customer satisfaction ratings on scale of 1-5",
            "type": "array",
            "items": {
              "type": "integer"
            },
            "examples": [
              [
                5,
                4,
                5,
                4,
                5
              ]
            ]
          }
        },
        "required": [
          "total_defects_found",
          "defects_found_before_release",
          "project_size",
          "customer_satisfaction_ratings"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "defect_density": {
            "description": "Defects per thousand lines of code or function points",
            "type": "number",
            "examples": [
              0.9
            ]
          },
          "defect_removal_efficiency": {
            "description": "Percentage of defects found before release",
            "type": "number",
            "examples": [
              88.89
            ]
          },
          "average_customer_satisfaction": {
            "description": "Average customer satisfaction score",
            "type": "number",
            "examples": [
              4.6
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_project_duration",
      "description": "Calculate the total duration of a project based on task durations and dependencies using critical path method",
      "group": "project_management",
      "object_category": "schedule_management",
      "action_category": "computation",
      "pre_condition": "Task durations and dependencies must be provided",
      "post_condition": "Project duration and critical path are calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "task_durations": {
            "description": "Dictionary mapping task names to their durations in days",
            "type": "object",
            "examples": [
              {
                "design": 10,
                "development": 20,
                "testing": 5
              }
            ]
          },
          "dependencies": {
            "description": "List of task dependencies where each dependency is [predecessor, successor]",
            "type": "array",
            "items": {
              "type": "array"
            },
            "examples": [
              [
                [
                  "design",
                  "development"
                ],
                [
                  "development",
                  "testing"
                ]
              ]
            ]
          }
        },
        "required": [
          "task_durations",
          "dependencies"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_duration": {
            "description": "Total project duration in days",
            "type": "integer",
            "examples": [
              35
            ]
          },
          "critical_path": {
            "description": "List of tasks on the critical path",
            "type": "array",
            "examples": [
              [
                "design",
                "development",
                "testing"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "assess_change_impact",
      "description": "Assess the impact of proposed changes on project scope, schedule, cost, quality, and risks",
      "group": "project_management",
      "object_category": "change_management",
      "action_category": "data_analysis",
      "pre_condition": "Change request details must be provided",
      "post_condition": "Change impact assessment is completed",
      "parameters": {
        "type": "object",
        "properties": {
          "change_description": {
            "description": "Description of the proposed change",
            "type": "string",
            "examples": [
              "Add mobile app support to project scope"
            ]
          },
          "estimated_hours": {
            "description": "Estimated effort required in hours",
            "type": "number",
            "examples": [
              320
            ]
          },
          "estimated_cost": {
            "description": "Estimated cost impact in currency units",
            "type": "number",
            "examples": [
              48000
            ]
          },
          "schedule_impact_days": {
            "description": "Estimated schedule delay in days",
            "type": "integer",
            "examples": [
              20
            ]
          },
          "affected_deliverables": {
            "description": "List of deliverables affected by the change",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "User Interface",
                "Testing Plan",
                "Documentation"
              ]
            ]
          }
        },
        "required": [
          "change_description",
          "estimated_hours",
          "estimated_cost",
          "schedule_impact_days",
          "affected_deliverables"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "impact_level": {
            "description": "Overall impact level of the change",
            "type": "string",
            "enum": [
              "low",
              "medium",
              "high",
              "critical"
            ],
            "examples": [
              "high"
            ]
          },
          "impact_summary": {
            "description": "Detailed impact analysis across all dimensions",
            "type": "object",
            "examples": [
              {
                "scope": "major_addition",
                "schedule": "20_days_delay",
                "cost": 48000,
                "quality": "additional_testing_required"
              }
            ]
          },
          "recommendation": {
            "description": "Recommendation on whether to approve the change",
            "type": "string",
            "enum": [
              "approve",
              "reject",
              "defer",
              "modify"
            ],
            "examples": [
              "defer"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_resource_cost",
      "description": "Calculate total cost for resources based on hourly rates and allocated hours",
      "group": "project_management",
      "object_category": "resource_management",
      "action_category": "computation",
      "pre_condition": "Resource rates and hours must be provided",
      "post_condition": "Resource costs are calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "resource_rates": {
            "description": "Dictionary mapping resource names to their hourly rates in currency units",
            "type": "object",
            "examples": [
              {
                "senior_developer": 150,
                "junior_developer": 80
              }
            ]
          },
          "allocated_hours": {
            "description": "Dictionary mapping resource names to their allocated hours",
            "type": "object",
            "examples": [
              {
                "senior_developer": 160,
                "junior_developer": 200
              }
            ]
          }
        },
        "required": [
          "resource_rates",
          "allocated_hours"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "resource_costs": {
            "description": "Dictionary mapping resource names to their total costs in currency units",
            "type": "object",
            "examples": [
              {
                "senior_developer": 24000,
                "junior_developer": 16000
              }
            ]
          },
          "total_cost": {
            "description": "Total cost across all resources in currency units",
            "type": "number",
            "examples": [
              40000
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    }
  ],
  "schema_classification": {
    "Project": {
      "schema_name": "Project",
      "instance_key": "project_id",
      "fields": [
        {
          "field_name": "project_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "项目名称属于自然语言文本，不同措辞可能表达同一个项目"
        },
        {
          "field_name": "description",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "项目描述为自由文本，内容可语义等价"
        },
        {
          "field_name": "start_date",
          "field_type": "date",
          "comparison_type": "strict",
          "reason": "日期字段，需精确匹配"
        },
        {
          "field_name": "end_date",
          "field_type": "date",
          "comparison_type": "strict",
          "reason": "日期字段，需精确匹配"
        },
        {
          "field_name": "budget",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "项目预算为数值金额，必须严格相等"
        },
        {
          "field_name": "project_manager",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "项目经理为人名，自然语言，推荐语义比较"
        },
        {
          "field_name": "status",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "项目状态为枚举值，需严格相等"
        },
        {
          "field_name": "completion_percentage",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "进度百分比为数值，需精确匹配"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "创建时间戳为日期时间字段，需严格相等"
        },
        {
          "field_name": "updated_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "更新时间戳为日期时间字段，需严格相等"
        }
      ]
    },
    "Task": {
      "schema_name": "Task",
      "instance_key": "task_id",
      "fields": [
        {
          "field_name": "task_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识任务，每次可能不同"
        },
        {
          "field_name": "project_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格匹配以确保任务归属项目一致"
        },
        {
          "field_name": "task_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "任务名称，属于自然语言文本，不同措辞可表达同义"
        },
        {
          "field_name": "description",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "任务描述，自由文本，措辞不同可表达相同含义"
        },
        {
          "field_name": "assigned_to",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "分配对象，通常为姓名或ID，部分场景下姓名表达可有细微变化"
        },
        {
          "field_name": "due_date",
          "field_type": "date",
          "comparison_type": "strict",
          "reason": "日期，任务截止时间必须严格一致"
        },
        {
          "field_name": "estimated_hours",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "数值型字段，任务预估工时必须精确匹配"
        },
        {
          "field_name": "priority",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，任务优先级必须严格一致"
        },
        {
          "field_name": "status",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，任务状态必须严格一致"
        },
        {
          "field_name": "completion_percentage",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值型字段，任务完成百分比必须精确匹配"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，任务创建时间须严格一致"
        },
        {
          "field_name": "updated_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，任务更新时间须严格一致"
        }
      ]
    },
    "Milestone": {
      "schema_name": "Milestone",
      "instance_key": "milestone_id",
      "fields": [
        {
          "field_name": "milestone_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识，每次生成可能不同"
        },
        {
          "field_name": "project_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保关联到同一项目"
        },
        {
          "field_name": "milestone_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "人名/标题类型文本，不同措辞（如简写或全称）可能等价"
        },
        {
          "field_name": "target_date",
          "field_type": "date",
          "comparison_type": "strict",
          "reason": "目标完成日期，日期须完全一致"
        },
        {
          "field_name": "is_completed",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，表示完成状态，必须精确匹配"
        },
        {
          "field_name": "actual_completion_date",
          "field_type": "Optional[date]",
          "comparison_type": "strict",
          "reason": "实际完成日期，日期须严格匹配"
        },
        {
          "field_name": "completion_notes",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本备注，不同措辞可以表达相同含义"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "创建时间戳，必须精确匹配以反映创建时间"
        },
        {
          "field_name": "updated_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "更新时间戳，必须精确匹配以反映最新状态"
        }
      ]
    },
    "MilestoneDeliverable": {
      "schema_name": "MilestoneDeliverable",
      "instance_key": "deliverable_id",
      "fields": [
        {
          "field_name": "deliverable_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "milestone_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用同一里程碑"
        },
        {
          "field_name": "deliverable_description",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        }
      ]
    },
    "Risk": {
      "schema_name": "Risk",
      "instance_key": "risk_id",
      "fields": [
        {
          "field_name": "risk_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "project_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配才能确认归属项目一致"
        },
        {
          "field_name": "risk_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "通常为风险名称，不同措辞可能等价，需语义比较"
        },
        {
          "field_name": "description",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "probability",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值型，表示风险发生概率，微小差异也重要"
        },
        {
          "field_name": "impact",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "数值型，风险影响等级，必须严格相等"
        },
        {
          "field_name": "category",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，风险类别，须精确匹配"
        },
        {
          "field_name": "owner",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "通常为姓名或ID，可能存在不同表达方式，需语义比较"
        },
        {
          "field_name": "status",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，风险状态，须精确匹配"
        },
        {
          "field_name": "risk_score",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值型，计算结果，需严格相等确认一致性"
        },
        {
          "field_name": "priority",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，优先级等级，须精确匹配"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，记录创建时间，需严格相等"
        },
        {
          "field_name": "updated_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，记录最后更新时间，需严格相等"
        }
      ]
    },
    "RiskMitigationAction": {
      "schema_name": "RiskMitigationAction",
      "instance_key": "action_id",
      "fields": [
        {
          "field_name": "action_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "risk_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保关联到相同的风险"
        },
        {
          "field_name": "action_description",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "action_date",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间字段，必须精确匹配以确保动作时间一致"
        }
      ]
    },
    "ResourceAllocation": {
      "schema_name": "ResourceAllocation",
      "instance_key": "allocation_id",
      "fields": [
        {
          "field_name": "allocation_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识该分配记录，每次生成都不同"
        },
        {
          "field_name": "task_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配，表示分配关联的任务"
        },
        {
          "field_name": "resource_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配，表示分配的资源"
        },
        {
          "field_name": "allocated_hours",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值，表示分配的工时，必须精确匹配"
        },
        {
          "field_name": "start_date",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，表示分配开始时间，必须精确匹配"
        },
        {
          "field_name": "end_date",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，表示分配结束时间，必须精确匹配"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，表示分配记录创建时间，必须精确匹配"
        }
      ]
    }
  }
}