Targeting videos based on viewer similarity

Information

  • Patent Grant
  • 10462504
  • Patent Number
    10,462,504
  • Date Filed
    Thursday, March 29, 2018
    6 years ago
  • Date Issued
    Tuesday, October 29, 2019
    5 years ago
Abstract
Presentation of a video clip is made to persons having a high probability of viewing the clip. A database containing viewers of previously offered video clips is analyzed to determine similarities of preferences among viewers. When a new video clip has been watched by one or more viewers in the database, those viewers who have watched the new clip with positive results are compared with others in the database who have not yet seen it. Prospective viewers with similar preferences are identified as high likelihood candidates to watch the new clip when presented. Bids to offer the clip are based on the degree of likelihood. For one embodiment, a data collection agent (DCA) is loaded to a player and/or to a web page to collect viewing and behavior information to determine viewer preferences. Viewer behavior may be monitored passively by different disclosed methods.
Description
BACKGROUND

Technical Field


The invention relates to the monitoring of a website and the interaction of a client with a website relative to web content. More particularly, the invention relates to passively monitoring online video viewing behavior to determine viewer preference similarities, and to determine the likelihood that a viewer chooses to view a particular video clip when offered.


Description of the Background Art


Video clips may be supplied to viewers from any website for information, entertainment, or advertising purposes. Some of these websites may be Web 2.0 websites where a user can create an account, upload, share, contribute, comment, vote, or read personal opinions of other users, all on the same site. When video clips are viewed purely for entertainment purposes, users may be more motivated to rate a particular video clip according to their preferences. However, not all viewers expend the effort to rate a video, even if they feel strongly about it.


Video sharing and online video services allow individuals or content publishers to upload video clips to Internet websites. The website stores the video clip on its server, and provides different types of functions to allow others to view that video clip. These websites may allow commenting and rating of a video clip. Many services have options for private sharing and other publication options. Video sharing services can be classified into several categories including, user generated video sharing websites, video sharing platform, white label providers, and web based video editing.


As video hosting websites become increasingly popular, such websites provide a platform for traditional publishers, such as television broadcasters, to use these websites as another medium to display media content which may be of a more informative nature. For example, CBS and CNN networks often publish video clips on YouTube. For such publishers, it is highly desirable to know the ratings of their published video clips. In television the ratings, e.g. Nielsen Ratings, estimate the audience size and composition of television programming, and thus determine advertising rates. This method is not applicable for the Internet. Again, given the opportunity to rate a particular video clip, not all viewers expend the effort to rate the video clip, even if they feel strongly about it.


Either independent of, or associated with, entertainment or informative video clips, advertisement video clips may also be supplied to online users. Websites that supply such advertisement video clips may or may not provide users a means to rate such clips. In circumstances where the advertisement is embedded as part of an entertainment or informative clip, such as a pre-roll advertisement, offering users a voluntary rating facility for the advertisement portion becomes difficult from a practicality standpoint.


In the related art there are different techniques to determine the popularity of a website. One technique known in the art refers to page-hit or page views. The page-hit refers to an event in which a server receives a request for a page and then serves up the page. A common measure of traffic at a website is the number of page hits, especially in. an advertising context, for particular pages or sets of pages. Page-hit counts are a rough measure of the traffic of a website. Other techniques involve the analyzing of the traffic between a Web server and clients. Such prior art techniques work well when the traffic of interest relates to particular pages, but are generally not informative when traffic by topic is desired because one page may relate to multiple topics. Systems have been suggested for embedding script code in web pages for tracking user activity on a web page.


Another technique for determining the rating of video clips published on online video sites is based on viewership information provided by these sites. Typically, the sites count the cumulative number of users who view the clip. However, more refined measurements that include, for example, the quantity and characteristics of viewers, as well as detailed information about the duration and repetition of each view, are neither generated by video sharing websites nor by any other prior art technique. Furthermore, viewership information is easily manipulated by the use of, for example, scripts, browser refreshes, and other means that skew the results. As a result, ratings measurements that are based on the viewership information are inaccurate at best and often misleading.


Systems have been suggested for placement of advertising slots within or in proximity to hosted video clips. In such systems, methods are used to track the ad placement and viewing. Such methods require preparation of the video clips for ad placement.


It would be therefore advantageous to provide a solution for online video analytics for generally available video clips on the Internet.


To acquire user preference information for a particular advertisement video clip effectively, and to expand the base of user preference information for any video clip beyond those viewers who voluntarily rate a video clip, it would be useful to provide a solution for acquiring viewership information reflecting viewer preferences without requiring viewers to provide their preferences proactively. Also, when a particular video clip is in the form of an advertisement, it would be advantageous to determine the best target viewers to whom the video may be offered, especially if a bidding process is used to determine which advertising video clip is to be shown to a prospective viewer at a particular moment in time.


SUMMARY OF THE INVENTION

An embodiment of the invention enables presentation of a video clip to a potential viewer who has a high probability of viewing the clip. A database containing viewers of previously offered video clips is analyzed to determine similarities of preferences among viewers. When a new video clip has been watched by one or more viewers in the database, those viewers who have watched the new clip with positive results are compared with others in the database who have not yet seen it. Prospective viewers with similar preferences are identified as high likelihood candidates to watch the new clip when presented. Bids to offer the clip are based on the degree of likelihood. For one embodiment, a data collection agent (DCA) is loaded to a player and/or to a web page to collect viewing and behavior information to determine viewer preferences. Viewer behavior may be monitored passively by different disclosed methods.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram of a network used to describe the various embodiments disclosed in accordance with the invention;



FIG. 2 is a block diagram of the VAS disclosed in accordance with an embodiment of the invention;



FIGS. 3A-3C show exemplary charts generated by the VAS according to one embodiment of the invention;



FIG. 4 is a flowchart that describes the operation of the DCA in accordance with an embodiment of the invention;



FIG. 5 is a flowchart for capturing, processing, creating and recording a preference score for a video clip in accordance with an embodiment of the invention;



FIG. 6 is a block diagram showing possible communication alternatives for sharing a video clip with other persons in accordance with an embodiment of the invention;



FIG. 7 shows a table containing elements of viewing duration analysis for a sample of video clips and viewers in accordance with an embodiment of the invention;



FIG. 8 is a block diagram illustrating how viewers may be grouped according to videos viewed and similarity of preferences in an example analysis according to the invention; and



FIG. 9 is a flow chart showing how preference similarities are determined and analyzed to determine the likelihood that a viewer chooses to watch a particular video when it is presented in accordance with an embodiment of the invention.





DETAILED DESCRIPTION OF THE INVENTION

