CROSS-REFERENCE TO RELATED APPLICATIONSThe present application claims priority to U.S. provisional patent application Ser. No. 61/165,197, filed Mar. 31, 2009, entitled “Building Large VOD Libraries With Next Generation On Demand Architecture,” hereby incorporated by reference as to its entirety.
BACKGROUNDIncreasingly, cable operators are using video-on-demand (VOD) as a competitive advantage. Alternative video delivery methods such as movie download or video streaming via the Internet are also becoming more practical and feasible as service providers deploy either DOCSIS 3.0 wideband or fiber-to-the-home technologies.
Using the existing managed network approach that is adopted by various cable and telephone network operators, VOD content is typically encoded in MPEG-2 format and replicated/pushed along with metadata via a satellite or Internet Protocol (IP) backbone to local VOD systems. However, this approach does not necessarily scale well as the amount of available content increases. For instance, as the network grows and the amount of VOD content expands, it quickly becomes overly burdensome on the network to replicate all of the content out to local VOD systems.
In an alternative emerging “over-the-top” approach, the broadband Internet is typically used as the content distribution and streaming platform. In this approach, content aggregators and integrators license and publish movies and television shows via Internet websites. Client devices such as set-top boxes may be able to access media content via the Internet using a broadband pipe such as via a cable modem, DSL connection, or fiber-to-the-home (FTTH) network. Content distribution within the Internet is often driven by a “pull” model in response to client device requests.
However, there are several limitations of this over-the-top approach. For instance, it may be difficult to achieve high concurrency for high-definition (HD) VOD streaming, and this approach relies on public Internet infrastructure that imposes quality of service constraints, which may result in substantial network congestion. Moreover, there is typically a lack of end-to-end network resource management, as well as inconsistent premium content offerings due to lack of programming agreements with content providers. In addition, a pure over-the-top approach typically requires subscribers to purchase a separate client device appliance for viewing VOD assets.
There are significant opportunities for network operators to expand the current VOD architecture in order to support larger VOD content libraries that provide an expansive amount of content, and to provide the VOD offerings to devices other than conventional set-top boxes, such as personal computers and portable media players. Such a new architecture may be capable of handling larger non-VOD content libraries as well.
SUMMARYAn integrated video-on-demand (VOD) content library platform may be provided that supports virtually an unlimited amount of media content assets such as movies, television shows, Internet video, and user-generated content. This approach may combine features of existing managed network approaches with emerging over-the-top approaches, by introducing a content delivery network that has a large content library, typically made up of smaller libraries interconnected together and with content providers and local head ends via a high-speed backbone, such as an Internet Protocol (IP) backbone, and/or via regional networks.
The content delivery network may enable operators to cost-effectively provide a much larger amount of media content, such as VOD content, by serving at least some of the content from national and regional libraries instead of replicating all content to the local distribution systems (e.g., head end systems) as is conventionally done. Intelligent caching may be used by the content delivery network and/or by the local systems, where the caching locations and caching timeframes for each piece of content may be based on such priority factors as the actual or expected popularity (global or local) of the content, the actual or expected usage (global or local) of the content, the quality of service (QoS) of the content, the data size of the content, storage and responsiveness expectations defined by service-level agreements (SLAs), the demographics of the expected audience for the content, and the identity of the provider or owner of the content. Such intelligent caching may be expected to reduce network bandwidth usage and enhance overall service performance by potentially reducing the amount of redundant storage and transfer that would ordinarily be needed as the amount of available content increases.
As a default, most content may be stored in the main content library. Then, depending upon content popularity and/or other factors, the content may be replicated and propagated ahead of time, or in response to a client request, to or near one or more of the local head end systems. Upon a subscriber's request for content, the local system serving that subscriber may begin immediately streaming the content if the content is already cached at the local system. If the content is not cached at the local system, then the local system may pull the content from the content library or elsewhere. The pulled content may thereafter continue to be cached at the local system for a period of time to serve expected future requests from other subscribers served by that local system, and then later removed if desired.
In addition, certain content, such as trick files, may be generated dynamically as needed. In this way, it is not necessarily to pre-generate and pre-store all possible trick files for real-time and non-real-time content.
And, because not all content will necessarily be stored at all local regions of the network, a bi-directional transfer of content between local regions of the network may be provided for. For example, a first head end system may not only receive content downstream from the main network, but may also send content upstream through the network to another head end system requesting the content.
Thus, some aspects as described herein may be directed to systems, apparatuses, methods, and software for receiving from a first client device a first request for a media content asset; responsive to the first request, determining whether the media content asset is stored at a first location in a network; responsive to determining that the media content asset is not stored at the first location, fetching the media content asset from a second location in the network and storing the media content asset in a computer-readable medium at the first location; streaming to the first client device the media content asset stored at the first location; and responsive to a second request from a second client device, streaming to the second client device the media content asset stored at the first location.
Further aspects are directed to systems, apparatuses, methods, and software utilizing a network storing a plurality of media content assets, for determining a popularity of each of the media content assets; and for each of the media content assets, replicating the stored media content asset to a particular computer-readable medium in the network that depends upon the determined popularity for that media content asset.
Still further aspects are directed to systems, apparatuses, methods, and software for receiving a request for a first media content asset; determining whether the first media content asset is already stored; and responsive to determining that the first media content asset is not already stored, generating by a computer the first media content asset from a stored second media content asset.
Yet further aspects are directed to systems, apparatuses, methods, and software for receiving first media content and associated first metadata at a first video-on-demand system, the first video-on-demand system being configured to stream media content assets to a first plurality of client devices; storing, by the first video-on-demand system, a first media content asset in a first computer-readable medium; and sending, by the first video-on-demand system, the first metadata to a database, wherein the database is accessible by a second video-on-demand system configured to stream media content assets to a second plurality of client devices to which the first video-on-demand system is not configured to stream media content assets.
These and other aspects of the disclosure will be apparent upon consideration of the following detailed description.
BRIEF DESCRIPTION OF THE DRAWINGSA more complete understanding of the present disclosure and the potential advantages of various aspects described herein may be acquired by referring to the following description in consideration of the accompanying drawings, in which like reference numbers indicate like features, and wherein:
FIG. 1 is a functional block diagram of an illustrativecontent delivery network100 and surrounding environment.
FIG. 2 is another illustrative functional block diagram of a portion ofcontent delivery network100 in conjunction with head ends and client devices.
FIG. 3 is a diagram of illustrative interactions between various elements of a content delivery network and its environment, when performing ingest of non-real-time media content assets.
FIG. 4 is a diagram of illustrative interactions between various elements of a content delivery network and its environment, when performing ingest of real-time media content assets.
FIG. 5 is a diagram of illustrative interactions between various elements of a content delivery network and its environment, when pre-positioning a media content asset already stored in a content library to a replicated location.
FIG. 6 is a diagram of illustrative interactions between various elements of a content delivery network and its environment, when streaming content to a client device in response to a request from the client device.
FIG. 7 is a diagram of illustrative interactions between various elements of a content delivery network and its environment, when a pre-stored trick file is requested to be streamed to a client device.
FIG. 8 is another diagram of illustrative interactions between various elements of a content delivery network and its environment, when a trick file that has not yet been created is requested to be streamed to a client device.
FIG. 9 is a functional block diagram of an example of how a content delivery network may be used to perform bi-directional local content sharing between head ends.
FIG. 10 shows illustrative interactions between various equipment when a local media content asset is shared between streaming servers of two different head ends.
DETAILED DESCRIPTIONFIG. 1 is a functional block diagram of an illustrativecontent delivery network100 and surrounding environment. In this example,content delivery network100 includes acontent library101, acaching gateway102, a content propagation manager (CPM)103, a content library service (CLS)104, a content ingestblock105, and a real-timeingest block106, each being communicatively coupled to each other (bidirectionally or unidirectionally as desired) in the manner shown inFIG. 1.
Content delivery network100 in this example may be communicatively coupled to (again, bidirectionally or unidirectionally as desired) the following functional blocks: a content ingestmanager107, atranscoder108, a derivedcontent generator109, a real-time manager110, a rights management system (RMS)111, a content management system (CMS)112, a metadata distribution hub (MD H)113, an asset management system (AMS)114, one or more video-on-demand (VOD)backoffices115, one or moreedge resource managers116, one ormore streaming servers117, one or more edge quadrature amplitude modulation (QAM)units118, one ormore staging servers119, one or more cable modem termination systems (CMTSs)120, adata warehouse server121, and anetwork management system122 Together,VOD backoffices115,edge resource managers116,streaming servers117,edge QAMs118,staging servers119, and CMTSs120 may be considered as one or more head ends190 forcontent delivery network100.
Content delivery network100 may be any type of network, and may be a single network or a combination of multiple networks, such as a television distribution network, a telephone network, and/or the Internet. Physically,content delivery network100 may be embodied as multiple computers communicatively coupled together in a wired and/or wireless manner.Content delivery network100 may also be communicatively coupled to a plurality of end-user client devices201A-H (FIG. 2) in a wired and/or wireless manner, such as via coaxial cable, optical fiber, hybrid-fiber-coaxial cable, and/or cellular data or telephone links. Whilecontent delivery network100 is shown to encompass certain functional blocks and not other functional blocks, it is noted that this division may be functional rather than necessarily physical, and somewhat arbitrary. Thus,content delivery network100 may alternatively include others of the functions shown inFIG. 1. For instance,head ends190 may be considered part ofcontent delivery network100. Alternatively or additionally, some of the functional blocks shown inFIG. 1 as part ofcontent delivery network100 may be considered outside ofcontent delivery network100.
Any of the above-mentioned functional blocks101-122 may each be implemented, for example, as a computer or as a system or device that includes a computer. The term “computer” as referred to herein broadly refers to any electronic, electro-optical, and/or mechanical device, or system of multiple physically separate or physically joined such devices, that is able to process and manipulate information, such as in the form of data. Non-limiting examples of a computer include one or more personal computers (e.g., desktop or laptop), servers, smart phones, personal digital assistants (PDAs), television set top boxes, and/or a system of these in any combination or subcombination. In addition, a given computer may be physically located completely in one location or may be distributed amongst a plurality of locations (i.e., may implement distributive computing). A computer may be or include a general-purpose computer and/or a dedicated computer configured to perform only certain limited functions.
A computer typically includes hardware that may execute software and/or be configured in hardware to perform specific functions. The software may be stored on a computer-readable medium in the form of computer-readable instructions. A computer may read those computer-readable instructions, and in response perform various steps as defined by those computer-readable instructions. Thus, any functions attributed to any of functional blocks101-122 as described herein may be implemented, for example, by reading and executing such computer-readable instructions for performing those functions, and/or by any hardware subsystem (e.g., a processor) from which the computer is composed.
The term “computer-readable medium” as used herein includes not only a single physical medium or single type of medium, but also a combination of one or more physical media and/or types of media. Examples of a computer-readable medium include, but are not limited to, one or more memories, hard drives, optical discs (such as CDs or DVDs), magnetic discs, and magnetic tape drives.
Such a computer-readable medium may store computer-readable instructions (e.g., software) and/or computer-readable data (i.e., information that may or may not be executable). In the present example, a computer-readable medium (such as memory) may be included in any one or more of functional blocks101-122 and may store computer-executable instructions and/or data used by any of those blocks101-122. Alternatively or additionally, such a computer-readable medium storing the data and/or software may be physically separate from, yet accessible by, any of blocks101-122.
In general,content delivery network100 is configured to receive a plurality of media content assets, store the media content assets in various distributed locations such ascontent library101, one ormore caching gateways102, and/or one or more head ends190 such as one ormore streaming servers117.Content delivery network100 is further configured to forward selected ones of the media content assets to end users viaedge QAMs118. In other embodiments, media content assets may be streamed to client devices201 by other additional or alternative means, such as over the Internet or over a cellular data network. In such a case,QAMs118 may be replaced or augmented with other devices appropriate for providing the requested media content assets to client devices201. Each media content asset may be stored at a single location withincontent delivery network100 and/or head ends190, or replicated among multiple different locations withincontent delivery network100 and/or head ends190.
A “media content asset” is any unit of media content that includes audio and/or video content. As used herein, the term, “video content asset,” is a media content asset that includes video content and may optionally also include audio content. Likewise, an “audio content asset” is a media content asset that includes audio content and may optionally also include video content. Examples of a media content asset includes, without limitation, movies, television programs, news programs, advertisements, video clips, audio (e.g., radio) programs, audio clips, and trick files. Media content assets may include live content (e.g., a live sports game) and/or pre-recorded content, and may include VOD content or pre-scheduled broadcast content. A media content asset may also be associated with or include metadata that is descriptive of the media content asset and/or the content therein. For example, such metadata may include or otherwise indicate a description of the content in the media content assets, a date or date range of the content, a time length of the content, a data size of the content, a format of the content, a bit rate of the content, etc.
Referring again toFIG. 1, one or more content providers provide media content assets in the form of files (typically for non-real-time content) and/or streams (typically for real-time content), along with any associated content metadata totranscoder108, which may transcode the incoming content to a target format, such as by transcoding the content to different CODEC standards and resolutions. Derivedcontent generator109 generates trick files and other types of derived content from the original content, such as fast-forward and rewind trick files, movie trailers, re-formatted content, and advertising-spliced content. Content ingestmanager107 and content ingestblock105 handle the receipt and ingest of the non-real-time content intocontent delivery network100, including managing ingest provisioning and life cycle and negotiating withCPM103 for storage locations withincontent library101.
Real-time manager110 and real-time ingestblock106 have a similar function as content ingestmanager107 and content ingestblock105, except that these functions are performed for incoming streamed real-time content. In addition, real-time manager110 assigns multicast addresses and ports for real-time content distribution. The encoded video program of a real-time media content asset may be sent via, e.g., IP multicast, and real-time manager110 may direct real-time ingestblock106 to join the corresponding multicast and record the encoded stream based on the start and end times. The resulting files may be stored incontent library101,caching gateways102, and/or streamingservers117 as desired. Client devices201 may request session and streaming of a real-time media content asset during and/or after the real-time ingest of that particular asset intocontent delivery network100, and may further perform certain trick modes on real-time content assets as appropriate, such as rewind and pause.
MDH113 interfaces withcontent delivery network100, and the metadata and status for stored media content assets may be reported toMDH113 so as to make the assets available for applications such as for queries by, and storage to, a unified database901 (FIG. 9), and for asset status and verification.
AMS114 manages VOD asset metadata, andCMS112 publishes the asset metadata toAMS114, such as via a CableLabs ADI interface. The asset metadata of the ADI package is sent toAMS114 while the content files are ingested intocontent delivery network100. Together,CMS112 andRMS111 may support both VOD content metadata (such as using CableLabs ADI) and Internet video metadata (such as using Media Really Simple Syndication, or RSS) formats.
Interface with Asset Management System: The content metadata is published to the Regional Asset Management Systems via the CableLabs ADI interface. Only the metadata is sent via this interface while the content files are ingested into the CDN.
RMS111 manages the licensing rights of real-time media content assets, including enabling and disabling based on licensing rights whether each real-time media content asset may be real-time ingested, determining licensing start and end times of real-time media content assets, and controlling certain business rules such as disabling fast forward trick play for real-time media content assets.
Data warehouse server121 archives content usage statistics periodically received fromcontent delivery network100 and/or VOD backoffices115.
Network management system122 provides a network management interface for configuration, monitoring, fault detection, and alarm functions.
Content library101 includes one or more physical computer-readable media for storing the media content assets ingested by content ingest105 and real-time ingest106, along with one or more computers for managing the input, output, and internal data management ofcontent library101. Whilecontent library101 is shown as a single functional block inFIG. 1, in reality the various computer-readable media may include multiple computer-readable media and computers distributed over a wide geographical area, especially wherecontent delivery network100 itself services client devices201 that are geographically diverse. The computer-readable media and computers may be interconnected via, e.g., an IP network. Thus,content library101 may actually be a collection of multiple libraries that together are functionally treated as one logical library. In some embodiments,content library101 may have a multi-tiered hierarchical topology of the various computer-readable media.
Caching gateways102 include one or more physical computer-readable media for storing at least a subset of the media content assets stored incontent library101, along with one or more computers for managing the input, output, and internal data management ofcaching gateways102. In general, media content assets may be replicated into one or more ofcaching gateways102 as desired. Thus, while not necessarily always the case, it may be expected that any media content assets stored incaching gateways102 may also be stored somewhere incontent library101. As is the case withcontent library101, the various computer-readable media ofcaching gateways102 may also be distributed over a wide geographical area. While cachinggateways102 andcontent library101 are shown as separate functional blocks, physically they may share some or all of the same computer-readable media and/or computers. Alternatively,caching gateways102 andcontent library101 may be embodied as physically separate systems.
CPM103 may containmultiple content library101 nodes coupled via national and/or regional networks, such as IP networks.CPM103 is responsible for replicating and/or moving the media content assets through various storage locations ofcontent library110 and/orcaching gateways102 in a dynamic manner based on content popularity, content usage, and/or other factors.CPM103 is further responsible for deciding and directing which particular ones of the streamingservers117 will stream particular content to client devices201. This decision may be based on, for example, the current or expected load of thevarious streaming servers117.
The locations for all media content assets withincontent delivery network100 are maintained and updated by theCLS104. Upon a session setup request from a client device201, if the requested content is already pre-positioned or cached at astreaming server117, the content will be streamed from streamingserver117 to the requestingclient device117. If the content is not available at thestreaming server117,head end190 will queryCLS104 for the locations of the requested media content asset withincontent library101 and/orcaching gateways102 in order to fetch the media content asset and stream it to the requesting client device201.
Upon initial ingest of a media content asset, content ingestblock105 and real-time ingestblock106 report the status and location of the media content asset toCLS104. Then, when the location is requested byhead end190,CPM103 fetches the reported location fromCLS104. Where a media content asset is to be later replicated or moved,CPM103 is responsible for updatingCLS104 dynamically on the new media content asset location and/or status. Thus, ingeneral CPM103 is responsible for deciding where media content assets are to be stored, andCLS104 is responsive to keeping track of those locations.
In the present example, multiple head ends190 may be distributed geographically to serve the various client devices201, and may each contain the functional blocks as shown inFIG. 1, which may operate as follows. Also, as shown by way of example inFIG. 2, eachhead end190 may be coupled to, and serve, only a subset of the total set of client devices201. Likewise, each streamingserver117 within a respective headend may be coupled to, and serve, only that respective subset of client devices201. Thus, content to be delivered to a given client device201 is forwarded to and provided by one of the streamingservers117 that is coupled to the target client device201.
Returning toFIG. 1,VOD backoffice115 for each of head ends190 may manage the receipt and fulfillment of VOD requests from those client devices201 that are served by therespective head end190, including session setup and stream control management of VOD media content assets. In addition,VOD backoffice115 may receive asset title and content metadata fromCMS112 throughAMS114, and pass business rules such as trick mode restriction to streamingserver117 upon session setup time, assist with allocatingedge QAM118 resources for VOD sessions, and assist with advertisement insertion into the stream.
For instance, in response to a VOD request from one of client devices201 served by aparticular VOD backoffice115, that VOD backoffice115 may obtain the requested VOD media content asset from content delivery network100 (if not already stored in head end190) and cause the asset to be streamed in well-known ways to the requesting client device201 via streamingserver117 andedge QAM118, and/or CMTS120 (which provides IP-based content streaming to client devices201).Streaming server117 may also include one or more computer-readable media for caching one or more of the media content assets, especially those that have been recently streamed by that streamingserver117.
Staging server119 is used for Internet Protocol (IP) based streaming services for client data devices such as personal computers and smart phones.Staging server119 supports various content formats and protocols, such as hypertext transfer protocol (HTTP) progressive download, FLASH download, and WINDOWS media streaming.Staging server119 may also use the standard HTTP-based content locate and streaming protocol for pulling content fromcontent delivery network100. In addition, stagingserver119 utilizes caching algorithms for caching library content fromcontent delivery network100.
Edge resource managers116 manage bandwidth and program resources onQAMs118.Edge resource managers116 may support session requests from multiple session managers. If an edge device such asedge QAM118 orCMTS120 announces a failure to one of theedge resource managers116, thatedge resource manager116 may be configured to not make any session related decisions. Thatedge resource manager116 may instead forward a notification to the VOD system to determine how to resolve the issue.
As stated above, the media content assets may be permanently or temporarily stored incontent delivery network100 and/or at one or more head ends190 at various distributed locations, includingcontent library101, one ormore caching gateways102, and/or one ormore streaming servers117. The actual locations at which each media content asset is stored may depend upon one or more factors, such as how popular the media content asset is to the end users, how popular the media content asset is expected to be, how often the media content assets is requested by one or more of the end users, and/or which end users have requested or are expected to request the media content assets. The locations at which the media content assets are stored may change dynamically over time in responses to changes in these and/or other factors.
FIG. 2 shows another illustrative functional block diagram of a portion ofcontent delivery network100 in conjunction with head ends190A-D andclient devices201A-H. In this view,caching gateways102 are shown asmultiple caching gateways102A-E. The number of caching gateways shown here is merely an example; there may be a fewer or greater number of caching gateways. Also in this example,caching gateways102A-E are shown as being inter-coupled in a multi-tiered hierarchical topology. In particular, a first tier ofcaching gateways102A,102B and a second tier ofcaching gateways102C-E, are provided. Also, a third tier in the hierarchy may be considered to be head ends190A-D. Such a hierarchical topology may make certain organizations of media content assets easier. For example, a tier that is more local to ahead end190 may store copies of those content media assets that are the most requested or most popular (e.g., top ten) for client devices201 of thathead end190, and a tier that is less local to thathead end190 may store copies of those content media assets that are less requested or less popular (e.g., top twenty) for client devices201 of that head end. Using such a hierarchical caching technique, those storage nodes that are closer and more local to head ends may not need to be as large as those storage nodes that are more global and less local to head ends. Moreover, each tier may have its own network bandwidth resource management capability. For instance, each tier may be able to independently manage bit rates, compression, statistical multiplexing, and user limits. However, any topology of caching gateways and head ends may be used. As mentioned previously,content library101 may also have a multi-tiered hierarchical topology.
Example operation scenarios ofcontent delivery network100 will now be described with reference toFIGS. 3-8.
FIG. 3 is a diagram of illustrative interactions between various elements ofcontent delivery network100 and its environment, when performing ingest of non-real-time media content assets. In this example, metadata associated with a certain media content asset is delivered from a content source toRMS111 and/orCMS112.RMS111 and/orCMS112 generate a unique identifier for the media content asset, and provision the media content asset with content ingestmanager107. Content ingestmanager107 then instructs content ingestblock105 to begin content ingest. Content ingestblock105queries CPM103, and inresponse CPM103 determines and returns to content ingestblock105 the target location(s) at which the media content asset will be stored incontent library101. Also, content ingestmanager107 periodically provides the content transfer status toRMS111 and/orCMS112.
Next content ingestblock105 retrieves the media content asset file from the content provider, and also interfaces withtranscoder108 and derivedcontent generator109 as needed, for transcoding the media content asset file and generating auxiliary trick files. The retrieved files and any generated trick files are saved tocontent library101 at the previously determined location(s). Content ingestblock105 reports toCLS104 upon completion of ingesting the content, and also to content ingestmanager107 about content transfer status. Then, content ingestmanager107 reports, or responds to a request from,RMS111 and/orCMS112 regarding content status.
FIG. 4 is a diagram of illustrative interactions between various elements ofcontent delivery network100 and its environment, when performing ingest of real-time media content assets. The process is similar, with the main difference being that real-time manager110 is used in place of content ingestmanager107, and real-time ingestblock106 is used in place of content ingestblock105. First, program guide metadata including a real-time program schedule is delivered from a content source toRMS111 and/orCMS112.RMS111 and/orCMS112 generate a unique identifier for the real-time media content asset, and provision the media content asset with content ingestmanager107. Real-time manager110 then instructs content real-time ingestblock106 to begin stream ingest at times defined by the real-time program schedule. Real-time ingestblock106queries CPM103, and inresponse CPM103 determines and returns to content ingestblock105 the target location(s) at which the real-time media content asset will be stored incontent library101. Also, content ingestmanager107 periodically provides the content transfer status toRMS111 and/orCMS112.
Upon the scheduled start of the real-time program, real-time ingestblock106 retrieves the media content asset stream from the content provider such as via IP multicast, and also interfaces withtranscoder108 and derivedcontent generator109 as needed, for transcoding the media content asset file and generating auxiliary trick files. The retrieved files and any generated trick files are saved tocontent library101 at the previously determined location(s). Real-time ingestblock106 reports toCLS104 upon completion of ingesting the stream, and also to real-time manager110 about content transfer status. Then, real-time manager110 reports, or responds to a request from,RMS111 and/orCMS112 regarding content status.
FIG. 5 is a diagram of illustrative interactions between various elements ofcontent delivery network100 and its environment, when pre-positioning an entire media content asset, or a portion thereof, already stored incontent library101 to a replicated location. This pre-positioning may be performed regardless of any client device201 request for the media content asset, and may be performed so as to replicate the media content asset to a location that is closer—geographically or logically—to client devices201 that are expected to request the media content asset. In this particular example, a media content asset (or a portion thereof) is pre-positioned fromcontent library110 to astreaming server117. However, this process could alternatively be used to pre-position the media content asset from and to any other locations, such ascaching gateway102 or elsewhere. Also in this particular example, the media content asset is a VOD asset, however any type of media content asset may be used.
New content is provisioned and ingested intocontent distribution network100 byRMS111 and/orCMS112, which publish media content asset metadata toAMS114.AMS114, in turn publishes the metadata to some or all of theVOD backoffices115. The VOD backoffice115 associated with thetarget streaming server117 determines that pre-positioning at thestreaming server117 is desired, and initiates a content transfer command to streamingserver117. Inresponse streaming server117 sends a content locate and transfer request toCLS104. In response,CLS103redirects streaming server117 to the actual location of the desired media content asset incontent library101. In response, the located media content asset (or a portion thereof) fromcontent library101 is replicated to streamingserver117.
In the example ofFIG. 5, pre-positioning of a media content asset by replication occurred in response to a request fromVOD backoffice115. However,CPM103 may alternatively initiate pre-positioning. Also, although inFIG. 5 the media content asset was pre-positioned to streamingserver117, such pre-positioning may be made to any computer-readable medium incontent delivery network100 and/or outside ofcontent delivery network100, such as inhead end190. For example, a media content asset (or a portion thereof) may be pre-positioned to one ormore caching gateways102.
Moreover, the particular location(s) to which a media content asset is pre-positioned, as well as whether or not such pre-positioning should occur in the first place, may be determined responsive to a determination that the media content asset is popular or is expected to be popular. This determination may be made by, e.g.,CPM103 and/orVOD backoffice115. And, the particular location(s) to which the media content asset is pre-positioned may be determined based on which geographical locations served bycontent data network100 and/or head ends190 the popularity is expected to occur. For example, a newly-released movie may be expected to be popular throughout the country, and so the movie (or a portion thereof) may be pre-positioned to all ormost caching gateways102 and/or VOD backoffices115. Or, a media content asset, or portion thereof, of particular interest to only a certain geographic region may be pre-positioned only to one ormore caching gateways102 and/orVOD backoffices115 that serve that geographic region.
In addition, although a media content asset may be pre-positioned prior to any or substantial requests for that media content asset by client devices201, the media content asset (or portion thereof) may further be replicated to one or more additional locations based on actual experienced requests by client devices201 for that media content asset. And, once a media content asset has been pre-positioned or otherwise replicated to a location, the replicated copy of the media content asset may remain at that location for a predetermined period of time or until it is later determined that the popularity for that media content asset has dropped below a predetermined threshold, after which time the replicated copy may be deleted or moved to yet another location in the network.
Popularity of a media content asset may be determined in many ways, such as being based on a measured frequency of client device201 requests for the media content asset, determining whether the media content asset has been requested by client devices201 a sufficient number of times over a predetermined period of time, and/or based on historical or predicted future demand for the media content asset. Also, such determinations may be made on a global basis (i.e., across the entire network) and/or on a geographic regional basis, and may be made more than once over time to re-determine the popularity of the media content asset and re-replicate the entire media content asset or a portion thereof as appropriate based on the newly-determined popularity.
Trick files may be treated like any other type of media content asset, and thus may be pre-positioned and otherwise replicated in the same manner as any other type of media content asset. In some cases, it may be desirable to locate trick files in the same computer-readable media and/or otherwise a same node of the network as their associated program content files. In other cases, it may be desirable to locate trick files independently of the location of their associated program content if it is not expected that the trick file will be as popular as the program content itself.
FIG. 6 is a diagram of illustrative interactions between various elements ofcontent delivery network100 and its environment, when streaming content to a client device201 in response to a request from the client device201. In this particular example, the media content asset is a VOD asset; however any type of media content asset may be used. Also in this particular example, the desired media content asset is streamed from a location incontent library101, however the media content asset may be stored anywhere such as incaching gateway102 or in streamingserver117.
As before, new content is provisioned and ingested intocontent distribution network100 byRMS111 and/orCMS112, which publish media content asset metadata toAMS114.AMS114, in turn publishes the metadata to some or all of theVOD backoffices115. One of the VOD backoffices115 optimistically processes a session setup request from client device201, and in response to the request sends a session setup request to streamingserver117. In response, streamingserver117 checks its local cache for the requested content. If the content is available at the local cache of streamingserver117, then streamingserver117 will stream the content directly to the requesting client device201. If the requested content is not stored at the local cache of streamingserver117, then streamingserver117 sends a content locate and transfer request toCLS104.
In response,CLS104redirects streaming server117 to the actual location in content library101 (or elsewhere) where the requested media content asset is stored. In response to this redirection, streamingserver117 performs content transfer of the media content asset fromcontent library101, and streams the transferred content to the requesting client device201.
FIG. 7 is a diagram of illustrative interactions between various elements ofcontent delivery network100 and its environment, when a trick file or other type of derived content is requested to be streamed to a client device201. In this particular example, the requested trick file is already generated and is stored incontent library101. However, the trick file may be stored elsewhere, such as incaching gateway102 or streamingserver117.
After an initial setup request and response between client device201 and VOD backoffice201, content fromcontent library101 is streamed by streamingserver117 to client device201. During the content streaming, the user of client device201 requests a trick play function, such as by selecting “fast forward” on the remote control. In response to the user request, client device201 sends a trick play command from client device201 to streamingserver117. In response, streamingserver117 checks its local cache for the requested trick file. If the trick file is available at the local cache of streamingserver117, then streamingserver117 will stream the trick file directly to the requesting client device201. If the requested trick file is not stored at the local cache of streamingserver117, then streamingserver117 sends a content locate and transfer request toCLS104.
In response,CLS104redirects streaming server117 to the actual location in content library101 (or elsewhere) where the requested trick file is stored. In response to this redirection, streamingserver117 performs transfer of the trick file fromcontent library101, and streams the transferred trick file to the requesting client device201.
Later, during streaming of the trick file, client device201 may request that the trick play end (in response to a user request to end the trick play function) and that the content stream resume to the normal content that was streaming prior to the trick play. This request is received by streamingserver117, and inresponse streaming server117 resumes normal content streaming to client device201.
FIG. 8 is another diagram of illustrative interactions between various elements ofcontent delivery network100 and its environment, when a trick file or other type of derived content is requested to be streamed to a client device201. This time, the requested trick file is not already generated and stored, and is to be generated in response to the client device201 request, such as by deriving the trick file from an existing pre-stored or live media content asset. Although a trick file is requested and generated in this example, such dynamic generation may be performed to generate any type of media content file, such as a VOD movie or television program.
Trick files and other types of derived media content assets may be derived from original, or parent, media content assets in several ways. In one way, the derived content may be one or more portions of the original content, such as where the derived content is a trick file or movie trailer. For instance, the derived trick file may be a video file having every nth (n>1) video frame of the original content, such as in a fast-forward trick file.
Another way to derive content is to generate a re-formatted version of the original content. For example, the derived content may be based on the original content except at a lower video and/or audio resolution, different video frame size, being transcoded using a different CODEC, or configured to be played at a different bit rate or frame rate. This type of derivation may be desirable where, for example, the client device201 that will be receiving the derived content is not compatible with the format of the original content.
Still another way to derive content from original content is to add content to the original content, such as by splicing in local or non-local advertising. This may be useful where, for example, it is desired to insert local advertising relevant to the geographical region in which client device201 that will be receiving the derived content is located.
Any or all of these types of derivation may be used separately or together in any combination to provide a derived media content asset from an original live or stored media content asset.
In the example ofFIG. 8, after an initial setup request and response between client device201 and VOD backoffice201, content fromcontent library101 is streamed by streamingserver117 to client device201. During the content streaming, the user of client device201 requests a trick play function, such as by selecting “fast forward” on the remote control. In response to the user request, client device201 sends a trick play command from client device201 to streamingserver117. In response, streamingserver117 checks its local cache for the requested trick file. If the trick file is available at the local cache of streamingserver117, then streamingserver117 will stream the trick file directly to the requesting client device201. If the requested trick file is not stored at the local cache of streamingserver117, then streamingserver117 sends a content locate and transfer request toCLS104.
In response,CLS104 determines that the trick file is not stored in content library101 (or elsewhere), and sends a trick file locate response to streamingserver117 indicating this. In response to the trick file locate response, streamingserver117 sends a trick file transfer request tocontent library101, which in turn sends a trick file object request to real-time ingest106. In response, real-time ingest106 sends a trick play generation request to derivedcontent generator109, identifying the particular trick file that is needed, and streams the transferred trick file to the requesting client device201. In response to the trick play generation request, derivedcontent generator109 generates the trick file, by deriving it from original live or store content such as described previously, and sends it (or an identifier that identifies the newly-generated trick file) back to real-time ingest106 in the form of a trick play generation response. In this example ofFIG. 8, the derived content is a trick file. However, the derived content may be any type of derived content, such as a movie trailer, reformatted content, or content spliced with local advertising.
In response to the trick play generation response, real-time ingest106 sends a trick file object response indicating or including the trick file tocontent library101, and then in response to that content library sends a trick file transfer response to streamingserver117.Content library101 may also store the newly-generated trick file in the event that it is requested again. Next, streamingserver117 begins streaming the trick file to client device201.
Later, during streaming of the trick file, client device201 may request that the trick play end (in response to a user request to end the trick play function) and that the content stream resume to the normal content that was streaming prior to the trick play. This request is received by streamingserver117, and inresponse streaming server117 resumes normal content streaming to client device201.
In other embodiments, a command may be generated by client device201, with or without user intervention, that requests derived content (trick file or otherwise). In such a situation,FIGS. 7 and 8 might be modified, for example, by the “trick play command” being replaced with the more generic “derived content request,” which may be sent automatically responsive to establishing a session. In the derived content request, client device201 may request that a particular type of formatted content be provided, such as a particular coding format, video frame size, bit rate, video and/or audio resolution, etc. The type of format requested may depend upon the type of device that client device201 is. For example, where client device201 is a smart phone with a cellular connection (directly or indirectly) to streamingserver117, client device201 may request a low-resolution and/or low bit-rate version of the content.
As previously discussed, one of the locations at which a media content asset may be stored is at astreaming server117 of ahead end190. While this may occur through normal replication of the asset fromcontent library101, it is also possible that the media content asset may be stored only locally at streamingserver117 and not centrally or globally atcontent library101. In such a case, the ingested media content asset may either be transferred fromcontent library101 to streamingserver117 without maintaining a copy atcontent library101, or the media content asset may be ingested and stored directly in streamingserver117 without first being stored incontent library101. Any of these situations may be determined and controlled by, for example,content propagation manager103. In the latter situation, a media content asset may be stored at one ormore streaming servers117 but not necessarily atcontent library101 when the media content asset is considered a local media content asset. That is, a media content asset that is expected to have interested viewers only in one or more local geographic regions, or an asset that is licensed only to be viewed in one or more local geographic regions rather than nationwide.
For example, a local semi-professional baseball game may be recorded and provided to viewers in northern California. It would not be expected that many viewers anywhere other than northern California would be interested in viewing that game. Thus, it would not necessarily be efficient to store a media content asset showing that game incontent library101 or at head ends190 or cachingservers102 not located in northern California. Therefore, it might be preferable in such a situation to normally store the asset only locally in one or more network locations in or near northern California.
However, there may be an occasion where someone outside of northern California (in the above example) would like to view the game. To accomplish this, the network may be configured to allow bi-directional sharing between head ends190 that serve different geographic regions, or in fact between any two head ends190 in the network.FIG. 9 is a functional block diagram of an example of howcontent delivery network100 may be used to perform such bi-directional local content sharing.
In the example ofFIG. 9, there are multiple content ingestmanagers107, real-time ingestmanagers110, content ingestblocks105, and real-time ingestblocks106 that are part ofcontent delivery network100, each serving a different geographic region. For instance,FIG. 9 shows that a first geographic region is served by content ingest block CI1, real-time ingest block RTI1, content ingest manager CIM1, and real-time ingest manager RTM1. Likewise, a second geographic region is served by content ingest block CI2, real-time ingest block RTI2, content ingest manager CIM2, and real-time ingest manager RTM2. Also, a firsthead end190 serving the first geographic region includes VOD backoffice VB1 and streaming server SS1, whereas asecond head end190 serving the second geographic region includes VOD backoffice VB2 and streaming server SS2. Each geographic region also serves their own sets of client devices201, represented illustratively inFIG. 9 as client device C1 for the first geographic region and as client device C2 for the second geographic region.
The first and second geographic regions may be geographically separate from each other, such as being in different cities, counties, states, or countries. In terms of distance, the first and second geographic regions may be close to each other or far from each other, such as at least five hundred miles apart from each other.
A unified database (UDB)901 for storing metadata describing media content assets is communicatively coupled (uni-directionally or bi-directionally) to equipment serving both the first and second geographic regions. For instance, as shown inFIG. 9,UDB901 is coupled to content ingest manager CIM1, real-time ingest manager RTM1, content ingest manager CIM2, real-time ingest manager RTM2, VOD backoffice VB1, and VOD backoffice VB2. Any or all of these blocks are capable of querying and updating the data stored inUDB901.
The media content assets for which metadata is stored inUDB901 may include local media content assets received by a content source that serves or is located in the first or second geographic region, such as Local Content Source1 and Local Content Source2 inFIG. 9. These local media content assets are received into content ingest manager CIM1, real-time ingest manager RTM1, content ingest manager CIM2, or real-time ingest manager RTM2.
When a local media content asset is ingested at one of the geographic locations, the local media content asset (either real-time or non-real-time) may be stored at ahead end190, such as thehead end190 serving that geographic location. In particular, the media content asset may be stored at the streaming server or otherwise at a computer-readable medium to which the streaming server has access. In addition, the metadata for that local media content asset may be passed on toUDB901. BecauseUDB901 shares access to multiple geographic regions, such as the first and second geographic regions ofFIG. 9, the metadata for a media content asset may be available to any of those geographic regions even though the media content asset itself may only be stored at one of those geographic regions.
For example, if a local media content asset is ingested by content ingest block CI1, the local media content asset may be stored at streaming server SS1, and the metadata for that local media content asset may be stored inUDB901, such as via a path from content ingest block CI1 to content ingest manager CIM1 toUDB901. In this example, the local media content asset is a VOD asset. If client device C1 wishes to view the local media content asset, then VOD backoffice VB1 can look up the metadata for that asset inUDB901 and determine fromCLS104 that the asset is stored at streaming server SS1. The asset is then streamed to client device C1 from streaming server SS1. If client device C2 wishes to view the local media content asset, then VOD backoffice VB2 can also look up that same metadata for the asset inUDB901 and determine fromCLS104 that the asset is stored at streaming server SS1. The asset can then be transferred to streaming server SS2, such as via acaching gateway102. Streaming server SS2 then streams the asset to client device C2. Thus locally-stored content may be shared between different geographic regions of the network.
An example of interactions between various equipment when a local media content asset is shared between streaming servers is shown in the diagram ofFIG. 10. Metadata for a local media content asset is received by content ingest block CI1 (for a non-real-time asset) or real-time ingest block RTI1 (for a real-time asset). The metadata is then forwarded by content ingest manager CIM1 or real-time manager RTM1 toUDB901 for storage. The actual local media content asset may be ingested by content ingest CI1 or real-time ingest RTI1, and stored at streaming server SS1 and/or acaching gateway102 local to streaming server SS1.
At some future point in time, the metadata for that local media content asset is replicated, in whole or in part, fromUDB901 to VOD backoffice VB2, either spontaneously or in response to a request for the local media content asset by VOD backoffice VB2, and some or all of the metadata for that asset may be passed on to client device C2, such as in the form of an electronic program guide indicating the local media content asset as an available choice. In response to a session setup request from client device C2, such as by the user selecting the indicated local media content asset from the program guide, VOD backoffice VB2 sends a content locate request to its local caching gateway102 (not necessarily the same caching gateway at which the local media content is stored). In response,caching gateway102 performs a content check withCLS104, which returns the location of the desired local media content asset tocaching gateway102 and then on to VOD backoffice VB2. VOD backoffice VB2 then sends a session setup response to client device C2 and requests that the found local media content asset be replicated to streaming server SS2. The transfer is performed, and streaming server SS2 streams the local content media asset to client device C2.
Alternatively, rather than streaming the replicated media content asset, it may be possible that client device C2 desires a different format of the media content asset. In that case, either during or after session setup, client device C2 may request that the media content asset be in a particular format. If the particular format is not already pre-stored, then similar to theFIG. 8 embodiments, derivedcontent generator109 may derive the requested version of the media content asset such that the derived version is streamed to client device C2.
The process ofFIG. 10 may also be reversed, such as where the local media content asset is initially received, ingested, and stored at the second geographic region and transferred to the first geographic region. And, as in the other embodiments described herein, any of the media content assets shared between video-on-demand systems may be live media content assets or non-live media content assets.
Thus, various systems, apparatuses, methods, and software have been described by way of example for using a network to efficiently distributing media content assets from a virtually unlimited content library and/or other storage to a plurality of client devices. In addition, it has been shown how bi-directional local content sharing between head ends may be accomplished, as well as dynamic distribution and generation of media content assets within the network.