फ़ंक्शन का इस्तेमाल करके, Gemini मॉडल को कस्टम फ़ंक्शन तय किए जा सकते हैं और दिए जा सकते हैं कॉल करने की सुविधा. मॉडल सीधे तौर पर इन फ़ंक्शन को शुरू नहीं करते हैं. इसके बजाय, ये सीधे तौर पर इन फ़ंक्शन को शुरू करते हैं ऐसा स्ट्रक्चर्ड डेटा आउटपुट जनरेट करता है जो फ़ंक्शन के नाम और सुझाए गए विकल्पों की जानकारी देता है आर्ग्युमेंट. इस आउटपुट से आप ऐसे ऐप्लिकेशन लिख सकते हैं जो स्ट्रक्चर्ड आउटपुट और कॉल बाहरी API को कॉल करता है, और फिर परिणाम में बनने वाला API आउटपुट इसे एक आगे के मॉडल प्रॉम्प्ट में शामिल किया गया है, जो ज़्यादा व्यापक क्वेरी की अनुमति देता है जवाब. फ़ंक्शन कॉलिंग की मदद से, उपयोगकर्ता रीयल-टाइम में इंटरैक्ट कर सकते हैं जानकारी और विविध सेवाएं, जैसे डेटाबेस, ग्राहक संबंध और दस्तावेज़ का डेटा स्टोर करने की जगहों को मैनेज कर सकता है, ताकि काम के और कॉन्टेक्स्ट के हिसाब से जवाब उपलब्ध कराएं.
फ़ंक्शन कॉलिंग की सुविधा कैसे काम करती है
यह जानकारी देने वाला स्ट्रक्चर्ड क्वेरी डेटा जोड़कर, फ़ंक्शन कॉलिंग की सुविधा का इस्तेमाल किया जाता है प्रोग्रामिंग इंटरफ़ेस, जिन्हें फ़ंक्शन डिक्लेरेशन कहते हैं. इन्हें मॉडल प्रॉम्प्ट में जोड़ा जाता है. कॉन्टेंट बनाने फ़ंक्शन एलान में एपीआई फ़ंक्शन का नाम बताया जाता है और इसके मकसद के बारे में बताया जाता है. और उन पैरामीटर के बारे में जानकारी. पास हो जाने के बाद मॉडल के लिए क्वेरी में फ़ंक्शन एलान की सूची, यह फ़ंक्शन का विश्लेषण करती है एलानों और बाकी क्वेरी का इस्तेमाल करके, अनुरोध के जवाब में एपीआई.
इसके बाद मॉडल, OpenAPI के साथ काम करने वाला स्कीमा बताया गया है कि जवाब देने के लिए, एक या उससे ज़्यादा एलान किए गए फ़ंक्शन को कैसे कॉल करें उपयोगकर्ता के सवालों के जवाब देना. इसके बाद, सुझाए गए फ़ंक्शन कॉल पैरामीटर, वास्तविक API को कॉल करें, प्रतिक्रिया पाएं, और वह प्रतिक्रिया या आगे की कार्रवाई करें. ध्यान दें कि मॉडल वास्तव में बताए गए फ़ंक्शन. इसके बजाय, लौटाए गए स्कीमा ऑब्जेक्ट पैरामीटर का इस्तेमाल इन कामों के लिए किया जाता है फ़ंक्शन को कॉल करें. Gemini 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
(स्ट्रिंग): एपीआई में मौजूद फ़ंक्शन के लिए यूनीक आइडेंटिफ़ायर कॉल.description
(स्ट्रिंग): फ़ंक्शन के बारे में पूरी जानकारी मकसद और क्षमताओं को पूरा करता हो.parameters
(ऑब्जेक्ट): फ़ंक्शन के लिए ज़रूरी इनपुट डेटा के बारे में बताता है.type
(स्ट्रिंग): इससे, कुल डेटा टाइप की जानकारी मिलती है, जैसे किobject
.properties
(object): इसमें अलग-अलग पैरामीटर की सूची होती है. हर पैरामीटर में:type
(स्ट्रिंग): पैरामीटर का डेटा टाइप, जैसे कि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"]
). अगर पैरामीटर का मान हमेशा एक पूर्णांक होता है. इसके बजाय, टाइप कोinteger
पर सेट करेंnumber
.properties
>description
: सटीक उदाहरण और शर्तें बताएं. उदाहरण के लिए,the location to search
के बजायThe city and state, e.g. San Francisco, CA or a zip code e.g. 95616
का इस्तेमाल करें.
फ़ंक्शन कॉलिंग का इस्तेमाल करते समय ज़्यादा सबसे सही तरीकों के बारे में जानने के लिए, सबसे सही तरीके सेक्शन.
फ़ंक्शन कॉलिंग मोड
कोड को एक्ज़ीक्यूट करने के तरीके में बदलाव करने के लिए, फ़ंक्शन कॉलिंग mode
पैरामीटर का इस्तेमाल किया जा सकता है
सुविधा का व्यवहार. तीन मोड उपलब्ध हैं:
AUTO
: यह मॉडल का डिफ़ॉल्ट व्यवहार होता है. मॉडल यह अनुमान लगाता है कि फ़ंक्शन कॉल या आम बोलचाल वाली भाषा में जवाब देना.ANY
: इस मॉडल को हमेशा फ़ंक्शन कॉल का अनुमान लगाने की अनुमति है. अगर आपनेallowed_function_names
की जानकारी नहीं दी गई है, यह मॉडल सभी उपलब्ध फ़ंक्शन एलान. अगरallowed_function_names
दिया गया है तो, मॉडल, अनुमति वाले फ़ंक्शन के सेट में से कोई विकल्प चुनता है.NONE
: यह मॉडल, फ़ंक्शन कॉल का अनुमान नहीं लगाएगा. इस मामले में, मॉडल यह वैसा ही होगा जैसे किसी फ़ंक्शन से जुड़ी जानकारी को पास नहीं किया जाता.
ANY
मोड ("फ़ोर्स्ड फ़ंक्शन कॉलिंग") का इस्तेमाल किया जा रहा है
यह सुविधा सिर्फ़ Gemini 1.5 Pro
मॉडल के साथ काम करती है.
आप allowed_function_names
का एक सेट भी पास कर सकते हैं, जिसे दिए जाने पर, सीमा
फ़ंक्शन जिन्हें मॉडल कॉल करेगा. आपको सिर्फ़ इसे शामिल करना चाहिए
मोड ANY
होने पर, allowed_function_names
. फ़ंक्शन के नाम मेल खाने चाहिए
फ़ंक्शन की जानकारी के लिए नाम. जब मोड को 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 के साथ काम करने वाला स्कीमा,
और फ़ंक्शन का ब्यौरा.
एक मोड़ वाला उदाहरण
एक टर्न तब होता है, जब भाषा के मॉडल को एक बार कॉल किया जाता है. फ़ंक्शन कॉलिंग के साथ, उस स्थिति में एक बार में इस्तेमाल का उदाहरण दिया जा सकता है, जब मॉडल क्वेरी और फ़ंक्शन की सूची देखें. इस मामले में, मॉडल एलान में, फ़ंक्शन का नाम, पैरामीटर, और ब्यौरा शामिल होता है. अनुमान लगाएं कि किस फ़ंक्शन को कॉल करना है और आर्ग्युमेंट के साथ कॉल करना है.
नीचे दिया गया कर्ल सैंपल,
फ़ंक्शन, जो इस बारे में जानकारी देता है कि फ़िल्म कहां चल रही है. कई
अनुरोध में फ़ंक्शन से जुड़ी जानकारी शामिल होती है, जैसे कि 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" ] } } ] } ] }'
इस कर्ल के उदाहरण के लिए रिस्पॉन्स कुछ ऐसा हो सकता है.
एक टर्न वाला फ़ंक्शन, जिसमें कर्ल के उदाहरण का जवाब दिया गया है
[{ "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
तक:
"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" } ] } }
किसी भी मोड और अनुमति वाले फ़ंक्शन का इस्तेमाल करके एक मोड़ों वाला उदाहरण
नीचे दिए गए कर्ल का उदाहरण
एक मोड़ वाला उदाहरण, लेकिन यह सेट हो जाता है
mode से 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" } ] } }
मल्टी-टर्न के उदाहरण
एक से ज़्यादा टर्न वाले फ़ंक्शन को कॉल करने के लिए, ये काम किए जा सकते हैं:
- लैंग्वेज मॉडल को कॉल करके, फ़ंक्शन कॉल का जवाब पाएं. यह पहला टर्न.
- पहले मोड़ से मिले फ़ंक्शन कॉल के जवाब का इस्तेमाल करके, लैंग्वेज मॉडल को कॉल करें और उस फ़ंक्शन को कॉल करने पर आपको मिलने वाला फंक्शन रिस्पॉन्स. यह है दूसरी बारी.
दूसरी बारी में मिले जवाब में आपको कम शब्दों में क्वेरी को पहली बार में क्वेरी आती है या उसमें कोई दूसरा फ़ंक्शन कॉल शामिल है, जिसका उपयोग आप आपकी क्वेरी के लिए ज़्यादा जानकारी.
इस विषय में मल्टी-टर्न कर्ल के दो उदाहरण शामिल हैं:
- कर्ल का उदाहरण, जो किसी पिछले मोड़ से मिले फ़ंक्शन रिस्पॉन्स का इस्तेमाल करता है
- कर्ल का उदाहरण, जो किसी भाषा के मॉडल को कई बार कॉल करता है
पिछली क्वेरी के जवाब का इस्तेमाल करें
नीचे दिया गया कर्ल सैंपल, फ़ंक्शन और आर्ग्युमेंट को पिछले एक टर्न वाला उदाहरण देखें. तरीका और पैरामीटर एक टर्न वाले उदाहरण से मिले नतीजे, इस JSON में दिए गए हैं.
"functionCall": {
"name": "find_theaters",
"args": {
"movie": "Barbie",
"location": "Mountain View, CA"
}
}
मल्टी-टर्न फ़ंक्शन कॉल करने की सुविधा देने वाले यूआरएल का उदाहरण
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"] } }] }] }'
इस कर्ल उदाहरण के लिए प्रतिक्रिया के रूप में
find_theaters
तरीका. रिस्पॉन्स, इससे मिलता-जुलता हो सकता है:
मल्टी-टर्न फ़ंक्शन कॉल करने की सुविधा देने वाले यूआरएल का उदाहरण
{ "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 के उदाहरण में, कॉल करने के लिए जनरेटिव एआई मॉडल को कई बार इस्तेमाल किया गया है एक फ़ंक्शन का इस्तेमाल करें. जब भी मॉडल, फ़ंक्शन को कॉल करता है, तो यह फ़ंक्शन का इस्तेमाल करें.
मल्टी-टर्न फ़ंक्शन कॉल करने की सुविधा देने वाले यूआरएल का उदाहरण
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"] } }] }] }'
मल्टी-टर्न फ़ंक्शन कॉल करने की सुविधा देने वाले यूआरएल का उदाहरण
[{ "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
या कोई दूसरी कम वैल्यू इस्तेमाल करें. यह निर्देश देता है
ताकि गलत जानकारी को कम किया जा सके और ज़्यादा भरोसेमंद नतीजे जनरेट किए जा सकें.
एपीआई शुरू करना
अगर मॉडल किसी ऐसे फ़ंक्शन को शुरू करने का सुझाव देता है जो ऑर्डर भेजता है, तो या किसी डेटाबेस को अपडेट करने के गंभीर नतीजे हो सकते हैं, तो फ़ंक्शन को एक्ज़ीक्यूट करने से पहले उपयोगकर्ता को कॉल करें.