An embodiment of the invention enables presentation of a video clip to a potential viewer who has a high probability of viewing the clip. A database containing viewers of previously offered video clips is analyzed to determine similarities of preferences among viewers. When a new video clip has been watched by one or more viewers in the database, those viewers who have watched the new clip with positive results are compared with others in the database who have not yet seen it. Prospective viewers with similar preferences are identified as high likelihood candidates to watch the new clip when presented. Bids to offer the clip are based on the degree of likelihood. For one embodiment, a data collection agent (DCA) is loaded to a player and/or to a web page to collect viewing and behavior information to determine viewer preferences. Viewer behavior may be monitored passively by different disclosed methods.


According to an embodiment of the invention, a profile is created of those viewers in a database of viewers who are deemed likely to watch a particular video clip when presented. This profile is based on the calculated likelihood for each viewer being over a specific likelihood level defined for the profile. Subsequently, when an opportunity to offer a video clip to a prospective viewer arises, a decision to offer the video may include that prospective viewer being on a list of viewers that matches the profile.


When video clips are used as advertisements, it is especially useful to be able to predict the degree of likelihood that a particular prospective viewer chooses to watch a video clip not seen before by the viewer. If the advertiser must bid for the opportunity to offer a video clip to a prospective viewer, the likelihood prediction is a critical component in computing the amount to bid, and the decision of how much to bid for presenting the video can vary from viewer to viewer based on a specific likelihood calculation for the particular viewer.


According to an embodiment of the invention, determining the likelihood that a prospective viewer chooses to view a particular video clip is accomplished by analyzing preference similarities between the particular prospective viewer and other viewers. This analysis determines which other viewers have similarities most closely aligned with the perspective viewer, and when these other viewers have viewed the particular video clip, it can be inferred from a preference analysis according to the invention that the particular perspective viewer has a certain likelihood of choosing to watch the video clip when presented. The stronger the association of preferences between the particular prospective viewer and the other viewers, the higher the likelihood that the particular prospective viewer chooses to watch the video clip if other viewers with similar preferences watched the video clip in a positive manner. Watching the video in a positive manner may include, for example and without limitation, watching the entire clip, sharing the clip, or purchasing an item or service after watching the clip, to mention a few. A more extensive list of viewership parameters that indicate a positive viewing experience are described herein. While the conventional method for determining user preferences requires a viewer to rate a video clip actively, an effective alternative or supplemental process involves capturing viewership information by passive means and subsequently determining and analyzing user preferences based on captured viewership information.


Monitoring viewer behavior by passive means is useful because users are not required to spend time rating a video clip, something which they are less likely to do. As such, many more viewers have their viewing behavior captured, and a larger amount of behavior information is collected, recorded, and processed than would be otherwise possible if only actively supplied information is used for this purpose, as suggested by the prior art. Also, by concentrating on rating the user rather than just the video clip, it is more likely to be able to match preference similarities with other viewers because more facets of viewing behavior are available for analysis.


As such, in addition to allowing users to rate videos actively, an embodiment of the invention passively monitors and records various user behaviors when a user/viewer interacts with a network video player, e.g. a web video player, while watching an online video clip. In one embodiment, a data collection agent (DCA) is loaded to the player and/or to a web page that displays the video clip. The DCA passively collects detailed viewing and behavior information without requiring any specific input or actions on the part of the user. Indications of user preferences are inferred by user actions leading up to viewing the video, while viewing the video, and just after and still related to viewing the video. The DCA periodically sends this information to a central server where it is stored in a central database and where it is used to determine preference similarities among different users. Recorded user preference information may also be used to rate a video itself.


In one embodiment, the invention comprises a method and/or an apparatus for monitoring and recording when a user interacts with a video player while watching a video clip online. Specifically, a data collection agent (DCA) is loaded to the player or to a web page that displays the video clip. The DCA collects detailed viewing information and periodically sends this information to a central server. The viewing information is processed by the central server and the central server then generates any of a viewership attention span report, a viewership demographics report, a viewership geographic report, and a viewership sharing report. The attention span report and the sharing report provide inferred user preference information that is used to rate a video clip passively without requiring any specific input from the user/viewer. For purposes of the discussion herein, the terms watching, viewing, and playing are used as interchangeably. When a video clip is playing it is assumed that the viewer is viewing or watching the clip. However, the viewer may in fact be watching something else and not the video clip at a particular moment in time. There is no way to know for sure and, thus, the assumption is made.



FIG. 1 is a block schematic diagram of an arrangement of elements 100 that may be used in connection with the invention. These elements 100 include at least a web server 110 for hosting video sharing websites. The websites include, but are not limited to, YouTube™, MetaCafe™, Yahoo® video, Myspace.com®, users' blogs, etc.


A viewership analytics server (VAS) 120 is configured to connect to each web server 110 through a network 130, for example, but not limited to, a wide area network (WAN), which enables connectivity such as Internet connectivity. The VAS 120 executes the tasks related to gathering of viewership information for web servers 110, analyzing the gathered information, and generating reports on the quantity and characteristics of viewers, as well as providing information about the duration and repetition of each view. These tasks are described in greater detail below. The VAS 120 is connected to a database 140 in which the collected and generated viewership data is saved.


Clients 150-1 through 150-M communicate with web servers 110 through the network 130. A client 150 comprises at least a web browser, such as Microsoft® Internet Explorer, that allows the user to view and navigate through web pages downloaded from one or ⋅ more servers 110. Each client 150 is capable of downloading, playing, and displaying video clips provided by the servers 110. With this aim, each client 150 is capable of running a video player (not shown), which is typically integrated into a web page. The video player may be, but is not limited to, a Flash-based web player, DivX web player, HTML5 player, Microsoft Media Player, etc.


In accordance with the principles of the invention, a data collector agent (DCA) is loaded to video sharing websites that are hosted on servers 110 to capture information about the interactions of the viewers with web players. The DCA may be a script code, e.g. JavaScript, hosted by the VAS 120 and loaded to web pages hosted on servers 110. The DCA may be also in a form of a plug-in installed in the video players provided by video content providers.


The DCA collects and sends metadata and detailed viewing information to the VAS 120. The metadata comprises at least a video identification (ID), a publisher ID, a website ID that is derived from the uniform resource locator (URL), a length of the video clip being viewed, and the current time. The detailed viewing information includes the actions performed on the player and a timestamp. The recorded actions may be, for example, playing, pausing, rewinding, forwarding, and so on. The timestamp start and end times are expressed, for example, in seconds from the beginning of the video clip. For instance, the pair <play, 20-35> means that a user viewed the clip for only for 15 seconds starting at the 20.sup.th second from the beginning. The pair <pause, 30> means that the user paused 30 seconds after the beginning of the clip. The data gathered by the DCA is used by the VAS 120. In one embodiment, these requests are sent to the VAS 120 in the form of a hypertext transfer protocol (HTTP) request. An HTTP request that includes the metadata is sent to the VAS 120 once a web page, including the DCA, has completely uploaded to a client's 150 browser. The detailed viewing information, including the pairs of actions and timestamps, is periodically sent to the VAS 120. The VAS 120 extracts the data encapsulated in the received requests and saves the data in the database 140.


