Flight_tool_description = [
    {
        "type": "function",
        "function": {
            "name": "search_flights",
            "description": "Search flights with filters for departure/arrival time window, sorting by time or price, and pagination.",
            "parameters": {
                "type": "object",
                "properties": {
                    "departure_city": {
                        "type": "string",
                        "description": "Departure city name, e.g. 'Beijing' or 'Shanghai'."
                    },
                    "arrival_city": {
                        "type": "string",
                        "description": "Arrival city name, e.g. 'Sanya' or 'Changchun'."
                    },
                    "date_str": {
                        "type": "string",
                        "description": "Travel date in format YYYY-MM-DD, e.g. '2025-12-10'."
                    },
                    "dep_period": {
                        "type": "string",
                        "description": "Departure time window in format 'HH:MM-HH:MM', e.g. '06:00-12:00'. Default: '00:00-24:00'."
                    },
                    "arr_period": {
                        "type": "string",
                        "description": "Arrival time window in format 'HH:MM-HH:MM', e.g. '12:00-18:00'. Default: '00:00-24:00'."
                    },
                    "sort_key": {
                        "type": "string",
                        "enum": ["time", "price"],
                        "description": "Sort key, either 'time' (by departure time) or 'price'. Default: 'time'."
                    },
                    "sort_order": {
                        "type": "string",
                        "enum": ["asc", "desc"],
                        "description": "Sort order, either 'asc' for ascending or 'desc' for descending. Default: 'asc'."
                    },
                    "page": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Page number starting from 1. Default: 1."
                    },
                    "page_size": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Number of results per page (at least 1). Default: 10."
                    }
                },
                "required": ["departure_city", "arrival_city", "date_str"]
            }
        }
    },
    {
        "type": "function",
        "function": {
            "name": "get_flight_detail_with_products",
            "description": "Get flight details and available products for a given flight and date.",
            "parameters": {
                "type": "object",
                "properties": {
                    "flight_id": {
                        "type": "string",
                        "description": "Internal flight ID corresponding to the 'Flight_id' field."
                    },
                    "date_str": {
                        "type": "string",
                        "description": "Target date in format YYYY-MM-DD, e.g. '2025-12-10'."
                    },
                    "source_platform": {
                        "type": "array",
                        "items": {
                            "type": "string",
                            "enum": ["ctrip", "alitrip", "qunar", "direct"]
                        },
                        "minItems": 1,
                        "description": "List of product source platforms. Must contain at least one of: 'ctrip', 'alitrip', 'qunar', 'direct'. Do NOT pass an empty array. To use all platforms, omit this field entirely."
                    },
                    "seat_type": {
                        "type": "string",
                        "enum": ["Economy class", "Business class"],
                        "description": "Seat/cabin type. Allowed values: 'Economy class' or 'Business class'. If this field is omitted, 'Economy class' is used by default."
                    }
                },
                "required": ["flight_id", "date_str"]
            }
        }
    },
    {
        "type": "function",
        "function": {
            "name": "get_airport_coordinates",
            "description": "Get latitude and longitude for an airport.",
            "parameters": {
                "type": "object",
                "properties": {
                    "airport_name": {
                        "type": "string",
                        "description": "Airport name, e.g. 'Hongqiao Airport'."
                    }
                },
                "required": ["airport_name"]
            }
        }
    }
]


