The present disclosure relates generally to synchronized source selection.
Adaptive bitrate (ABR) streaming is a method of video streaming over Hypertext Transfer Protocol (HTTP) where the source content is encoded at multiple bit rates, then each of the different bit rate streams are segmented into small multi-second parts. The streaming client is made aware of the available streams at differing bit rates, and segments of the streams by a manifest file. When starting, the client typically requests the segments from the lowest bit rate stream. If the client finds the download speed is greater than the bit rate of the segment downloaded, then it may request the next higher bit rate segments. Later, if the client finds the download speed for a segment is lower than the bit rate for the segment, and therefore the network throughput has deteriorated, then it may request a lower bit rate segment. The segment size can vary depending on the particular implementation, but they are typically between two and ten seconds.
The accompanying drawings, which are incorporated in and constitute a part of this disclosure, illustrate various embodiments of the present disclosure. In the drawings:
Overview
Synchronized source selection for adaptive bitrate (ABR) encoders may be provided. First, a first adaptive transport stream (ATS) that is aligned with a second ATS produced by a second device may be provided from a first source by a first device. The first device may be fed from the first source. Next, an indication that the second device switched from being fed from the first source to being fed from a second source may be received. In response to receiving the indication, the first device may be switched from being fed from the first source to being fed from the second source. The first ATS that is aligned with the second ATS produced by the second device may then be produced from the second source by the first device.
Both the foregoing overview and the following example embodiments are examples and explanatory only, and should not be considered to restrict the disclosure's scope, as described and claimed. Further, features and/or variations may be provided in addition to those set forth herein. For example, embodiments of the disclosure may be directed to various feature combinations and sub-combinations described in the example embodiments.
The following detailed description refers to the accompanying drawings. Wherever possible, the same reference numbers are used in the drawings and the following description to refer to the same or similar elements. While embodiments of the disclosure may be described, modifications, adaptations, and other implementations are possible. For example, substitutions, additions, or modifications may be made to the elements illustrated in the drawings, and the methods described herein may be modified by substituting, reordering, or adding stages to the disclosed methods. Accordingly, the following detailed description does not limit the disclosure. Instead, the proper scope of the disclosure is defined by the appended claims.
For Adaptive Bitrate (ABR) encoding (or transcoding), audio and video may be encoded by ABR encoders/transcoders as chunks comprising short sequences that may be independently decoded. For high availability, a one-to-one redundancy architecture may be used. In the one-to-one redundancy architecture, a main ABR encoder/transcoder may be backed-up by a second (i.e., redundant) ABR encoder/transcoder. The main ABR encoder/transcoder and the back-up ABR encoder/transcoder may be used in a hot-hot configuration where both ABR encoders/transcoders may output the same service at the same time. The redundant ABR encoder/transcoder may be feeding redundant downstream ABR packagers.
These redundant encoders/transcoders may place their video chunk boundaries on the same video frames and their audio chunk boundaries on the same audio samples (i.e., the ABR profiles of the encoders/transcoders may be “aligned”). This may allow downstream redundant packagers to generate ABR segments that may be interchanged (i.e., segments from one packager may be mixed with segments from another packager by a downstream client). The placement of the aforementioned boundaries may be based upon timestamps present in the input (i.e., the source). In order for redundant ABR encoding/transcoding to work, both main and back-up encoders/transcoders may need to receive a source with aligned input timestamps.
Consistent with embodiments of the disclosure, in order to increase error resiliency of the aforementioned redundant ABR encoder/transcoder system, source redundancy may also be used at the ABR encoder/transcoder input. Source redundancy may comprise using multiple sources (e.g., a main source and a backup source). For example, in case the main source fails, an ABR encoder/transcoder may switch from the main to the backup source.
One issue with source redundancy may comprise the main source and the backup source feeding an end-to-end video delivery chain not containing the same timestamps (e.g., they may originate from two independent upstream encoders). In this situation, if the main ABR encoder/transcoder switches to the backup source while the redundant ABR encoder/transcoder stays on the main source, the redundant ABR encoders/transcoders may no longer generate aligned ABR output profiles because the source timestamps may not match. From this point onwards, an interruption may be visible by viewers of the content. Furthermore, the interruption may not only be visible to live viewers, but may also be visible to viewers who watch the content at a later time. This may be because the same misaligned chunks may have been cached in the edge of a Content Deliver Network (CDN) or have been recorded (e.g., via a cloud Digital Video Recorder (cDVR)).
This issue may impact virtually any service provider supporting Internet Protocol (IP) video. For live viewing, this may be a case where thousands or tens of thousands of subscribers are “tuned” in and watching. Accordingly, outages should be avoided (or minimized), especially at a “head-end”. This may be achieved by a form of redundancy of both encoders/transcoders as well as their input sources. Embodiments of the disclosure may provide synchronized failover of redundant ABR encoders/transcoders to the same (e.g., corresponding) input sources for ABR redundancy.
According to embodiments of the disclosure, source back-up switching may be synchronized between the redundant ABR encoders/transcoders by continuously exchanging the active source for each encoder/transcoder. In case one decides to switch to another source, the redundant ABR encoder/transcoder may be notified and may also switch to the same source to make sure the ABR output profiles stay aligned between the redundant ABR encoders/transcoders.
First encoder 102, first packager 104, first origin server 106, second encoder 108, second packager 110, second origin server 112, and client device 116 may be embodied by computing device 600 described in greater detail below with respect to
ABR video and audio may be packaged in small media files (e.g., chunks) that may have a fixed duration (e.g., 2s). Each ABR chunk may be fully decodable on its own (i.e., it may not need previous chunks for decoding). Audio and video that may be contained in an ABR chunk may be aligned (i.e., a first audio sample in the chunk may correspond to a first video sample in the chunk).
With ABR, a single video/audio source may be encoded in multiple representations that may have different resolutions, framerates, and/or bitrates. Each of these representations may be separated into individually decodable chunks. Moreover, the chunk boundaries may be aligned (i.e., the corresponding chunks of the individual representations may start with the same video frame/audio sample). Aligning the chunk boundaries allows an ABR client to seamlessly switch between the available representations at the chunk boundaries. This allows the ABR client to switch to an appropriate representation based on the network bandwidth it has available at a certain moment of time. When the ABR client has a high network bandwidth available, it may switch to a representation that has a higher video resolution, framerate, and bitrate. When the available bandwidth is lower, the ABR client may switch to a representation with a lower video resolution, framerate, and bitrate.
As shown in
Services may be encoded by first encoder 102 and second encoder 108, packaged (i.e., cut in first data chunks 126 and second data chunks 128) by first packager 104 and second packager 110, and delivered using first origin server 106 and second origin server 112 to client device 116 over CDN 114. Client device 116 may receive first data chunks 126 and second data chunks 128 as client data chunks 130 for further processing (e.g., displaying the content) or recording the content (e.g., on a cDVR).
First encoder 102 and second encoder 108 may encode the video/audio source to the video/audio format that may be needed (e.g., H.264 video and AAC audio) and may generate a set of representations of the ABR service (e.g., different resolutions, framerates, and bitrates). First encoder 102 and second encoder 108 may also determine the chunk size and chunk alignment by inserting Encoder Boundary Points (EBPs) into first a first adaptive transport stream (ATS) 122 and a second ATS 124. These EBPs may be inserted, for example, at regular intervals (e.g., 2s) on the video Packet Identification (PID) (alternatives are possible depending on the ABR format).
As illustrated in
These redundant ABR encoders/transcoders (e.g., first encoder 102 and second encoder 108) may place their video chunk boundaries on the same video frames and their audio chunk boundaries on the same audio samples (i.e., the ABR profiles of the ABR encoders/transcoders may be “aligned”). This chunk boundary alignment may be coordinated between first encoder 102 and second encoder 108 via inter-node communications 134. One process for providing the aforementioned alignment is described in U.S. Pat. No. 9,706,509, which is incorporated herein by reference in its entirety. The placement of the aforementioned boundaries may be based upon timestamps present in the input (i.e., the source). In order for redundant ABR encoding/transcoding to be aligned, both main and back-up ABR encoders/transcoders may need to receive a source with same input timestamps as described below with respect to
Method 200 may begin at starting block 205 and proceed to stage 210 where a first device (e.g., first encoder 102) may produce, from first source 118, first ATS 122 that may be aligned with second ATS 124 produced by a second device (e.g., second encoder 108). The first device (e.g., first encoder 102) and the first device (e.g., second encoder 108) may be fed from first source 118. For example, as shown in
ABR alignment may exist between first ATS 122 and second ATS 124, otherwise first packager 104 and second packager 110 may not select aligned copies from either source (e.g., first ATS 122 and second ATS 124). If first package 104 and second packager 110 select non-aligned copies, non-aligned segments in first data chunks 126 and second data chunks 128 may exist, effectively disturbing the viewer's experience as described above. While ABR alignment may exist between first ATS 122 and second ATS 124 using the alignment process described in U.S. Pat. No. 9,706,509, other alignment process may be used and embodiments of the disclosure are not limited to the process described in U.S. Pat. No. 9,706,509.
From stage 210, where first device (e.g., first encoder 102) produced, from first source 118, first ATS 122 that may be aligned with second ATS 124 produced by second device (e.g., second encoder 108), method 200 may advance to stage 220 where the first device (e.g., first encoder 102) may receive an indication that the second device (e.g., second encoder 108) switched from being fed from first source 118 to being fed from second source 120. For example, second encoder switch 306 may have been in a position that may have caused second encoder module 308 of second encoder 108 to produce second ATS 124 from first source 118. However, as shown in
The active source (e.g., first source 118 or second source 120) of each ABR encoder/transcoder (i.e., first encoder 102 and second encoder 108) may be exchanged over inter-node communications 134. By doing this with some frequency, first encoder 102 and second encoder 108 may know if they are using the same source or not. In this way, in case one of first encoder 102 and second encoder 108 switches to another source, the other encoder may be notified and can also switch to the same source to keep the ABR output profiles (e.g., first ATS 122 and second ATS 124) aligned.
Once the first device (e.g., first encoder 102) receives the indication that the second device (e.g., second encoder 108) switched from being fed from first source 118 to being fed from second source 120 in stage 220, method 200 may continue to stage 230 where the first device (e.g., first encoder 102) may switch, in response to receiving the indication, from being fed from first source 118 to being fed from second source 120. For example, from data (e.g., an indication) received over inter-node communications 134 from second encoder 108, first encoder module 304 may cause first encoder switch 302 to switch to a position that may cause first encoder module 304 of first encoder 102 to produce first ATS 122 from second source 120 as shown in
After the first device (e.g., first encoder 102) switches, in response to receiving the indication, from being fed from first source 118 to being fed from second source 120 in stage 230, method 200 may proceed to stage 240 where the first device (e.g., first encoder 102) may produce, from second source 120, first ATS 122 that is aligned with second ATS 124 produced by the second device (e.g., second encoder 108). For example, in case one of first encoder 102 and second encoder 108 switches to another source, the other encoder may be notified and can also switch to the same source to keep the ABR output profiles (e.g., first ATS 122 and second ATS 124) aligned. In other words, in order for first ATS 122 and second ATS 124 to be aligned, both encoders (e.g., first encoder 102 and second encoder 108) may need to receive input from the same source (i.e., with the same input timestamps). Once the first device (e.g., first encoder 102) produces, from second source 120, first ATS 122 that is aligned with second ATS 124 produced by the second device (e.g., second encoder 108) in stage 240, method 200 may then end at stage 250.
Method 400 may begin at starting block 405 and proceed to stage 410 where the first device (e.g., first encoder 102) may produce, from first source 118, first ATS 122 that is aligned with second ATS 124 produced by the second device (e.g., second encoder 108). The first device (e.g., first encoder 102) and the second device (e.g., second encoder 108) may be fed from first source 118. For example, as shown in
From stage 410, where the first device (e.g., first encoder 102) produces, from first source 118, first ATS 122 that is aligned with second ATS 124 produced by the second device (e.g., second encoder 108), method 400 may advance to stage 420 where the first device (e.g., first encoder 102) may switch the first device (e.g., first encoder 102) from being fed from first source 118 to being fed from second source 120. For example, as shown in
Once the first device (e.g., first encoder 102) switches the first device (e.g., first encoder 102) from being fed from first source 118 to being fed from second source 120 in stage 420, method 400 may continue to stage 430 where the first device (e.g., first encoder 102) may receive an indication that the second device (e.g., second encoder 108) cannot be switched from being fed from first source 118 to being fed from second source 120. For example, second encoder module 308 may sense a second fault 504 and know that it cannot switch to second source 120 because second source 120 is not available. The available sources (e.g., first source 118 or second source 120) of each ABR encoder/transcoder (i.e., first encoder 102 and second encoder 108) may be exchanged over inter-node communications 134. By doing this with some frequency, first encoder 102 and second encoder 108 may know which sources are available or not available to the other encoder.
After the first device (e.g., first encoder 102) receives the indication that the second device (e.g., second encoder 108) cannot be switched from being fed from first source 118 to being fed from second source 120 in stage 430, method 400 may proceed to stage 440 where the first device (e.g., first encoder 102) may determine that second source 120 is lower in priority than first source 118. For example, first encoder 102 and second encoder 108 may receive a list indicating a priority relationship between the sources (e.g., first source 118 and second source 120). From this list, first encoder 102 may determine that second source 120 is lower in priority than first source 118.
From stage 440, where the first device (e.g., first encoder 102) determines that second source 120 is lower in priority than first source 118, method 400 may advance to stage 450 where the first device (e.g., first encoder 102) may mute first ATS 122 in response to receiving the indication and in response to determining that second source 120 is lower in priority than first source 118. For example, first encoder 102 and second encoder 108 cannot both use the same source at the same time (e.g., in the case of multiple source losses as shown in
In the case of double failure as shown in
Computing device 600 may be implemented using a Wi-Fi access point, a cellular base station, a tablet device, a mobile device, a smart phone, a telephone, a remote control device, a set-top box, a digital video recorder, a cable modem, a personal computer, a network computer, a mainframe, a router, a switch, an encoder, a transcoder, a camera, a load balancer or other similar microcomputer-based device. Computing device 600 may comprise any computer operating environment, such as hand-held devices, multiprocessor systems, microprocessor-based or programmable sender electronic devices, minicomputers, mainframe computers, and the like. Computing device 600 may also be practiced in distributed computing environments where tasks are performed by remote processing devices. The aforementioned systems and devices are examples and computing device 600 may comprise other systems or devices.
Embodiments of the disclosure, for example, may be implemented as a computer process (method), a computing system, or as an article of manufacture, such as a computer program product or computer readable media. The computer program product may be a computer storage media readable by a computer system and encoding a computer program of instructions for executing a computer process. The computer program product may also be a propagated signal on a carrier readable by a computing system and encoding a computer program of instructions for executing a computer process. Accordingly, the present disclosure may be embodied in hardware and/or in software (including firmware, resident software, micro-code, etc.). In other words, embodiments of the present disclosure may take the form of a computer program product on a computer-usable or computer-readable storage medium having computer-usable or computer-readable program code embodied in the medium for use by or in connection with an instruction execution system. A computer-usable or computer-readable medium may be any medium that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
The computer-usable or computer-readable medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium. More specific computer-readable medium examples (a non-exhaustive list), the computer-readable medium may include the following: an electrical connection having one or more wires, a portable computer diskette, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, and a portable compact disc read-only memory (CD-ROM). Note that the computer-usable or computer-readable medium could even be paper or another suitable medium upon which the program is printed, as the program can be electronically captured, via, for instance, optical scanning of the paper or other medium, then compiled, interpreted, or otherwise processed in a suitable manner, if necessary, and then stored in a computer memory.
While certain embodiments of the disclosure have been described, other embodiments may exist. Furthermore, although embodiments of the present disclosure have been described as being associated with data stored in memory and other storage mediums, data can also be stored on or read from other types of computer-readable media, such as secondary storage devices, like hard disks, floppy disks, or a CD-ROM, a carrier wave from the Internet, or other forms of RAM or ROM. Moreover, the semantic data consistent with embodiments of the disclosure may be analyzed without being stored. In this case, in-line data mining techniques may be used as data traffic passes through, for example, a caching server or network router. Further, the disclosed methods' stages may be modified in any manner, including by reordering stages and/or inserting or deleting stages, without departing from the disclosure.
Furthermore, embodiments of the disclosure may be practiced in an electrical circuit comprising discrete electronic elements, packaged or integrated electronic chips containing logic gates, a circuit utilizing a microprocessor, or on a single chip containing electronic elements or microprocessors. Embodiments of the disclosure may also be practiced using other technologies capable of performing logical operations such as, for example, AND, OR, and NOT, including, but not limited to, mechanical, optical, fluidic, and quantum technologies. In addition, embodiments of the disclosure may be practiced within a general purpose computer or in any other circuits or systems.
Embodiments of the disclosure may be practiced via a system-on-a-chip (SOC) where each or many of the components illustrated in
Embodiments of the present disclosure, for example, are described above with reference to block diagrams and/or operational illustrations of methods, systems, and computer program products according to embodiments of the disclosure. The functions/acts noted in the blocks may occur out of the order as shown in any flowchart. For example, two blocks shown in succession may in fact be executed substantially concurrently or the blocks may sometimes be executed in the reverse order, depending upon the functionality/acts involved.
While the specification includes examples, the disclosure's scope is indicated by the following claims. Furthermore, while the specification has been described in language specific to structural features and/or methodological acts, the claims are not limited to the features or acts described above. Rather, the specific features and acts described above are disclosed as example for embodiments of the disclosure.
Number | Name | Date | Kind |
---|---|---|---|
7139999 | Bowman-Amuah | Nov 2006 | B2 |
8639971 | White | Jan 2014 | B1 |
9100700 | Major | Aug 2015 | B2 |
9432704 | Mutton | Aug 2016 | B2 |
9467708 | Soroushian | Oct 2016 | B2 |
9706509 | Beheydt et al. | Jul 2017 | B2 |
20040172478 | Jacobs | Sep 2004 | A1 |
20050246612 | Leis | Nov 2005 | A1 |
20070033154 | Trainum | Feb 2007 | A1 |
20070050336 | Bugir | Mar 2007 | A1 |
20070180528 | Kane | Aug 2007 | A1 |
20080086773 | Tuvell | Apr 2008 | A1 |
20080155390 | Karim | Jun 2008 | A1 |
20080273504 | Foley | Nov 2008 | A1 |
20090119499 | Cao | May 2009 | A1 |
20100146040 | Ramakrishnan et al. | Jun 2010 | A1 |
20100191539 | Loughery, III | Jul 2010 | A1 |
20100218033 | Safar et al. | Aug 2010 | A1 |
20110009991 | Dinicola | Jan 2011 | A1 |
20110050990 | Farkash | Mar 2011 | A1 |
20110083037 | Bocharov | Apr 2011 | A1 |
20110225417 | Maharajh | Sep 2011 | A1 |
20110235703 | Labrozzi et al. | Sep 2011 | A1 |
20110252233 | De Atley | Oct 2011 | A1 |
20110314130 | Strasman | Dec 2011 | A1 |
20120011270 | Priddle et al. | Jan 2012 | A1 |
20120023251 | Pyle et al. | Jan 2012 | A1 |
20120117225 | Kordasiewicz et al. | Feb 2012 | A1 |
20120128061 | Labrozzi et al. | May 2012 | A1 |
20120159098 | Cheung | Jun 2012 | A1 |
20120265856 | Major et al. | Oct 2012 | A1 |
20130227573 | Morsi et al. | Aug 2013 | A1 |
20130232289 | Zhong | Sep 2013 | A1 |
20130315567 | Narayanan et al. | Nov 2013 | A1 |
20140006854 | Bello | Jan 2014 | A1 |
20140006951 | Hunter | Jan 2014 | A1 |
20140013349 | Millar et al. | Jan 2014 | A1 |
20140019587 | Giladi | Jan 2014 | A1 |
20140025710 | Sarto | Jan 2014 | A1 |
20140059243 | Reisner | Feb 2014 | A1 |
20140079207 | Zhakov | Mar 2014 | A1 |
20140140417 | Shaffer et al. | May 2014 | A1 |
20150040169 | Hoffert | Feb 2015 | A1 |
20150256617 | Klose | Oct 2015 | A1 |
20160316235 | Van Veldhuisen | Oct 2016 | A1 |
Entry |
---|
Notice of Allowance dated May 10, 2019 cited in U.S. Appl. No. 14/213,156, 14 pgs. |
Dr. Gorry Fairhurst, “MPEG-2 Transmission,” Jan 2001, 7 pages; http://www.erg.abdn.ac.uk/future-net/digital-video/mpeg2-trans.html (9 pgs). |
Wikipedia, the free encyclopedia, “MPEG transport stream,” Wikipedia, Feb. 26, 2013, 7 pages; http://en.wikipedia.org/wiki/MPEG_transport_stream. |
Cable Television Laboratories, Inc., OpenCable tm Specifications, OC-SP-EBP=I01-130118, Jan. 18, 2013 (31 pgs). |
Wikipedia, the free encyclopedia, Presentation time stamp, Wikipedia, May 27, 2012, 1 page; http://en.wikipedia.org/wiki/Presentation_time-stamp (1 pg.). |
Chinese Second Office Action issued in Application No. 201580013828.3 dated Feb. 24, 2019, 8 pp. |
Number | Date | Country | |
---|---|---|---|
20190166178 A1 | May 2019 | US |