The present document relates to techniques for identifying multi-media content and associated information on a television device or a video server delivering multimedia content, and enabling embedded software applications to utilize the multimedia content to provide content and services synchronous with that multimedia content. Various embodiments relate to methods and systems for providing automated video and audio analysis that are used to identify and extract information in sports television video content, and to create metadata associated with video highlights for in-game and post-game reviewing of the sports television video content.
Enhanced television applications such as interactive advertising and enhanced program guides with pre-game, in-game and post-game interactive applications have long been envisioned. Existing cable systems that were originally engineered for broadcast television are being called on to support a host of new applications and services including interactive television services and enhanced (interactive) programming guides.
Some frameworks for enabling enhanced television applications have been standardized. Examples include the OpenCable™ Enhanced TV Application Messaging Specification, as well as the Tru2way specification, which refer to interactive digital cable services delivered over a cable video network and which include features such as interactive program guides, interactive ads, games, and the like. Additionally, cable operator “OLAP” programs provide interactive services such as e-commerce shopping, online banking, electronic program guides, and digital video recording. These efforts have enabled the first generation of video-synchronous applications, synchronized with video content delivered by the programmer/broadcaster, and providing added data and interactivity to television programming.
Recent developments in video/audio content analysis technologies and capable mobile devices have opened up an array of new possibilities in developing sophisticated applications that operate synchronously with live TV programming events. These new technologies and advances in computer vision and video processing, as well as improved computing power of modern processors, allow for real-time generation of sophisticated programming content highlights accompanied by metadata.
Methods and systems are presented for automatically finding the location of an information card (“card image”), such as an information score board, in a video frame, or multiple video frames, in sports television broadcast programming. Also described are methods and systems for identifying text strings within various fields of the localized card image, and reading and interpreting textual information from various fields of the localized card image.
In at least one embodiment, the card image detection, localization, and reading are performed synchronously with respect to presentation of sports television programming content. In at least one embodiment, an automated process is provided for receiving a digital video stream, analyzing one or more frames of the digital video stream, and automatically detecting and localizing card image quadrilaterals. In another embodiment, an automated process is provided for analyzing one or more localized card images, recognizing and extracting text strings (for example, in text boxes), and reading information from extracted text boxes.
In yet another embodiment, detected text strings associated with particular fields within the card image are interpreted, thus providing immediate in-game information related to the content of the televised broadcast of the sporting event. The extracted in-frame information may be used to generate metadata related to automatically created custom video content as a set of highlights of broadcast television programming content associated with audiovisual and textual data.
In at least one embodiment, a method for extracting metadata from a video stream may include storing at least a portion of the video stream in a data store. At a processor, one or more card images embedded in at least one of the video frames may be automatically identified and extracted by performing at least one of identifying a predetermined location, within the video frame, that defines a video frame region containing the card image, and sequentially processing a plurality of regions of the video frame to identify the video frame region containing the card image. At the processor, the card image may be analyzed to obtain metadata, which may be stored, at the data store, in association with at least one of the video frames.
In at least one embodiment, the video stream may be a broadcast of a sporting event. The video frames may constitute a highlight deemed to be of particular interest to one or more users. The metadata may be descriptive of a status of the sporting event during the highlight.
In at least one embodiment, the method may further include, at an output device, presenting the metadata during viewing of the highlight. Automatically identifying and extracting a card image and analyzing the card image to obtain the metadata may be carried out, for a highlight, during viewing of the highlight.
In at least one embodiment, the method may further include localizing and extracting the card image from the video frame region. Localizing and extracting the card image from the video frame region may include cropping the video frame to isolate the video frame region. Alternatively, or in addition, localizing and extracting the card image from the video frame region may include segmenting the video frame region, or a processed version of the video frame region, to generate a segmented image, and modifying pixel values of segments adjacent to boundaries of the segmented image. Alternatively, or in addition, localizing and extracting the card image from the video frame region may include removing background from the video frame region or a processed version of the video frame region. Alternatively, or in addition, localizing and extracting the card image from the video frame region may include generating an edge image based on the video frame region, finding contours in the edge image, approximating the contours as polygons, and extracting a region enclosed by a minimum rectangular perimeter encompassing all of the contours to generate a perimeter rectangular image.
In at least one embodiment, the method may further include, iteratively, counting color-modified pixels for each edge of the perimeter rectangular image, and moving any boundary edge, with a number of color-modified pixels exceeding a threshold, inward.
In at least one embodiment, the method may further include validating a quadrilateral detected within the region by counting a first number of pixels in the video frame region, a second number of pixels in a perimeter rectangular image, and a third number of pixels in an adjusted perimeter rectangular image. The first number, the second number, and the third number may be compared to determine whether an assumed quadrilateral within the region is viable.
In at least one embodiment, localizing and extracting the card image from the video frame region may include adjusting a left boundary (or another boundary) of the card image.
Further details and variations are described herein.
The accompanying drawings, together with the description, illustrate several embodiments. One skilled in the art will recognize that the particular embodiments illustrated in the drawings are merely exemplary, and are not intended to limit scope.
Definitions
The following definitions are presented for explanatory purposes only, and are not intended to limit scope.
The highlight show may be presented linearly (such as a video stream), or in a manner that allows the user to select which highlight to view and in which order (for example by clicking on links or thumbnails). Presentation of highlight show can be non-interactive or interactive, for example allowing a user to pause, rewind, skip, fast-forward, communicate a preference for or against, and/or the like. A highlight show can be, for example, a condensed game. A highlight show can include any number of contiguous or non-contiguous highlights, from a single event or from multiple events, and can even include highlights from different types of events (e.g. different sports, and/or a combination of highlights from sporting and non-sporting events).
According to various embodiments, methods and systems are provided for automatically creating time-based metadata associated with highlights of television programming of a sporting event. The highlights and associated in-frame time-based information may be extracted synchronously with respect to the television broadcast of a sporting event, or while the sporting event video content is being streamed via a video server from a backup device after the television broadcast of a sporting event.
In at least one embodiment, a software application operates synchronously with playback and/or receipt of the television programming content to provide information metadata associated with content highlights. Such software can run, for example, on the television device itself, or on an associated STB, or on a video server with the capability of receiving and subsequently streaming programming content, or on a mobile device equipped with the capability of receiving a video feed including live programming.
In video management and processing systems as well as in the context of an interactive (enhanced) programming guide, a set of video clips representing television broadcast content highlights can be automatically generated and/or stored in real-time, along with a database containing time-based meta-data describing, in more detail, the events presented in the highlights. The meta-data accompanying the video clips can include any information, such as for example textual information, images, and/or any type of audiovisual data. In this manner, interactive television applications can provide timely, relevant content to users who are watching programming content, either on a primary television display or on a secondary display such as tablet, laptop or a smartphone.
One type of metadata associated with in-game and post-game video content highlights carries real-time information about sporting game parameters extracted directly from live programming content by reading information cards (“card images”) embedded in one or more of video frames of the programming content. In various embodiments, the system and method described herein enable this type of automatic metadata generation.
In at least one embodiment, the system and method automatically detect and localize card images embedded in one or more of decoded video frames of television broadcast of a sporting event program, or in a sporting event video streamed from a playback device. A multitude of predetermined regions of interest are analyzed in decoded video frames, and card image quadrilaterals are localized and processed in real-time using computer vision techniques to transform information from an identified card image into a set of metadata describing the status of the sporting event.
In another embodiment, an automated process is described, wherein a digital video stream is received, and wherein one or more video frames of the digital video stream are analyzed for the presence of card image quadrilaterals. Text boxes are then localized within the identified card image, and text residing within the said text boxes is interpreted to create a metadata file associating card image content with video highlights of the analyzed digital video stream.
In yet another embodiment, a plurality of text strings (text boxes) is identified, and the location and size of the image of each character in the string of characters associated with said text boxes are detected. Next, a plurality of text strings from various fields of the card image are processed and interpreted, and corresponding metadata are formed, providing a plurality of information related to the portion of the sporting event associated with the processed card image and analyzed video frames.
The automated metadata generation video system presented herein may operate in connection with a live broadcast video stream or a digital video streamed via a computer server. In at least one embodiment, the video stream can be processed in real-time using computer vision techniques to extract metadata from embedded card images.
System Architecture
According to various embodiments, the system can be implemented on any electronic device, or set of electronic devices, equipped to receive, store, and present information. Such an electronic device may be, for example, a desktop computer, laptop computer, television, smartphone, tablet, music player, audio device, kiosk, set-top box (STB), game system, wearable device, consumer electronic device, and/or the like.
Although the system is described herein in connection with an implementation in particular types of computing devices, one skilled in the art will recognize that the techniques described herein can be implemented in other contexts, and indeed in any suitable device capable of receiving and/or processing user input, and presenting output to the user. Accordingly, the following description is intended to illustrate various embodiments by way of example, rather than to limit scope.
Referring now to
Client device 106 can be any electronic device, such as a desktop computer, laptop computer, television, smartphone, tablet, music player, audio device, kiosk, set-top box, game system, wearable device, consumer electronic device, and/or the like. In at least one embodiment, client device 106 has a number of hardware components well known to those skilled in the art. Input device(s) 151 can be any component(s) that receive input from user 150, including, for example, a handheld remote control, keyboard, mouse, stylus, touch-sensitive screen (touchscreen), touchpad, gesture receptor, trackball, accelerometer, five-way switch, microphone, or the like. Input can be provided via any suitable mode, including for example, one or more of: pointing, tapping, typing, dragging, gesturing, tilting, shaking, and/or speech. Display screen 152 can be any component that graphically displays information, video, content, and/or the like, including depictions of events, highlights, and/or the like. Such output may also include, for example, audiovisual content, data visualizations, navigational elements, graphical elements, queries requesting information and/or parameters for selection of content, or the like. In at least one embodiment, where only some of the desired output is presented at a time, a dynamic control, such as a scrolling mechanism, may be available via input device(s) 151 to choose which information is currently displayed, and/or to alter the manner in which the information is displayed.
Processor 157 can be a conventional microprocessor for performing operations on data under the direction of software, according to well-known techniques. Memory 156 can be random-access memory, having a structure and architecture as are known in the art, for use by processor 157 in the course of running software for performing the operations described herein. Client device 106 can also include local storage (not shown), which may be a hard drive, flash drive, optical or magnetic storage device, web-based (cloud-based) storage, and/or the like.
Any suitable type of communications network 104, such as the Internet, a television network, a cable network, a cellular network, and/or the like can be used as the mechanism for transmitting data between client device 106 and various server(s) 102, 114, 116 and/or content provider(s) 124 and/or data provider(s) 122, according to any suitable protocols and techniques. In addition to the Internet, other examples include cellular telephone networks, EDGE, 3G, 4G, long term evolution (LTE), Session Initiation Protocol (SIP), Short Message Peer-to-Peer protocol (SMPP), SS7, Wi-Fi, Bluetooth, ZigBee, Hypertext Transfer Protocol (HTTP), Secure Hypertext Transfer Protocol (SHTTP), Transmission Control Protocol/Internet Protocol (TCP/IP), and/or the like, and/or any combination thereof. In at least one embodiment, client device 106 transmits requests for data and/or content via communications network 104, and receives responses from server(s) 102, 114, 116 containing the requested data and/or content.
In at least one embodiment, the system of
In at least one embodiment, system 100 identifies highlights of broadcast events by analyzing a video stream of the event. This analysis may be carried out in real-time. In at least one embodiment, system 100 includes one or more web server(s) 102 coupled via a communications network 104 to one or more client devices 106. Communications network 104 may be a public network, a private network, or a combination of public and private networks such as the Internet. Communications network 104 can be a LAN, WAN, wired, wireless and/or combination of the above. Client device 106 is, in at least one embodiment, capable of connecting to communications network 104, either via a wired or wireless connection. In at least one embodiment, client device may also include a recording device capable of receiving and recording events, such as a DVR, PVR, or other media recording device. Such recording device can be part of client device 106, or can be external; in other embodiments, such recording device can be omitted. Although
Web server(s) 102 may include one or more physical computing devices and/or software that can receive requests from client device(s) 106 and respond to those requests with data, as well as send out unsolicited alerts and other messages. Web server(s) 102 may employ various strategies for fault tolerance and scalability such as load balancing, caching and clustering. In at least one embodiment, web server(s) 102 may include caching technology, as known in the art, for storing client requests and information related to events.
Web server(s) 102 may maintain, or otherwise designate, one or more application server(s) 114 to respond to requests received from client device(s) 106. In at least one embodiment, application server(s) 114 provide access to business logic for use by client application programs in client device(s) 106. Application server(s) 114 may be co-located, co-owned, or co-managed with web server(s) 102. Application server(s) 114 may also be remote from web server(s) 102. In at least one embodiment, application server(s) 114 interact with one or more analytical server(s) 116 and one or more data server(s) 118 to perform one or more operations of the disclosed technology.
One or more storage devices 153 may act as a “data store” by storing data pertinent to operation of system 100. This data may include, for example, and not by way of limitation, card data 154 pertinent to card images embedded in video streams presenting events such as sporting events, user data 155 pertinent to one or more users 150, and/or highlight data 164 pertinent to one or more highlights of the events.
Card data 154 can include any information related to card images embedded in the video stream, such as the card images themselves, subsets thereof such as character images, text extracted from the card images such as characters and character strings, and attributes of any of the foregoing that can be helpful in text and/or meaning extraction. User data 155 can include any information describing one or more users 150, including for example, demographics, purchasing behavior, video stream viewing behavior, interests, preferences, and/or the like. Highlight data 164 may include highlights, highlight identifiers, time indicators, categories, excitement levels, and other data pertaining to highlights. Card data 154, user data 155, and highlight data 164 will be described in detail subsequently.
Notably, many components of system 100 may be, or may include, computing devices. Such computing devices may each have an architecture similar to that of client device 106, as shown and described above. Thus, any of communications network 104, web servers 102, application servers 114, analytical servers 116, data providers 122, content providers 124, data servers 118, and storage devices 153 may include one or more computing devices, each of which may optionally have an input device 151, display screen 152, memory 156, and/or a processor 157, as described above in connection with client devices 106.
In an exemplary operation of system 100, one or more users 150 of client devices 106 view content from content providers 124, in the form of video streams. The video streams may show events, such as sporting events. The video streams may be digital video streams that can readily be processed with known computer vision techniques.
As the video streams are displayed, one or more components of system 100, such as client devices 106, web servers 102, application servers 114, and/or analytical servers 116, may analyze the video streams, identify highlights within the video streams, and/or extract metadata from the video stream, for example, from embedded card images and/or other aspects of the video stream. This analysis may be carried out in response to receipt of a request to identify highlights and/or metadata for the video stream. Alternatively, in another embodiment, highlights may be identified without a specific request having been made by user 150. In yet another embodiment, the analysis of video streams can take place without a video stream being displayed.
In at least one embodiment, user 150 can specify, via input device(s) 151 at client device 106, certain parameters for analysis of the video stream (such as, for example, what event/games/teams to include, how much time user 150 has available to view the highlights, what metadata is desired, and/or any other parameters). User preferences can also be extracted from storage, such as from user data 155 stored in one or more storage devices 153, so as to customize analysis of the video stream without necessarily requiring user 150 to specify preferences. In at least one embodiment, user preferences can be determined based on observed behavior and actions of user 150, for example, by observing website visitation patterns, television watching patterns, music listening patterns, online purchases, previous highlight identification parameters, highlights and/or metadata actually viewed by user 150, and/or the like.
Additionally or alternatively, user preferences can be retrieved from previously stored preferences that were explicitly provided by user 150. Such user preferences may indicate which teams, sports, players, and/or types of events are of interest to user 150, and/or they may indicate what type of metadata or other information related to highlights, would be of interest to user 150. Such preferences can therefore be used to guide analysis of the video stream to identify highlights and/or extract metadata for the highlights.
Analytical server(s) 116, which may include one or more computing devices as described above, may analyze live and/or recorded feeds of play-by-play statistics related to one or more events from data provider(s) 122. Examples of data provider(s) 122 may include, but are not limited to, providers of real-time sports information such as STATSTM, Perform (available from Opta Sports of London, UK), and SportRadar of St. Gallen, Switzerland. In at least one embodiment, analytical server(s) 116 generate different sets of excitement levels for events; such excitement levels can then be stored in conjunction with highlights identified by system 100 according to the techniques described herein.
Application server(s) 114 may analyze the video stream to identify the highlights and/or extract the metadata. Additionally or alternatively, such analysis may be carried out by client device(s) 106. The identified highlights and/or extracted metadata may be specific to a user 150; in such case, it may be advantageous to identify the highlights in client device 106 pertaining to a particular user 150. Client device 106 may receive, retain, and/or retrieve the applicable user preferences for highlight identification and/or metadata extraction, as described above. Additionally or alternatively, highlight generation and/or metadata extraction may carried out globally (i.e., using objective criteria applicable to the user population in general, without regard to preferences for a particular user 150). In such a case, it may be advantageous to identify the highlights and/or extract the metadata in application server(s) 114.
Content that facilitates highlight identification and/or metadata extraction may come from any suitable source, including from content provider(s) 124, which may include websites such as YouTube, MLB.com, and the like; sports data providers; television stations; client- or server-based DVRs; and/or the like. Alternatively, content can come from a local source such as a DVR or other recording device associated with (or built into) client device 106. In at least one embodiment, application server(s) 114 generate a customized highlight show, with highlights and metadata, available to user 150, either as a download, or streaming content, or on-demand content, or in some other manner.
As mentioned above, it may be advantageous for user-specific highlight identification and/or metadata extraction to be carried out at a particular client device 106 associated with a particular user 150. Such an embodiment may avoid the need for video content or other high-bandwidth content to be transmitted via communications network 104 unnecessarily, particularly if such content is already available at client device 106.
For example, referring now to
Returning to
Additional details on such functionality are provided in the above-cited related U.S. Patent Applications.
In at least one embodiment, one more data server(s) 118 are provided. Data server(s) 118 may respond to requests for data from any of server(s) 102, 114, 116, for example to obtain or provide card data 154, user data 155, and/or highlight data 164. In at least one embodiment, such information can be stored at any suitable storage device 153 accessible by data server 118, and can come from any suitable source, such as from client device 106 itself, content provider(s) 124, data provider(s) 122, and/or the like.
Referring now to
User data 155 may include preferences and interests of user 150. Based on such user data 155, system 180 may extract metadata within card data 154 to present to user 150 in the manner described herein. Additionally or alternatively, metadata may be extracted based on objective criteria that are not based on information specific to user 150.
Referring now to
The specific hardware architectures depicted in
In at least one embodiment, the system can be implemented as software written in any suitable computer programming language, whether in a standalone or client/server architecture. Alternatively, it may be implemented and/or embedded in hardware.
Data Structures
As shown, card data 154 may include a record for each of a plurality of broadcast networks 202. For example, for each of the broadcast networks 202, card data 154 may include a predetermined card location 203 at which the broadcast network typically displays card images within a video frame. The predetermined card locations may, for example, be represented as coordinates (such as Cartesian coordinates) identifying opposite corners of the location, identifying the center, height, and width, and/or otherwise identifying the location and/or size of the card image.
Further, card data 154 may include one or more video frame regions 204 that have been, or are to be, analyzed for card image extraction and interpretation. Each video frame region 204 may be extracted from a video frame of the video stream.
For each video frame region 204, card data 154 may also include one or more processed video frame regions 206, which may be generated by modifying video frame region 204 in a manner that facilitates identification and/or extraction of a card image 207. For example, processed video frame regions 206 may include one or more cropped, re-colored, segmented, augmented, or otherwise modified versions of each video frame region 204.
Each video frame region 204 may also have a card image 207 that has been identified within and/or extracted from video frame region 204. Each card image 207 may contain text that can be interpreted to provide metadata related to a specific time in a video stream.
Card data 154 may also include one or more interpretations 208 for each video frame region 204. Each interpretation 208 may be the specific text believed to be represented in associated card image 207 after some analysis has been performed to recognize and interpret characters appearing in card image 207. Interpretation 208 may be used to obtain the metadata from card image 207.
As further shown, user data 155 may include records pertaining to users 150, each of which may include demographic data 212, preferences 214, viewing history 216, and purchase history 218 for a particular user 150.
Demographic data 212 may include any type of demographic data, including but not limited to age, gender, location, nationality, religious affiliation, education level, and/or the like.
Preferences 214 may include selections made by user 150 regarding his or her preferences. Preferences 214 may relate directly to highlight and metadata gathering and/or viewing, or may be more general in nature. In either case, preferences 214 may be used to facilitate identification and/or presentation of the highlights and metadata to user 150.
Viewing history 216 may list the television programs, video streams, highlights, web pages, search queries, sporting events, and/or other content retrieved and/or viewed by user 150.
Purchase history 218 may list products or services purchased or requested by user 150.
As further shown, highlight data 164 may include records for j highlights 220, each of which may include a video stream 222, an identifier, and/or metadata 224 for a particular highlight 220.
Video stream 222 may include video depicting highlight 220, which may be obtained from one or more video streams of one or more events (for example, by cropping the video stream to include only video stream 222 pertaining to highlight 220). Identifier 223 may include time codes and/or other indicia that indicate where highlight 220 resides within the video stream of the event from which it is obtained.
In some embodiments, the record for each of highlights 220 may contain only one of video stream 222 and identifier 223. Highlight playback may be carried out by playing video stream 222 for user 150, or by using identifier 223 to play only the highlighted portion of the video stream for the event from which highlight 220 is obtained.
Metadata 224 may include information about highlight 220, such as the event date, season, and groups or individuals involved in the event or the video stream from which highlight 220 was obtained, such as teams, players, coaches, anchors, broadcasters, and fans, and/or the like. Among other information, metadata 224 for each highlight 220 may include a time 225, phase 226, clock 227, score 228, and/or frame number 229.
Time 225 may be a time, within video stream 222, from which highlight 220 is obtained, or within video stream 222 pertaining to highlight 220, at which metadata is available. In some examples, time 225 may be the playback time, within video stream 222, pertaining to highlight 220, at which a card image 207 is displayed containing metadata 224.
Phase 226 may be the phase of the event pertaining to highlight 220. More particularly, phase 226 may be the stage of a sporting event at which card image 207 is displayed containing metadata 224. For example, phase 226 may be “third quarter,” “second inning,” “bottom half,” or the like.
Clock 227 may be the game clock pertaining to highlight 220. More particularly, clock 227 may be state of the game clock at the time card image 207 is displayed containing metadata 224. For example, clock 227 may be “15:47” for a card image 207 displayed with fifteen minutes and forty-seven seconds displayed on the game clock.
Score 228 may be the game score pertaining to highlight 220. More particularly, score 228 may be the score when card image 207 is displayed containing metadata 224. For example, score 228 may be “45-38,” “7-0,” “30-love,” or the like.
Frame number 229 may be the number of the video frame, within the video stream from which highlight 220 is obtained, or video stream 222 pertaining to highlight 220, that relates most directly to highlight 220. More particularly, frame number 229 may be the number of such a video frame at which card image 207 is displayed containing metadata 224.
The data structures set forth in
Card Images
Referring now to
In at least one embodiment, the information in card images 207, 320 is localized and processed for automatic recognition and interpretation of embedded text in card images 207, 320. The interpreted text may then be assembled into textual metadata describing the status of the sporting game at particular point of time within the sporting event timeline.
Notably, card image 207 may pertain to the sporting event currently being shown, while second card image 320 may contain information for a different sporting event. In some embodiments, only card images containing information deemed to be pertinent to the currently playing sporting event is processed for metadata generation. Thus, without limiting scope, the exemplary description below assumes that only card image 207 will be processed. However, in alternative embodiments, it may be desirable to process multiple card images in a given video frame 300, even including card images pertaining to other sporting events.
As shown in
Card Image Localization and Extraction
Method 400 of
In at least one embodiment, the detection of one or more card images 207 present in a decoded video frame 300 is performed by analyzing a single predetermined frame area. Alternatively, such detection can be performed by analyzing multiple predetermined frame areas, if the approximate location of a card image 207 in decoded video frame 300 is not known in advance. Thus, query 420 may determine whether the position of card image 207, within video frame 300, is known. For example, some broadcasting networks may always show a card image 207 in the same position within video frame 300. If the broadcasting network is known, the position of card image 207 may also be known. In the alternative, the position of card image 207 within video frame 300 may not be known, and may need to be ascertained by system 100.
Pursuant to query 420, if the position of card image 207, within video frame 300, is known, method 400 may proceed to step 430 in which the known portion, or video frame region, may be processed to isolate the quadrilateral shape typically associated with a card image 207. If the position of the card image 207, within video frame 300, is not known, method 400 may proceed to step 440, in which video frame 300 is divided into a plurality of regions, which may be predetermined regions of video frame 300. The regions of video frame 300 are sequentially analyzed to determine which of the regions contains a card image similar to card images 207, 395, 397, and/or 399.
For example, the particular region(s) of video frame 300 containing card image 207 may be known for each of a variety of broadcasting networks. If the broadcasting network is not known, system 100 may sequentially proceed through each region of video frame 300 known to be used by a broadcasting network for display of card image 207, until card image 207 is located in one of the regions.
Pursuant to query 450, if card image 207 has been located, method 400 may proceed to step 460 in which card image 207 is processed and information is extracted from card image 207 to provide metadata 224. If, pursuant to query 450, card image 207 has not been located, method 400 may return to step 410, in which a new video frame may be loaded, decoded, and then analyzed for presence of a card image 207.
As mentioned previously, method 400 may, in some embodiments, be carried out in real-time, while user 150 is viewing the program (for example, while a video stream 222 corresponding to a highlight 220 is being presented). Thus, method 400 may be carried out in the background for each video frame 300 as video frame 300 is being decoded for playback for user 150. There may be some delay as system 100 localizes, extracts, and interprets card images 207. Thus, in this application, presenting metadata extracted from card images 207 is considered to be in “real-time” even if presentation of metadata 224 lags behind playback of video frame 300 from which it was obtained (for example, by a few video frames 300 amounting to a delay that is not perceptible or not distracting to user 150).
In at least one embodiment, the predetermined regions in decoded video frames 300 are generated based on the knowledge of approximate positions of card images 207 used by various television networks engaged in broadcasting of sporting event television programs, as indicated previously. Such television networks may be known to use one or more regions of video frame 300 for delivering in-frame visual and textual data via card images 207.
In a step 510, sequential processing of the regions may commence. In a step 520, one of the regions may be processed to ascertain whether a valid card image 207 is present in the region. A query 530 may determine whether a card image 207 has been found in the region. If so, the region may be further processed to extract card image 207. Localized card image 207 may be further processed for automatic recognition and interpretation of embedded text. Such interpreted text can then be further assembled into textual metadata describing the status of the sporting event (such as a game) at particular points of time on the sporting event timeline. In at least one embodiment, the available choices for text rendering are based on the type of card image 207 that has been detected in video frame 300, which may be determined by system 100 during localization and/or extraction of card image 207. Additionally or alternatively, the available choices for text rendering may be based on pre-assigned meanings of selected fields present within the particular type of card image 207 that has been detected.
If no card image 207 has been found in the region, a query 550 may ascertain whether the region is the last region in video frame 300. If not, system 100 may proceed, in a step 560, to the next region, and then repeat processing per step 520 for the next region. If the region is the last region in video frame 300, then video frame 300 may not contain a valid card image 207, and system 100 may proceed to next video frame 300.
Automatic Detection and Localization of Card Image Quadrilaterals
First, in a step 610, a decoded video frame 300 may be cropped to a smaller area containing the designated video frame region, providing a cropped image. In a step 620, the cropped image may be segmented using any suitable segmentation algorithm, such as graph-based segmentation (e.g. “Efficient Graph-Based Image Segmentation, P. Felzenszwalb, D. Huttenlocher, Int. Journal of Computer Vision, 2004, Vol. 59), and all generated segments may be color-coded and enumerated, providing a segmented image. Further processing of the segmented image may include removing background material surrounding a possible quadrilateral defining a card image 207. In at least one embodiment, method 600 may proceed to a step 630 in which all pixels of segments adjacent to the boundaries of the segmented cropped image are set to a black level. In a step 640, all pixels of the remaining inner segments of the segmented cropped image are set to a white level. In a step 650, the two-colored cropped image with partially removed background may be passed along for further processing for precise card image quadrilateral delineation.
The method of
Next, in a step 940, a weighted comparison of these three parameters may be performed, such that if a viable card image quadrilateral is to be detected, the squeezed quadrilateral none-black valued pixel area stands in a particular proportion with respect to the other two parameters. In a step 950, based on the above weighted comparison, if a valid card image 207 has been detected, a flag is set to true. Pursuant to a query 960, if the flag is set to true, system 100 may proceed to a step 970 in which card image 207 (and/or a processed version of card image 207) is passed to card image internal content processing. In step 950, if a valid card image 207 has not been detected, the flag is set to false, and pursuant to query 960, system 100 may proceed, in a step 980, to the next designated frame region to search for a viable card image 207 therein, or to next video frame 300.
Card Image Internal Processing for Information Extraction
In at least one embodiment, an automated process is performed, including receiving a digital video stream (which may include one or more highlights of a broadcast sporting event), analyzing one or more video frames of the digital video stream for the presence of card images 207, extracting card image 207, localizing text boxes within card image 207, and interpreting text residing within the text boxes to create metadata 224 associating content from card image 207 with video highlights of the analyzed digital video stream.
In at least one embodiment, a plurality of text strings (text boxes) are identified within card image 207, and the location and size of each character in the string of characters associated with said text boxes is detected. Next, text strings from various fields of card image 207 are processed and interpreted, and corresponding metadata 224 are generated, thus providing real-time information related to the current sporting event television program, and the current timeline associated with processed embedded card images 207.
The present system and method have been described in particular detail with respect to possible embodiments. Those of skill in the art will appreciate that the system and method may be practiced in other embodiments. First, the particular naming of the components, capitalization of terms, the attributes, data structures, or any other programming or structural aspect is not mandatory or significant, and the mechanisms and/or features may have different names, formats, or protocols. Further, the system may be implemented via a combination of hardware and software, or entirely in hardware elements, or entirely in software elements. Also, the particular division of functionality between the various system components described herein is merely exemplary, and not mandatory; functions performed by a single system component may instead be performed by multiple components, and functions performed by multiple components may instead be performed by a single component.
Reference in the specification to “one embodiment” or to “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiments is included in at least one embodiment. The appearances of the phrases “in one embodiment” or “in at least one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.
Various embodiments may include any number of systems and/or methods for performing the above-described techniques, either singly or in any combination. Another embodiment includes a computer program product comprising a non-transitory computer-readable storage medium and computer program code, encoded on the medium, for causing a processor in a computing device or other electronic device to perform the above-described techniques.
Some portions of the above are presented in terms of algorithms and symbolic representations of operations on data bits within the memory of a computing device. These algorithmic descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. An algorithm is here, and generally, conceived to be a self-consistent sequence of steps (instructions) leading to a desired result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical, magnetic or optical signals capable of being stored, transferred, combined, compared and otherwise manipulated. It is convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like. Furthermore, it is also convenient at times, to refer to certain arrangements of steps requiring physical manipulations of physical quantities as modules or code devices, without loss of generality.
It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussion, it is appreciated that throughout the description, discussions utilizing terms such as “processing” or “computing” or “calculating” or “displaying” or “determining” or the like, refer to the action and processes of a computer system, or similar electronic computing module and/or device, that manipulates and transforms data represented as physical (electronic) quantities within the computer system memories or registers or other such information storage, transmission or display devices.
Certain aspects include process steps and instructions described herein in the form of an algorithm. It should be noted that the process steps and instructions can be embodied in software, firmware and/or hardware, and when embodied in software, can be downloaded to reside on and be operated from different platforms used by a variety of operating systems.
The present document also relates to an apparatus for performing the operations herein. This apparatus may be specially constructed for the required purposes, or it may comprise a general-purpose computing device selectively activated or reconfigured by a computer program stored in the computing device. Such a computer program may be stored in a computer readable storage medium, such as, but is not limited to, any type of disk including floppy disks, optical disks, CD-ROMs, DVD-ROMs, magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, flash memory, solid state drives, magnetic or optical cards, application specific integrated circuits (ASICs), or any type of media suitable for storing electronic instructions, and each coupled to a computer system bus. The program and its associated data may also be hosted and run remotely, for example on a server. Further, the computing devices referred to herein may include a single processor or may be architectures employing multiple processor designs for increased computing capability.
The algorithms and displays presented herein are not inherently related to any particular computing device, virtualized system, or other apparatus. Various general-purpose systems may also be used with programs in accordance with the teachings herein, or it may prove convenient to construct more specialized apparatus to perform the required method steps. The required structure for a variety of these systems will be apparent from the description provided herein. In addition, the system and method are not described with reference to any particular programming language. It will be appreciated that a variety of programming languages may be used to implement the teachings described herein, and any references above to specific languages are provided for disclosure of enablement and best mode.
Accordingly, various embodiments include software, hardware, and/or other elements for controlling a computer system, computing device, or other electronic device, or any combination or plurality thereof. Such an electronic device can include, for example, a processor, an input device (such as a keyboard, mouse, touchpad, track pad, joystick, trackball, microphone, and/or any combination thereof), an output device (such as a screen, speaker, and/or the like), memory, long-term storage (such as magnetic storage, optical storage, and/or the like), and/or network connectivity, according to techniques that are well known in the art. Such an electronic device may be portable or non-portable. Examples of electronic devices that may be used for implementing the described system and method include: a desktop computer, laptop computer, television, smartphone, tablet, music player, audio device, kiosk, set-top box, game system, wearable device, consumer electronic device, server computer, and/or the like. An electronic device may use any operating system such as, for example and without limitation: Linux; Microsoft Windows, available from Microsoft Corporation of Redmond, Washington; Mac OS X, available from Apple Inc. of Cupertino, California; iOS, available from Apple Inc. of Cupertino, California; Android, available from Google, Inc. of Mountain View, California; and/or any other operating system that is adapted for use on the device.
While a limited number of embodiments have been described herein, those skilled in the art, having benefit of the above description, will appreciate that other embodiments may be devised. In addition, it should be noted that the language used in the specification has been principally selected for readability and instructional purposes, and may not have been selected to delineate or circumscribe the subject matter. Accordingly, the disclosure is intended to be illustrative, but not limiting, of scope.
The application is a continuation of U.S. patent application Ser. No. 17/449,882, filed Oct. 4, 2021, which is a continuation of U.S. patent application Ser. No. 16/411,713, filed May 14, 2019, now U.S. Pat. No. 11,138,438 issued Oct. 5, 2021, which claims priority to U.S. Provisional Application No. 62/673,412, filed May 18, 2018, U.S. Provisional Application No. 62/673,411, filed May 18, 2018, U.S. Provisional Application No. 62/673,413, filed May 18, 2018, U.S. Provisional Application No. 62/680,955, filed Jun. 5, 2018, U.S. Provisional Application No. 62/712,041, filed Jul. 30, 2018, and U.S. Provisional Application No. 62/746,454, filed Oct. 16, 2018, which are incorporated by reference in their entireties. The application is also related to U.S. patent application Ser. No. 13/601,915, filed Aug. 31, 2012, now U.S. Pat. No. 9,060,210, issued Jun. 16, 2015, U.S. patent application Ser. No. 13/601,927, filed Aug. 31, 2012, now U.S. Pat. No. 8,842,007, issued Sep. 23, 2014, U.S. patent application Ser. No. 13/601,933, filed Aug. 31, 2012, now U.S. Pat. No. 8,595,763, issued Nov. 26, 2013, U.S. patent application Ser. No. 14/510,481, filed Oct. 9, 2014, now U.S. Pat. No. 10,419,830, issued Sep. 17, 2019, U.S. patent application Ser. No. 14/710,438, filed May 12, 2015, now U.S. Pat. No. 10,433,030, issued Oct. 1, 2019, U.S. patent application Ser. No. 14/877,691, filed Oct. 7, 2015, now U.S. Pat. No. 10,536,758, issued Jan. 14, 2020, U.S. patent application Ser. No. 15/264,928, filed Sep. 14, 2016, U.S. patent application Ser. No. 16/411,704, filed May 14, 2019, and U.S. patent application Ser. No. 16/411,710, filed May 14, 2019, which are incorporated by reference in their entireties.
Number | Name | Date | Kind |
---|---|---|---|
6005562 | Shiga et al. | Dec 1999 | A |
6177931 | Alexander et al. | Jan 2001 | B1 |
6185527 | Petkovic et al. | Feb 2001 | B1 |
6195458 | Warnick | Feb 2001 | B1 |
6557042 | He et al. | Apr 2003 | B1 |
6665442 | Sekiguchi et al. | Dec 2003 | B2 |
6681396 | Bates et al. | Jan 2004 | B1 |
6721490 | Yao et al. | Apr 2004 | B1 |
6954611 | Hashimoto et al. | Oct 2005 | B2 |
7174512 | Martin et al. | Feb 2007 | B2 |
7197715 | Valeria | Mar 2007 | B1 |
7382933 | Dorai et al. | Jun 2008 | B2 |
7386217 | Zhang | Jun 2008 | B2 |
7543322 | Bhogal et al. | Jun 2009 | B1 |
7623677 | Girgensohn | Nov 2009 | B2 |
7633887 | Panwar et al. | Dec 2009 | B2 |
7646962 | Ellis et al. | Jan 2010 | B1 |
7680894 | Diot et al. | Mar 2010 | B2 |
7742111 | Shiu et al. | Jun 2010 | B2 |
7774811 | Poslinski et al. | Aug 2010 | B2 |
7778470 | Aoki | Aug 2010 | B2 |
7818368 | Yang et al. | Oct 2010 | B2 |
7825989 | Greenberg | Nov 2010 | B1 |
7831112 | Wang et al. | Nov 2010 | B2 |
7849487 | Vosseller | Dec 2010 | B1 |
7929808 | Seaman et al. | Apr 2011 | B2 |
8024753 | Kummer et al. | Sep 2011 | B1 |
8046798 | Schlack et al. | Oct 2011 | B1 |
8079052 | Chen et al. | Dec 2011 | B2 |
8099315 | Amento et al. | Jan 2012 | B2 |
8104065 | Aaby et al. | Jan 2012 | B2 |
8126268 | Rossato | Feb 2012 | B2 |
8140570 | Ingrassia et al. | Mar 2012 | B2 |
8196168 | Bryan et al. | Jun 2012 | B1 |
8209713 | Lai et al. | Jun 2012 | B1 |
8269857 | Ishizaka | Sep 2012 | B2 |
8296797 | Olstad et al. | Oct 2012 | B2 |
8296808 | Hardacker et al. | Oct 2012 | B2 |
8312486 | Briggs et al. | Nov 2012 | B1 |
8320674 | Guillou et al. | Nov 2012 | B2 |
8424041 | Candelore et al. | Apr 2013 | B2 |
8427356 | Satish | Apr 2013 | B1 |
8457768 | Hammer et al. | Jun 2013 | B2 |
8522300 | Relyea et al. | Aug 2013 | B2 |
8535131 | Packard et al. | Sep 2013 | B2 |
8595763 | Packard et al. | Nov 2013 | B1 |
8627349 | Kirby et al. | Jan 2014 | B2 |
8688434 | Birnbaum et al. | Apr 2014 | B1 |
8689258 | Kemp | Apr 2014 | B2 |
8702504 | Hughes et al. | Apr 2014 | B1 |
8713008 | Negi | Apr 2014 | B2 |
8752084 | Lai et al. | Jun 2014 | B1 |
8793579 | Halliday et al. | Jul 2014 | B2 |
8842007 | Packard et al. | Sep 2014 | B2 |
8872979 | Bagga et al. | Oct 2014 | B2 |
8923607 | Kwatra et al. | Dec 2014 | B1 |
8966513 | John et al. | Feb 2015 | B2 |
8973038 | Gratton | Mar 2015 | B2 |
8973068 | Kotecha et al. | Mar 2015 | B2 |
8990418 | Bragg et al. | Mar 2015 | B1 |
9038127 | Hastings et al. | May 2015 | B2 |
9060210 | Packard et al. | Jun 2015 | B2 |
9066156 | Kapa | Jun 2015 | B2 |
9141859 | Vunic | Sep 2015 | B2 |
9213986 | Buchheit et al. | Dec 2015 | B1 |
9251853 | Jeong et al. | Feb 2016 | B2 |
9253533 | Morgan et al. | Feb 2016 | B1 |
9264779 | Kirby et al. | Feb 2016 | B2 |
9420333 | Martch et al. | Aug 2016 | B2 |
9451202 | Beals et al. | Sep 2016 | B2 |
9565474 | Petruzzelli et al. | Feb 2017 | B2 |
9578377 | Malik et al. | Feb 2017 | B1 |
9583149 | Stieglitz et al. | Feb 2017 | B2 |
9648379 | Howcroft et al. | May 2017 | B2 |
9715902 | Coviello et al. | Jul 2017 | B2 |
9788062 | Dimov et al. | Oct 2017 | B2 |
9805268 | Xing et al. | Oct 2017 | B2 |
10056116 | Packard et al. | Aug 2018 | B2 |
10200764 | Oguchi et al. | Feb 2019 | B2 |
10297287 | Maisenbacher et al. | May 2019 | B2 |
10410060 | Balasubramanian et al. | Sep 2019 | B2 |
10419830 | Packard et al. | Sep 2019 | B2 |
10433030 | Packard et al. | Oct 2019 | B2 |
10536758 | Packard et al. | Jan 2020 | B2 |
20010013123 | Freeman et al. | Aug 2001 | A1 |
20010026609 | Weinstein et al. | Oct 2001 | A1 |
20020041752 | Abiko et al. | Apr 2002 | A1 |
20020059610 | Ellis | May 2002 | A1 |
20020067376 | Martin et al. | Jun 2002 | A1 |
20020075402 | Robson et al. | Jun 2002 | A1 |
20020136528 | Dagtas | Sep 2002 | A1 |
20020157095 | Masumitsu et al. | Oct 2002 | A1 |
20020157101 | Schrader et al. | Oct 2002 | A1 |
20020174430 | Ellis et al. | Nov 2002 | A1 |
20020178444 | Trajkovic et al. | Nov 2002 | A1 |
20020180774 | Errico et al. | Dec 2002 | A1 |
20020194095 | Koren | Dec 2002 | A1 |
20030012554 | Zeidler et al. | Jan 2003 | A1 |
20030023742 | Allen et al. | Jan 2003 | A1 |
20030056220 | Thornton et al. | Mar 2003 | A1 |
20030063798 | Li et al. | Apr 2003 | A1 |
20030066077 | Gutta et al. | Apr 2003 | A1 |
20030118014 | Iyer et al. | Jun 2003 | A1 |
20030126605 | Betz et al. | Jul 2003 | A1 |
20030126606 | Buczak et al. | Jul 2003 | A1 |
20030154475 | Rodriguez et al. | Aug 2003 | A1 |
20030172376 | Coffin | Sep 2003 | A1 |
20030188317 | Liew et al. | Oct 2003 | A1 |
20030189674 | Inoue et al. | Oct 2003 | A1 |
20030208763 | Mcelhatten et al. | Nov 2003 | A1 |
20030229899 | Thompson et al. | Dec 2003 | A1 |
20040003403 | Marsh | Jan 2004 | A1 |
20040041831 | Zhang | Mar 2004 | A1 |
20040167767 | Xiong et al. | Aug 2004 | A1 |
20040181807 | Theiste et al. | Sep 2004 | A1 |
20050005308 | Logan et al. | Jan 2005 | A1 |
20050015712 | Plastina et al. | Jan 2005 | A1 |
20050030977 | Casey et al. | Feb 2005 | A1 |
20050044570 | Poslinski | Feb 2005 | A1 |
20050071865 | Martins | Mar 2005 | A1 |
20050071881 | Deshpande | Mar 2005 | A1 |
20050091690 | Delpuch et al. | Apr 2005 | A1 |
20050120368 | Goronzy et al. | Jun 2005 | A1 |
20050125302 | Brown et al. | Jun 2005 | A1 |
20050149965 | Neogi | Jul 2005 | A1 |
20050152565 | Jouppi et al. | Jul 2005 | A1 |
20050154987 | Otsuka et al. | Jul 2005 | A1 |
20050166230 | Gaydou et al. | Jul 2005 | A1 |
20050180568 | Krause et al. | Aug 2005 | A1 |
20050182792 | Israel et al. | Aug 2005 | A1 |
20050191041 | Braun et al. | Sep 2005 | A1 |
20050198570 | Otsuka et al. | Sep 2005 | A1 |
20050204294 | Burke et al. | Sep 2005 | A1 |
20050240961 | Jerding et al. | Oct 2005 | A1 |
20050264705 | Kitamura | Dec 2005 | A1 |
20060020962 | Stark et al. | Jan 2006 | A1 |
20060085828 | Dureau et al. | Apr 2006 | A1 |
20060174277 | Sezan et al. | Aug 2006 | A1 |
20060190615 | Panwar et al. | Aug 2006 | A1 |
20060218573 | Proebstel | Sep 2006 | A1 |
20060238656 | Chen et al. | Oct 2006 | A1 |
20060253581 | Dixon et al. | Nov 2006 | A1 |
20060282852 | Purpura et al. | Dec 2006 | A1 |
20060282869 | Plourde | Dec 2006 | A1 |
20070033616 | Gutta | Feb 2007 | A1 |
20070041706 | Gunatilake | Feb 2007 | A1 |
20070058930 | Iwamoto | Mar 2007 | A1 |
20070083901 | Bond | Apr 2007 | A1 |
20070127894 | Ando et al. | Jun 2007 | A1 |
20070146554 | Strickland et al. | Jun 2007 | A1 |
20070154163 | Cordray | Jul 2007 | A1 |
20070154169 | Cordray et al. | Jul 2007 | A1 |
20070157235 | Teunissen | Jul 2007 | A1 |
20070157249 | Cordray et al. | Jul 2007 | A1 |
20070157253 | Ellis et al. | Jul 2007 | A1 |
20070157285 | Frank et al. | Jul 2007 | A1 |
20070162924 | Radhakrishnan et al. | Jul 2007 | A1 |
20070169165 | Crull et al. | Jul 2007 | A1 |
20070188655 | Ohta | Aug 2007 | A1 |
20070199040 | Kates | Aug 2007 | A1 |
20070201764 | Jung et al. | Aug 2007 | A1 |
20070204302 | Calzone | Aug 2007 | A1 |
20070212023 | Whillock | Sep 2007 | A1 |
20070226766 | Poslinski et al. | Sep 2007 | A1 |
20070239856 | Abadir | Oct 2007 | A1 |
20070245379 | Agnihortri | Oct 2007 | A1 |
20070250777 | Chen et al. | Oct 2007 | A1 |
20070288951 | Ray et al. | Dec 2007 | A1 |
20080022012 | Wang | Jan 2008 | A1 |
20080060006 | Shanks et al. | Mar 2008 | A1 |
20080064490 | Ellis | Mar 2008 | A1 |
20080086743 | Cheng et al. | Apr 2008 | A1 |
20080092168 | Logan et al. | Apr 2008 | A1 |
20080097949 | Kelly et al. | Apr 2008 | A1 |
20080109307 | Ullah | May 2008 | A1 |
20080115166 | Bhogal et al. | May 2008 | A1 |
20080134043 | Georgis et al. | Jun 2008 | A1 |
20080155602 | Collet et al. | Jun 2008 | A1 |
20080159708 | Kazama et al. | Jul 2008 | A1 |
20080163305 | Johnson et al. | Jul 2008 | A1 |
20080168503 | Sparrell | Jul 2008 | A1 |
20080175486 | Yamamoto | Jul 2008 | A1 |
20080178219 | Grannan | Jul 2008 | A1 |
20080193016 | Lim et al. | Aug 2008 | A1 |
20080195457 | Sherman et al. | Aug 2008 | A1 |
20080235348 | Dasgupta | Sep 2008 | A1 |
20080239169 | Moon et al. | Oct 2008 | A1 |
20080244666 | Moon et al. | Oct 2008 | A1 |
20080270038 | Partovi et al. | Oct 2008 | A1 |
20080271078 | Gossweiler et al. | Oct 2008 | A1 |
20080300982 | Scott et al. | Dec 2008 | A1 |
20080303942 | Chang et al. | Dec 2008 | A1 |
20080307485 | Clement et al. | Dec 2008 | A1 |
20080320523 | Morris et al. | Dec 2008 | A1 |
20090025027 | Craner | Jan 2009 | A1 |
20090034932 | Oisel et al. | Feb 2009 | A1 |
20090055385 | Jeon et al. | Feb 2009 | A1 |
20090080857 | St. John-Larkin | Mar 2009 | A1 |
20090082110 | Relyea et al. | Mar 2009 | A1 |
20090102984 | Arling et al. | Apr 2009 | A1 |
20090138902 | Kamen | May 2009 | A1 |
20090144777 | Mikami et al. | Jun 2009 | A1 |
20090158357 | Miller et al. | Jun 2009 | A1 |
20090178071 | Whitehead | Jul 2009 | A1 |
20090210898 | Cullen et al. | Aug 2009 | A1 |
20090228911 | Vrijsen | Sep 2009 | A1 |
20090234828 | Tu | Sep 2009 | A1 |
20090235313 | Maruyama et al. | Sep 2009 | A1 |
20090249412 | Bhogal et al. | Oct 2009 | A1 |
20090293093 | Igarashi | Nov 2009 | A1 |
20090299824 | Barnes, Jr. | Dec 2009 | A1 |
20090325523 | Choi | Dec 2009 | A1 |
20100040151 | Garrett | Feb 2010 | A1 |
20100064306 | Tiongson et al. | Mar 2010 | A1 |
20100071007 | Meijer | Mar 2010 | A1 |
20100071062 | Choyi et al. | Mar 2010 | A1 |
20100086277 | Craner | Apr 2010 | A1 |
20100089996 | Koplar | Apr 2010 | A1 |
20100115554 | Drouet et al. | May 2010 | A1 |
20100122294 | Craner | May 2010 | A1 |
20100123830 | Vunic | May 2010 | A1 |
20100125864 | Dwyer et al. | May 2010 | A1 |
20100146560 | Bonfrer | Jun 2010 | A1 |
20100153856 | Russ | Jun 2010 | A1 |
20100153983 | Philmon et al. | Jun 2010 | A1 |
20100153999 | Yates | Jun 2010 | A1 |
20100157340 | Chen et al. | Jun 2010 | A1 |
20100158479 | Craner | Jun 2010 | A1 |
20100166389 | Knee et al. | Jul 2010 | A1 |
20100169925 | Takegoshi | Jul 2010 | A1 |
20100218214 | Fan et al. | Aug 2010 | A1 |
20100251295 | Amento et al. | Sep 2010 | A1 |
20100251304 | Donoghue et al. | Sep 2010 | A1 |
20100251305 | Kimble et al. | Sep 2010 | A1 |
20100262986 | Adimatyam et al. | Oct 2010 | A1 |
20100269144 | Forsman et al. | Oct 2010 | A1 |
20100319019 | Zazza | Dec 2010 | A1 |
20100322592 | Casagrande | Dec 2010 | A1 |
20100333131 | Parker et al. | Dec 2010 | A1 |
20110016492 | Morita | Jan 2011 | A1 |
20110016493 | Lee et al. | Jan 2011 | A1 |
20110019839 | Nandury | Jan 2011 | A1 |
20110052156 | Kuhn | Mar 2011 | A1 |
20110072448 | Stiers et al. | Mar 2011 | A1 |
20110082858 | Yu et al. | Apr 2011 | A1 |
20110096228 | Deigmoeller et al. | Apr 2011 | A1 |
20110109801 | Thomas et al. | May 2011 | A1 |
20110138418 | Choi et al. | Jun 2011 | A1 |
20110161242 | Chung et al. | Jun 2011 | A1 |
20110173337 | Walsh et al. | Jul 2011 | A1 |
20110202956 | Connelly et al. | Aug 2011 | A1 |
20110206342 | Thompson et al. | Aug 2011 | A1 |
20110212756 | Packard et al. | Sep 2011 | A1 |
20110217024 | Schlieski et al. | Sep 2011 | A1 |
20110231887 | West et al. | Sep 2011 | A1 |
20110239249 | Murison et al. | Sep 2011 | A1 |
20110243533 | Stern et al. | Oct 2011 | A1 |
20110252451 | Turgeman et al. | Oct 2011 | A1 |
20110286721 | Craner | Nov 2011 | A1 |
20110289410 | Paczkowski et al. | Nov 2011 | A1 |
20110293113 | Mccarthy | Dec 2011 | A1 |
20120020641 | Sakaniwa et al. | Jan 2012 | A1 |
20120047542 | Lewis et al. | Feb 2012 | A1 |
20120052941 | Mo | Mar 2012 | A1 |
20120060178 | Minakuchi et al. | Mar 2012 | A1 |
20120082431 | Sengupta et al. | Apr 2012 | A1 |
20120106932 | Grevers | May 2012 | A1 |
20120110615 | Kilar et al. | May 2012 | A1 |
20120110616 | Kilar et al. | May 2012 | A1 |
20120124625 | Foote et al. | May 2012 | A1 |
20120131613 | Ellis et al. | May 2012 | A1 |
20120185895 | Wong et al. | Jul 2012 | A1 |
20120204209 | Kubo | Aug 2012 | A1 |
20120216118 | Lin et al. | Aug 2012 | A1 |
20120230651 | Chen | Sep 2012 | A1 |
20120237182 | Eyer | Sep 2012 | A1 |
20120246672 | Sridhar et al. | Sep 2012 | A1 |
20120260295 | Rondeau | Oct 2012 | A1 |
20120263439 | Lassman et al. | Oct 2012 | A1 |
20120278834 | Richardson | Nov 2012 | A1 |
20120278837 | Curtis et al. | Nov 2012 | A1 |
20120284745 | Strong | Nov 2012 | A1 |
20120311633 | Mandrekar et al. | Dec 2012 | A1 |
20120324491 | Bathiche et al. | Dec 2012 | A1 |
20130014159 | Wiser et al. | Jan 2013 | A1 |
20130042179 | Cormack et al. | Feb 2013 | A1 |
20130055304 | Kirby et al. | Feb 2013 | A1 |
20130061313 | Cullimore et al. | Mar 2013 | A1 |
20130073473 | Heath et al. | Mar 2013 | A1 |
20130074109 | Skelton et al. | Mar 2013 | A1 |
20130114940 | Merzon et al. | May 2013 | A1 |
20130128119 | Madathodiyil et al. | May 2013 | A1 |
20130138435 | Weber | May 2013 | A1 |
20130138693 | Sathish et al. | May 2013 | A1 |
20130145023 | Li et al. | Jun 2013 | A1 |
20130160051 | Armstrong et al. | Jun 2013 | A1 |
20130174196 | Herlein | Jul 2013 | A1 |
20130194503 | Yamashita | Aug 2013 | A1 |
20130226983 | Beining et al. | Aug 2013 | A1 |
20130251331 | Sambongi | Sep 2013 | A1 |
20130263189 | Garner | Oct 2013 | A1 |
20130268620 | Osminer et al. | Oct 2013 | A1 |
20130268955 | Conrad et al. | Oct 2013 | A1 |
20130283162 | Aronsson et al. | Oct 2013 | A1 |
20130291037 | Im et al. | Oct 2013 | A1 |
20130298146 | Conrad et al. | Nov 2013 | A1 |
20130298151 | Leske et al. | Nov 2013 | A1 |
20130325869 | Reiley et al. | Dec 2013 | A1 |
20130326406 | Reiley et al. | Dec 2013 | A1 |
20130326575 | Robillard et al. | Dec 2013 | A1 |
20130332962 | Moritz et al. | Dec 2013 | A1 |
20130332965 | Seyller et al. | Dec 2013 | A1 |
20130346302 | Purves et al. | Dec 2013 | A1 |
20140023348 | O'kelly et al. | Jan 2014 | A1 |
20140028917 | Smith et al. | Jan 2014 | A1 |
20140032709 | Saussy et al. | Jan 2014 | A1 |
20140062696 | Packard et al. | Mar 2014 | A1 |
20140067825 | Oztaskent et al. | Mar 2014 | A1 |
20140067828 | Archibong et al. | Mar 2014 | A1 |
20140067939 | Packard et al. | Mar 2014 | A1 |
20140068675 | Mountain | Mar 2014 | A1 |
20140068692 | Archibong et al. | Mar 2014 | A1 |
20140074866 | Shah et al. | Mar 2014 | A1 |
20140082670 | Papish et al. | Mar 2014 | A1 |
20140088952 | Fife et al. | Mar 2014 | A1 |
20140114647 | Allen | Apr 2014 | A1 |
20140114966 | Bilinski et al. | Apr 2014 | A1 |
20140123160 | van Coppenolle et al. | May 2014 | A1 |
20140130094 | Kirby et al. | May 2014 | A1 |
20140139555 | Levy | May 2014 | A1 |
20140140680 | Jo et al. | May 2014 | A1 |
20140150009 | Sharma et al. | May 2014 | A1 |
20140153904 | Adimatyam et al. | Jun 2014 | A1 |
20140157327 | Roberts et al. | Jun 2014 | A1 |
20140161417 | Kurupacheril et al. | Jun 2014 | A1 |
20140215539 | Chen et al. | Jul 2014 | A1 |
20140223479 | Krishnamoorthi et al. | Aug 2014 | A1 |
20140282714 | Hussain et al. | Sep 2014 | A1 |
20140282741 | Shoykhet | Sep 2014 | A1 |
20140282744 | Hardy et al. | Sep 2014 | A1 |
20140282745 | Chipman et al. | Sep 2014 | A1 |
20140282759 | Harvey et al. | Sep 2014 | A1 |
20140282779 | Navarro et al. | Sep 2014 | A1 |
20140294201 | Johnson et al. | Oct 2014 | A1 |
20140298378 | Kelley et al. | Oct 2014 | A1 |
20140310819 | Cakarel et al. | Oct 2014 | A1 |
20140313341 | Stribling et al. | Oct 2014 | A1 |
20140321831 | Olsen et al. | Oct 2014 | A1 |
20140325556 | Hoang et al. | Oct 2014 | A1 |
20140331260 | Gratton | Nov 2014 | A1 |
20140333841 | Steck | Nov 2014 | A1 |
20140351045 | Abihssira et al. | Nov 2014 | A1 |
20140373079 | Friedrich et al. | Dec 2014 | A1 |
20150003814 | Miller | Jan 2015 | A1 |
20150012656 | Phillips et al. | Jan 2015 | A1 |
20150020097 | Freed et al. | Jan 2015 | A1 |
20150040176 | Hybertson et al. | Feb 2015 | A1 |
20150052568 | Glennon et al. | Feb 2015 | A1 |
20150058890 | Kapa | Feb 2015 | A1 |
20150082172 | Shakib et al. | Mar 2015 | A1 |
20150095932 | Ren | Apr 2015 | A1 |
20150110461 | Maisenbacher et al. | Apr 2015 | A1 |
20150110462 | Maisenbacher et al. | Apr 2015 | A1 |
20150118992 | Wyatt et al. | Apr 2015 | A1 |
20150181077 | Misawa et al. | Jun 2015 | A1 |
20150181132 | Kummer et al. | Jun 2015 | A1 |
20150181279 | Martch et al. | Jun 2015 | A1 |
20150189377 | Wheatley et al. | Jul 2015 | A1 |
20150243326 | Pacurariu et al. | Aug 2015 | A1 |
20150249803 | Tozer et al. | Sep 2015 | A1 |
20150249864 | Tang et al. | Sep 2015 | A1 |
20150281778 | Xhafa et al. | Oct 2015 | A1 |
20150310725 | Koskan et al. | Oct 2015 | A1 |
20150310894 | Stieglitz et al. | Oct 2015 | A1 |
20150334461 | Yu | Nov 2015 | A1 |
20150358687 | Kummer et al. | Dec 2015 | A1 |
20150358688 | Kummer | Dec 2015 | A1 |
20160066020 | Mountain et al. | Mar 2016 | A1 |
20160066026 | Mountain et al. | Mar 2016 | A1 |
20160066042 | Dimov et al. | Mar 2016 | A1 |
20160066049 | Mountain et al. | Mar 2016 | A1 |
20160066056 | Mountain et al. | Mar 2016 | A1 |
20160073172 | Sharples | Mar 2016 | A1 |
20160088351 | Petruzzelli et al. | Mar 2016 | A1 |
20160105708 | Packard et al. | Apr 2016 | A1 |
20160105733 | Packard et al. | Apr 2016 | A1 |
20160105734 | Packard et al. | Apr 2016 | A1 |
20160191147 | Martch et al. | Jun 2016 | A1 |
20160198229 | Keipert et al. | Jul 2016 | A1 |
20160261929 | Lee et al. | Sep 2016 | A1 |
20160309212 | Martch et al. | Oct 2016 | A1 |
20160371545 | Ramnani et al. | Dec 2016 | A1 |
20170069159 | Vikranth et al. | Mar 2017 | A1 |
20170228600 | Syed et al. | Aug 2017 | A1 |
20170337693 | Baruch et al. | Nov 2017 | A1 |
20180014072 | Dimov et al. | Jan 2018 | A1 |
20190354763 | Stojancic et al. | Nov 2019 | A1 |
20190356948 | Stojancic et al. | Nov 2019 | A1 |
Number | Date | Country |
---|---|---|
1666503 | Sep 2005 | CN |
1991864 | Jul 2007 | CN |
101079150 | Nov 2007 | CN |
101371273 | Feb 2009 | CN |
101371274 | Feb 2009 | CN |
101377852 | Mar 2009 | CN |
101650722 | Oct 2011 | CN |
102254160 | Nov 2011 | CN |
102263907 | Nov 2011 | CN |
105912560 | Aug 2016 | CN |
106503702 | Mar 2017 | CN |
1469476 | Oct 2004 | EP |
1865716 | Dec 2007 | EP |
2107477 | Oct 2009 | EP |
2309733 | Apr 2011 | EP |
2403239 | Jan 2012 | EP |
2464138 | Jun 2012 | EP |
2902568 | Aug 2015 | EP |
H10322622 | Dec 1998 | JP |
2001251581 | Sep 2001 | JP |
2003101939 | Apr 2003 | JP |
2004072540 | Mar 2004 | JP |
2004260297 | Sep 2004 | JP |
2005317165 | Nov 2005 | JP |
2006211311 | Aug 2006 | JP |
2006245745 | Sep 2006 | JP |
2006333451 | Dec 2006 | JP |
2007202206 | Aug 2007 | JP |
2008167019 | Jul 2008 | JP |
2008176538 | Jul 2008 | JP |
2011009816 | Jan 2011 | JP |
2011075935 | Apr 2011 | JP |
2011514789 | May 2011 | JP |
2012029150 | Feb 2012 | JP |
2012037910 | Feb 2012 | JP |
5034516 | Sep 2012 | JP |
2013175854 | Sep 2013 | JP |
2014157460 | Aug 2014 | JP |
2014187687 | Oct 2014 | JP |
2016048852 | Apr 2016 | JP |
2015139016 | Mar 2018 | JP |
20040025073 | Mar 2004 | KR |
20060128295 | Dec 2006 | KR |
9837694 | Aug 1998 | WO |
0243353 | May 2002 | WO |
2005059807 | Jun 2005 | WO |
2007064987 | Jun 2007 | WO |
2007098067 | Nov 2007 | WO |
2009073925 | Jun 2009 | WO |
2011040999 | Apr 2011 | WO |
2013016626 | Jan 2013 | WO |
2013166456 | Nov 2013 | WO |
2014072742 | May 2014 | WO |
2014164782 | Oct 2014 | WO |
2014179017 | Nov 2014 | WO |
2016030380 | Mar 2016 | WO |
2016030384 | Mar 2016 | WO |
2016030477 | Mar 2016 | WO |
2016033545 | Mar 2016 | WO |
2016034899 | Mar 2016 | WO |
2016055761 | Apr 2016 | WO |
2016057416 | Apr 2016 | WO |
2016057844 | Apr 2016 | WO |
Entry |
---|
Office Action issued in JP Application No. 2020-564749, 6 pages, dated Apr. 14, 2023. |
Office Action issued in CN Application No. 201980042463.5, 19 pages, dated Jun. 1, 2023. |
A. Baijal et al. “Sports Highlights Generation Based on Acoustic Events Detection: A Rugby Case Study”, IEEE International Conference on Consumer Electronics (ICCE), pp. 20-23, 2015. |
A. Krizhevsky et al. “ImageNet Classification with Deep Convolutional Neural Networks”, In Proc. NIPS, pp. 1097-1105, 2012. |
Abstract for Chinese Application No. 106503702, published Mar. 15, 2017. |
Boxfish/TV's API; www.boxfish.com, (retrieved Mar. 28, 2017), 5 pages. |
C. J. C. Burges “A Tutorial on Support Vector Machines for Pattern Recognition”, Springer, Data Mining and Knowledge Discovery, Jun. 1998, vol. 2, Issue 2, pp. 121-167. |
D. A. Sadlier et al. “A Combined Audio-Visual Contribution to Event Detection in Field Sports Broadcast Video. Case Study: Gaelic Football”, Proceedings of the 3rd IEEE International Symposium on Signal Processing and Information Technology, Dec. 2003. |
D. A. Sadlier et al. “Event Detection in Field Sports Video Using Audio-Visual Features and a Support Vector Machine”, IEEE Trans. on Circuits and Systems for Video Technology, vol. 15, No. 10, Oct. 2005. |
E. Kijak et al. “Audiovisual Integration for Tennis Broadcast Structuring”, Multimedia Tools and Applications, Springer, vol. 30, Issue 3, pp. 289-311, Sep. 2006. |
H. Harb, et al., Highlights Detection in Sports Videos Based on Audio Analysis, pp. 1-4, Sep. 2009. |
Huang-Chia Shih “A Survey on Content-aware Video Analysis for Sports”, IEEE Trans. on Circuits and Systems for Video Technology, vol. 99, No. 9, Jan. 2017. |
International Search Report for PCT/US2014/060649 dated Jan. 8, 2015 (9 pages). |
International Search Report for PCT/US2014/060651 dated Jan. 19, 2015 (9 pages). |
J. Han et al. “A Unified and Efficient Framework for Court-Net Sports Video Analysis Using 3-D Camera Modeling”, Proceedings vol. 6506, Multimedia Content Access: Algorithms and Systems; 65060F (2007). |
J. Ye, et al., Audio-Based Sports Highlight Detection by Fourier Local-Auto-Correlations, 11th Annual Conference of the International Speech Communication Association, Sep. 2010, pp. 2198-2201. |
Jin, S.H., et al., “Intelligent broadcasting system and services for personalized semantic contents consumption”, Expert Systems with Applications, Oxford, GB, vol. 31, No. 1, Jul. 1, 2006, pp. 164-173. |
Jin, S.H., et al., “Real-time content filtering for live broadcasts in TV terminals”, Multimedia Tools and Applications, Kluwer Academic Publishers, BO, vol. 36, No. 3, Jun. 29, 2007, pp. 285-301. |
L. Neumann, J. Matas, “Real-Time Scene Text Localization and Recognition”, 5th IEEE Conference on Computer Vision and Pattern Recognition, Jun. 2012. |
M. Baillie et al. “Audio-based Event Detection for Sports Video”, International Conference on Image and Video, CIVR 2003. |
M. Merler, et al., “The Excitement of Sports: Automatic Highlights Using Audio/Visual Cues”, Dec. 31, 2017, pp. 2520-2523. |
Miyamori, Hisashi “Automatic Generation of Personalized Digest Based on Context Flow and Distinctive Events”, IEICE Technical Report, Jul. 10, 2003, vol. 103, No. 209, pp. 35-40. |
P. F. Felzenszwalb et al. “Efficient Graph-Based Image Segmentation”, International Journal of Computer Vision, Sep. 2004, vol. 59, Issue 2, pp. 167-181. |
Q. Huang et al. “Hierarchical Language Modeling for Audio Events Detection in a Sports Game”, IEEE International Conference on Acoustics, Speech and Signal Processing, 2010. |
Q. Huang et al. “Inferring the Structure of a Tennis Game Using Audio Information, IEEE Trans. on Audio Speech and Language Proc., Oct. 2011.”. |
R. Natarajan et al. “Audio-Based Event Detection in Videos-A Comprehensive Survey”, Int. Journal of Engineering and Technology, vol. 6 No. 4 Aug.-Sep. 2014. |
R. Smith “An Overview of the Tesseract OCR Engine”, International Conference on Document Analysis and Recognition, 2007. |
Thuuz Sports, “Frequently Asked Questions”, www.thuuz.com/faq/, (retrieved Mar. 28, 2017), 5 pages. |
U.S. Pat. No. 10,462,538 B2, Oct. 2019, Packard et al. (withdrawn). |
Y. Rui et al. “Automatically Extracting Highlights for TV Baseball Programs”, Proceedings of the eighth ACM international conference on Multimedia, 2000. |
Y.A. LeCun et al. “Efficient BackProp” Neural Networks: Tricks of the Trade. Lecture Notes in Computer Science, vol. 7700, Springer, 2012. |
Yuma Koizumi, and Katsunori Ito. “Decomposition of volume trajectory into dynamics and articulations based on transitional state space representation.” IEICE Transactions D 98.3 (2015): 492-500. |
Number | Date | Country | |
---|---|---|---|
20230230377 A1 | Jul 2023 | US |
Number | Date | Country | |
---|---|---|---|
62746454 | Oct 2018 | US | |
62712041 | Jul 2018 | US | |
62680955 | Jun 2018 | US | |
62673411 | May 2018 | US | |
62673413 | May 2018 | US | |
62673412 | May 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17449882 | Oct 2021 | US |
Child | 18188926 | US | |
Parent | 16411713 | May 2019 | US |
Child | 17449882 | US |