Train_tool_description = [
    {
        "type": "function",
        "function": {
            "name": "search_trains",
            "description": "Search trains with filters for departure/arrival time window, sorting by time or price, and pagination.",
            "parameters": {
                "type": "object",
                "properties": {
                    "departure_city": {
                        "type": "string",
                        "description": "Departure city name, e.g. 'Beijing' or 'Shanghai'."
                    },
                    "arrival_city": {
                        "type": "string",
                        "description": "Arrival city name, e.g. 'Guangzhou' or 'Shenzhen'."
                    },
                    "date_str": {
                        "type": "string",
                        "description": "Travel date in format YYYY-MM-DD, e.g. '2025-12-10'."
                    },
                    "dep_period": {
                        "type": "string",
                        "description": "Departure time window in format 'HH:MM-HH:MM', e.g. '06:00-12:00'. Default: '00:00-24:00'."
                    },
                    "arr_period": {
                        "type": "string",
                        "description": "Arrival time window in format 'HH:MM-HH:MM', e.g. '12:00-18:00'. Default: '00:00-24:00'."
                    },
                    "sort_key": {
                        "type": "string",
                        "enum": ["time", "price"],
                        "description": "Sort key, either 'time' (by departure time) or 'price'. Default: 'time'."
                    },
                    "sort_order": {
                        "type": "string",
                        "enum": ["asc", "desc"],
                        "description": "Sort order, either 'asc' for ascending or 'desc' for descending. Default: 'asc'."
                    },
                    "page": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Page number starting from 1. Default: 1."
                    },
                    "page_size": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Number of results per page (at least 1). Default: 10."
                    }
                },
                "required": ["departure_city", "arrival_city", "date_str"]
            }
        }
    },
    {
        "type": "function",
        "function": {
            "name": "get_train_detail_with_products",
            "description": "Get train details and available products for a given train and date.",
            "parameters": {
                "type": "object",
                "properties": {
                    "train_id": {
                        "type": "string",
                        "description": "Internal train ID corresponding to the 'Train_id' field."
                    },
                    "date_str": {
                        "type": "string",
                        "description": "Target date in format YYYY-MM-DD, e.g. '2025-12-10'."
                    },
                    "source_platform": {
                        "type": "array",
                        "items": {
                            "type": "string",
                            "enum": ["ctrip", "alitrip", "qunar", "direct"]
                        },
                        "minItems": 1,
                        "description": "List of product source platforms. Must contain at least one of: 'ctrip', 'alitrip', 'qunar', 'direct'. Do NOT pass an empty array. To use all platforms, omit this field entirely."
                    },
                    "seat_type": {
                        "type": "string",
                        "enum": ["Second class", "First class", "Business class"],
                        "description": "Seat type. Allowed values: 'Second class', 'First class', or 'Business class'. If this field is omitted, 'Second class' is used by default."
                    }
                },
                "required": ["train_id", "date_str"]
            }
        }
    },
    {
        "type": "function",
        "function": {
            "name": "get_station_coordinates",
            "description": "Get latitude and longitude for a train station.",
            "parameters": {
                "type": "object",
                "properties": {
                    "station_name": {
                        "type": "string",
                        "description": "Station name or common alias, e.g. 'Beijing South Railway Station'."
                    }
                },
                "required": ["station_name"]
            }
        }
    }
]