In accordance with one embodiment of the invention users, e.g. advertisers and content publishers, can access the VAS 120 through, for example, a client 150. This process is similar to that used when a user viewing the content accesses the VAS 120. Advertisers and content publishers can designate which websites, publishers, and video clips to trace. In one embodiment of the invention, the user views generated data from the VAS 120 by logging onto a website.



FIG. 2 is a block diagram showing the VAS 120 implemented in accordance with one embodiment of the invention. The VAS 120 includes an information collection module 210, an analyzer 220, and a graphical user interface (GUI) module 230. The collection module 210 communicates with a DCA on a client 150 for the purpose of receiving HTTP requests and responding thereto.


Specifically, the module 210 generates HTTP responses containing the script code of the DCA. The information collection module 210 further receives the HTTP requests, including the data collected by the DCA, extracts the information from the requests, and saves the information in the database 140. This information includes detailed viewing information and content metadata, which is saved together with tracking data including, but not limited to, the Internet protocol (IP) address, as well as the operating system and browser type of the client 150. The detailed viewing information is saved in an entry associated with the video ID. In an exemplary embodiment, the database 140 includes a table having the following fields: video_ID, website_ID, publisher_ID, date, IP, OS, browser type, and <action, timestamp> pairs.


The analyzer 220 processes the information saved in the database 140 to generate viewership-related analytics data, an attention span report, and viewership demographics. Viewership-related analytics data includes, but is not limited to, the number of viewers during any period of time, e.g. last three days, last week, last months, etc. for a video clip, for a publisher, or for a group of video clips over different periods of time. This information can be generated for a single website or across a plurality of websites. To generate the analytics data mentioned herein, the analyzer 220 first computes the number of viewers in each day, or any other time interval, from the gathered information. The process for generating the viewership-related analytics data is further discussed in U.S. patent application Ser. No. 11/871,880, A Method and System for Monitoring Online Video, assigned to a common assignee, the entirety of which is incorporated herein by this reference thereto.


The analyzer 220 also generates an attention span report that includes detailed information about the duration and repetition of each view. This report includes, per each video clip, the total number of viewers, and the number of viewers that viewed the complete video clip. This report is produced by processing the data stored in the database 140. In addition, the analyzer 220 produces a viewership-geographic report. This report includes the number of viewers of a video clip in each country around the globe. The report is generated by correlating the number of views with IP addresses of the different viewers. Furthermore, a viewership demographics report is generated by analyzer 220. This report correlates the number of viewers with demographics including race, age, income, educational attainment, employment status, etc. The demographics are retrieved from the users profiles as saved in the online video websites, if and when available.


In accordance with another embodiment, the analyzer 220 can detect fraud attempts. Such attempts are typically performed by browser refreshes or scripting intended to inflate the view count artificially. With this aim, the analyzer 220 maintains a history file of the video IDs that have been viewed in the past during a predefined period of time, e.g. video clips viewed in last two hours, by each IP address. If the analyzer 220 detects multiple views above a threshold from the same IP address within a predefined period time, the analyzer 220 discards the data regarding the subsequent views or any views. The analyzer 220 also validates that the database 140 does not contain timestamp entries with duration longer than the length of the video clip. This check protects against scripting attacks intended to record repeated video views under a single view count.


The GUI 230 displays the viewership-related analytics data produced by the analyzer 220 as charts or text-based reports. In one embodiment, the charts are dynamic. That is, the GUI 230 dynamically changes the displayed content of the chart as the user changes the chart's time scale. FIGS. 3A-3C show examples of charts of the various reports as generated by the GUI 230 according to several embodiments of the invention. FIG. 3A is a chart that shows an attention span report. FIG. 3B is a chart representing the viewership by geography. FIG. 3C shows charts of viewership demographics, specifically, the age distribution and gender distribution of viewers.



FIG. 4 is a flowchart 400 that shows the steps for operating the DCA in accordance with one embodiment of the invention. When a web page that includes a video clip is loaded, the DCA is inserted S410 on the page and sets a third party cookie in the browser. The third party cookie is used to track the video viewing activity of each unique user across all video providers. The DCA is inserted on the web page using an HTTP response from the server 110 and contains a script code. The DCA generates S420 an HTTP request that includes metadata and sends the request to the VAS 120. This request contains the provider site in the URL path and the ID of the video being viewed, the local client's current time, the client time zone offset, and the non-personally identifiable provider user ID. The VAS 120, upon receiving this request, extracts the metadata and saves it in database 140. Once the video clip is internally loaded in the player, the DCA generates S430 HT″TP requests that include the detailed viewing information, for example in the format described above. Thereafter, these HTTP requests are periodically sent S440 to the VAS 120. Once the web page is closed or the browser window location is changed while a video clip is being viewed, the DCA transmits an HTTP request that includes the final data pair that ends at the current viewing time-point.


The earlier discussion regarding FIG. 1 refers to collecting detailed information about the duration and repetition for viewing a particular video clip. The DCA functionality residing in the viewer's computer 150 or supplying website 110 collects this information passively and may include detailed information to enable further analysis of parameters related, for instance, to viewing duration and repetition. For instance, the DCA may passively record whether a viewer watched a particular video clip at all. It may also record what specific portions of a video clip the viewer watched and the sequence in which they watched those portions. Viewers are known to rewind entire videos, rewind portions of a video, or skip around within a particular video, watching different portions in a regular or irregular sequence. In fact, many other actions of a viewer may be passively observed and used to rate the viewer according to their preferences as well as rate a video clip itself. FIG. 5 is a flowchart 500 that shows the steps for passively collecting and processing behavior or viewership information related to a video clip. Viewer actions that reflect their preferences with respect to a particular video clip may occur before they play the clip, given some foreknowledge of the clip content; while they watch the clip; and after they watch the clip. In step S510, parameters respective of a viewer's behavior and actions leading up to their playing a video clip are recorded. Examples of such actions include but are not limited to:


(i) Enduring a pre-roll advertisement, thus showing an affinity and/or tolerance for ads;


(ii) Accessing the video clip by a particular method:


(a) Authenticating or logging-in, thus showing higher interest, to view the video clip;


(b) Being incentivized to see the video, such as obtaining points in an online game; and


(iii) Adjusting the bit rate for streaming or downloading the video prior to playing it, and in which direction they adjusted the bit rate, e.g. faster or slower.


(iv) Clicking Play in the event that the video isn't auto-playing.


In step S520, parameters respective of a viewer's behavior and actions during their playing of a video clip are recorded. Examples of such actions include but are not limited to:


(i) Adjusting the volume level, muting, and un-muting;


(ii) Pausing and un-pausing;


(iii) Fast-forwarding and rewinding;


(iv) Replaying the video clip, how many times it was replayed, and what portion was replayed;


(v) Viewing duration and % completion;


(vi) Viewing in full-screen mode;


(vii) Adjusting the bit rate for streaming or downloading the video while playing it, and in which direction did they adjust the bit rate, e.g. faster or slower;


(viii) Clicking-through on an overlay image or the video itself to be taken to another webpage or website;


(ix) Spending time viewing certain segments of the video clip that are judged to have higher value based on actions of previous viewers; and


(x) Enduring a mid-roll advertisement, thus showing an affinity and/or tolerance for ads.


In step S530, parameters respective of a viewer's behavior and actions after playing of a video clip are recorded. Examples of such actions include but are not limited to:


(i) Sharing the video via an embed code. Generally, with online video a user can copy a small HTML tag out and paste it into their blog to share the video. The system according to the invention tracks the action of copying out that HTML code. Such action may be the operation of a button or simply the act of highlighting the text in a textbox;


(ii) Sharing the video via E-mail;


(iii) Sharing the video via a social network;


(iv) Sharing the video in multiple separate events and how many separate sharing events the viewer initiated to share the video clip;


(v) Waiting for a recorded time duration between viewing the video clip and initiating a sharing event;


(vi) Bookmarking the video clip for later viewing;


(vii) Downloading and saving the video for later viewing; and


(viii) Subscribing to a channel or feed for the video content producer or artist to become better aware of new videos.


In step S540, a viewer preference score is created for the video clip based on the particular viewer's behavior and the score is associated with the user as metadata. In step S550, a video clip score is created for the video clip based on the particular viewer's behavior and the score is associated with the video clip as metadata. When a score is calculated for either the user's preference or the video clip itself, the different factors above that contribute to the score are optionally weighted in the score calculation. For instance, the fact that a video clip is shared may have more value in calculating a preference score than the fact that they paused the video clip. The weighting may also be different for calculating the score for a user's preference relative to a particular clip as opposed to the score for the clip itself. For instance, the fact that the viewer watched the pre-roll advertisement may be more valuable for scoring the user than for scoring the video. Another example of weighting occurs where an un-mute or full-screen action is considered to be a highly-valuable action, whereas simple viewing duration for a video that plays automatically may not be, as it may simply be playing in the user's browser without their attention.


In step S560, the viewer preference score and the video clip score are recorded in a database.


Network 600 in FIG. 6 shows a flow of information within an embodiment of the invention with regard to sharing of information related to video clips between users. Sharing typically occurs by way of a wide-area network 130 normally comprising the Internet or a portion thereof. The sharing process is initiated by the terminal belonging to a primary viewer/user 150 who decides that a particular video clip is interesting enough or entertaining enough to share with a friend. A terminal or communication device 640 as shown would typically be used by a friend or a group of friends. Many types of communication devices or terminals are known in the art to be used for communication within social networks and include PCs and smart phones. The process is initiated when the primary viewer at terminal 150 is supplied a video clip 610 from a webpage 110. This video clip may be supplied automatically without any initiation by the user, or it may be supplied to the user upon some action the user takes to view the video clip. When the primary viewer decides they wish to share a video clip they may be offered the ability to share by way of webpage 110, or alternately by providing the link to the particular video clip to a third-party link sharing website 660. When a sharing request 620 is made by viewer 150 to website 110, website 110 can notify a friend at terminal 640 via email or directly if the friend at terminal 640 is logged into website 110.


User 150 may also share the link to a video clip through communication path 650 and a third-party website 660 where link sharing is supported. Examples of link sharing websites include, but are not limited to, digg, del.icio.us, and reddit. Links to video clips can also be shared in a similar manner via social networking sites such as Facebook® and twitter. Sharing behaviors can be monitored by DCA functions located in the viewer's computer 150, located on a server at the supplying website 110, or both. Data gathered by these DCA functions is periodically transferred to VAS 120 for logging, analysis, and reporting. The link sharing website may communicate with a friend using terminal 640 via email or directly if terminal 640 is logged into website 660. In addition to the sharing mechanisms described in FIG. 6, sharing may also be accomplished via an embed code as previously described for step S530 of FIG. 5.


Passively monitored sharing activity may include at least one or more of the following:


i. If a viewer shared a particular video clip;


ii. How many times they shared the video clip;


iii. How many persons they shared the clip with;


iv. Which sharing mechanisms and/or websites they chose to use to share the video clip; and


v. The time duration between when they watched the clip and when they shared it.


While immediately sharing a video clip certainly shows interest, sharing the video clip after a period of time has passed shows that the video clip left a lasting impression on the viewer. Also, should the user initiate a large number of separate sharing events or sharing actions for a particular video clip, this may provide an indication that the video clip deserves a higher score for the sharing-based component of its score.


Thus, passively observed user actions and behaviors are used to rate a particular user's preferences relative to the video clip in question, as well as rate the video clip itself.


One parameter that may be passively acquired and then used as a component of a viewing preference analysis is viewing duration. FIG. 7 shows an exemplary and non-limiting table 700 containing elements of a viewing duration analysis for a sample of video clips. Each of video clips A through G have been previously viewed by at least two of the three viewers shown: Joe, Bill, and Jane. For this example, it is assumed for the sake of simplicity that a judgment is made based solely on viewing duration analysis. In reality, the judgment relative to the likelihood of a viewer choosing to view a new video is far more complex and may include any or all of the viewership parameters discussed previously that may be passively captured prior, during, or after the viewing of a video clip, or alternately proactively supplied by a viewer.


For the analysis of FIG. 7, note that for video A the viewing durations for Joe and Bill were both high, indicating a similar preference level with regard to this parameter. Likewise for video B, the viewing duration for all three viewers was low, indicating again a similar preference level. Note that preference similarities may be positive or negative, and the degree of similarity is used by analysis algorithms according to the invention to determine a likeliness score, that score indicating the likelihood that a prospective viewer chooses to watch a video they have not seen before. For videos C, F, and G, there does not exist enough commonality of viewing to be useful in making a judgment. Thus, the greatest similarity of preferences among the viewers shown in FIG. 7 with regard to previously viewed videos is between Joe and Bill. Later, an opportunity arises to present to Bill a new video 710 called video Z. Bill has not seen video Z before.


An analysis of the database containing preferences relative to previously viewed videos shows that because Joe had viewed video Z with a 95% viewing duration, there is a high likelihood that Bill chooses to watch video Z when it is offered to him. If video Z is an advertisement video clip where an advertiser bids for the opportunity to present the clip, the likeliness score for Bill to watch video Z may be used to determine the amount of the bid, i.e. the higher the likeliness score, the higher the bid.



