अनुरोध प्रोसेस करें
संग्रह की मदद से व्यवस्थित रहें
अपनी प्राथमिकताओं के आधार पर, कॉन्टेंट को सेव करें और कैटगरी में बांटें.
रीयल-टाइम बिडिंग इंटरैक्शन तब शुरू होता है, जब 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 की जानकारी मौजूद है या नहीं.
%%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;//Deprecated.ThisfieldwillberemovedinFebruary2026.//Theminimumbidvaluenecessarytohavewontheserver-sidecomponentof//theoverallauctiongiventhattherewasalsoaninterestgroupbidding//componenttotheoverallauctionwhichranusingtheProtectedAudience//API.ThevalueisexpressedinCPMofthebuyeraccountcurrency.The//minimumbidtowinfortheoverallauction,includingbidsfromthe//server-sideandtheon-deviceinterestgroupcomponents,ispopulatedin//theminimum_bid_to_winfieldofthesameBidFeedbackobject.optionaldoublesscminbidtowin=14[deprecated=true];//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;//Possibletypesofbidresponsefeedbackobjects.enumFeedbackType{FEEDBACK_TYPE_UNSPECIFIED=0;//Feedbackforabidthatwassubmittedonabidresponse.BID_FEEDBACK=1;//Feedbackforaninterestgroupbuyersubmittedonabidresponseto//particpateinaninterestgroupbiddingcomponentoftheauctionrun//usingtheProtectedAudienceAPI.INTEREST_GROUP_BUYER_FEEDBACK=2;}//Deprecated.ThisfieldwillberemovedinFebruary2026.//ThetypeoftheBidFeedbackmessage.Googlewillsendseparate//BidFeedbackobjectsfor://a)Eachbidsubmittedonabidresponse//b)Eachbuyersubmittedonabidresponsetoparticpateinaninterest//groupbiddingcomponentoftheauctionrunusingtheProtectedAudience//API.optionalFeedbackTypefeedbacktype=15[deprecated=true];//Deprecated.ThisfieldwillberemovedinFebruary2026.//Originofaninterestgroupbuyerthatwasincludedinthebidresponse.//Thisfieldispopulatedonlyforfeedbackwhereabidderoptedinan//interestgroupbuyertoparticipateintheinterestgroupbidding//componentoftheoverallauctionrunusingtheProtectedAudienceAPI.//Tolearnmoreaboutorigins,seehttps://www.rfc-editor.org/rfc/rfc6454.//TolearnmoreaboutinterestgroupbiddingandtheProtectedAudience//API,see//https://developers.google.com/authorized-buyers/rtb/fledge-origin-trial.optionalstringbuyerorigin=16[deprecated=true];//Deprecated.ThisfieldwillberemovedinFebruary2026.//Thestatuscodeforthesubmittedinterestgroupbuyer.Thisfieldis//onlypopulatedinthefeedbackforaninterestgroupbuyerthatabidder//requestedtoenterintotheinterestgroupauctionthroughthebid//response.Individualcreativestatuscodesofbidssubmittedbythebuyer//intheon-deviceinterestgroupauctionarenotavailable.See//https://storage.googleapis.com/adx-rtb-dictionaries/interest-group-buyer-status-codes.txt//foralistofinterestgroupbuyerstatuscodes.optionalint32igbuyerstatus=17[deprecated=true];}
इस मैसेज में, आपको सबसे पहले 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 (true OR false)
बिना फ़्लैट किए गए ओरिजनल अनुरोध
15
true
फ़्लैटेंड अनुरोध #1: स्किप नहीं किया जा सकता
15
false
फ़्लैट किया गया अनुरोध #2: स्किप किया जा सकता है
60
true
स्किप किए जा सकने वाले वीडियो की अवधि के लिए बिड अनुरोध को फ़्लैट करने की सुविधा सिर्फ़ तब काम करेगी, जब ये शर्तें पूरी होंगी:
अनुरोध में वीडियो की अनुमति दी गई हो.
इसमें स्किप किए जा सकने वाले और स्किप न किए जा सकने वाले, दोनों तरह के वीडियो दिखाए जा सकते हैं. साथ ही, दोनों की ज़्यादा से ज़्यादा अवधि अलग-अलग होती है.
यह अनुरोध, निजी नीलामी या खुली नीलामी के लिए ज़रूरी शर्तें पूरी करता है.
अपने टेक्निकल खाता मैनेजर से संपर्क करके, इस तरह के फ़्लैटनिंग से ऑप्ट आउट किया जा सकता है. इस सुविधा के बंद होने पर, पब्लिशर को स्किप किए जा सकने वाले और स्किप न किए जा सकने वाले, दोनों तरह के वीडियो विज्ञापन दिखाने की अनुमति मिलती है. हालांकि, स्किप किए जा सकने की सुविधा के आधार पर, इन विज्ञापनों की ज़्यादा से ज़्यादा अवधि अलग-अलग होती है. ऐसे में, skip को true पर सेट कर दिया जाएगा. साथ ही, maxduration को स्किप किए जा सकने वाले और स्किप न किए जा सकने वाले विज्ञापन की पाबंदियों के बीच, कम अवधि वाले विज्ञापन पर सेट कर दिया जाएगा.
वीडियो पॉड
एक से ज़्यादा विज्ञापन दिखाने की सुविधा वाले वीडियो पॉड के लिए बिड अनुरोधों को फ़्लैट किया जाता है, ताकि हर बिड अनुरोध उस पॉड में विज्ञापन दिखाने के अलग-अलग अवसरों के लिए हो.
इससे आपको किसी पॉड के लिए, विज्ञापन दिखाने के कई मौकों पर बिड करने की सुविधा मिलती है.
मेज़रमेंट खोलें
ओपन मेज़रमेंट की मदद से, तीसरे पक्ष के उन वेंडर के बारे में बताया जा सकता है जो मोबाइल ऐप्लिकेशन पर दिखाए जाने वाले विज्ञापनों के लिए, मेज़रमेंट और पुष्टि की सेवाएं उपलब्ध कराते हैं.
यह पता लगाया जा सकता है कि पब्लिशर, बिड अनुरोध में ओपन मेज़रमेंट की सुविधा देता है या नहीं. इसके लिए, यह देखें कि विज्ञापन दिखाने के लिए उपलब्ध जगह में, पब्लिशर के हिसाब से क्रिएटिव एट्रिब्यूट में मौजूद OmsdkType:
OMSDK 1.0 एट्रिब्यूट शामिल नहीं है. यह battrएट्रिब्यूट के तहत बैनर या वीडियो में दिखेगा. यह फ़ॉर्मैट पर निर्भर करता है.
ओपन मेज़रमेंट सिग्नल वाली बिड के अनुरोधों को समझने के बारे में ज़्यादा जानने के लिए, ओपन मेज़रमेंट 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-01-13 (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"]]