Hotel_tool_description = [
    {
        "type": "function",
        "function": {
            "name": "search_hotels",
            "description": "Search hotels in a city with filters for price, ratings, distance, room types, and amenities, with sorting and pagination.",
            "parameters": {
                "type": "object",
                "properties": {
                    "city": {
                        "type": "string",
                        "description": "City name to search hotels in, e.g. 'Beijing' or 'Shanghai'."
                    },
                    "check_in_date": {
                        "type": "string",
                        "description": "Check-in date in format YYYY-MM-DD, e.g. '2025-12-10'."
                    },
                    "check_out_date": {
                        "type": "string",
                        "description": "Check-out date in format YYYY-MM-DD. Must be later than check_in_date."
                    },
                    "price_min": {
                        "type": "number",
                        "minimum": 0,
                        "description": "Minimum average price per night. Default: 0.0."
                    },
                    "price_max": {
                        "type": "number",
                        "minimum": 0,
                        "description": "Maximum average price per night. Default: 9999999.0."
                    },
                    "longitude": {
                        "type": "number",
                        "description": "Longitude of the search center. If omitted, the system will automatically use the city's central longitude."
                    },
                    "latitude": {
                        "type": "number",
                        "description": "Latitude of the search center. If omitted, the system will automatically use the city's central latitude."
                    },
                    "distance_threshold": {
                        "type": "number",
                        "minimum": 0,
                        "description": "Maximum distance in kilometers from the search center. Hotels farther than this will be filtered out. Default: 10.0."
                    },
                    "hotel_type": {
                        "type": "array",
                        "items": {
                            "type": "string",
                            "enum": ["Economy", "Midscale", "Upscale", "Luxury"]
                        },
                        "description": "List of hotel types to include. Default: ['Economy', 'Midscale', 'Upscale', 'Luxury'] (no restriction)."
                    },
                    "stars": {
                        "type": "number",
                        "minimum": 0,
                        "maximum": 5,
                        "description": "Minimum star rating (0-5). Only hotels with star rating >= this value are returned. Default: 0.0."
                    },
                    "review_count": {
                        "type": "integer",
                        "minimum": 0,
                        "description": "Minimum review count. Hotels with fewer reviews will be excluded. Default: 0."
                    },
                    "good_remarks_rate": {
                        "type": "number",
                        "minimum": 0,
                        "maximum": 1,
                        "description": "Minimum good remarks rate (0-1). Hotels with lower rate will be excluded. Default: 0.0."
                    },
                    "product_rating": {
                        "type": "number",
                        "minimum": 0,
                        "maximum": 5,
                        "description": "Minimum product rating (0-5). Default: 0.0."
                    },
                    "environment_rating": {
                        "type": "number",
                        "minimum": 0,
                        "maximum": 5,
                        "description": "Minimum environment rating (0-5). Default: 0.0."
                    },
                    "service_rating": {
                        "type": "number",
                        "minimum": 0,
                        "maximum": 5,
                        "description": "Minimum service rating (0-5). Default: 0.0."
                    },
                    "room_types": {
                        "type": "array",
                        "items": {
                            "type": "string",
                            "enum": ["single", "large", "double", "triple", "family"]
                        },
                        "minItems": 1,
                        "description": "Optional room-type filter. If provided (e.g. ['single','double']), the hotel must support ALL specified room types. Do NOT pass an empty array; omit this field entirely if you do not want to filter by room type. Default: no filter."
                    },
                    "cancel_policy": {
                        "type": "string",
                        "enum": ["0", "1", "2", "3"],
                        "description": "Maximum strictness of cancellation policy for hotels. The larger the value, the stricter the policy: 0 = cancellable before noon on check-in day; 1 = cancellable up to 1 day before; 2 = cancellable up to 3 days before; 3 = non-cancellable. A hotel is returned only if it has at least one room product with cancel_policy <= the given value. Default: 3 (no restriction)."
                    },
                    "is_pet_friendly": {
                        "type": "boolean",
                        "description": "Whether the hotel must be pet-friendly. If omitted, pet-friendliness is not filtered."
                    },
                    "has_breakfast": {
                        "type": "boolean",
                        "description": "Whether the hotel must include breakfast. If omitted, breakfast is not filtered."
                    },
                    "sort_key": {
                        "type": "string",
                        "enum": ["price", "stars", "review_count", "distance"],
                        "description": "Sort key: 'price' (average price per night), 'stars', 'review_count', or 'distance'. Default: 'price'."
                    },
                    "sort_order": {
                        "type": "string",
                        "enum": ["asc", "desc", "default"],
                        "description": "Sort order: 'asc' for ascending and 'desc' for descending. When set to 'default', sorting uses ascending order for sort_key = 'price' or 'distance', and descending order for sort_key = 'stars' or 'review_count'. Default: 'default'."
                    },
                    "page": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Page number starting from 1. Default: 1."
                    },
                    "page_size": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Number of results per page (at least 1). Default: 10."
                    }
                },
                "required": ["city", "check_in_date", "check_out_date"]
            }
        }
    },
    {
        "type": "function",
        "function": {
            "name": "get_hotel_detail_with_products",
            "description": "Get detailed hotel information and its available room products for a given stay period, with filters on room type, breakfast, cancellation policy, and window, plus pagination.",
            "parameters": {
                "type": "object",
                "properties": {
                    "hotel_id": {
                        "type": "string",
                        "description": "Internal hotel ID corresponding to the 'Hotel_id' field in search results."
                    },
                    "check_in_date": {
                        "type": "string",
                        "description": "Check-in date in format YYYY-MM-DD, e.g. '2025-12-10'."
                    },
                    "check_out_date": {
                        "type": "string",
                        "description": "Check-out date in format YYYY-MM-DD. Must be later than check_in_date."
                    },
                    "room_num": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Number of rooms to book. Default: 1."
                    },
                    "person_num": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Total number of guests for this stay (across all rooms). Default: 1."
                    },
                    "room_type": {
                        "type": "array",
                        "items": {
                            "type": "string",
                            "enum": ["single", "large", "double", "triple", "family"]
                        },
                        "minItems": 1,
                        "description": "Optional room-type filter for products, e.g. ['single','double']. A product matches if its room type is one of the specified values. Do NOT pass an empty array; omit this field instead if you don't want to filter by room type."
                    },
                    "min_breakfast_per_room": {
                        "type": "integer",
                        "minimum": 0,
                        "description": "Minimum number of breakfasts included per room. Products with fewer breakfasts will be excluded. Default: 0."
                    },
                    "cancel_policy": {
                        "type": "string",
                        "enum": ["0", "1", "2", "3"],
                        "description": "Maximum strictness of cancellation policy for returned room products. The larger the value, the stricter the policy: 0 = cancellable before noon on check-in day; 1 = cancellable up to 1 day before; 2 = cancellable up to 3 days before; 3 = non-cancellable. Only products with cancel_policy <= the given value are returned. If this field is omitted, the default value 3 is used (no restriction)."
                    },
                    "has_window": {
                        "type": "boolean",
                        "description": "Whether the room must have a window. If omitted, both with and without window are allowed."
                    },
                    "page": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Page number starting from 1. Default: 1."
                    },
                    "page_size": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Number of products per page (at least 1). Default: 10."
                    }
                },
                "required": ["hotel_id", "check_in_date", "check_out_date"]
            }
        }
    },
    {
        "type": "function",
        "function": {
            "name": "get_hotel_coordinates",
            "description": "Get latitude and longitude for a given hotel ID.",
            "parameters": {
                "type": "object",
                "properties": {
                    "hotel_id": {
                        "type": "string",
                        "description": "Hotel ID to look up."
                    }
                },
                "required": ["hotel_id"]
            }
        }
    }
]


