अनुरोध प्रोसेस करें

Google, आपके ऐप्लिकेशन को बिड का अनुरोध भेजता है. इसके बाद, रीयल-टाइम बिडिंग इंटरैक्शन शुरू होता है. इस गाइड में, बिड के अनुरोध को प्रोसेस करने के लिए, अपने ऐप्लिकेशन को कोड करने का तरीका बताया गया है.

पार्स करने का अनुरोध

Google, OpenRTB JSON या Protobuf फ़ॉर्मैट में क्रम से लगाई गई बिड रिक्वेस्ट भेजता है. इसे एचटीटीपी पोस्ट अनुरोध के पेलोड के तौर पर अटैच किया जाता है. आपको किस फ़ॉर्मैट में डेटा मिलेगा, यह आपके एंडपॉइंट के कॉन्फ़िगरेशन पर निर्भर करता है. उदाहरण के लिए, बिड अनुरोध का उदाहरण देखें.

सीरियलाइज़ किए गए BidRequest को पाने के लिए, आपको इस अनुरोध को पार्स करना होगा. अगर Protobuf फ़ॉर्मैट का इस्तेमाल किया जा रहा है, तो आपको रेफ़रंस डेटा पेज से openrtb.proto और openrtb-adx.proto डाउनलोड करने होंगे. इसके बाद, इनका इस्तेमाल करके एक ऐसी लाइब्रेरी जनरेट करनी होगी जिसका इस्तेमाल BidRequest मैसेज को पार्स करने के लिए किया जा सकता है. उदाहरण के लिए, यहां दिया गया C++ कोड, स्ट्रिंग में दिए गए POST पेलोड से अनुरोध को पार्स करता है:

string post_payload = /* the payload from the POST request */;
BidRequest bid_request;
if (bid_request.ParseFromString(post_payload)) {
  // Process the request.
}

BidRequest मिलने के बाद, इसे ऑब्जेक्ट के तौर पर इस्तेमाल किया जा सकता है. साथ ही, इसमें से अपनी ज़रूरत के हिसाब से फ़ील्ड निकाले जा सकते हैं और उनकी व्याख्या की जा सकती है. उदाहरण के लिए, C++ में OpenRTB `BidRequest` में डील को दोहराने का तरीका यहां दिया गया है:

for (const BidRequest::Imp::Pmp::Deal& deal : pmp.deals()) {
  DoSomething(deal.id(), deal.wseat());
}

बिलिंग आईडी

आपको बिड का अनुरोध तब मिलता है, जब पब्लिशर की विज्ञापन इन्वेंट्री को आपके एक या उससे ज़्यादा प्रीटारगेटिंग कॉन्फ़िगरेशन से टारगेट किया जाता है. 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": {
    ...
  }
}
      
// 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 का ऐप्लिकेशन आईडी है.

लेन-देन के यूआरएल से मोबाइल ऐप्लिकेशन का नाम ढूंढना

यहां ऐप्लिकेशन का नाम पाने का एक उदाहरण दिया गया है. जिस यूआरएल की शिकायत की गई है वह यह है:

mbappMFUXELTDN5WS42DZOBQWQLTJN4XHG3DJORUGK4Q888.com
इस वैल्यू को डिकोड करने पर:
MFUXELTDN5WS42DZOBQWQLTJN4XHG3DJORUGK4Q===
नतीजे:
air.com.hypah.io.slither
यह नतीजा, 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

  1. कुछ वेंडर के बारे में जानकारी देना ज़रूरी नहीं है. इन वेंडर की सूची Ad Manager के सर्टिफ़ाइड बाहरी वेंडर में दी गई है.
  2. अन्य वेंडर सिर्फ़ तब हिस्सा ले सकते हैं, जब उन्हें BidRequest में शामिल किया गया हो:
    • BidRequest में, BidRequest.imp.ext.allowed_vendor_type फ़ील्ड से पता चलता है कि सेलर ने किन वेंडर को अनुमति दी है. allowed_vendor_type में भेजे जाने वाले वेंडर, vendors.txt डिक्शनरी फ़ाइल में मौजूद होते हैं.

बिड अनुरोध का उदाहरण

यहां Protobuf और JSON अनुरोधों के ऐसे उदाहरण दिए गए हैं जिन्हें कोई भी व्यक्ति आसानी से पढ़ सकता है.

OpenRTB Protobuf

OpenRTB JSON

बिड अनुरोध को बाइनरी फ़ॉर्म में बदलने के लिए, यहां दिया गया तरीका अपनाएं. इससे आपको असली अनुरोध में POST पेलोड मिलेगा. यह तरीका C++ में उपलब्ध है. हालांकि, ध्यान दें कि यह OpenRTB JSON पर लागू नहीं होता.

string text_format_example = /* example from above */;
BidRequest bid_request;
if (TextFormat::ParseFromString(text_format_example, &bid_request)) {
  string post_payload;
  if (bid_request.SerializeToString(&post_payload)) {
    // post_payload is a binary serialization of the protocol buffer
  }
}