FIG. 8 is a block diagram 800 describing one possible organization of viewers in a database according to the invention. For simplicity and in keeping with the simplified example of FIG. 7, diagram 800 of FIG. 8 refers to an organization in keeping with table 700 of FIG. 7 and, in particular, refers to the grouping of viewers in the database with respect to video clip Z. Group (1) 810 comprises viewers of previous video clips who have not viewed video clip Z. With respect to FIG. 7, this group contains Bill and Jane. Group (2) 820 comprises viewers who have viewed clip Z in a positive manner. With respect to FIG. 7, this group contains Joe. Group (3) 830 comprises viewers who have not yet viewed video clip Z, however have preference similarities most closely aligned to viewers in Group (2) 820 who have previously viewed clip Z in a positive manner. With respect to FIG. 7, Group (3) 830 contains Bill. Thus, Bill is deemed to have a high likelihood of choosing to watch video clip Z if and when it is presented to him.



FIG. 9 shows a flowchart 900 whereby preference similarities are determined and analyzed to determine the likelihood that a viewer chooses to watch a particular video clip when presented.


In step 910, a database is constructed based on captured viewership information respective of a first set of video clips. The capturing process for viewership information may be active whereby the viewer proactively supplies preference information, or passive whereby viewership information is captured without requiring any action by the viewer in accordance with one or more methods previously described for the invention.


In step 920, the database is analyzed to determine preference similarities among viewers who have previously viewed the first set of video clips.


In step 930, viewer characteristics respective of a second video clip are captured and recorded in the database. Typically, some of the viewers of the second video clip have previously watched the first video clip.


Subsequently in step 940, viewership characteristics respective of the second video clip are analyzed with respect to the database to produced a list of viewers in the database who are deemed most likely to watch the second video if and when it is offered to them. As described for FIG. 7, a prospective viewer who has not seen the second video, but has strong preference similarities with someone who has responded in a positive manner to viewing the second video, is determined to be a likely candidate to watch the second video when presented. The degree of likelihood is computed according to the present invention by analyzing each preference-related parameter of the viewership information, weighting the parameters as appropriate, and developing a likelihood score as a result. Should the second video clip be an advertisement, and should the advertiser be required to place a bid to offer the video to the prospective viewer, the amount of the bid is determined based at least in part on the likelihood score.


In step 950, the second video clip is presented to the prospective viewer who was previously determined to be part of a list or group of viewers likely to choose to watch the second video clip.


It should be appreciated by a person skilled in the art that methods, processes and systems described herein can be implemented in software, hardware, firmware, or any combination thereof. The implementation may include the use of a computer system having a processor and a memory under the control of the processor, the memory storing instructions adapted to enable the processor to carry out operations as described hereinabove. The implementation may be realized, in a concrete manner, as a computer program product that includes a tangible computer readable medium holding instructions adapted to enable a computer system to perform the operations as described above.


Although the invention is described herein with reference to the preferred embodiment, one skilled in the art will readily appreciate that other applications may be substituted for those set forth herein without departing from the spirit and scope of the present invention. Accordingly, the invention should only be limited by the Claims included below.

