CN102714662A - 用于http媒体流分发的方法和装置 - Google Patents
用于http媒体流分发的方法和装置 Download PDFInfo
- Publication number
- CN102714662A CN102714662A CN2011800063876A CN201180006387A CN102714662A CN 102714662 A CN102714662 A CN 102714662A CN 2011800063876 A CN2011800063876 A CN 2011800063876A CN 201180006387 A CN201180006387 A CN 201180006387A CN 102714662 A CN102714662 A CN 102714662A
- Authority
- CN
- China
- Prior art keywords
- expression
- medium
- unit
- client
- media
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/40—Support for services or applications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/02—Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/61—Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
- H04L65/612—Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio for unicast
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/61—Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
- H04L65/613—Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio for the control of the source by the destination
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/65—Network streaming protocols, e.g. real-time transport protocol [RTP] or real-time control protocol [RTCP]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/75—Media network packet handling
- H04L65/752—Media network packet handling adapting media to network capabilities
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/75—Media network packet handling
- H04L65/756—Media network packet handling adapting media to device capabilities
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/75—Media network packet handling
- H04L65/762—Media network packet handling at the source
Abstract
本发明提供了由通信网络的服务器执行的方法,用于使HTTP媒体流能够由客户端访问,其中,产生媒体呈现描述(MPD),以使得向MPD提供根据媒体播放时间轴顺序布置的至少一个周期单元,使得向每个周期单元提供至少一个表示,以及使得向该至少一个周期单元中的至少一个周期单元提供至少两个备选表示,其中,向每个表示提供至少一个媒体段URI的有序序列,每个媒体段URI引用HTTP媒体流的至少一个媒体段。所产生的MPD使得客户端能够选择表示,并基于所选择的表示来获取所引用的媒体段。
Description
技术领域
本发明涉及使HTTP媒体流能够由客户端访问的方法、获取HTTP媒体流的方法以及用于执行相应方法的服务器和客户端。
背景技术
HTTP流传输是对实体间(例如,从服务器或中间网络节点至客户端)的实况或点播内容的基于文件的流传输方法。要求上载内容的具有HTTP流传输能力的客户端首先通过从服务器或任何其他的网络节点取得来获取小文件或文件段的列表,这些小文件或文件段一起构成所需内容的流,或者具体地,所需内容的描述。通常将这种列表称为媒体呈现描述(MPD)。在本上下文中,我们也将术语MPD同义地用于播放列表和清单。可以通过M3U8格式来描述播放列表,或者将播放列表描述为以XML格式提供的列表。
在每个时间点处,可存在多个小的文件,或者文件段,此后,将其称为媒体段,可以由客户端在媒体段之间进行选择。HTTP流传输可以基于模板或者基于播放列表。在基于模板的HTTP流传输中,使用模板在MPD中描述所请求的URL,该URL可以是例如以下的类型:
www.server.com/streamfile/$Rep$/$Index$/
其中,由所请求的表示来替换$Rep$,以及由序列号来替代$Index$,序列号被用于确定请求媒体段的时间。
在基于列表的HTTP流传输中,每个媒体段和每个时间具有其自己的URL,例如:
视频时间0
->与视频时间0相关联的URL
视频时间1
->与视频时间1相关联的URL
视频时间2
->与视频时间2相关联的URL
然而,已知的MPD结构非常严格,从而允许极少量的灵活性,当涉及可以从不同的内容源访问的内容和/或随时间改变可具有不同特性的内容时,尤其如此。
发明内容
本文的目的是解决上述问题中的至少一些。更具体地,目的是提供新的MPD结构、提供这种MPD的方法、获取和处理MPD以使得可以通过更灵活的方式来执行HTTP媒体流的下载的方法,包括提供请求媒体流下载的客户端的备选方案。
根据第一方面,提供了由通信网络的服务器执行的方法,用于使HTTP媒体流能够由客户端访问。当应用该方法时,产生MPD,以使得向MPD提供根据媒体播放时间轴(timeline)顺序布置的至少一个周期单元,使得向每个周期单元提供至少一个表示,以及使得向该至少一个周期单元中的至少一个周期单元提供至少两个备选表示,其中,向每个表示提供至少一个媒体段URI的有序序列,每个媒体段URI引用HTTP媒体流的至少一个媒体段。
然后,提供MPD,以使得客户端可以获取MPD,基于MPD的内容,针对至少一个周期单元来选择表示,以及针对每个所选择的表示,获取相应的所引用的媒体段。
所建议的MPD布置简化了对备选媒体段的引用,以及特别地,对源自于不同源的媒体段的引用。
产生步骤可以包括以下步骤:对至少一个媒体段URI的有序序列中的至少一个进行布置,以使得将其作为至少一个表示来提供并以模板格式来描述。
备选地,或者与以模板格式来提供一个或多个表示相结合,产生步骤可以包括以下步骤:布置至少一个表示,以使得将其作为至少两个媒体段URI的有序序列来提供,并以播放列表格式来描述。
此外,可以向与相同周期单元相关联的各个表示提供第一属性,可以将第一属性备选地称为第一表示属性,第一表示属性具有代表在表示中引用的媒体段的设置,使得客户端将能够基于相应的设置来选择相应周期单元的表示。
还可以向周期单元提供第二属性或表示属性,其中,选择第二表示属性的设置,以使得其对与相应周期单元相关联的所有媒体段而言是公共的,以及使得其代表与该周期单元相关联的所有表示。
如果需要更加分层的结构,可以在相应周期单元的每个表示中提供相应的第二表示属性,以使得在表示等级上描述第二表示属性,或者在相应的周期单元中提供相应的第二表示属性,以使得在周期单元等级上描述第二表示属性。
备选地,可以甚至进一步地发展分层结构,使得在产生步骤期间,向MPD的至少一个周期单元提供至少两个备选的周期构造,其中,向每个周期构造提供至少两个表示以及第二表示属性,以及选择第二表示属性的设置,以使得该设置代表相应的周期构造,使得客户端将能够基于一个或多个所述表示属性来选择周期单元的表示。
在MPD中应用的表示属性可以例如定义编解码器、比特率、分辨率或语言,由此使得服务提供商能够提供一个或多个可选择的备选,该一个或多个可选择的备选可以依赖于用户设备能力、用户偏好或环境情况中的任一个或其组合。
除了提供更灵活的MPD之外,还可以通过向MPD增加至少一个表示,通过从MPD移除至少一个表示,或者通过修改MPD的至少一个表示来更新这种MPD。
根据MPD的更新基于轮询的一个实施例,可以向MPD提供对轮询间隔的指示,以使得已获取MPD的客户端将能够以通过该指示确定的间隔来轮询MPD更新,而根据另一备选,可代之向客户端推送已更新的MPD。
为了使客户端可以确定最新的可用媒体段,还可以向MPD提供对HTTP传输流的媒体播放时间轴与基准(例如,服务器时间轴或挂钟时间)的映射的描述。
优选地,布置相同周期单元的不同表示的媒体段,以使得媒体段在周期单元的开始处在时间上对齐。
根据另一方面,提供了由通信网络中的客户端执行的方法,用于从通信网络的至少一个网络节点获得HTTP媒体流。根据该方法,客户端从一个网络节点获取MPD,该MPD包括根据媒体播放时间轴顺序布置的至少一个周期单元,其中,每个周期单元包括至少一个表示,以及该至少一个周期单元中的至少一个周期单元包括至少两个备选表示,每个表示包括至少一个媒体段URI的有序序列,每个媒体段URI引用HTTP媒体流的至少一个媒体段。一旦拥有MPD,客户端就可以基于MPD的内容,针对至少一个周期单元来选择表示,以及针对每个所选择的表示,获取所引用的媒体段。
可以基于相应周期单元的一个或多个表示属性来选择相应表示,其中,每个表示具有代表相应表示或周期单元的相应设置。
为了能够使对表示的选择基于环境改变,可以估计可用于从所述至少一个网络节点向客户端发送HTTP媒体流的比特率,以及客户端可以通过考虑至少一个比特率相关的表示属性,基于这种估计来选择至少一个周期单元的表示。
根据又一方面,提供了能够使得HTTP媒体流能够由客户端访问的服务器,该服务器包括产生单元和提供单元,产生单元被配置为产生如上配置的MPD,提供单元被配置为使得客户端可访问媒体呈现描述,由此使得客户端可以获取MPD,基于MPD的内容,针对至少一个周期单元来选择表示,以及针对每个所选择的表示,获取相应的所引用的媒体段。
产生单元可被配置为向MPD提供以模板格式、播放列表格式或其组合来描述的至少一个表示。
此外,产生单元可以被配置为针对每个媒体段URI,向MPD提供对相应的所引用的一个或多个媒体段的持续时间的指示。
产生单元还可以被配置为:向与相同周期单元相关联的各个表示提供表示属性和相应的表示属性设置,以使得该表示可由客户端基于表示属性进行选择。
产生单元可以被配置为:提供至少两种不同类别的表示属性,以及通过分层的方式提供表示属性,以使得在以周期等级提供相应的表示属性的情况下,表示属性对相应周期单元的所有表示有效,而在以表示等级提供时,表示属性仅对相应周期单元的相应表示有效。
产生单元可以被配置为:通过向媒体呈现描述增加至少一个表示,通过从媒体呈现描述移除至少一个表示,或者通过修改媒体呈现描述的至少一个表示来更新MPD。
根据另一方面,提供了通信网络中能够从通信网络的至少一个网络节点获取HTTP媒体流的客户端。客户端包括请求单元和选择单元,请求单元被配置为从所述至少一个网络节点中的一个获取如上指示地布置的MPD,选择单元被配置为基于MPD内容来选择每个相应的表示。
选择单元通常被配置为基于表示的至少一个表示属性来选择相应的表示。
还可以向客户端提供估计单元,估计单元被配置为估计可用于从至少一个网络节点向客户端发送HTTP媒体流的比特率,以使得选择单元将能够通过考虑至少一个比特率相关的表示属性,基于该估计来选择至少一个周期单元的表示。
附图说明
当与附图一起阅读时,根据对本发明的示例性实施例的详细描述,将更加容易理解本发明的目的、好处和效果以及特征,附图中:
图1是示出了适于HTTP媒体流分发的通信网络的简化概述图。
图2是示出了在网络节点处产生和提供MPD的方法的流程图。
图3是更详细地示出了图2的产生过程的另一流程图。
图4是示出了从网络节点获取MPD的方法的又一流程图。
图5是根据一个实施例布置的MPD的示意。
图6是根据另一个实施例布置的MPD的示意。
图7是根据又一个实施例布置的MPD的示意。
图8a和8b是分别示出了第一MPD和第一MPD的更新版本的图。
图9是根据一个实施例、被配置为提供MPD的服务器的简化框图方案。
图10是根据一个实施例、被配置为获取和处理MPD的客户端的简化框图方案。
图11是根据另一实施例的服务器配置的简化示意。
图12是根据另一实施例的客户端配置的简化示意。
具体实施方式
虽然本文档覆盖了下面参考所公开的图描述的方法和装置的各种备选实施例,要理解,特定的描述和图不是旨在将本发明的范围限制在所公开的特定形式。相反,要将所要求权利的发明的范围视为包括其落在所附权利要求中表达的本发明的精神和范围内的所有修改和备选构造。
本文档涉及适于与HTTP流传输相关联地使用的新的更灵活的MPD结构。图1是适于实现服务器和客户端之间的自适应HTTP流传输(包括MPD的分发)的简化系统架构的示意。图1包括两个客户端100a、100b,可以将其称为HTTP流传输客户端,其各自可以向用户发起相应的流传输服务,以通过下载对媒体呈现进行描述的相关元数据以及相关联的媒体段形式的媒体呈现来获得结构化的数据集合(通常称之为媒体呈现)。可以直接从服务器101(可以称为HTTP流传输服务器),或者可以从中间网络节点(在此由高速缓存102a和高速缓存102b来标识,两者可以都保留媒体段及其相关元数据的拷贝)执行元数据和相关联的媒体呈现的下载。在所描述的实施例中,将各个高速缓存102a、102b附接至相应的HTTP代理103a、103b。
通常将上述元数据称为MPD、清单或列表。在当前上下文中,这种列表通常被称为播放列表,通常但不是必须作为XML结构化文档来提供。
下面将描述可应用于HTTP流传输的更加灵活的MPD构造的原理。通过应用所建议的MPD,客户端将能够以简单和更灵活的方式来请求上载媒体内容,当所请求的媒体呈现具有随时间改变的特性时尤其如此。更具体地,建议了灵活的MPD结构,该MPD结构可以携带描述备选选项(在此称为备选表示)的元数据。可以将备选表示作为模板和/或播放列表风格结构来提供,这将需要对原始的方案进行最小程度的改变。
所提出的新的MPD结构特别适用于自适应HTTP流传输场景,其中,将连续的媒体流细分为媒体段,以通过HTTP高速缓存分层结构(如上述的高速缓存分层结构)运送。
在网络的服务器侧,服务器从媒体源104提供的连续的字节流创建连续的段或文件流,其中,可以向服务器101连续上载新的媒体段。除了向进行请求的客户端提供灵活的MPD之外,服务器101还可以通过从MPD修改或移除URI或者通过向MPD增加URI,利用新媒体段的新URI来更新MPD。根据本发明,这种MPD更新过程甚至可以在正在进行的媒体呈现的上载过程期间执行。
所建议的MPD结构是由周期定义构成的构造,其中,以一个或多个周期的序列来描述媒体呈现,其中,向每个周期提供周期描述,或者时间范围,或者媒体播放时间的间隔。这种形成MPD的一部分的描述也可以被称为周期单元。还可以将MPD描述为由表示定义构成的构造,其中,提供各个表示,使得其描述一个或多个媒体段的有序列表,媒体段包含媒体数据和/或用于解码和呈现相关联的媒体内容的元数据。与相同周期单元相关联的不同表示表示媒体内容的不同备选,其中,各个表示可通过至少一个表示属性区分。
连续周期单元的相关表示可通过特定的表示属性标识,已被设置为公共设置的表示属性将一起构成特定的轨道或通道。通过向周期单元提供两个或更多的备选表示(其各自可由一个或多个表示属性来标识),针对每个周期单元,已经获取MPD的客户端基于一个或多个表示属性的相应设置,将能够选择备选表示中的一个,以使得针对每个周期单元,可以通过从相应的源取得来获取最适合的媒体段。更具体地,客户端可以在任何时间选择从一个通道或轨道切换到另一通道或轨道,然后保持在所选择的轨道上,直到情况改变(例如,环境改变或者用户偏好使得另一备选轨道更有利或更优选)。
通过MPD中包括的媒体段URI来唯一地引用客户端可访问的每个媒体段,其中,每个媒体段URI可以是已通过模板隐式创建的,或者被显式地创建为列表(例如,播放列表)。
图2是示出了提供MPD的服务器可执行的方法的简化流程图。在第一步骤200中,遵循以上讨论的原理,通过应用模板方案、播放列表方案或其组合来产生MPD,以使得针对要在MPD中描述的媒体呈现的每个周期提供所需的备选,以及在后续步骤210中,通常通过将MPD存储在布置在服务器上或可操作地连接到服务器的存储装置中,或者通过向客户端可以从其请求MPD的中间节点(例如高速缓存)发送MPD,服务器提供所产生的MPD,以使得客户端可以进行访问。如图2中指示的,可以将后一步骤称为提供MPD的步骤。
经由服务器分发媒体内容的内容提供商可能要求与所分发的媒体内容相关联的MPD是可更新的,在实况会话期间尤其如此。由此,附加的表示可以变得可用,或者可以移除或修改已经可用的表示。内容提供商可以例如决定在实况会话期间提供更高质量的表示,或者提高经由MPD将广告插入所呈现的媒体流中的灵活性。
如另一步骤220中所指示的,因此,可以在步骤200中产生第一MPD之后,在任何时间通过增加、删除或修改周期单元的方式来更新MPD。在步骤220中确定需要任何的MPD更新的情况下,在后续步骤230中相应地产生已更新的MPD,以及由服务器在步骤210中提供已更新的MPD,以使得其可由客户端访问。在后一情况下,步骤210可以例如包括向一个或多个客户端推送已更新的MPD。然而,仅可以增加、删除或修改MPD中描述的媒体播放时间的开始处或MPD的结束处的周期。
现在,将参考图3,根据一个实施例来进一步详细描述图2的产生步骤200和230。如第一步骤300所指示的,以媒体呈现的第一周期单元开始,如后续步骤310中指示的,针对第一周期单元提供第一表示,或者更具体地,提供描述第一表示的指令。后一步骤包括:向表示提供表示属性,并进行重复,直到针对该表示,相应地已经设置了所有所需的表示属性,所述表示属性具有代表所述表示的设置。后一步骤还包括向每个表示提供相关媒体段URI。如上所示,在产生MPD时应用哪个备选表示,或者可选地,还应用哪个备选周期构造可以取决于各种情况。可以设置表示属性,以使得其定义例如备选语言、比特率、编解码器、分辨率或者应该可由客户端选择的任何其他准则。
在接下来的步骤320中,确定针对相关周期单元,是否要将另一表示提供到MPD中,或者所提供的表示是否是周期单元的最后的表示。在前者的情况下,如步骤310后的步骤330所指示的,通过向周期单元提供另一表示来继续该过程,在后者的情况下,在后一步骤340中,确定正在构造的周期单元是否要包括另一周期构造(即,要被提供到MPD中作为进一步的可选择备选的、除了在步骤330和310中产生的集合之外的一个或多个表示的另一集合)。如果另一周期构造对于正在构造的周期单元相关,在步骤350中发起新的周期构造,并在步骤330和310中选择和产生相关表示和表示属性。
在MPD更新的情况下,步骤310还可以包括提供与这种MPD更新相关联的指令。通常,在周期级提供这种信息。此外,还可以在步骤310中将对MPD所描述的HTTP传输流的媒体播放时间轴与服务器时间轴或挂钟(wall clock)时间或任何其他基准时间中的任何时间的映射的描述提供到MPD中。当在步骤310中提供表示时,通常提供相应表示的媒体段,以使得在相应周期单元的开始处,它们在时间上对齐。
在不同周期构造的情况下,设置至少一个表示属性,以使得其将两个周期构造彼此区分开,同时设置至少一个其他的表示属性,以使得其将周期构造的表示与至少一个其他表示区分开。如果应用不同的分层等级,在所需分层等级处提供各个表示属性。
一旦周期单元准备好,在后续步骤360中确定是否还有要针对其来定义一个或多个表示的任何更多的周期单元。如果有,在步骤370中提供下一个周期单元,继续以上已经描述的步骤,直到已经将下一个周期单元的所有周期单元包括在MPD中。当已经定义并相应地布置了MPD的所有周期单元时,如最终步骤380所指示的,产生过程终止。
通常,在步骤300和370中分别将相应周期单元的所有表示的任何公共的表示属性包括在MPD中。通过对应方式,在步骤350中,将相应周期单元的周期构造的任何公共的表示属性包括在MPD中。
一旦已经相应地构建了MPD并使其对客户端而言可以访问,任何的这些客户端将能够访问MPD,并基于MPD的内容(即,向MPD中提供的指令),客户端将能够选择轨道,以使得可以获取相关媒体段。然而,从客户端的角度,一旦已经相应地处理了MPD,就可以根据多种已知的现有技术解决方案来执行基于MPD的内容访问媒体段的过程,这不属于本文档的范围。
图4是另一流程图,示出了可在客户端执行的用于使客户端能够获取媒体内容形式的所需媒体呈现的方法,该媒体呈现可作为MPD中呈现的备选选项加以选择。在图4的第一步骤400中,从网络节点(例如,服务器,或者中间高速缓存)获取与所请求的媒体呈现相关联的MPD,以及在后续步骤410中,存储MPD,通常存储在客户端处的常规存储装置中,或者可操作地连接到客户端的单元处。应理解的是,如何找到与所需媒体呈现相关联的MPD是本领域技术人员公知的,并因此不属于本文档的范围。
在客户端处,以包含在相应的周期单元中的周期描述的形式提供的MPD的内容是可逐周期地标识的,如另一步骤420中所指示的,从与媒体呈现的所请求的部分相关联的第一周期单元处开始。
在下载点播媒体呈现的情况下,第一周期单元将是相应MPD的初始周期单元,而在下载实况会话的情况下,第一周期单元将是MPD的第一可标识周期单元,即,可以从其执行下载的第一周期单元。
在后续的步骤430中,询问代表相关周期单元的MPD的内容(包括针对每个表示的指令,以及对于所有表示或者在周期构造中表示的表示组相关的指令),以使得可以至少部分地基于这些指令,为相应的周期单元选择表示。这种表示的选择以及不同表示之间的切换可以基于以上已经提到的一个或多个准则。此外,MPD还可以包括与表示无关的附加指令,例如,如何获得已更新的MPD的指令。
为了不浪费无线资源,客户端应该仅从相应的周期取得一个表示,以及同时,可以相对频繁地从周期单元到周期单元地切换编码选择(例如,比特率),例如,基于改变的环境情况,不应基于链路比特率估计或者任何其他的基于质量的估计来对其他选项(例如,特定语言所表示的音轨)进行下载改变,这是因为:由于以不同的媒体比特率来编码的不同语言之间的重复切换,改变语言将导致非常差的体验质量。
通常,可以类似地描述对于能力相关的表示属性(例如,不同的显示分辨率)适用的客户端行为,以使得在不同的分辨率(例如,QVGA和VGA)下,向客户端分发的媒体内容是可用的。通常,在交付(render)所获取的媒体内容之前,客户端基于终端偏好和/或用户偏好来选择最适合的分辨率,并在整个下载期间维持所选择的分辨率。备选地,客户端具有在下载期间改变分辨率的选项,例如,由于经历了过糟的连接。如果例如在整个播放时间期间,所选择的音轨不可用,客户端可被配置为代之以选择例如缺省的语言,或者第一可用语言。
对表示和/或周期构造的选择也可以基于测量或估计,例如,所估计的可用比特率,这通常是由客户端连续执行的。在执行对比特率的估计的情况下,通常可以基于这种估计来选择不同质量的表示。
一旦已经选择了表示,就可以根据MDP的相应指令从其源取得相关媒体段,如步骤440所指示的那样。在下一步骤450中,确定对于获取所需媒体表示而言,任何其他的周期单元是否是相关的,以及如果是相关的,在步骤430中,考虑和选择下一周期单元的表示,之后,根据步骤440,通过获取与所选择的表示相关联的媒体段来继续该过程。
如果针对特定的周期单元已经定义了多于一个的周期构造,在步骤430中也将考虑这种备选的周期构造的表示,以使得选择相应周期单元的周期构造之一的一个表示。当不再有对于下载相关的周期单元时(即,已经下载了客户端所需的完整的媒体表示),如步骤470中指示的,所描述的过程终止。
现在,下面将参考图5描述以上建议的MPD结构或构造的一些基本原理。如图5中所指示的,将通过MPD描述的单个媒体播放时间轴500细分为一个或多个播放时间周期,以使得可以通过MPD所描述的每个周期的时间轴(或周期单元)的级联来定义播放时间轴500。MPD包括一个或多个周期单元的序列,在此示出为两个周期单元501、502,其中,每个周期单元包括相同媒体内容的一个或多个备选描述,在此称为所描述的媒体表示或媒体流的媒体内容的表示或者表示单元。备选地,MPD可以针对每个媒体分量包括一个媒体时间轴,以使得可以应用针对例如音频和视频的具有同步点的单独的时间轴。
在图5中,第一周期单元501包括三个不同的表示503a、503b、503c,其在此分别代表不同的表示属性,并可由不同的表示属性来区分,在此代表比特率属性,即,代表100kbps的比特率的低质量(LQ)属性、代表200kbps的中等质量(MQ)属性以及代表400kbps的高质量(HQ)属性,而第二周期单元502仅包括两个备选表示504a、504b,提供150kbps的LQ选项和500kbps的HQ选项。针对相同周期来描述的多个表示的媒体段通常在周期单元的开始处在时间上对齐。从而,对图5的MPD进行构造,以使得所有的指令都被布置在相应的表示或表示单元中,即,通过考虑表示的内容,对该表示有效的所有指令对客户端都将是可用的。
除了一个或多个表示属性,周期单元的每个表示描述相同的内容,其中,如果向客户端提供可选择的选项,从一个表示到另一个表示,这些属性中的一个或多个可以不同。
一般而言,相同的内容可具有不同的表示,可以经由一个或多个表示属性来标识不同表示,针对客户端,每个表示属性可以定义备选的选择。如果针对相应的周期单元,当涉及相应的表示属性时,代之以没有针对该客户端的可用选项,针对该周期单元的所有表示,可以向该属性提供相同的设置。如图5中指示的,已经将视频和音频属性(在此,分别由设置为H.264基线简档等级1.3和AAC音频的相应表示属性来定义)定义为对两个所示出的周期单元的所有表示有效的公共表示属性,即,这些属性不是可由客户端选择的,而是假设客户端针对图5中示出的所有或者至少两个周期而应用的。
虽然(代表不同媒体质量的)表示通常可基于一些环境方面(例如,如可用比特率)进行选择,一般可以代之以基于用户偏好(例如,以特定的优选语言来获取所请求的内容的偏好)或基于内容供给(例如,所请求的内容仅在英语版本下可用)选择具有不同语言的表示。从而,在后一情况下,通常针对后续的周期来选择和维持语言,而与客户端可以识别的任何可能的环境改变无关。相同的考虑适用于针对不同分辨率定义的表示,分辨率通常取决于用户设备的显示器的类型,并且其在上载媒体表示期间通常将是不改变的。
根据另一实现,可以通过分级的描述结构来产生或构造MPD,使得将所有表示的公共表示属性被放置在MPD的较高分层等级(周期单元等级或周期等级)处,而在MPD的较低分层等级(这里称为表示等级)上提供在周期单元的备选表示之间不同的表示属性(即,仅针对相应的表示有效的表示属性)。如下面将要进一步描述的,还可以在这种分层结构中应用其他等级,例如,中间周期构造等级。
图6示出了这种备选的分层布置的结构,其中,在针对每个相应周期601、602的周期等级上,公共地定义除比特率以外的、图5的MPD中描述的所有视频和音频相关的表示属性。与图2的实施例相似,将每个表示单元(在此,由周期601的三个表示603a、603b、603c和周期602的两个表示604a、604b来表示)作为取决于比特率的备选表示来提供,这些备选标识可以是例如可通过其比特率属性来标识的,该比特率属性针对周期601的表示分别被设置为LQ、MQ、HQ,针对周期602的表示分别被设置为LQ、MQ,即,在表示等级上定义比特率属性。
备选地,针对MPD的一个或多个周期单元,可以使一个以上的属性是客户端可选择的。图7描述了根据另一实施例的这种备选的分层MPD结构,其中,第一和第二周期701、702对应于图6相应的第一和第二周期。然而,在第三周期703中,周期单元包括两个不同的表示组(此后称为备选周期构造)704a、704b,形成高于表示等级但低于周期等级的又一分层等级。通过引入备选的周期构造,可以将可选择的表示布置在不同的组中,由此使得客户端可以轻易地基于多于一个的选择准则来选择相应的表示。
在当前示例中,周期构造704a包括基于语言的表示组,具有被设置为英语(en)的公共语言属性(lang),而对于备选的周期构造704b,相应的表示组具有被设置为法语(Fr)的公共语言属性(Lang)。第一周期构造704a包括分别对两个不同的比特率LQ和HQ进行描述的两个备选表示705a、705b,而第二周期构造704b包括分别对三个不同的比特率LQ、MQ和HQ进行描述的三个备选表示706a、706b、706c。由此,已经选择了优选语言(即,周期构造704a、704b中的一个)的客户端还将从所选择的周期构造中选择优选质量,并因此取决于选择这些可用选项中的哪一个来取得不同的媒体段。如图中指示的,在周期等级上给出针对相应周期构造的剩余给定表示属性,并从而是对所有三个周期的媒体段而言公共的、不可选择的选项。
参考MPD中的相应表示的媒体段的相应序列,存在描述URI的序列的不同方式。对于上述实施例,可以通过应用模板方案来描述相应的媒体段,或者通过列表(通常是播放列表)来显式地描述媒体段。备选地,可以应用该两个方案的组合。
当应用模板方案时,相应的媒体段(即,由特定的表示属性来表示的表示)应该针对基准轨道的每个段包含相同媒体持续时间,以使得客户端可以导出内容的正常媒体播放时间。因此,针对每个模板来定义对信息(例如,媒体呈现的相应周期的开始和持续时间)进行指定的有效索引的范围。
下面可以例如定义被描述为模板的媒体段URI的序列,在此由一个URI来描述。
在MPD中使用标识为$SegmentNumber$的索引来标识相应的段编号。上述模板包括带宽特有的表示属性,其已被设置为200kbps。此外,在此通过由“SegmentNumberStart”标识的相应表示的开始(在此设置为段编号11)以及由“SegmentDuration”标识的持续时间(在此设置为10s的段持续时间,即,可以从所引用的请求URL获取的每个段具有10s长的持续时间)来描述所描述的媒体段序列的有效索引范围。
如果代之使用播放列表方案来描述引用媒体段的URI的序列,每个所引用的媒体段可以包含不同持续时间的媒体数据。下面给出了与被描述为播放列表的一个表示相关联的媒体段URI的序列的示例。
优选地,针对每个媒体段给出对媒体段的媒体持续时间(在此,由“segment dur”来指示)进行定义的索引,由此,使得客户端可以从接收到的段计算正常的媒体播放时间轴。如给出的播放列表示例中所指示的,以秒来描述精确的持续时间。
下面示出了分层布置的MPD的另一示例,该MPD基于标准模板,即没有任何播放列表,其也利用两个备选的表示来描述一个周期:
显而易见地,以上模板描述了240s长的会话,该会话具有相同长度的单个周期。其包括两个不同的表示,以英语(en)作为在表示级上呈现的公共语言,然而,这些表示可通过在两个表示中不同的带宽属性来区分。对于给定的周期,在周期等级上将两个表示公共的一些表示属性(例如,被设置为1.0的xml版本,以及被设置为UTF-8的编码)插入到MPD中。
与上述基于模板的MPD相比,播放列表风格的MPD具有类似的结构,不同之处在于播放列表风格的MPD包括多个周期单元。这种播放列表风格的MPD的示例(没有任何模板)如下,该MPD包括三个周期。
向上述MPD提供具有带宽属性的表示,带宽属性使得可以针对每个周期选择优选带宽,而在播放列表的开始指示的其他表示属性对所有周期和表示而言是公共的。针对每个周期,客户端使用所描述的URL来进行单个请求,并顺序地播出每个周期。
根据下面给出的又一实施例,可以代之以将MPD配置为播放列表和模板的组合。这种配置使得可以接收可从多个源下载的内容。在给出的示例中,播放列表将分别具有“周期开始”0、110和120的三个模板表示相链接。这种MPD可以例如适于描述已被中间的广告分为两块的电视节目。客户端可以与以上示例类似地请求第一和第三周期,其中,可以选择适合的表示,而在第二周期中,仅单个表示可用,以及客户端将能够向不同的服务器请求访问该表示。
从上可看出,在通道或轨道之间可以存在多个关联,即在不同的备选表示之间进行选择和切换的备选方式。例如,可以通过英语来提供除了一条通道之外的所有通道,或者甚至对不同表示进行描述的URL直到甚至最后的字符可以是公共的。
根据一个实施例,可以在分层结构的所有等级上应用表示属性(例如,如语言属性),以使得除非其被覆盖(overridden),可以针对感兴趣的整个子树定义语言。
另一方案是允许要在表示等级上定义的扩展单元(在此称为RequestURLExtension单元),而可以在周期单元等级上描述requestURL,其中,例如
RequestURL=http://www.example.com/content/example.3gp
以及,通过例如以下方式以表示等级扩展周期单元等级的该URL:
RequestURLExtension=″R2/$SegmentNumber$
在以上给出的示例中,对于进行请求的客户端,该客户端通过级联“RequestURL=http://www.example.com/content/example.3gp”以及“R2/$SegmentNumber$”形成http://www.example.com/content/example.3gpR2/$SegmentNumber$来产生内容的RequestURL,以使得可以选择相应的表示。
下面给出了以分层方式描述的表示属性的另一示例,其中,第一和第二周期中,以周期等级指示视频内容大小和语言属性,并因此对于这些周期的所有表示,这些备选是有效的。
在第三周期中,代之以更高的周期等级指示视频内容大小和带宽属性,并因此对于该周期的所有表示,这些表示属性是有效的,而在表示等级上将对第三周期的各个表示而言不同的语言指示为语言属性。
根据同样以分层方式来描述表示属性的另一实施例,周期单元描述了包括开始媒体播放时间的持续时间,针对开始媒体播放时间,描述了媒体段URI。表示单元封装了针对单个流属性的所有URI,例如,200kbps流的媒体段的第一轨道,以及400kbps流的媒体段的第二轨道。
在下面呈现的MPD中,使用基于模板的构造来描述第一周期,而使用播放列表构造来描述第二周期。如上已经提到的,对于不同的表示,播放列表构造所描述的媒体段的内容持续时间是不同的。
在第一周期期间,媒体段包含10秒的200kbps质量等级的媒体数据以及5秒的400kbps质量等级的媒体数据。然而,每个媒体段的确精确地包含了相同的媒体持续时间。
在第二周期期间,媒体段的持续时间改变。对于带宽属性被设置为200kbps的LQ表示,媒体段平均包含20秒的媒体数据,而对于HQ版本的媒体段(即,带宽属性被设置为400kbps的段),媒体段平均仅包含10秒。
MPD可在需要时进行更新。图8a和8b是简化的示意,其中,图8a是包括具有相应表示的两个周期单元801、802的旧MPD的示意,而图8b是更新的MPD的示意,已经向该更新的MPD提供了增加至媒体播放时间轴末尾的附加的周期单元803,周期单元803在第三周期中包括三个备选表示。在更新期间,必须修改最新的周期描述,以使得其描述媒体URI的有效范围。此外,模板构造可因新表示的增加而改变。如图8a和8b中指示的,在旧的MPD和更新的MPD中,周期801和802的指令是相同的。
即使没有应用MPD的更新,对实况情况的支持也是可能的。如果客户端至少以粗略的精度与服务器时间同步,可以通过相关联的MPD来描述具有明确末尾的任何实况传输。在这种情况下,MPD可以被配置为还描述相应的媒体播放时间轴与服务器的时间或挂钟时间(例如,NTP(网络时间周期))的映射。
作为示例,MPD可以定义媒体播放时间起始于1605h CET。当客户端已经以特定的精度进行了时间同步时,客户端将能够确定最新的可用媒体段,或者当前正在客户端处构造的媒体段。
时间偏移将取决于实况情况。当终端对“最新的可用媒体段”有着充分精确的理解时,可以通过“正常的媒体播放时间”或者通过“段的数目”来描述时间偏移缓冲。其他方法(例如通过挂钟时间来描述时间偏移缓冲)也是可能的。
对于可以从服务器使其可用的MPD更新的情况,现在将在下面描述使客户端知道MPD更新的两种不同的方案。
根据第一实施例,客户端被配置为对来自服务器或来自高速缓存或其他任何中间网络节点的新MPD更新执行频繁轮询。通常在MPD描述中给出轮询间隔,然而,备选地,轮询间隔可以是预定义的。MPD文件通常比媒体段小得多,因此,与媒体段相比,更易于由HTTP高速缓存来处理。还通常对常规的高速缓存分层结构进行优化,以处理数目稳定增加的小文档,以及因此还处理更新的MPD。
根据另一实施例,取而代之地,客户端被配置为应用推送通知方案,其中,通常通过接收与相关联的媒体段一起带内发送的通知,向客户端通知服务器的MPD更新。服务器可以在多部分MIME容器中将新的MPD与相关联的媒体段一起提供。中间高速缓存可以通过处理任何其他类型的文件的相同方式来处理这种多部分MIME容器。如果客户端在时间偏移模式下,客户端通常将被配置为在发起任何寻找操作前轮询MPD更新。
下面,将参考图9的简化框图方案更详细地描述服务器,该服务器被配置为提供具有根据上述的任何实施例的结构的MPD。服务器900包括产生单元910,产生单元910被配置为针对播放时间轴的每个周期,产生相关的表示,以及可选地,针对经由通信单元920作为对服务器900的输入数据从任何类型的常规媒体源(未示出)提供的相应媒体呈现,还产生备选的周期构造,以使得可以将与相应的表示相关联的可选择的表示属性用作对于客户端而言可选择的选项。
产生单元910通常还被配置为在需要时根据上述的过程更新MPD。在此称为服务器900的提供单元930的另一单元被配置为提供MPD,以使得MPD可被进行请求的客户端访问。根据一个实施例,提供单元930可因此被配置为将MPD存储在任何类型的存储装置中,以使得访问服务器900的客户端可以经由通信单元(在此,由第二通信单元940来表示)请求并从存储装置获取MPD。在此,由存储单元950来提供这种存储功能,其可以基于任何类型的常规存储功能。备选地,提供单元930可以被配置为经由第二通信单元940向中间网络节点(例如,如高速缓存)发送MPD,由此使得客户端可以在需要时从中间节点获取MPD。
如上所述,服务器900还可以被配置为更新之前由服务器900产生并在服务器900处存储的MPD。如果要应用这种更新选项,还将向产生单元910提供适合的更新功能,这可以使得可将一个或多个表示增加到MPD的现有周期单元、增加新的周期单元、从周期单元移除一个或多个表示和/或相应地修改一个或多个表示。可以经由任何类型的用户接口(UI)(在此以UI 960来表示)向产生单元910提供修改MPD的指令。将由MPD描述的媒体播放时间放松(unbounded)到“将来”。当内容提供商想要增加现有的周期单元的一个或多个新的表示或者新的周期单元时,其可以控制服务器900,以使得将新的周期描述增加到媒体播放时间轴的结尾处,保持任何之前的周期单元不变。
以对应的方式,现在,下面将参考图10的简化框图方案更详细地描述客户端(例如,移动电话、机顶盒、膝上型设备或PC),该客户端适于在能够交付媒体呈现并能够从网络节点(例如,服务器或高速缓存)请求MPD和相关联的媒体段的任何类型的用户设备中实现。
客户端1000包括请求单元1010,请求客户端1010被配置为通常基于经由用户接口(UI)输入的命令,经由通信单元1020从网络节点请求和获取MPD以及相关联的媒体段,在此由UI 1030来表示该UI,其可以是任何类型的常规UI。如以上的可能选项提及的,如果客户端1030还被配置为轮询已更新的MPD,请求单元1010还可以被配置为通常根据之前从MPD获取的轮询间隔来执行这种轮询。像这样的轮询机制是本领域技术人员所公知的,并从而不属于本文档的范围。
客户端1000还包括存储单元1040,存储单元1040可基于任何类型的可用存储技术来配置,连接到请求单元1010,以使得一旦由请求单元1010经由通信单元1020接收到MPD,MPD将被存储,并从而可由客户端1000访问,以用于媒体呈现目的。客户端1000还包括选择单元1050,选择单元1050被配置为根据可针对相应的周期单元应用的一个或多个选择准则来选择表示和/或周期构造。选择单元1050可以经由UI 1030接收选项(例如,用户选择的优选语言),然后,选择单元1050使用该输入来针对相应的周期单元选择相关的周期构造或表示。
为了向最终用户提供可能的最佳质量体验,客户端1000可被配置为通过根据可用链路比特率或任何其他的质量相关估计来在表示之间切换,自适应地调整媒体呈现的媒体质量。为了提供这种选项,还可以向客户端1000提供单元,该单元被配置为通常连续地估计适当的参数,并基于该估计来选择最适合的、实现特有的表示。在此,这种功能是由估计单元1060来提供的。估计单元1060通常可被配置为:当所估计的比特率超过或低于由当前选择的表示所表示的比特率预定义的容限时,从一个备选表示切换到一个备选表示。
备选地,或者除了从UI 1030提供的输入以外附加地,选择单元1050可因此被配置为仅基于从估计单元1060提供的输入数据(或者与来自UI 1030的输入相结合)来进行判决。此外,选择单元1050可以被配置为将预定义的、所存储的设置或偏好与上述可能的输入数据相结合来进行考虑,或者作为优先化的设置。通过示例的方式,与其他备选相比,客户端驻留其上的用户设备的显示可以是预定义的和优先化的。
图10的选择单元1050还可操作地连接到请求单元1010,以使得其可以指示请求单元1010根据所选择的表示的URI的相应有序列表,从一个或多个相应的网络节点请求所选择的媒体段。
通常还向通信单元1020提供与服务器进行同步的功能,通常是基于从MPD获得的同步信息来进行同步的。
一旦选择单元1050已经执行了对表示的选择,以及已经由请求单元1010请求了对应的媒体段,通常由客户端的通信装置或者客户端1000在其上驻留的设备来接收相关媒体段,其中,对媒体段进行缓冲,以使得可以通过常规的方式对其进行交付。此外,获取和处理媒体段的过程是本领域技术人员所周知的,并因此在本文档中将不进行任何更详细的讨论。
应理解,图9的服务器和图10的客户端都表示简化的配置,为了简洁的目的,已经省略了通常可以分别包括在正常的服务器和客户端中,然而对于理解本文档中建议的MPD的处理不是必不可少的实体。此外,应理解,这些图中呈现的单元仅被视为一种可能的配置,以及其他的功能单元和功能的其他组合也可适用,只要所描述的功能可遵循上述的一般性原理执行即可。
可以将服务器,以及上述的客户端作为相应的基于硬件的解决方案、基于软件的解决方案或其组合来实现。在前者的情况下,可以通过相应的专用集成电路(ASIC)配置的形式来实现图9和10中分别描述的相应单元。
现在,将参考图11来描述被配置为基于软件的解决方案的服务器1100,其中,将处理器1110连接到存储单元830、第一通信单元820和第二通信单元840,并配置为基于存储单元830中维护的指令来控制服务器功能。更具体地,处理器1110被配置为控制产生功能1120和提供功能1130,产生功能1120被配置为通过实现与图8的产生单元810的功能相对应的功能来产生MPD,提供功能1130被配置为通过实现与图8的提供单元930的功能相对应的功能来提供所产生的MPD。
以对应的方式,下面参考图12来描述基于软件的客户端1200,其中,连接到通信单元920和存储单元940的处理器1210被配置为基于存储单元940中包含的指令,来控制请求功能1220和选择功能1230执行与相应单元执行的功能相对应的功能,该相应单元与图9的请求单元910和选择单元950相对应。
此外,处理器1210可以被配置为控制估计功能1240,估计功能1240被配置为通过与图9的估计单元960的功能相对应的方式来执行估计功能。
Claims (37)
1.一种由通信网络的服务器执行的方法,用于使HTTP媒体流能够由客户端访问,所述方法包括:
-产生媒体呈现描述,以使得向媒体呈现描述提供根据媒体播放时间轴顺序布置的至少一个周期单元,使得向每个周期单元提供至少一个表示,以及使得向所述至少一个周期单元中的至少一个周期单元提供至少两个备选表示,其中,向每个表示提供至少一个媒体段URI的有序序列,每个媒体段URI引用所述HTTP媒体流的至少一个媒体段,以及
-提供媒体呈现描述,由此使得所述客户端能够获取MPD,基于媒体呈现描述的内容,针对至少一个周期单元来选择表示,以及针对每个所选择的表示,获取相应的所引用的媒体段。
2.根据权利要求1所述的方法,其中,所述产生步骤包括:
-对至少一个媒体段URI的有序序列中的至少一个有序序列进行布置,以使得将该至少一个有序序列作为至少一个表示来提供并以模板格式来描述。
3.根据权利要求1或2所述的方法,其中,所述产生步骤包括:
-布置所述表示中的至少一个表示,以使得将该至少一个表示作为至少两个媒体段URI的有序序列来提供,并以播放列表格式来描述。
4.根据前述权利要求中任一项所述的方法,其中,所述产生步骤包括:
-向与相同周期单元相关联的各个表示提供第一表示属性,所述第一表示属性具有代表在所述表示中引用的媒体段的设置,由此使得客户端能够基于相应的设置来选择相应周期单元的表示。
5.根据权利要求4所述的方法,其中,所述产生步骤包括:
-向每个周期单元提供第二表示属性;以及
-选择对与所述周期单元相关联的所有媒体段而言公共的第二表示属性的设置,以使得所述设置代表与所述周期单元相关联的所有表示。
6.根据权利要求5所述的方法,其中,所述产生步骤包括:
-在相应周期单元的每个表示中提供相应的第二表示属性,以使得在表示这一级别上描述所述第二表示属性,或者
-在相应周期单元中提供相应的第二表示属性,以使得在周期单元这一级别上描述所述第二表示属性。
7.根据权利要求4所述的方法,其中,所述产生步骤包括:
-向媒体呈现描述的至少一个周期单元提供至少两个备选周期构造,其中,向每个周期构造提供至少两个表示以及第二表示属性,以及
-选择第二表示属性的设置,以使得所述设置代表相应的周期构造,由此使得客户端能够基于所述表示属性中的一个或多个表示属性来选择所述周期单元的表示。
8.根权利要求5、6或7所述的方法,其中,所述表示属性中的每一个表示属性定义编解码器、比特率、分辨率和语言中的任一个。
9.根据前述权利要求中任一项所述的方法,包括其他步骤:
-通过向媒体呈现描述增加至少一个表示,通过从媒体呈现描述移除至少一个表示,或者通过修改媒体呈现描述的至少一个表示来更新媒体呈现描述。
10.根据权利要求9所述的方法,其中,所述产生步骤包括:
-向媒体呈现描述提供对轮询间隔的指示,由此使得客户端能够以通过所述指示确定的间隔来轮询媒体呈现描述更新。
11.根据权利要求9所述的方法,包括其他步骤:
-向客户端推送已更新的媒体呈现描述。
12.根据前述权利要求中任一项所述的方法,其中,所述产生步骤包括:
-向媒体呈现描述提供对映射的描述,所述映射是所述HTTP传输流的媒体播放时间轴与服务器时间轴或挂钟时间中任一时间的映射。
13.根据前述权利要求中任一项所述的方法,其中,所述产生步骤包括:
-布置相同周期单元的不同表示的媒体段,以使得媒体段在所述周期单元的开始处在时间上对齐。
14.一种由通信网络中的客户端执行的方法,用于从通信网络的至少一个网络节点获得HTTP媒体流,所述方法包括:
-从所述至少一个网络节点中的一个网络节点获取媒体呈现描述,所述媒体呈现描述包括根据媒体播放时间轴顺序布置的至少一个周期单元,其中,每个周期单元包括至少一个表示,以及所述至少一个周期单元中的至少一个周期单元包括至少两个备选表示,每个表示包括至少一个媒体段URI的有序序列,每个媒体段URI引用所述HTTP媒体流的至少一个媒体段,以及
-基于媒体呈现描述的内容,针对所述周期单元中的至少一个周期单元来选择表示,以及
-针对每个所选择的表示,获取与相应的表示相关联的所引用的媒体段。
15.根据权利要求14所述的方法,其中,所述选择包括:
-基于相应周期单元的一个或多个表示属性来选择相应表示,每个表示具有代表相应表示或周期单元的相应设置。
16.根据权利要求15所述的方法,包括其他步骤:
-估计能够用于从所述至少一个网络节点向客户端发送HTTP媒体流的比特率,以及
-通过考虑所述一个或多个表示属性中的至少一个表示属性,基于所述估计来选择至少一个周期单元的表示,所述至少一个表示属性是比特率相关的表示属性。
17.根据权利要求15或16所述的方法,其中,所述选择包括:
-通过还考虑至少一个客户端能力,选择相应的表示。
18.根据权利要求14-17中任一项所述的方法,包括其他步骤:
-对所述网络节点轮询媒体呈现描述更新,以及
-在确定媒体呈现描述已被更新的情况下,获取并存储所述已更新的媒体呈现描述。
19.根据权利要求18所述的方法,其中,所述轮询是根据从之前获取的媒体呈现描述所获取的轮询间隔来执行的。
20.根据权利要求14-17中任一项所述的方法,包括其他步骤:
-在从所述至少一个网络节点提供的推送通知中接收已更新的媒体呈现描述,以及
-存储所述已更新的媒体呈现描述。
21.一种通信网络中的服务器,能够使得客户端能够访问HTTP媒体流,所述服务器包括:
产生单元,被配置为产生媒体呈现描述,以使得向媒体呈现描述提供根据媒体播放时间轴顺序布置的至少一个周期单元,使得向每个周期单元提供至少一个表示,以及使得向所述至少一个周期单元中的至少一个周期单元提供至少两个备选表示,其中,向每个表示提供至少一个媒体段URI的有序序列,每个媒体段URI引用所述HTTP媒体流的至少一个媒体段,以及
提供单元,被配置为使得客户端能够访问媒体呈现描述,由此使得客户端能够获取媒体呈现描述,基于媒体呈现描述的内容,针对至少一个周期单元来选择表示,以及针对每个所选择的表示,获取相应的所引用的媒体段。
22.根据权利要求21所述的服务器,其中,所述产生单元被配置为:向媒体呈现描述提供以模板格式、播放列表格式或二者的组合描述的至少一个表示。
23.根据权利要求21或22所述的服务器,其中,所述产生单元被配置为:针对每个媒体段URI,向媒体呈现描述提供对相应的所引用的一个或多个媒体段的持续时间的指示。
24.根据权利要求21、22或23所述的服务器,其中,所述产生单元被配置为:向与相同周期单元相关联的各个表示提供表示属性和相应的表示属性设置,以使得所述表示是所述客户端能够基于所述表示属性来选择的。
25.根据权利要求24所述的服务器,其中,所述产生单元被配置为:提供至少两种不同类别的表示属性,以及通过分层的方式提供所述表示属性,以使得在以周期这一级别提供相应的表示属性的情况下,表示属性对相应周期单元的所有表示有效,而在以表示这一级别提供表示属性的情况下,表示属性仅对相应周期单元的相应表示有效。
26.根据权利要求21-25中任一项所述的服务器,其中,所述产生单元被配置为:通过向媒体呈现描述增加至少一个表示,通过从媒体呈现描述移除至少一个表示,或者通过修改媒体呈现描述的至少一个表示来更新媒体呈现描述。
27.根据权利要求26所述的服务器,其中,所述产生单元被配置为:向媒体呈现描述提供对轮询间隔的指示,由此使得已获取所述媒体呈现描述的客户端能够以通过轮询间隔指示确定的间隔来轮询媒体呈现描述更新。
28.根据权利要求26所述的服务器,还包括通信单元,所述通信单元被配置为:识别媒体呈现描述更新何时已被执行,以及向客户端推送已更新的媒体呈现描述。
29.根据权利要求21-28中任一项所述的服务器,其中,所述产生单元被配置为:向所述媒体呈现描述提供对映射的描述,所述映射是所述HTTP传输流的媒体播放时间轴与服务器时间轴或挂钟时间中任一时间的映射。
30.根据权利要求29所述的服务器,其中,所述产生单元被配置为:布置相同周期单元的不同表示的媒体段,以使得媒体段在所述周期单元的开始处在时间上对齐。
31.一种通信网络中的客户端,能够从通信网络的至少一个网络节点获取HTTP媒体流,所述客户端包括:
-请求单元,被配置为从所述至少一个网络节点中的一个网络节点获取媒体呈现描述,所述媒体呈现描述包括根据媒体播放时间轴顺序布置的至少一个周期单元,其中,每个周期单元包括至少一个表示,以及所述至少一个周期单元中的至少一个周期单元包括至少两个备选表示,每个表示包括至少一个媒体段URI的有序序列,每个媒体段URI引用所述HTTP媒体流的至少一个媒体段,以及所述请求单元被配置为获取与相应表示相关联的所引用的媒体段,以及
-选择单元,被配置为基于所述媒体呈现描述内容来选择每个相应的表示。
32.根据权利要求31所述的客户端,其中,所述选择单元被配置为:基于所述表示的至少一个表示属性来选择相应的表示,由此使得所述请求单元能够获取由所选择的表示引用的一个或多个媒体段。
33.根据权利要求32所述的客户端,还包括估计单元,所述估计单元被配置为:估计能够用于从所述至少一个网络节点向客户端发送HTTP媒体流的比特率,由此使得所述选择单元能够通过考虑所述一个或多个表示属性中的至少一个表示属性,基于所述估计来选择至少一个周期单元的表示,所述至少一个表示属性是比特率相关的表示属性。
34.根据权利要求32或33所述的客户端,其中,所述选择单元还被配置为:
通过还考虑至少一个客户端能力,选择相应的表示。
35.根据权利要求30-34中任一项所述的客户端,其中,所述请求单元还被配置为:对所述网络节点轮询媒体呈现描述更新;以及在确定媒体呈现描述已被更新的情况下,从所述网络节点获取已更新的媒体呈现描述。
36.根据权利要求35所述的客户端,其中,所述请求单元被配置为:通过应用从之前获取的媒体呈现描述所获取的轮询间隔,对所述网络节点轮询媒体呈现描述更新。
37.根据权利要求30-34中任一项所述的客户端,其中,所述请求单元被配置为:从所述至少一个网络节点接收包括已更新的媒体呈现描述的推送通知。
Applications Claiming Priority (5)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US29583010P | 2010-01-18 | 2010-01-18 | |
US61/295,830 | 2010-01-18 | ||
US29610410P | 2010-01-19 | 2010-01-19 | |
US61/296,104 | 2010-01-19 | ||
PCT/SE2011/050054 WO2011087449A1 (en) | 2010-01-18 | 2011-01-18 | Methods and arrangements for http media stream distribution |
Publications (2)
Publication Number | Publication Date |
---|---|
CN102714662A true CN102714662A (zh) | 2012-10-03 |
CN102714662B CN102714662B (zh) | 2017-06-09 |
Family
ID=43734037
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201180006387.6A Expired - Fee Related CN102714662B (zh) | 2010-01-18 | 2011-01-18 | 用于http媒体流分发的方法和装置 |
Country Status (8)
Country | Link |
---|---|
US (1) | US9621610B2 (zh) |
EP (1) | EP2526671B1 (zh) |
JP (1) | JP5667646B2 (zh) |
KR (1) | KR101636108B1 (zh) |
CN (1) | CN102714662B (zh) |
CA (1) | CA2784233C (zh) |
DK (1) | DK2526671T3 (zh) |
WO (1) | WO2011087449A1 (zh) |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2014173079A1 (zh) * | 2013-04-24 | 2014-10-30 | 华为技术有限公司 | 媒体文件接收、媒体文件发送方法和装置及系统 |
WO2015109492A1 (zh) * | 2014-01-23 | 2015-07-30 | 华为技术有限公司 | 移动终端、第一基站及流媒体分段获取方法 |
WO2016202225A1 (zh) * | 2015-06-16 | 2016-12-22 | 华为技术有限公司 | 内容项聚合方法和相关装置及通信系统 |
CN106936808A (zh) * | 2015-12-31 | 2017-07-07 | 中兴通讯股份有限公司 | Http流媒体传输方法及装置 |
CN108600789A (zh) * | 2013-03-29 | 2018-09-28 | 英特尔Ip公司 | 用于多媒体自适应流传输的装置和机器可读存储介质 |
CN110087093A (zh) * | 2013-04-19 | 2019-08-02 | 索尼公司 | 信息处理装置和方法以及非暂态计算机可读介质 |
CN112601113A (zh) * | 2019-10-01 | 2021-04-02 | 腾讯美国有限责任公司 | 流媒体传输方法、电子设备及存储介质 |
Families Citing this family (98)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8472792B2 (en) | 2003-12-08 | 2013-06-25 | Divx, Llc | Multimedia distribution system |
US7519274B2 (en) | 2003-12-08 | 2009-04-14 | Divx, Inc. | File format for multiple track digital data |
WO2007106844A2 (en) | 2006-03-14 | 2007-09-20 | Divx, Inc. | Federated digital rights management scheme including trusted systems |
US9432433B2 (en) | 2006-06-09 | 2016-08-30 | Qualcomm Incorporated | Enhanced block-request streaming system using signaling or block creation |
ES2875428T3 (es) | 2007-01-05 | 2021-11-10 | Divx Llc | Sistema de distribución de vídeo que incluye reproducción progresiva |
EP2223232A4 (en) | 2007-11-16 | 2015-02-25 | Sonic Ip Inc | Hierarchical and reduced index structures for multimedia files |
US8156089B2 (en) | 2008-12-31 | 2012-04-10 | Apple, Inc. | Real-time or near real-time streaming with compressed playlists |
US8260877B2 (en) | 2008-12-31 | 2012-09-04 | Apple Inc. | Variant streams for real-time or near real-time streaming to provide failover protection |
US8099473B2 (en) | 2008-12-31 | 2012-01-17 | Apple Inc. | Variant streams for real-time or near real-time streaming |
US9917874B2 (en) | 2009-09-22 | 2018-03-13 | Qualcomm Incorporated | Enhanced block-request streaming using block partitioning or request controls for improved client-side handling |
US8781122B2 (en) | 2009-12-04 | 2014-07-15 | Sonic Ip, Inc. | Elementary bitstream cryptographic material transport systems and methods |
US8805963B2 (en) | 2010-04-01 | 2014-08-12 | Apple Inc. | Real-time or near real-time streaming |
GB201105502D0 (en) | 2010-04-01 | 2011-05-18 | Apple Inc | Real time or near real time streaming |
CN102882845B (zh) | 2010-04-07 | 2016-07-13 | 苹果公司 | 实时或准实时流传输 |
KR101652255B1 (ko) * | 2010-04-26 | 2016-09-09 | 삼성전자주식회사 | 라이브 컨텐츠의 효과적인 재생방법 |
US8667164B2 (en) | 2010-04-26 | 2014-03-04 | Samsung Electronics Co., Ltd. | Method and apparatus for playing live content |
US9253548B2 (en) * | 2010-05-27 | 2016-02-02 | Adobe Systems Incorporated | Optimizing caches for media streaming |
GB201010456D0 (en) * | 2010-06-22 | 2010-08-04 | Vodafone Ip Licensing Ltd | Congestion control for streaming data |
WO2012030178A2 (ko) | 2010-09-01 | 2012-03-08 | 한국전자통신연구원 | 스트리밍 컨텐츠 제공 장치 및 방법 |
US20120124179A1 (en) * | 2010-11-12 | 2012-05-17 | Realnetworks, Inc. | Traffic management in adaptive streaming protocols |
US8914534B2 (en) | 2011-01-05 | 2014-12-16 | Sonic Ip, Inc. | Systems and methods for adaptive bitrate streaming of media stored in matroska container files using hypertext transfer protocol |
KR20120079880A (ko) * | 2011-01-06 | 2012-07-16 | 삼성전자주식회사 | 스트리밍 서비스 시스템에서 북마크 생성 장치 및 방법 |
US9661104B2 (en) * | 2011-02-07 | 2017-05-23 | Blackberry Limited | Method and apparatus for receiving presentation metadata |
CN107071513B (zh) * | 2011-03-16 | 2020-03-10 | 艾迪尔哈布股份有限公司 | 用于提供媒体内容的方法、客户机和服务器 |
US8856283B2 (en) | 2011-06-03 | 2014-10-07 | Apple Inc. | Playlists for real-time or near real-time streaming |
US8843586B2 (en) * | 2011-06-03 | 2014-09-23 | Apple Inc. | Playlists for real-time or near real-time streaming |
WO2012174301A1 (en) | 2011-06-14 | 2012-12-20 | Related Content Database, Inc. | System and method for presenting content with time based metadata |
US20130191745A1 (en) * | 2012-01-10 | 2013-07-25 | Zane Vella | Interface for displaying supplemental dynamic timeline content |
US8812662B2 (en) | 2011-06-29 | 2014-08-19 | Sonic Ip, Inc. | Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content |
US9590814B2 (en) * | 2011-08-01 | 2017-03-07 | Qualcomm Incorporated | Method and apparatus for transport of dynamic adaptive streaming over HTTP (DASH) initialization segment description fragments as user service description fragments |
CN103858457B (zh) | 2011-08-01 | 2018-11-13 | 英特尔公司 | 用于身份提供商(IdP)漫游/代理的多跳单点登录(SSO) |
KR101928910B1 (ko) | 2011-08-30 | 2018-12-14 | 쏘닉 아이피, 아이엔씨. | 복수의 최대 비트레이트 레벨들을 사용하여 인코딩된 비디오를 인코딩하고 스트리밍하기 위한 시스템들 및 방법들 |
US9467708B2 (en) * | 2011-08-30 | 2016-10-11 | Sonic Ip, Inc. | Selection of resolutions for seamless resolution switching of multimedia content |
US8818171B2 (en) | 2011-08-30 | 2014-08-26 | Kourosh Soroushian | Systems and methods for encoding alternative streams of video for playback on playback devices having predetermined display aspect ratios and network connection maximum data rates |
US8787570B2 (en) | 2011-08-31 | 2014-07-22 | Sonic Ip, Inc. | Systems and methods for automatically genenrating top level index files |
US8799647B2 (en) | 2011-08-31 | 2014-08-05 | Sonic Ip, Inc. | Systems and methods for application identification |
US8964977B2 (en) | 2011-09-01 | 2015-02-24 | Sonic Ip, Inc. | Systems and methods for saving encoded media streamed using adaptive bitrate streaming |
US8909922B2 (en) | 2011-09-01 | 2014-12-09 | Sonic Ip, Inc. | Systems and methods for playing back alternative streams of protected content protected using common cryptographic information |
US9591361B2 (en) * | 2011-09-07 | 2017-03-07 | Qualcomm Incorporated | Streaming of multimedia data from multiple sources |
JP5908984B2 (ja) | 2011-10-21 | 2016-04-26 | フラウンホーファー−ゲゼルシャフト・ツール・フェルデルング・デル・アンゲヴァンテン・フォルシュング・アインゲトラーゲネル・フェライン | 情報資源管理概念 |
US9712891B2 (en) * | 2011-11-01 | 2017-07-18 | Nokia Technologies Oy | Method and apparatus for selecting an access method for delivery of media |
US8977704B2 (en) | 2011-12-29 | 2015-03-10 | Nokia Corporation | Method and apparatus for flexible caching of delivered media |
WO2013098317A1 (en) * | 2011-12-29 | 2013-07-04 | Koninklijke Kpn N.V. | Network-initiated content streaming control |
US8918908B2 (en) | 2012-01-06 | 2014-12-23 | Sonic Ip, Inc. | Systems and methods for accessing digital content using electronic tickets and ticket tokens |
US20130182643A1 (en) * | 2012-01-16 | 2013-07-18 | Qualcomm Incorporated | Method and system for transitions of broadcast dash service receptions between unicast and broadcast |
US20150172348A1 (en) * | 2012-01-17 | 2015-06-18 | Telefonaktiebolaget L M Ericsson (Publ) | Method for sending respectively receiving a media stream |
TW201349870A (zh) * | 2012-01-19 | 2013-12-01 | Vid Scale Inc | 支援自適應觀看條件的視訊傳遞的方法和系統 |
US9401968B2 (en) | 2012-01-20 | 2016-07-26 | Nokia Techologies Oy | Method and apparatus for enabling pre-fetching of media |
EP2661045A1 (en) * | 2012-05-04 | 2013-11-06 | Thomson Licensing | Method and apparatus for providing a plurality of transcoded content streams |
EP2870770A2 (en) * | 2012-07-09 | 2015-05-13 | VID SCALE, Inc. | Power aware video decoding and streaming |
US8924582B2 (en) | 2012-07-09 | 2014-12-30 | Futurewei Technologies, Inc. | Dynamic adaptive streaming over hypertext transfer protocol client behavior framework and implementation of session management |
US20140052824A1 (en) * | 2012-08-20 | 2014-02-20 | Qualcomm Incorporated | Conveying state information for streaming media |
US20140068657A1 (en) * | 2012-08-29 | 2014-03-06 | The Directv Group, Inc. | Method and apparatus for inserting advertising into a video signal at a receiving device not having a digital video recorder (non-dvr) receiver |
US9936267B2 (en) | 2012-08-31 | 2018-04-03 | Divx Cf Holdings Llc | System and method for decreasing an initial buffering period of an adaptive streaming system |
US8949206B2 (en) | 2012-10-04 | 2015-02-03 | Ericsson Television Inc. | System and method for creating multiple versions of a descriptor file |
US10708335B2 (en) | 2012-11-16 | 2020-07-07 | Time Warner Cable Enterprises Llc | Situation-dependent dynamic bit rate encoding and distribution of content |
JP6141628B2 (ja) * | 2012-12-07 | 2017-06-07 | ハンファテクウィン株式会社Hanwha Techwin Co.,Ltd. | 映像信号圧縮装置、映像信号伸長装置、映像信号圧縮方法、及び映像信号伸長方法 |
JP6139872B2 (ja) * | 2012-12-10 | 2017-05-31 | キヤノン株式会社 | 情報処理装置及びその制御方法、プログラム、記憶媒体、並びに、映像処理システム |
US9191457B2 (en) | 2012-12-31 | 2015-11-17 | Sonic Ip, Inc. | Systems, methods, and media for controlling delivery of content |
US9313510B2 (en) | 2012-12-31 | 2016-04-12 | Sonic Ip, Inc. | Use of objective quality measures of streamed content to reduce streaming bandwidth |
US9426196B2 (en) | 2013-01-04 | 2016-08-23 | Qualcomm Incorporated | Live timing for dynamic adaptive streaming over HTTP (DASH) |
EP2904764B1 (en) | 2013-01-16 | 2016-09-21 | Huawei Technologies Co., Ltd. | Url parameter insertion and addition in adaptive streaming |
FR3002105A1 (fr) * | 2013-02-13 | 2014-08-15 | France Telecom | Procede de selection de la representation des segments d'un contenu multimedia transmis sur un reseau de communication |
US9906785B2 (en) | 2013-03-15 | 2018-02-27 | Sonic Ip, Inc. | Systems, methods, and media for transcoding video data according to encoding parameters indicated by received metadata |
US10397292B2 (en) | 2013-03-15 | 2019-08-27 | Divx, Llc | Systems, methods, and media for delivery of content |
US9438652B2 (en) | 2013-04-15 | 2016-09-06 | Opentv, Inc. | Tiered content streaming |
FR3005820B1 (fr) | 2013-05-17 | 2015-05-29 | Envivio France | Procede de gestion de listes de lecture personnalisees du type comprenant un gabarit d'uri et une liste d'identifiants de segments. |
US9094737B2 (en) | 2013-05-30 | 2015-07-28 | Sonic Ip, Inc. | Network video streaming with trick play based on separate trick play files |
US9100687B2 (en) | 2013-05-31 | 2015-08-04 | Sonic Ip, Inc. | Playback synchronization across playback devices |
US9380099B2 (en) | 2013-05-31 | 2016-06-28 | Sonic Ip, Inc. | Synchronizing multiple over the top streaming clients |
EP2819367A1 (en) * | 2013-06-28 | 2014-12-31 | Thomson Licensing | Method for retrieving, by a client terminal, a content part of a multimedia content |
WO2015000936A1 (en) | 2013-07-03 | 2015-01-08 | Koninklijke Kpn N.V. | Streaming of segmented content |
JPWO2015008775A1 (ja) * | 2013-07-19 | 2017-03-02 | ソニー株式会社 | 情報処理装置および方法 |
US9386067B2 (en) | 2013-12-30 | 2016-07-05 | Sonic Ip, Inc. | Systems and methods for playing adaptive bitrate streaming content by multicast |
US10476930B2 (en) * | 2014-01-06 | 2019-11-12 | Intel IP Corporation | Client/server signaling commands for dash |
EP3105903B1 (en) * | 2014-02-13 | 2019-08-07 | Koninklijke KPN N.V. | Requesting multiple chunks from a network node on the basis of a single request message |
US9866878B2 (en) | 2014-04-05 | 2018-01-09 | Sonic Ip, Inc. | Systems and methods for encoding and playing back video at different frame rates using enhancement layers |
US10045050B2 (en) | 2014-04-25 | 2018-08-07 | Vid Scale, Inc. | Perceptual preprocessing filter for viewing-conditions-aware video coding |
US10523723B2 (en) | 2014-06-06 | 2019-12-31 | Koninklijke Kpn N.V. | Method, system and various components of such a system for selecting a chunk identifier |
US10033824B2 (en) * | 2014-06-30 | 2018-07-24 | Samsung Electronics Co., Ltd. | Cache manifest for efficient peer assisted streaming |
KR20170030490A (ko) * | 2014-07-07 | 2017-03-17 | 소니 주식회사 | 수신 장치, 수신 방법, 송신 장치, 및 송신 방법 |
WO2016022979A1 (en) | 2014-08-07 | 2016-02-11 | Sonic IP. Inc. | Systems and methods for protecting elementary bitstreams incorporating independently encoded tiles |
US9894130B2 (en) * | 2014-09-23 | 2018-02-13 | Intel Corporation | Video quality enhancement |
EP3910904A1 (en) | 2015-01-06 | 2021-11-17 | DivX, LLC | Systems and methods for encoding and sharing content between devices |
EP3057319A1 (en) * | 2015-02-10 | 2016-08-17 | Harmonic Inc. | Adaptive resolution video decoder |
US9826016B2 (en) | 2015-02-24 | 2017-11-21 | Koninklijke Kpn N.V. | Fair adaptive streaming |
WO2016138493A1 (en) | 2015-02-27 | 2016-09-01 | Sonic Ip, Inc. | Systems and methods for frame duplication and frame extension in live video encoding and streaming |
US10075292B2 (en) | 2016-03-30 | 2018-09-11 | Divx, Llc | Systems and methods for quick start-up of playback |
US10587934B2 (en) * | 2016-05-24 | 2020-03-10 | Qualcomm Incorporated | Virtual reality video signaling in dynamic adaptive streaming over HTTP |
US10231001B2 (en) | 2016-05-24 | 2019-03-12 | Divx, Llc | Systems and methods for providing audio content during trick-play playback |
US10129574B2 (en) | 2016-05-24 | 2018-11-13 | Divx, Llc | Systems and methods for providing variable speeds in a trick-play mode |
JP6669402B2 (ja) * | 2016-05-26 | 2020-03-18 | キヤノン株式会社 | 通信装置、システム、情報処理方法及びプログラム |
US10148989B2 (en) | 2016-06-15 | 2018-12-04 | Divx, Llc | Systems and methods for encoding video content |
US10498795B2 (en) | 2017-02-17 | 2019-12-03 | Divx, Llc | Systems and methods for adaptive switching between multiple content delivery networks during adaptive bitrate streaming |
JP7162295B2 (ja) * | 2018-08-01 | 2022-10-28 | 株式会社radiko | セグメントファイル分割機能を備えたストリーム配信システム及びプログラム |
JP7305371B2 (ja) * | 2019-02-20 | 2023-07-10 | キヤノン株式会社 | 情報配信装置、情報配信方法及びプログラム |
EP3942437B1 (en) | 2019-03-21 | 2024-01-10 | DivX, LLC | Systems and methods for multimedia swarms |
WO2023056392A1 (en) * | 2021-10-01 | 2023-04-06 | Bytedance Inc. | Method, apparatus, and medium for video processing |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1328300A (zh) * | 2000-06-14 | 2001-12-26 | 松下电器产业株式会社 | 数据处理装置及数据处理方法 |
WO2002057943A1 (en) * | 2001-01-18 | 2002-07-25 | Yahoo! Inc. | Method and system for managing digital content, including streaming media |
WO2003059825A1 (fr) * | 2002-01-02 | 2003-07-24 | Ondeo Degremont | Procede de traitement des boues et des dechets issus du traitement d'eaux usees |
CN101371307A (zh) * | 2006-01-31 | 2009-02-18 | 株式会社东芝 | 使用信息存储介质的信息再现系统 |
US20090150557A1 (en) * | 2007-12-05 | 2009-06-11 | Swarmcast, Inc. | Dynamic bit rate scaling |
WO2009101787A1 (ja) * | 2008-02-15 | 2009-08-20 | Panasonic Corporation | 再生装置、記録装置、再生方法および記録方法 |
US20090259766A1 (en) * | 2008-04-11 | 2009-10-15 | Mobitv, Inc. | Client capability adjustment |
US20090282162A1 (en) * | 2008-05-12 | 2009-11-12 | Microsoft Corporation | Optimized client side rate control and indexed file layout for streaming media |
Family Cites Families (16)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6128653A (en) * | 1997-03-17 | 2000-10-03 | Microsoft Corporation | Method and apparatus for communication media commands and media data using the HTTP protocol |
US6910078B1 (en) * | 2001-11-15 | 2005-06-21 | Cisco Technology, Inc. | Methods and apparatus for controlling the transmission of stream data |
US7451229B2 (en) * | 2002-06-24 | 2008-11-11 | Microsoft Corporation | System and method for embedding a streaming media format header within a session description message |
US8204079B2 (en) * | 2002-10-28 | 2012-06-19 | Qualcomm Incorporated | Joint transmission of multiple multimedia streams |
US20070110074A1 (en) * | 2004-06-04 | 2007-05-17 | Bob Bradley | System and Method for Synchronizing Media Presentation at Multiple Recipients |
JP2007074684A (ja) * | 2005-09-09 | 2007-03-22 | Ssc Partners:Kk | 動画配信システム |
US9432433B2 (en) * | 2006-06-09 | 2016-08-30 | Qualcomm Incorporated | Enhanced block-request streaming system using signaling or block creation |
US9386064B2 (en) | 2006-06-09 | 2016-07-05 | Qualcomm Incorporated | Enhanced block-request streaming using URL templates and construction rules |
KR20080018778A (ko) * | 2006-08-25 | 2008-02-28 | 삼성전자주식회사 | Av 컨텐츠를 세그먼트 단위로 실행하는 방법, 제어포인트 장치 및 홈 네트워크 시스템 |
US9167007B2 (en) * | 2008-06-06 | 2015-10-20 | Amazon Technologies, Inc. | Stream complexity mapping |
US20090307602A1 (en) * | 2008-06-06 | 2009-12-10 | Life In Focus, Llc | Systems and methods for creating and sharing a presentation |
US8205004B1 (en) * | 2009-06-26 | 2012-06-19 | Adobe Systems Incorporated | Multi-bit-rate streaming delivery |
US8914835B2 (en) * | 2009-10-28 | 2014-12-16 | Qualcomm Incorporated | Streaming encoded video data |
AU2010314582B2 (en) | 2009-11-09 | 2015-03-12 | Snaptrack, Inc. | Method, system and network equipment for implementing HTTP-based streaming media service |
KR101786051B1 (ko) * | 2009-11-13 | 2017-10-16 | 삼성전자 주식회사 | 데이터 제공 방법 및 장치와 데이터 수신 방법 및 장치 |
KR101786050B1 (ko) | 2009-11-13 | 2017-10-16 | 삼성전자 주식회사 | 데이터 전송 방법 및 장치 |
-
2011
- 2011-01-18 US US13/521,387 patent/US9621610B2/en active Active
- 2011-01-18 CA CA2784233A patent/CA2784233C/en active Active
- 2011-01-18 JP JP2012548920A patent/JP5667646B2/ja not_active Expired - Fee Related
- 2011-01-18 WO PCT/SE2011/050054 patent/WO2011087449A1/en active Application Filing
- 2011-01-18 DK DK11703511.3T patent/DK2526671T3/en active
- 2011-01-18 EP EP11703511.3A patent/EP2526671B1/en not_active Not-in-force
- 2011-01-18 KR KR1020127018847A patent/KR101636108B1/ko active IP Right Grant
- 2011-01-18 CN CN201180006387.6A patent/CN102714662B/zh not_active Expired - Fee Related
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1328300A (zh) * | 2000-06-14 | 2001-12-26 | 松下电器产业株式会社 | 数据处理装置及数据处理方法 |
CN1584882A (zh) * | 2000-06-14 | 2005-02-23 | 松下电器产业株式会社 | 数据处理装置及数据处理方法 |
WO2002057943A1 (en) * | 2001-01-18 | 2002-07-25 | Yahoo! Inc. | Method and system for managing digital content, including streaming media |
WO2003059825A1 (fr) * | 2002-01-02 | 2003-07-24 | Ondeo Degremont | Procede de traitement des boues et des dechets issus du traitement d'eaux usees |
CN101371307A (zh) * | 2006-01-31 | 2009-02-18 | 株式会社东芝 | 使用信息存储介质的信息再现系统 |
US20090150557A1 (en) * | 2007-12-05 | 2009-06-11 | Swarmcast, Inc. | Dynamic bit rate scaling |
WO2009101787A1 (ja) * | 2008-02-15 | 2009-08-20 | Panasonic Corporation | 再生装置、記録装置、再生方法および記録方法 |
US20090259766A1 (en) * | 2008-04-11 | 2009-10-15 | Mobitv, Inc. | Client capability adjustment |
US20090282162A1 (en) * | 2008-05-12 | 2009-11-12 | Microsoft Corporation | Optimized client side rate control and indexed file layout for streaming media |
Non-Patent Citations (2)
Title |
---|
ALEX ZAMBELLI: "《IIS Smooth Streaming Technical Overview》", 31 March 2009 * |
R. PANTOS, ED.: "《HTTP Live Streaming draft-pantos-http-live-streaming-00》", 1 May 2009 * |
Cited By (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108600789A (zh) * | 2013-03-29 | 2018-09-28 | 英特尔Ip公司 | 用于多媒体自适应流传输的装置和机器可读存储介质 |
CN110087093A (zh) * | 2013-04-19 | 2019-08-02 | 索尼公司 | 信息处理装置和方法以及非暂态计算机可读介质 |
WO2014173079A1 (zh) * | 2013-04-24 | 2014-10-30 | 华为技术有限公司 | 媒体文件接收、媒体文件发送方法和装置及系统 |
US9628547B2 (en) | 2013-04-24 | 2017-04-18 | Huawei Technologies Co., Ltd. | Media file receiving and media file sending methods, apparatuses, and systems |
WO2015109492A1 (zh) * | 2014-01-23 | 2015-07-30 | 华为技术有限公司 | 移动终端、第一基站及流媒体分段获取方法 |
CN105027530A (zh) * | 2014-01-23 | 2015-11-04 | 华为技术有限公司 | 移动终端、第一基站及流媒体分段获取方法 |
CN105027530B (zh) * | 2014-01-23 | 2018-09-07 | 华为技术有限公司 | 移动终端、第一基站及流媒体分段获取方法 |
WO2016202225A1 (zh) * | 2015-06-16 | 2016-12-22 | 华为技术有限公司 | 内容项聚合方法和相关装置及通信系统 |
CN106936808A (zh) * | 2015-12-31 | 2017-07-07 | 中兴通讯股份有限公司 | Http流媒体传输方法及装置 |
CN106936808B (zh) * | 2015-12-31 | 2021-01-26 | 中兴通讯股份有限公司 | Http流媒体传输方法及装置 |
CN112601113A (zh) * | 2019-10-01 | 2021-04-02 | 腾讯美国有限责任公司 | 流媒体传输方法、电子设备及存储介质 |
CN112601113B (zh) * | 2019-10-01 | 2023-04-07 | 腾讯美国有限责任公司 | 流媒体传输方法、电子设备及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
US9621610B2 (en) | 2017-04-11 |
US20120290644A1 (en) | 2012-11-15 |
WO2011087449A1 (en) | 2011-07-21 |
KR101636108B1 (ko) | 2016-07-04 |
JP5667646B2 (ja) | 2015-02-12 |
JP2013517676A (ja) | 2013-05-16 |
CA2784233C (en) | 2017-05-16 |
CA2784233A1 (en) | 2011-07-21 |
EP2526671B1 (en) | 2016-11-16 |
EP2526671A1 (en) | 2012-11-28 |
DK2526671T3 (en) | 2017-02-27 |
KR20120117829A (ko) | 2012-10-24 |
CN102714662B (zh) | 2017-06-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN102714662A (zh) | 用于http媒体流分发的方法和装置 | |
US11877017B2 (en) | System for measuring video playback events using a server generated manifest/playlist | |
US11477521B2 (en) | Media presentation description patches for video streaming | |
AU2010314061B2 (en) | Method and apparatus for managing content service in network based on content use history | |
CN110121871B (zh) | 对于流式内容部分的基于请求的编码系统和方法 | |
US10277669B1 (en) | Communication channel between device and CDN during playback | |
EP2494482B1 (en) | Assembling streamed content for on-demand presentation | |
US11228792B1 (en) | Transcoding of video content | |
JP6761983B2 (ja) | 広告配信サーバ、番組配信サーバ及び再生端末、並びに映像配信システム | |
US20210274245A1 (en) | Identification of elements in a group for dynamic element replacement | |
CN102790779A (zh) | 一种直播视频资源下载方法和装置 | |
JP2017108217A (ja) | 受信装置、再生時刻制御方法、及びプログラム | |
KR101068363B1 (ko) | 콘텐츠 사용 이력에 따른 단말기 최적 메뉴 제공 시스템,장치 및 방법 | |
CN108271040A (zh) | 播放视频的方法和装置 | |
CN114270869A (zh) | 现场制作和频道播出的ai驱动编排自动化的系统及方法 | |
KR20230047720A (ko) | 컨텐츠 풀 기반 방송 시스템 및 그 방법 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant | ||
CF01 | Termination of patent right due to non-payment of annual fee | ||
CF01 | Termination of patent right due to non-payment of annual fee |
Granted publication date: 20170609 Termination date: 20220118 |