Attraction_tool_description = [
    {
        "type": "function",
        "function": {
            "name": "search_attractions",
            "description": "Search attractions by city, keywords, location, rating, price, and other filters with sorting and pagination.",
            "parameters": {
                "type": "object",
                "properties": {
                    "city": {
                        "type": "string",
                        "description": "City name to search in, e.g. 'Beijing' or 'Shanghai'."
                    },
                    "attraction_name": {
                        "type": "string",
                        "description": "Attraction name keyword for fuzzy search, e.g. 'Forbidden City'."
                    },
                    "categories": {
                        "type": "array",
                        "items": { "type": "string" },
                        "minItems": 1,
                        "description": "Category list, e.g. ['Landmarks','Museums']. If omitted, no category filter."
                    },
                    "longitude": {
                        "type": "number",
                        "description": "Longitude of the search center. If omitted, the system will automatically use the city's central longitude."
                    },
                    "latitude": {
                        "type": "number",
                        "description": "Latitude of the search center. If omitted, the system will automatically use the city's central latitude."
                    },
                    "distance_threshold": {
                        "type": "number",
                        "minimum": 0,
                        "description": "Maximum distance from origin in kilometers. Default: 50."
                    },
                    "rating": {
                        "type": "string",
                        "enum": ["4.0", "4.5"],
                        "description": "Minimum rating threshold. Only two threshold values are allowed: 4.0 or 4.5. If set to 4.0, only attractions with rating >= 4.0 are returned; if set to 4.5, only attractions with rating >= 4.5 are returned."
                    },
                    "sight_level": {
                        "type": "string",
                        "enum": ["4A", "5A"],
                        "description": "Sight level filter. Optional: when omitted, no sight level filtering is applied. If set to '4A', only attractions with level 4A or higher are returned (including 5A). If set to '5A', only 5A attractions are returned."
                    },
                    "comment_count": {
                        "type": "integer",
                        "description": "Minimum number of comments required, e.g. 100."
                    },
                    "free_only": {
                        "type": "boolean",
                        "description": "If true, only attractions that are free are returned. Default: false."
                    },
                    "sort_key": {
                        "type": "string",
                        "enum": ["commentScore", "heatScore", "distance"],
                        "description": "Sort field. When omitted, results are sorted by keyword match score (if available) and then by popularity (heatScore) in descending order."
                    },
                    "sort_order": {
                        "type": "string",
                        "enum": ["asc", "desc", "default"],
                        "description": "Sort order. For distance, 'default' behaves like ascending; for scores, 'default' behaves like descending. Default: 'default'."
                    },
                    "page": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Page number starting from 1. Default: 1."
                    },
                    "page_size": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Number of results per page (at least 1). Default: 10."
                    }
                },
                "required": ["city"]
            }
        }
    },
    {
        "type": "function",
        "function": {
            "name": "get_attraction_detail_with_products",
            "description": "Get attraction detail and ticket products for a given POI ID.",
            "parameters": {
                "type": "object",
                "properties": {
                    "poi_id": {
                        "type": "string",
                        "description": "Attraction POI ID."
                    }
                },
                "required": ["poi_id"]
            }
        }
    },
    {
        "type": "function",
        "function": {
            "name": "get_attraction_coordinates",
            "description": "Get latitude and longitude coordinates for an attraction by POI ID.",
            "parameters": {
                "type": "object",
                "properties": {
                    "poi_id": {
                        "type": "string",
                        "description": "Attraction POI ID."
                    }
                },
                "required": ["poi_id"]
            }
        }
    }
]


