{
  "domain": "express_logistics",
  "databases": [
    {
      "table_name": "shipment_order",
      "description": "Stores shipment order information including sender, recipient, package details, and order status",
      "schema": {
        "columns": [
          {
            "name": "order_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the shipment order",
            "optional": false
          },
          {
            "name": "tracking_number",
            "type": "VARCHAR(20)",
            "description": "Tracking number for the shipment",
            "optional": false
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Current status of the shipment",
            "default": "pending",
            "optional": false,
            "enum": [
              "pending",
              "picked_up",
              "in_transit",
              "out_for_delivery",
              "delivered",
              "failed",
              "cancelled",
              "returned"
            ]
          },
          {
            "name": "sender_name",
            "type": "VARCHAR(100)",
            "description": "Sender's full name",
            "optional": false
          },
          {
            "name": "sender_phone",
            "type": "VARCHAR(20)",
            "description": "Sender's phone number",
            "optional": false
          },
          {
            "name": "sender_address",
            "type": "TEXT",
            "description": "Sender's complete address",
            "optional": false
          },
          {
            "name": "recipient_name",
            "type": "VARCHAR(100)",
            "description": "Recipient's full name",
            "optional": false
          },
          {
            "name": "recipient_phone",
            "type": "VARCHAR(20)",
            "description": "Recipient's phone number",
            "optional": false
          },
          {
            "name": "recipient_address",
            "type": "TEXT",
            "description": "Recipient's complete address",
            "optional": false
          },
          {
            "name": "weight",
            "type": "DECIMAL(10,2)",
            "description": "Package weight in kilograms",
            "optional": false
          },
          {
            "name": "length",
            "type": "DECIMAL(10,2)",
            "description": "Package length in centimeters",
            "optional": false
          },
          {
            "name": "width",
            "type": "DECIMAL(10,2)",
            "description": "Package width in centimeters",
            "optional": false
          },
          {
            "name": "height",
            "type": "DECIMAL(10,2)",
            "description": "Package height in centimeters",
            "optional": false
          },
          {
            "name": "service_type",
            "type": "VARCHAR(20)",
            "description": "Type of courier service",
            "optional": false,
            "enum": [
              "standard",
              "express",
              "same_day",
              "next_day"
            ]
          },
          {
            "name": "declared_value",
            "type": "DECIMAL(10,2)",
            "description": "Declared value of package contents in currency units",
            "optional": true
          },
          {
            "name": "total_cost",
            "type": "DECIMAL(10,2)",
            "description": "Total shipping cost including all charges",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Order creation timestamp",
            "optional": false
          },
          {
            "name": "updated_at",
            "type": "DATETIME",
            "description": "Last update timestamp",
            "optional": true
          }
        ],
        "primary_key": "order_id"
      }
    },
    {
      "table_name": "courier",
      "description": "Stores courier information and current location data",
      "schema": {
        "columns": [
          {
            "name": "courier_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the courier",
            "optional": false
          },
          {
            "name": "courier_name",
            "type": "VARCHAR(100)",
            "description": "Courier's full name",
            "optional": false
          },
          {
            "name": "phone_number",
            "type": "VARCHAR(20)",
            "description": "Courier's phone number",
            "optional": false
          },
          {
            "name": "current_latitude",
            "type": "DECIMAL(10,6)",
            "description": "Current latitude coordinate",
            "optional": true
          },
          {
            "name": "current_longitude",
            "type": "DECIMAL(10,6)",
            "description": "Current longitude coordinate",
            "optional": true
          },
          {
            "name": "last_location_update",
            "type": "DATETIME",
            "description": "Last location update timestamp",
            "optional": true
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Current working status of the courier",
            "default": "available",
            "optional": false,
            "enum": [
              "available",
              "busy",
              "offline"
            ]
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Courier registration timestamp",
            "optional": false
          }
        ],
        "primary_key": "courier_id"
      }
    },
    {
      "table_name": "courier_assignment",
      "description": "Stores courier assignment information for pickup and delivery tasks",
      "schema": {
        "columns": [
          {
            "name": "assignment_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the assignment",
            "optional": false
          },
          {
            "name": "order_id",
            "type": "VARCHAR(10)",
            "description": "Reference to shipment order",
            "optional": false,
            "references": "shipment_order.order_id"
          },
          {
            "name": "courier_id",
            "type": "VARCHAR(10)",
            "description": "Reference to courier",
            "optional": false,
            "references": "courier.courier_id"
          },
          {
            "name": "assignment_type",
            "type": "VARCHAR(20)",
            "description": "Type of assignment",
            "optional": false,
            "enum": [
              "pickup",
              "delivery"
            ]
          },
          {
            "name": "scheduled_time",
            "type": "DATETIME",
            "description": "Scheduled pickup or delivery time",
            "optional": false
          },
          {
            "name": "assignment_status",
            "type": "VARCHAR(20)",
            "description": "Status of the assignment",
            "default": "assigned",
            "optional": false,
            "enum": [
              "assigned",
              "in_progress",
              "completed",
              "cancelled"
            ]
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Assignment creation timestamp",
            "optional": false
          }
        ],
        "primary_key": "assignment_id"
      }
    },
    {
      "table_name": "pickup_record",
      "description": "Stores pickup completion records with signature and timestamp",
      "schema": {
        "columns": [
          {
            "name": "pickup_record_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the pickup record",
            "optional": false
          },
          {
            "name": "order_id",
            "type": "VARCHAR(10)",
            "description": "Reference to shipment order",
            "optional": false,
            "references": "shipment_order.order_id"
          },
          {
            "name": "courier_id",
            "type": "VARCHAR(10)",
            "description": "Reference to courier who performed pickup",
            "optional": false,
            "references": "courier.courier_id"
          },
          {
            "name": "pickup_time",
            "type": "DATETIME",
            "description": "Actual pickup timestamp",
            "optional": false
          },
          {
            "name": "pickup_signature",
            "type": "VARCHAR(100)",
            "description": "Digital signature or confirmation code from sender",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Record creation timestamp",
            "optional": false
          }
        ],
        "primary_key": "pickup_record_id"
      }
    },
    {
      "table_name": "delivery_record",
      "description": "Stores delivery completion records with recipient signature and proof",
      "schema": {
        "columns": [
          {
            "name": "delivery_record_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the delivery record",
            "optional": false
          },
          {
            "name": "order_id",
            "type": "VARCHAR(10)",
            "description": "Reference to shipment order",
            "optional": false,
            "references": "shipment_order.order_id"
          },
          {
            "name": "courier_id",
            "type": "VARCHAR(10)",
            "description": "Reference to courier who performed delivery",
            "optional": false,
            "references": "courier.courier_id"
          },
          {
            "name": "actual_delivery_time",
            "type": "DATETIME",
            "description": "Actual delivery timestamp",
            "optional": false
          },
          {
            "name": "recipient_signature",
            "type": "VARCHAR(100)",
            "description": "Digital signature or confirmation code from recipient",
            "optional": false
          },
          {
            "name": "received_by",
            "type": "VARCHAR(100)",
            "description": "Name of the person who received the package",
            "optional": false
          },
          {
            "name": "photo_evidence",
            "type": "TEXT",
            "description": "Photo evidence of delivery (URL or base64 data)",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Record creation timestamp",
            "optional": false
          }
        ],
        "primary_key": "delivery_record_id"
      }
    },
    {
      "table_name": "delivery_attempt",
      "description": "Stores failed delivery attempt records with failure reasons",
      "schema": {
        "columns": [
          {
            "name": "attempt_record_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the delivery attempt record",
            "optional": false
          },
          {
            "name": "order_id",
            "type": "VARCHAR(10)",
            "description": "Reference to shipment order",
            "optional": false,
            "references": "shipment_order.order_id"
          },
          {
            "name": "courier_id",
            "type": "VARCHAR(10)",
            "description": "Reference to courier who attempted delivery",
            "optional": false,
            "references": "courier.courier_id"
          },
          {
            "name": "attempt_time",
            "type": "DATETIME",
            "description": "Delivery attempt timestamp",
            "optional": false
          },
          {
            "name": "failure_reason",
            "type": "VARCHAR(50)",
            "description": "Reason for delivery failure",
            "optional": false,
            "enum": [
              "recipient_not_home",
              "incorrect_address",
              "refused_delivery",
              "access_denied",
              "weather_conditions",
              "other"
            ]
          },
          {
            "name": "notes",
            "type": "TEXT",
            "description": "Additional notes about the delivery attempt",
            "optional": true
          },
          {
            "name": "attempt_count",
            "type": "INTEGER",
            "description": "Sequential attempt number for this order",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Record creation timestamp",
            "optional": false
          }
        ],
        "primary_key": "attempt_record_id"
      }
    },
    {
      "table_name": "tracking_event",
      "description": "Stores tracking events and status updates for shipments",
      "schema": {
        "columns": [
          {
            "name": "event_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the tracking event",
            "optional": false
          },
          {
            "name": "tracking_number",
            "type": "VARCHAR(20)",
            "description": "Tracking number for the shipment",
            "optional": false,
            "references": "shipment_order.tracking_number"
          },
          {
            "name": "event_type",
            "type": "VARCHAR(30)",
            "description": "Type of tracking event",
            "optional": false,
            "enum": [
              "order_created",
              "picked_up",
              "in_transit",
              "arrived_at_facility",
              "out_for_delivery",
              "delivered",
              "exception",
              "returned"
            ]
          },
          {
            "name": "event_location",
            "type": "VARCHAR(200)",
            "description": "Location where the event occurred",
            "optional": false
          },
          {
            "name": "event_time",
            "type": "DATETIME",
            "description": "Event timestamp",
            "optional": false
          },
          {
            "name": "event_description",
            "type": "TEXT",
            "description": "Detailed description of the event",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Event addition timestamp",
            "optional": false
          }
        ],
        "primary_key": "event_id"
      }
    }
  ],
  "tools": [
    {
      "name": "calculate_service_zone",
      "description": "Determine the service zone based on geographical coordinates",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "route_management",
      "action_category": "computation",
      "pre_condition": "Latitude and longitude coordinates must be provided",
      "post_condition": "Service zone classification is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "latitude": {
            "description": "Latitude coordinate",
            "type": "number",
            "examples": [
              39.9042
            ]
          },
          "longitude": {
            "description": "Longitude coordinate",
            "type": "number",
            "examples": [
              116.4074
            ]
          }
        },
        "required": [
          "latitude",
          "longitude"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "zone_id": {
            "description": "Service zone identifier",
            "type": "string",
            "examples": [
              "ZONE_BJ_01"
            ]
          },
          "zone_type": {
            "description": "Type of service zone",
            "type": "string",
            "enum": [
              "urban",
              "suburban",
              "rural",
              "remote"
            ],
            "examples": [
              "urban"
            ]
          },
          "service_level": {
            "description": "Available service level in this zone",
            "type": "string",
            "examples": [
              "full_service"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "validate_customs_declaration",
      "description": "Validate completeness and accuracy of customs declaration information",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "customs_management",
      "action_category": "validation",
      "pre_condition": "Customs declaration data must be provided",
      "post_condition": "Validation result with any errors is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "declared_value": {
            "description": "Declared value of goods",
            "type": "number",
            "examples": [
              500.0
            ]
          },
          "item_descriptions": {
            "description": "List of item descriptions",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "electronics",
                "clothing"
              ]
            ]
          },
          "hs_codes": {
            "description": "List of Harmonized System codes for items",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "8517.12.00",
                "6204.62.40"
              ]
            ]
          },
          "origin_country": {
            "description": "Country of origin",
            "type": "string",
            "examples": [
              "CN"
            ]
          },
          "destination_country": {
            "description": "Destination country",
            "type": "string",
            "examples": [
              "US"
            ]
          }
        },
        "required": [
          "declared_value",
          "item_descriptions",
          "hs_codes",
          "origin_country",
          "destination_country"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Whether customs declaration is valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "validation_errors": {
            "description": "List of validation errors if any",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "missing_hs_code",
                "invalid_value_format"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "generate_shipping_label",
      "description": "Generate shipping label data with all required information",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "label_management",
      "action_category": "content_generation",
      "pre_condition": "Order details must be provided",
      "post_condition": "Shipping label data is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "tracking_number": {
            "description": "Tracking number for the shipment",
            "type": "string",
            "examples": [
              "TRK20240115001"
            ]
          },
          "sender_name": {
            "description": "Sender's full name",
            "type": "string",
            "examples": [
              "Zhang Wei"
            ]
          },
          "sender_address": {
            "description": "Sender's complete address",
            "type": "string",
            "examples": [
              "Room 1001, Building 5, Chaoyang District, Beijing"
            ]
          },
          "recipient_name": {
            "description": "Recipient's full name",
            "type": "string",
            "examples": [
              "Li Ming"
            ]
          },
          "recipient_address": {
            "description": "Recipient's complete address",
            "type": "string",
            "examples": [
              "Room 502, Building 3, Pudong New Area, Shanghai"
            ]
          },
          "service_type": {
            "description": "Type of courier service",
            "type": "string",
            "enum": [
              "standard",
              "express",
              "same_day",
              "next_day"
            ],
            "examples": [
              "express"
            ]
          },
          "weight": {
            "description": "Package weight in kilograms",
            "type": "number",
            "examples": [
              2.5
            ]
          }
        },
        "required": [
          "tracking_number",
          "sender_name",
          "sender_address",
          "recipient_name",
          "recipient_address",
          "service_type",
          "weight"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "label_data": {
            "description": "Complete label data in structured format",
            "type": "object",
            "examples": [
              {
                "tracking": "TRK20240115001",
                "from": "Beijing",
                "to": "Shanghai"
              }
            ]
          },
          "barcode": {
            "description": "Barcode data for the label",
            "type": "string",
            "examples": [
              "TRK20240115001-SH-PD-01-EXP"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "record_delivery_completion",
      "description": "Record the completion of a package delivery to recipient",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "delivery_management",
      "action_category": "data_creation",
      "pre_condition": "Order ID, courier ID, and delivery details must be provided",
      "post_condition": "Delivery completion is recorded and order status is updated to delivered",
      "parameters": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier for the shipment order",
            "type": "string",
            "examples": [
              "ORD20240115001"
            ]
          },
          "courier_id": {
            "description": "Unique identifier for the courier",
            "type": "string",
            "examples": [
              "COU20240115001"
            ]
          },
          "actual_delivery_time": {
            "description": "Actual delivery timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 10:30:00"
            ]
          },
          "recipient_signature": {
            "description": "Digital signature or confirmation code from recipient",
            "type": "string",
            "examples": [
              "SIG789012"
            ]
          },
          "received_by": {
            "description": "Name of the person who received the package",
            "type": "string",
            "examples": [
              "Li Ming"
            ]
          }
        },
        "required": [
          "order_id",
          "courier_id",
          "actual_delivery_time",
          "recipient_signature",
          "received_by"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "delivery_record_id": {
            "description": "Unique identifier for the delivery record",
            "type": "string",
            "examples": [
              "DLV20240116001"
            ]
          },
          "recorded_at": {
            "description": "Record creation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 10:30:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "delivery_record",
        "shipment_order"
      ]
    },
    {
      "name": "record_pickup_completion",
      "description": "Record the completion of a package pickup by a courier",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "delivery_management",
      "action_category": "data_creation",
      "pre_condition": "Order ID and courier ID must be provided",
      "post_condition": "Pickup completion is recorded and order status is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier for the shipment order",
            "type": "string",
            "examples": [
              "ORD20240115001"
            ]
          },
          "courier_id": {
            "description": "Unique identifier for the courier",
            "type": "string",
            "examples": [
              "COU20240115001"
            ]
          },
          "pickup_time": {
            "description": "Actual pickup timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 15:10:00"
            ]
          },
          "pickup_signature": {
            "description": "Digital signature or confirmation code from sender",
            "type": "string",
            "examples": [
              "SIG123456"
            ]
          }
        },
        "required": [
          "order_id",
          "courier_id",
          "pickup_time"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "pickup_record_id": {
            "description": "Unique identifier for the pickup record",
            "type": "string",
            "examples": [
              "PKP20240115001"
            ]
          },
          "recorded_at": {
            "description": "Record creation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 15:10:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "pickup_record",
        "shipment_order"
      ]
    },
    {
      "name": "get_shipment_order_details",
      "description": "Retrieve complete details of a shipment order by order ID",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "order_management",
      "action_category": "data_retrieval",
      "pre_condition": "Order ID must be provided and exist in the system",
      "post_condition": "Complete shipment order details are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier for the shipment order",
            "type": "string",
            "examples": [
              "ORD20240115001"
            ]
          }
        },
        "required": [
          "order_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier for the shipment order",
            "type": "string",
            "examples": [
              "ORD20240115001"
            ]
          },
          "tracking_number": {
            "description": "Tracking number for the shipment",
            "type": "string",
            "examples": [
              "TRK20240115001"
            ]
          },
          "status": {
            "description": "Current status of the shipment",
            "type": "string",
            "examples": [
              "in_transit"
            ]
          },
          "sender_name": {
            "description": "Sender's full name",
            "type": "string",
            "examples": [
              "Zhang Wei"
            ]
          },
          "sender_phone": {
            "description": "Sender's phone number",
            "type": "string",
            "examples": [
              "13812345678"
            ]
          },
          "sender_address": {
            "description": "Sender's complete address",
            "type": "string",
            "examples": [
              "Room 1001, Building 5, Chaoyang District, Beijing"
            ]
          },
          "recipient_name": {
            "description": "Recipient's full name",
            "type": "string",
            "examples": [
              "Li Ming"
            ]
          },
          "recipient_phone": {
            "description": "Recipient's phone number",
            "type": "string",
            "examples": [
              "13987654321"
            ]
          },
          "recipient_address": {
            "description": "Recipient's complete address",
            "type": "string",
            "examples": [
              "Room 502, Building 3, Pudong New Area, Shanghai"
            ]
          },
          "package_weight": {
            "description": "Package weight in kilograms",
            "type": "number",
            "examples": [
              2.5
            ]
          },
          "service_type": {
            "description": "Type of courier service",
            "type": "string",
            "examples": [
              "express"
            ]
          },
          "total_cost": {
            "description": "Total shipping cost",
            "type": "number",
            "examples": [
              50.7
            ]
          },
          "created_at": {
            "description": "Order creation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "shipment_order"
      ]
    },
    {
      "name": "calculate_customs_duty",
      "description": "Calculate estimated customs duty for international shipments",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "customs_management",
      "action_category": "computation",
      "pre_condition": "Declared value, item category, and destination country must be provided",
      "post_condition": "Estimated customs duty is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "declared_value": {
            "description": "Declared value of package contents in currency units",
            "type": "number",
            "examples": [
              500.0
            ]
          },
          "item_category": {
            "description": "Category of items for customs classification",
            "type": "string",
            "examples": [
              "electronics"
            ]
          },
          "origin_country": {
            "description": "Origin country code",
            "type": "string",
            "examples": [
              "CN"
            ]
          },
          "destination_country": {
            "description": "Destination country code",
            "type": "string",
            "examples": [
              "US"
            ]
          }
        },
        "required": [
          "declared_value",
          "item_category",
          "origin_country",
          "destination_country"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "duty_amount": {
            "description": "Estimated customs duty in currency units",
            "type": "number",
            "examples": [
              50.0
            ]
          },
          "tax_rate": {
            "description": "Applied tax rate as percentage",
            "type": "number",
            "examples": [
              10.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "reverse_geocode_coordinates",
      "description": "Convert geographical coordinates to a text address",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "address_management",
      "action_category": "data_transformation",
      "pre_condition": "Latitude and longitude coordinates must be provided",
      "post_condition": "Text address is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "latitude": {
            "description": "Latitude coordinate",
            "type": "number",
            "examples": [
              39.9042
            ]
          },
          "longitude": {
            "description": "Longitude coordinate",
            "type": "number",
            "examples": [
              116.4074
            ]
          }
        },
        "required": [
          "latitude",
          "longitude"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "address": {
            "description": "Formatted address string",
            "type": "string",
            "examples": [
              "Chaoyang District, Beijing"
            ]
          },
          "city": {
            "description": "City name",
            "type": "string",
            "examples": [
              "Beijing"
            ]
          },
          "district": {
            "description": "District or area name",
            "type": "string",
            "examples": [
              "Chaoyang District"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_delivery_density",
      "description": "Calculate delivery density in a specific geographical area",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "route_management",
      "action_category": "computation",
      "pre_condition": "Area coordinates and delivery count must be provided",
      "post_condition": "Delivery density is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "center_latitude": {
            "description": "Center point latitude of the area",
            "type": "number",
            "examples": [
              39.9042
            ]
          },
          "center_longitude": {
            "description": "Center point longitude of the area",
            "type": "number",
            "examples": [
              116.4074
            ]
          },
          "radius_km": {
            "description": "Radius of the area in kilometers",
            "type": "number",
            "examples": [
              5.0
            ]
          },
          "delivery_count": {
            "description": "Number of deliveries in the area",
            "type": "integer",
            "examples": [
              50
            ]
          }
        },
        "required": [
          "center_latitude",
          "center_longitude",
          "radius_km",
          "delivery_count"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "density_per_sq_km": {
            "description": "Delivery density per square kilometer",
            "type": "number",
            "examples": [
              6.37
            ]
          },
          "density_classification": {
            "description": "Density level classification",
            "type": "string",
            "enum": [
              "sparse",
              "moderate",
              "dense",
              "very_dense"
            ],
            "examples": [
              "moderate"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_package_handling_fee",
      "description": "Calculate additional handling fee for packages with special requirements",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "pricing_management",
      "action_category": "computation",
      "pre_condition": "Package characteristics and special requirements must be provided",
      "post_condition": "Handling fee is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "is_fragile": {
            "description": "Whether package contains fragile items",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "requires_signature": {
            "description": "Whether signature is required for delivery",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "is_oversized": {
            "description": "Whether package exceeds standard dimensions",
            "type": "boolean",
            "examples": [
              false
            ]
          },
          "requires_refrigeration": {
            "description": "Whether package requires temperature control",
            "type": "boolean",
            "examples": [
              false
            ]
          },
          "base_handling_fee": {
            "description": "Base handling fee in currency units",
            "type": "number",
            "examples": [
              10.0
            ]
          }
        },
        "required": [
          "is_fragile",
          "requires_signature",
          "is_oversized",
          "requires_refrigeration",
          "base_handling_fee"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_handling_fee": {
            "description": "Total calculated handling fee",
            "type": "number",
            "examples": [
              25.0
            ]
          },
          "fee_breakdown": {
            "description": "Breakdown of handling fees by category",
            "type": "object",
            "examples": [
              {
                "fragile": 10.0,
                "signature": 5.0
              }
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_carbon_footprint",
      "description": "Calculate the estimated carbon footprint for a shipment based on distance and transport mode",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "environmental_management",
      "action_category": "computation",
      "pre_condition": "Distance and transport mode must be provided",
      "post_condition": "Carbon footprint is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "distance_km": {
            "description": "Transportation distance in kilometers",
            "type": "number",
            "examples": [
              1067.5
            ]
          },
          "transport_mode": {
            "description": "Mode of transportation",
            "type": "string",
            "enum": [
              "road",
              "air",
              "rail",
              "sea"
            ],
            "examples": [
              "road"
            ]
          },
          "weight": {
            "description": "Package weight in kilograms",
            "type": "number",
            "examples": [
              2.5
            ]
          }
        },
        "required": [
          "distance_km",
          "transport_mode",
          "weight"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "carbon_emissions_kg": {
            "description": "Estimated carbon emissions in kilograms of CO2",
            "type": "number",
            "examples": [
              3.2
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "validate_package_dimensions",
      "description": "Validate if package dimensions meet courier service requirements and restrictions",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "package_management",
      "action_category": "validation",
      "pre_condition": "Package dimensions and service type must be provided",
      "post_condition": "Validation result with compliance status is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "length": {
            "description": "Package length in centimeters",
            "type": "number",
            "examples": [
              30.0
            ]
          },
          "width": {
            "description": "Package width in centimeters",
            "type": "number",
            "examples": [
              20.0
            ]
          },
          "height": {
            "description": "Package height in centimeters",
            "type": "number",
            "examples": [
              15.0
            ]
          },
          "weight": {
            "description": "Package weight in kilograms",
            "type": "number",
            "examples": [
              2.5
            ]
          },
          "service_type": {
            "description": "Type of courier service",
            "type": "string",
            "enum": [
              "standard",
              "express",
              "same_day",
              "next_day"
            ],
            "examples": [
              "express"
            ]
          }
        },
        "required": [
          "length",
          "width",
          "height",
          "weight",
          "service_type"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Whether package dimensions are valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "violation_reasons": {
            "description": "List of reasons if validation fails",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "exceeds_weight_limit",
                "oversized_dimensions"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "geocode_address",
      "description": "Convert a text address to geographical coordinates",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "address_management",
      "action_category": "data_transformation",
      "pre_condition": "Address string must be provided",
      "post_condition": "Geographical coordinates are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "address": {
            "description": "Complete address string to geocode",
            "type": "string",
            "examples": [
              "Room 1001, Building 5, Chaoyang District, Beijing"
            ]
          }
        },
        "required": [
          "address"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "latitude": {
            "description": "Latitude coordinate of the address",
            "type": "number",
            "examples": [
              39.9042
            ]
          },
          "longitude": {
            "description": "Longitude coordinate of the address",
            "type": "number",
            "examples": [
              116.4074
            ]
          },
          "accuracy": {
            "description": "Geocoding accuracy level",
            "type": "string",
            "examples": [
              "high"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "generate_performance_metrics",
      "description": "Generate performance metrics for courier or service evaluation",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "performance_management",
      "action_category": "data_analysis",
      "pre_condition": "Performance data for evaluation period must be provided",
      "post_condition": "Performance metrics are calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "total_deliveries": {
            "description": "Total number of deliveries attempted",
            "type": "integer",
            "examples": [
              100
            ]
          },
          "successful_deliveries": {
            "description": "Number of successful first-attempt deliveries",
            "type": "integer",
            "examples": [
              85
            ]
          },
          "on_time_deliveries": {
            "description": "Number of on-time deliveries",
            "type": "integer",
            "examples": [
              80
            ]
          },
          "total_distance_km": {
            "description": "Total distance covered in kilometers",
            "type": "number",
            "examples": [
              1500.5
            ]
          },
          "total_time_hours": {
            "description": "Total time spent on deliveries in hours",
            "type": "number",
            "examples": [
              120.0
            ]
          },
          "customer_ratings": {
            "description": "List of customer rating scores (1-5)",
            "type": "array",
            "items": {
              "type": "number"
            },
            "examples": [
              [
                5,
                4,
                5,
                4,
                5,
                3,
                5,
                4
              ]
            ]
          }
        },
        "required": [
          "total_deliveries",
          "successful_deliveries",
          "on_time_deliveries",
          "total_distance_km",
          "total_time_hours",
          "customer_ratings"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success_rate": {
            "description": "First-attempt delivery success rate as percentage",
            "type": "number",
            "examples": [
              85.0
            ]
          },
          "on_time_rate": {
            "description": "On-time delivery rate as percentage",
            "type": "number",
            "examples": [
              80.0
            ]
          },
          "average_speed_kmh": {
            "description": "Average delivery speed in km/h",
            "type": "number",
            "examples": [
              12.5
            ]
          },
          "average_customer_rating": {
            "description": "Average customer rating score",
            "type": "number",
            "examples": [
              4.4
            ]
          },
          "efficiency_score": {
            "description": "Overall efficiency score (0-100)",
            "type": "number",
            "examples": [
              82.5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "validate_address_format",
      "description": "Validate if an address string meets the required format standards",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "address_management",
      "action_category": "validation",
      "pre_condition": "Address string must be provided",
      "post_condition": "Validation result with format compliance is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "address": {
            "description": "Complete address string to validate",
            "type": "string",
            "examples": [
              "Room 1001, Building 5, Chaoyang District, Beijing"
            ]
          },
          "country_code": {
            "description": "ISO country code for address validation rules",
            "type": "string",
            "examples": [
              "CN"
            ]
          }
        },
        "required": [
          "address",
          "country_code"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Whether the address format is valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "validation_errors": {
            "description": "List of validation errors if any",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "missing_postal_code",
                "invalid_district_name"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_courier_active_deliveries",
      "description": "Retrieve all active delivery assignments for a specific courier",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "courier_management",
      "action_category": "data_retrieval",
      "pre_condition": "Courier ID must be provided",
      "post_condition": "List of active delivery assignments is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "courier_id": {
            "description": "Unique identifier for the courier",
            "type": "string",
            "examples": [
              "COU20240115001"
            ]
          }
        },
        "required": [
          "courier_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "active_deliveries": {
            "description": "List of active delivery order IDs",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "ORD20240115001",
                "ORD20240115002"
              ]
            ]
          },
          "total_count": {
            "description": "Total number of active deliveries",
            "type": "integer",
            "examples": [
              2
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "courier_assignment",
        "courier"
      ]
    },
    {
      "name": "update_courier_location",
      "description": "Update the GPS location of a courier",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "courier_management",
      "action_category": "data_modification",
      "pre_condition": "Courier ID and location coordinates must be provided",
      "post_condition": "Courier location is updated in the system",
      "parameters": {
        "type": "object",
        "properties": {
          "courier_id": {
            "description": "Unique identifier for the courier",
            "type": "string",
            "examples": [
              "COU20240115001"
            ]
          },
          "latitude": {
            "description": "Current latitude coordinate",
            "type": "number",
            "examples": [
              39.9042
            ]
          },
          "longitude": {
            "description": "Current longitude coordinate",
            "type": "number",
            "examples": [
              116.4074
            ]
          }
        },
        "required": [
          "courier_id",
          "latitude",
          "longitude"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "updated": {
            "description": "Whether the location was successfully updated",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_at": {
            "description": "Location update timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 12:35:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "courier"
      ]
    },
    {
      "name": "create_shipment_order",
      "description": "Create a new shipment order with sender, recipient, and package details",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "order_management",
      "action_category": "data_creation",
      "pre_condition": "Sender, recipient, and package information must be provided",
      "post_condition": "Shipment order is created and order ID is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "sender_name": {
            "description": "Sender's full name",
            "type": "string",
            "examples": [
              "Zhang Wei"
            ]
          },
          "sender_phone": {
            "description": "Sender's phone number",
            "type": "string",
            "examples": [
              "13812345678"
            ]
          },
          "sender_address": {
            "description": "Sender's complete address",
            "type": "string",
            "examples": [
              "Room 1001, Building 5, Chaoyang District, Beijing"
            ]
          },
          "recipient_name": {
            "description": "Recipient's full name",
            "type": "string",
            "examples": [
              "Li Ming"
            ]
          },
          "recipient_phone": {
            "description": "Recipient's phone number",
            "type": "string",
            "examples": [
              "13987654321"
            ]
          },
          "recipient_address": {
            "description": "Recipient's complete address",
            "type": "string",
            "examples": [
              "Room 502, Building 3, Pudong New Area, Shanghai"
            ]
          },
          "weight": {
            "description": "Package weight in kilograms",
            "type": "number",
            "examples": [
              2.5
            ]
          },
          "length": {
            "description": "Package length in centimeters",
            "type": "number",
            "examples": [
              30.0
            ]
          },
          "width": {
            "description": "Package width in centimeters",
            "type": "number",
            "examples": [
              20.0
            ]
          },
          "height": {
            "description": "Package height in centimeters",
            "type": "number",
            "examples": [
              15.0
            ]
          },
          "service_type": {
            "description": "Type of courier service",
            "type": "string",
            "enum": [
              "standard",
              "express",
              "same_day",
              "next_day"
            ],
            "examples": [
              "express"
            ]
          },
          "declared_value": {
            "description": "Declared value of package contents in currency units",
            "type": "number",
            "examples": [
              500.0
            ]
          }
        },
        "required": [
          "sender_name",
          "sender_phone",
          "sender_address",
          "recipient_name",
          "recipient_phone",
          "recipient_address",
          "weight",
          "length",
          "width",
          "height",
          "service_type"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier for the shipment order",
            "type": "string",
            "examples": [
              "ORD20240115001"
            ]
          },
          "tracking_number": {
            "description": "Tracking number for the shipment",
            "type": "string",
            "examples": [
              "TRK20240115001"
            ]
          },
          "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": [
        "shipment_order"
      ]
    },
    {
      "name": "generate_delivery_proof",
      "description": "Generate delivery proof document with all verification details",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "document_management",
      "action_category": "content_generation",
      "pre_condition": "Delivery details and signature must be provided",
      "post_condition": "Delivery proof document data is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "tracking_number": {
            "description": "Tracking number for the shipment",
            "type": "string",
            "examples": [
              "TRK20240115001"
            ]
          },
          "actual_delivery_time": {
            "description": "Actual delivery timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 10:30:00"
            ]
          },
          "recipient_signature": {
            "description": "Digital signature from recipient",
            "type": "string",
            "examples": [
              "SIG789012"
            ]
          },
          "received_by": {
            "description": "Name of person who received the package",
            "type": "string",
            "examples": [
              "Li Ming"
            ]
          },
          "courier_id": {
            "description": "Unique identifier for the courier",
            "type": "string",
            "examples": [
              "COU20240115001"
            ]
          },
          "photo_evidence": {
            "description": "Photo evidence of delivery",
            "type": "string",
            "examples": [
              "photo_url_or_base64_data"
            ]
          }
        },
        "required": [
          "tracking_number",
          "actual_delivery_time",
          "recipient_signature",
          "received_by",
          "courier_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "proof_id": {
            "description": "Unique identifier for the delivery proof",
            "type": "string",
            "examples": [
              "PROOF20240116001"
            ]
          },
          "proof_document": {
            "description": "Complete proof document in structured format",
            "type": "object",
            "examples": [
              {
                "tracking": "TRK20240115001",
                "delivered_at": "2024-01-16 10:30:00"
              }
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "generate_barcode_data",
      "description": "Generate barcode data string for package labeling",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "package_management",
      "action_category": "content_generation",
      "pre_condition": "Tracking number and order details must be provided",
      "post_condition": "Barcode data string is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "tracking_number": {
            "description": "Tracking number for the shipment",
            "type": "string",
            "examples": [
              "TRK20240115001"
            ]
          },
          "destination_code": {
            "description": "Destination sorting center code",
            "type": "string",
            "examples": [
              "SH-PD-01"
            ]
          },
          "service_code": {
            "description": "Service type code",
            "type": "string",
            "examples": [
              "EXP"
            ]
          }
        },
        "required": [
          "tracking_number",
          "destination_code",
          "service_code"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "barcode": {
            "description": "Encoded barcode data string",
            "type": "string",
            "examples": [
              "TRK20240115001-SH-PD-01-EXP"
            ]
          },
          "barcode_format": {
            "description": "Barcode format type",
            "type": "string",
            "examples": [
              "CODE128"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "check_service_availability",
      "description": "Check if a specific courier service is available for given origin and destination",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "service_management",
      "action_category": "validation",
      "pre_condition": "Service type and location coordinates must be provided",
      "post_condition": "Service availability status is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "service_type": {
            "description": "Type of courier service",
            "type": "string",
            "enum": [
              "standard",
              "express",
              "same_day",
              "next_day"
            ],
            "examples": [
              "same_day"
            ]
          },
          "origin_latitude": {
            "description": "Origin location latitude",
            "type": "number",
            "examples": [
              39.9042
            ]
          },
          "origin_longitude": {
            "description": "Origin location longitude",
            "type": "number",
            "examples": [
              116.4074
            ]
          },
          "destination_latitude": {
            "description": "Destination location latitude",
            "type": "number",
            "examples": [
              31.2304
            ]
          },
          "destination_longitude": {
            "description": "Destination location longitude",
            "type": "number",
            "examples": [
              121.4737
            ]
          }
        },
        "required": [
          "service_type",
          "origin_latitude",
          "origin_longitude",
          "destination_latitude",
          "destination_longitude"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_available": {
            "description": "Whether the service is available",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "unavailable_reason": {
            "description": "Reason if service is not available",
            "type": "string",
            "examples": [
              "destination outside service area"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_return_shipping_cost",
      "description": "Calculate the cost for return shipping based on original shipment details",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "pricing_management",
      "action_category": "computation",
      "pre_condition": "Original shipment cost and return policy must be provided",
      "post_condition": "Return shipping cost is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "original_shipping_cost": {
            "description": "Original shipping cost in currency units",
            "type": "number",
            "examples": [
              50.7
            ]
          },
          "return_reason": {
            "description": "Reason for return",
            "type": "string",
            "enum": [
              "customer_request",
              "damaged_goods",
              "wrong_item",
              "quality_issue",
              "other"
            ],
            "examples": [
              "damaged_goods"
            ]
          },
          "who_pays": {
            "description": "Who is responsible for return shipping cost",
            "type": "string",
            "enum": [
              "sender",
              "recipient",
              "shared"
            ],
            "examples": [
              "sender"
            ]
          },
          "return_discount_percentage": {
            "description": "Discount percentage for return shipping",
            "type": "number",
            "examples": [
              20.0
            ]
          }
        },
        "required": [
          "original_shipping_cost",
          "return_reason",
          "who_pays",
          "return_discount_percentage"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "return_shipping_cost": {
            "description": "Calculated return shipping cost",
            "type": "number",
            "examples": [
              40.56
            ]
          },
          "customer_responsibility": {
            "description": "Amount customer needs to pay",
            "type": "number",
            "examples": [
              0.0
            ]
          },
          "sender_responsibility": {
            "description": "Amount sender needs to pay",
            "type": "number",
            "examples": [
              40.56
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_weight_discrepancy",
      "description": "Calculate the discrepancy between declared weight and actual weight",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "package_management",
      "action_category": "computation",
      "pre_condition": "Declared weight and actual weight must be provided",
      "post_condition": "Weight discrepancy is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "declared_weight": {
            "description": "Declared package weight in kilograms",
            "type": "number",
            "examples": [
              2.5
            ]
          },
          "actual_weight": {
            "description": "Actual measured weight in kilograms",
            "type": "number",
            "examples": [
              2.8
            ]
          },
          "tolerance_percentage": {
            "description": "Acceptable weight tolerance as percentage",
            "type": "number",
            "examples": [
              5.0
            ]
          }
        },
        "required": [
          "declared_weight",
          "actual_weight",
          "tolerance_percentage"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "discrepancy_kg": {
            "description": "Weight discrepancy in kilograms",
            "type": "number",
            "examples": [
              0.3
            ]
          },
          "discrepancy_percentage": {
            "description": "Weight discrepancy as percentage",
            "type": "number",
            "examples": [
              12.0
            ]
          },
          "exceeds_tolerance": {
            "description": "Whether discrepancy exceeds tolerance",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_estimated_arrival_time",
      "description": "Calculate estimated arrival time based on current location and destination",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "delivery_management",
      "action_category": "computation",
      "pre_condition": "Current location, destination coordinates, and average speed must be provided",
      "post_condition": "Estimated arrival time is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "current_latitude": {
            "description": "Current latitude coordinate",
            "type": "number",
            "examples": [
              39.9042
            ]
          },
          "current_longitude": {
            "description": "Current longitude coordinate",
            "type": "number",
            "examples": [
              116.4074
            ]
          },
          "destination_latitude": {
            "description": "Destination latitude coordinate",
            "type": "number",
            "examples": [
              31.2304
            ]
          },
          "destination_longitude": {
            "description": "Destination longitude coordinate",
            "type": "number",
            "examples": [
              121.4737
            ]
          },
          "average_speed_kmh": {
            "description": "Average travel speed in kilometers per hour",
            "type": "number",
            "examples": [
              60.0
            ]
          }
        },
        "required": [
          "current_latitude",
          "current_longitude",
          "destination_latitude",
          "destination_longitude",
          "average_speed_kmh"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "estimated_arrival_time": {
            "description": "Estimated arrival timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 10:00:00"
            ]
          },
          "remaining_distance_km": {
            "description": "Remaining distance to destination in kilometers",
            "type": "number",
            "examples": [
              850.5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_distance_between_coordinates",
      "description": "Calculate the geographical distance between two coordinate points using Haversine formula",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "route_management",
      "action_category": "computation",
      "pre_condition": "Origin and destination coordinates must be provided",
      "post_condition": "Distance between coordinates is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "origin_latitude": {
            "description": "Origin location latitude",
            "type": "number",
            "examples": [
              39.9042
            ]
          },
          "origin_longitude": {
            "description": "Origin location longitude",
            "type": "number",
            "examples": [
              116.4074
            ]
          },
          "destination_latitude": {
            "description": "Destination location latitude",
            "type": "number",
            "examples": [
              31.2304
            ]
          },
          "destination_longitude": {
            "description": "Destination location longitude",
            "type": "number",
            "examples": [
              121.4737
            ]
          }
        },
        "required": [
          "origin_latitude",
          "origin_longitude",
          "destination_latitude",
          "destination_longitude"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "distance_km": {
            "description": "Distance in kilometers",
            "type": "number",
            "examples": [
              1067.5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "assign_courier_to_pickup",
      "description": "Assign a courier to pick up a shipment order",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "courier_management",
      "action_category": "resource_transfer",
      "pre_condition": "Order ID and courier ID must be provided",
      "post_condition": "Courier is assigned to the pickup task",
      "parameters": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier for the shipment order",
            "type": "string",
            "examples": [
              "ORD20240115001"
            ]
          },
          "courier_id": {
            "description": "Unique identifier for the courier",
            "type": "string",
            "examples": [
              "COU20240115001"
            ]
          },
          "scheduled_pickup_time": {
            "description": "Scheduled pickup time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 15:00:00"
            ]
          }
        },
        "required": [
          "order_id",
          "courier_id",
          "scheduled_pickup_time"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "assignment_id": {
            "description": "Unique identifier for the assignment",
            "type": "string",
            "examples": [
              "ASG20240115001"
            ]
          },
          "assigned_at": {
            "description": "Assignment timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 12:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "courier_assignment",
        "shipment_order",
        "courier"
      ]
    },
    {
      "name": "add_tracking_event",
      "description": "Add a new tracking event to a shipment's history",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "tracking_management",
      "action_category": "data_creation",
      "pre_condition": "Tracking number and event details must be provided",
      "post_condition": "Tracking event is added to shipment history",
      "parameters": {
        "type": "object",
        "properties": {
          "tracking_number": {
            "description": "Tracking number for the shipment",
            "type": "string",
            "examples": [
              "TRK20240115001"
            ]
          },
          "event_type": {
            "description": "Type of tracking event",
            "type": "string",
            "enum": [
              "order_created",
              "picked_up",
              "in_transit",
              "arrived_at_facility",
              "out_for_delivery",
              "delivered",
              "exception",
              "returned"
            ],
            "examples": [
              "in_transit"
            ]
          },
          "event_location": {
            "description": "Location where the event occurred",
            "type": "string",
            "examples": [
              "Beijing Sorting Center"
            ]
          },
          "event_time": {
            "description": "Event timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 18:00:00"
            ]
          },
          "event_description": {
            "description": "Detailed description of the event",
            "type": "string",
            "examples": [
              "Package departed from sorting facility"
            ]
          }
        },
        "required": [
          "tracking_number",
          "event_type",
          "event_location",
          "event_time"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "event_id": {
            "description": "Unique identifier for the tracking event",
            "type": "string",
            "examples": [
              "EVT20240115001"
            ]
          },
          "added_at": {
            "description": "Event addition timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 18:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "tracking_event"
      ]
    },
    {
      "name": "get_courier_current_location",
      "description": "Retrieve the current GPS location of a courier",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "courier_management",
      "action_category": "data_retrieval",
      "pre_condition": "Courier ID must be provided",
      "post_condition": "Current location coordinates are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "courier_id": {
            "description": "Unique identifier for the courier",
            "type": "string",
            "examples": [
              "COU20240115001"
            ]
          }
        },
        "required": [
          "courier_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "latitude": {
            "description": "Current latitude coordinate",
            "type": "number",
            "examples": [
              39.9042
            ]
          },
          "longitude": {
            "description": "Current longitude coordinate",
            "type": "number",
            "examples": [
              116.4074
            ]
          },
          "last_updated": {
            "description": "Last location update timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 12:30:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "courier"
      ]
    },
    {
      "name": "validate_phone_number",
      "description": "Validate if a phone number meets the required format for the specified country",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "contact_management",
      "action_category": "validation",
      "pre_condition": "Phone number and country code must be provided",
      "post_condition": "Validation result is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "phone_number": {
            "description": "Phone number to validate",
            "type": "string",
            "examples": [
              "13812345678"
            ]
          },
          "country_code": {
            "description": "ISO country code",
            "type": "string",
            "examples": [
              "CN"
            ]
          }
        },
        "required": [
          "phone_number",
          "country_code"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Whether the phone number is valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "formatted_number": {
            "description": "Standardized formatted phone number",
            "type": "string",
            "examples": [
              "+86 138 1234 5678"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "estimate_package_transit_stages",
      "description": "Estimate the number and duration of transit stages for a shipment",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "delivery_management",
      "action_category": "computation",
      "pre_condition": "Origin, destination, and service type must be provided",
      "post_condition": "Transit stage estimates are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "origin_latitude": {
            "description": "Origin location latitude",
            "type": "number",
            "examples": [
              39.9042
            ]
          },
          "origin_longitude": {
            "description": "Origin location longitude",
            "type": "number",
            "examples": [
              116.4074
            ]
          },
          "destination_latitude": {
            "description": "Destination location latitude",
            "type": "number",
            "examples": [
              31.2304
            ]
          },
          "destination_longitude": {
            "description": "Destination location longitude",
            "type": "number",
            "examples": [
              121.4737
            ]
          },
          "service_type": {
            "description": "Type of courier service",
            "type": "string",
            "enum": [
              "standard",
              "express",
              "same_day",
              "next_day"
            ],
            "examples": [
              "express"
            ]
          }
        },
        "required": [
          "origin_latitude",
          "origin_longitude",
          "destination_latitude",
          "destination_longitude",
          "service_type"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "stage_count": {
            "description": "Number of transit stages",
            "type": "integer",
            "examples": [
              4
            ]
          },
          "stages": {
            "description": "List of transit stages with estimated durations",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "stage": "pickup",
                  "duration_hours": 2
                },
                {
                  "stage": "sorting",
                  "duration_hours": 4
                }
              ]
            ]
          },
          "total_transit_time_hours": {
            "description": "Total estimated transit time in hours",
            "type": "number",
            "examples": [
              24.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_shipping_cost",
      "description": "Calculate the shipping cost based on package weight, dimensions, distance, and service type",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "pricing_management",
      "action_category": "computation",
      "pre_condition": "Package weight, dimensions, origin and destination coordinates, and service type must be provided",
      "post_condition": "Shipping cost is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "weight": {
            "description": "Package weight in kilograms",
            "type": "number",
            "examples": [
              2.5
            ]
          },
          "length": {
            "description": "Package length in centimeters",
            "type": "number",
            "examples": [
              30.0
            ]
          },
          "width": {
            "description": "Package width in centimeters",
            "type": "number",
            "examples": [
              20.0
            ]
          },
          "height": {
            "description": "Package height in centimeters",
            "type": "number",
            "examples": [
              15.0
            ]
          },
          "origin_latitude": {
            "description": "Origin location latitude",
            "type": "number",
            "examples": [
              39.9042
            ]
          },
          "origin_longitude": {
            "description": "Origin location longitude",
            "type": "number",
            "examples": [
              116.4074
            ]
          },
          "destination_latitude": {
            "description": "Destination location latitude",
            "type": "number",
            "examples": [
              31.2304
            ]
          },
          "destination_longitude": {
            "description": "Destination location longitude",
            "type": "number",
            "examples": [
              121.4737
            ]
          },
          "service_type": {
            "description": "Type of courier service",
            "type": "string",
            "enum": [
              "standard",
              "express",
              "same_day",
              "next_day"
            ],
            "examples": [
              "express"
            ]
          }
        },
        "required": [
          "weight",
          "length",
          "width",
          "height",
          "origin_latitude",
          "origin_longitude",
          "destination_latitude",
          "destination_longitude",
          "service_type"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "base_cost": {
            "description": "Base shipping cost in currency units",
            "type": "number",
            "examples": [
              45.5
            ]
          },
          "fuel_surcharge": {
            "description": "Fuel surcharge amount",
            "type": "number",
            "examples": [
              5.2
            ]
          },
          "total_cost": {
            "description": "Total shipping cost including all charges",
            "type": "number",
            "examples": [
              50.7
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "check_delivery_time_compliance",
      "description": "Check if actual delivery time complies with service level agreement",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "compliance_management",
      "action_category": "validation",
      "pre_condition": "Promised and actual delivery times must be provided",
      "post_condition": "Compliance check result is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "promised_delivery_time": {
            "description": "Promised delivery timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 18:00:00"
            ]
          },
          "actual_delivery_time": {
            "description": "Actual delivery timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 16:30:00"
            ]
          },
          "grace_period_minutes": {
            "description": "Grace period allowed beyond promised time in minutes",
            "type": "integer",
            "examples": [
              30
            ]
          }
        },
        "required": [
          "promised_delivery_time",
          "actual_delivery_time",
          "grace_period_minutes"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_compliant": {
            "description": "Whether delivery time is compliant",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "time_difference_minutes": {
            "description": "Time difference in minutes (negative if early, positive if late)",
            "type": "number",
            "examples": [
              -90.0
            ]
          },
          "compliance_status": {
            "description": "Compliance status classification",
            "type": "string",
            "enum": [
              "early",
              "on_time",
              "late_within_grace",
              "late_beyond_grace"
            ],
            "examples": [
              "early"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_fuel_surcharge",
      "description": "Calculate fuel surcharge based on current fuel prices and distance",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "pricing_management",
      "action_category": "computation",
      "pre_condition": "Distance and current fuel price must be provided",
      "post_condition": "Fuel surcharge is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "distance_km": {
            "description": "Transportation distance in kilometers",
            "type": "number",
            "examples": [
              1067.5
            ]
          },
          "fuel_price_per_liter": {
            "description": "Current fuel price per liter in currency units",
            "type": "number",
            "examples": [
              7.5
            ]
          },
          "base_fuel_price": {
            "description": "Base fuel price for surcharge calculation",
            "type": "number",
            "examples": [
              6.0
            ]
          },
          "vehicle_efficiency": {
            "description": "Vehicle fuel efficiency in kilometers per liter",
            "type": "number",
            "examples": [
              12.0
            ]
          }
        },
        "required": [
          "distance_km",
          "fuel_price_per_liter",
          "base_fuel_price",
          "vehicle_efficiency"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "surcharge_amount": {
            "description": "Calculated fuel surcharge in currency units",
            "type": "number",
            "examples": [
              13.34
            ]
          },
          "surcharge_percentage": {
            "description": "Surcharge as percentage of base cost",
            "type": "number",
            "examples": [
              25.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_tracking_history",
      "description": "Retrieve the complete tracking history for a shipment",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "tracking_management",
      "action_category": "data_retrieval",
      "pre_condition": "Tracking number must be provided",
      "post_condition": "Complete tracking history with all status updates is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "tracking_number": {
            "description": "Tracking number for the shipment",
            "type": "string",
            "examples": [
              "TRK20240115001"
            ]
          }
        },
        "required": [
          "tracking_number"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "tracking_events": {
            "description": "List of tracking events in chronological order",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "status": "picked_up",
                  "location": "Beijing",
                  "timestamp": "2024-01-15 15:10:00"
                }
              ]
            ]
          },
          "status": {
            "description": "Current status of the shipment",
            "type": "string",
            "examples": [
              "in_transit"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "tracking_event",
        "shipment_order"
      ]
    },
    {
      "name": "record_delivery_attempt",
      "description": "Record a failed delivery attempt with reason",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "delivery_management",
      "action_category": "data_creation",
      "pre_condition": "Order ID, courier ID, and failure reason must be provided",
      "post_condition": "Delivery attempt is recorded in the system",
      "parameters": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier for the shipment order",
            "type": "string",
            "examples": [
              "ORD20240115001"
            ]
          },
          "courier_id": {
            "description": "Unique identifier for the courier",
            "type": "string",
            "examples": [
              "COU20240115001"
            ]
          },
          "attempt_time": {
            "description": "Delivery attempt timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 09:00:00"
            ]
          },
          "failure_reason": {
            "description": "Reason for delivery failure",
            "type": "string",
            "enum": [
              "recipient_not_home",
              "incorrect_address",
              "refused_delivery",
              "access_denied",
              "weather_conditions",
              "other"
            ],
            "examples": [
              "recipient_not_home"
            ]
          },
          "notes": {
            "description": "Additional notes about the delivery attempt",
            "type": "string",
            "examples": [
              "Left notice at door"
            ]
          }
        },
        "required": [
          "order_id",
          "courier_id",
          "attempt_time",
          "failure_reason"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "attempt_record_id": {
            "description": "Unique identifier for the delivery attempt record",
            "type": "string",
            "examples": [
              "ATM20240116001"
            ]
          },
          "attempt_count": {
            "description": "Total number of delivery attempts for this order",
            "type": "integer",
            "examples": [
              1
            ]
          },
          "recorded_at": {
            "description": "Record creation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 09:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "delivery_attempt",
        "shipment_order"
      ]
    },
    {
      "name": "check_delivery_time_window",
      "description": "Check if a delivery can be completed within the specified time window",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "delivery_management",
      "action_category": "validation",
      "pre_condition": "Current time, destination, and time window must be provided",
      "post_condition": "Feasibility result is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "current_time": {
            "description": "Current timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 14:00:00"
            ]
          },
          "destination_latitude": {
            "description": "Destination latitude coordinate",
            "type": "number",
            "examples": [
              39.91
            ]
          },
          "destination_longitude": {
            "description": "Destination longitude coordinate",
            "type": "number",
            "examples": [
              116.42
            ]
          },
          "window_start": {
            "description": "Time window start in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 16:00:00"
            ]
          },
          "window_end": {
            "description": "Time window end in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 18:00:00"
            ]
          },
          "average_speed_kmh": {
            "description": "Average travel speed in kilometers per hour",
            "type": "number",
            "examples": [
              40.0
            ]
          }
        },
        "required": [
          "current_time",
          "destination_latitude",
          "destination_longitude",
          "window_start",
          "window_end",
          "average_speed_kmh"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_feasible": {
            "description": "Whether delivery within time window is feasible",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "buffer_time_minutes": {
            "description": "Buffer time before window closes in minutes",
            "type": "number",
            "examples": [
              45.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "update_shipment_status",
      "description": "Update the status of a shipment order",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "order_management",
      "action_category": "data_modification",
      "pre_condition": "Order ID and new status must be provided",
      "post_condition": "Shipment status is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier for the shipment order",
            "type": "string",
            "examples": [
              "ORD20240115001"
            ]
          },
          "new_status": {
            "description": "New status to be set for the shipment",
            "type": "string",
            "enum": [
              "pending",
              "picked_up",
              "in_transit",
              "out_for_delivery",
              "delivered",
              "failed",
              "cancelled",
              "returned"
            ],
            "examples": [
              "in_transit"
            ]
          },
          "status_note": {
            "description": "Additional note or comment about the status change",
            "type": "string",
            "examples": [
              "Package departed from sorting facility"
            ]
          }
        },
        "required": [
          "order_id",
          "new_status"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "updated": {
            "description": "Whether the status was successfully updated",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_at": {
            "description": "Status update timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 14:20:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "shipment_order"
      ]
    },
    {
      "name": "cancel_shipment_order",
      "description": "Cancel a shipment order before pickup",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "order_management",
      "action_category": "data_modification",
      "pre_condition": "Order ID must be provided and order must be in cancellable status",
      "post_condition": "Shipment order is cancelled",
      "parameters": {
        "type": "object",
        "properties": {
          "order_id": {
            "description": "Unique identifier for the shipment order",
            "type": "string",
            "examples": [
              "ORD20240115001"
            ]
          },
          "cancellation_reason": {
            "description": "Reason for cancelling the shipment",
            "type": "string",
            "examples": [
              "Customer request"
            ]
          }
        },
        "required": [
          "order_id",
          "cancellation_reason"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "cancelled": {
            "description": "Whether the order was successfully cancelled",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "refund_amount": {
            "description": "Amount to be refunded in currency units",
            "type": "number",
            "examples": [
              50.7
            ]
          },
          "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": [
        "shipment_order"
      ]
    },
    {
      "name": "calculate_delivery_priority_score",
      "description": "Calculate priority score for delivery scheduling based on multiple factors",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "delivery_management",
      "action_category": "computation",
      "pre_condition": "Order details and service parameters must be provided",
      "post_condition": "Priority score is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "service_type": {
            "description": "Type of courier service",
            "type": "string",
            "enum": [
              "standard",
              "express",
              "same_day",
              "next_day"
            ],
            "examples": [
              "same_day"
            ]
          },
          "order_time": {
            "description": "Order creation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 09:00:00"
            ]
          },
          "deadline": {
            "description": "Delivery deadline in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 18:00:00"
            ]
          },
          "declared_value": {
            "description": "Declared value of package contents",
            "type": "number",
            "examples": [
              1000.0
            ]
          },
          "customer_tier": {
            "description": "Customer tier level",
            "type": "string",
            "enum": [
              "regular",
              "silver",
              "gold",
              "platinum"
            ],
            "examples": [
              "gold"
            ]
          }
        },
        "required": [
          "service_type",
          "order_time",
          "deadline",
          "declared_value",
          "customer_tier"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "priority_score": {
            "description": "Calculated priority score (0-100)",
            "type": "number",
            "examples": [
              85.5
            ]
          },
          "priority_level": {
            "description": "Priority level classification",
            "type": "string",
            "enum": [
              "low",
              "medium",
              "high",
              "urgent"
            ],
            "examples": [
              "high"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "estimate_sorting_center_processing_time",
      "description": "Estimate processing time at sorting center based on package volume and center capacity",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "facility_management",
      "action_category": "computation",
      "pre_condition": "Package count and center capacity must be provided",
      "post_condition": "Estimated processing time is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "current_package_count": {
            "description": "Current number of packages at the sorting center",
            "type": "integer",
            "examples": [
              500
            ]
          },
          "center_capacity": {
            "description": "Maximum processing capacity per hour",
            "type": "integer",
            "examples": [
              1000
            ]
          },
          "package_priority": {
            "description": "Priority level of the package",
            "type": "string",
            "enum": [
              "low",
              "medium",
              "high",
              "urgent"
            ],
            "examples": [
              "high"
            ]
          }
        },
        "required": [
          "current_package_count",
          "center_capacity",
          "package_priority"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "estimated_processing_hours": {
            "description": "Estimated processing time in hours",
            "type": "number",
            "examples": [
              0.5
            ]
          },
          "queue_position": {
            "description": "Estimated position in processing queue",
            "type": "integer",
            "examples": [
              50
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_volumetric_weight",
      "description": "Calculate the volumetric weight of a package based on its dimensions",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "package_management",
      "action_category": "computation",
      "pre_condition": "Package dimensions must be provided",
      "post_condition": "Volumetric weight is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "length": {
            "description": "Package length in centimeters",
            "type": "number",
            "examples": [
              30.0
            ]
          },
          "width": {
            "description": "Package width in centimeters",
            "type": "number",
            "examples": [
              20.0
            ]
          },
          "height": {
            "description": "Package height in centimeters",
            "type": "number",
            "examples": [
              15.0
            ]
          },
          "divisor": {
            "description": "Volumetric divisor used for calculation (default 5000 for international shipping)",
            "type": "number",
            "examples": [
              5000.0
            ]
          }
        },
        "required": [
          "length",
          "width",
          "height",
          "divisor"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "volumetric_weight": {
            "description": "Calculated volumetric weight in kilograms",
            "type": "number",
            "examples": [
              1.8
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_multi_package_discount",
      "description": "Calculate discount for shipping multiple packages in a single order",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "pricing_management",
      "action_category": "computation",
      "pre_condition": "Package count and individual costs must be provided",
      "post_condition": "Discount amount is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "package_count": {
            "description": "Number of packages in the order",
            "type": "integer",
            "examples": [
              5
            ]
          },
          "individual_costs": {
            "description": "List of individual package shipping costs",
            "type": "array",
            "items": {
              "type": "number"
            },
            "examples": [
              [
                45.0,
                50.0,
                48.0,
                52.0,
                46.0
              ]
            ]
          },
          "discount_tier": {
            "description": "Discount tier based on package count",
            "type": "string",
            "enum": [
              "tier1",
              "tier2",
              "tier3",
              "tier4"
            ],
            "examples": [
              "tier2"
            ]
          }
        },
        "required": [
          "package_count",
          "individual_costs",
          "discount_tier"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_before_discount": {
            "description": "Total cost before discount",
            "type": "number",
            "examples": [
              241.0
            ]
          },
          "discount_amount": {
            "description": "Total discount amount",
            "type": "number",
            "examples": [
              24.1
            ]
          },
          "total_after_discount": {
            "description": "Total cost after discount",
            "type": "number",
            "examples": [
              216.9
            ]
          },
          "discount_percentage": {
            "description": "Applied discount percentage",
            "type": "number",
            "examples": [
              10.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_package_insurance_premium",
      "description": "Calculate insurance premium based on declared package value and service type",
      "group": "express_logistics.Courier_Service_Platform",
      "object_category": "pricing_management",
      "action_category": "computation",
      "pre_condition": "Declared value and service type must be provided",
      "post_condition": "Insurance premium is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "declared_value": {
            "description": "Declared value of package contents in currency units",
            "type": "number",
            "examples": [
              1000.0
            ]
          },
          "service_type": {
            "description": "Type of courier service",
            "type": "string",
            "enum": [
              "standard",
              "express",
              "same_day",
              "next_day"
            ],
            "examples": [
              "express"
            ]
          },
          "insurance_rate": {
            "description": "Insurance rate as percentage of declared value",
            "type": "number",
            "examples": [
              0.5
            ]
          }
        },
        "required": [
          "declared_value",
          "service_type",
          "insurance_rate"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "premium_amount": {
            "description": "Calculated insurance premium in currency units",
            "type": "number",
            "examples": [
              5.0
            ]
          },
          "coverage_amount": {
            "description": "Maximum coverage amount",
            "type": "number",
            "examples": [
              1000.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    }
  ],
  "schema_classification": {
    "ShipmentOrder": {
      "schema_name": "ShipmentOrder",
      "instance_key": "order_id",
      "fields": [
        {
          "field_name": "order_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "tracking_number",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "随机生成的字段，每次执行可能不同"
        },
        {
          "field_name": "status",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，必须严格匹配"
        },
        {
          "field_name": "sender_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "人名，不同表达可能等价"
        },
        {
          "field_name": "sender_phone",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "电话号码，必须严格匹配"
        },
        {
          "field_name": "sender_address",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "地址，自然语言文本，不同措辞可能表达同一地址"
        },
        {
          "field_name": "recipient_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "人名，不同表达可能等价"
        },
        {
          "field_name": "recipient_phone",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "电话号码，必须严格匹配"
        },
        {
          "field_name": "recipient_address",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "地址，自然语言文本，不同措辞可能表达同一地址"
        },
        {
          "field_name": "weight",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值，必须精确匹配"
        },
        {
          "field_name": "length",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值，必须精确匹配"
        },
        {
          "field_name": "width",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值，必须精确匹配"
        },
        {
          "field_name": "height",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值，必须精确匹配"
        },
        {
          "field_name": "service_type",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，必须严格匹配"
        },
        {
          "field_name": "declared_value",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "数值金额，必须精确匹配"
        },
        {
          "field_name": "total_cost",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "数值金额，必须精确匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "创建时间，必须严格匹配"
        },
        {
          "field_name": "updated_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "更新时间，必须严格匹配"
        }
      ]
    },
    "Courier": {
      "schema_name": "Courier",
      "instance_key": "courier_id",
      "fields": [
        {
          "field_name": "courier_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识快递员，每次生成均不同"
        },
        {
          "field_name": "courier_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "姓名，可能存在不同写法但指向同一人，应语义比较"
        },
        {
          "field_name": "phone_number",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "电话号码，需要精确匹配，任何差异都表示不同的联系方式"
        },
        {
          "field_name": "current_latitude",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "地理坐标数值，必须完全一致才表示同一位置"
        },
        {
          "field_name": "current_longitude",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "地理坐标数值，必须完全一致才表示同一位置"
        },
        {
          "field_name": "last_location_update",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "时间戳，代表最后更新时间，必须精确匹配"
        },
        {
          "field_name": "status",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举类型，表示工作状态，必须完全一致"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "注册时间，时间戳，必须精确匹配"
        }
      ]
    },
    "CourierAssignment": {
      "schema_name": "CourierAssignment",
      "instance_key": "assignment_id",
      "fields": [
        {
          "field_name": "assignment_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，由系统随机生成，每次都不同"
        },
        {
          "field_name": "order_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保分配到同一个订单"
        },
        {
          "field_name": "courier_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保分配给同一个快递员"
        },
        {
          "field_name": "assignment_type",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，代表分配类型，必须精确匹配"
        },
        {
          "field_name": "scheduled_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，必须精确匹配以保证调度时间一致"
        },
        {
          "field_name": "assignment_status",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，代表当前分配状态，必须精确匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "创建时间戳，必须精确匹配以确保数据一致性"
        }
      ]
    },
    "PickupRecord": {
      "schema_name": "PickupRecord",
      "instance_key": "pickup_record_id",
      "fields": [
        {
          "field_name": "pickup_record_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，由工具随机生成，每次执行都不同"
        },
        {
          "field_name": "order_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用订单一致"
        },
        {
          "field_name": "courier_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保快递员身份一致"
        },
        {
          "field_name": "pickup_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，实际取件时间必须严格一致"
        },
        {
          "field_name": "pickup_signature",
          "field_type": "Optional[str]",
          "comparison_type": "ignore",
          "reason": "确认码/签名，属于随机生成的验证信息，每次执行都不同"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "记录创建时间，必须精确匹配以确保数据状态一致"
        }
      ]
    },
    "DeliveryRecord": {
      "schema_name": "DeliveryRecord",
      "instance_key": "delivery_record_id",
      "fields": [
        {
          "field_name": "delivery_record_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，每次记录唯一且随机生成"
        },
        {
          "field_name": "order_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保关联订单一致"
        },
        {
          "field_name": "courier_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格匹配以确定具体快递员"
        },
        {
          "field_name": "actual_delivery_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期和时间，必须严格一致，时间差异即为不同交付"
        },
        {
          "field_name": "recipient_signature",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "确认码或数字签名，通常为每次交付随机生成"
        },
        {
          "field_name": "received_by",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "姓名（人名），不同表述可能语义等价，如‘张三’与‘张三先生’"
        },
        {
          "field_name": "photo_evidence",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "照片证据（URL或base64数据），内容差异即为不同交付证据"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "记录创建时间，需精确匹配以确认记录生成时刻"
        }
      ]
    },
    "DeliveryAttempt": {
      "schema_name": "DeliveryAttempt",
      "instance_key": "attempt_record_id",
      "fields": [
        {
          "field_name": "attempt_record_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识delivery attempt记录，每次生成都不同"
        },
        {
          "field_name": "order_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，引用订单，必须精确匹配"
        },
        {
          "field_name": "courier_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，引用快递员，必须精确匹配"
        },
        {
          "field_name": "attempt_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，必须精确匹配以确保准确性"
        },
        {
          "field_name": "failure_reason",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，代表失败原因，需精确匹配"
        },
        {
          "field_name": "notes",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本备注，不同措辞可能表达相同含义"
        },
        {
          "field_name": "attempt_count",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "数值，代表尝试次数，需精确匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "记录创建时间，需精确匹配以保证状态一致"
        }
      ]
    },
    "TrackingEvent": {
      "schema_name": "TrackingEvent",
      "instance_key": "event_id",
      "fields": [
        {
          "field_name": "event_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，工具随机生成，每次执行都不同"
        },
        {
          "field_name": "tracking_number",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "必须精确匹配的快递单号，具有唯一性和业务关键性"
        },
        {
          "field_name": "event_type",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，必须精确匹配以保证事件类型一致"
        },
        {
          "field_name": "event_location",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "地点名称可能存在不同表达方式，如‘上海’与‘上海市’，需语义比对"
        },
        {
          "field_name": "event_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "事件时间戳，必须精确匹配"
        },
        {
          "field_name": "event_description",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述，可能不同措辞表达相同事件"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "记录创建时间戳，通常需精确匹配以确认记录一致性"
        }
      ]
    }
  }
}