{
  "domain": "stock_trading",
  "databases": [
    {
      "table_name": "user_account",
      "description": "Stores user account information including cash balance and buying power",
      "schema": {
        "columns": [
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the user",
            "optional": false
          },
          {
            "name": "cash_balance",
            "type": "DECIMAL(15,2)",
            "description": "Available cash balance in USD",
            "default": "0.00",
            "optional": false
          },
          {
            "name": "buying_power",
            "type": "DECIMAL(15,2)",
            "description": "Total buying power including margin",
            "default": "0.00",
            "optional": false
          },
          {
            "name": "margin_used",
            "type": "DECIMAL(15,2)",
            "description": "Amount of margin currently used",
            "default": "0.00",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Account creation timestamp",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          },
          {
            "name": "updated_at",
            "type": "TIMESTAMP",
            "description": "Last update timestamp",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          }
        ],
        "primary_key": "user_id"
      }
    },
    {
      "table_name": "stock_order",
      "description": "Stores all trading orders including market, limit, and stop-loss orders",
      "schema": {
        "columns": [
          {
            "name": "order_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the order",
            "optional": false
          },
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "User who placed the order",
            "optional": false,
            "references": "user_account.user_id"
          },
          {
            "name": "ticker_symbol",
            "type": "VARCHAR(10)",
            "description": "Stock ticker symbol",
            "optional": false
          },
          {
            "name": "order_type",
            "type": "VARCHAR(20)",
            "description": "Type of order",
            "optional": false,
            "enum": [
              "market",
              "limit",
              "stop_loss"
            ]
          },
          {
            "name": "order_side",
            "type": "VARCHAR(10)",
            "description": "Order side: buy or sell",
            "optional": false,
            "enum": [
              "buy",
              "sell"
            ]
          },
          {
            "name": "quantity",
            "type": "INTEGER",
            "description": "Number of shares to trade",
            "optional": false
          },
          {
            "name": "limit_price",
            "type": "DECIMAL(10,2)",
            "description": "Limit price for limit orders",
            "optional": true
          },
          {
            "name": "stop_price",
            "type": "DECIMAL(10,2)",
            "description": "Stop price for stop-loss orders",
            "optional": true
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Current order status",
            "optional": false,
            "enum": [
              "pending",
              "monitoring",
              "filled",
              "cancelled",
              "rejected"
            ]
          },
          {
            "name": "filled_quantity",
            "type": "INTEGER",
            "description": "Number of shares filled",
            "default": "0",
            "optional": false
          },
          {
            "name": "average_fill_price",
            "type": "DECIMAL(10,2)",
            "description": "Average execution price",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Order creation timestamp",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          },
          {
            "name": "filled_at",
            "type": "TIMESTAMP",
            "description": "Order fill timestamp",
            "optional": true
          },
          {
            "name": "cancelled_at",
            "type": "TIMESTAMP",
            "description": "Order cancellation timestamp",
            "optional": true
          }
        ],
        "primary_key": "order_id"
      }
    },
    {
      "table_name": "portfolio_position",
      "description": "Stores current portfolio holdings for each user",
      "schema": {
        "columns": [
          {
            "name": "position_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the position",
            "optional": false
          },
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "User who owns the position",
            "optional": false,
            "references": "user_account.user_id"
          },
          {
            "name": "ticker_symbol",
            "type": "VARCHAR(10)",
            "description": "Stock ticker symbol",
            "optional": false
          },
          {
            "name": "quantity",
            "type": "INTEGER",
            "description": "Number of shares held",
            "optional": false
          },
          {
            "name": "average_cost",
            "type": "DECIMAL(10,2)",
            "description": "Average cost per share",
            "optional": false
          },
          {
            "name": "sector",
            "type": "VARCHAR(50)",
            "description": "Market sector of the stock",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Position creation timestamp",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          },
          {
            "name": "updated_at",
            "type": "TIMESTAMP",
            "description": "Last update timestamp",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          }
        ],
        "primary_key": "position_id"
      }
    },
    {
      "table_name": "account_transaction",
      "description": "Stores all account transactions including deposits and withdrawals",
      "schema": {
        "columns": [
          {
            "name": "transaction_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the transaction",
            "optional": false
          },
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "User associated with the transaction",
            "optional": false,
            "references": "user_account.user_id"
          },
          {
            "name": "transaction_type",
            "type": "VARCHAR(20)",
            "description": "Type of transaction",
            "optional": false,
            "enum": [
              "deposit",
              "withdrawal"
            ]
          },
          {
            "name": "amount",
            "type": "DECIMAL(15,2)",
            "description": "Transaction amount in USD",
            "optional": false
          },
          {
            "name": "balance_after",
            "type": "DECIMAL(15,2)",
            "description": "Account balance after transaction",
            "optional": false
          },
          {
            "name": "timestamp",
            "type": "TIMESTAMP",
            "description": "Transaction timestamp",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          }
        ],
        "primary_key": "transaction_id"
      }
    },
    {
      "table_name": "price_alert",
      "description": "Stores user-defined price alerts for stocks",
      "schema": {
        "columns": [
          {
            "name": "alert_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the alert",
            "optional": false
          },
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "User who created the alert",
            "optional": false,
            "references": "user_account.user_id"
          },
          {
            "name": "ticker_symbol",
            "type": "VARCHAR(10)",
            "description": "Stock ticker symbol",
            "optional": false
          },
          {
            "name": "target_price",
            "type": "DECIMAL(10,2)",
            "description": "Price level that triggers the alert",
            "optional": false
          },
          {
            "name": "condition",
            "type": "VARCHAR(10)",
            "description": "Alert condition",
            "optional": false,
            "enum": [
              "above",
              "below"
            ]
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Alert status",
            "optional": false,
            "enum": [
              "active",
              "triggered",
              "deleted"
            ]
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Alert creation timestamp",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          },
          {
            "name": "triggered_at",
            "type": "TIMESTAMP",
            "description": "Alert trigger timestamp",
            "optional": true
          }
        ],
        "primary_key": "alert_id"
      }
    },
    {
      "table_name": "watchlist",
      "description": "Stores user-created watchlists for tracking stocks",
      "schema": {
        "columns": [
          {
            "name": "watchlist_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the watchlist",
            "optional": false
          },
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "User who owns the watchlist",
            "optional": false,
            "references": "user_account.user_id"
          },
          {
            "name": "watchlist_name",
            "type": "VARCHAR(100)",
            "description": "Name of the watchlist",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Watchlist creation timestamp",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          }
        ],
        "primary_key": "watchlist_id"
      }
    },
    {
      "table_name": "watchlist_stock",
      "description": "Stores the stocks within each watchlist",
      "schema": {
        "columns": [
          {
            "name": "watchlist_stock_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the watchlist-stock relationship",
            "optional": false
          },
          {
            "name": "watchlist_id",
            "type": "VARCHAR(10)",
            "description": "Watchlist containing the stock",
            "optional": false,
            "references": "watchlist.watchlist_id"
          },
          {
            "name": "ticker_symbol",
            "type": "VARCHAR(10)",
            "description": "Stock ticker symbol",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when stock was added to watchlist",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          }
        ],
        "primary_key": "watchlist_stock_id"
      }
    },
    {
      "table_name": "stock_price_history",
      "description": "Stores historical price data for stocks",
      "schema": {
        "columns": [
          {
            "name": "price_history_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the price record",
            "optional": false
          },
          {
            "name": "ticker_symbol",
            "type": "VARCHAR(10)",
            "description": "Stock ticker symbol",
            "optional": false
          },
          {
            "name": "date",
            "type": "DATE",
            "description": "Date of the price record",
            "optional": false
          },
          {
            "name": "open",
            "type": "DECIMAL(10,2)",
            "description": "Opening price",
            "optional": false
          },
          {
            "name": "high",
            "type": "DECIMAL(10,2)",
            "description": "Highest price",
            "optional": false
          },
          {
            "name": "low",
            "type": "DECIMAL(10,2)",
            "description": "Lowest price",
            "optional": false
          },
          {
            "name": "close",
            "type": "DECIMAL(10,2)",
            "description": "Closing price",
            "optional": false
          },
          {
            "name": "volume",
            "type": "BIGINT",
            "description": "Trading volume",
            "optional": false
          }
        ],
        "primary_key": "price_history_id"
      }
    },
    {
      "table_name": "stock_fundamental",
      "description": "Stores fundamental financial data for stocks",
      "schema": {
        "columns": [
          {
            "name": "ticker_symbol",
            "type": "VARCHAR(10)",
            "description": "Stock ticker symbol",
            "optional": false
          },
          {
            "name": "market_cap",
            "type": "BIGINT",
            "description": "Market capitalization",
            "optional": true
          },
          {
            "name": "pe_ratio",
            "type": "DECIMAL(10,2)",
            "description": "Price-to-earnings ratio",
            "optional": true
          },
          {
            "name": "eps",
            "type": "DECIMAL(10,2)",
            "description": "Earnings per share",
            "optional": true
          },
          {
            "name": "dividend_yield",
            "type": "DECIMAL(10,6)",
            "description": "Dividend yield as decimal",
            "optional": true
          },
          {
            "name": "revenue",
            "type": "BIGINT",
            "description": "Annual revenue",
            "optional": true
          },
          {
            "name": "sector",
            "type": "VARCHAR(50)",
            "description": "Market sector",
            "optional": true
          },
          {
            "name": "updated_at",
            "type": "TIMESTAMP",
            "description": "Last update timestamp",
            "default": "CURRENT_TIMESTAMP",
            "optional": false
          }
        ],
        "primary_key": "ticker_symbol"
      }
    }
  ],
  "tools": [
    {
      "name": "create_price_alert",
      "description": "Creates a price alert that triggers when stock reaches specified price level",
      "group": "stock_trading",
      "object_category": "alert_management",
      "action_category": "data_operations",
      "pre_condition": "Valid user ID, ticker symbol, and target price must be provided",
      "post_condition": "Alert is created and monitoring price",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "ticker_symbol": {
            "description": "Stock ticker symbol",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          },
          "target_price": {
            "description": "Price level that triggers the alert",
            "type": "number",
            "examples": [
              180.0
            ]
          },
          "condition": {
            "description": "Alert condition (above or below target price)",
            "type": "string",
            "enum": [
              "above",
              "below"
            ],
            "examples": [
              "above"
            ]
          }
        },
        "required": [
          "user_id",
          "ticker_symbol",
          "target_price",
          "condition"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "alert_id": {
            "description": "Unique identifier for the created alert",
            "type": "string",
            "examples": [
              "alert_56789"
            ]
          },
          "status": {
            "description": "Alert status",
            "type": "string",
            "examples": [
              "active"
            ]
          },
          "created_at": {
            "description": "Alert creation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "price_alert"
      ]
    },
    {
      "name": "calculate_tax_liability",
      "description": "Calculates estimated tax liability on realized capital gains",
      "group": "stock_trading",
      "object_category": "tax_reporting_management",
      "action_category": "computation",
      "pre_condition": "Capital gains and tax rate must be provided",
      "post_condition": "Returns estimated tax liability",
      "parameters": {
        "type": "object",
        "properties": {
          "short_term_gains": {
            "description": "Short-term capital gains (held < 1 year)",
            "type": "number",
            "examples": [
              5000.0
            ]
          },
          "long_term_gains": {
            "description": "Long-term capital gains (held >= 1 year)",
            "type": "number",
            "examples": [
              10000.0
            ]
          },
          "short_term_tax_rate": {
            "description": "Tax rate for short-term gains as decimal",
            "type": "number",
            "examples": [
              0.24
            ]
          },
          "long_term_tax_rate": {
            "description": "Tax rate for long-term gains as decimal",
            "type": "number",
            "examples": [
              0.15
            ]
          }
        },
        "required": [
          "short_term_gains",
          "long_term_gains",
          "short_term_tax_rate",
          "long_term_tax_rate"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_tax_liability": {
            "description": "Total estimated tax liability",
            "type": "number",
            "examples": [
              2700.0
            ]
          },
          "short_term_tax": {
            "description": "Tax on short-term gains",
            "type": "number",
            "examples": [
              1200.0
            ]
          },
          "long_term_tax": {
            "description": "Tax on long-term gains",
            "type": "number",
            "examples": [
              1500.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_stock_news",
      "description": "Retrieves recent news articles related to a specific stock",
      "group": "stock_trading",
      "object_category": "market_data_management",
      "action_category": "data_operations",
      "pre_condition": "Valid ticker symbol must be provided",
      "post_condition": "Returns list of news articles",
      "parameters": {
        "type": "object",
        "properties": {
          "ticker_symbol": {
            "description": "Stock ticker symbol",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          },
          "limit": {
            "description": "Maximum number of news articles to return",
            "type": "integer",
            "examples": [
              10
            ]
          }
        },
        "required": [
          "ticker_symbol"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "news_articles": {
            "description": "List of news articles",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "title": "Apple announces new product",
                  "source": "Reuters",
                  "published_at": "2024-01-15 09:00:00",
                  "url": "https://example.com/news"
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_watchlist_stocks",
      "description": "Retrieves all stocks in a specific watchlist with current prices",
      "group": "stock_trading",
      "object_category": "watchlist_management",
      "action_category": "data_operations",
      "pre_condition": "Valid watchlist ID must be provided",
      "post_condition": "Returns list of stocks in watchlist",
      "parameters": {
        "type": "object",
        "properties": {
          "watchlist_id": {
            "description": "Unique identifier of the watchlist",
            "type": "string",
            "examples": [
              "watchlist_11111"
            ]
          }
        },
        "required": [
          "watchlist_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "watchlist_id": {
            "description": "Unique identifier of the watchlist",
            "type": "string",
            "examples": [
              "watchlist_11111"
            ]
          },
          "watchlist_name": {
            "description": "Name of the watchlist",
            "type": "string",
            "examples": [
              "Tech Stocks"
            ]
          },
          "stocks": {
            "description": "List of stocks in watchlist",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "ticker_symbol": "AAPL",
                  "current_price": 175.43,
                  "change": 2.5,
                  "change_percentage": 1.45
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "watchlist",
        "watchlist_stock"
      ]
    },
    {
      "name": "get_order_status",
      "description": "Retrieves the current status and details of a specific order",
      "group": "stock_trading",
      "object_category": "order_management",
      "action_category": "data_operations",
      "pre_condition": "Valid order ID must be provided",
      "post_condition": "Returns complete order information",
      "parameters": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier of the order",
            "type": "string",
            "examples": [
              "order_98765"
            ]
          }
        },
        "required": [
          "order_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier of the order",
            "type": "string",
            "examples": [
              "order_98765"
            ]
          },
          "ticker_symbol": {
            "description": "Stock ticker symbol",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          },
          "order_type": {
            "description": "Type of order",
            "type": "string",
            "examples": [
              "market"
            ]
          },
          "order_side": {
            "description": "Order side",
            "type": "string",
            "examples": [
              "buy"
            ]
          },
          "quantity": {
            "description": "Number of shares",
            "type": "integer",
            "examples": [
              100
            ]
          },
          "status": {
            "description": "Current order status",
            "type": "string",
            "examples": [
              "filled"
            ]
          },
          "filled_quantity": {
            "description": "Number of shares filled",
            "type": "integer",
            "examples": [
              100
            ]
          },
          "average_fill_price": {
            "description": "Average execution price",
            "type": "number",
            "examples": [
              175.43
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "stock_order"
      ]
    },
    {
      "name": "calculate_rsi",
      "description": "Calculates the Relative Strength Index (RSI) indicator for stock price momentum analysis",
      "group": "stock_trading",
      "object_category": "analysis_management",
      "action_category": "computation",
      "pre_condition": "Price data and period must be provided",
      "post_condition": "Returns RSI value between 0 and 100",
      "parameters": {
        "type": "object",
        "properties": {
          "prices": {
            "description": "Array of historical closing prices",
            "type": "array",
            "items": {
              "type": "number"
            },
            "examples": [
              [
                100.5,
                101.2,
                99.8,
                102.0,
                103.5
              ]
            ]
          },
          "period": {
            "description": "Number of periods for RSI calculation (typically 14)",
            "type": "integer",
            "examples": [
              14
            ]
          }
        },
        "required": [
          "prices",
          "period"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "rsi_value": {
            "description": "RSI indicator value between 0 and 100",
            "type": "number",
            "examples": [
              65.4
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_portfolio_diversification",
      "description": "Calculates portfolio diversification metrics including sector and position weights",
      "group": "stock_trading",
      "object_category": "portfolio_management",
      "action_category": "data_analysis",
      "pre_condition": "Portfolio positions with sector information must be provided",
      "post_condition": "Returns diversification breakdown",
      "parameters": {
        "type": "object",
        "properties": {
          "positions": {
            "description": "Array of portfolio positions with sector and market value",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "ticker_symbol": "AAPL",
                  "sector": "Technology",
                  "market_value": 17543.0
                }
              ]
            ]
          }
        },
        "required": [
          "positions"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "sector_weights": {
            "description": "Percentage allocation by sector",
            "type": "object",
            "examples": [
              {
                "Technology": 65.5,
                "Healthcare": 20.0,
                "Finance": 14.5
              }
            ]
          },
          "position_weights": {
            "description": "Percentage allocation by position",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "ticker_symbol": "AAPL",
                  "weight": 33.7
                }
              ]
            ]
          },
          "concentration_risk": {
            "description": "Risk level based on concentration (low, medium, high)",
            "type": "string",
            "examples": [
              "medium"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "cancel_order",
      "description": "Cancels an existing pending order",
      "group": "stock_trading",
      "object_category": "order_management",
      "action_category": "data_operations",
      "pre_condition": "Order must exist and be in cancellable status",
      "post_condition": "Order is cancelled and no longer active",
      "parameters": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier of the order to cancel",
            "type": "string",
            "examples": [
              "order_98765"
            ]
          }
        },
        "required": [
          "order_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier of the cancelled order",
            "type": "string",
            "examples": [
              "order_98765"
            ]
          },
          "status": {
            "description": "Updated order status",
            "type": "string",
            "examples": [
              "cancelled"
            ]
          },
          "cancelled_at": {
            "description": "Cancellation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 11:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "stock_order"
      ]
    },
    {
      "name": "get_sector_performance",
      "description": "Retrieves performance metrics for different market sectors",
      "group": "stock_trading",
      "object_category": "market_data_management",
      "action_category": "data_operations",
      "pre_condition": "Time period must be provided",
      "post_condition": "Returns sector performance data",
      "parameters": {
        "type": "object",
        "properties": {
          "time_period": {
            "description": "Time period for performance calculation",
            "type": "string",
            "enum": [
              "1D",
              "1W",
              "1M",
              "3M",
              "1Y",
              "YTD"
            ],
            "examples": [
              "1M"
            ]
          }
        },
        "required": [
          "time_period"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "sector_performance": {
            "description": "List of sectors with performance metrics",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "sector": "Technology",
                  "return": 0.085,
                  "volatility": 0.18
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_position_risk",
      "description": "Calculates risk metrics for a specific position including value at risk",
      "group": "stock_trading",
      "object_category": "risk_management",
      "action_category": "computation",
      "pre_condition": "Position details and historical volatility must be provided",
      "post_condition": "Returns risk metrics for the position",
      "parameters": {
        "type": "object",
        "properties": {
          "quantity": {
            "description": "Number of shares held",
            "type": "integer",
            "examples": [
              100
            ]
          },
          "price": {
            "description": "Current market price per share",
            "type": "number",
            "examples": [
              175.43
            ]
          },
          "volatility": {
            "description": "Historical volatility (standard deviation)",
            "type": "number",
            "examples": [
              0.25
            ]
          },
          "confidence_level": {
            "description": "Confidence level for VaR calculation (e.g., 0.95 for 95%)",
            "type": "number",
            "examples": [
              0.95
            ]
          }
        },
        "required": [
          "quantity",
          "price",
          "volatility",
          "confidence_level"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "value_at_risk": {
            "description": "Value at Risk (VaR) amount",
            "type": "number",
            "examples": [
              2500.0
            ]
          },
          "position_value": {
            "description": "Total position value",
            "type": "number",
            "examples": [
              17543.0
            ]
          },
          "risk_percentage": {
            "description": "Risk as percentage of position value",
            "type": "number",
            "examples": [
              14.25
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_market_indices",
      "description": "Retrieves current values and changes for major market indices",
      "group": "stock_trading",
      "object_category": "market_data_management",
      "action_category": "data_operations",
      "pre_condition": "No preconditions required",
      "post_condition": "Returns current market index values",
      "parameters": {
        "type": "object",
        "properties": {},
        "required": []
      },
      "returns": {
        "type": "object",
        "properties": {
          "indices": {
            "description": "List of market indices with current values",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "index_name": "S&P 500",
                  "value": 4750.5,
                  "change": 25.3,
                  "change_percentage": 0.54
                }
              ]
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_real_time_stock_price",
      "description": "Retrieves the current real-time price of a specific stock by its ticker symbol",
      "group": "stock_trading",
      "object_category": "market_data_management",
      "action_category": "data_operations",
      "pre_condition": "Valid stock ticker symbol must be provided",
      "post_condition": "Returns current price with timestamp",
      "parameters": {
        "type": "object",
        "properties": {
          "ticker_symbol": {
            "description": "The stock ticker symbol (e.g., AAPL, GOOGL)",
            "type": "string",
            "examples": [
              "AAPL",
              "MSFT"
            ]
          }
        },
        "required": [
          "ticker_symbol"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "ticker_symbol": {
            "description": "The stock ticker symbol",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          },
          "current_price": {
            "description": "Current stock price in USD",
            "type": "number",
            "examples": [
              175.43
            ]
          },
          "timestamp": {
            "description": "Time of price retrieval in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "stock_price_history"
      ]
    },
    {
      "name": "get_user_watchlists",
      "description": "Retrieves all watchlists for a specific user",
      "group": "stock_trading",
      "object_category": "watchlist_management",
      "action_category": "data_operations",
      "pre_condition": "Valid user ID must be provided",
      "post_condition": "Returns list of watchlists",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          }
        },
        "required": [
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "watchlists": {
            "description": "List of user watchlists",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "watchlist_id": "watchlist_11111",
                  "watchlist_name": "Tech Stocks",
                  "stock_count": 5
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "watchlist"
      ]
    },
    {
      "name": "check_buying_power",
      "description": "Checks if user has sufficient buying power for a proposed trade",
      "group": "stock_trading",
      "object_category": "risk_management",
      "action_category": "validation",
      "pre_condition": "User ID and trade details must be provided",
      "post_condition": "Returns whether user has sufficient buying power",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "order_value": {
            "description": "Total value of the proposed order",
            "type": "number",
            "examples": [
              17550.0
            ]
          }
        },
        "required": [
          "user_id",
          "order_value"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "has_sufficient_power": {
            "description": "Whether user has sufficient buying power",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "buying_power": {
            "description": "Available buying power",
            "type": "number",
            "examples": [
              20000.0
            ]
          },
          "shortfall": {
            "description": "Amount short if insufficient (0 if sufficient)",
            "type": "number",
            "examples": [
              0.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "user_account"
      ]
    },
    {
      "name": "create_stop_loss_order",
      "description": "Creates a stop-loss order to automatically sell when price falls to specified level",
      "group": "stock_trading",
      "object_category": "order_management",
      "action_category": "data_operations",
      "pre_condition": "Valid ticker symbol, quantity, and stop price must be provided",
      "post_condition": "Stop-loss order is created and monitoring price",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user placing the order",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "ticker_symbol": {
            "description": "The stock ticker symbol",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          },
          "quantity": {
            "description": "Number of shares to sell",
            "type": "integer",
            "examples": [
              100
            ]
          },
          "stop_price": {
            "description": "Price level that triggers the stop-loss order",
            "type": "number",
            "examples": [
              170.0
            ]
          }
        },
        "required": [
          "user_id",
          "ticker_symbol",
          "quantity",
          "stop_price"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier for the created order",
            "type": "string",
            "examples": [
              "order_98767"
            ]
          },
          "status": {
            "description": "Order status",
            "type": "string",
            "examples": [
              "monitoring"
            ]
          },
          "created_at": {
            "description": "Order creation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "stock_order",
        "user_account"
      ]
    },
    {
      "name": "calculate_moving_average",
      "description": "Calculates the moving average of stock prices over a specified period",
      "group": "stock_trading",
      "object_category": "analysis_management",
      "action_category": "computation",
      "pre_condition": "Price data and period must be provided",
      "post_condition": "Returns calculated moving average value",
      "parameters": {
        "type": "object",
        "properties": {
          "prices": {
            "description": "Array of historical closing prices",
            "type": "array",
            "items": {
              "type": "number"
            },
            "examples": [
              [
                100.5,
                101.2,
                102.0,
                101.8,
                103.5
              ]
            ]
          },
          "period": {
            "description": "Number of periods for moving average calculation",
            "type": "integer",
            "examples": [
              20,
              50
            ]
          }
        },
        "required": [
          "prices",
          "period"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "moving_average": {
            "description": "Calculated moving average value",
            "type": "number",
            "examples": [
              101.8
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_position_profit_loss",
      "description": "Calculates profit/loss for a specific position",
      "group": "stock_trading",
      "object_category": "portfolio_management",
      "action_category": "computation",
      "pre_condition": "Position details with cost basis and current price must be provided",
      "post_condition": "Returns profit/loss amount and percentage",
      "parameters": {
        "type": "object",
        "properties": {
          "quantity": {
            "description": "Number of shares held",
            "type": "integer",
            "examples": [
              100
            ]
          },
          "average_cost": {
            "description": "Average cost per share",
            "type": "number",
            "examples": [
              170.5
            ]
          },
          "price": {
            "description": "Current market price per share",
            "type": "number",
            "examples": [
              175.43
            ]
          }
        },
        "required": [
          "quantity",
          "average_cost",
          "price"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "profit_loss": {
            "description": "Profit or loss amount in USD",
            "type": "number",
            "examples": [
              493.0
            ]
          },
          "profit_loss_percentage": {
            "description": "Profit or loss percentage",
            "type": "number",
            "examples": [
              2.89
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "create_limit_order",
      "description": "Creates a limit order to buy or sell stock at a specified price or better",
      "group": "stock_trading",
      "object_category": "order_management",
      "action_category": "data_operations",
      "pre_condition": "Valid ticker symbol, order side, quantity, and limit price must be provided",
      "post_condition": "Limit order is created and pending execution",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user placing the order",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "ticker_symbol": {
            "description": "The stock ticker symbol",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          },
          "order_side": {
            "description": "Order side: buy or sell",
            "type": "string",
            "enum": [
              "buy",
              "sell"
            ],
            "examples": [
              "buy"
            ]
          },
          "quantity": {
            "description": "Number of shares to trade",
            "type": "integer",
            "examples": [
              100
            ]
          },
          "limit_price": {
            "description": "Maximum price for buy or minimum price for sell",
            "type": "number",
            "examples": [
              175.5
            ]
          }
        },
        "required": [
          "user_id",
          "ticker_symbol",
          "order_side",
          "quantity",
          "limit_price"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier for the created order",
            "type": "string",
            "examples": [
              "order_98766"
            ]
          },
          "status": {
            "description": "Order status",
            "type": "string",
            "examples": [
              "pending"
            ]
          },
          "created_at": {
            "description": "Order creation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "stock_order",
        "user_account"
      ]
    },
    {
      "name": "remove_stock_from_watchlist",
      "description": "Removes a stock from an existing watchlist",
      "group": "stock_trading",
      "object_category": "watchlist_management",
      "action_category": "data_operations",
      "pre_condition": "Valid watchlist ID and ticker symbol must be provided",
      "post_condition": "Stock is removed from watchlist",
      "parameters": {
        "type": "object",
        "properties": {
          "watchlist_id": {
            "description": "Unique identifier of the watchlist",
            "type": "string",
            "examples": [
              "watchlist_11111"
            ]
          },
          "ticker_symbol": {
            "description": "Stock ticker symbol to remove",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          }
        },
        "required": [
          "watchlist_id",
          "ticker_symbol"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "watchlist_id": {
            "description": "Unique identifier of the watchlist",
            "type": "string",
            "examples": [
              "watchlist_11111"
            ]
          },
          "ticker_symbol": {
            "description": "Stock ticker symbol removed",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "watchlist_stock"
      ]
    },
    {
      "name": "calculate_pe_ratio",
      "description": "Calculates the price-to-earnings ratio for a stock",
      "group": "stock_trading",
      "object_category": "analysis_management",
      "action_category": "computation",
      "pre_condition": "Stock price and earnings per share must be provided",
      "post_condition": "Returns calculated PE ratio",
      "parameters": {
        "type": "object",
        "properties": {
          "price": {
            "description": "Current stock price",
            "type": "number",
            "examples": [
              175.43
            ]
          },
          "earnings_per_share": {
            "description": "Earnings per share",
            "type": "number",
            "examples": [
              6.15
            ]
          }
        },
        "required": [
          "price",
          "earnings_per_share"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "pe_ratio": {
            "description": "Calculated price-to-earnings ratio",
            "type": "number",
            "examples": [
              28.52
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "add_stock_to_watchlist",
      "description": "Adds a stock to an existing watchlist",
      "group": "stock_trading",
      "object_category": "watchlist_management",
      "action_category": "data_operations",
      "pre_condition": "Valid watchlist ID and ticker symbol must be provided",
      "post_condition": "Stock is added to watchlist",
      "parameters": {
        "type": "object",
        "properties": {
          "watchlist_id": {
            "description": "Unique identifier of the watchlist",
            "type": "string",
            "examples": [
              "watchlist_11111"
            ]
          },
          "ticker_symbol": {
            "description": "Stock ticker symbol to add",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          }
        },
        "required": [
          "watchlist_id",
          "ticker_symbol"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "watchlist_id": {
            "description": "Unique identifier of the watchlist",
            "type": "string",
            "examples": [
              "watchlist_11111"
            ]
          },
          "ticker_symbol": {
            "description": "Stock ticker symbol added",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          },
          "created_at": {
            "description": "Timestamp when stock was added in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "watchlist_stock"
      ]
    },
    {
      "name": "validate_order_parameters",
      "description": "Validates order parameters before submission to ensure compliance with trading rules",
      "group": "stock_trading",
      "object_category": "risk_management",
      "action_category": "validation",
      "pre_condition": "Order parameters must be provided",
      "post_condition": "Returns validation result with any errors",
      "parameters": {
        "type": "object",
        "properties": {
          "ticker_symbol": {
            "description": "Stock ticker symbol",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          },
          "order_type": {
            "description": "Type of order",
            "type": "string",
            "enum": [
              "market",
              "limit",
              "stop_loss"
            ],
            "examples": [
              "limit"
            ]
          },
          "order_side": {
            "description": "Order side",
            "type": "string",
            "enum": [
              "buy",
              "sell"
            ],
            "examples": [
              "buy"
            ]
          },
          "quantity": {
            "description": "Number of shares",
            "type": "integer",
            "examples": [
              100
            ]
          },
          "price": {
            "description": "Order price (for limit/stop orders)",
            "type": "number",
            "examples": [
              175.5
            ]
          }
        },
        "required": [
          "ticker_symbol",
          "order_type",
          "order_side",
          "quantity"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Whether order parameters are valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "errors": {
            "description": "List of validation errors if any",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": []
          }
        },
        "raises": "ValueError"
      },
      "raises": "",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_portfolio_return",
      "description": "Calculates the total return and return percentage of a portfolio",
      "group": "stock_trading",
      "object_category": "portfolio_management",
      "action_category": "computation",
      "pre_condition": "Portfolio positions with cost basis and current prices must be provided",
      "post_condition": "Returns total return amount and percentage",
      "parameters": {
        "type": "object",
        "properties": {
          "positions": {
            "description": "Array of portfolio positions with quantities, cost basis, and current prices",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "ticker_symbol": "AAPL",
                  "quantity": 100,
                  "average_cost": 170.5,
                  "current_price": 175.43
                }
              ]
            ]
          }
        },
        "required": [
          "positions"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "profit_loss": {
            "description": "Total return amount in USD",
            "type": "number",
            "examples": [
              493.0
            ]
          },
          "return_percentage": {
            "description": "Return percentage",
            "type": "number",
            "examples": [
              2.89
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_dividend_yield",
      "description": "Calculates the dividend yield for a stock",
      "group": "stock_trading",
      "object_category": "analysis_management",
      "action_category": "computation",
      "pre_condition": "Annual dividend and stock price must be provided",
      "post_condition": "Returns calculated dividend yield",
      "parameters": {
        "type": "object",
        "properties": {
          "annual_dividend": {
            "description": "Annual dividend per share",
            "type": "number",
            "examples": [
              0.92
            ]
          },
          "price": {
            "description": "Current stock price",
            "type": "number",
            "examples": [
              175.43
            ]
          }
        },
        "required": [
          "annual_dividend",
          "price"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "dividend_yield": {
            "description": "Calculated dividend yield as decimal",
            "type": "number",
            "examples": [
              0.0052
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_transaction_history",
      "description": "Retrieves account transaction history for a specified date range",
      "group": "stock_trading",
      "object_category": "account_management",
      "action_category": "data_operations",
      "pre_condition": "Valid user ID and date range must be provided",
      "post_condition": "Returns list of transactions",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "start_date": {
            "description": "Start date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-01"
            ]
          },
          "end_date": {
            "description": "End date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-15"
            ]
          }
        },
        "required": [
          "user_id",
          "start_date",
          "end_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "transactions": {
            "description": "List of account transactions",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "transaction_id": "txn_12345",
                  "type": "deposit",
                  "amount": 5000.0,
                  "timestamp": "2024-01-10 10:00:00"
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "account_transaction"
      ]
    },
    {
      "name": "calculate_portfolio_value",
      "description": "Calculates the total current market value of a portfolio",
      "group": "stock_trading",
      "object_category": "portfolio_management",
      "action_category": "computation",
      "pre_condition": "Portfolio positions with current prices must be provided",
      "post_condition": "Returns total portfolio value",
      "parameters": {
        "type": "object",
        "properties": {
          "positions": {
            "description": "Array of portfolio positions with quantities and current prices",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "ticker_symbol": "AAPL",
                  "quantity": 100,
                  "current_price": 175.43
                }
              ]
            ]
          }
        },
        "required": [
          "positions"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_value": {
            "description": "Total portfolio market value",
            "type": "number",
            "examples": [
              52000.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "create_market_order",
      "description": "Creates a market order to buy or sell stock at current market price",
      "group": "stock_trading",
      "object_category": "order_management",
      "action_category": "data_operations",
      "pre_condition": "Valid ticker symbol, order side, and quantity must be provided",
      "post_condition": "Order is created and pending execution",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user placing the order",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "ticker_symbol": {
            "description": "The stock ticker symbol",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          },
          "order_side": {
            "description": "Order side: buy or sell",
            "type": "string",
            "enum": [
              "buy",
              "sell"
            ],
            "examples": [
              "buy"
            ]
          },
          "quantity": {
            "description": "Number of shares to trade",
            "type": "integer",
            "examples": [
              100
            ]
          }
        },
        "required": [
          "user_id",
          "ticker_symbol",
          "order_side",
          "quantity"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier for the created order",
            "type": "string",
            "examples": [
              "order_98765"
            ]
          },
          "status": {
            "description": "Order status",
            "type": "string",
            "examples": [
              "pending"
            ]
          },
          "created_at": {
            "description": "Order creation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "stock_order",
        "user_account"
      ]
    },
    {
      "name": "withdraw_funds",
      "description": "Withdraws funds from a user's trading account",
      "group": "stock_trading",
      "object_category": "account_management",
      "action_category": "data_operations",
      "pre_condition": "Valid user ID, positive amount, and sufficient balance must be provided",
      "post_condition": "Funds are deducted from account balance",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "amount": {
            "description": "Amount to withdraw in USD",
            "type": "number",
            "examples": [
              2000.0
            ]
          }
        },
        "required": [
          "user_id",
          "amount"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "transaction_id": {
            "description": "Unique identifier for the withdrawal transaction",
            "type": "string",
            "examples": [
              "txn_12346"
            ]
          },
          "new_balance": {
            "description": "Updated cash balance after withdrawal",
            "type": "number",
            "examples": [
              8000.0
            ]
          },
          "timestamp": {
            "description": "Transaction timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 11:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "user_account",
        "account_transaction"
      ]
    },
    {
      "name": "create_watchlist",
      "description": "Creates a new watchlist for tracking multiple stocks",
      "group": "stock_trading",
      "object_category": "watchlist_management",
      "action_category": "data_operations",
      "pre_condition": "Valid user ID and watchlist name must be provided",
      "post_condition": "Watchlist is created",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "watchlist_name": {
            "description": "Name of the watchlist",
            "type": "string",
            "examples": [
              "Tech Stocks"
            ]
          }
        },
        "required": [
          "user_id",
          "watchlist_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "watchlist_id": {
            "description": "Unique identifier for the created watchlist",
            "type": "string",
            "examples": [
              "watchlist_11111"
            ]
          },
          "watchlist_name": {
            "description": "Name of the watchlist",
            "type": "string",
            "examples": [
              "Tech Stocks"
            ]
          },
          "created_at": {
            "description": "Watchlist creation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "watchlist"
      ]
    },
    {
      "name": "get_user_portfolio",
      "description": "Retrieves the complete portfolio holdings for a specific user",
      "group": "stock_trading",
      "object_category": "portfolio_management",
      "action_category": "data_operations",
      "pre_condition": "Valid user ID must be provided",
      "post_condition": "Returns all portfolio positions",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          }
        },
        "required": [
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "positions": {
            "description": "List of stock positions",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "ticker_symbol": "AAPL",
                  "quantity": 100,
                  "average_cost": 170.5,
                  "current_price": 175.43,
                  "market_value": 17543.0
                }
              ]
            ]
          },
          "total_value": {
            "description": "Total portfolio market value",
            "type": "number",
            "examples": [
              52000.0
            ]
          },
          "cash_balance": {
            "description": "Available cash balance",
            "type": "number",
            "examples": [
              10000.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "portfolio_position",
        "user_account"
      ]
    },
    {
      "name": "get_stock_fundamentals",
      "description": "Retrieves fundamental financial data for a stock",
      "group": "stock_trading",
      "object_category": "analysis_management",
      "action_category": "data_operations",
      "pre_condition": "Valid ticker symbol must be provided",
      "post_condition": "Returns fundamental financial metrics",
      "parameters": {
        "type": "object",
        "properties": {
          "ticker_symbol": {
            "description": "Stock ticker symbol",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          }
        },
        "required": [
          "ticker_symbol"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "ticker_symbol": {
            "description": "Stock ticker symbol",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          },
          "market_cap": {
            "description": "Market capitalization",
            "type": "number",
            "examples": [
              2800000000000
            ]
          },
          "pe_ratio": {
            "description": "Price-to-earnings ratio",
            "type": "number",
            "examples": [
              28.5
            ]
          },
          "eps": {
            "description": "Earnings per share",
            "type": "number",
            "examples": [
              6.15
            ]
          },
          "dividend_yield": {
            "description": "Dividend yield as decimal",
            "type": "number",
            "examples": [
              0.0052
            ]
          },
          "revenue": {
            "description": "Annual revenue",
            "type": "number",
            "examples": [
              394000000000
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "stock_fundamental"
      ]
    },
    {
      "name": "calculate_correlation_coefficient",
      "description": "Calculates the correlation coefficient between two stocks' price movements",
      "group": "stock_trading",
      "object_category": "analysis_management",
      "action_category": "computation",
      "pre_condition": "Price data for both stocks must be provided",
      "post_condition": "Returns correlation coefficient",
      "parameters": {
        "type": "object",
        "properties": {
          "stock1_prices": {
            "description": "Array of historical prices for first stock",
            "type": "array",
            "items": {
              "type": "number"
            },
            "examples": [
              [
                100.5,
                101.2,
                99.8,
                102.0
              ]
            ]
          },
          "stock2_prices": {
            "description": "Array of historical prices for second stock",
            "type": "array",
            "items": {
              "type": "number"
            },
            "examples": [
              [
                200.0,
                202.5,
                198.0,
                205.0
              ]
            ]
          }
        },
        "required": [
          "stock1_prices",
          "stock2_prices"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "correlation_coefficient": {
            "description": "Correlation coefficient between -1 and 1",
            "type": "number",
            "examples": [
              0.85
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_bollinger_bands",
      "description": "Calculates Bollinger Bands for volatility analysis",
      "group": "stock_trading",
      "object_category": "analysis_management",
      "action_category": "computation",
      "pre_condition": "Price data, period, and standard deviation multiplier must be provided",
      "post_condition": "Returns upper band, middle band, and lower band values",
      "parameters": {
        "type": "object",
        "properties": {
          "prices": {
            "description": "Array of historical closing prices",
            "type": "array",
            "items": {
              "type": "number"
            },
            "examples": [
              [
                100.5,
                101.2,
                99.8,
                102.0,
                103.5
              ]
            ]
          },
          "period": {
            "description": "Number of periods for moving average (typically 20)",
            "type": "integer",
            "examples": [
              20
            ]
          },
          "std_dev_multiplier": {
            "description": "Standard deviation multiplier (typically 2)",
            "type": "number",
            "examples": [
              2.0
            ]
          }
        },
        "required": [
          "prices",
          "period",
          "std_dev_multiplier"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "upper_band": {
            "description": "Upper Bollinger Band value",
            "type": "number",
            "examples": [
              105.2
            ]
          },
          "middle_band": {
            "description": "Middle Bollinger Band (SMA) value",
            "type": "number",
            "examples": [
              101.8
            ]
          },
          "lower_band": {
            "description": "Lower Bollinger Band value",
            "type": "number",
            "examples": [
              98.4
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_user_alerts",
      "description": "Retrieves all active price alerts for a specific user",
      "group": "stock_trading",
      "object_category": "alert_management",
      "action_category": "data_operations",
      "pre_condition": "Valid user ID must be provided",
      "post_condition": "Returns list of active alerts",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          }
        },
        "required": [
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "alerts": {
            "description": "List of active price alerts",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "alert_id": "alert_56789",
                  "ticker_symbol": "AAPL",
                  "target_price": 180.0,
                  "condition": "above",
                  "status": "active"
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "price_alert"
      ]
    },
    {
      "name": "compare_stocks",
      "description": "Compares key metrics between multiple stocks for analysis",
      "group": "stock_trading",
      "object_category": "analysis_management",
      "action_category": "data_analysis",
      "pre_condition": "List of ticker symbols must be provided",
      "post_condition": "Returns comparison of stock metrics",
      "parameters": {
        "type": "object",
        "properties": {
          "ticker_symbols": {
            "description": "Array of stock ticker symbols to compare",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "AAPL",
                "MSFT",
                "GOOGL"
              ]
            ]
          },
          "metrics": {
            "description": "List of metrics to compare",
            "type": "array",
            "items": {
              "type": "string",
              "enum": [
                "price",
                "pe_ratio",
                "market_cap",
                "dividend_yield",
                "revenue",
                "eps"
              ]
            },
            "examples": [
              [
                "price",
                "pe_ratio",
                "market_cap"
              ]
            ]
          }
        },
        "required": [
          "ticker_symbols",
          "metrics"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "comparison_data": {
            "description": "Comparison data for specified stocks and metrics",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "ticker_symbol": "AAPL",
                  "price": 175.43,
                  "pe_ratio": 28.5,
                  "market_cap": 2800000000000
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "stock_fundamental",
        "stock_price_history"
      ]
    },
    {
      "name": "get_user_order_history",
      "description": "Retrieves historical order records for a user within a date range",
      "group": "stock_trading",
      "object_category": "order_management",
      "action_category": "data_operations",
      "pre_condition": "Valid user ID and date range must be provided",
      "post_condition": "Returns list of historical orders",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "start_date": {
            "description": "Start date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-01"
            ]
          },
          "end_date": {
            "description": "End date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-15"
            ]
          }
        },
        "required": [
          "user_id",
          "start_date",
          "end_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "order_history": {
            "description": "List of historical orders",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "order_id": "order_98765",
                  "ticker_symbol": "AAPL",
                  "order_type": "market",
                  "quantity": 100,
                  "status": "filled",
                  "filled_at": "2024-01-10 14:30:00"
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "stock_order"
      ]
    },
    {
      "name": "calculate_sharpe_ratio",
      "description": "Calculates the Sharpe ratio for portfolio performance evaluation",
      "group": "stock_trading",
      "object_category": "analysis_management",
      "action_category": "computation",
      "pre_condition": "Portfolio returns, risk-free rate, and standard deviation must be provided",
      "post_condition": "Returns Sharpe ratio value",
      "parameters": {
        "type": "object",
        "properties": {
          "portfolio_return": {
            "description": "Portfolio return as decimal (e.g., 0.15 for 15%)",
            "type": "number",
            "examples": [
              0.15
            ]
          },
          "risk_free_rate": {
            "description": "Risk-free rate as decimal",
            "type": "number",
            "examples": [
              0.03
            ]
          },
          "standard_deviation": {
            "description": "Portfolio standard deviation",
            "type": "number",
            "examples": [
              0.2
            ]
          }
        },
        "required": [
          "portfolio_return",
          "risk_free_rate",
          "standard_deviation"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "sharpe_ratio": {
            "description": "Calculated Sharpe ratio",
            "type": "number",
            "examples": [
              0.6
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_user_open_orders",
      "description": "Retrieves all open orders for a specific user",
      "group": "stock_trading",
      "object_category": "order_management",
      "action_category": "data_operations",
      "pre_condition": "Valid user ID must be provided",
      "post_condition": "Returns list of all open orders",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          }
        },
        "required": [
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "open_orders": {
            "description": "List of open orders",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "order_id": "order_98765",
                  "ticker_symbol": "AAPL",
                  "order_type": "limit",
                  "quantity": 100,
                  "status": "pending"
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "stock_order"
      ]
    },
    {
      "name": "calculate_macd",
      "description": "Calculates the Moving Average Convergence Divergence (MACD) indicator",
      "group": "stock_trading",
      "object_category": "analysis_management",
      "action_category": "computation",
      "pre_condition": "Price data must be provided",
      "post_condition": "Returns MACD line, signal line, and histogram values",
      "parameters": {
        "type": "object",
        "properties": {
          "prices": {
            "description": "Array of historical closing prices",
            "type": "array",
            "items": {
              "type": "number"
            },
            "examples": [
              [
                100.5,
                101.2,
                99.8,
                102.0,
                103.5
              ]
            ]
          },
          "fast_period": {
            "description": "Fast EMA period (typically 12)",
            "type": "integer",
            "examples": [
              12
            ]
          },
          "slow_period": {
            "description": "Slow EMA period (typically 26)",
            "type": "integer",
            "examples": [
              26
            ]
          },
          "signal_period": {
            "description": "Signal line period (typically 9)",
            "type": "integer",
            "examples": [
              9
            ]
          }
        },
        "required": [
          "prices",
          "fast_period",
          "slow_period",
          "signal_period"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "macd_line": {
            "description": "MACD line value",
            "type": "number",
            "examples": [
              2.34
            ]
          },
          "signal_line": {
            "description": "Signal line value",
            "type": "number",
            "examples": [
              1.98
            ]
          },
          "histogram": {
            "description": "MACD histogram value",
            "type": "number",
            "examples": [
              0.36
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_portfolio_beta",
      "description": "Calculates the portfolio beta relative to market benchmark",
      "group": "stock_trading",
      "object_category": "risk_management",
      "action_category": "computation",
      "pre_condition": "Portfolio positions with individual stock betas must be provided",
      "post_condition": "Returns weighted portfolio beta",
      "parameters": {
        "type": "object",
        "properties": {
          "positions": {
            "description": "Array of positions with beta values and weights",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "ticker_symbol": "AAPL",
                  "beta": 1.2,
                  "weight": 0.4
                }
              ]
            ]
          }
        },
        "required": [
          "positions"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "portfolio_beta": {
            "description": "Weighted portfolio beta",
            "type": "number",
            "examples": [
              1.15
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_stock_historical_prices",
      "description": "Retrieves historical price data for a stock within a specified date range",
      "group": "stock_trading",
      "object_category": "market_data_management",
      "action_category": "data_operations",
      "pre_condition": "Valid ticker symbol and date range must be provided",
      "post_condition": "Returns list of historical price records",
      "parameters": {
        "type": "object",
        "properties": {
          "ticker_symbol": {
            "description": "The stock ticker symbol",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          },
          "start_date": {
            "description": "Start date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-01"
            ]
          },
          "end_date": {
            "description": "End date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-15"
            ]
          }
        },
        "required": [
          "ticker_symbol",
          "start_date",
          "end_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "ticker_symbol": {
            "description": "The stock ticker symbol",
            "type": "string",
            "examples": [
              "AAPL"
            ]
          },
          "price_data": {
            "description": "List of historical price records",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "date": "2024-01-01",
                  "open": 170.5,
                  "high": 175.2,
                  "low": 169.8,
                  "close": 174.3,
                  "volume": 50000000
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "stock_price_history"
      ]
    },
    {
      "name": "deposit_funds",
      "description": "Deposits funds into a user's trading account",
      "group": "stock_trading",
      "object_category": "account_management",
      "action_category": "data_operations",
      "pre_condition": "Valid user ID and positive deposit amount must be provided",
      "post_condition": "Funds are added to account balance",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "amount": {
            "description": "Amount to deposit in USD",
            "type": "number",
            "examples": [
              5000.0
            ]
          }
        },
        "required": [
          "user_id",
          "amount"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "transaction_id": {
            "description": "Unique identifier for the deposit transaction",
            "type": "string",
            "examples": [
              "txn_12345"
            ]
          },
          "new_balance": {
            "description": "Updated cash balance after deposit",
            "type": "number",
            "examples": [
              15000.0
            ]
          },
          "timestamp": {
            "description": "Transaction timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "user_account",
        "account_transaction"
      ]
    },
    {
      "name": "get_account_balance",
      "description": "Retrieves the current cash balance and buying power of a user account",
      "group": "stock_trading",
      "object_category": "account_management",
      "action_category": "data_operations",
      "pre_condition": "Valid user ID must be provided",
      "post_condition": "Returns account balance information",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          }
        },
        "required": [
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "cash_balance": {
            "description": "Available cash balance in USD",
            "type": "number",
            "examples": [
              10000.0
            ]
          },
          "buying_power": {
            "description": "Total buying power including margin",
            "type": "number",
            "examples": [
              20000.0
            ]
          },
          "margin_used": {
            "description": "Amount of margin currently used",
            "type": "number",
            "examples": [
              5000.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "user_account"
      ]
    },
    {
      "name": "delete_price_alert",
      "description": "Deletes an existing price alert",
      "group": "stock_trading",
      "object_category": "alert_management",
      "action_category": "data_operations",
      "pre_condition": "Valid alert ID must be provided",
      "post_condition": "Alert is deleted and no longer active",
      "parameters": {
        "type": "object",
        "properties": {
          "alert_id": {
            "description": "Unique identifier of the alert to delete",
            "type": "string",
            "examples": [
              "alert_56789"
            ]
          }
        },
        "required": [
          "alert_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "alert_id": {
            "description": "Unique identifier of the deleted alert",
            "type": "string",
            "examples": [
              "alert_56789"
            ]
          },
          "status": {
            "description": "Updated alert status",
            "type": "string",
            "examples": [
              "deleted"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "price_alert"
      ]
    }
  ]
}