Restaurant_tool_description = [
    {
        "type": "function",
        "function": {
            "name": "search_restaurants",
            "description": "Search restaurants in a city with filters for price, ratings, categories, distance, reservability, and other filters with sorting and pagination.",
            "parameters": {
                "type": "object",
                "properties": {
                    "city": {
                        "type": "string",
                        "description": "City name (or internal location key) to search restaurants in, e.g. 'Beijing' or 'Shanghai'."
                    },
                    "longitude": {
                        "type": "number",
                        "description": "Longitude of the search center. If omitted, the system will automatically use the city's central longitude."
                    },
                    "latitude": {
                        "type": "number",
                        "description": "Latitude of the search center. If omitted, the system will automatically use the city's central latitude."
                    },
                    "distance_threshold": {
                        "type": "number",
                        "minimum": 0,
                        "description": "Maximum distance in kilometers from the search center. Restaurants farther than this will be filtered out. Default: 5.0 km."
                    },
                    "price_min": {
                        "type": "number",
                        "minimum": 0,
                        "description": "Minimum average price per person. Default: 0.0."
                    },
                    "price_max": {
                        "type": "number",
                        "minimum": 0,
                        "description": "Maximum average price per person. Default: 999999.0."
                    },
                    "stars": {
                        "type": "number",
                        "minimum": 0,
                        "maximum": 5,
                        "description": "Minimum star rating (0-5). Only restaurants with star rating >= this value are returned. Default: 0.0."
                    },
                    "review_count": {
                        "type": "integer",
                        "minimum": 0,
                        "description": "Minimum review count. Restaurants with fewer reviews will be excluded. Default: 0."
                    },
                    "product_rating": {
                        "type": "number",
                        "minimum": 0,
                        "maximum": 5,
                        "description": "Minimum product rating (0-5). Default: 0.0."
                    },
                    "environment_rating": {
                        "type": "number",
                        "minimum": 0,
                        "maximum": 5,
                        "description": "Minimum environment rating (0-5). Default: 0.0."
                    },
                    "service_rating": {
                        "type": "number",
                        "minimum": 0,
                        "maximum": 5,
                        "description": "Minimum service rating (0-5). Default: 0.0."
                    },
                    "categories": {
                        "type": "array",
                        "items": {
                            "type": "string",
                            "enum": ["Anhui Cuisine", "Barbecue", "Beijing Cuisine", "Buffet", "Chaoshan Cuisine", "Crayfish", "Creative Cuisine", "Farmhouse Cuisine", "Fast Food", "Fujian Cuisine", "Guangdong cuisine", "Guangxi Cuisine", "Guizhou Cuisine", "Hainan Cuisine", "Hakka Cuisine", "Henan Cuisine", "Home-style Cooking", "Hot Pot", "Huaiyang Cuisine", "Hubei Cuisine", "Hunan Cuisine", "Japanese Cuisine", "Jiangsu and Zhejiang Cuisine", "Jiangxi Cuisine", "Korean Cuisine", "Malatang", "Northeastern Cuisine", "Northwestern Cuisine", "Other Chinese Cuisine", "Other Delicacies", "Pizza", "Porridge Shop", "Private Kitchen", "Rice Noodles", "Seafood", "Shaanxi Cuisine", "Shandong Cuisine", "Shanxi Cuisine", "Sichuan Cuisine", "Snacks", "Southeast Asian Cuisine", "Taiwanese Cuisine", "Tea Restaurant", "Tianjin Cuisine", "Vegetarian Cuisine", "Western Cuisine", "Wontons and Dumplings", "Xinjiang Cuisine", "Yunnan and Guizhou Cuisine"]
                        },
                        "minItems": 1,
                        "description": "Optional list of restaurant categories to include, e.g. ['Seafood','Hot Pot']; if omitted, no category filter is applied and all categories are allowed."
                    },
                    "reservable": {
                        "type": "boolean",
                        "description": "Whether the restaurant must support reservations. True: only restaurants that support reservations; False: only restaurants that do NOT support reservations (walk-in / queue on-site only); if omitted, reservability is not filtered."
                    },
                    "sort_key": {
                        "type": "string",
                        "enum": ["stars", "review_count", "price", "distance"],
                        "description": "Sort key: 'stars', 'review_count', 'price' (average price per person), or 'distance'. Default: 'stars'."
                    },
                    "sort_order": {
                        "type": "string",
                        "enum": ["asc", "desc", "default"],
                        "description": "Sort order: 'asc' for ascending, 'desc' for descending. When set to 'default', sorting uses ascending order for 'price' and 'distance', and descending order for 'stars' and 'review_count'. Default: 'default'."
                    },
                    "page": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Page number starting from 1. Default: 1."
                    },
                    "page_size": {
                        "type": "integer",
                        "minimum": 1,
                        "description": "Number of results per page (at least 1). Default: 10."
                    }
                },
                "required": ["city"]
            }
        }
    },
    {
        "type": "function",
        "function": {
            "name": "get_restaurant_detail_with_products",
            "description": "Get detailed restaurant information and all its available products (set meals) for a given restaurant ID, including ratings, open hours, and each product's people count, price, and available time ranges.",
            "parameters": {
                "type": "object",
                "properties": {
                    "restaurant_id": {
                        "type": "string",
                        "description": "Internal restaurant ID corresponding to the 'restaurant_id' or 'id' field in search results."
                    }
                },
                "required": ["restaurant_id"]
            }
        }
    },
    {
        "type": "function",
        "function": {
            "name": "get_restaurant_coordinates",
            "description": "Get latitude and longitude for a given restaurant ID.",
            "parameters": {
                "type": "object",
                "properties": {
                    "restaurant_id": {
                        "type": "string",
                        "description": "Restaurant ID to look up."
                    }
                },
                "required": ["restaurant_id"]
            }
        }
    }
]



