अनुरोध प्रोसेस करें
संग्रह की मदद से व्यवस्थित रहें
अपनी प्राथमिकताओं के आधार पर, कॉन्टेंट को सेव करें और कैटगरी में बांटें.
Google, आपके ऐप्लिकेशन को बिड का अनुरोध भेजता है. इसके बाद, रीयल-टाइम बिडिंग इंटरैक्शन शुरू होता है. इस गाइड में, बिड के अनुरोध को प्रोसेस करने के लिए, अपने ऐप्लिकेशन को कोड करने का तरीका बताया गया है.
पार्स करने का अनुरोध
Google, OpenRTB JSON या Protobuf फ़ॉर्मैट में क्रम से लगाई गई बिड रिक्वेस्ट भेजता है. इसे एचटीटीपी पोस्ट अनुरोध के पेलोड के तौर पर अटैच किया जाता है. आपको किस फ़ॉर्मैट में डेटा मिलेगा, यह आपके एंडपॉइंट के कॉन्फ़िगरेशन पर निर्भर करता है. उदाहरण के लिए, बिड अनुरोध का उदाहरण देखें.
सीरियलाइज़ किए गए BidRequest को पाने के लिए, आपको इस अनुरोध को पार्स करना होगा. अगर Protobuf फ़ॉर्मैट का इस्तेमाल किया जा रहा है, तो आपको रेफ़रंस डेटा पेज से openrtb.proto और openrtb-adx.proto डाउनलोड करने होंगे. इसके बाद, इनका इस्तेमाल करके एक ऐसी लाइब्रेरी जनरेट करनी होगी जिसका इस्तेमाल BidRequest मैसेज को पार्स करने के लिए किया जा सकता है. उदाहरण के लिए, यहां दिया गया C++ कोड, स्ट्रिंग में दिए गए POST पेलोड से अनुरोध को पार्स करता है:
BidRequest मिलने के बाद, इसे ऑब्जेक्ट के तौर पर इस्तेमाल किया जा सकता है. साथ ही, इसमें से अपनी ज़रूरत के हिसाब से फ़ील्ड निकाले जा सकते हैं और उनकी व्याख्या की जा सकती है. उदाहरण के लिए, C++ में OpenRTB `BidRequest` में डील को दोहराने का तरीका यहां दिया गया है:
आपको बिड का अनुरोध तब मिलता है, जब पब्लिशर की विज्ञापन इन्वेंट्री को आपके एक या उससे ज़्यादा
प्रीटारगेटिंग कॉन्फ़िगरेशन से टारगेट किया जाता है. BidRequest.imp.ext.billing_id
फ़ील्ड में, ज़रूरी शर्तें पूरी करने वाले खरीदारों के बिलिंग आईडी और
प्रीटारगेटिंग के काम के कॉन्फ़िगरेशन की जानकारी अपने-आप भर जाएगी. इसके अलावा, डील वाली इन्वेंट्री के लिए, BidRequest.imp.pmp.deal.ext.billing_id का इस्तेमाल करके, खरीदारों से जुड़े बिलिंग आईडी ढूंढे जा सकते हैं. बिड करते समय, बिड के अनुरोध में शामिल खरीदारों के सिर्फ़ बिलिंग आईडी दिए जा सकते हैं.
अगर बिड अनुरोध में एक से ज़्यादा बिलिंग आईडी शामिल हैं, तो आपको BidResponse.seatbid.bid.ext.billing_id फ़ील्ड का इस्तेमाल करके, उस खरीदार का बिलिंग आईडी बताना होगा जिसे आपको अपनी बिड एट्रिब्यूट करनी है.
imp {
ext {
// The billing IDs of all of your matching pretargeting configs and eligible child seats are
// stored in a flat list here.
billing_id: 123
billing_id: 456
billing_id: 789
}
pmp {
// All eligible deals are stored in a single flat list.
deal {
id: 1000
ext {
// The specific billing IDs eligible to bid on this deal are indicated here.
billing_id: 789
}
...
}
deal {
id: 2000
ext {
billing_id: 123
billing_id: 456
}
...
}
}
...
}
...
ब्लॉक की गई कैटगरी का पता लगाना
बिड लगाते समय, शामिल किए गए क्रिएटिव में ऐसी कैटगरी का पता नहीं चलना चाहिए जिन्हें पब्लिशर ने ब्लॉक किया है. ऐसा न होने पर, बिड को नीलामी से फ़िल्टर कर दिया जाता है.
किसी इंप्रेशन के लिए ब्लॉक की गई कैटगरी देखने के लिए, BidRequest.bcat फ़ील्ड की समीक्षा करें. इस फ़ील्ड में, आपके खाते के लिए कॉन्फ़िगर की गई टैक्सोनॉमी की कैटगरी शामिल होती हैं.
यहां दिए गए उदाहरण में, कॉन्फ़िगर की गई विज्ञापन कैटगरी के टैक्सोनॉमी के आधार पर ब्लॉक की गई कैटगरी दिखाई गई हैं:
IAB कॉन्टेंट टैक्सनॉमी 1.0
// Bid request{// Indicates the blocked categories using IAB Content 1.0 Taxonomy."bcat":["IAB9-9",// Cigars"IAB8-18"// Wine]"imp":{...}}
Google विज्ञापन कैटगरी की टैक्सोनॉमी
// Bid request{// Indicates the blocked categories using Google Ad Category Taxonomy."bcat":["10138",// Cigar and tobacco collecting"10080",// Tobacco"11649",// Wine"10674",// Wine collecting"13008"// Wine clubs]"imp":{...}}
डिक्शनरी फ़ाइलें
बिड अनुरोध में, डिक्शनरी फ़ाइलों में तय किए गए आइडेंटिफ़ायर का इस्तेमाल किया जाता है. ये आइडेंटिफ़ायर, रेफ़रंस डेटा पेज पर उपलब्ध होते हैं.
बिडर के यूआरएल मैक्रो
इसके अलावा, BidRequest से मिली कुछ जानकारी को मैक्रो का इस्तेमाल करके, बिडिंग एंडपॉइंट यूआरएल में डाला जा सकता है. हालांकि, ऐसा करना ज़रूरी नहीं है. अगर आपने एक या उससे ज़्यादा मैक्रो के साथ कोई एंडपॉइंट यूआरएल कॉन्फ़िगर किया है, तो बिड अनुरोध में मौजूद जानकारी के आधार पर उन्हें बड़ा किया जाएगा. यह फ़ायदेमंद हो सकता है. उदाहरण के लिए, अगर आपको BidRequest में मौजूद जानकारी के आधार पर लोड बैलेंसिंग करनी है.
नए मैक्रो के लिए सहायता पाने का अनुरोध करने के लिए, अपने खाता मैनेजर से संपर्क करें.
मैक्रो
ब्यौरा
%%GOOGLE_USER_ID%%
इसे BidRequest.user.id में मौजूद Google यूज़र आईडी से बदल दिया गया है. उदाहरण के लिए, बिडर यूआरएल http://google.bidder.com/path?gid=%%GOOGLE_USER_ID%% को अनुरोध के समय http://google.bidder.com/path?gid=dGhpyBhbiBleGFtGxl से बदल दिया जाएगा.
अगर Google User ID की जानकारी नहीं है, तो खाली स्ट्रिंग को बदल दिया जाता है. इसका नतीजा,
http://google.bidder.com/path?gid=
%%HAS_MOBILE%%
इसे 1 से बदल दिया जाता है. इससे पता चलता है कि बिड का अनुरोध किसी मोबाइल डिवाइस से किया गया है. अगर ऐसा नहीं है, तो इसे 0 से बदल दिया जाता है. यह BidRequest.device.devicetype की वैल्यू पर आधारित होता है. इसमें मोबाइल डिवाइसों को HIGHEND_PHONE (4) या Tablet (5) से दिखाया जाता है.
%%HAS_VIDEO%%
1 से बदल दिया जाता है, ताकि यह पता चल सके कि बिड अनुरोध में वीडियो इन्वेंट्री शामिल है. अगर ऐसा नहीं है, तो 0 से बदल दिया जाता है. यह इस बात पर निर्भर करता है कि बिड अनुरोध में BidRequest.imp.video की जानकारी मौजूद है या नहीं.
%%IS_CTV%%
इसे 1 से बदल दिया जाता है. इससे पता चलता है कि बिड का अनुरोध किसी सीटीवी डिवाइस से किया गया है. अगर ऐसा नहीं है, तो इसे 0 से बदल दिया जाता है. यह BidRequest.device.devicetype की वैल्यू पर आधारित होता है. Protobuf के लिए, सीटीवी डिवाइस CONNECTED_TV, CONNECTED_DEVICE या SET_TOP_BOX होते हैं. ये JSON के लिए, पूर्णांक वैल्यू 3, 6 या 7 से मेल खाते हैं.
%%HOSTED_MATCH_DATA%%
BidRequest.user.buyeruid के आधार पर वैल्यू से बदल दिया जाता है.
%%MOBILE_IS_APP%%
इसे 1 से बदल दिया गया है. इससे पता चलता है कि बिड का अनुरोध मोबाइल ऐप्लिकेशन की इन्वेंट्री के लिए है या 0 के लिए. यह इस बात पर निर्भर करता है कि BidRequest.app फ़ील्ड में वैल्यू मौजूद है या नहीं.
लेन-देन के यूआरएल से मोबाइल ऐप्लिकेशन का आईडी ढूंढना
मोबाइल ऐप्लिकेशन के लेन-देन, इस तरह के यूआरएल रिपोर्ट करेंगे:
mbappgewtimrzgyytanjyg4888888.com
बोल्ड किए गए स्ट्रिंग के हिस्से को डिकोड करने के लिए, बेस-32 डिकोडर का इस्तेमाल करें
(gewtimrzgyytanjyg4888888).
ऑनलाइन डिकोडर का इस्तेमाल किया जा सकता है. हालांकि, आपको अक्षरों को कैपिटल करना होगा और आखिर में मौजूद 8 को = वैल्यू से बदलना होगा.
इसलिए, इस वैल्यू को डिकोड करने पर:
GEWTIMRZGYYTANJYG4======
नतीजे:
1-429610587
स्ट्रिंग 429610587, iOS ऐप्लिकेशन iFunny का आईडी है.
यहां एक और उदाहरण दिया गया है. शिकायत किया गया यूआरएल यह है:
mbappgewtgmjug4ytmmrtgm888888.com
इस वैल्यू को डिकोड करने पर:
GEWTGMJUG4YTMMRTGM======
नतीजे:
1-314716233
नतीजा 314716233, iOS ऐप्लिकेशन TextNow का ऐप्लिकेशन आईडी है.
लेन-देन के यूआरएल से मोबाइल ऐप्लिकेशन का नाम ढूंढना
यहां ऐप्लिकेशन का नाम पाने का एक उदाहरण दिया गया है. जिस यूआरएल की शिकायत की गई है वह यह है:
यह नतीजा, Android ऐप्लिकेशन slither.io के बराबर है.
ओपन बिडिंग फ़ील्ड
ओपन बिडिंग में हिस्सा लेने वाले एक्सचेंज और नेटवर्क बिडर को भेजे गए बिड अनुरोध, स्टैंडर्ड रीयल-टाइम बिडिंग में हिस्सा लेने वाले Authorized Buyers को भेजे गए बिड अनुरोधों की तरह ही होते हैं. Open Bidding का इस्तेमाल करने वाले ग्राहकों को कुछ अतिरिक्त फ़ील्ड मिलेंगे. साथ ही, कुछ मौजूदा फ़ील्ड का इस्तेमाल अलग-अलग कामों के लिए किया जा सकेगा. इनमें ये शामिल हैं:
OpenRTB
विवरण
BidRequest.imp.ext.dfp_ad_unit_code
इसमें पब्लिशर का Ad Manager नेटवर्क कोड होता है. इसके बाद, विज्ञापन यूनिट का क्रम होता है. इन्हें फ़ॉरवर्ड स्लैश से अलग किया जाता है.
उदाहरण के लिए, यह इस तरह के फ़ॉर्मैट में दिखेगा:
/1234/cruises/mars.
BidRequest.user.data.segment
पब्लिशर से एक्सचेंज बिडर को बार-बार भेजे गए की-वैल्यू पेयर.
यह तय किया जा सकता है कि वैल्यू, पब्लिशर की ओर से भेजे गए की-वैल्यू पेयर हैं. ऐसा तब होता है, जब BidRequest.user.data.name को “Publisher Passed” पर सेट किया जाता है.
अनुमति पा चुके वेंडर के बारे में जानकारी देना
टेक्नोलॉजी वेंडर, खरीदारों और सेलर के बीच इंटरैक्शन में अहम भूमिका निभा सकते हैं. ये वेंडर, रिसर्च, रीमार्केटिंग, और विज्ञापन दिखाने जैसी सेवाएं देते हैं. सिर्फ़ उन वेंडर को अनुमति है जिनकी Google ने Authorized Buyers के साथ इंटरैक्शन करने के लिए जांच की है.
BidRequest को समझने और अपना BidRequest बनाने के लिए, आपको टेक्नोलॉजी वेंडर के बारे में जानकारी देने के दो अलग-अलग तरीकों के बारे में पता होना चाहिए:BidResponse
अन्य वेंडर सिर्फ़ तब हिस्सा ले सकते हैं, जब उन्हें BidRequest में शामिल किया गया हो:
BidRequest में, BidRequest.imp.ext.allowed_vendor_type फ़ील्ड से पता चलता है कि सेलर ने किन वेंडर को अनुमति दी है. allowed_vendor_type में भेजे जाने वाले वेंडर, vendors.txt डिक्शनरी फ़ाइल में मौजूद होते हैं.
बिड अनुरोध का उदाहरण
यहां Protobuf और JSON अनुरोधों के ऐसे उदाहरण दिए गए हैं जिन्हें कोई भी व्यक्ति आसानी से पढ़ सकता है.
बिड अनुरोध को बाइनरी फ़ॉर्म में बदलने के लिए, यहां दिया गया तरीका अपनाएं. इससे आपको असली अनुरोध में POST पेलोड मिलेगा. यह तरीका C++ में उपलब्ध है. हालांकि, ध्यान दें कि यह OpenRTB JSON पर लागू नहीं होता.
रीयल-टाइम फ़ीडबैक, Authorized Buyers के साथ-साथ ओपन बिडिंग का इस्तेमाल करने वाले एक्सचेंज और नेटवर्क के लिए भी उपलब्ध है.
रीयल-टाइम फ़ीडबैक, BidRequest.ext.bid_feedback के आधार पर तैयार होता है. यह फ़ीडबैक, आपकी पिछली एक या उससे ज़्यादा बिड के नतीजे के आधार पर तैयार होता है. इसका इस्तेमाल, यह जानने के लिए किया जा सकता है कि बिड ने नीलामी जीती या नहीं. साथ ही, यह भी पता लगाया जा सकता है कि नीलामी जीतने के लिए कम से कम कितनी बिड की ज़रूरत थी. रीयल-टाइम में मिलने वाली प्रतिक्रिया की सुविधा चालू करने के लिए, अपने खाता मैनेजर से संपर्क करें.
बिड रिस्पॉन्स फ़ीडबैक में भेजे गए डिफ़ॉल्ट फ़ील्ड के अलावा, BidResponse.seatbid.bid.ext.event_notification_token फ़ील्ड का इस्तेमाल करके बिड रिस्पॉन्स में कस्टम डेटा भी भेजा जा सकता है. event_notification_token एक ऐसा डेटा है जिसके बारे में सिर्फ़ बिडर को पता होता है. इससे डीबग करने में मदद मिल सकती है. उदाहरण के लिए: नया टारगेटिंग आईडी या नई रणनीति को दिखाने वाला बिडिंग आईडी या क्रिएटिव से जुड़ा मेटाडेटा, जिसके बारे में सिर्फ़ बिडर को पता होता है. ज़्यादा जानकारी के लिए, OpenRTB एक्सटेंशन प्रोटोकॉल बफ़र फ़ाइल देखें.
जब Authorized Buyers, बिड करने वाले व्यक्ति या कंपनी को बिड अनुरोध भेजता है, तो बिडर BidResponse के साथ जवाब देता है. अगर बिडर ने रीयल-टाइम फ़ीडबैक की सुविधा चालू की है, तो Authorized Buyers, बिड के अगले अनुरोध में BidFeedback मैसेज में जवाब के बारे में फ़ीडबैक भेजता है:
messageBidFeedback{//TheuniqueidfromBidRequest.id.optionalstringrequest_id=1;//Thestatuscodeforthead.Seecreative-status-codes.txtinthe//technicaldocumentationforalistofids.optionalint32creative_status_code=2;//Deprecated.ThisfieldisnotpopulatedandwillberemovedafterMarch,//2025.Ifthebidwontheauction,thisisthepricepaidinyouraccount//currency.Ifthebidparticipatedintheauctionbutwasout-bid,this//istheCPMthatshouldhavebeenexceededinordertowin.Thisisnot//setifthebidwasfilteredpriortotheauction,ifthepublisheror//winningbidderhasoptedoutofpricefeedbackorifyouraccounthas//optedoutofsharingwinningpriceswithotherbidders.Forfirst-price//auctions,minimum_bid_to_winispopulatedinsteadofthisfield.optionaldoubleprice=3[deprecated=true];//Theminimumbidvaluenecessarytohavewontheauction,inyouraccount//currency.Ifyourbidwontheauction,thisisthesecondhighestbid//thatwasnotfiltered(includingthefloorprice).Ifyourbiddidn't win//theauction,thisisthewinningcandidate's bid. This field will only be//populatedifyourbidparticipatedinafirst-priceauction,andwillnot//bepopulatedifyourbidwasfilteredpriortotheauction.optionaldoubleminimum_bid_to_win=6;//Billableeventratemultiplierthatwasappliedtothisbidduring//ranking.Theadjustmentreflectsthelikelihoodthatyourbidwould//generateabillableevent(namely,theadrenderssuccessfully)ifitwon//theauction,relativetotheprobabilitythatotherbidsgeneratea//billableeventiftheywontheauction.Thisadjustmentcanbelargeror//smallerthan1.Thisaffectsthefinalrankingintheauctiononly;in//particular,thismultiplierdoesnotaffectthepaymentorwhetherthe//bidclearsanyfloorprice.optionalfloatbillable_event_rate_bid_adjustment=13[default=1];//WhenapublisherusesanRTBauctionandwaterfall-basedSDKmediationon//thesamequery,thewinnerofthereal-timeauctionmustalsocompetein//amediationwaterfall(whichisorderedbyprice)towintheimpression.//Ifthebidparticipatedintheauctionandtherewasnowaterfall,the//valueofthisfieldis0.Ifthebidparticipatedintheauctionand//therewasawaterfall,thevalueofthisfieldisapricerepresentinga//samplebidfromtheeligiblemediationnetworksthatwerehigherthanthe//auctionwinner,weightedbyexpectedfillrate.Thisfieldcanbeused//inconjunctionwithminimum_bid_to_wintotrainbiddingmodels.TheCPM//isinyouraccountcurrency.optionaldoublesampled_mediation_cpm_ahead_of_auction_winner=8;messageEventNotificationToken{//Thecontentsofthetoken.optionalstringpayload=1;}//Thetokenincludedinthecorrespondingbid.optionalEventNotificationTokenevent_notification_token=4;//ThecreativeIDincludedinthecorrespondingbid.optionalstringbuyer_creative_id=5;}
इस मैसेज में, आपको सबसे पहले bid_feedback.creative_status_code फ़ील्ड की जांच करनी चाहिए. आपको
creative-status-codes.txt में कोड का मतलब मिल सकता है. ध्यान दें कि बिड जीतने पर, कीमत के बारे में मिले सुझावों से ऑप्ट आउट किया जा सकता है. ज़्यादा जानकारी के लिए, ऑप्ट-आउट करने का तरीका लेख पढ़ें.
रीयल-टाइम में मिलने वाले सुझाव, शिकायत या राय में बिड अनुरोध आईडी और इनमें से कोई एक जानकारी शामिल होती है:
नीलामी का नतीजा
रीयल-टाइम में सुझाव, राय या शिकायतें पाना
खरीदार ने बिड सबमिट नहीं की है.
कुछ नहीं.
खरीदार ने ऐसी बिड सबमिट की थी जिसे नीलामी तक पहुंचने से पहले ही फ़िल्टर कर दिया गया था.
फ़र्स्ट-प्राइस ऑक्शन में बिड लगाने के बाद, आपको रीयल-टाइम में सुझाव मिलेंगे. अगर बिड को ऑक्शन से फ़िल्टर नहीं किया गया है, तो आपको minimum_bid_to_win और sampled_mediation_cpm_ahead_of_auction_winner फ़ील्ड भी दिखेंगे. इन सिग्नल का इस्तेमाल करके, बोली लगाने के लॉजिक को यह जानकारी दी जा सकती है कि इंप्रेशन जीतने के लिए, आपकी बिड कितनी ज़्यादा या कम हो सकती थी.
minimum_bid_to_win: रीयल-टाइम बिडिंग की नीलामी जीतने के लिए, कम से कम इतनी बिड लगानी ज़रूरी थी. अगर आपने नीलामी जीत ली है, तो यह वह सबसे कम बिड होगी जिसे लगाकर भी आपको जीत मिल सकती थी. अगर आपकी बिड नीलामी में नहीं जीती है, तो यह जीतने वाली बिड होगी.
sampled_mediation_cpm_ahead_of_auction_winner: अगर मीडिएशन चेन में अन्य नेटवर्क मौजूद हैं, तो इस फ़ील्ड की वैल्यू एक ऐसी कीमत होती है जो ज़रूरी शर्तें पूरी करने वाले किसी ऐसे मीडिएशन नेटवर्क की सैंपल बिड को दिखाती है जिसने नीलामी जीतने वाले नेटवर्क से ज़्यादा बिड की थी. इस कीमत को अनुमानित फ़िल रेट के हिसाब से तय किया जाता है. अगर मीडिएशन चेन में मौजूद किसी भी नेटवर्क से विज्ञापन नहीं मिलने की उम्मीद है या पब्लिशर एसडीके मीडिएशन का इस्तेमाल नहीं करता है, तो इसे 0 पर सेट किया जाएगा.
यह कैसे काम करता है
minimum_bid_to_win और sampled_mediation_cpm_ahead_of_auction_winner के लिए संभावित वैल्यू तय करने के लिए इस्तेमाल की गई कैलकुलेशन के बारे में बताने से पहले, हमें यहां दी गई जानकारी देनी होगी:
यहां मीडिएशन चेन में सीपीएम को घटते क्रम में दिखाया गया है:
\[C_1, C_2, …, C_n\]
यहां मीडिएशन चेन में सीपीएम के लिए, विज्ञापन इन्वेंट्री भरने की दर दिखाई गई है:
\[f_1, f_2, …, f_n\]
यहां दिया गया फ़ंक्शन, मीडिएशन चेन एलिमेंट \(i\)से अनुमानित सीपीएम और उसकी संभावना का पता लगाने के लिए इस्तेमाल किया जाता है. यह फ़ंक्शन, दिए गए फ़िल रेट के आधार पर काम करता है:
\(X_i = \{C_i\) with probability \(f_i\); \(0\) with probability \(1 - f_i\}\)
मीडिएशन की आखिरी चेन यह होगी:
\[\{C_1, C_2, …, C_K, W\}\]
जहां \(W\) विजेता बिड है और \(C_K > W >= C_{K+1}\)
रिज़र्व कीमत या फ़्लोर प्राइस को \(F\)के तौर पर दिखाया जाता है.
दूसरे नंबर पर सबसे ज़्यादा बोली लगाने वाले व्यक्ति की बोली को \(R\)के तौर पर दिखाया जाता है.
नीलामी जीतने वाले व्यक्ति के लिए कैलकुलेशन
फ़ील्ड
कैलकुलेशन
minimum_bid_to_win
\(max\{F, R, X_{K+1}, …, X_n\}\)
sampled_mediation_cpm_ahead_ of_auction_winner
\(\{C_i\) की संभावना है \(\prod_{j=1}^{i-1}(1-f_j) \cdot f_i \div \prod_{j=1}^{K}(1-f_j)\}\)
\(1 <= i <= K\)के लिए.
नीलामी हारने वाले व्यक्ति के लिए कैलकुलेशन
फ़ील्ड
कैलकुलेशन
minimum_bid_to_win
\(max\{F, W\}\)
sampled_mediation_cpm_ahead_ of_auction_winner
\(max\{X_1, …, X_K\}\)
सामान्य मीडिएशन चेन का उदाहरण
मान लें कि कोई पब्लिशर, रीयल-टाइम बिडिंग और एसडीके मीडिएशन चेन, दोनों का इस्तेमाल इस तरह करता है:
एसडीके मीडिएशन चेन
अनुमानित सीपीएम
फ़िल रेट
नेटवर्क 1
\(C_1 = $3.00\)
\(f_1 = 5\%\)
नेटवर्क 2
\(C_2 = $2.00\)
\(f_2 = 45\%\)
नेटवर्क 3
\(C_3 = $0.50\)
\(f_3 = 80\%\)
नेटवर्क 4
\(C_4 = $0.10\)
\(f_4 = 85\%\)
मान लें कि आरटीबी नीलामी के नतीजे इस तरह हैं:
आरटीबी नीलामी
सीपीएम
नीलामी जीतने वाला (W)
1.00 डॉलर
नीलामी में दूसरे नंबर पर रहा विज्ञापन (R)
0.05 डॉलर
कम से कम कीमत (F)
$0
नीलामी जीतने वाली बिड
यहां एक उदाहरण दिया गया है. इसमें बताया गया है कि जीतने वाली बिड के लिए, minimum_bid_to_win और sampled_mediation_cpm_ahead_of_auction_winner की वैल्यू और प्रायिकताएं कैसे कैलकुलेट की जाती हैं.
यहां एक उदाहरण दिया गया है. इसमें बताया गया है कि जिन बोलियों को स्वीकार नहीं किया गया उनके लिए, minimum_bid_to_win और sampled_mediation_cpm_ahead_of_auction_winner की वैल्यू और प्रायिकताएं कैसे कैलकुलेट की जाती हैं.
minimum_bid_to_win
प्रॉबेबिलिटी
\(max(F, W) = $1.00\)
\(100\%\)
sampled_mediation_cpm_ ahead_of_auction_winner
प्रॉबेबिलिटी
\(C_1 = $3.00\)
\(f_1 = 5\%\)
\(C_2 = $2.00\)
\((1-f_1) \cdot f_2 =~ 42.8\%\)
\(0\)
\((1-f_1) \cdot (1-f_2) =~ 52.2\%\)
बिड को फ़्लैट करना
बिड फ़्लैटनिंग का मतलब है कि एक जटिल BidRequest को प्रोसेस करके, कई बिड अनुरोधों में बदला जाता है. ये अनुरोध आपके ऐप्लिकेशन को भेजे जाते हैं. बिड अनुरोध को फ़्लैट करने पर, यह पता लगाया जा सकता है कि कौनसी बिड रिक्वेस्ट, ओरिजनल बिड रिक्वेस्ट का हिस्सा थीं. ऐसा इसलिए, क्योंकि BidRequest.ext.google_query_id फ़ील्ड में उनकी वैल्यू एक जैसी होगी.
बिड फ़्लैटनिंग की सुविधा डिफ़ॉल्ट रूप से चालू होती है. हालांकि, इसे बंद करने के लिए अपने खाता मैनेजर से संपर्क किया जा सकता है.
विज्ञापन फ़ॉर्मैट
विज्ञापन दिखाने के कुछ अवसरों के लिए, एक से ज़्यादा फ़ॉर्मैट स्वीकार किए जा सकते हैं. बिड फ़्लैटनिंग की मदद से, हर फ़ॉर्मैट को अलग बिड अनुरोध में भेजा जाता है. इसमें, अनुरोध में बताए गए फ़ॉर्मैट के लिए ज़रूरी एट्रिब्यूट शामिल होते हैं. जैसे, ज़रूरी बिलिंग आईडी.
इन फ़ॉर्मैट वाली बिड रिक्वेस्ट को अलग-अलग बिड रिक्वेस्ट में फ़्लैट किया जाएगा:
बैनर
वीडियो
ऑडियो
मूल भाषा वाला
विज्ञापन फ़ॉर्मैट को छोटा करने का उदाहरण
यहां एक उदाहरण दिया गया है, जिसमें विज्ञापन फ़ॉर्मैट को छोटा किए बिना, OpenRTB JSON बिड अनुरोध को आसान तरीके से दिखाया गया है. इसकी तुलना, छोटे किए गए अनुरोधों के बराबर सेट से की गई है:
किसी बिडर के लिए विज्ञापन दिखाने का अवसर, ओपन ऑक्शन के अलावा अलग-अलग तरह की डील पर भी लागू हो सकता है. डील के लिए बिड फ़्लैटनिंग की सुविधा का इस्तेमाल करने पर, ओपन ऑक्शन के लिए एक बिड अनुरोध भेजा जाएगा. साथ ही, तय कीमत वाली हर डील के लिए एक बिड अनुरोध भेजा जाएगा. असल में, विज्ञापन से जुड़ी पाबंदियां, नीलामी और तय कीमत वाली डील के टाइप के हिसाब से अलग-अलग हो सकती हैं. उदाहरण के लिए, अगर कोई वीडियो विज्ञापन दिखाने का मौका, ओपन ऑक्शन और तय कीमत वाली डील, दोनों के लिए उपलब्ध है, तो बिडर को हर डील के लिए अलग-अलग बिड अनुरोध मिलेंगे. इनमें विज्ञापन की ज़्यादा से ज़्यादा अवधि और स्किप किए जा सकने वाले विज्ञापनों को अनुमति है या नहीं, जैसी पाबंदियां अलग-अलग हो सकती हैं. इस वजह से, विज्ञापन के अवसर पर फ़्लैटनिंग लागू करने से, आपको ओपन ऑक्शन और तय कीमत वाली डील के लिए विज्ञापन से जुड़ी पाबंदियों के बारे में आसानी से पता चल जाता है.
स्किप करने की सुविधा और वीडियो की अवधि
OpenRTB स्पेसिफ़िकेशन में, स्किप किए जा सकने वाले और स्किप न किए जा सकने वाले विज्ञापनों की ज़्यादा से ज़्यादा अवधि बताने के लिए अलग-अलग फ़ील्ड नहीं होते. Google के लागू करने के तरीके में, बिड फ़्लैटनिंग का इस्तेमाल किया जाता है. इससे मौजूदा BidRequest.video.maxduration और BidRequest.video.skip फ़ील्ड का इस्तेमाल करके, इन दोनों के बीच अंतर किया जाता है.
यहां दिए गए उदाहरण में बताया गया है कि स्किप न किए जा सकने वाले विज्ञापन की ज़्यादा से ज़्यादा अवधि 15 और स्किप किए जा सकने वाले विज्ञापन की ज़्यादा से ज़्यादा अवधि 60 होने पर, वीडियो इन्वेंट्री को कैसे फ़्लैट किया जाता है.
उदाहरण
max_ad_duration
skip (सही या गलत)
बिना फ़्लैट किए गए मूल अनुरोध
15
true
फ़्लैटेंड अनुरोध #1: स्किप नहीं किया जा सकता
15
false
फ़्लैट किया गया दूसरा अनुरोध: स्किप किया जा सकने वाला
60
true
स्किप किए जा सकने वाले वीडियो की अवधि के लिए बिड अनुरोध फ़्लैटनिंग की सुविधा सिर्फ़ तब काम करेगी, जब ये शर्तें पूरी की गई हों:
अनुरोध में वीडियो शामिल करने की अनुमति है.
इसमें स्किप किए जा सकने वाले और स्किप न किए जा सकने वाले, दोनों तरह के वीडियो दिखाए जा सकते हैं. साथ ही, दोनों की ज़्यादा से ज़्यादा अवधि अलग-अलग होती है.
यह अनुरोध, निजी नीलामी या खुली नीलामी में शामिल होने की ज़रूरी शर्तें पूरी करता है.
अपने टेक्निकल खाता मैनेजर से संपर्क करके, इस तरह की फ़्लैटनिंग से ऑप्ट आउट किया जा सकता है. इस सुविधा को बंद करने पर, अगर पब्लिशर ने स्किप किए जा सकने वाले और स्किप न किए जा सकने वाले, दोनों तरह के वीडियो विज्ञापनों को अनुमति दी है, तो स्किप किए जा सकने की सुविधा के आधार पर, उनकी ज़्यादा से ज़्यादा अवधि अलग-अलग होगी. ऐसे में, skip को true पर सेट किया जाएगा. साथ ही, maxduration को स्किप किए जा सकने वाले और स्किप न किए जा सकने वाले विज्ञापन की शर्तों के हिसाब से, कम अवधि पर सेट किया जाएगा.
वीडियो पॉड
एक से ज़्यादा विज्ञापन दिखाने के मौके वाले वीडियो पॉड के लिए बिड अनुरोधों को फ़्लैट किया जाता है, ताकि हर बिड अनुरोध उस पॉड में विज्ञापन दिखाने के किसी एक मौके के लिए हो.
इससे आपको किसी पॉड के लिए, विज्ञापन दिखाने के कई मौकों पर बिड करने की सुविधा मिलती है.
मेज़रमेंट खोलें
ओपन मेज़रमेंट की मदद से, तीसरे पक्ष के उन वेंडर के बारे में बताया जा सकता है जो मोबाइल ऐप्लिकेशन पर दिखाए जाने वाले विज्ञापनों के लिए, मेज़रमेंट और पुष्टि की सेवाएं उपलब्ध कराते हैं.
यह पता लगाया जा सकता है कि पब्लिशर, बिड अनुरोध में ओपन मेज़रमेंट की सुविधा देता है या नहीं. इसके लिए, यह देखें कि विज्ञापन दिखाने के मौके में, पब्लिशर के लिए उपलब्ध क्रिएटिव एट्रिब्यूट में मौजूद OmsdkType:
OMSDK 1.0 एट्रिब्यूट शामिल नहीं है. यह बैनर या वीडियो के लिए battr एट्रिब्यूट में दिखेगा. यह फ़ॉर्मैट पर निर्भर करता है.
Open Measurement के सिग्नल वाली बिड के अनुरोधों को समझने के बारे में ज़्यादा जानने के लिए, Open Measurement SDK के सहायता केंद्र का लेख पढ़ें.
बिड रिक्वेस्ट के सैंपल
यहां दिए गए सेक्शन में, अलग-अलग तरह के विज्ञापनों के लिए बिड अनुरोध के सैंपल दिखाए गए हैं.
[[["समझने में आसान है","easyToUnderstand","thumb-up"],["मेरी समस्या हल हो गई","solvedMyProblem","thumb-up"],["अन्य","otherUp","thumb-up"]],[["वह जानकारी मौजूद नहीं है जो मुझे चाहिए","missingTheInformationINeed","thumb-down"],["बहुत मुश्किल है / बहुत सारे चरण हैं","tooComplicatedTooManySteps","thumb-down"],["पुराना","outOfDate","thumb-down"],["अनुवाद से जुड़ी समस्या","translationIssue","thumb-down"],["सैंपल / कोड से जुड़ी समस्या","samplesCodeIssue","thumb-down"],["अन्य","otherDown","thumb-down"]],["आखिरी बार 2026-03-18 (UTC) को अपडेट किया गया."],[],["Bid requests are HTTP POSTs using OpenRTB Protobuf, replacing the deprecated Google RTB protocol. Parsing involves `ParseFromString()` to access fields in the `BidRequest` object. Billing IDs, found in `BidRequest.imp.ext.billing_id` and `BidRequest.imp.pmp.deal.ext.billing_id`, must be specified in `BidResponse.seatbid.bid.ext.billing_id`. Key information comes from dictionary files. Bid URL macros dynamically insert `BidRequest` data. Complex bid requests can be broken into simpler, flattened requests per format or deal, such as skippable/non-skippable video ads, or video pods. Bidders get real-time feedback. The provided sample requests are used to help the process.\n"]]