Non-limiting and non-exhaustive embodiments are described with reference to the following drawings. In the drawings, like reference numerals refer to like parts throughout the various figures unless otherwise specified.
Advertisers and advertising providers would like an accurate measure of ad impressions to determine the value of a particular advertisement or ad location. The International Advertising Bureau (“IAB”) has established that an ad impression should be a measurement of responses from an ad delivery system to an ad request from the user's browser, which is filtered from robotic activity and is recorded at a point as late as possible in the process of delivery of the creative material to the user's browser—therefore closest to actual opportunity to see by the user. Two methods may be used to deliver ad content to the user—server-initiated and client-initiated. Server initiated ad counting uses the site's web content server for making requests, formatting and re-directing content. Client-initiated ad counting relies on the user's browser to perform these activities. Client Side Counting (“CSC”) is an industry-sponsored standard utilizing a client-initiated approach.
Client Side Counting (“CSC”) is an industry-sponsored standard proposed through the Interactive Advertising Bureau (“IAB”). By adopting this standard, ad serving companies could employ consistent techniques when measuring ad impressions across different technologies and platforms. According to LAB, adoption of the CSC standard will result in two benefits to advertisers and the industry: It will lower discrepancy rates of media places across multiple systems, and it will improve the quality and consistency of the collected data. CSC will be described in more detail below regarding
In
Some or all of ad server 110, portal server 102, and third-party server 104 may be in communication with each other by way of network 108. The ad server 110 and portal server 102 may each represent multiple linked computing devices, and multiple third-party servers, such as third-party server 104, may be included in environment 100. Network 108 may be regarded as a public or private network connection and may include, for example, a virtual private network or an encryption or other security mechanism employed over the public Internet, or the like.
Client device 106 and mobile client device 112 are represented by user-interactive devices that typically run browser applications, and the like, to display requested pages received over a network that include advertisements. The user/client may be a consumer of goods of services that is searching for a business such as a business of the advertiser. Such devices are in communication with portal server 102 and/or third-party server 104 by way of network 109. Network 109 may include the Internet and may include all or part of network 108; network 108 may include all or part of network 109.
Portal server 104, third-party server 104, ad server 110, log database 105, client device 106, and mobile client device 112 represent computing devices of various kinds as discussed below with
Networks 108, 109 may be configured to couple one computing device to another computing device to enable communication of data between the devices. Networks 108, 109 may generally be enabled to employ any form of machine-readable media for communicating information from one device to another. Each of networks 108, 109 may include one or more of a wireless network, a wired network, a local area network (LAN), a wide area network (WAN), a direct connection such as through a Universal Serial Bus (USB) port, and the like, and may include the set of interconnected networks that make up the Internet. Networks 108, 109 may include any communication method by which information may travel between computing devices.
The ad server 110 may be used for providing advertisements that are displayed to clients 106. The ads that are displayed or transmitted to the client 106 may be recorded in the log database 105. The ad server log database 105 may be used for traditional access log ad impression counting. In one embodiment, the ad server log database may only record a subset of the information transmitted over networks 108 and/or 109. The data that is stored in the log database 105 may be dependent on the type of ad counting mechanism that is used. Before CSC, traditional access logs may have included data or information similar to that stored by CSC logs. Although not shown in
Both the web server in the traditional server log style counting and the beacon servers may have a web server software. One example of which is APACHE, an open source web server software application. The general format of the logs involved in either traditional or CSC may be the same or may be different. Both the traditional logs and the CSC logs may contain similar non-ad information like the referrer, the URL requested, date/time, cookie information, etc. They may also include a field with ad-specific information. Both the traditional and CSC beacon server logs may contain similar ad information, such as the location on the page and specific tracking information related to that ad. The delimiters may be different, and there may be some more granular tracking metrics for CSC logs. The generation of the log entry is different for CSC because it is initiated by a beacon on the client.
The web server 203 may be a portal allowing the client 106 to access a network, such as the Internet. The client 106 may request content from the web server 203. The web server 203 provides the content, only after receiving advertising content from the ad server 110. In a CSC context, the content may include a beacon that is added to the content that the web server 203 delivers to the client 106. The web server 203 may include a web server log database 207 that is used to track the requests for pages or the delivery of pages. In a non-CSC advertising system the web server log database may store information on web pages that are requested or delivered. Accordingly, these web server logs may be used to charge an advertiser based on delivery of an advertisement. The web server log database 207 may be referred to as “web server access logs” and may record the ads shown on web pages. The logs may record which files (URL's, pages, etc.) the web server has delivered and inside each access log entry may be information on the ads included in that outbound page. Accordingly, the ads that are displayed or transmitted to the client 106 may be recorded in the web server access logs of the host, which served the page containing the ads.
Stored logs may contain one line for every page/file served by the webserver. Along with information on the date/time of the request, the URL requested, the referrer (from where the request was made), etc. ad-specific information may be logged which operates to maintain a record the ads shown on the page. As discussed below, logs may only be recorded once the client has created the final CSC beacon URL in the browser on the client side and the browser then requests this URL.]
A beacon is an identifier that is inserted into a web page to track viewing of elements within that page. The beacon may be a uniquely identifiable 1×1 pixel that is placed in a web page after an ad is inserted into that page. In one embodiment, a beacon may be JavaScript that is inserted into a page. The JavaScript may be associated with each advertisement on the page. There also may be a final JavaScript at the end of the page. The JavaScript may be referred to as beaconing code. Also, the beacon, such as a 1×1 pixel or image, may be a uniform resource locator (“URL”) that includes ad information for a page.
After the page containing the ad is delivered by the web server 203 to the client 106, the beacon server 204 (also referred to as a pixel counter) may request the beacon in order to count the ad impression viewed by the client 106. In particular, the URL which is formed may be requested by the browser. The URL actually requests (and returns) a dummy 1×1 empty image. Accordingly, the logging of the beacon information may be a request for a (dummy) file. The request may result in logged information related to the ads on the page where the URL was formed.
The beacon may submit a request to the beacon server 204 upon being loaded onto a page. Specifically, the final JavaScript in the page may send a request to the beacon server 204 including the advertisement information from that page. The beacon server 204 may then record information received from beacons in the beacon server log database 205. The beacon request to the beacon server 204 may be used as a way of counting an ad impression that is triggered upon the ad being viewed. In one embodiment, the beacon server 204 may be a part of or coupled with the ad server 110. Likewise, the beacon server 204 may be a part of or coupled with the web server 203. The beacon server 204 counts the fetching and delivery of a beacon as an ad impression. The ad impressions may be recorded and stored in the beacon server log database 205. The log data stored in the beacon server log database 205 may be raw data that is cleansed or edited.
The web server logging data 302 is used for a traditional ad 312, but not a CSC ad 314. As discussed above in association with
The CSC ad 314 includes the ad creative 304, and the link for the ad 306 in addition to CSC beaconing code 308 and beacon server logging data 310. As discussed above, the CSC beaconing code 308 may be used to identify when a page has been viewed. The CSC beaconing code 308 may be referred to as a beacon, which is an identifier that is inserted into a web page to track viewing of elements within that page. As discussed above, the CSC beaconing code may be JavaScript that is inserted into a page and associated with each advertisement on the page. The beacon server logging data 310 records the information from the beacon or CSC beaconing code 308. Specifically, the beacon server logging data 310 may record the number of viewings of a page or elements on a page. The beacon server logging data 310 may then be used to charge the advertisers for advertisements based on the number of times that the ad is viewed.
Steps 402-410 incorporate elements discussed in
In step 412, the ads in a page are compared with the beacons in the page. The beacon information in the page should mirror the ad information in the page which existed prior to CSC. Each ad in the page, has specific data relating to it's position in the page, tracking information etc. To determine if the beacon information is properly recorded, a comparison may be made between the location, tracking information and content of the ads with the information that the beacon may include. The comparison may track the accuracy of the beacon data by comparing the beacon data with the actual ads. In this scenario, the beacon data should mirror the ad data with 100% accuracy since the information is available in the same data store on the adserver. The measurement of the ads in a page or the beacons in a page may be accomplished by monitoring a transient outgoing page as discussed in
In step 414, the beacons in a page are compared with the web server logs. As discussed above, the beacons in a page may include ad information. This information may be compared with the web server logs. The beacons may include information on the number, content and location of ads. The web server logs may include the same information regarding the ads that are displayed on a page. As in the comparison from step 414, the beacon information may be compared to determine its accuracy. In one embodiment, the web server logs may include the pages that are transmitted and include ad information that is used to determine the accuracy of the beacon information. Accordingly, a comparison between the beacons and the web server logs may be used to verify that the beacon data is accurate.
In step 416, the beacons in the page are compared with the beacon server logs. The beacon server logs may record information retrieved from the individual beacons in a page. As discussed above, the beacon server logs may include the number of times that a beacon and the corresponding ads are displayed. This comparison may ensure the beacon information is consistent between the beacon(s) on the page and those recorded in the beacon logs. For example, with CSC a new identifier may be introduced that is referred to as a “pageview id.” This pageview id is not recorded in the ad data or in the web log data. To ensure the pageview ids were being recorded correctly the place the data exists is in the beacons in the page and in the beacon server access logs. Accordingly, a comparision between beacon server logs and the beacons may allow verification of the pageview id, which may be used in CSC log processing.
In step 418, the web server logs are compared with the beacon server logs. The web server logs may include the number of times that any given page is requested and transmitted by the web server. The beacon server logs may include the number of times that a beacon reports being viewed by a user. The beacon server logs may be compared with the web server logs to verify that the beacon server log data regarding the number of ads that are viewed is comparable with the number of pages that are requested or transmitted. In one embodiment, the number of times that an ad is requested/transmitted may be much greater than the number of times that an ad is viewed because non-human or robot requests may be included in the web server logs. Accordingly, the web server logs may have to be analyzed to filter out the robotic requests when making a comparison, or the comparison may include a consideration of the fact that the web server logs include non-human requests. The beacon server logs register the number of times that a page is viewed, so the non-human or robotic activity should not trigger the beacon and be recorded in the beacon server logs. In the context of verification testing in a quarantined environment there may be no robotic requests. Accordingly, rather than filtering out robotic traffic, an assumption of 100% matching may be made.
Step 418 may be used as a comparison of the accuracy of ad impression calculations. In particular, a comparison with the web server logs may determine if the beacon logs are properly tracking the ad impressions for a page or ad. The comparison may be a percent comparison. The comparison may take into account the robots discussed above. In one embodiment, it may be known that the ad impressions tracked by the beacon logs should be approximately 80% of the ad impressions tracked in the web server logs. The percentage of robots may be known to be 20% and the web server logs do not remove those hits from its logs of ad impressions. In alternate embodiments, the comparison between the web server logs and beacon logs may consider other measures to verify the accuracy of the beacon logs.
As discussed above, the testing the system may control the traffic behavior and help limit robotic activity. Thorough testing in this context may be undertaken to determine if CSC data and counts are identical to the former counts. An exact correlation between CSC logs and web logs may be required in a quarantined environment. When testing with live traffic, robotic data activity may occur and be measured for comparisons.
In alternate embodiments, the number of comparisons may vary. There may be more or fewer comparisons that are made. Accordingly, the steps 402-410 may be unnecessary for different comparisons. Alternatively, there may be more steps that are not shown for other comparisons. The comparisons may include determining if the ad impressions from CSC, through the use of beacons or a beacon server log database, are similar to the ad impressions that are derived through a web server.
The local file may be on a local file system or may be where the outgoing requests are recorded. The local file may be analyzed for the comparisons discussed above. In particular, the local file may assist in the comparisons from steps 412 and 414. The snooping may operate in real-time so that when a page is served, the local file is created that includes what is sent to the user. This allows for real-time checks of data. The web server may automatically check for a flag in a periodic intervals. In alternate embodiments, the process may be manual, requiring the web server to be told to check for a flag.
The web server may check for the existence of a flag or a file whenever a new child process is spawned. When a flag is found, the web server may write to the client socket like normal as well as writing the same data to an audit file. The corresponding log line may be written to the access log file and may also be written to the same audit file as the outbound request. Thus, when the flag is turned on, each web server child process may create a file which contains outgoing requests interleaved with the corresponding access log lines for those requests. The resultant audit files may then be parsed to examine the consistency of data within the page or to ensure the content in the page matches the content in the log line corresponding to the page.]
Referring to
In a networked deployment, the computer system may operate in the capacity of a server or as a client user computer in a server-client user network environment, or as a peer computer system in a peer-to-peer (or distributed) network environment. The computer system 600 can also be implemented as or incorporated into various devices, such as a personal computer (PC), a tablet PC, a set-top box (STB), a personal digital assistant (PDA), a mobile device, a palmtop computer, a laptop computer, a desktop computer, a communications device, a wireless telephone, a land-line telephone, a control system, a camera, a scanner, a facsimile machine, a printer, a pager, a personal trusted device, a web appliance, a network router, switch or bridge, or any other machine capable of executing a set of instructions (sequential or otherwise) that specify actions to be taken by that machine. In a particular embodiment, the computer system 600 can be implemented using electronic devices that provide voice, video or data communication. Further, while a single computer system 600 is illustrated, the term “system” shall also be taken to include any collection of systems or sub-systems that individually or jointly execute a set, or multiple sets, of instructions to perform one or more computer functions.
As illustrated in
The computer system 600 may include a memory 604 that can communicate via a bus 608. The memory 604 may be a main memory, a static memory, or a dynamic memory. The memory 604 may include, but is not limited to computer readable storage media such as various types of volatile and non-volatile storage media, including but not limited to random access memory, read-only memory, programmable read-only memory, electrically programmable read-only memory, electrically erasable read-only memory, flash memory, magnetic tape or disk, optical media and the like. In one embodiment, the memory 604 includes a cache or random access memory for the processor 602. In alternative embodiments, the memory 604 is separate from the processor 602, such as a cache memory of a processor, the system memory, or other memory. The memory 604 may be an external storage device or database for storing data. Examples include a hard drive, compact disc (“CD”), digital video disc (“DVD”), memory card, memory stick, floppy disc, universal serial bus (“USB”) memory device, or any other device operative to store data. The memory 604 is operable to store instructions executable by the processor 602. The functions, acts or tasks illustrated in the figures or described herein may be performed by the programmed processor 602 executing the instructions stored in the memory 604. The functions, acts or tasks are independent of the particular type of instructions set, storage media, processor or processing strategy and may be performed by software, hardware, integrated circuits, firm-ware, micro-code and the like, operating alone or in combination. Likewise, processing strategies may include multiprocessing, multitasking, parallel processing and the like.
As shown, the computer system 600 may further include a display unit 614, such as a liquid crystal display (LCD), an organic light emitting diode (OLED), a flat panel display, a solid state display, a cathode ray tube (CRT), a projector, a printer or other now known or later developed display device for outputting determined information. The display 614 may act as an interface for the user to see the functioning of the processor 602, or specifically as an interface with the software stored in the memory 604 or in the drive unit 606.
Additionally, the computer system 600 may include an input device 616 configured to allow a user to interact with any of the components of system 600. The input device 616 may be a number pad, a keyboard, or a cursor control device, such as a mouse, or a joystick, touch screen display, remote control or any other device operative to interact with the system 600.
In a particular embodiment, as depicted in
The present disclosure contemplates a computer-readable medium that includes instructions 612 or receives and executes instructions 612 responsive to a propagated signal, so that a device connected to a network 620 can communicate voice, video, audio, images or any other data over the network 620. Further, the instructions 612 may be transmitted or received over the network 620 via a communication port 618. The communication port 618 may be a part of the processor 602 or may be a separate component. The communication port 618 may be created in software or may be a physical connection in hardware. The communication port 618 is configured to connect with a network 620, external media, the display 614, or any other components in system 600, or combinations thereof. The connection with the network 620 may be a physical connection, such as a wired Ethernet connection or may be established wirelessly as discussed below. Likewise, the additional connections with other components of the system 600 may be physical connections or may be established wirelessly.
The network 620 may include wired networks, wireless networks, or combinations thereof. The wireless network may be a cellular telephone network, an 802.11, 802.16, 802.20, or WiMax network. Further, the network 620 may be a public network, such as the Internet, a private network, such as an intranet, or combinations thereof, and may utilize a variety of networking protocols now available or later developed including, but not limited to TCP/IP based networking protocols.
While the computer-readable medium is shown to be a single medium, the term “computer-readable medium” includes a single medium or multiple media, such as a centralized or distributed database, and/or associated caches and servers that store one or more sets of instructions. The term “computer-readable medium” shall also include any medium that is capable of storing, encoding or carrying a set of instructions for execution by a processor or that cause a computer system to perform any one or more of the methods or operations disclosed herein.
In a particular non-limiting, exemplary embodiment, the computer-readable medium can include a solid-state memory such as a memory card or other package that houses one or more non-volatile read-only memories. Further, the computer-readable medium can be a random access memory or other volatile re-writable memory. Additionally, the computer-readable medium can include a magneto-optical or optical medium, such as a disk or tapes or other storage device to capture carrier wave signals such as a signal communicated over a transmission medium. A digital file attachment to an e-mail or other self-contained information archive or set of archives may be considered a distribution medium that is a tangible storage medium. Accordingly, the disclosure is considered to include any one or more of a computer-readable medium or a distribution medium and other equivalents and successor media, in which data or instructions may be stored.
In an alternative embodiment, dedicated hardware implementations, such as application specific integrated circuits, programmable logic arrays and other hardware devices, can be constructed to implement one or more of the methods described herein. Applications that may include the apparatus and systems of various embodiments can broadly include a variety of electronic and computer systems. One or more embodiments described herein may implement functions using two or more specific interconnected hardware modules or devices with related control and data signals that can be communicated between and through the modules, or as portions of an application-specific integrated circuit. Accordingly, the present system encompasses software, firmware, and hardware implementations.
In accordance with various embodiments of the present disclosure, the methods described herein may be implemented by software programs executable by a computer system. Further, in an exemplary, non-limited embodiment, implementations can include distributed processing, component/object distributed processing, and parallel processing. Alternatively, virtual computer system processing can be constructed to implement one or more of the methods or functionality as described herein.
Although the present specification describes components and functions that may be implemented in particular embodiments with reference to particular standards and protocols, the invention is not limited to such standards and protocols. For example, standards for Internet and other packet switched network transmission (e.g., TCP/IP, UDP/IP, HTML, HTTP) represent examples of the state of the art. Such standards are periodically superseded by faster or more efficient equivalents having essentially the same functions. Accordingly, replacement standards and protocols having the same or similar functions as those disclosed herein are considered equivalents thereof.
The illustrations of the embodiments described herein are intended to provide a general understanding of the structure of the various embodiments. The illustrations are not intended to serve as a complete description of all of the elements and features of apparatus and systems that utilize the structures or methods described herein. Many other embodiments may be apparent to those of skill in the art upon reviewing the disclosure. Other embodiments may be utilized and derived from the disclosure, such that structural and logical substitutions and changes may be made without departing from the scope of the disclosure. Additionally, the illustrations are merely representational and may not be drawn to scale. Certain proportions within the illustrations may be exaggerated, while other proportions may be minimized. Accordingly, the disclosure and the figures are to be regarded as illustrative rather than restrictive.
One or more embodiments of the disclosure may be referred to herein, individually and/or collectively, by the term “invention” merely for convenience and without intending to voluntarily limit the scope of this application to any particular invention or inventive concept. Moreover, although specific embodiments have been illustrated and described herein, it should be appreciated that any subsequent arrangement designed to achieve the same or similar purpose may be substituted for the specific embodiments shown. This disclosure is intended to cover any and all subsequent adaptations or variations of various embodiments. Combinations of the above embodiments, and other embodiments not specifically described herein, will be apparent to those of skill in the art upon reviewing the description.
The Abstract of the Disclosure is provided to comply with 37 C.F.R. §1.72(b) and is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, various features may be grouped together or described in a single embodiment for the purpose of streamlining the disclosure. This disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter may be directed to less than all of the features of any of the disclosed embodiments. Thus, the following claims are incorporated into the Detailed Description, with each claim standing on its own as defining separately claimed subject matter.
The above disclosed subject matter is to be considered illustrative, and not restrictive, and the appended claims are intended to cover all such modifications, enhancements, and other embodiments, which fall within the true spirit and scope of the present invention. Thus, to the maximum extent allowed by law, the scope of the present invention is to be determined by the broadest permissible interpretation of the following claims and their equivalents, and shall not be restricted or limited by the foregoing detailed description.