रीयल-टाइम में सुझाव/राय या शिकायतें

रीयल-टाइम फ़ीडबैक, Authorized Buyers के साथ-साथ ओपन बिडिंग का इस्तेमाल करने वाले एक्सचेंज और नेटवर्क के लिए भी उपलब्ध है.

रीयल-टाइम फ़ीडबैक, BidRequest.ext.bid_feedback के आधार पर तैयार होता है. यह फ़ीडबैक, आपकी पिछली एक या उससे ज़्यादा बिड के नतीजे के आधार पर तैयार होता है. इसका इस्तेमाल, यह जानने के लिए किया जा सकता है कि बिड ने नीलामी जीती या नहीं. साथ ही, यह भी पता लगाया जा सकता है कि नीलामी जीतने के लिए कम से कम कितनी बिड की ज़रूरत थी. रीयल-टाइम में मिलने वाली प्रतिक्रिया की सुविधा चालू करने के लिए, अपने खाता मैनेजर से संपर्क करें.

बिड रिस्पॉन्स फ़ीडबैक में भेजे गए डिफ़ॉल्ट फ़ील्ड के अलावा, BidResponse.seatbid.bid.ext.event_notification_token फ़ील्ड का इस्तेमाल करके बिड रिस्पॉन्स में कस्टम डेटा भी भेजा जा सकता है. event_notification_token एक ऐसा डेटा है जिसके बारे में सिर्फ़ बिडर को पता होता है. इससे डीबग करने में मदद मिल सकती है. उदाहरण के लिए: नया टारगेटिंग आईडी या नई रणनीति को दिखाने वाला बिडिंग आईडी या क्रिएटिव से जुड़ा मेटाडेटा, जिसके बारे में सिर्फ़ बिडर को पता होता है. ज़्यादा जानकारी के लिए, OpenRTB एक्सटेंशन प्रोटोकॉल बफ़र फ़ाइल देखें.

जब Authorized Buyers, बिड करने वाले व्यक्ति या कंपनी को बिड अनुरोध भेजता है, तो बिडर BidResponse के साथ जवाब देता है. अगर बिडर ने रीयल-टाइम फ़ीडबैक की सुविधा चालू की है, तो Authorized Buyers, बिड के अगले अनुरोध में BidFeedback मैसेज में जवाब के बारे में फ़ीडबैक भेजता है:

message BidFeedback {
  // The unique id from BidRequest.id.
  optional string request_id = 1;

  // The status code for the ad. See creative-status-codes.txt in the
  // technical documentation for a list of ids.
  optional int32 creative_status_code = 2;

  // Deprecated. This field is not populated and will be removed after March,
  // 2025. If the bid won the auction, this is the price paid in your account
  // currency. If the bid participated in the auction but was out-bid, this
  // is the CPM that should have been exceeded in order to win. This is not
  // set if the bid was filtered prior to the auction, if the publisher or
  // winning bidder has opted out of price feedback or if your account has
  // opted out of sharing winning prices with other bidders. For first-price
  // auctions, minimum_bid_to_win is populated instead of this field.
  optional double price = 3 [deprecated = true];

  // The minimum bid value necessary to have won the auction, in your account
  // currency. If your bid won the auction, this is the second highest bid
  // that was not filtered (including the floor price). If your bid didn't win
  // the auction, this is the winning candidate's bid. This field will only be
  // populated if your bid participated in a first-price auction, and will not
  // be populated if your bid was filtered prior to the auction.
  optional double minimum_bid_to_win = 6;

  // Billable event rate multiplier that was applied to this bid during
  // ranking. The adjustment reflects the likelihood that your bid would
  // generate a billable event (namely, the ad renders successfully) if it won
  // the auction, relative to the probability that other bids generate a
  // billable event if they won the auction. This adjustment can be larger or
  // smaller than 1. This affects the final ranking in the auction only; in
  // particular, this multiplier does not affect the payment or whether the
  // bid clears any floor price.
  optional float billable_event_rate_bid_adjustment = 13 [default = 1];

  // When a publisher uses an RTB auction and waterfall-based SDK mediation on
  // the same query, the winner of the real-time auction must also compete in
  // a mediation waterfall (which is ordered by price) to win the impression.
  // If the bid participated in the auction and there was no waterfall, the
  // value of this field is 0. If the bid participated in the auction and
  // there was a waterfall, the value of this field is a price representing a
  // sample bid from the eligible mediation networks that were higher than the
  // auction winner, weighted by expected fill rate. This field can be used
  // in conjunction with minimum_bid_to_win to train bidding models. The CPM
  // is in your account currency.
  optional double sampled_mediation_cpm_ahead_of_auction_winner = 8;

  message EventNotificationToken {
    // The contents of the token.
    optional string payload = 1;
  }

  // The token included in the corresponding bid.
  optional EventNotificationToken event_notification_token = 4;

  // The creative ID included in the corresponding bid.
  optional string buyer_creative_id = 5;
}

