Vertex AI in Firebase SDK टूल का इस्तेमाल करके, अपने ऐप्लिकेशन से Gemini API को कॉल करते समय, आपके अनुरोध में कई पैरामीटर होते हैं. ये पैरामीटर, जनरेटिव एआई के जवाबों को कंट्रोल करते हैं. आम तौर पर, इनमें मॉडल का नाम, मॉडल जनरेशन कॉन्फ़िगरेशन (ज़्यादा से ज़्यादा टोकन, तापमान वगैरह), सुरक्षा सेटिंग, सिस्टम के निर्देश, और प्रॉम्प्ट डेटा शामिल होता है.
ज़्यादातर मामलों में, आपको इन सेटिंग को मांग पर या ज़रूरत के हिसाब से बदलना होगा. ऐसा कई मामलों में करना पड़ सकता है:
- नया ऐप्लिकेशन रिलीज़ किए बिना, जनरेटिव एआई मॉडल को अपडेट करें. पुराने वर्शन बंद होने से पहले, नए और बेहतर मॉडल के वर्शन पर अपग्रेड किया जा सकता है. इसके अलावा, उपयोगकर्ताओं की ज़रूरतों और एट्रिब्यूट के आधार पर, कम कीमत वाले या बेहतर परफ़ॉर्मेंस वाले मॉडल पर स्विच किया जा सकता है. इसके अलावा, खास उपयोगकर्ता सेगमेंट (जैसे, बीटा टेस्टर) के लिए, नए और बेहतर मॉडल को शर्तों के साथ डिप्लॉय किया जा सकता है.
- मॉडल को ऐक्सेस करने की जगह सेट करें, ताकि वह आपके उपयोगकर्ताओं के करीब हो.
- सिस्टम के अलग-अलग निर्देशों और प्रॉम्प्ट की A/B टेस्टिंग करें. इसके बाद, अपने उपयोगकर्ताओं के लिए, एक्सपेरिमेंट की सबसे अच्छी वैल्यू को धीरे-धीरे रोल आउट करें.
- अपने ऐप्लिकेशन में जनरेटिव एआई की सुविधाओं को तुरंत दिखाने या छिपाने के लिए, फ़ीचर फ़्लैग का इस्तेमाल करें.
Firebase Remote Config, इनके अलावा और भी काम करता है. इसकी मदद से, ज़रूरत के हिसाब से पैरामीटर वैल्यू अपडेट की जा सकती हैं. साथ ही, Firebase कंसोल में सेट की गई विशेषताओं से मैच करने वाले ऐप्लिकेशन इंस्टेंस के लिए, शर्त के मुताबिक पैरामीटर वैल्यू अपडेट की जा सकती हैं. इसके लिए, आपको अपने ऐप्लिकेशन का नया वर्शन रिलीज़ करने की ज़रूरत नहीं है.
इस गाइड में, इस्तेमाल के कुछ खास उदाहरण दिए गए हैं. साथ ही, जनरेटिव एआई ऐप्लिकेशन में Remote Config जोड़ने का तरीका भी बताया गया है.
अपने ऐप्लिकेशन के साथ Firebase Remote Config का इस्तेमाल क्यों करना चाहिए?
Firebase Remote Config की मदद से, ऐप्लिकेशन को अपडेट किए बिना, डाइनैमिक तरीके से ऐप्लिकेशन के काम करने के तरीके में बदलाव किया जा सकता है. यह सुविधा, जनरेटिव एआई का इस्तेमाल करने वाले ऐप्लिकेशन के लिए काफ़ी कारगर है. इन ऐप्लिकेशन में, तेज़ी से बदलाव करना और उन्हें बेहतर बनाना ज़रूरी होता है.
जनरेटिव एआई ऐप्लिकेशन के साथ Remote Config के इस्तेमाल के ज़रूरी उदाहरण
हमारा सुझाव है कि इस्तेमाल के इन ज़रूरी उदाहरणों के लिए, Remote Config के साथ Vertex AI in Firebase का इस्तेमाल करें:
- ऐप्लिकेशन अपडेट किए बिना, मॉडल के नए वर्शन पर अपग्रेड करना: ज़रूरत के हिसाब से मॉडल का नाम बदलने के लिए, Remote Config पैरामीटर का इस्तेमाल करें. इससे, अपने पसंदीदा Gemini मॉडल के नए वर्शन के उपलब्ध होने पर, उसे तुरंत अपग्रेड किया जा सकता है.
- ऐप्लिकेशन को अपडेट किए बिना, सिस्टम से जुड़े निर्देश और सुरक्षा सेटिंग अपडेट करें: सिस्टम से जुड़े निर्देश और सुरक्षा सेटिंग, Remote Config पैरामीटर में सेव करें. इससे यह पक्का किया जा सकेगा कि डिप्लॉयमेंट के बाद समस्याएं मिलने पर, ज़रूरत के हिसाब से इनमें बदलाव किया जा सकता है.
- जोखिम कम करना और एआई की सुरक्षा को लागू करना: अपने iOS और Android उपयोगकर्ताओं के लिए, जनरेटिव एआई से जुड़े बदलावों को सुरक्षित और धीरे-धीरे रिलीज़ करने के लिए, Remote Config रोल आउट का इस्तेमाल करें.
जनरेटिव एआई ऐप्लिकेशन के साथ, Remote Config के इस्तेमाल के बेहतर और सुझाए गए उदाहरण
Remote Config और Google Analytics की मदद से अपने ऐप्लिकेशन को इंस्ट्रूमेंट करने के बाद, ऐप्लिकेशन के इस्तेमाल के बेहतर उदाहरणों को एक्सप्लोर किया जा सकता है:
- क्लाइंट की जगह की जानकारी के आधार पर जगह की जानकारी सेट करना: क्लाइंट की पहचान की गई जगह के आधार पर, मॉडल की जगह की जानकारी सेट करने के लिए, Remote Configशर्तों का इस्तेमाल करें.
- अलग-अलग मॉडल आज़माना: जनरेटिव एआई के अलग-अलग मॉडल को तुरंत टेस्ट करें और उनमें स्विच करें. इसके अलावा, अपने खास इस्तेमाल के उदाहरण के लिए सबसे सही मॉडल चुनने के लिए, अलग-अलग उपयोगकर्ता सेगमेंट में अलग-अलग मॉडल डिप्लॉय करें.
- मॉडल की परफ़ॉर्मेंस को ऑप्टिमाइज़ करना: मॉडल के पैरामीटर को बेहतर बनाएं. जैसे, सिस्टम के प्रॉम्प्ट, ज़्यादा से ज़्यादा आउटपुट टोकन, तापमान, और अन्य सेटिंग.
क्लाइंट एट्रिब्यूट के आधार पर, सिस्टम के अलग-अलग निर्देशों, प्रॉम्प्ट, और मॉडल कॉन्फ़िगरेशन का इस्तेमाल करें: Google Analytics के साथ Remote Config का इस्तेमाल करते समय, क्लाइंट एट्रिब्यूट या कस्टम ऑडियंस के आधार पर शर्तें बनाई जा सकती हैं. साथ ही, इन एट्रिब्यूट के आधार पर अलग-अलग पैरामीटर सेट किए जा सकते हैं.
उदाहरण के लिए, अगर अपने ऐप्लिकेशन में तकनीकी सहायता देने के लिए जनरेटिव एआई का इस्तेमाल किया जा रहा है, तो हो सकता है कि आप ऐप्लिकेशन प्लैटफ़ॉर्म के हिसाब से सिस्टम के निर्देश सेट करना चाहें. इससे यह पक्का किया जा सकेगा कि Android, iOS, और वेब प्लैटफ़ॉर्म के उपयोगकर्ताओं को सटीक निर्देश दिए जाएं.
हर उपयोगकर्ता के लिए अनुभव को मनमुताबिक बनाएं: हर उपयोगकर्ता के लिए जनरेटिव एआई की सबसे सही सेटिंग अपने-आप तय करने के लिए, Remote Config उपयोगकर्ता के हिसाब से बनाने की सुविधा का इस्तेमाल करें.
लागत को कंट्रोल करना: रिमोट से यह तय करें कि कौनसे जनरेटिव एआई मॉडल इस्तेमाल किए जाएं और उनका इस्तेमाल कितनी बार किया जाए. साथ ही, ज़रूरत से ज़्यादा खर्च को कम करने के लिए, उपयोगकर्ता ऑडियंस के आधार पर, ज़्यादा से ज़्यादा आउटपुट टोकन वैल्यू को डाइनैमिक तौर पर कॉन्फ़िगर करें.
ऐप्लिकेशन के अनुभव और नतीजों को ऑप्टिमाइज़ करना: अपने iOS, Android, और Flutter ऐप्लिकेशन में, A/B Testing के साथ Remote Config का इस्तेमाल करें. इससे, अलग-अलग उपयोगकर्ता सेगमेंट में जनरेटिव एआई पैरामीटर में किए गए बदलावों की जांच की जा सकती है. इससे यह पता चलता है कि इन बदलावों का, उपयोगकर्ताओं के ऐप्लिकेशन में बने रहने और आय जैसी मुख्य मेट्रिक पर क्या असर पड़ता है.
Firebase Remote Config की मदद से, अपने जनरेटिव एआई ऐप्लिकेशन को इंस्ट्रूमेंट करके, एआई की मदद से काम करने वाले ऐसे ऐप्लिकेशन बनाए जा सकते हैं जो उपयोगकर्ताओं के लिए बेहतरीन अनुभव देते हों. साथ ही, ये ऐप्लिकेशन आसानी से इस्तेमाल किए जा सकते हैं, सुरक्षित हैं, और इनकी लागत कम होती है.
अपने ऐप्लिकेशन में Firebase Remote Config जोड़ना
समाधान वाली इस गाइड में, आपको Vertex AI in Firebase SDK टूल का इस्तेमाल करने वाले Android ऐप्लिकेशन में, पैरामीटर को डाइनैमिक तौर पर अपडेट करने के लिए Firebase Remote Config का इस्तेमाल करना होगा. आपको इनके बारे में जानकारी मिलेगी:
- Firebase Remote Config से मॉडल के नाम और सिस्टम के निर्देश जैसे पैरामीटर फ़ेच और चालू करें.
- डाइनैमिक तौर पर वापस पाए गए पैरामीटर का इस्तेमाल करने के लिए, अपने Gemini API कॉल अपडेट करें. इससे, ऐप्लिकेशन अपडेट किए बिना, अलग-अलग मॉडल के बीच स्विच किया जा सकता है या सिस्टम के निर्देशों में बदलाव किया जा सकता है.
- ज़रूरत के मुताबिक मॉडल के व्यवहार और क्षमताओं में बदलाव करके, पैरामीटर को रिमोट से कंट्रोल करें.
ज़रूरी शर्तें
इस गाइड में यह माना गया है कि आपको वेब ऐप्लिकेशन डेवलप करने के लिए, JavaScript का इस्तेमाल करने के बारे में पता है. यह गाइड, फ़्रेमवर्क पर निर्भर नहीं करती. शुरू करने से पहले, पक्का करें कि आपने ये काम पूरे कर लिए हों:
Vertex AI in Firebase एसडीके टूल के लिए शुरुआती निर्देश देखें. पक्का करें कि आपने ये सभी काम कर लिए हों:
- कोई नया या मौजूदा Firebase प्रोजेक्ट सेट अप करें. इसमें, ब्लेज़ प्राइसिंग प्लान का इस्तेमाल करना और ज़रूरी एपीआई चालू करना शामिल है.
- अपने ऐप्लिकेशन को Firebase से कनेक्ट करें. इसमें अपना ऐप्लिकेशन रजिस्टर करना और ऐप्लिकेशन में Firebase कॉन्फ़िगरेशन जोड़ना भी शामिल है.
- SDK टूल जोड़ें और अपने ऐप्लिकेशन में Vertex AI सेवा और जनरेटिव मॉडल को शुरू करें.
अपने प्रोजेक्ट में Google Analytics चालू करें और उसका एसडीके अपने ऐप्लिकेशन में जोड़ें. यह ज़रूरी है, ताकि क्लाइंट डिवाइस की जगह की जानकारी के आधार पर, सेवा और मॉडल की जगह की जानकारी सेट करने जैसी शर्त के हिसाब से टारगेटिंग की जा सके.
पहला चरण: Firebase कंसोल में पैरामीटर वैल्यू सेट करना
क्लाइंट Remote Config टेंप्लेट बनाएं और ऐप्लिकेशन में फ़ेच और इस्तेमाल करने के लिए, पैरामीटर और वैल्यू कॉन्फ़िगर करें.
- Firebase कंसोल खोलें और नेविगेशन मेन्यू में, रन करें को बड़ा करें और Remote Config को चुनें.
- पक्का करें कि Remote Config पेज में सबसे ऊपर दिए गए क्लाइंट/सर्वर सिलेक्टर में से क्लाइंट को चुना गया हो.
- अगर आपने Remote Config क्लाइंट टेंप्लेट का इस्तेमाल पहले कभी नहीं किया है, तो कॉन्फ़िगरेशन बनाएं पर क्लिक करें. आपको अपना पहला पैरामीटर बनाएं पैनल दिखेगा.
- अगर आपने पहले भी Remote Config टेंप्लेट का इस्तेमाल किया है, तो पैरामीटर जोड़ें पर क्लिक करें.
इन Remote Config पैरामीटर को तय करें:
पैरामीटर का नाम जानकारी टाइप डिफ़ॉल्ट वैल्यू model_name
मॉडल का नाम. अपने कोड में इस्तेमाल किए जाने वाले मॉडल के नामों की अप-टू-डेट सूचियां देखने के लिए, उपलब्ध मॉडल के नाम देखें. स्ट्रिंग gemini-1.5-flash
system_instructions
सिस्टम के निर्देश एक "प्रींबल" की तरह होते हैं, जिन्हें मॉडल के व्यवहार को प्रभावित करने से पहले जोड़ा जाता है. मॉडल को असल उपयोगकर्ता की ओर से कोई और निर्देश दिखाए जाने से पहले, खास ज़रूरतों और इस्तेमाल के उदाहरणों के आधार पर मॉडल के व्यवहार में बदलाव किया जाता है. स्ट्रिंग You are a helpful assistant who knows everything there is to know about Firebase!
prompt
जनरेटिव एआई की सुविधा के साथ इस्तेमाल करने के लिए डिफ़ॉल्ट प्रॉम्प्ट. स्ट्रिंग I am a developer who wants to know more about Firebase!
vertex_location
Vertex AI सेवा को चलाने और मॉडल को ऐक्सेस करने के लिए, जगह की जानकारी को कंट्रोल करें. हालांकि, ऐसा करना ज़रूरी नहीं है. Google Analytics की मदद से पता लगाई गई क्लाइंट की जगह के आधार पर, इस विकल्प को कॉन्फ़िगर करने के लिए शर्तें सेट की जा सकती हैं. स्ट्रिंग us-central1
पैरामीटर जोड़ने के बाद, बदलावों को पब्लिश करें पर क्लिक करें. अगर यह नया Remote Config टेंप्लेट नहीं है, तो बदलावों की समीक्षा करें और बदलावों को पब्लिश करें पर फिर से क्लिक करें.
दूसरा चरण: Remote Config SDK टूल जोड़ें और शुरू करें
Remote Config SDK टूल जोड़ें और उसे शुरू करें:
अपना कोड किसी टेक्स्ट एडिटर में खोलें और Remote Config इंपोर्ट करें:
import { getRemoteConfig } from 'firebase/remote-config';
आपके मुख्य फ़ंक्शन में और Vertex AI in Firebase SDK टूल के लिए Firebase ऐप्लिकेशन शुरू होने के बाद, Remote Config शुरू करें:
// Initialize Remote Config and get a reference to the service const remoteConfig = getRemoteConfig(app);
डेटा फ़ेच करने के लिए, कम से कम इंटरवल सेट करें. इस उदाहरण में, फ़ेच करने के लिए डिफ़ॉल्ट इंटरवल 3600 सेकंड है. हालांकि, हमारा सुझाव है कि डेवलपमेंट के दौरान, अपने कोड में फ़ेच करने के लिए कम से कम इंटरवल सेट करें.
remoteConfig.settings.minimumFetchIntervalMillis = 3600000;
तीसरा चरण: इन-ऐप्लिकेशन पैरामीटर वैल्यू सेट करना
आपको Remote Config ऑब्जेक्ट में, इन-ऐप्लिकेशन डिफ़ॉल्ट पैरामीटर वैल्यू सेट करनी चाहिए, ताकि Remote Config बैकएंड से कनेक्ट होने से पहले आपका ऐप्लिकेशन काम कर सके. साथ ही, क्लाइंट नेटवर्क के ऐक्सेस में रुकावट आने पर और/या बैकएंड पर कोई वैल्यू कॉन्फ़िगर न होने पर भी वह काम कर सके.
इस उदाहरण में, मॉडल के नाम, सिस्टम के निर्देशों, उपयोगकर्ता के प्रॉम्प्ट, और Vertex AI की जगह के लिए, मैन्युअल रूप से डिफ़ॉल्ट वैल्यू सेट की गई हैं:
// Set default Remote Config parameter values
remoteConfig.defaultConfig = {
model_name: 'gemini-1.5-flash',
system_instructions:
'You are a helpful assistant who knows everything there is to know about Firebase!',
prompt: 'I am a developer who wants to know more about Firebase!',
vertex_location: 'us-central1',
};
चौथा चरण: वैल्यू फ़ेच करना और उन्हें चालू करना
अपने इंपोर्ट में
getValue
औरfetchAndActivate
जोड़ें:import { getValue, fetchAndActivate } from 'firebase/remote-config';
Remote Config की डिफ़ॉल्ट वैल्यू को कॉन्फ़िगर करने के लिए जोड़े गए कोड के बाद, कॉन्फ़िगरेशन को फ़ेच और चालू करें. इसके बाद,
modelName
,systemInstructions
,prompt
, औरvertexLocation
कॉन्सटेंट के लिए वैल्यू असाइन करें.// Fetch and activate Remote Config. try { await fetchAndActivate(remoteConfig); } catch(err) { console.error('Remote Config fetch failed', err); } console.log('Remote Config fetched.'); // Assign Remote Config values. const modelName = getValue(remoteConfig, 'model_name').asString(); const systemInstructions = getValue(remoteConfig, 'system_instructions').asString(); const prompt = getValue(remoteConfig, 'prompt').asString(); const vertexLocation = getValue(remoteConfig, 'vertex_location').asString();
पांचवां चरण: Remote Config वैल्यू का इस्तेमाल करने के लिए, Vertex AI कॉल को अपडेट करना
अब Remote Config पूरी तरह से कॉन्फ़िगर हो गया है. इसलिए, अपने कोड को अपडेट करें, ताकि हार्ड कोड की गई वैल्यू को Remote Config से ली गई वैल्यू से बदला जा सके. उदाहरण के लिए, Firebase SDK टूल में Vertex AI का इस्तेमाल करके Gemini API का इस्तेमाल शुरू करने में इस्तेमाल किए गए उदाहरण का इस्तेमाल करने पर, आपको इसे इस तरह से अपडेट करना होगा:
// Initialize FirebaseApp
const firebaseApp = initializeApp(firebaseConfig);
// Initialize the Vertex AI service
// Optionally specify a location in which to run the service and access the model
const vertexAI = getVertexAI(firebaseApp, { location: vertexLocation });
// Initialize the generative model with a model that supports your use case
// Gemini 1.5 models are versatile and can be used with all API capabilities
const model = getGenerativeModel(vertexAI, {
model: modelName,
systemInstruction: systemInstruction
});
// Wrap in an async function so you can use await
async function run() {
// Provide a prompt that contains text
const userPrompt = prompt;
// To generate text output, call generateContent with the text input
const result = await model.generateContent(userPrompt);
const response = result.response;
const text = response.text();
console.log(text);
}
छठा चरण: ऐप्लिकेशन चलाना
ऐप्लिकेशन चलाएं और पुष्टि करें कि वह काम कर रहा है. Firebase कंसोल में Remote Config पेज पर जाकर, अपने कॉन्फ़िगरेशन में बदलाव करें. इसके बाद, बदलावों को पब्लिश करें और नतीजे की पुष्टि करें.
अगले चरण
- Remote Config के बारे में और जानें.
- टारगेटिंग चालू करने के लिए, अपने कोड में Google Analytics जोड़ें.