General_tool_description = [
    {
        "type": "function",
        "function": {
            "name": "get_route_estimate",
            "description": "Return an estimated travel distance and travel time for local transportation only—defined as travel within the same city, based on their latitude and longitude coordinates.",
            "parameters": {
                "type": "object",
                "properties": {
                    "origin_lat": {
                        "type": "number",
                        "description": "Latitude of the origin point."
                    },
                    "origin_lng": {
                        "type": "number",
                        "description": "Longitude of the origin point."
                    },
                    "destination_lat": {
                        "type": "number",
                        "description": "Latitude of the destination point."
                    },
                    "destination_lng": {
                        "type": "number",
                        "description": "Longitude of the destination point."
                    }
                },
                "required": ["origin_lat", "origin_lng", "destination_lat", "destination_lng"]
            }
        }
    },
    {
        "type": "function",
        "function": {
            "name": "get_city_center_coords",
            "description": "Retrieve the central coordinates (longitude and latitude) for a given city name.",
            "parameters": {
                "type": "object",
                "properties": {
                    "city_name": {
                        "type": "string",
                        "description": "Name of the city to look up, e.g. 'Beijing', 'Shanghai'."
                    }
                },
                "required": ["city_name"]
            }
        }
    },
    {
    "type": "function",
    "function": {
        "name": "get_date_after",
        "description": "Given a date string and a number of days, return the date after adding the specified number of days.",
        "parameters": {
            "type": "object",
            "properties": {
                "date_str": {
                    "type": "string",
                    "description": "Input date string in 'YYYY-MM-DD' format, e.g. '2025-03-01'."
                },
                "days": {
                    "type": "number",
                    "description": "Number of days to add to the input date."
                }
            },
            "required": ["date_str", "days"]
            }
        }
    }


]