इस मैसेज में, आपको सबसे पहले bid_feedback.creative_status_code फ़ील्ड की जांच करनी चाहिए. आपको creative-status-codes.txt में कोड का मतलब मिल सकता है. ध्यान दें कि बिड जीतने पर, कीमत के बारे में मिले सुझावों से ऑप्ट आउट किया जा सकता है. ज़्यादा जानकारी के लिए, ऑप्ट-आउट करने का तरीका लेख पढ़ें.

रीयल-टाइम में मिलने वाले सुझाव, शिकायत या राय में बिड अनुरोध आईडी और इनमें से कोई एक जानकारी शामिल होती है:

नीलामी का नतीजा रीयल-टाइम में सुझाव, राय या शिकायतें पाना
खरीदार ने बिड सबमिट नहीं की है. कुछ नहीं.
खरीदार ने ऐसी बिड सबमिट की थी जिसे नीलामी तक पहुंचने से पहले ही फ़िल्टर कर दिया गया था. क्रिएटिव का स्टेटस कोड (creative-status-codes.txt).
खरीदार ने बिड सबमिट की, लेकिन वह नीलामी हार गया. क्रिएटिव का स्टेटस कोड 79 (नीलामी में ज़्यादा बोली लगाई गई).
खरीदार ने ऐसी बिड सबमिट की है जिसने नीलामी जीत ली है. क्लियरिंग प्राइस और क्रिएटिव का स्टेटस कोड 1.

ऐप्लिकेशन इंप्रेशन और 83 के क्रिएटिव स्टेटस कोड के लिए, ऐप्लिकेशन पब्लिशर मीडिएशन वॉटरफ़ॉल का इस्तेमाल कर रहा होगा. इसलिए, सबसे ज़्यादा बिड लगाने वाले विज्ञापन को पब्लिशर की पासबैक वॉटरफ़ॉल चेन में, मांग के अन्य स्रोतों से प्रतिस्पर्धा करनी होगी. बिडिंग के दौरान sampled_mediation_cpm_ahead_of_auction_winner का इस्तेमाल करने का तरीका जानें.

नमूना

यहां उन प्रोटोकॉल में दिखने वाले रीयल-टाइम फ़ीडबैक का एक उदाहरण दिया गया है जिनमें यह सुविधा काम करती है:

OpenRTB Protobuf

OpenRTB JSON

फ़र्स्ट-प्राइस ऑक्शन के लिए बिडिंग मॉडल बनाना

फ़र्स्ट-प्राइस ऑक्शन में बिड लगाने के बाद, आपको रीयल-टाइम में सुझाव मिलेंगे. अगर बिड को ऑक्शन से फ़िल्टर नहीं किया गया है, तो आपको 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 प्रॉबेबिलिटी
\(max(F, R, C_3) = $0.50\) \(f_3 = 80\%\)
\(max(F, R, C_4) = $0.10\) \((1-f_3) \cdot f_4 = 17\%\)
\(max(F, R, 0) = $0.05\) \((1-f_3) \cdot (1-f_4) = 3\%\)
sampled_mediation_cpm_
ahead_of_auction_winner
प्रॉबेबिलिटी
\(C_1 = $3.00\) \(f_1 \div (1-(1-f_1) \cdot (1-f_2)) =~ 10.5\%\)
\(C_2 = $2.00\) \(((1-f_1) \cdot f_2) \div (1-(1-f_1) \cdot (1-f_2)) =~ 89.5\%\)
नीलामी में हार गई बिड

यहां एक उदाहरण दिया गया है. इसमें बताया गया है कि जिन बोलियों को स्वीकार नहीं किया गया उनके लिए, 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 के सहायता केंद्र का लेख पढ़ें.

बिड रिक्वेस्ट के सैंपल

यहां दिए गए सेक्शन में, अलग-अलग तरह के विज्ञापनों के लिए बिड अनुरोध के सैंपल दिखाए गए हैं.

ऐप्लिकेशन बैनर

OpenRTB Protobuf

OpenRTB JSON

ऐप्लिकेशन पर अचानक दिखने वाला विज्ञापन

OpenRTB Protobuf

OpenRTB JSON

ऐप्लिकेशन पर अचानक दिखने वाला वीडियो विज्ञापन

OpenRTB Protobuf

OpenRTB JSON

ऐप्लिकेशन नेटिव

OpenRTB Protobuf

OpenRTB JSON

वेब वीडियो

OpenRTB Protobuf

OpenRTB JSON

एक्सचेंज बिडर के लिए मोबाइल वेब बैनर

OpenRTB Protobuf

OpenRTB JSON

अलग-अलग फ़ॉर्मैट वाले नेटिव और वीडियो विज्ञापन

OpenRTB Protobuf

OpenRTB JSON