Claims
  • 1. A computer-implemented method for serving video clips comprising: determining a subset of viewers of a video, from viewers of the video, that shared the video within a threshold period of time after viewing the video based on passive actions of the viewers of the video;generating a viewer characteristic profile for the video based on characteristics of viewers in the subset of viewers of the video, the viewer characteristic profile for the video reflecting characteristics of a viewer most likely to have a positive interaction with the video;determining a likelihood score of a prospective viewer based on a profile for the prospective viewer and the viewer characteristic profile for the video;determining that the likelihood score of the prospective viewer is above a defined likelihood level; andserving, over a network, the video to a client device associated with the prospective viewer based on the determination that the likelihood score of the prospective viewer is above the defined likelihood level.
  • 2. The computer-implemented method of claim 1, further comprising inserting a data collection script into a player or webpage that displays videos, the data collection script programmed to monitor viewer activity relative to the videos.
  • 3. The computer-implemented method of claim 2, further comprising: determining the passive actions of the viewers of the video relative to the video by: receiving HTTP requests from client devices having interacted with the video; andextracting metadata from the HTTP requests indicating one or more passive actions relative to the video; anddetermining the subset of viewers of the video based on the passive actions of the viewers of the video.
  • 4. The computer-implemented method of claim 1, further comprising: determining the passive actions of the viewers of the video relative to the video by determining whether the viewers performed, prior to commencement of the video, one or more of: viewing a pre-roll advertisement,accessing the video by a particular method,adjusting a bit rate for streaming or downloading the video prior to playing the video, orclicking play if the video is not an auto-playing video; anddetermining the subset of viewers of the video based on the passive actions of the viewers of the video.
  • 5. The computer-implemented method of claim 1, further comprising: determining the passive actions of the viewers of the video relative to the video by determining whether the viewers performed, during play of the video, one or more of: adjusting a volume level, muting, or un-muting the video,pausing or un-pausing the video,fast-forwarding or rewinding the video,replaying the video,viewing the video for a recorded duration or percent completion,viewing the video in full-screen mode,adjusting a bit rate for streaming or downloading the video,clicking-through on an overlay image or on the video itself,spending time viewing certain segments of the video, orviewing a mid-roll advertisement; anddetermining the subset of viewers of the video based on the passive actions of the viewers of the video.
  • 6. The computer-implemented method of claim 1, further comprising: determining the passive actions of the viewers of the video relative to the video by determining whether the viewers performed, after completion of the video, one or more of: sharing the video via an embedded code,sharing the video via e-mail,sharing the video via a social network,sharing the video in multiple separate events,bookmarking the video for later viewing,downloading and saving the video for later viewing, orsubscribing to a channel or feed associated with the video; anddetermining the subset of viewers of the video based on the passive actions of the viewers of the video.
  • 7. The computer-implemented method of claim 1, further comprising determining the subset of viewers of the video that shared the video or purchased an item or service after watching the video based on the passive actions of the viewers of the video.
  • 8. A system for serving video clips comprising: at least one server; andat least one non-transitory computer readable storage medium storing instructions thereon, that, when executed by the at least one server, cause the system to: determine a subset of viewers of a video that shared the video within a threshold period of time after viewing the video based on passive actions of the viewers of the video;generate a viewer characteristic profile for the video based on characteristics of viewers in the subset of viewers of the video, the viewer characteristic profile for the video reflecting characteristics of a viewer most likely to have a positive interaction with the video;determine a likelihood score of a prospective viewer based on a profile for the prospective viewer and the viewer characteristic profile for the video;determine that the likelihood score of the prospective viewer is above a defined likelihood level; andserve, over a network, the video to a client device associated with the prospective viewer based on the determination that the likelihood score of the prospective viewer is above the defined likelihood level.
  • 9. The system of claim 8, further comprising instructions that, when executed by the at least one server, cause the system to: insert a data collection script into a player or webpage that displays videos, the data collection script programmed to monitor viewer activity relative to the videos; anddetermine the passive actions of the viewers of the video relative to the video by: receiving HTTP requests from client devices having interacted with the video; andextracting metadata from the HTTP requests indicating one or more passive actions relative to the video.
  • 10. The system of claim 8, further comprising instructions that, when executed by the at least one server, cause the system to: determine the passive actions of the viewers of the video relative to the video during one or more of a period of time prior to commencement of the video, during play of the video, or after completion of the video; anddetermine the subset of viewers of the video based on the passive actions of the viewers of the video.
  • 11. The system of claim 8, further comprising instructions that, when executed by the at least one server, cause the system to: determine the passive actions of the viewers of the video relative to the video by determining whether the viewers performed, prior to commencement of the video, one or more of: viewing a pre-roll advertisement,accessing the video by a particular method,adjusting a bit rate for streaming or downloading the video prior to playing the video, orclicking play if the video is not an auto-playing video; anddetermine the subset of viewers of the video based on the passive actions of the viewers of the video.
  • 12. The system of claim 8, further comprising instructions that, when executed by the at least one server, cause the system to: determine the passive actions of the viewers of the video relative to the video by determining whether the viewers performed, during play of the video, one or more of: adjusting a volume level, muting, or un-muting the video,pausing or un-pausing the video,fast-forwarding or rewinding the video,replaying the video,viewing the video for a recorded duration or percent completion,viewing the video in full-screen mode,adjusting a bit rate for streaming or downloading the video,clicking-through on an overlay image or on the video itself,spending time viewing certain segments of the video, orviewing a mid-roll advertisement; anddetermine the subset of viewers of the video based on the passive actions of the viewers of the video.
  • 13. The system of claim 8, further comprising instructions that, when executed by the at least one server, cause the system to: determine the passive actions of the viewers of the video relative to the video by determining whether the viewers performed, after completion of the video, one or more of: sharing the video via an embedded code,sharing the video via e-mail,sharing the video via a social network,sharing the video in multiple separate events,bookmarking the video for later viewing,downloading and saving the video for later viewing, orsubscribing to a channel or feed associated with the video; anddetermine the subset of viewers of the video based on the passive actions of the viewers of the video.
  • 14. The system of claim 8, further comprising instructions that, when executed by the at least one server, cause the system to determine the subset of viewers of the video that shared the video or purchased an item or service after watching the video based on the passive actions of the viewers of the video.
  • 15. A non-transitory computer-readable medium storing instructions thereon that, when executed by at least one processor, cause a computing device to: determine a subset of viewers of a video that shared the video within a threshold period of time after viewing the video based on passive actions of the viewers of the video;generate a viewer characteristic profile for the video based on characteristics of viewers in the subset of viewers of the video, the viewer characteristic profile for the video reflecting characteristics of a viewer most likely to have a positive interaction with the video;determine a likelihood score of a prospective viewer based on a profile for the prospective viewer and the viewer characteristic profile for the video;determine that the likelihood score of the prospective viewer is above a defined likelihood level; andserve, over a network, the video to a client device associated with the prospective viewer based on the determination that the likelihood score of the prospective viewer is above the defined likelihood level.
  • 16. The non-transitory computer-readable medium of claim 15, further comprising instructions that, when executed by the at least one processor, cause the computing device to: insert a data collection script into a player or webpage that displays videos, the data collection script programmed to monitor viewer activity relative to the videos; anddetermine the passive actions of the viewers of the video relative to the video by: receiving HTTP requests from client devices having interacted with the video; andextracting metadata from the HTTP requests indicating one or more passive actions relative to the video.
  • 17. The non-transitory computer-readable medium of claim 15, further comprising instructions that, when executed by the at least one processor, cause the computing device to: determine the passive actions of the viewers of the video relative to the video during one or more of a period of time prior to commencement of the video, during play of the video, or after completion of the video; anddetermine the subset of viewers of the video based on the passive actions of the viewers of the video.
  • 18. The non-transitory computer-readable medium of claim 15, further comprising instructions that, when executed by the at least one processor, cause the computing device to: determine the passive actions of the viewers of the video relative to the video by determining whether the viewers performed, prior to commencement of the video, one or more of: viewing a pre-roll advertisement,accessing the video by a particular method,adjusting a bit rate for streaming or downloading the video prior to playing the video, orclicking play if the video is not an auto-playing video; anddetermine the subset of viewers of the video based on the passive actions of the viewers of the video.
  • 19. The non-transitory computer-readable medium of claim 15, further comprising instructions that, when executed by the at least one processor, cause the computing device to: determine the passive actions of the viewers of the video relative to the video by determining whether the viewers performed, during play of the video, one or more of: adjusting a volume level, muting, or un-muting the video,pausing or un-pausing the video,fast-forwarding or rewinding the video,replaying the video,viewing the video for a recorded duration or percent completion,viewing the video in full-screen mode,adjusting a bit rate for streaming or downloading the video,clicking-through on an overlay image or on the video itself,spending time viewing certain segments of the video, orviewing a mid-roll advertisement; anddetermine the subset of viewers of the video based on the passive actions of the viewers of the video.
  • 20. The non-transitory computer-readable medium of claim 15, further comprising instructions that, when executed by the at least one processor, cause the computing device to: determine the passive actions of the viewers of the video relative to the video by determining whether the viewers performed, after completion of the video, one or more of: sharing the video via an embedded code,sharing the video via e-mail,sharing the video via a social network,sharing the video in multiple separate events,bookmarking the video for later viewing,downloading and saving the video for later viewing, orsubscribing to a channel or feed associated with the video; anddetermine the subset of viewers of the video based on the passive actions of the viewers of the video.
CROSS REFERENCE TO RELATED APPLICATIONS

This application is a continuation of U.S. patent application Ser. No. 15/348,780, filed Nov. 10, 2016, which is continuation of U.S. patent application Ser. No. 13/111,705, filed on May 19, 2011, now issued as U.S. Pat. No. 9,612,995, which is a continuation-in-part of U.S. patent application Ser. No. 12/904,552, filed Oct. 14, 2010, now issued as U.S. Pat. No. 8,549,550, which is a continuation-in-part of U.S. patent application Ser. No. 12/212,556, filed Sep. 17, 2008, now issued as U.S. Pat. No. 8,577,996. The aforementioned applications are hereby incorporated by reference in their entirety.

