توابع سفارشی را می توان با استفاده از قابلیت فراخوانی تابع تعریف و برای مدل های Gemini ارائه کرد. مدلها مستقیماً این توابع را فراخوانی نمیکنند، بلکه در عوض خروجی دادههای ساختاری تولید میکنند که نام تابع و آرگومانهای پیشنهادی را مشخص میکند. این خروجی به شما امکان میدهد برنامههایی بنویسید که خروجی ساختیافته را میگیرند و APIهای خارجی را فراخوانی میکنند، و خروجی API حاصل میتواند در یک اعلان مدل دیگر گنجانده شود و پاسخهای پرس و جو جامعتری را ممکن میسازد. فراخوانی تابع، کاربران را قادر میسازد تا با اطلاعات بلادرنگ و خدمات مختلف، مانند پایگاههای داده، سیستمهای مدیریت ارتباط با مشتری و مخازن اسناد تعامل داشته باشند و توانایی آنها را برای ارائه پاسخهای مرتبط و متنی افزایش دهد.
فراخوانی تابع چگونه کار می کند
شما از ویژگی فراخوانی تابع با افزودن داده های پرس و جوی ساختاریافته که رابط های برنامه نویسی را توصیف می کنند، به نام اعلان تابع ، به اعلان مدل استفاده می کنید. اعلانهای تابع نام تابع API را ارائه میکنند، هدف آن، هر پارامتری را که پشتیبانی میکند و توصیف آن پارامترها را توضیح میدهند. پس از اینکه لیستی از اعلان های تابع در یک کوئری را به مدل ارسال کردید، اعلان های تابع و بقیه پرس و جو را تجزیه و تحلیل می کند تا نحوه استفاده از API اعلام شده در پاسخ به درخواست را تعیین کند.
سپس مدل یک شی را در یک طرحواره سازگار با OpenAPI برمی گرداند که نحوه فراخوانی یک یا چند تابع اعلام شده را برای پاسخ به سؤال کاربر مشخص می کند. سپس میتوانید پارامترهای فراخوانی تابع توصیهشده را بگیرید، API واقعی را فراخوانی کنید، پاسخی دریافت کنید و آن پاسخ را به کاربر ارائه دهید یا اقدامات بعدی را انجام دهید. توجه داشته باشید که مدل در واقع توابع اعلام شده را فراخوانی نمی کند. در عوض، شما از پارامترهای شی طرحواره برگشتی برای فراخوانی تابع استفاده می کنید. Gemini API همچنین از فراخوانی تابع موازی پشتیبانی می کند، که در آن مدل چندین تابع API را بر اساس یک درخواست توصیه می کند.
مدل های پشتیبانی شده
مدل های زیر از قابلیت فراخوانی تابع پشتیبانی می کنند:
-
gemini-1.0-pro
-
gemini-1.0-pro-001
-
gemini-1.5-flash-latest
-
gemini-1.5-pro-latest
اعلامیه های عملکرد
هنگامی که فراخوانی تابع را در یک درخواست پیاده سازی می کنید، یک شی tools
ایجاد می کنید که حاوی یک یا چند function declarations
است. توابع را با استفاده از JSON تعریف میکنید، بهویژه با یک زیرمجموعه انتخابی از قالب طرحواره OpenAPI . یک اعلان تابع می تواند شامل پارامترهای زیر باشد:
-
name
(رشته): شناسه منحصر به فرد برای تابع در فراخوانی API. -
description
(رشته): توضیحی جامع از هدف و قابلیت های تابع. -
parameters
(شیء): داده های ورودی مورد نیاز تابع را تعریف می کند.-
type
(string): نوع کلی داده را مشخص می کند، مانندobject
. -
properties
(شیء): پارامترهای فردی را فهرست می کند که هر کدام دارای:-
type
(string): نوع داده پارامتر مانندstring
،integer
،boolean
. -
description
(رشته): توضیح واضحی از هدف پارامتر و قالب مورد انتظار.
-
-
required
(آرایه): آرایه ای از رشته ها که نام پارامترهایی را که برای عملکرد تابع اجباری هستند فهرست می کند.
-
برای مثالهای کد اعلان تابع با استفاده از دستورات cURL، به مثالهای فراخوانی تابع مراجعه کنید. برای مثالها و اطلاعات مربوط به ایجاد اعلانهای عملکرد برای پلتفرمهای دیگر، راهنمای پلتفرمهای فراخوانی عملکرد را ببینید.
بهترین شیوه ها برای اعلام عملکرد
تعریف دقیق توابع هنگام ادغام آنها در درخواست های شما ضروری است. هر تابع به پارامترهای خاصی متکی است که رفتار و تعامل آن با مدل را هدایت می کند. فهرست زیر راهنمایی در مورد تعریف پارامترهای یک تابع در یک آرایه functions_declarations
ارائه می دهد.
name
: از نام های واضح و توصیفی بدون نویسه های فاصله، نقطه (.
) یا خط تیره (-
) استفاده کنید. در عوض، از نویسه های زیرخط (_
) یا شتر استفاده کنید.description
: توضیحات عملکرد را با جزئیات، واضح و خاص ارائه دهید و در صورت لزوم مثال هایی ارائه دهید. بهعنوان مثال، بهجایfind theaters
،find theaters based on location and optionally movie title that is currently playing in theaters.
از توصیف های بیش از حد گسترده یا مبهم خودداری کنید.properties
>type
: از پارامترهای قوی تایپ شده برای کاهش توهمات مدل استفاده کنید. به عنوان مثال، اگر مقادیر پارامتر از یک مجموعه محدود هستند، به جای فهرست کردن مقادیر در توضیحات، از یک فیلدenum
استفاده کنید (به عنوان مثال،"type": "enum", "values": ["now_playing", "upcoming"]
) . اگر مقدار پارامتر همیشه یک عدد صحیح است، نوع را به جایnumber
،integer
قرار دهید.properties
>description
: مثالها و محدودیتهای عینی ارائه کنید. به عنوان مثال، به جایthe location to search
، ازThe city and state, eg San Francisco, CA or a zip code eg 95616
استفاده کنید.
برای بهترین روشهای بیشتر هنگام استفاده از فراخوانی تابع، بخش بهترین روشها را ببینید.
عملکرد حالت تماس
می توانید از پارامتر mode
فراخوانی تابع برای تغییر رفتار اجرای ویژگی استفاده کنید. سه حالت موجود است:
-
AUTO
: رفتار مدل پیش فرض. مدل تصمیم می گیرد که یک فراخوانی تابع یا یک پاسخ زبان طبیعی را پیش بینی کند. -
ANY
: مدل محدود شده است تا همیشه یک فراخوانی تابع را پیش بینی کند. اگرallowed_function_names
ارائه نشده باشد، مدل از بین تمام اعلانهای تابع موجود انتخاب میکند. اگرallowed_function_names
ارائه شده باشد ، مدل از مجموعه توابع مجاز انتخاب می کند. -
NONE
: مدل فراخوانی تابع را پیش بینی نمی کند. در این مورد، رفتار مدل مانند این است که هیچ اعلان تابعی را ارسال نکنید.
استفاده از حالت ANY
("تماس عملکرد اجباری") فقط برای مدل های Gemini 1.5 Pro
پشتیبانی می شود.
همچنین میتوانید مجموعهای از allowed_function_names
را ارسال کنید که در صورت ارائه، عملکردهایی را که مدل فراخوانی میکند محدود میکند. شما باید فقط allowed_function_names
در زمانی بگنجانید که حالت ANY
باشد. نام توابع باید با نام اعلان تابع مطابقت داشته باشد. با تنظیم حالت بر روی ANY
و تنظیم نام allowed_function_names
، مدل یک فراخوانی تابع را از مجموعه نام های تابع ارائه شده پیش بینی می کند.
قطعه کد زیر از یک درخواست مثال نشان می دهد که چگونه mode
را روی ANY
تنظیم کنید و لیستی از توابع مجاز را مشخص کنید:
"tool_config": {
"function_calling_config": {
"mode": "ANY",
"allowed_function_names": ["find_theaters", "get_showtimes"]
},
}
نمونه های فراخوانی تابع
این بخش اعلانهایی را برای فراخوانی تابع با استفاده از دستورات cURL ارائه میکند. مثالها شامل سناریوهای یک دور و چند دور، و فعال کردن حالتهای مختلف فراخوانی عملکرد است.
هنگام استفاده از دستورات cURL با این ویژگی، اطلاعات عملکرد و پارامتر در عنصر tools
گنجانده می شود. هر اعلان تابع در عنصر tools
حاوی نام تابع است و شما پارامترها را با استفاده از طرحواره سازگار با OpenAPI و شرح تابع مشخص میکنید.
مثال تک چرخشی
Single-turn زمانی است که یک بار مدل زبان را فرا می خوانید. با فراخوانی تابع، یک مورد استفاده تک نوبتی ممکن است زمانی باشد که یک جستار زبان طبیعی و لیستی از توابع را به مدل ارائه دهید. در این حالت، مدل از اعلان تابع استفاده می کند که شامل نام تابع، پارامترها و توضیحات است تا پیش بینی کند کدام تابع را فراخوانی کند و آرگومان هایی که آن را با آن فراخوانی کند.
نمونه curl زیر نمونهای از توضیح عملکردی است که اطلاعات مربوط به مکان پخش فیلم را برمیگرداند. چندین اعلان تابع در درخواست گنجانده شده است، مانند find_movies
و find_theaters
.
درخواست مثال فراخوانی تابع تک چرخشی
curl https://generativelanguage.googleapis.com/v1beta/models/gemini-pro:generateContent?key=$API_KEY \ -H 'Content-Type: application/json' \ -d '{ "contents": { "role": "user", "parts": { "text": "Which theaters in Mountain View show Barbie movie?" } }, "tools": [ { "function_declarations": [ { "name": "find_movies", "description": "find movie titles currently playing in theaters based on any description, genre, title words, etc.", "parameters": { "type": "object", "properties": { "location": { "type": "string", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "description": { "type": "string", "description": "Any kind of description including category or genre, title words, attributes, etc." } }, "required": [ "description" ] } }, { "name": "find_theaters", "description": "find theaters based on location and optionally movie title which is currently playing in theaters", "parameters": { "type": "object", "properties": { "location": { "type": "string", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "movie": { "type": "string", "description": "Any movie title" } }, "required": [ "location" ] } }, { "name": "get_showtimes", "description": "Find the start times for movies playing in a specific theater", "parameters": { "type": "object", "properties": { "location": { "type": "string", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "movie": { "type": "string", "description": "Any movie title" }, "theater": { "type": "string", "description": "Name of the theater" }, "date": { "type": "string", "description": "Date for requested showtime" } }, "required": [ "location", "movie", "theater", "date" ] } } ] } ] }'
پاسخ به این مثال کرل ممکن است شبیه به زیر باشد.
تابع تک چرخشی فراخوانی پاسخ مثال curl
[{ "candidates": [ { "content": { "parts": [ { "functionCall": { "name": "find_theaters", "args": { "movie": "Barbie", "location": "Mountain View, CA" } } } ] }, "finishReason": "STOP", "safetyRatings": [ { "category": "HARM_CATEGORY_HARASSMENT", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_HATE_SPEECH", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_SEXUALLY_EXPLICIT", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_DANGEROUS_CONTENT", "probability": "NEGLIGIBLE" } ] } ], "usageMetadata": { "promptTokenCount": 9, "totalTokenCount": 9 } }]
مثال تک چرخشی با استفاده از حالت ANY
مثال حلقه زیر شبیه به مثال یک چرخش است، اما حالت را روی ANY
تنظیم می کند:
"tool_config": {
"function_calling_config": {
"mode": "ANY"
},
}
فراخوانی تابع تک چرخشی با استفاده از هر حالت (درخواست)
curl https://generativelanguage.googleapis.com/v1beta/models/gemini-pro:generateContent?key=$API_KEY \ -H 'Content-Type: application/json' \ -d '{ "contents": { "role": "user", "parts": { "text": "What movies are showing in North Seattle tonight?" } }, "tools": [ { "function_declarations": [ { "name": "find_movies", "description": "find movie titles currently playing in theaters based on any description, genre, title words, etc.", "parameters": { "type": "object", "properties": { "location": { "type": "string", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "description": { "type": "string", "description": "Any kind of description including category or genre, title words, attributes, etc." } }, "required": [ "description" ] } }, { "name": "find_theaters", "description": "find theaters based on location and optionally movie title which is currently playing in theaters", "parameters": { "type": "object", "properties": { "location": { "type": "string", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "movie": { "type": "string", "description": "Any movie title" } }, "required": [ "location" ] } }, { "name": "get_showtimes", "description": "Find the start times for movies playing in a specific theater", "parameters": { "type": "object", "properties": { "location": { "type": "string", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "movie": { "type": "string", "description": "Any movie title" }, "theater": { "type": "string", "description": "Name of the theater" }, "date": { "type": "string", "description": "Date for requested showtime" } }, "required": [ "location", "movie", "theater", "date" ] } } ] } ], "tool_config": { "function_calling_config": { "mode": "ANY" }, } }'
پاسخ ممکن است مشابه موارد زیر باشد:
فراخوانی تابع تک چرخشی با استفاده از هر حالت (پاسخ)
{ "candidates": [ { "content": { "parts": [ { "functionCall": { "name": "find_movies", "args": { "description": "", "location": "North Seattle, WA" } } } ], "role": "model" }, "finishReason": "STOP", "index": 0, "safetyRatings": [ { "category": "HARM_CATEGORY_DANGEROUS_CONTENT", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_HARASSMENT", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_HATE_SPEECH", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_SEXUALLY_EXPLICIT", "probability": "NEGLIGIBLE" } ] } ], "promptFeedback": { "safetyRatings": [ { "category": "HARM_CATEGORY_SEXUALLY_EXPLICIT", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_HATE_SPEECH", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_HARASSMENT", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_DANGEROUS_CONTENT", "probability": "NEGLIGIBLE" } ] } }
مثال تک چرخشی با استفاده از هر حالت و توابع مجاز
مثال curl زیر شبیه مثال تک چرخشی است، اما حالت را روی ANY
تنظیم میکند و شامل لیستی از توابع مجاز است:
"tool_config": {
"function_calling_config": {
"mode": "ANY",
"allowed_function_names": ["find_theaters", "get_showtimes"]
},
}
فراخوانی تابع تک چرخشی با استفاده از هر حالت و توابع مجاز (درخواست)
curl https://generativelanguage.googleapis.com/v1beta/models/gemini-pro:generateContent?key=$API_KEY \ -H 'Content-Type: application/json' \ -d '{ "contents": { "role": "user", "parts": { "text": "What movies are showing in North Seattle tonight?" } }, "tools": [ { "function_declarations": [ { "name": "find_movies", "description": "find movie titles currently playing in theaters based on any description, genre, title words, etc.", "parameters": { "type": "object", "properties": { "location": { "type": "string", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "description": { "type": "string", "description": "Any kind of description including category or genre, title words, attributes, etc." } }, "required": [ "description" ] } }, { "name": "find_theaters", "description": "find theaters based on location and optionally movie title which is currently playing in theaters", "parameters": { "type": "object", "properties": { "location": { "type": "string", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "movie": { "type": "string", "description": "Any movie title" } }, "required": [ "location" ] } }, { "name": "get_showtimes", "description": "Find the start times for movies playing in a specific theater", "parameters": { "type": "object", "properties": { "location": { "type": "string", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "movie": { "type": "string", "description": "Any movie title" }, "theater": { "type": "string", "description": "Name of the theater" }, "date": { "type": "string", "description": "Date for requested showtime" } }, "required": [ "location", "movie", "theater", "date" ] } } ] } ], "tool_config": { "function_calling_config": { "mode": "ANY", "allowed_function_names": ["find_theaters", "get_showtimes"] }, } }'
مدل نمیتواند تابع find_movies
را پیشبینی کند، زیرا در لیست توابع مجاز نیست، بنابراین در عوض یک تابع متفاوت را پیشبینی میکند. پاسخ ممکن است مشابه موارد زیر باشد:
فراخوانی تابع تک چرخشی با استفاده از هر حالت و توابع مجاز (پاسخ)
{ "candidates": [ { "content": { "parts": [ { "functionCall": { "name": "find_theaters", "args": { "location": "North Seattle, WA", "movie": null } } } ], "role": "model" }, "finishReason": "STOP", "index": 0, "safetyRatings": [ { "category": "HARM_CATEGORY_SEXUALLY_EXPLICIT", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_HARASSMENT", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_HATE_SPEECH", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_DANGEROUS_CONTENT", "probability": "NEGLIGIBLE" } ] } ], "promptFeedback": { "safetyRatings": [ { "category": "HARM_CATEGORY_SEXUALLY_EXPLICIT", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_HATE_SPEECH", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_HARASSMENT", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_DANGEROUS_CONTENT", "probability": "NEGLIGIBLE" } ] } }
نمونه های چند چرخشی
با انجام موارد زیر می توانید سناریوی فراخوانی تابع چند چرخشی را پیاده سازی کنید:
- با فراخوانی مدل زبان، پاسخ فراخوانی تابع را دریافت کنید. این اولین نوبت است.
- مدل زبان را با استفاده از پاسخ فراخوانی تابع از نوبت اول و پاسخ تابعی که از فراخوانی آن تابع دریافت میکنید، فراخوانی کنید. این نوبت دوم است.
پاسخ نوبت دوم یا نتایج را برای پاسخ به پرس و جوی شما در نوبت اول خلاصه می کند یا شامل یک فراخوانی تابع دوم است که می توانید از آن برای دریافت اطلاعات بیشتر برای درخواست خود استفاده کنید.
این مبحث شامل دو نمونه پیچ چند چرخشی است:
- مثال Curl که از پاسخ تابعی از نوبت قبلی استفاده می کند
- مثال Curl که یک مدل زبان را چندین بار فراخوانی می کند
از پاسخ نوبت قبلی استفاده کنید
نمونه curl زیر تابع و آرگومان های برگردانده شده توسط مثال تک چرخشی قبلی را برای دریافت پاسخ فراخوانی می کند. متد و پارامترهای برگردانده شده توسط مثال تک چرخشی در این JSON هستند.
"functionCall": {
"name": "find_theaters",
"args": {
"movie": "Barbie",
"location": "Mountain View, CA"
}
}
تابع چند نوبتی فراخوانی درخواست مثال curl
curl https://generativelanguage.googleapis.com/v1beta/models/gemini-pro:generateContent?key=$API_KEY \ -H 'Content-Type: application/json' \ -d '{ "contents": [{ "role": "user", "parts": [{ "text": "Which theaters in Mountain View show Barbie movie?" }] }, { "role": "model", "parts": [{ "functionCall": { "name": "find_theaters", "args": { "location": "Mountain View, CA", "movie": "Barbie" } } }] }, { "role": "function", "parts": [{ "functionResponse": { "name": "find_theaters", "response": { "name": "find_theaters", "content": { "movie": "Barbie", "theaters": [{ "name": "AMC Mountain View 16", "address": "2000 W El Camino Real, Mountain View, CA 94040" }, { "name": "Regal Edwards 14", "address": "245 Castro St, Mountain View, CA 94040" }] } } } }] }], "tools": [{ "functionDeclarations": [{ "name": "find_movies", "description": "find movie titles currently playing in theaters based on any description, genre, title words, etc.", "parameters": { "type": "OBJECT", "properties": { "location": { "type": "STRING", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "description": { "type": "STRING", "description": "Any kind of description including category or genre, title words, attributes, etc." } }, "required": ["description"] } }, { "name": "find_theaters", "description": "find theaters based on location and optionally movie title which is currently playing in theaters", "parameters": { "type": "OBJECT", "properties": { "location": { "type": "STRING", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "movie": { "type": "STRING", "description": "Any movie title" } }, "required": ["location"] } }, { "name": "get_showtimes", "description": "Find the start times for movies playing in a specific theater", "parameters": { "type": "OBJECT", "properties": { "location": { "type": "STRING", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "movie": { "type": "STRING", "description": "Any movie title" }, "theater": { "type": "STRING", "description": "Name of the theater" }, "date": { "type": "STRING", "description": "Date for requested showtime" } }, "required": ["location", "movie", "theater", "date"] } }] }] }'
پاسخ به این مثال curl شامل نتیجه فراخوانی متد find_theaters
است. پاسخ ممکن است مشابه موارد زیر باشد:
تابع چند چرخشی فراخوانی پاسخ مثال curl
{ "candidates": [ { "content": { "parts": [ { "text": " OK. Barbie is showing in two theaters in Mountain View, CA: AMC Mountain View 16 and Regal Edwards 14." } ] } } ], "usageMetadata": { "promptTokenCount": 9, "candidatesTokenCount": 27, "totalTokenCount": 36 } }
چندین بار با مدل تماس بگیرید
مثال cURL زیر چندین بار مدل AI مولد را برای فراخوانی یک تابع فراخوانی می کند. هر بار که مدل تابع را فراخوانی میکند، میتواند از یک تابع متفاوت برای پاسخ به درخواست کاربر مختلف در درخواست استفاده کند.
تابع چند نوبتی فراخوانی درخواست مثال curl
curl https://generativelanguage.googleapis.com/v1beta/models/gemini-pro:generateContent?key=$API_KEY \ -H 'Content-Type: application/json' \ -d '{ "contents": [{ "role": "user", "parts": [{ "text": "Which theaters in Mountain View show Barbie movie?" }] }, { "role": "model", "parts": [{ "functionCall": { "name": "find_theaters", "args": { "location": "Mountain View, CA", "movie": "Barbie" } } }] }, { "role": "function", "parts": [{ "functionResponse": { "name": "find_theaters", "response": { "name": "find_theaters", "content": { "movie": "Barbie", "theaters": [{ "name": "AMC Mountain View 16", "address": "2000 W El Camino Real, Mountain View, CA 94040" }, { "name": "Regal Edwards 14", "address": "245 Castro St, Mountain View, CA 94040" }] } } } }] }, { "role": "model", "parts": [{ "text": " OK. Barbie is showing in two theaters in Mountain View, CA: AMC Mountain View 16 and Regal Edwards 14." }] },{ "role": "user", "parts": [{ "text": "Can we recommend some comedy movies on show in Mountain View?" }] }], "tools": [{ "functionDeclarations": [{ "name": "find_movies", "description": "find movie titles currently playing in theaters based on any description, genre, title words, etc.", "parameters": { "type": "OBJECT", "properties": { "location": { "type": "STRING", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "description": { "type": "STRING", "description": "Any kind of description including category or genre, title words, attributes, etc." } }, "required": ["description"] } }, { "name": "find_theaters", "description": "find theaters based on location and optionally movie title which is currently playing in theaters", "parameters": { "type": "OBJECT", "properties": { "location": { "type": "STRING", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "movie": { "type": "STRING", "description": "Any movie title" } }, "required": ["location"] } }, { "name": "get_showtimes", "description": "Find the start times for movies playing in a specific theater", "parameters": { "type": "OBJECT", "properties": { "location": { "type": "STRING", "description": "The city and state, e.g. San Francisco, CA or a zip code e.g. 95616" }, "movie": { "type": "STRING", "description": "Any movie title" }, "theater": { "type": "STRING", "description": "Name of the theater" }, "date": { "type": "STRING", "description": "Date for requested showtime" } }, "required": ["location", "movie", "theater", "date"] } }] }] }'
تابع چند چرخشی فراخوانی پاسخ مثال curl
[{ "candidates": [ { "content": { "parts": [ { "functionCall": { "name": "find_movies", "args": { "description": "comedy", "location": "Mountain View, CA" } } } ] }, "finishReason": "STOP", "safetyRatings": [ { "category": "HARM_CATEGORY_HARASSMENT", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_HATE_SPEECH", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_SEXUALLY_EXPLICIT", "probability": "NEGLIGIBLE" }, { "category": "HARM_CATEGORY_DANGEROUS_CONTENT", "probability": "NEGLIGIBLE" } ] } ], "usageMetadata": { "promptTokenCount": 48, "totalTokenCount": 48 } } ]
بهترین شیوه ها
این بهترین شیوه ها را برای بهبود دقت و قابلیت اطمینان تماس های عملکرد خود دنبال کنید.
درخواست کاربر
برای بهترین نتایج، درخواست کاربر را با جزئیات زیر اضافه کنید:
- زمینه اضافی برای مدل برای مثال،
You are a movie API assistant to help users find movies and showtimes based on their preferences.
- جزئیات یا دستورالعمل هایی در مورد نحوه و زمان استفاده از توابع. به عنوان مثال،
Don't make assumptions on showtimes. Always use a future date for showtimes.
- دستورالعمل هایی برای پرسیدن سؤالات روشنگر در صورت مبهم بودن سؤالات کاربر. به عنوان مثال،
Ask clarifying questions if not enough information is available to complete the request.
پارامترهای نمونه برداری
برای پارامتر دما، از 0
یا مقدار پایین دیگری استفاده کنید. این به مدل دستور می دهد تا نتایج مطمئن تری تولید کند و توهمات را کاهش دهد.
فراخوانی API
اگر مدل فراخوانی تابعی را پیشنهاد میکند که میتواند سفارشی را ارسال کند، پایگاه داده را بهروزرسانی کند یا پیامدهای مهمی داشته باشد، قبل از اجرای فراخوانی تابع با کاربر اعتبارسنجی کنید.