US Referenced Citations (176)
Number Name Date Kind
5617486 Chow et al. Apr 1997 A
5778340 Hattori Jul 1998 A
5864810 Digalakis et al. Jan 1999 A
5951642 Onoe Sep 1999 A
6134532 Lazarus et al. Oct 2000 A
6208720 Curtis Mar 2001 B1
6223159 Ishii Apr 2001 B1
6285999 Page Sep 2001 B1
6343267 Kuhn et al. Jan 2002 B1
6389377 Pineda et al. May 2002 B1
6505169 Bhagavath et al. Jan 2003 B1
6557042 He et al. Apr 2003 B1
6560578 Eldering et al. May 2003 B2
6704930 Eldering et al. Mar 2004 B1
6879956 Honda et al. Apr 2005 B1
6888477 Lai et al. May 2005 B2
6907566 McElfresh et al. Jun 2005 B1
6944585 Pawson Sep 2005 B1
6952419 Cassiday et al. Oct 2005 B1
7065488 Yajima et al. Jun 2006 B2
7117439 Barrett et al. Oct 2006 B2
7136875 Anderson et al. Nov 2006 B2
7146416 Yoo et al. Dec 2006 B1
7149772 Kalavade Dec 2006 B1
7356590 Wilson et al. Apr 2008 B2
7822636 Ferber et al. Oct 2010 B1
8060463 Spiegel Nov 2011 B1
8301497 Amini et al. Oct 2012 B2
8549550 Lopatecki Oct 2013 B2
8577996 Hughes et al. Nov 2013 B2
9485316 Lopatecki et al. Nov 2016 B2
9612995 Lopatecki Apr 2017 B2
9781221 Lopatecki et al. Oct 2017 B2
9967603 Lopatecki May 2018 B2
20020032904 Lerner Mar 2002 A1
20020049635 Mai et al. Apr 2002 A1
20020059604 Papagan et al. May 2002 A1
20020068525 Brown et al. Jun 2002 A1
20020082941 Bird Jun 2002 A1
20020087980 Eldering et al. Jul 2002 A1
20020144261 Schwalb et al. Oct 2002 A1
20020174425 Markel et al. Nov 2002 A1
20030050863 Radwin Mar 2003 A1
20030055729 Bezos et al. Mar 2003 A1
20030055951 Chemali Mar 2003 A1
20030061566 Rubstein et al. Mar 2003 A1
20030070167 Holtz et al. Apr 2003 A1
20030076347 Barrett et al. Apr 2003 A1
20030079226 Barrett Apr 2003 A1
20030101230 Benschoter et al. May 2003 A1
20030110485 Lu et al. Jun 2003 A1
20030121046 Roy et al. Jun 2003 A1
20030142670 Gould et al. Jul 2003 A1
20030174837 Candelore et al. Sep 2003 A1
20030206720 Abecassis Nov 2003 A1
20030220791 Toyama Nov 2003 A1
20040001081 Marsh Jan 2004 A1
20040003397 Boston et al. Jan 2004 A1
20040051812 Hayward Mar 2004 A1
20040059708 Dean Mar 2004 A1
20040059712 Dean et al. Mar 2004 A1
20040073918 Ferman et al. Apr 2004 A1
20040093327 Anderson et al. May 2004 A1
20040172267 Patel et al. Sep 2004 A1
20040204983 Shen et al. Oct 2004 A1
20040221309 Zaner et al. Nov 2004 A1
20040267806 Lester Dec 2004 A1
20050021403 Ozer et al. Jan 2005 A1
20050076357 Fenne Apr 2005 A1
20050102375 Varghese May 2005 A1
20050114198 Koningstein et al. May 2005 A1
20050114367 Serebrennikov May 2005 A1
20050137958 Huber et al. Jun 2005 A1
20050149396 Horowitz et al. Jul 2005 A1
20050182626 Kim et al. Aug 2005 A1
20050190973 Kristensson et al. Sep 2005 A1
20050192802 Robinson et al. Sep 2005 A1
20050210145 Kim et al. Sep 2005 A1
20050246348 Hijikata et al. Nov 2005 A1
20060026067 Nicholas et al. Feb 2006 A1
20060026628 Wan et al. Feb 2006 A1
20060031187 Pyrce Feb 2006 A1
20060058999 Barker et al. Mar 2006 A1
20060063587 Manzo Mar 2006 A1
20060064500 Roth et al. Mar 2006 A1
20060074753 Schuh et al. Apr 2006 A1
20060116924 Angles et al. Jun 2006 A1
20060135232 Willis Jun 2006 A1
20060156326 Goronzy et al. Jul 2006 A1
20060161553 Woo Jul 2006 A1
20060167749 Pitkow et al. Jul 2006 A1
20060212350 Ellis et al. Sep 2006 A1
20060212897 Li et al. Sep 2006 A1
20060224444 Koningstein et al. Oct 2006 A1
20060224448 Herf Oct 2006 A1
20060242016 Chenard Oct 2006 A1
20070055986 Gilley et al. Mar 2007 A1
20070067215 Agarwal et al. Mar 2007 A1
20070078707 Axe et al. Apr 2007 A1
20070078948 Julia et al. Apr 2007 A1
20070094363 Yruski et al. Apr 2007 A1
20070101387 Hua et al. May 2007 A1
20070112567 Lau et al. May 2007 A1
20070112630 Lau et al. May 2007 A1
20070118848 Schwesinger et al. May 2007 A1
20070184820 Marshall Aug 2007 A1
20070219984 Aravamudan et al. Sep 2007 A1
20070226365 Hildreth et al. Sep 2007 A1
20070268164 Lai et al. Nov 2007 A1
20070300258 O'Connor et al. Dec 2007 A1
20080010339 Shin et al. Jan 2008 A1
20080010654 Barrett et al. Jan 2008 A1
20080045336 Stelzer et al. Feb 2008 A1
20080046562 Butler Feb 2008 A1
20080059312 Gern et al. Mar 2008 A1
20080066107 Moonka et al. Mar 2008 A1
20080092159 Dmitriev Apr 2008 A1
20080098301 Black et al. Apr 2008 A1
20080101763 Bhogal et al. May 2008 A1
20080109300 Bason May 2008 A1
20080109391 Chan May 2008 A1
20080133475 Fischer Jun 2008 A1
20080178198 Gauba Jul 2008 A1
20080178234 Eyal Jul 2008 A1
20080183555 Walk Jul 2008 A1
20080195761 Jabri et al. Aug 2008 A1
20080207182 Maharajh et al. Aug 2008 A1
20080228576 Yonezaki Sep 2008 A1
20080228581 Yonezaki et al. Sep 2008 A1
20080250445 Zigmond et al. Oct 2008 A1
20080288973 Carson et al. Nov 2008 A1
20080300989 Coker et al. Dec 2008 A1
20080307454 Ahanger Dec 2008 A1
20080319827 Yee et al. Dec 2008 A1
20080320531 Kim et al. Dec 2008 A1
20090007172 Ahanger et al. Jan 2009 A1
20090013347 Ahanger et al. Jan 2009 A1
20090019488 Ruiz-Velasco et al. Jan 2009 A1
20090077033 McGary et al. Mar 2009 A1
20090089830 Chandratillake et al. Apr 2009 A1
20090094520 Kulas Apr 2009 A1
20090100456 Hughes Apr 2009 A1
20090119169 Chandratillake et al. May 2009 A1
20090144780 Toebes et al. Jun 2009 A1
20090171728 Yan et al. Jul 2009 A1
20090183210 Andrade Jul 2009 A1
20090259551 Chenard et al. Oct 2009 A1
20090259552 Chenard et al. Oct 2009 A1
20090328105 Craner Dec 2009 A1
20100011020 Bouzid et al. Jan 2010 A1
20100023960 Hasson Jan 2010 A1
20100049613 Angles et al. Feb 2010 A1
20100057576 Brodersen et al. Mar 2010 A1
20100088394 Barbieri et al. Apr 2010 A1
20100088614 Barbieri et al. Apr 2010 A1
20100095317 Toebes et al. Apr 2010 A1
20100114696 Yang May 2010 A1
20100191680 Lee et al. Jul 2010 A1
20100242060 Liu et al. Sep 2010 A1
20100251305 Kimble et al. Sep 2010 A1
20100287580 Harding et al. Nov 2010 A1
20100318611 Curtin Dec 2010 A1
20110010231 Price et al. Jan 2011 A1
20110029666 Lopatecki et al. Feb 2011 A1
20110072449 Ivanyi Mar 2011 A1
20110078018 Chunilal Mar 2011 A1
20110078740 Bolyukh et al. Mar 2011 A1
20110093783 Parra Apr 2011 A1
20110125573 Yonezaki et al. May 2011 A1
20110295716 Dumon et al. Dec 2011 A1
20120278169 Lau et al. Nov 2012 A1
20130145388 Girouard et al. Jun 2013 A1
20130185153 Howcroft Jul 2013 A1
20140298373 Jing et al. Oct 2014 A1
20170094331 Lopatecki et al. Mar 2017 A1
20170346913 Lopatecki Nov 2017 A1
Foreign Referenced Citations (1)
Number Date Country
WO 2006-076661 Jul 2006 WO
Non-Patent Literature Citations (35)
Entry
Chorianopoulos, K et al., “Affective Usability Evaluation for an Interactive Music Television Channel”, ACM Computer in Entertainment. vol. 2, No. 3. Article 78. Retrieved Apr. 24, 2008 from the internet: http://www.dmst.aueb.gr/dds/pubs/jrnl/2004-CIE-VC/html/CS04b.pdf, Jul. 2004, 1-11.
Hanjalic, A et al., “Affective Video Content Representation and Modeling”, IEEE Transactions on Multimedia. vol. 7, No. 1., Feb. 2005, pp. 143-154.
Mihalcea, R et al., “A Corpus-Based Approach to Finding Happiness”, AAAI Spring Symposium, Mar. 2006, pp. 1-6.
Mihalcea, R et al., “Learning to Laugh (Automatically): Computational Models for Humor Recognition”, Computational Intelligence. vol. 22, Issue 2., May 2006, pp. 126-142.
Young, S et al., “The HTK Book”, Microsoft. Hidden Markov Model Toolkit User Manual., Jul. 2000, 277 pages.
Flanagan, David, “JavaScript: The Definitive Guide, 5th Edition”, O'Reilly Media, (Aug. 17, 2006), pp. 271-272 and 536-538.
U.S. Appl. No. 11/871,880, filed Dec. 9, 2009, Office Action.
U.S. Appl. No. 11/871,880, filed Jun. 8, 2010, Office Action.
U.S. Appl. No. 11/871,880, filed Dec. 20, 2010, Office Action.
U.S. Appl. No. 11/871,880, filed Aug. 10, 2011, Office Action.
U.S. Appl. No. 12/212,556, filed Nov. 17, 2009, Office Action.
U.S. Appl. No. 12/212,556, filed May 13, 2010, Office Action.
U.S. Appl. No. 12/212,556, filed Sep. 21, 2010, Office Action.
U.S. Appl. No. 12/212,556, filed Mar. 10, 2011, Office Action.
U.S. Appl. No. 12/212,556, filed May 10, 2012, Office Action.
U.S. Appl. No. 12/212,556, filed Feb. 4, 2013, Office Action.
U.S. Appl. No. 12/212,556, filed Aug. 22, 2013, Notice of Allowance.
U.S. Appl. No. 12/904,552, filed Apr. 26, 2012, Office Action.
U.S. Appl. No. 12/904,552, filed Dec. 18, 2012, Office Action.
U.S. Appl. No. 12/904,552, filed May 30, 2013, Notice of Allowance.
U.S. Appl. No. 13/111,705, filed Jul. 31, 2014, Office Action.
U.S. Appl. No. 13/111,705, filed Mar. 10, 2015, Office Action.
U.S. Appl. No. 13/111,705, filed Feb. 23, 2016, Office Action.
U.S. Appl. No. 13/111,705, filed Aug. 10, 2016, Office Action.
U.S. Appl. No. 13/111,705, filed Nov. 16, 2016, Notice of Allowance.
U.S. Appl. No. 13/975,196, filed Jul. 21, 2015, Office Action.
U.S. Appl. No. 13/975,196, filed May 13, 2016, Office Action.
U.S. Appl. No. 13/975,196, filed Sep. 26, 2016, Notice of Allowance.
U.S. Appl. No. 15/285,356, filed Feb. 10, 2017, Office Action.
U.S. Appl. No. 15/285,356, filed May 18, 2017, Notice of Allowance.
U.S. Appl. No. 15/348,780, filed Oct. 5, 2017, Office Action.
U.S. Appl. No. 15/348,780, filed Feb. 5, 2018, Notice of Allowance.
U.S. Appl. No. 15/680,605, filed Jun. 7, 2018, Preinterview 1st OA.
U.S. Appl. No. 15/680,605, filed Sep. 21, 2018, Office Action.
U.S. Appl. No. 15/680,605, filed Feb. 6, 2019, Notice of Allowance.
Related Publications (1)
Number Date Country
20180227615 A1 Aug 2018 US
Continuations (2)
Number Date Country
Parent 15348780 Nov 2016 US
Child 15940882 US
Parent 13111705 May 2011 US
Child 15348780 US
Continuation in Parts (2)
Number Date Country
Parent 12904552 Oct 2010 US
Child 13111705 US
Parent 12212556 Sep 2008 US
Child 12904552 US