US20110231520A1 - Method and apparatus for adaptively streaming content including plurality of chapters - Google Patents
Method and apparatus for adaptively streaming content including plurality of chapters Download PDFInfo
- Publication number
- US20110231520A1 US20110231520A1 US13/051,514 US201113051514A US2011231520A1 US 20110231520 A1 US20110231520 A1 US 20110231520A1 US 201113051514 A US201113051514 A US 201113051514A US 2011231520 A1 US2011231520 A1 US 2011231520A1
- Authority
- US
- United States
- Prior art keywords
- media data
- tag
- content
- client
- information
- 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
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/235—Processing of additional data, e.g. scrambling of additional data or processing content descriptors
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/234—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
- H04N21/2343—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements
- H04N21/23439—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements for generating different versions
-
- 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/70—Media network packetisation
-
- 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
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/235—Processing of additional data, e.g. scrambling of additional data or processing content descriptors
- H04N21/2353—Processing of additional data, e.g. scrambling of additional data or processing content descriptors specifically adapted to content descriptors, e.g. coding, compressing or processing of metadata
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/236—Assembling of a multiplex stream, e.g. transport stream, by combining a video stream with other content or additional data, e.g. inserting a URL [Uniform Resource Locator] into a video stream, multiplexing software data into a video stream; Remultiplexing of multiplex streams; Insertion of stuffing bits into the multiplex stream, e.g. to obtain a constant bit-rate; Assembling of a packetised elementary stream
- H04N21/2362—Generation or processing of Service Information [SI]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/24—Monitoring of processes or resources, e.g. monitoring of server load, available bandwidth, upstream requests
- H04N21/2402—Monitoring of the downstream path of the transmission network, e.g. bandwidth available
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/60—Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client
- H04N21/65—Transmission of management data between client and server
- H04N21/658—Transmission by the client directed to the server
- H04N21/6581—Reference data, e.g. a movie identifier for ordering a movie or a product identifier in a home shopping application
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/80—Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
- H04N21/81—Monomedia components thereof
- H04N21/812—Monomedia components thereof involving advertisement data
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/80—Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
- H04N21/83—Generation or processing of protective or descriptive data associated with content; Content structuring
- H04N21/845—Structuring of content, e.g. decomposing content into time segments
- H04N21/8456—Structuring of content, e.g. decomposing content into time segments by decomposing the content in the time domain, e.g. in time segments
-
- 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/75—Media network packet handling
- H04L65/764—Media network packet handling at 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/80—Responding to QoS
Definitions
- Exemplary embodiments relate to a streaming method and apparatus, and more particularly, to a method and apparatus for adaptively streaming media data according to fluctuations in a streaming environment.
- Examples of a method of transmitting media data through a network include a downloading method and a streaming method.
- a server transmits media data in real time
- a client reproduces the received media data in real time.
- the streaming method transmits and receives the media data through a logical channel set between the server and the client, and reproduces the media data in real time
- a method and apparatus for maintaining quality of service (QoS) in reproducing the media data by reflecting fluctuations in a streaming environment are required.
- Methods and apparatuses consistent with exemplary embodiments generally relate to adaptively adjusting and performing streaming, i.e., adaptively transmitting and receiving media data according to a streaming environment.
- An exemplary embodiment also provides a non-transitory computer readable recording medium having recorded thereon a program which when executed by a computer performs the methods described herein.
- a method of receiving media data including receiving a file including information regarding a plurality of media data generated by encoding content so as to have different qualities, from a server; and receiving at least one media data from among the plurality of media data, based on the received file, wherein the file comprises information regarding a plurality of still images corresponding to a plurality of chapters of the content.
- the receiving of the at least one media data may include receiving the plurality of still images, based on the received file; and receiving the at least one media data, starting from a chapter selected based on the plurality of still images.
- the file may include a first tag including at least one from among location information, resolution information, and compression type information regarding the plurality of still images.
- the first tag may have a same level as a second tag that identifies a reproduction period of the content.
- the first tag may have a same level as a third tag that is subject to a second tag, which identifies a reproduction period of the content, and that defines a plurality of media data to be reproduced in a predetermined reproduction period.
- the first tag may further include information regarding intervals between the plurality of still images.
- a method of transmitting media data including transmitting a file including information regarding a plurality of media data generated by encoding content so as to have different qualities, to a client; and transmitting at least one media data from among the plurality of media data to the client, in response to a request based on the transmitted file, received from the client, wherein the file comprises information regarding a plurality of still images corresponding to a plurality of chapters of the content.
- the transmitting of the at least one media data to the client may include transmitting the plurality of still images to the client, in response to the request based on the received file, received from the client; and transmitting the at least one media data, starting from a chapter selected by the client based on the plurality of still images.
- an apparatus which receives media data, the apparatus including an information receiving unit which receives a file including information regarding a plurality of media data generated by encoding content so as to have different qualities, from a server; and a media data receiving unit which receives at least one media data from among the plurality of media data, based on the received file, wherein the file comprises information regarding a plurality of still images corresponding to a plurality of chapters of the content.
- an apparatus which transmits media data
- the apparatus including an information transmitting unit which transmits a file including information regarding a plurality of media data generated by encoding content so as to have different qualities, to a client; and a media data transmitting unit which transmits at least one media data from among the plurality of media data to the client, in response to a request based on the transmitted file, received from the client, wherein the file comprises information regarding a plurality of still images corresponding to a plurality of chapters of the content.
- a non-transitory computer readable recording medium having stored thereon a computer readable program which when executed by a computer performs the method of receiving media data and/or the method of transmitting media data.
- FIG. 1 is a diagram of a streaming system according to an exemplary embodiment
- FIGS. 2A and 2B are flowcharts for describing streaming methods according to exemplary embodiments
- FIG. 3 is a schema of a file including information about content, according to an exemplary embodiment
- FIG. 4A illustrates information for defining a plurality of media data, according to an exemplary embodiment
- FIG. 4B illustrates information about a header of media data, according to an exemplary embodiment
- FIG. 4C illustrates information about at least one segment included in each one of a plurality of media data, according to an exemplary embodiment
- FIGS. 5A and 5B are flowcharts for describing streaming methods according to other exemplary embodiments.
- FIG. 6 is a schema of a file including information about content, according to another exemplary embodiment
- FIG. 7 illustrates information about content according to an exemplary embodiment
- FIGS. 8A and 8B are schemas of a media presentation description according to exemplary embodiments.
- FIGS. 9A , 9 B, 9 C, 9 D, 9 E, 9 F, 9 G and 9 H illustrate media presentation descriptions according to exemplary embodiments
- FIGS. 10A , 10 B and 10 C each illustrate a plurality of media data according to exemplary embodiments
- FIGS. 11A and 11B are flowcharts for describing streaming methods according to exemplary embodiments
- FIGS. 12A , 12 B and 12 C each illustrate a plurality of media data according to exemplary embodiments
- FIGS. 13A and 13B are flowcharts illustrating streaming methods according to exemplary embodiments
- FIGS. 14A through 14H illustrate media presentation descriptions according to other embodiments
- FIGS. 15A and 15B illustrate schemas of a chapter according to other embodiments
- FIG. 16 illustrates information regarding a chapter, according to an embodiment
- FIG. 17 is a diagram illustrates the structure of chaptering data, according to an embodiment
- FIGS. 18A and 18B are flowcharts illustrating streaming methods according to other embodiments.
- FIG. 19 is a block diagram of a media data transmitting apparatus that may be included in the server of FIG. 1 , according to an embodiment.
- FIG. 20 is a diagram of a media data receiving apparatus that may be included in the client of FIG. 1 , according to an embodiment.
- FIG. 1 is a diagram of a streaming system 100 according to an exemplary embodiment.
- the streaming system 100 includes an encoding device 110 , a server 120 , and a client 130 .
- the encoding device 110 generates a plurality of media data about one input content by encoding the input content to have a plurality of different qualities.
- a streaming environment may change when the server 120 streams media data to the client 130 . For example, a bandwidth of a network 140 for streaming may be changed, or a hardware source that may be used by the server 120 to transmit media data or by the client 130 to receive media data may be changed.
- the encoding device 110 encodes one content to have different qualities for adaptive streaming according to a fluidic streaming environment.
- One content may be encoded to have different qualities by adjusting a factor, such as a bit rate, a sampling frequency, resolution, or a frame rate.
- a factor such as a bit rate, a sampling frequency, resolution, or a frame rate.
- a plurality of media data in 500 Kbps, 1000 Kbps, and 2000 Kbps may be generated by encoding one image content in different resolutions.
- the plurality of media data in different qualities are transmitted to the server 120 , and at this time, information about the content and information about each media data may also be transmitted to the server 120 .
- the information about the content may include, but is not limited to, information about a title, a synopsis, a content identifier (ID), and a content uniform resource locator (URL) of the content as metadata of the content.
- the information about each media data may include a quality, a type, an ID, or the like of each media data, and will be described in detail with reference to FIGS. 4A , 4 B and 4 C.
- the client 130 receives at least one of the information about content and information about each media data, and requests the server 120 for at least one of the plurality of media data, based on the received at least one of the information about content and information about each media data.
- the client 130 estimates a streaming environment, and selects at least one of the plurality of media data based on the estimated streaming environment.
- the at least one media data that may maintain a suitable quality of service (QoS) in the estimated streaming environment may be selected.
- the client 130 may transmit a hypertext transfer protocol (HTTP) request requesting the server 120 to transmit the selected at least one media data.
- HTTP hypertext transfer protocol
- low quality media data may be requested from among a plurality of media data.
- the high quality media data may continue to be requested from among a plurality of media data.
- the client 130 may request the server 120 to transmit another media data while receiving a predetermined media data.
- the client 130 which requested and was receiving first media data that is of low quality in a deteriorated streaming environment, may request the server 120 to transmit second media data that is of a higher quality than the first media data as the streaming environment improves.
- a conventional streaming method when the server 120 and the client 130 sets a quality while initially setting a streaming channel, media data is continuously transmitted and received having the same quality.
- streaming that is adaptive to the streaming environment is possible since the client 130 is able to request the second media data again even while receiving the first media data about the same content.
- the client 130 may estimate a streaming environment by using any method of estimating a streaming environment based on the bandwidth of the network 140 or the hardware resource that may be used by the server 120 or the client 130 .
- the client 130 may estimate the streaming environment based on a time stamp and a bit error rate (BER) of received media data.
- the streaming environment may be determined to be deteriorated when media data is received slower than a reproduction speed by checking time stamps of the received media data.
- the streaming environment may be determined to be deteriorated when BERs of the received media data are increased.
- the server 120 transmits requested media data to the client 130 .
- the server 120 may transmit the requested media data to the client 130 as an HTTP response to the HTTP request.
- Each media data may include at least one of a plurality of segments generated by encoding content in different qualities and dividing the encoded content.
- each media data generated by encoding the content by the encoding device 110 may include at least one segment divided based on time.
- the server 120 transmits the content by dividing the content into the plurality of segments and respectively transmitting the plurality of segments, instead of encoding the content in one stream and continuously transmitting the content.
- the plurality of segments may be generated by dividing the content into predetermined time units, such as units of 10 or 20 seconds.
- the time that is the basis for dividing the content may be set based on a group of pictures (GOP).
- Media data corresponding to pictures of one or more GOPs may be set as one segment.
- the first media data may include at least one segment generated by encoding the content to have a first quality and dividing the encoded content based on time
- the second media data may include at least one segment generated by encoding the content to have a second quality and dividing the encoded content based on time.
- the adaptive streaming is possible by dividing each media data based on time. For example, when streaming starts, the server 120 transmits a segment corresponding to 0 to 20 seconds of the first media data that is of low quality. Then, when it is determined that the streaming environment is improved after 20 seconds and the client 130 requests media data that is of higher quality, the server 120 may transmit a segment corresponding to 20 to 40 seconds of the second media data that is of the higher quality. Since media data is divided into a plurality of segments based on time, segments of different media data may be transmitted according to a streaming environment, even during streaming.
- FIG. 2A is a flowchart for describing a streaming method according to an exemplary embodiment.
- the client 130 transmits a request to the server 120 to transmit information about predetermined content, in operation 210 .
- the client 130 requests the server 120 to transmit information about the selected content.
- the client 130 may transmit an HTTP request requesting the server 120 to transmit information about predetermined content.
- the server 120 Upon receiving the request from the client 130 , the server 120 transmits the information about the predetermined content to the client 130 .
- the server 120 may transmit the information about the predetermined content as an HTTP response to the HTTP request to the client 130 .
- the information about the predetermined content may be a content access descriptor (CAD) according to an open IPTV forum (OIPF) standard.
- CAD content access descriptor
- OIPF open IPTV forum
- FIG. 3 is a schema of a file including information about content, according to an exemplary embodiment.
- the file may be a CAD, and may be an eXtensible Markup Language (XML) file.
- XML eXtensible Markup Language
- a tag and an attribute are separately described, but it is understood that according to an exemplary embodiment an item defined by a tag can be defined by an attribute or an item defined by an attribute can be defined by a tag.
- the information about content may include “Title”, “Synopsis”, “OriginSite”, and “ContentURL” tags.
- conventional information (specifically, CAD according to OIPF) about content does not include information about a plurality of media data generated by encoding the content to have different qualities.
- the information about content includes information about a plurality of media data generated by encoding one content to have different qualities, and corresponds to “Tracks”, “RefData”, and “Fragments” tags in FIG. 3 .
- FIG. 4A illustrates information for defining a plurality of media data, according to an exemplary embodiment.
- a “Tracks” tag is information for classifying a plurality of media data generated by encoding content to have different qualities.
- the “Tracks” tag includes an “ID” attribute, a “Type” attribute, and a “BitRate” attribute assigned to each media data.
- the “ID” attribute defines identifiers sequentially given to the plurality of media data, and the “Type” attribute defines whether media data corresponds to audio data, video data, video/audio data, or subtitle data.
- the “Type” attribute is “Packed”, the media data is video/audio data, and when the “Type” attribute is “Video”, the media data is video data.
- the “BitRate” attribute defines a bit rate used to encode the media data.
- FIG. 4B illustrates information about a header of media data, according to an exemplary embodiment.
- a “RefData” tag includes a “Type” attribute and an “ID” attribute.
- the “Type” attribute defines a media format of a header. For example, when the “Type” attribute is “HEAD-TS”, the header is a header of a transport stream format.
- the “ID” attribute defines a media data of a header. When the “ID” attribute is “1”, the header is a header of media data having a media data ID of “1”.
- the “RefData” tag includes information pointing to a header, and an “URL” tag defines a location of a header, i.e., a URL of a header.
- the “RefData” tag is a selective element.
- the “RefData” tag is included in information about content only when a header is separated from media data and exists as a separate file, and may not be included in the information about content when the header is combined with the media data.
- FIG. 4C illustrates information about at least one segment included in each of a plurality of media data, according to an exemplary embodiment.
- a “Fragment” tag which is a sub tag of a “Fragments” tag, includes the information about at least one segment included in each of the plurality of media data.
- the “Fragments” tag includes a “NextFragmentsXMLURL” attribute.
- the “Fragments” tag defines the information about the following content as the “NextFragmentsXMLURL” attribute.
- URLs of the plurality of media data with respect to the following content may be defined as the “NextFragmentsXMLURL” attribute.
- the “Fragment” tag includes information about at least one segment of current content.
- URL information of “slice1-1.as” constituting a first segment generated by encoding content in a first quality as first media data is defined by a “URL” tag, and an ID of a corresponding header is defined by a “RefPointer” tag.
- a starting time of the first segment is defined by a “StartTime” attribute
- a duration time of each segment is defined by a “Duration” attribute.
- a quality of the first media data is defined by a “BitRate” attribute.
- the “Fragments” tag shows each media data including only one segment.
- one “Fragments” tag may include information about at least two segments.
- the client 130 requests the server 120 to transmit at least one of the plurality of media data, in operation 220 .
- the plurality of media data are generated by encoding one content to have different qualities.
- the client 130 selects at least one media data encoded to have a quality suitable for a streaming environment from among the plurality of media data, and requests the server 120 for the selected at least one media data.
- the client 130 may transmit an HTTP request to the server 120 based on information about the plurality of media data, which is included in the information about the content.
- the information about the content may include a “Fragments” tag. Accordingly, the client 130 requests the server 120 to transmit selected media data based on URL information included in the “Fragments” tag.
- the server 120 transmits the media data according to the request of the client 130 .
- the server 120 may transmit at least one segment of the requested media data to the client 130 .
- the server 120 may transmit media data requested as an HTTP response with respect to an HTTP request to the client 130 .
- FIG. 2B is a flowchart for describing a streaming method according to another exemplary embodiment.
- FIG. 2B illustrates the streaming method when a header exists as a separate file from media data.
- the client 130 requests the server 120 to transmit information about predetermined content, in operation 212 , and the server 120 transmits the information about content.
- Operation 212 corresponds to operation 210 of FIG. 2A .
- the information about content including the “RefData” tag described above with reference to FIG. 4B is received.
- the client 130 requests a header of selected media data from among a plurality of media data, based on the information about content received in operation 212 .
- At least one media data suitable for a streaming environment is selected from among the plurality of media data based on the information about content received in operation 212 , and a header of the selected at least one media data is requested.
- the header of the selected at least one media data is requested by referring to the “RefData” tag included in the information about content received in operation 212 .
- the server 120 transmits the requested header to the client 130 .
- a header file may be transmitted to the client 130 , and may be an XML file.
- the client 130 requests the server 120 to transmit selected media data based on the information about content received in operation 212 and the header received in operation 222 .
- the client 130 requests the server 120 to transmit at least one segment generated by dividing media data based on time, and the server 120 transmits the requested at least one segment to the client 130 .
- FIG. 5A is a flowchart for describing a streaming method according to another exemplary embodiment.
- the client 130 requests the server 120 to transmit information about predetermined content, in operation 510 , and the server 120 transmits the information about content.
- the client 130 transmits an HTTP request for requesting the server 120 to transmit the information about content, and receives the information about content as an HTTP response to the HTTP request.
- the information about content may be an XML file.
- the information about content received by the client 130 in operation 510 is different from the information about content received by client 130 in operation 210 of FIG. 2 , and the difference will now be described with reference to FIGS. 6 and 7 .
- FIG. 6 is a schema of a file including information about content, according to another exemplary embodiment.
- the information about content according to the present exemplary embodiment may include “Title”, “Synopsis”, “OriginSite”, and “ContentURL” tags like FIG. 3 .
- the information about content includes the information about the plurality of media data by including the “Tracks”, “RefData”, and “Fragments” tags
- the information about content instead of including the information about the plurality of media data, the information about content only defines a URL of a file (hereinafter, referred to as a “media presentation description”) including the information about the plurality of media data.
- the “ContentURL” tag may define the URL of the media presentation description.
- Compatibility with various media data formats may be maintained while performing streaming that is adaptive to a streaming environment by inserting the URL of the media presentation description into the information about content as shown in FIG. 6 , without largely changing conventional schema of the file containing the information about content.
- the information about content may only include information related to the streaming method, and not include the information about the plurality of media data.
- the “ContentURL” tag may include a “MediaFormat” attribute defining a format of media data used during streaming, and a “MIMEType” attribute defining a type of media data.
- the “ContentURL” tag may include a “TransferType” attribute defining a service to which streaming of content is related.
- the “TransferType” attribute may define whether the streaming of content is related to a Content on Delivery (CoD) service, a live service, an adaptive streaming live service, or an adaptive streaming CoD service.
- CoD Content on Delivery
- FIG. 7 illustrates information about content according to an exemplary embodiment.
- FIG. 7 may be a CAD according to the OIPF standard.
- the information about content generated according to the schema of FIG. 6 may define a URL of a media presentation description in a “ContentURL” tag. http://asexample.com/vod/movies/18888/Meta/MainMeta.xml is the URL of the media presentation description. Also, as described with reference to FIG. 6 , the “MediaFormat” attribute, the “MIMEType” attribute, and the “TransferType” attribute may be defined in the “ContentURL” tag.
- the client 130 requests the server 120 for the information about the plurality of media data, based on the information about content received in operation 510 .
- the client 130 may request a media presentation description to the server 120 through an HTTP request, and may receive the media presentation description as an HTTP response.
- the information about content received by the client 130 from the server 120 in operation 510 may include the URL of the media presentation description as described with reference to FIGS. 6 and 7 , and thus the client 130 requests and receives the media presentation description from the server 120 by referring to the “ContentURL” tag of the information about content.
- the media presentation description will now be described in detail with reference to FIGS. 8A and 8B , and FIGS. 9A , 9 B, 9 C, 9 D, 9 E, 9 F, 9 G and 9 H.
- FIGS. 8A and 8B are schemas of a media presentation description according to exemplary embodiments.
- the media presentation description may comply with the OIPF standard.
- the media presentation description includes a template tag about URLs of a plurality of media data, a tag for defining a location of a header, a tag for defining to which service the streaming is related to, a tag for defining a container format of media data, and a tag for defining the plurality of media data.
- An “urlTemplate” tag defines a common portion of the URLs of the plurality of media data. For example, if “http://example.com/vod/movie/18888/Track/ ⁇ TrackID ⁇ /Segments/ ⁇ SegmentI D ⁇ ” is a URL template, a URL of media data may be defined by respectively substituting an ID of each media data and an ID of at least one segment included in each media data for “TrackID” and “SegmentID”.
- a “headerUrl” tag corresponds to the “RefData” tag described with reference to FIG. 4B .
- the “headerUrl” tag defines URLs of headers of the plurality of media data.
- An “is Live” tag defines a service related to streaming. For example, when the “is Live” tag is defined as “Live”, the streaming is related to a live service, and when the “is Live” tag is defined as “CoD”, the streaming is related to a CoD service.
- a “contentType” tag defines a container format of media data used during streaming.
- the “contentType” tag may indicate whether the container format is an MP4 format or an MPEG2-TS format.
- the container format is an MP4 format or an MPEG2-TS format herein, however, though it is understood that according to an exemplary embodiment the container format is not limited thereto, and any container format for transmitting media data may be used.
- the “contentType” tag may define that the container format complies with an MPEG Media Transport (MMT) standard.
- MMT MPEG Media Transport
- a “Stream” tag is generated for each media data and defines each media data.
- the “Stream” tag includes a “streamName” attribute, a “type” attribute, a “bitrate” attribute, a “startTime” attribute, a “firstIntervalNum” attribute, a “duration” attribute, and an “intervalCount” attribute.
- the “streamName” attribute defines a name of media data, and may be an ID of media data.
- the “type” attribute defines a type of media data, wherein it is defined whether the media data is audio data, video data, or audio/video data. When media data only includes data about an I-frame for a trick play, such information may be defined in the “type” attribute.
- the “bitrate” attribute defines a bit rate of media data
- the “startTime” attribute defines a time stamp for specifying a starting time of media data
- the “firstIntervalNum” attribute defines a number of a segment that initially starts.
- the “duration” attribute defines a duration time of a segment included in media data
- the “intervalCount” attribute defines a total number of at least one segment included in media data
- the “Segment” tag is a sub tag of the “Stream” tag, and as described above, when media data includes at least one segment generated by encoding content in a predetermined quality and dividing the encoded content based on time, each of the at least one segment is defined.
- the “IntNum” attribute defines a number of a segment
- the “StartTime” tag defines a starting time of a corresponding segment.
- the “Duration” tag defines a duration time of a corresponding segment
- the “url” defines a URL of a corresponding segment.
- the “Segment” tag is a selective tag, and may not be included in the media presentation description if the information about at least one segment included in the media data can be inferred from other attributes of the “Stream” tag. In other words, when content of the “Segment” tag can be inferred from the “startTime”, “firstIntervalNum”, “duration”, and “intervalCount” attributes defined in the “Stream” tag, the “Segment” tag may not be included in the media presentation description.
- a “url” attribute of the “Segment” tag may not be required if a predetermined template is defined in the “urlTemplate”, and the URLs of segments are inferred by substituting each ID of the plurality of media data and an ID of at least one segment included in each media data with the defined predetermined template.
- attributes of the “Segment” tag are separately defined for each segment, if the attributes of the “Segment” tag cannot be inferred from other attributes of the “Stream” tag.
- the attributes of the “Segment” tag may not be inferred if duration times of segments are different.
- duration times are different, the duration times of segments included in media data cannot be inferred from the attributes of the “Stream” tag, and thus the duration times of the segments may be each set by using a “duration” attribute of the “Segment” tag.
- the duration times of the segments are different, starting times of continuous segments are also different.
- a starting time of each segment may be defined by a “startTime” attribute.
- the duration times and/or starting times may be defined by using a sub tag of the “Segment” tag, instead of using the “duration” attribute and the “startTime” attribute of the “Segment” tag.
- duration time may be defined based on a difference between duration times of continuous segments.
- An upper tag may define a default duration time
- the “Url” tag constituting the sub tag may define only a difference between the default duration time and an actual duration time for each segment.
- the media presentation description may further include a “nextManifestURL” tag.
- a URL of a media presentation description of the following content to be streamed after current content may be defined by the “nextManifestURL” tag.
- FIGS. 9A , 9 B, 9 C, 9 D, 9 E, 9 F, 9 G and 9 H illustrate media presentation descriptions according to exemplary embodiments.
- the media presentation description includes a “URLTemplate” tag, a “RefDataURL” tag, and a plurality of tags respectively defining a plurality of media data.
- the “URLTemplate” tag and the “RefDataURL” tag of FIG. 9A respectively correspond to the “urlTemplate” tag and the “RefDataURL” tag of FIGS. 8A and 8B .
- An “ID” attribute, a “Type” attribute, a “BitRate” attribute, a “StartTime” attribute, a “SegmentDuration” attribute, a “SegmentStartID” attribute, and a “SegmentCount” attribute of FIG. 9A respectively correspond to the “streamName” attribute, the “type” attribute, the “bitrate” attribute, the “startTime” attribute, the “duration” attribute of the “Stream” tag, the “firstIntervalNum” attribute of the “Stream” tag, and the “intervalCount” attribute of FIGS. 8A and 8B .
- the media presentation description of FIG. 9A includes information about three video data generated by encoding content to have different qualities, information about one audio data, and information about media data generated by encoding only I-frames for a trick play.
- the media presentation description according to an exemplary embodiment further includes a “NextAdaptiveControlURL” tag.
- the “NextAdaptiveControlURL” tag corresponds to the “nextManifestURL” tag of FIG. 8B . Accordingly, a URL of a media presentation description of following content to be reproduced after current content may be defined by the “NextAdaptiveControlURL” tag.
- FIG. 9C shows a media presentation description of the following content, when the URL of the media presentation description of the following content to be reproduced after the current content is defined by the “NextAdaptiveControlURL” tag of FIG. 9B . Comparing the media presentation descriptions of FIGS. 9B and 9C , a “StartTime” attribute is different from the media presentation description of the current content of FIG. 9B , since the media presentation description of FIG. 9C is for the following content.
- FIGS. 9D and 9E illustrate media presentation descriptions for selectively controlling high quality video reproduction that a user want to perform.
- FIG. 9D illustrates the media presentation description when a plurality of media data are generated by encoding one content to have 5 different qualities.
- the media presentation descriptions of FIGS. 9D and 9E are different in a tag including information about video encoded to have high quality, i.e., a “StartTime” attribute and a “SegmentCount” attribute of media data having an “ID” attribute of “5”.
- the server 120 selectively transmits the media presentation description of FIG. 9D or the media presentation description of FIG. 9E according to a user rating of the client 130 .
- the media presentation description of FIG. 9D is transmitted so that high quality video is freely reproduced
- the media presentation description of FIG. 9E is transmitted so that segments defined by the “SegmentCount” attribute are reproduced from a time defined by the “StartTime” attribute in high quality video.
- FIG. 9F illustrates a media presentation description when an advertisement is inserted into content.
- the media presentation description may include information about advertisement content and main content, which have different “StartTime” attributes.
- the media presentation description may include information about advertisement content, which is reproduced from “00:00:00” to “00:02:00” at a bit rate of “500000”, and information about main content, which is reproduced from “00:02:00” at bit rates of “1000000”, “2000000”, “3000000”, or “4000000”.
- 9F may be transmitted from the server 120 to the client 130 if the server 120 provides the advertisement content to the client 130 by encoding the advertisement content to have one bit rate, and provides the main content, which has a different “StartTime” attribute from the advertisement content, to the client 130 by encoding the main content in four different bit rates.
- FIG. 9G illustrates a media presentation description including information about advertisement content, according to an exemplary embodiment.
- a server for providing main content and a server for providing advertisement content may be different.
- the media presentation description of FIG. 9G may include a URL of the advertisement content.
- the media presentation description may include the URL of the advertisement content that is encoded to have one quality.
- FIG. 9H illustrates a media presentation description including language and subtitle information, according to an exemplary embodiment.
- audio data may include information about multiple languages.
- the media presentation description may include information about audio data of multiple languages, wherein an “ID” attribute is “4” or “5”, or information about subtitles of multiple languages, wherein the “ID” attribute is “6” or “7”.
- the audio data and the subtitle may be changed to audio data and a subtitle of another language during streaming.
- the client 130 requests the server 120 to transmit at least one of the plurality of media data, in operation 530 .
- the client 130 selects at least one media data that is encoded to have a quality suitable for the streaming environment by referring to the information about the plurality of media data, and requests the server 120 for the selected at least one media data.
- the client 130 may transmit an HTTP request for requesting the server 120 to transmit a predetermined media data.
- the server 120 transmits the media data according to the request of the client 130 .
- the server may transmit at least one segment generated by encoding content to have a predetermined quality and dividing the encoded content based on time, to the client 130 .
- the server 120 may transmit the requested media data to the client 130 as an HTTP response to the HTTP request.
- FIG. 5B is a flowchart for describing a streaming method according to another exemplary embodiment.
- the client 130 requests the server 120 to transmit information about predetermined content, in operation 512 , and receives the information about predetermined content from the server 120 .
- the client 130 may transmit an HTTP request for requesting the server 120 to transmit the information about predetermined content, and receive the information about predetermined content as an HTTP response to the HTTP request.
- the information about predetermined content may be included in an XML file.
- the client 130 requests the server 120 to transmit information about a plurality of media data based on the information about predetermined content received in operation 512 .
- the client 130 may request the server 120 for a media presentation description through the HTTP request, and receive the media presentation description as the HTTP response.
- the client 130 requests a header of media data selected based on the information about a plurality of media data received in operation 522 .
- At least one media data that is suitable to a streaming environment is selected from among the plurality of media data based on the information about the plurality of media data received in operation 522 , and a header of the selected at least one media data is requested.
- the header of the selected at least one media data is requested by referring to the information about the plurality of media data received in operation 522 .
- the server 120 transmits a file of the header of the selected at least one media data to the client 130 in response to the request of the client 130 .
- the client 130 requests the server 120 to transmit selected media data based on the information about the plurality of media data received in operation 522 , and the header received in operation 532 .
- the client 130 requests the server 120 to transmit at least one segment generated by encoding content to have a predetermined quality and dividing the encoded content based on time, and the server 120 transmits the requested at least one segment to the client 130 .
- FIGS. 10A , 10 B and 10 C each illustrate a plurality of media data according to exemplary embodiments.
- FIGS. 10A , 10 B and 10 C each illustrate the plurality of media data included in the server 120 to perform the streaming methods according to FIGS. 5A and 5B .
- the server 120 may include a plurality of media data 1010 through 1030 generated by encoding one content to have a plurality of different qualities, for streaming that is adaptive to a streaming environment.
- “Track1” through “TrackN” denote the plurality of media data 1010 through 1030 .
- each of the plurality of media data 1010 through 1030 may include at least one segment generated by dividing each of the plurality of media data 1010 through 1030 based on time.
- the server 120 may include information 1040 required for the client 130 to access the plurality of media data 1010 through 1030 .
- the server 120 may include a “CadMeta.xml” file as information about content, a “MainMeta.xml” file as information about the plurality of media data 1010 through 1030 , and a “Head1.ref” file, a “Head2.ref” file, etc. as header files of the plurality of media data 1010 through 1030 .
- the “Head1.ref” file may be a header file of the “Track1”
- the “Head2.ref” file may be a header file of the “Track2”.
- the “CadMeta.xml” file may be a CAD file according to the OIPF standard, and the “MainMeta.xml” file may be the media presentation description described above. Also, the “Head1.ref” and “Head2.ref” files are selective elements, and may not exist when headers are included in the plurality of media data 1010 through 1030 .
- information 1042 required for the client 130 to access the plurality of media data 1010 through 1030 may further include a “NextMeta.xml” file.
- the “NextMeta.xml” file may be a media presentation description of a following content to be reproduced after current content.
- the media presentation description of the current content i.e., the “MainMeta.xml” file, includes the URL of the media presentation description of the following content, and thus the client 130 may access the “NextMeta.xml” file based on the “MainMeta.xml” file.
- header files of the plurality of media data 1010 through 1030 may exist in one header file 1050 .
- the header files may exist as one header file 1050 and may be included in information 1044 required to access the plurality of media data 1010 through 1030 .
- each of the header files of the plurality of media data 1010 through 1030 may be the header file 1050 including a program association table (PAT) and a program map table (PMT). At least one of the PAT and the PMT may be separated from the plurality of media data 1010 through 1030 to prepare the header file 1050 , and the media presentation description may include information pointing to the header file 1050 .
- the information pointing to the header file 1050 may be URL information of the header file 1050 or information for specifying a packet including the header file 1050 in a MPEG-2 transport stream (TS).
- the header file 1050 including at least one of the PAT and the PMT is an initialization segment, and may be transmitted to the client 130 before segments including payload data, so as to initiate reproduction of the plurality of media data 1010 through 1030 .
- the client 130 may obtain the information pointing to the header file 1050 by referring to the media presentation description, and may request the header file 1050 based on the information pointing the header file 1050 .
- the client 130 may obtain the information pointing to the header file 1050 by referring to the media presentation description, and may request the header file 1050 based on the information pointing the header file 1050 .
- at least one of the plurality of media data 1010 through 1030 is selected based on at least one of the PAT and the PMT included in the header file 1050 , and the selected at least one media data is requested from the server 120 .
- the PAT and the PMT may be separated as the header file 1050 or included in the plurality of media data 1010 through 1030 , but may include an entire list of elementary streams included in the plurality of media data 1010 through 1030 regardless of locations of the PAT and the PMT.
- packet IDs (PIDs) defined in the PAT and the PMT are different according to elementary streams. Accordingly, PIDs assigned to each of the plurality of media data 1010 through 1030 may be different. Alternatively, according to another exemplary embodiment, since the plurality of media data 1010 through 1030 , generated by encoding one content to have different qualities, are elementary streams of the same content, the same PID may be employed.
- each of segments included in the plurality of media data 1010 through 1030 may include at least one continuous packetized elementary stream (PES).
- PES packetized elementary stream
- one PES may be included in only one segment from among the segments. In other words, one PES may not be included in two different segments.
- presentation time stamps (PTSs) and/or decoding time stamps (DTSs) included in PESs of the plurality of media data may be aligned according to reproduction times.
- PTSs presentation time stamps
- DTSs decoding time stamps
- the PTSs and/or the DTSs may be continuously aligned so that the first and second media data are continuously reproduced.
- the PTS and/or the DTS of the last PES before the changing of the media data, and the PTS and/or the DTS of the first PES after the changing of the media data may be continuously set.
- the PTS and/or the DTS define a time stamp of video data. Accordingly, time stamps of the plurality of media data with respect to video data are aligned according to the reproduction times of the plurality of media data as described above. Such alignment of the time stamps based on the reproduction times may be equally applied to audio data. In other words, like the time stamps of the plurality of media data with respect to the video data, time stamps of the pieces media data with respect to the audio data may also be aligned according to the reproduction times for adaptive streaming.
- FIG. 11A is a flowchart for describing a streaming method according to another exemplary embodiment.
- the client 130 requests information about a plurality of media data to the server 120 , in operation 1110 .
- the client 130 may request a media presentation description from the server 120 via an HTTP request, and may receive the media presentation description as an HTTP response.
- the client 130 requests the server 120 for and receives the information about the plurality of media data generated by encoding one content to have a plurality of different qualities, so as to perform streaming that is adaptive to a streaming environment.
- the streaming method of FIG. 11A is different from the streaming method of FIG. 5A as the information about the plurality of media data is requested and received without requesting and receiving information about content.
- the client 130 requests the server 120 to transmit at least one of the plurality of media data.
- the client 130 selects and requests at least one media data that is encoded to have a quality suitable for the streaming environment by referring to the information about the plurality of media data, and receives the requested at least one media data from the server 120 .
- FIG. 11B is a flowchart for describing a streaming method according to another exemplary embodiment.
- the client 130 requests the server 120 to transmit information about a plurality of media data and receives the information about the plurality of media data from the server 120 in response to the request, in operation 1112 .
- the client 130 may request the server 120 for a media presentation description through an HTTP request, and receive the media presentation description as an HTTP response.
- the client 130 requests a header of selected media data based on the information about the plurality of media data received in operation 1112 .
- the client 130 requests the header of media data selected according to a streaming environment by referring to the information about the plurality of media data received in operation 1112 .
- the server 120 transmits a file including the header of the selected media data to the client 130 .
- the client 130 requests the server 120 to transmit the media data selected based on the information about the plurality of media data received in operation 1112 , and the header received in operation 1122 .
- the client 130 requests the server 120 to transmit at least one segment generated by encoding content in a predetermined quality and dividing the encoded content based on time, and the server 120 transmits the requested at least one segment to the client 130 .
- FIGS. 12A , 12 B and 12 C each illustrate a plurality of media data according to other exemplary embodiments.
- FIGS. 12A and 12B each illustrate the plurality of media data included in the server 120 , which are used to perform the streaming methods of FIGS. 11A and 11B .
- the server 120 may include the plurality of media data 1010 through 1030 generated by encoding one content to have the plurality of different qualities for streaming that is adaptive to a streaming environment, as shown in FIG. 10A .
- the plurality of media data 1010 through 1030 of FIG. 12A is different from the plurality of media data 1010 through 1030 of FIG. 10A in information 1240 required for the client 130 to access the plurality of media data 1010 through 1030 , wherein the server 120 only includes information about the plurality of media data 1010 through 1030 and not information about content, unlike the exemplary embodiment of FIG. 10A .
- the client 130 may receive the information about content from another entity instead of the server 120 , and access the plurality of media data 1010 through 1030 included in the server 120 based on the received information about content.
- information 1242 required for the client 130 to access the plurality of media data 1010 through 1030 may be prepared by further including a “NextMeta.xml” file to the information 1240 of FIG. 12A .
- the header files of the plurality of media data 1010 through 1030 may exist in one header file 1250 .
- the header files do not exist for each of the plurality of media data 1010 through 1030 , but may be included in information 1244 required to access the plurality of media data 1010 through 1030 , as one header file 1250 .
- the header file 1250 corresponds to the header file 1050 of FIG. 10C .
- FIG. 13A is a flowchart illustrating a streaming method according to another embodiment.
- a client 130 requests a server 120 to provide information regarding desired content, and receives the information regarding the desired content from the server 120 .
- the client 130 may transmit an HTTP request for the information regarding the desired content to the server 120 and receive the information regarding the desired content from the server 120 according to the HTTP response.
- An XML file containing the information regarding the desired content may be received.
- the information regarding the desired content may include the URL of a media presentation description as described above in detail with reference to FIGS. 6 and 7 .
- the client 130 requests the server 120 to provide information regarding a plurality of media data, based on the information regarding the desired content received in operation 1310 .
- the client 130 may transmit an HTTP request for a media presentation description to the server 120 and receive the media presentation description from the server 120 according to the HTTP response.
- the media presentation description that the client 130 receives in operation 1320 may be one of the media presentation descriptions described above in detail with reference to FIGS. 8A , 8 B, and 9 A to 9 G and may contain information regarding a plurality of chapters of the content.
- the plurality of chapters of the content will now be described in detail with reference to FIGS. 14A to 14H .
- FIGS. 14A through 14H illustrate media presentation descriptions according to other embodiments.
- a media presentation description includes “Period” tags that are subject to a “MPD” tag (an uppermost tag) and identify reproduction periods of content that is being streamed, respectively.
- Each of the “Period” tags includes an “Representation” tag having information regarding a plurality of media data that are to be streamed in a corresponding reproduction period.
- each of the “Representation” tags may include a “SegmenInfo” tag having information regarding a plurality of segments divided from one media data according to time.
- the media presentation description further includes a “Chaptering” tag having information regarding a plurality of chapters of the content that is being streamed.
- the content may include the plurality of chapters classified according to a scene, a story, or time.
- the information regarding the plurality of chapters is defined with the “Chaptering” tag.
- Information regarding at least one of a still image and texts related to a particular chapter may be information regarding the chapter.
- the “Chaptering” tag may include at least one attribute defining a still image corresponding to the plurality of chapters.
- the format, URL, and time intervals of at least one still image are defined with a “mimeType” attribute, a “URL” attribute, and an “ImageInterval” attribute.
- the resolution of the at least one still image is defined with a “height” attribute and a “width” attribute.
- the “height” attribute and the “width” attribute define the horizontal and vertical sizes of the at least one still image, i.e., the resolution of the at least one still image.
- a compression type of the at least one still image is defined with a “compressiontype” attribute.
- the “URL” attribute of the “Chaptering” tag may be a template, similar to the “URL” attribute of the media presentation description described above.
- the template is a common part of the URLs of a plurality of still images and may be defined with the “URL” attribute.
- the name of a tag including information a plurality of chapters of content may be the same as that of a tag defining a plurality of media data.
- the tag defining a plurality of media data i.e., a “Representation” tag
- each of “Period” tags defining reproduction periods, respectively may include a “Representation” tag defining media data in a corresponding reproduction period, and a “Representation” tag defining a plurality of chapters in the corresponding reproduction period.
- a first “Representation” tag is used to define media data, e.g., video data
- a second “Representation” tag is used to define a plurality of chapters.
- the second “Representation” tag defines the “mimeType” attribute, the “width” attribute, the “height” attribute, and the “ImageInterval” attribute described above with reference to FIG. 14A so as to define a plurality of still images corresponding to the plurality of chapters.
- each of the “Representation” tags may include the “SegmentInfo” tag that is a lower tag defining a plurality of segments of the media data.
- a “SegmentInfo” of the “Representation” tag of FIG. 14B which defines the plurality of chapters, may define a plurality of segments divided from a plurality of still images according to a predetermined criterion. The plurality of still images may be divided into a plurality of segments according to data size or time, and the plurality of segments may be defined.
- each of the “SegmentInfo” tags defining the plurality of segments, respectively may include “Url” tags subject thereto, and each of the “URL” tags may define the URL of a corresponding still image.
- FIG. 14C illustrates a case where a “Representation” tag defining a plurality of chapters does not include the “imageInterval” attribute.
- the plurality of chapters may be classified according a scene, or a story other than time. In this case, time intervals between still images may not be uniform.
- the “Representation” tag may not include the “imageInterval” attribute, and may define an “ImagePresentationTime” attribute in an “Url” tag included in a “SegmentInfo” tag subject to the “Representation” tag.
- the “ImagePresentationTime” attribute defines time corresponding to a still image.
- FIG. 14D illustrates a case where a plurality of still images corresponding to a plurality of chapters and time information corresponding to the plurality of still images are included in one file.
- a “chaptering.mp4” file includes not only a plurality of still images corresponding to a plurality of chapters but also time information of each of the still images generated.
- the “chaptering.mp4” file may have a structure as will be later described with reference to FIG. 17 or may be generated in an ISO Base Media File Format (ISOBMFF).
- ISOBMFF ISO Base Media File Format
- a language based on which the “chaptering.mp4” file is generated is defined with a “lang” attribute, and a method of reproducing information regarding the plurality of chapters based on the “chaptring.mp4” file is defined with a “contentviewpoint” attribute. If the “contentviewpoint” attribute is defined as “navigation”, then a plurality of still images included in the “chaptering.mp4” file are reproduced at a predetermined speed so that a user may select a still image corresponding to a desired point of time from among the plurality of still images.
- the plurality of still images included in the “chaptering.mp4” file may be displayed in a scrolling manner so that a user may select a still image among the plurality of still images that are scrolled.
- a “mimeType” attribute defines the format of the chaptering.mp4′′ file including the plurality of still images. If the format of the “chaptering.mp4” file is “mp4”, then the “mimeType” attribute is defined as “jpeg/mp4” since the “chaptering.mp4” file includes the plurality of still image.
- FIG. 14E illustrates a case where a plurality of files are generated, including information regarding a plurality of chapters, according to an embodiment.
- Location information of the plurality of files is defined with a “sourceURL” attribute included in a “Url” tag.
- one media data may be divided into a plurality of segments according to time.
- a file containing information regarding chapters corresponding to the plurality of segments may be as illustrated in FIG. 14E .
- still images belonging to a plurality of chapters included in a first segment may be included in a “seg-1.mp4” file
- still images belonging to a plurality of chapters included in a second segment reproduced after the first segment may be included in a “seg-2.mp4” file.
- a “mimeType” attribute and a “contentviewpoint” attribute are as described above with reference to FIG. 14D .
- FIG. 14F illustrates a case where times corresponding to the plurality of files of FIG. 14E , respectively, are specified, according to an embodiment.
- the times corresponding to the files that include information regarding a plurality of chapters, respectively, are defined with an “imagePresentationTime” attribute.
- chapter information regarding media data from “00:00:00” to “00:20:00” is included in a “seg-1.mp4” file
- chapter information regarding media data from “00:20:00” to “00:40:00” is included in a “seg-2.mp4” file.
- the “imagePresentationTime” attribute may be used to define the starting times of the files, respectively, as illustrated in FIG. 14F .
- FIG. 14G illustrates a case where information regarding a plurality of chapters is included in one file.
- a “Representation” tag defining a plurality of media data is used to define a plurality of chapters, instead of a separate tag representing chapter information.
- the information regarding the plurality of chapters may be completely included in one file and the file may be defined using the “Representation” tag.
- FIG. 14H illustrates a case where each of the “Url” tags of FIG. 14C includes attributes defining a language, a title, and a description regarding a corresponding chapter, according to an embodiment.
- the title and description of a still image corresponding to each of a plurality of chapters are defined with a “title” attribute and a “description” attribute, respectively.
- the “title” attribute and the “description” attribute of each language defined by a “lang” attribute may be defined.
- a “contentviewpoint” attribute is defined as ‘chapter’ unlike in FIGS. 14D to 14G , then still images corresponding to the plurality of chapters are displayed in a thumbnail manner and a user may select one of the displayed still images.
- FIGS. 15A and 15B illustrate schemas of a chapter according to exemplary embodiments.
- FIG. 16 illustrates information regarding a chapter according to the schemas of FIGS. 15A and 15B , according to an embodiment.
- information regarding a plurality of chapters included in a media presentation description may be produced according to the schemas illustrated in FIGS. 15A and 15B .
- a plurality of chapters of content may be defined with a “ChapterItems” tag and a “ChapterItem” tag included in a “ChapterInfo” tag.
- the “ChapterItem” tag defines a plurality of still images corresponding to the plurality of chapters.
- An identifier and time corresponding to each of the still images are defined with an “id” attribute and a “time” attribute, respectively.
- the title and description of each of the chapters are defined as a “title” tag and a “Description” tag which are lower tags, respectively.
- a brief description of each of the chapter is defined with a “Tag” tag.
- the “title” tag, the “Description” tag, and the “Tag” tag are defined in a string, and the total number of strings is not limited.
- a “lang” attribute defines a language used in each of the “title”, “Tag”, and “Description” tags. Referring to FIG.
- the “lang” attribute may be subject to each of the “title”, “Tag”, and “Description” tags or may be on a same level as the “title”, “Tag”, and “Description” tags. If the same language is used in the “title”, “Tag”, and “Description” and the tags are the same, then the “lang” attribute does not need to be subject to the “title”, “Tag”, and “Description” tags, and may on the same level as the “title”, “Tag”, and “Description” tags and define a language used in “title”, “Tag”, and “Description” tags.
- the “ChapterItems” tag includes a plurality of “ChapterItem” tags, and define the resolutions of the still images by using an “imgWidth” attribute and an “imgHeight” attribute.
- a common part of the URLS of the still images is defined with a “ThumbnailImgUrlTemplate” attribute.
- the URL of a still image may be determined by using the identifier of the still image defined in the “id” attribute of the “ChapterItem” tag, instead of a “$ID$” of a URL template defined with the “ThumbnailImgUrlTemplate” attribute.
- the media presentation description received in operation 1320 may include a tag defining a plurality of media data and a tag including information regarding a plurality of chapters as illustrated in FIG. 16 .
- an additional XML file produced according to the schemas of FIGS. 15A and 15B may be transmitted or received separately from the media presentation description, in operation 1320 .
- the client 130 may request the server 120 to provide an XML file produced separately from the media presentation description to include the information regarding the plurality of chapters according to the schemas of FIGS. 15A and 15B , and the server 120 may transmit the XML file to the client 130 .
- the client 130 requests the server 120 provide chaptering data, and receives the chaptering data from the server 120 .
- the chaptering data may be data regarding still images corresponding to a plurality of chapters of content that is being streamed.
- the client 130 may transmit an HTTP request for the chaptering data to the server 120 , and receive the chaptering data as a HTTP response.
- the media presentation description received in operation 1320 includes the URLs of the still images corresponding to the plurality of chapters as described above.
- the client 130 requests the server 120 to provide the chaptering data based on the URLs, and receive the chaptering data as a reply to the request.
- the chaptering data may include data regarding the still images corresponding to the plurality of chapters of the content. The chaptering data will now be descried in detail with reference to FIG. 17 .
- FIG. 17 is a diagram illustrating the structure of chaptering data 1700 according to an embodiment.
- the chaptering data 1700 such as chaptering data received in operation 1330 , includes a header 1710 and a plurality of still image data 1720 .
- the header 1710 includes still image number information 1712 , still image time interval information 1714 , and still image data offset information 1716 and 1718 included in the chaptering data 1700 .
- the still image number information 1712 defines the total number of still images included in the chaptering data 1700 .
- the still image time interval information 1714 defines time intervals between the still images.
- the still image data offset information 1716 and 1718 define offsets for specifying still images 1722 and 724 from among the plurality of still image data 1720 , respectively.
- the first still image 1722 i.e., “Jpg 1”
- the second still image i.e., “Jpg 2”
- An absolute data interval between the start of the plurality of still image data 1720 and specified still image data may be defined with an offset.
- the client 130 receiving the chaptering data in operation 1330 requests the server 120 to transmit at least one media data from among the plurality of media data.
- the client 130 may select at least one media data encoded to have a quality sufficient for a current streaming environment from among the plurality of media data, based on the information regarding the plurality of media data, and then requests the server 120 to transmit the selected media data.
- the client 130 may transmit an HTTP request for predetermined media data to the server 120 .
- the server 120 transmits the at least one media data to the client 130 in response to the request.
- the server 120 may encode the content to have a predetermined quality, divides the encoded content into several segments according to time, and transmit at least one of the segments to the client 120 .
- the server 120 may transmit the predetermined media data to the client 130 as a HTTP response.
- a header of at least one media data selected adaptively to a streaming environment is first received and then the at least one media data may be received.
- the client 130 selects a particular chapter based on the chaptering data received in operation 1330 , at least one media data encoded to have a quality sufficient for the streaming environment is received, starting from the selected chapter. If the still images included in the chaptering data are displayed on a display device (not shown) of the client 130 and a user selects a particular chapter, then data streaming may be performed starting from the selected chapter. If a user of the client 130 selects a particular chapter based on the chaptering data during streaming of the content, the client 130 may receive at least one media data, starting from the selected chapter.
- FIG. 13B is a flowchart illustrating a streaming method according to another embodiment.
- operations 1312 and 1322 correspond to operations 1310 and 1320 of FIG. 13A , respectively.
- the client 130 requests the server 120 to provide information regarding content, and receives the information regarding the content, which includes the URL of a media presentation description, from the server 120 .
- the client 130 requests the server 120 provide a media presentation description including information regarding a plurality of chapters, based on the information regarding content received in operation 1312 , and then receives the media presentation description from the server 120 .
- the client 130 receives the chaptering data based on the information regarding the plurality of media data received in operation 1322 , i.e., the information regarding the plurality of chapters included in the media presentation description.
- the client 130 may request the server 120 to provide a header of the chaptering data, and receive the header of the chaptering data from the server 120 .
- the chaptering data 1700 may include the header 1710 and the plurality of still image data 1720 .
- the client 130 may request the server 120 to provide the header 1710 of the chaptering data 1700 , and receive the header 1710 from the server 120 . Since the header 1710 includes the still image number information 1712 , the still image time interval information 1714 , and the still image data offset information 1714 and 1716 , the client 130 may request and receive the plurality of still image data 1720 , based on the header 1710 , in operation 1342 .
- operation 1352 corresponds to operation 1340 of FIG. 13A .
- the client 130 requests the server 120 to transmit at least one media data from among the plurality of media data, and receives the at least one media data from the server 120 .
- the client 130 may receive at least one media data, starting from the selected chapter.
- FIG. 18A is a flowchart illustrating a streaming method according to another embodiment.
- the client 130 requests the server 120 to transmit information regarding a plurality of media data.
- the client 130 may transmit an HTTP request for a media presentation description to the server 120 , and receive the media presentation description from the server 120 as a HTTP response.
- the streaming method of FIG. 18A is different from the streaming method of FIG. 13A in that the information regarding the plurality of media data is requested and received without requesting and receiving information regarding content.
- the media presentation description received in operation 1810 may be the media presentation descriptions illustrated in FIGS. 14A to 14H .
- the client 130 requests the server 120 to transmit chaptering data, and receives the chaptering data from the server 120 .
- the chaptering data may be received based on the information regarding the plurality of chapters included in the media presentation description received in operation 1810 .
- the client 130 requests the server 120 to transmit at least one media data from among the plurality of media data.
- the client 130 may select at least one media data encoded to have a quality sufficient for a streaming environment from among the plurality of media data, based on the information regarding the plurality of media data, request the server 120 to transmit the at least one media data, and then receive the at least one media data from the server 120 . If a particular chapter is selected based on the chaptering data received in operation 1820 , at least one media data may be requested and received, starting from the selected chapter.
- a header of at least one media data selected adaptively to a streaming environment may first be received and the at least one media data may then be received.
- FIG. 18B is a flowchart illustrating a streaming method according to another embodiment.
- operation 1812 corresponds to operation 1810 of FIG. 18A .
- the client 130 requests the server 120 to transmit information regarding a plurality of media data.
- the client 130 may transmit an HTTP request for a media presentation description to the server 120 and receive the media presentation description from the server 120 as HTTP response.
- the streaming method of FIG. 18B is different from the streaming method of FIG. 13B in that the information regarding the plurality of media data is requested and received without requesting and receiving information regarding content.
- the media presentation description received in operation 1812 may be the media presentation descriptions illustrated in FIGS. 14A to 14H .
- the client 130 may request the server 120 to transmit a header of chaptering data and receive the header of chaptering data from the server 120 .
- the client 130 may first request the server 120 to transmit the header 1710 of the chaptering data 1700 of FIG. 17 and receive the header 1710 from the server 120 .
- the client may request and receive the plurality of still image data 1720 based on the header 1710 , in operation 1832 .
- Operation 1842 corresponds to operation 1830 of FIG. 18A .
- the client 130 requests the server 120 to transmit at least one media data from among the plurality of media data, based on the chaptering data received in operations 1822 and 1832 , and receives the at least one media data from the server 120 . If a particular chapter is selected based on the chaptering data received in operations 1822 and 1832 , at least one media data may be requested and received, starting from the selected chapter.
- FIG. 19 is a block diagram of a media data transmitting apparatus 1900 that may be included in the server 120 of FIG. 1 , according to an embodiment.
- the media data transmitting apparatus 1900 includes an information transmission or transmitting unit 1910 and a media data transmission or transmitting unit 1920 .
- the information transmission unit 1910 receives a request for predetermined information from the client 130 and transmits the requested information to the client 130 .
- the information transmission unit 1910 may receive a request for at least one piece from among information regarding content and information regarding a plurality of media data from the client 130 , and transmit the requested information to the client 130 .
- the information transmission unit 1910 may receive an HTTP request for at least one from among the information regarding the content and the information regarding the plurality of media data from the client 130 , and transmit the requested information to the client 130 as HTTP response.
- the information regarding the plurality of media data that the information transmission unit 1910 transmits to the client 130 may be a media presentation description.
- the media presentation description may be as described above with reference to FIGS. 9A to 9H and 14 A to 14 H.
- the media presentation description may include information regarding a plurality of chapters of content that is being streamed.
- the media data transmission unit 1920 receives a request for at least one media data, which is selected adaptively to a streaming environment from among the plurality of media data, from the client 130 , and transmits the requested media data to the client 130 .
- the media data transmission unit 1920 may receive a request for at least one media data, which is selected based on the media presentation description that the information transmission unit 1910 transmits to the client 130 , from the client 130 .
- the server 120 may receive a plurality of media data, which are encoded to have different qualities, respectively, from the encoding device 110 , store the plurality of media data, and transmit at least one media data requested to the client 130 from among the stored media data. Otherwise, the server 120 may receive media data from the encoding device 110 and transmit the media data to the client 130 in real time, in response to a request from the client 130 .
- the client 130 may request chaptering data based on the media presentation description that includes the information regarding the plurality of chapters. Then, the media data transmission unit 1920 may transmit the chaptering data to the client 130 .
- the media data transmission unit 1920 may transmit at least one media data to the client 130 , starting from the particular chapter.
- the client 130 may select a chapter during streaming of content, and in this case, the streaming is stopped and at least one media data is transmitted to the client 130 , starting from the selected chapter.
- the media data transmission unit 1920 may transmit the entire chaptering data to the client 130 at a time, as illustrated in FIGS. 13A and 18A , or may first transmit a header of the chaptering data and then transmit still image data as illustrated in FIGS. 13B and 18B .
- FIG. 20 is a diagram of a media data receiving apparatus 2000 that may be included in the client 1300 of FIG. 1 , according to an embodiment.
- the media data receiving apparatus 2000 of the client 130 includes an information receiving unit 2010 and a media data receiving unit 2020 .
- the information receiving unit 2010 transmits a request for desired information to the server 120 , and receives the requested information from the server 120 .
- a request for at least one from among information regarding content and information regarding a plurality of media data may be transmitted to the server 120 and may be received from the server 120 .
- an HTTP request for at least one from among the information regarding the content and the information regarding the plurality of media data may be transmitted to the server 120 and the at least one information may be received from the server 120 as a reply to the HTTP request.
- the information regarding the plurality of media data that the server 120 transmits to the client 130 may be a media presentation description.
- the media presentation description may be as described above with reference to FIGS. 9A to 9H and 14 A to 14 H. Accordingly, the media presentation description may include information regarding a plurality of chapters of content that is being streamed, as described above with reference to FIGS. 14A to 14H .
- the media data receiving unit 2020 transmits a request for at least one media data selected according to a streaming environment from among the plurality of media data, to the server 120 , and receives the requested media data from the client 130 .
- the media data receiving unit 2020 may transmit the request for the selected media data to the server 120 , based on the information regarding the plurality of media data that the information receiving unit 2010 receives from the server 120 .
- the media data receiving unit 2020 may request content sufficient for the streaming environment, based on the media presentation description received from the server 120 .
- the media presentation description includes information regarding the plurality of chapters as described above.
- the media data receiving unit 2020 may request and receive chaptering data, based on the media presentation description.
- the media data receiving unit 2020 may select a chapter based on the chaptering data, and may request the server 120 to provide media data corresponding to the selected chapter server 120 .
- the media data receiving unit 2020 may receive the entire chaptering data from the server 120 at a time as illustrated in FIGS. 13A and 18A , or may first receive a header of the chaptering data and then receive still image data as illustrated in FIGS. 13B and 18B .
- a system according to an embodiment can also be embodied as computer readable codes on a computer readable recording medium.
- a streaming apparatus of a server and a streaming apparatus of a client may include a bus coupled to each unit of the apparatuses 1900 and 2000 of FIGS. 19 and 20 , and at least one processor connected to the bus.
- the streaming apparatuses may further include a memory that is coupled to the bus so as to store a command, a received message, or a generated message and that is coupled to the at least one processor so as to perform commands as described above.
- the computer readable recording medium may be any recording apparatus capable of storing data that is read by a computer system. Examples of the computer readable recording medium include read-only memory (ROM), random-access memory (RAM), CD-ROMs, magnetic tapes, floppy disks, optical data storage devices, etc.
- the computer readable recording medium can also be distributed over network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Library & Information Science (AREA)
- Business, Economics & Management (AREA)
- Marketing (AREA)
- Information Transfer Between Computers (AREA)
- Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
Abstract
Description
- This application claims the benefit of U.S. Provisional Patent Application No. 61/315,500, filed on Mar. 19, 2010, U.S. Provisional Patent Application No. 61/362,805, filed on Jul. 9, 2010, and U.S. Provisional Patent Application No. 61/439,985, filed on Feb. 7, 2011, in the U.S. Patent and Trademark Office, and Korean Patent Application No. 10-2011-0021043, filed on Mar. 9, 2011 in the Korean Intellectual Property Office, the disclosures of which are incorporated herein in their entireties by reference.
- 1. Field
- Exemplary embodiments relate to a streaming method and apparatus, and more particularly, to a method and apparatus for adaptively streaming media data according to fluctuations in a streaming environment.
- 2. Description of the Related Art
- Examples of a method of transmitting media data through a network include a downloading method and a streaming method. In the streaming method, a server transmits media data in real time, and a client reproduces the received media data in real time.
- Unlike the downloading method that starts to reproduce media data after transmitting and receiving the media data, since the streaming method transmits and receives the media data through a logical channel set between the server and the client, and reproduces the media data in real time, a method and apparatus for maintaining quality of service (QoS) in reproducing the media data by reflecting fluctuations in a streaming environment are required.
- Methods and apparatuses consistent with exemplary embodiments generally relate to adaptively adjusting and performing streaming, i.e., adaptively transmitting and receiving media data according to a streaming environment.
- An exemplary embodiment also provides a non-transitory computer readable recording medium having recorded thereon a program which when executed by a computer performs the methods described herein.
- According to an exemplary embodiment, there is provided a method of receiving media data, the method including receiving a file including information regarding a plurality of media data generated by encoding content so as to have different qualities, from a server; and receiving at least one media data from among the plurality of media data, based on the received file, wherein the file comprises information regarding a plurality of still images corresponding to a plurality of chapters of the content.
- The receiving of the at least one media data may include receiving the plurality of still images, based on the received file; and receiving the at least one media data, starting from a chapter selected based on the plurality of still images.
- The file may include a first tag including at least one from among location information, resolution information, and compression type information regarding the plurality of still images.
- The first tag may have a same level as a second tag that identifies a reproduction period of the content.
- The first tag may have a same level as a third tag that is subject to a second tag, which identifies a reproduction period of the content, and that defines a plurality of media data to be reproduced in a predetermined reproduction period.
- The first tag may further include information regarding intervals between the plurality of still images.
- According to another exemplary embodiment, there is provided a method of transmitting media data, the method including transmitting a file including information regarding a plurality of media data generated by encoding content so as to have different qualities, to a client; and transmitting at least one media data from among the plurality of media data to the client, in response to a request based on the transmitted file, received from the client, wherein the file comprises information regarding a plurality of still images corresponding to a plurality of chapters of the content.
- The transmitting of the at least one media data to the client may include transmitting the plurality of still images to the client, in response to the request based on the received file, received from the client; and transmitting the at least one media data, starting from a chapter selected by the client based on the plurality of still images.
- According to another embodiment, there is provided an apparatus which receives media data, the apparatus including an information receiving unit which receives a file including information regarding a plurality of media data generated by encoding content so as to have different qualities, from a server; and a media data receiving unit which receives at least one media data from among the plurality of media data, based on the received file, wherein the file comprises information regarding a plurality of still images corresponding to a plurality of chapters of the content.
- According to another embodiment, there is provided an apparatus which transmits media data, the apparatus including an information transmitting unit which transmits a file including information regarding a plurality of media data generated by encoding content so as to have different qualities, to a client; and a media data transmitting unit which transmits at least one media data from among the plurality of media data to the client, in response to a request based on the transmitted file, received from the client, wherein the file comprises information regarding a plurality of still images corresponding to a plurality of chapters of the content.
- According to another embodiment, there is provided a non-transitory computer readable recording medium having stored thereon a computer readable program which when executed by a computer performs the method of receiving media data and/or the method of transmitting media data.
- The above and/or other features and advantages of the inventive concept will become more apparent by describing in detail exemplary embodiments thereof with reference to the attached drawings in which:
-
FIG. 1 is a diagram of a streaming system according to an exemplary embodiment; -
FIGS. 2A and 2B are flowcharts for describing streaming methods according to exemplary embodiments; -
FIG. 3 is a schema of a file including information about content, according to an exemplary embodiment; -
FIG. 4A illustrates information for defining a plurality of media data, according to an exemplary embodiment; -
FIG. 4B illustrates information about a header of media data, according to an exemplary embodiment; -
FIG. 4C illustrates information about at least one segment included in each one of a plurality of media data, according to an exemplary embodiment; -
FIGS. 5A and 5B are flowcharts for describing streaming methods according to other exemplary embodiments; -
FIG. 6 is a schema of a file including information about content, according to another exemplary embodiment; -
FIG. 7 illustrates information about content according to an exemplary embodiment; -
FIGS. 8A and 8B are schemas of a media presentation description according to exemplary embodiments; -
FIGS. 9A , 9B, 9C, 9D, 9E, 9F, 9G and 9H illustrate media presentation descriptions according to exemplary embodiments; -
FIGS. 10A , 10B and 10C each illustrate a plurality of media data according to exemplary embodiments; -
FIGS. 11A and 11B are flowcharts for describing streaming methods according to exemplary embodiments; -
FIGS. 12A , 12B and 12C each illustrate a plurality of media data according to exemplary embodiments; -
FIGS. 13A and 13B are flowcharts illustrating streaming methods according to exemplary embodiments; -
FIGS. 14A through 14H illustrate media presentation descriptions according to other embodiments; -
FIGS. 15A and 15B illustrate schemas of a chapter according to other embodiments; -
FIG. 16 illustrates information regarding a chapter, according to an embodiment; -
FIG. 17 is a diagram illustrates the structure of chaptering data, according to an embodiment; -
FIGS. 18A and 18B are flowcharts illustrating streaming methods according to other embodiments; -
FIG. 19 is a block diagram of a media data transmitting apparatus that may be included in the server ofFIG. 1 , according to an embodiment; and -
FIG. 20 is a diagram of a media data receiving apparatus that may be included in the client ofFIG. 1 , according to an embodiment. - Hereinafter, exemplary embodiments will be described more fully with reference to the accompanying drawings, in which exemplary embodiments are shown. Expressions such as “at least one of,” when preceding a list of elements, modify the entire list of elements and do not modify the individual elements of the list.
-
FIG. 1 is a diagram of astreaming system 100 according to an exemplary embodiment. - Referring to
FIG. 1 , thestreaming system 100 according to an exemplary embodiment includes anencoding device 110, aserver 120, and aclient 130. - The
encoding device 110 generates a plurality of media data about one input content by encoding the input content to have a plurality of different qualities. A streaming environment may change when theserver 120 streams media data to theclient 130. For example, a bandwidth of anetwork 140 for streaming may be changed, or a hardware source that may be used by theserver 120 to transmit media data or by theclient 130 to receive media data may be changed. - Accordingly, the
encoding device 110 encodes one content to have different qualities for adaptive streaming according to a fluidic streaming environment. One content may be encoded to have different qualities by adjusting a factor, such as a bit rate, a sampling frequency, resolution, or a frame rate. For example, a plurality of media data in 500 Kbps, 1000 Kbps, and 2000 Kbps may be generated by encoding one image content in different resolutions. - The plurality of media data in different qualities are transmitted to the
server 120, and at this time, information about the content and information about each media data may also be transmitted to theserver 120. The information about the content may include, but is not limited to, information about a title, a synopsis, a content identifier (ID), and a content uniform resource locator (URL) of the content as metadata of the content. The information about each media data may include a quality, a type, an ID, or the like of each media data, and will be described in detail with reference toFIGS. 4A , 4B and 4C. - The
client 130 receives at least one of the information about content and information about each media data, and requests theserver 120 for at least one of the plurality of media data, based on the received at least one of the information about content and information about each media data. Theclient 130 estimates a streaming environment, and selects at least one of the plurality of media data based on the estimated streaming environment. The at least one media data that may maintain a suitable quality of service (QoS) in the estimated streaming environment may be selected. Then, theclient 130 may transmit a hypertext transfer protocol (HTTP) request requesting theserver 120 to transmit the selected at least one media data. - When a streaming environment is deteriorated and high quality media data is received but continuous reproduction of media data is not possible, low quality media data may be requested from among a plurality of media data. When a streaming environment is improved and high quality media data is received and continuous reproduction of media data is possible, the high quality media data may continue to be requested from among a plurality of media data.
- The
client 130 may request theserver 120 to transmit another media data while receiving a predetermined media data. For example, theclient 130, which requested and was receiving first media data that is of low quality in a deteriorated streaming environment, may request theserver 120 to transmit second media data that is of a higher quality than the first media data as the streaming environment improves. According to a conventional streaming method, when theserver 120 and theclient 130 sets a quality while initially setting a streaming channel, media data is continuously transmitted and received having the same quality. However, according to an exemplary embodiment, streaming that is adaptive to the streaming environment is possible since theclient 130 is able to request the second media data again even while receiving the first media data about the same content. - The
client 130 may estimate a streaming environment by using any method of estimating a streaming environment based on the bandwidth of thenetwork 140 or the hardware resource that may be used by theserver 120 or theclient 130. For example, theclient 130 may estimate the streaming environment based on a time stamp and a bit error rate (BER) of received media data. The streaming environment may be determined to be deteriorated when media data is received slower than a reproduction speed by checking time stamps of the received media data. Alternatively, the streaming environment may be determined to be deteriorated when BERs of the received media data are increased. - When the
client 130 requests theserver 120 to transmit at least one of the media data according to the streaming environment, theserver 120 transmits requested media data to theclient 130. Theserver 120 may transmit the requested media data to theclient 130 as an HTTP response to the HTTP request. - Each media data may include at least one of a plurality of segments generated by encoding content in different qualities and dividing the encoded content. In other words, each media data generated by encoding the content by the
encoding device 110 may include at least one segment divided based on time. Theserver 120 transmits the content by dividing the content into the plurality of segments and respectively transmitting the plurality of segments, instead of encoding the content in one stream and continuously transmitting the content. The plurality of segments may be generated by dividing the content into predetermined time units, such as units of 10 or 20 seconds. The time that is the basis for dividing the content may be set based on a group of pictures (GOP). Media data corresponding to pictures of one or more GOPs may be set as one segment. - For example, when content is streamed having two qualities, the first media data may include at least one segment generated by encoding the content to have a first quality and dividing the encoded content based on time, and the second media data may include at least one segment generated by encoding the content to have a second quality and dividing the encoded content based on time.
- The adaptive streaming is possible by dividing each media data based on time. For example, when streaming starts, the
server 120 transmits a segment corresponding to 0 to 20 seconds of the first media data that is of low quality. Then, when it is determined that the streaming environment is improved after 20 seconds and theclient 130 requests media data that is of higher quality, theserver 120 may transmit a segment corresponding to 20 to 40 seconds of the second media data that is of the higher quality. Since media data is divided into a plurality of segments based on time, segments of different media data may be transmitted according to a streaming environment, even during streaming. -
FIG. 2A is a flowchart for describing a streaming method according to an exemplary embodiment. - Referring to
FIG. 2A , theclient 130 transmits a request to theserver 120 to transmit information about predetermined content, in operation 210. When a user of theclient 130 selects the predetermined content from a user interface displayed on a screen of theclient 130, theclient 130 requests theserver 120 to transmit information about the selected content. Theclient 130 may transmit an HTTP request requesting theserver 120 to transmit information about predetermined content. - Upon receiving the request from the
client 130, theserver 120 transmits the information about the predetermined content to theclient 130. Theserver 120 may transmit the information about the predetermined content as an HTTP response to the HTTP request to theclient 130. The information about the predetermined content may be a content access descriptor (CAD) according to an open IPTV forum (OIPF) standard. The information about the predetermined content will now be described in detail with reference toFIG. 3 . -
FIG. 3 is a schema of a file including information about content, according to an exemplary embodiment. The file may be a CAD, and may be an eXtensible Markup Language (XML) file. A tag and an attribute are separately described, but it is understood that according to an exemplary embodiment an item defined by a tag can be defined by an attribute or an item defined by an attribute can be defined by a tag. - Referring to
FIG. 3 , the information about content may include “Title”, “Synopsis”, “OriginSite”, and “ContentURL” tags. - Since conventional streaming of media data generates one media data by encoding one content to have a predetermined quality, conventional information (specifically, CAD according to OIPF) about content does not include information about a plurality of media data generated by encoding the content to have different qualities.
- However, the information about content, according to the present exemplary embodiment, includes information about a plurality of media data generated by encoding one content to have different qualities, and corresponds to “Tracks”, “RefData”, and “Fragments” tags in
FIG. 3 . -
FIG. 4A illustrates information for defining a plurality of media data, according to an exemplary embodiment. - Referring to
FIG. 4A , a “Tracks” tag is information for classifying a plurality of media data generated by encoding content to have different qualities. The “Tracks” tag includes an “ID” attribute, a “Type” attribute, and a “BitRate” attribute assigned to each media data. - The “ID” attribute defines identifiers sequentially given to the plurality of media data, and the “Type” attribute defines whether media data corresponds to audio data, video data, video/audio data, or subtitle data. When the “Type” attribute is “Packed”, the media data is video/audio data, and when the “Type” attribute is “Video”, the media data is video data. The “BitRate” attribute defines a bit rate used to encode the media data.
-
FIG. 4B illustrates information about a header of media data, according to an exemplary embodiment. - Referring to
FIG. 4B , a “RefData” tag includes a “Type” attribute and an “ID” attribute. The “Type” attribute defines a media format of a header. For example, when the “Type” attribute is “HEAD-TS”, the header is a header of a transport stream format. The “ID” attribute defines a media data of a header. When the “ID” attribute is “1”, the header is a header of media data having a media data ID of “1”. Also, the “RefData” tag includes information pointing to a header, and an “URL” tag defines a location of a header, i.e., a URL of a header. - The “RefData” tag is a selective element. The “RefData” tag is included in information about content only when a header is separated from media data and exists as a separate file, and may not be included in the information about content when the header is combined with the media data.
-
FIG. 4C illustrates information about at least one segment included in each of a plurality of media data, according to an exemplary embodiment. - Referring to
FIG. 4C , a “Fragment” tag, which is a sub tag of a “Fragments” tag, includes the information about at least one segment included in each of the plurality of media data. - The “Fragments” tag includes a “NextFragmentsXMLURL” attribute. When following content is continuously streamed after streaming of one content is completed like in the case of live streaming, the following content may be seamlessly streamed only when the
client 130 is aware of information about the following content. Accordingly, the “Fragments” tag defines the information about the following content as the “NextFragmentsXMLURL” attribute. URLs of the plurality of media data with respect to the following content may be defined as the “NextFragmentsXMLURL” attribute. - The “Fragment” tag includes information about at least one segment of current content. Referring to
FIG. 4C , URL information of “slice1-1.as” constituting a first segment generated by encoding content in a first quality as first media data is defined by a “URL” tag, and an ID of a corresponding header is defined by a “RefPointer” tag. Also, a starting time of the first segment is defined by a “StartTime” attribute, and a duration time of each segment is defined by a “Duration” attribute. A quality of the first media data is defined by a “BitRate” attribute. - In
FIG. 4C , the “Fragments” tag shows each media data including only one segment. However, as described above with reference toFIG. 1 , it is understood that according to an exemplary embodiment, when each media data is divided into a plurality of segments, one “Fragments” tag may include information about at least two segments. - Referring back to
FIG. 2A , theclient 130 requests theserver 120 to transmit at least one of the plurality of media data, inoperation 220. The plurality of media data are generated by encoding one content to have different qualities. Theclient 130 selects at least one media data encoded to have a quality suitable for a streaming environment from among the plurality of media data, and requests theserver 120 for the selected at least one media data. Theclient 130 may transmit an HTTP request to theserver 120 based on information about the plurality of media data, which is included in the information about the content. - As described with reference to
FIG. 4C , the information about the content may include a “Fragments” tag. Accordingly, theclient 130 requests theserver 120 to transmit selected media data based on URL information included in the “Fragments” tag. - The
server 120 transmits the media data according to the request of theclient 130. Theserver 120 may transmit at least one segment of the requested media data to theclient 130. Theserver 120 may transmit media data requested as an HTTP response with respect to an HTTP request to theclient 130. -
FIG. 2B is a flowchart for describing a streaming method according to another exemplary embodiment.FIG. 2B illustrates the streaming method when a header exists as a separate file from media data. - Referring to
FIG. 2B , theclient 130 requests theserver 120 to transmit information about predetermined content, inoperation 212, and theserver 120 transmits the information about content.Operation 212 corresponds to operation 210 ofFIG. 2A . The information about content including the “RefData” tag described above with reference toFIG. 4B is received. - In
operation 222, theclient 130 requests a header of selected media data from among a plurality of media data, based on the information about content received inoperation 212. At least one media data suitable for a streaming environment is selected from among the plurality of media data based on the information about content received inoperation 212, and a header of the selected at least one media data is requested. The header of the selected at least one media data is requested by referring to the “RefData” tag included in the information about content received inoperation 212. - The
server 120 transmits the requested header to theclient 130. A header file may be transmitted to theclient 130, and may be an XML file. - In
operation 232, theclient 130 requests theserver 120 to transmit selected media data based on the information about content received inoperation 212 and the header received inoperation 222. Theclient 130 requests theserver 120 to transmit at least one segment generated by dividing media data based on time, and theserver 120 transmits the requested at least one segment to theclient 130. -
FIG. 5A is a flowchart for describing a streaming method according to another exemplary embodiment. - Referring to
FIG. 5A , theclient 130 requests theserver 120 to transmit information about predetermined content, inoperation 510, and theserver 120 transmits the information about content. Theclient 130 transmits an HTTP request for requesting theserver 120 to transmit the information about content, and receives the information about content as an HTTP response to the HTTP request. The information about content may be an XML file. The information about content received by theclient 130 inoperation 510 is different from the information about content received byclient 130 in operation 210 ofFIG. 2 , and the difference will now be described with reference toFIGS. 6 and 7 . -
FIG. 6 is a schema of a file including information about content, according to another exemplary embodiment. - Referring to
FIG. 6 , the information about content according to the present exemplary embodiment may include “Title”, “Synopsis”, “OriginSite”, and “ContentURL” tags likeFIG. 3 . - However, in
FIG. 3 , the information about content includes the information about the plurality of media data by including the “Tracks”, “RefData”, and “Fragments” tags, whereas inFIG. 6 , instead of including the information about the plurality of media data, the information about content only defines a URL of a file (hereinafter, referred to as a “media presentation description”) including the information about the plurality of media data. The “ContentURL” tag may define the URL of the media presentation description. - Compatibility with various media data formats may be maintained while performing streaming that is adaptive to a streaming environment by inserting the URL of the media presentation description into the information about content as shown in
FIG. 6 , without largely changing conventional schema of the file containing the information about content. - As shown in
FIG. 6 , the information about content may only include information related to the streaming method, and not include the information about the plurality of media data. In other words, the “ContentURL” tag may include a “MediaFormat” attribute defining a format of media data used during streaming, and a “MIMEType” attribute defining a type of media data. - Specifically, the “ContentURL” tag may include a “TransferType” attribute defining a service to which streaming of content is related. The “TransferType” attribute may define whether the streaming of content is related to a Content on Delivery (CoD) service, a live service, an adaptive streaming live service, or an adaptive streaming CoD service.
-
FIG. 7 illustrates information about content according to an exemplary embodiment.FIG. 7 may be a CAD according to the OIPF standard. - Referring to
FIG. 7 , the information about content generated according to the schema ofFIG. 6 may define a URL of a media presentation description in a “ContentURL” tag. http://asexample.com/vod/movies/18888/Meta/MainMeta.xml is the URL of the media presentation description. Also, as described with reference toFIG. 6 , the “MediaFormat” attribute, the “MIMEType” attribute, and the “TransferType” attribute may be defined in the “ContentURL” tag. - Referring back to
FIG. 5A , inoperation 520, theclient 130 requests theserver 120 for the information about the plurality of media data, based on the information about content received inoperation 510. Theclient 130 may request a media presentation description to theserver 120 through an HTTP request, and may receive the media presentation description as an HTTP response. - The information about content received by the
client 130 from theserver 120 inoperation 510 may include the URL of the media presentation description as described with reference toFIGS. 6 and 7 , and thus theclient 130 requests and receives the media presentation description from theserver 120 by referring to the “ContentURL” tag of the information about content. The media presentation description will now be described in detail with reference toFIGS. 8A and 8B , andFIGS. 9A , 9B, 9C, 9D, 9E, 9F, 9G and 9H. -
FIGS. 8A and 8B are schemas of a media presentation description according to exemplary embodiments. The media presentation description may comply with the OIPF standard. - Referring to
FIG. 8A , the media presentation description according to the present exemplary embodiment includes a template tag about URLs of a plurality of media data, a tag for defining a location of a header, a tag for defining to which service the streaming is related to, a tag for defining a container format of media data, and a tag for defining the plurality of media data. - An “urlTemplate” tag defines a common portion of the URLs of the plurality of media data. For example, if “http://example.com/vod/movie/18888/Track/{TrackID}/Segments/{SegmentI D}” is a URL template, a URL of media data may be defined by respectively substituting an ID of each media data and an ID of at least one segment included in each media data for “TrackID” and “SegmentID”.
- A “headerUrl” tag corresponds to the “RefData” tag described with reference to
FIG. 4B . In other words, the “headerUrl” tag defines URLs of headers of the plurality of media data. - An “is Live” tag defines a service related to streaming. For example, when the “is Live” tag is defined as “Live”, the streaming is related to a live service, and when the “is Live” tag is defined as “CoD”, the streaming is related to a CoD service.
- A “contentType” tag defines a container format of media data used during streaming. The “contentType” tag may indicate whether the container format is an MP4 format or an MPEG2-TS format. The container format is an MP4 format or an MPEG2-TS format herein, However, though it is understood that according to an exemplary embodiment the container format is not limited thereto, and any container format for transmitting media data may be used. For example, the “contentType” tag may define that the container format complies with an MPEG Media Transport (MMT) standard.
- A “Stream” tag is generated for each media data and defines each media data. In order to define each media data generated by encoding one content to have different qualities, the “Stream” tag includes a “streamName” attribute, a “type” attribute, a “bitrate” attribute, a “startTime” attribute, a “firstIntervalNum” attribute, a “duration” attribute, and an “intervalCount” attribute.
- The “streamName” attribute defines a name of media data, and may be an ID of media data. The “type” attribute defines a type of media data, wherein it is defined whether the media data is audio data, video data, or audio/video data. When media data only includes data about an I-frame for a trick play, such information may be defined in the “type” attribute.
- The “bitrate” attribute defines a bit rate of media data, the “startTime” attribute defines a time stamp for specifying a starting time of media data, and the “firstIntervalNum” attribute defines a number of a segment that initially starts.
- The “duration” attribute defines a duration time of a segment included in media data, and the “intervalCount” attribute defines a total number of at least one segment included in media data.
- The “Segment” tag is a sub tag of the “Stream” tag, and as described above, when media data includes at least one segment generated by encoding content in a predetermined quality and dividing the encoded content based on time, each of the at least one segment is defined.
- The “IntNum” attribute defines a number of a segment, and the “StartTime” tag defines a starting time of a corresponding segment. The “Duration” tag defines a duration time of a corresponding segment, and the “url” defines a URL of a corresponding segment.
- The “Segment” tag is a selective tag, and may not be included in the media presentation description if the information about at least one segment included in the media data can be inferred from other attributes of the “Stream” tag. In other words, when content of the “Segment” tag can be inferred from the “startTime”, “firstIntervalNum”, “duration”, and “intervalCount” attributes defined in the “Stream” tag, the “Segment” tag may not be included in the media presentation description. Also, a “url” attribute of the “Segment” tag may not be required if a predetermined template is defined in the “urlTemplate”, and the URLs of segments are inferred by substituting each ID of the plurality of media data and an ID of at least one segment included in each media data with the defined predetermined template.
- However, on the other hand, attributes of the “Segment” tag are separately defined for each segment, if the attributes of the “Segment” tag cannot be inferred from other attributes of the “Stream” tag. The attributes of the “Segment” tag may not be inferred if duration times of segments are different. When duration times are different, the duration times of segments included in media data cannot be inferred from the attributes of the “Stream” tag, and thus the duration times of the segments may be each set by using a “duration” attribute of the “Segment” tag. When the duration times of the segments are different, starting times of continuous segments are also different. For example, when a duration time of a first segment of first media data is different from a duration time of a second segment of the first media data, a starting time of the second segment and a starting time of a third segment cannot be inferred from the “Stream” tag. Accordingly, a starting time of each segment may be defined by a “startTime” attribute.
- The duration times and/or starting times may be defined by using a sub tag of the “Segment” tag, instead of using the “duration” attribute and the “startTime” attribute of the “Segment” tag. For example, a “Url” tag constituting a sub tag of the “Segment” tag may be set, and a duration time may be defined as an attribute of the “Url” tag, such as “<Url=www.example.com/˜/segment.ts, duration=10/>”.
- According to another exemplary embodiment, duration time may be defined based on a difference between duration times of continuous segments. An upper tag may define a default duration time, and the “Url” tag constituting the sub tag may define only a difference between the default duration time and an actual duration time for each segment. As described above, the “Url” tag constituting the sub tag of the “Segment” tag may be defined as “<Url=www.example.com/˜/segment.ts, duration=difference/>”. “Difference” denotes a difference between the default duration time and the actual duration time.
- When a default duration time of a corresponding segment is defined to be 10 minutes by using the “Stream” tag or the “Segment” tag, and the “Url” tag constituting the sub tag is defined to be “<Url=www.example.com/˜/segment.ts, duration=2/>”, a duration time of the corresponding segment may be defined to be 10+2=12 minutes.
- Referring to
FIG. 8B , the media presentation description according to another exemplary embodiment may further include a “nextManifestURL” tag. As described above, when following content is continuously streamed after streaming of one content is completed, such as in the case of live streaming or advertisement insertion, theclient 130 requires to pre-know information about the following content so as to stream the following content seamlessly. Accordingly, a URL of a media presentation description of the following content to be streamed after current content may be defined by the “nextManifestURL” tag. -
FIGS. 9A , 9B, 9C, 9D, 9E, 9F, 9G and 9H illustrate media presentation descriptions according to exemplary embodiments. - Referring to
FIG. 9A , the media presentation description according to an exemplary embodiment includes a “URLTemplate” tag, a “RefDataURL” tag, and a plurality of tags respectively defining a plurality of media data. - The “URLTemplate” tag and the “RefDataURL” tag of
FIG. 9A respectively correspond to the “urlTemplate” tag and the “RefDataURL” tag ofFIGS. 8A and 8B . - An “ID” attribute, a “Type” attribute, a “BitRate” attribute, a “StartTime” attribute, a “SegmentDuration” attribute, a “SegmentStartID” attribute, and a “SegmentCount” attribute of
FIG. 9A respectively correspond to the “streamName” attribute, the “type” attribute, the “bitrate” attribute, the “startTime” attribute, the “duration” attribute of the “Stream” tag, the “firstIntervalNum” attribute of the “Stream” tag, and the “intervalCount” attribute ofFIGS. 8A and 8B . - The media presentation description of
FIG. 9A includes information about three video data generated by encoding content to have different qualities, information about one audio data, and information about media data generated by encoding only I-frames for a trick play. - Referring to
FIG. 9B , the media presentation description according to an exemplary embodiment further includes a “NextAdaptiveControlURL” tag. The “NextAdaptiveControlURL” tag corresponds to the “nextManifestURL” tag ofFIG. 8B . Accordingly, a URL of a media presentation description of following content to be reproduced after current content may be defined by the “NextAdaptiveControlURL” tag. -
FIG. 9C shows a media presentation description of the following content, when the URL of the media presentation description of the following content to be reproduced after the current content is defined by the “NextAdaptiveControlURL” tag ofFIG. 9B . Comparing the media presentation descriptions ofFIGS. 9B and 9C , a “StartTime” attribute is different from the media presentation description of the current content ofFIG. 9B , since the media presentation description ofFIG. 9C is for the following content. -
FIGS. 9D and 9E illustrate media presentation descriptions for selectively controlling high quality video reproduction that a user want to perform.FIG. 9D illustrates the media presentation description when a plurality of media data are generated by encoding one content to have 5 different qualities. Here, the media presentation descriptions ofFIGS. 9D and 9E are different in a tag including information about video encoded to have high quality, i.e., a “StartTime” attribute and a “SegmentCount” attribute of media data having an “ID” attribute of “5”. - The
server 120 selectively transmits the media presentation description ofFIG. 9D or the media presentation description ofFIG. 9E according to a user rating of theclient 130. When the user rating of theclient 130 is high (for example, when theclient 130 is a paid user), the media presentation description ofFIG. 9D is transmitted so that high quality video is freely reproduced, and when the user rating of theclient 130 is low (for example, when theclient 130 is a free user), the media presentation description ofFIG. 9E is transmitted so that segments defined by the “SegmentCount” attribute are reproduced from a time defined by the “StartTime” attribute in high quality video. -
FIG. 9F illustrates a media presentation description when an advertisement is inserted into content. Referring toFIG. 9F , the media presentation description may include information about advertisement content and main content, which have different “StartTime” attributes. The media presentation description may include information about advertisement content, which is reproduced from “00:00:00” to “00:02:00” at a bit rate of “500000”, and information about main content, which is reproduced from “00:02:00” at bit rates of “1000000”, “2000000”, “3000000”, or “4000000”. The media presentation description ofFIG. 9F may be transmitted from theserver 120 to theclient 130 if theserver 120 provides the advertisement content to theclient 130 by encoding the advertisement content to have one bit rate, and provides the main content, which has a different “StartTime” attribute from the advertisement content, to theclient 130 by encoding the main content in four different bit rates. -
FIG. 9G illustrates a media presentation description including information about advertisement content, according to an exemplary embodiment. A server for providing main content and a server for providing advertisement content may be different. In other words, when theclient 130 receives the main content from theserver 120 ofFIG. 5A and receives the advertisement content from a server other than theserver 120, the media presentation description ofFIG. 9G may include a URL of the advertisement content. As shown inFIG. 9G , the media presentation description may include the URL of the advertisement content that is encoded to have one quality. -
FIG. 9H illustrates a media presentation description including language and subtitle information, according to an exemplary embodiment. Referring toFIG. 9H , audio data may include information about multiple languages. The media presentation description may include information about audio data of multiple languages, wherein an “ID” attribute is “4” or “5”, or information about subtitles of multiple languages, wherein the “ID” attribute is “6” or “7”. - Since not only the audio data, but also the subtitle may be divided into a plurality of segments according to time, the audio data and the subtitle may be changed to audio data and a subtitle of another language during streaming.
- Referring back to
FIG. 5A , theclient 130 requests theserver 120 to transmit at least one of the plurality of media data, inoperation 530. Theclient 130 selects at least one media data that is encoded to have a quality suitable for the streaming environment by referring to the information about the plurality of media data, and requests theserver 120 for the selected at least one media data. Theclient 130 may transmit an HTTP request for requesting theserver 120 to transmit a predetermined media data. Theserver 120 transmits the media data according to the request of theclient 130. Alternatively, the server may transmit at least one segment generated by encoding content to have a predetermined quality and dividing the encoded content based on time, to theclient 130. Theserver 120 may transmit the requested media data to theclient 130 as an HTTP response to the HTTP request. -
FIG. 5B is a flowchart for describing a streaming method according to another exemplary embodiment. - Referring to
FIG. 5B , theclient 130 requests theserver 120 to transmit information about predetermined content, inoperation 512, and receives the information about predetermined content from theserver 120. Theclient 130 may transmit an HTTP request for requesting theserver 120 to transmit the information about predetermined content, and receive the information about predetermined content as an HTTP response to the HTTP request. The information about predetermined content may be included in an XML file. Inoperation 522, theclient 130 requests theserver 120 to transmit information about a plurality of media data based on the information about predetermined content received inoperation 512. Theclient 130 may request theserver 120 for a media presentation description through the HTTP request, and receive the media presentation description as the HTTP response. - In
operation 532, theclient 130 requests a header of media data selected based on the information about a plurality of media data received inoperation 522. At least one media data that is suitable to a streaming environment is selected from among the plurality of media data based on the information about the plurality of media data received inoperation 522, and a header of the selected at least one media data is requested. The header of the selected at least one media data is requested by referring to the information about the plurality of media data received inoperation 522. Theserver 120 transmits a file of the header of the selected at least one media data to theclient 130 in response to the request of theclient 130. - In
operation 542, theclient 130 requests theserver 120 to transmit selected media data based on the information about the plurality of media data received inoperation 522, and the header received inoperation 532. Theclient 130 requests theserver 120 to transmit at least one segment generated by encoding content to have a predetermined quality and dividing the encoded content based on time, and theserver 120 transmits the requested at least one segment to theclient 130. -
FIGS. 10A , 10B and 10C each illustrate a plurality of media data according to exemplary embodiments.FIGS. 10A , 10B and 10C each illustrate the plurality of media data included in theserver 120 to perform the streaming methods according toFIGS. 5A and 5B . - Referring to
FIG. 10A , theserver 120 may include a plurality ofmedia data 1010 through 1030 generated by encoding one content to have a plurality of different qualities, for streaming that is adaptive to a streaming environment. “Track1” through “TrackN” denote the plurality ofmedia data 1010 through 1030. Also, each of the plurality ofmedia data 1010 through 1030 may include at least one segment generated by dividing each of the plurality ofmedia data 1010 through 1030 based on time. “Slice1-1.as”, “Slice1-2.as”, “Slice1-3.as”, “Slice2-1.as”, “Slice2-2.as”, “Slice2-3.as”, “SliceN-1.as”, “SliceN-2.as”, and “SliceN-3.as” denote at least one segment. - The
server 120 may includeinformation 1040 required for theclient 130 to access the plurality ofmedia data 1010 through 1030. Theserver 120 may include a “CadMeta.xml” file as information about content, a “MainMeta.xml” file as information about the plurality ofmedia data 1010 through 1030, and a “Head1.ref” file, a “Head2.ref” file, etc. as header files of the plurality ofmedia data 1010 through 1030. Here, the “Head1.ref” file may be a header file of the “Track1”, and the “Head2.ref” file may be a header file of the “Track2”. - The “CadMeta.xml” file may be a CAD file according to the OIPF standard, and the “MainMeta.xml” file may be the media presentation description described above. Also, the “Head1.ref” and “Head2.ref” files are selective elements, and may not exist when headers are included in the plurality of
media data 1010 through 1030. - Referring to
FIG. 10B ,information 1042 required for theclient 130 to access the plurality ofmedia data 1010 through 1030 may further include a “NextMeta.xml” file. As described above, the “NextMeta.xml” file may be a media presentation description of a following content to be reproduced after current content. As described above, the media presentation description of the current content, i.e., the “MainMeta.xml” file, includes the URL of the media presentation description of the following content, and thus theclient 130 may access the “NextMeta.xml” file based on the “MainMeta.xml” file. - Referring to
FIG. 10C , header files of the plurality ofmedia data 1010 through 1030 may exist in oneheader file 1050. Instead of existing for each of the plurality ofmedia data 1010 through 1030, the header files may exist as oneheader file 1050 and may be included ininformation 1044 required to access the plurality ofmedia data 1010 through 1030. - For example, when each of the plurality of
media data 1010 through 1030 corresponds to an elementary stream, e.g., an elementary stream according to the MPEG-2 standard, each of the header files of the plurality ofmedia data 1010 through 1030 may be theheader file 1050 including a program association table (PAT) and a program map table (PMT). At least one of the PAT and the PMT may be separated from the plurality ofmedia data 1010 through 1030 to prepare theheader file 1050, and the media presentation description may include information pointing to theheader file 1050. The information pointing to theheader file 1050 may be URL information of theheader file 1050 or information for specifying a packet including theheader file 1050 in a MPEG-2 transport stream (TS). Theheader file 1050 including at least one of the PAT and the PMT is an initialization segment, and may be transmitted to theclient 130 before segments including payload data, so as to initiate reproduction of the plurality ofmedia data 1010 through 1030. - Referring back to
operation 532 ofFIG. 5B , theclient 130 may obtain the information pointing to theheader file 1050 by referring to the media presentation description, and may request theheader file 1050 based on the information pointing theheader file 1050. After requesting and receiving theheader file 1050 based on the information pointing to theheader file 1050, at least one of the plurality ofmedia data 1010 through 1030 is selected based on at least one of the PAT and the PMT included in theheader file 1050, and the selected at least one media data is requested from theserver 120. The PAT and the PMT may be separated as theheader file 1050 or included in the plurality ofmedia data 1010 through 1030, but may include an entire list of elementary streams included in the plurality ofmedia data 1010 through 1030 regardless of locations of the PAT and the PMT. - According to MPEG-2, packet IDs (PIDs) defined in the PAT and the PMT are different according to elementary streams. Accordingly, PIDs assigned to each of the plurality of
media data 1010 through 1030 may be different. Alternatively, according to another exemplary embodiment, since the plurality ofmedia data 1010 through 1030, generated by encoding one content to have different qualities, are elementary streams of the same content, the same PID may be employed. - When the plurality of
media data 1010 through 1030 correspond to a plurality of elementary streams according to MPEG-2, each of segments included in the plurality ofmedia data 1010 through 1030 may include at least one continuous packetized elementary stream (PES). However, one PES may be included in only one segment from among the segments. In other words, one PES may not be included in two different segments. - Since a plurality of media data are generated by encoding one content to have different qualities, presentation time stamps (PTSs) and/or decoding time stamps (DTSs) included in PESs of the plurality of media data may be aligned according to reproduction times. In other words, if an initial PES of first media data and an initial PES of second media data are content reproduced at the same time, a PTS and/or a DTS may be equally set.
- Further, when the second media data is reproduced while reproducing the first media data by changing media data according to the streaming environment, the PTSs and/or the DTSs may be continuously aligned so that the first and second media data are continuously reproduced. In other words, when the second media data is reproduced while reproducing the first media data, by changing media data, the PTS and/or the DTS of the last PES before the changing of the media data, and the PTS and/or the DTS of the first PES after the changing of the media data, may be continuously set.
- The PTS and/or the DTS define a time stamp of video data. Accordingly, time stamps of the plurality of media data with respect to video data are aligned according to the reproduction times of the plurality of media data as described above. Such alignment of the time stamps based on the reproduction times may be equally applied to audio data. In other words, like the time stamps of the plurality of media data with respect to the video data, time stamps of the pieces media data with respect to the audio data may also be aligned according to the reproduction times for adaptive streaming.
-
FIG. 11A is a flowchart for describing a streaming method according to another exemplary embodiment. - Referring to
FIG. 11A , theclient 130 requests information about a plurality of media data to theserver 120, inoperation 1110. Theclient 130 may request a media presentation description from theserver 120 via an HTTP request, and may receive the media presentation description as an HTTP response. Theclient 130 requests theserver 120 for and receives the information about the plurality of media data generated by encoding one content to have a plurality of different qualities, so as to perform streaming that is adaptive to a streaming environment. The streaming method ofFIG. 11A is different from the streaming method ofFIG. 5A as the information about the plurality of media data is requested and received without requesting and receiving information about content. - In
operation 1120, theclient 130 requests theserver 120 to transmit at least one of the plurality of media data. Theclient 130 selects and requests at least one media data that is encoded to have a quality suitable for the streaming environment by referring to the information about the plurality of media data, and receives the requested at least one media data from theserver 120. -
FIG. 11B is a flowchart for describing a streaming method according to another exemplary embodiment. - Referring to
FIG. 11B , theclient 130 requests theserver 120 to transmit information about a plurality of media data and receives the information about the plurality of media data from theserver 120 in response to the request, inoperation 1112. Theclient 130 may request theserver 120 for a media presentation description through an HTTP request, and receive the media presentation description as an HTTP response. - In
operation 1122, theclient 130 requests a header of selected media data based on the information about the plurality of media data received inoperation 1112. Theclient 130 requests the header of media data selected according to a streaming environment by referring to the information about the plurality of media data received inoperation 1112. In response to the request, theserver 120 transmits a file including the header of the selected media data to theclient 130. - In
operation 1132, theclient 130 requests theserver 120 to transmit the media data selected based on the information about the plurality of media data received inoperation 1112, and the header received inoperation 1122. Theclient 130 requests theserver 120 to transmit at least one segment generated by encoding content in a predetermined quality and dividing the encoded content based on time, and theserver 120 transmits the requested at least one segment to theclient 130. -
FIGS. 12A , 12 B and 12C each illustrate a plurality of media data according to other exemplary embodiments.FIGS. 12A and 12B each illustrate the plurality of media data included in theserver 120, which are used to perform the streaming methods ofFIGS. 11A and 11B . - Referring to
FIG. 12A , theserver 120 may include the plurality ofmedia data 1010 through 1030 generated by encoding one content to have the plurality of different qualities for streaming that is adaptive to a streaming environment, as shown inFIG. 10A . - Here, the plurality of
media data 1010 through 1030 ofFIG. 12A is different from the plurality ofmedia data 1010 through 1030 ofFIG. 10A ininformation 1240 required for theclient 130 to access the plurality ofmedia data 1010 through 1030, wherein theserver 120 only includes information about the plurality ofmedia data 1010 through 1030 and not information about content, unlike the exemplary embodiment ofFIG. 10A . Here, theclient 130 may receive the information about content from another entity instead of theserver 120, and access the plurality ofmedia data 1010 through 1030 included in theserver 120 based on the received information about content. - Referring to
FIG. 12B ,information 1242 required for theclient 130 to access the plurality ofmedia data 1010 through 1030 may be prepared by further including a “NextMeta.xml” file to theinformation 1240 ofFIG. 12A . - Referring to
FIG. 12C , the header files of the plurality ofmedia data 1010 through 1030 may exist in oneheader file 1250. The header files do not exist for each of the plurality ofmedia data 1010 through 1030, but may be included ininformation 1244 required to access the plurality ofmedia data 1010 through 1030, as oneheader file 1250. Theheader file 1250 corresponds to theheader file 1050 ofFIG. 10C . -
FIG. 13A is a flowchart illustrating a streaming method according to another embodiment. Referring toFIG. 13A , inoperation 1310, aclient 130 requests aserver 120 to provide information regarding desired content, and receives the information regarding the desired content from theserver 120. For this end, theclient 130 may transmit an HTTP request for the information regarding the desired content to theserver 120 and receive the information regarding the desired content from theserver 120 according to the HTTP response. An XML file containing the information regarding the desired content may be received. The information regarding the desired content may include the URL of a media presentation description as described above in detail with reference toFIGS. 6 and 7 . - In
operation 1320, theclient 130 requests theserver 120 to provide information regarding a plurality of media data, based on the information regarding the desired content received inoperation 1310. Theclient 130 may transmit an HTTP request for a media presentation description to theserver 120 and receive the media presentation description from theserver 120 according to the HTTP response. - The media presentation description that the
client 130 receives inoperation 1320 may be one of the media presentation descriptions described above in detail with reference toFIGS. 8A , 8B, and 9A to 9G and may contain information regarding a plurality of chapters of the content. The plurality of chapters of the content will now be described in detail with reference toFIGS. 14A to 14H . -
FIGS. 14A through 14H illustrate media presentation descriptions according to other embodiments. Referring toFIG. 14A , a media presentation description according to another embodiment includes “Period” tags that are subject to a “MPD” tag (an uppermost tag) and identify reproduction periods of content that is being streamed, respectively. Each of the “Period” tags includes an “Representation” tag having information regarding a plurality of media data that are to be streamed in a corresponding reproduction period. Also, each of the “Representation” tags may include a “SegmenInfo” tag having information regarding a plurality of segments divided from one media data according to time. - The media presentation description further includes a “Chaptering” tag having information regarding a plurality of chapters of the content that is being streamed. The content may include the plurality of chapters classified according to a scene, a story, or time. The information regarding the plurality of chapters is defined with the “Chaptering” tag. Information regarding at least one of a still image and texts related to a particular chapter may be information regarding the chapter.
- The “Chaptering” tag may include at least one attribute defining a still image corresponding to the plurality of chapters. The format, URL, and time intervals of at least one still image are defined with a “mimeType” attribute, a “URL” attribute, and an “ImageInterval” attribute. The resolution of the at least one still image is defined with a “height” attribute and a “width” attribute. The “height” attribute and the “width” attribute define the horizontal and vertical sizes of the at least one still image, i.e., the resolution of the at least one still image. Also, a compression type of the at least one still image is defined with a “compressiontype” attribute.
- The “URL” attribute of the “Chaptering” tag may be a template, similar to the “URL” attribute of the media presentation description described above. The template is a common part of the URLs of a plurality of still images and may be defined with the “URL” attribute.
- Referring to
FIG. 14B , the name of a tag including information a plurality of chapters of content may be the same as that of a tag defining a plurality of media data. In other words, the tag defining a plurality of media data, i.e., a “Representation” tag, may be used to define the plurality of chapters. Thus, each of “Period” tags defining reproduction periods, respectively, may include a “Representation” tag defining media data in a corresponding reproduction period, and a “Representation” tag defining a plurality of chapters in the corresponding reproduction period. - Referring to
FIG. 14B , in a first “Period” tag, a first “Representation” tag is used to define media data, e.g., video data, and a second “Representation” tag is used to define a plurality of chapters. The second “Representation” tag defines the “mimeType” attribute, the “width” attribute, the “height” attribute, and the “ImageInterval” attribute described above with reference toFIG. 14A so as to define a plurality of still images corresponding to the plurality of chapters. - As described above with reference to
FIG. 14A , each of the “Representation” tags may include the “SegmentInfo” tag that is a lower tag defining a plurality of segments of the media data. Likewise, a “SegmentInfo” of the “Representation” tag ofFIG. 14B , which defines the plurality of chapters, may define a plurality of segments divided from a plurality of still images according to a predetermined criterion. The plurality of still images may be divided into a plurality of segments according to data size or time, and the plurality of segments may be defined. As illustrated inFIG. 14B , each of the “SegmentInfo” tags defining the plurality of segments, respectively, may include “Url” tags subject thereto, and each of the “URL” tags may define the URL of a corresponding still image. -
FIG. 14C illustrates a case where a “Representation” tag defining a plurality of chapters does not include the “imageInterval” attribute. As described above, the plurality of chapters may be classified according a scene, or a story other than time. In this case, time intervals between still images may not be uniform. Thus, as illustrated inFIG. 14C , the “Representation” tag may not include the “imageInterval” attribute, and may define an “ImagePresentationTime” attribute in an “Url” tag included in a “SegmentInfo” tag subject to the “Representation” tag. The “ImagePresentationTime” attribute defines time corresponding to a still image. -
FIG. 14D illustrates a case where a plurality of still images corresponding to a plurality of chapters and time information corresponding to the plurality of still images are included in one file. Referring toFIG. 14D , a “chaptering.mp4” file includes not only a plurality of still images corresponding to a plurality of chapters but also time information of each of the still images generated. The “chaptering.mp4” file may have a structure as will be later described with reference toFIG. 17 or may be generated in an ISO Base Media File Format (ISOBMFF). - A language based on which the “chaptering.mp4” file is generated is defined with a “lang” attribute, and a method of reproducing information regarding the plurality of chapters based on the “chaptering.mp4” file is defined with a “contentviewpoint” attribute. If the “contentviewpoint” attribute is defined as “navigation”, then a plurality of still images included in the “chaptering.mp4” file are reproduced at a predetermined speed so that a user may select a still image corresponding to a desired point of time from among the plurality of still images. Otherwise, the plurality of still images included in the “chaptering.mp4” file may be displayed in a scrolling manner so that a user may select a still image among the plurality of still images that are scrolled. A “mimeType” attribute defines the format of the chaptering.mp4″ file including the plurality of still images. If the format of the “chaptering.mp4” file is “mp4”, then the “mimeType” attribute is defined as “jpeg/mp4” since the “chaptering.mp4” file includes the plurality of still image.
-
FIG. 14E illustrates a case where a plurality of files are generated, including information regarding a plurality of chapters, according to an embodiment. Location information of the plurality of files is defined with a “sourceURL” attribute included in a “Url” tag. - As described above, one media data may be divided into a plurality of segments according to time. In this case, a file containing information regarding chapters corresponding to the plurality of segments may be as illustrated in
FIG. 14E . For example, from among the plurality of segments, still images belonging to a plurality of chapters included in a first segment may be included in a “seg-1.mp4” file, and still images belonging to a plurality of chapters included in a second segment reproduced after the first segment may be included in a “seg-2.mp4” file. A “mimeType” attribute and a “contentviewpoint” attribute are as described above with reference toFIG. 14D . -
FIG. 14F illustrates a case where times corresponding to the plurality of files ofFIG. 14E , respectively, are specified, according to an embodiment. Referring toFIG. 14F , the times corresponding to the files that include information regarding a plurality of chapters, respectively, are defined with an “imagePresentationTime” attribute. Referring toFIG. 14F , chapter information regarding media data from “00:00:00” to “00:20:00” is included in a “seg-1.mp4” file, and chapter information regarding media data from “00:20:00” to “00:40:00” is included in a “seg-2.mp4” file. If the files including the information regarding the plurality of chapters correspond to a plurality of media data corresponding to different times, respectively, and times covered by the files are not periodic, then the “imagePresentationTime” attribute may be used to define the starting times of the files, respectively, as illustrated inFIG. 14F . -
FIG. 14G illustrates a case where information regarding a plurality of chapters is included in one file. Compared to the case ofFIG. 14D , a “Representation” tag defining a plurality of media data is used to define a plurality of chapters, instead of a separate tag representing chapter information. When the size of the information regarding the plurality of chapters is not large and there is no need to generate a plurality of files, unlike inFIGS. 14E and 14F , the information regarding the plurality of chapters may be completely included in one file and the file may be defined using the “Representation” tag. -
FIG. 14H illustrates a case where each of the “Url” tags ofFIG. 14C includes attributes defining a language, a title, and a description regarding a corresponding chapter, according to an embodiment. The title and description of a still image corresponding to each of a plurality of chapters are defined with a “title” attribute and a “description” attribute, respectively. The “title” attribute and the “description” attribute of each language defined by a “lang” attribute may be defined. If a “contentviewpoint” attribute is defined as ‘chapter’ unlike inFIGS. 14D to 14G , then still images corresponding to the plurality of chapters are displayed in a thumbnail manner and a user may select one of the displayed still images. -
FIGS. 15A and 15B illustrate schemas of a chapter according to exemplary embodiments.FIG. 16 illustrates information regarding a chapter according to the schemas ofFIGS. 15A and 15B , according to an embodiment. - Referring to
FIGS. 15A and 15B , information regarding a plurality of chapters included in a media presentation description may be produced according to the schemas illustrated inFIGS. 15A and 15B . Specifically, referring toFIG. 16 , a plurality of chapters of content may be defined with a “ChapterItems” tag and a “ChapterItem” tag included in a “ChapterInfo” tag. - The “ChapterItem” tag defines a plurality of still images corresponding to the plurality of chapters. An identifier and time corresponding to each of the still images are defined with an “id” attribute and a “time” attribute, respectively. The title and description of each of the chapters are defined as a “title” tag and a “Description” tag which are lower tags, respectively. A brief description of each of the chapter is defined with a “Tag” tag. The “title” tag, the “Description” tag, and the “Tag” tag are defined in a string, and the total number of strings is not limited. A “lang” attribute defines a language used in each of the “title”, “Tag”, and “Description” tags. Referring to
FIG. 15A , the “lang” attribute may be subject to each of the “title”, “Tag”, and “Description” tags or may be on a same level as the “title”, “Tag”, and “Description” tags. If the same language is used in the “title”, “Tag”, and “Description” and the tags are the same, then the “lang” attribute does not need to be subject to the “title”, “Tag”, and “Description” tags, and may on the same level as the “title”, “Tag”, and “Description” tags and define a language used in “title”, “Tag”, and “Description” tags. - The “ChapterItems” tag includes a plurality of “ChapterItem” tags, and define the resolutions of the still images by using an “imgWidth” attribute and an “imgHeight” attribute. A common part of the URLS of the still images is defined with a “ThumbnailImgUrlTemplate” attribute. The URL of a still image may be determined by using the identifier of the still image defined in the “id” attribute of the “ChapterItem” tag, instead of a “$ID$” of a URL template defined with the “ThumbnailImgUrlTemplate” attribute.
- The media presentation description received in
operation 1320 may include a tag defining a plurality of media data and a tag including information regarding a plurality of chapters as illustrated inFIG. 16 . Also, an additional XML file produced according to the schemas ofFIGS. 15A and 15B may be transmitted or received separately from the media presentation description, inoperation 1320. In other words, theclient 130 may request theserver 120 to provide an XML file produced separately from the media presentation description to include the information regarding the plurality of chapters according to the schemas ofFIGS. 15A and 15B , and theserver 120 may transmit the XML file to theclient 130. - Referring back to
FIG. 13A , inoperation 1330, theclient 130 requests theserver 120 provide chaptering data, and receives the chaptering data from theserver 120. The chaptering data may be data regarding still images corresponding to a plurality of chapters of content that is being streamed. Theclient 130 may transmit an HTTP request for the chaptering data to theserver 120, and receive the chaptering data as a HTTP response. - The media presentation description received in
operation 1320 includes the URLs of the still images corresponding to the plurality of chapters as described above. Theclient 130 requests theserver 120 to provide the chaptering data based on the URLs, and receive the chaptering data as a reply to the request. The chaptering data may include data regarding the still images corresponding to the plurality of chapters of the content. The chaptering data will now be descried in detail with reference toFIG. 17 . -
FIG. 17 is a diagram illustrating the structure ofchaptering data 1700 according to an embodiment. Referring toFIG. 17 , thechaptering data 1700, such as chaptering data received inoperation 1330, includes aheader 1710 and a plurality ofstill image data 1720. Theheader 1710 includes still imagenumber information 1712, still imagetime interval information 1714, and still image data offsetinformation chaptering data 1700. The stillimage number information 1712 defines the total number of still images included in thechaptering data 1700. The still imagetime interval information 1714 defines time intervals between the still images. - The still image data offset
information images 1722 and 724 from among the plurality ofstill image data 1720, respectively. The firststill image 1722, i.e., “Jpg 1”, is defined by the first still image data offsetinformation 1716, and the second still image, i.e., “Jpg 2”, is defined by the second still image data offsetinformation 1718. An absolute data interval between the start of the plurality ofstill image data 1720 and specified still image data may be defined with an offset. - Referring back to
FIG. 13A , inoperation 1340, theclient 130 receiving the chaptering data inoperation 1330 requests theserver 120 to transmit at least one media data from among the plurality of media data. Theclient 130 may select at least one media data encoded to have a quality sufficient for a current streaming environment from among the plurality of media data, based on the information regarding the plurality of media data, and then requests theserver 120 to transmit the selected media data. Also, theclient 130 may transmit an HTTP request for predetermined media data to theserver 120. Then theserver 120 transmits the at least one media data to theclient 130 in response to the request. Theserver 120 may encode the content to have a predetermined quality, divides the encoded content into several segments according to time, and transmit at least one of the segments to theclient 120. Theserver 120 may transmit the predetermined media data to theclient 130 as a HTTP response. - As described above with reference to
FIGS. 5B and 11B , a header of at least one media data selected adaptively to a streaming environment is first received and then the at least one media data may be received. - If the
client 130 selects a particular chapter based on the chaptering data received inoperation 1330, at least one media data encoded to have a quality sufficient for the streaming environment is received, starting from the selected chapter. If the still images included in the chaptering data are displayed on a display device (not shown) of theclient 130 and a user selects a particular chapter, then data streaming may be performed starting from the selected chapter. If a user of theclient 130 selects a particular chapter based on the chaptering data during streaming of the content, theclient 130 may receive at least one media data, starting from the selected chapter. -
FIG. 13B is a flowchart illustrating a streaming method according to another embodiment. InFIG. 13B ,operations operations FIG. 13A , respectively. Inoperation 1312, theclient 130 requests theserver 120 to provide information regarding content, and receives the information regarding the content, which includes the URL of a media presentation description, from theserver 120. Inoperation 1322, theclient 130 requests theserver 120 provide a media presentation description including information regarding a plurality of chapters, based on the information regarding content received inoperation 1312, and then receives the media presentation description from theserver 120. - In
operations client 130 receives the chaptering data based on the information regarding the plurality of media data received inoperation 1322, i.e., the information regarding the plurality of chapters included in the media presentation description. - Specifically, in
operation 1332, theclient 130 may request theserver 120 to provide a header of the chaptering data, and receive the header of the chaptering data from theserver 120. As described above with reference toFIG. 17 , thechaptering data 1700 may include theheader 1710 and the plurality ofstill image data 1720. Inoperation 1332, theclient 130 may request theserver 120 to provide theheader 1710 of thechaptering data 1700, and receive theheader 1710 from theserver 120. Since theheader 1710 includes the stillimage number information 1712, the still imagetime interval information 1714, and the still image data offsetinformation client 130 may request and receive the plurality ofstill image data 1720, based on theheader 1710, inoperation 1342. - In
FIG. 13B ,operation 1352 corresponds tooperation 1340 ofFIG. 13A . Inoperation 1352, theclient 130 requests theserver 120 to transmit at least one media data from among the plurality of media data, and receives the at least one media data from theserver 120. In this case, when a user of theclient 130 selects a particular chapter based on the chaptering data received inoperations client 130 may receive at least one media data, starting from the selected chapter. -
FIG. 18A is a flowchart illustrating a streaming method according to another embodiment. Referring toFIG. 18A , inoperation 1810, theclient 130 requests theserver 120 to transmit information regarding a plurality of media data. Theclient 130 may transmit an HTTP request for a media presentation description to theserver 120, and receive the media presentation description from theserver 120 as a HTTP response. The streaming method ofFIG. 18A is different from the streaming method ofFIG. 13A in that the information regarding the plurality of media data is requested and received without requesting and receiving information regarding content. The media presentation description received inoperation 1810 may be the media presentation descriptions illustrated inFIGS. 14A to 14H . - In
operation 1820, theclient 130 requests theserver 120 to transmit chaptering data, and receives the chaptering data from theserver 120. The chaptering data may be received based on the information regarding the plurality of chapters included in the media presentation description received inoperation 1810. - In
operation 1830, theclient 130 requests theserver 120 to transmit at least one media data from among the plurality of media data. Theclient 130 may select at least one media data encoded to have a quality sufficient for a streaming environment from among the plurality of media data, based on the information regarding the plurality of media data, request theserver 120 to transmit the at least one media data, and then receive the at least one media data from theserver 120. If a particular chapter is selected based on the chaptering data received inoperation 1820, at least one media data may be requested and received, starting from the selected chapter. - As described above with reference to
FIGS. 5B and 11B , a header of at least one media data selected adaptively to a streaming environment may first be received and the at least one media data may then be received. -
FIG. 18B is a flowchart illustrating a streaming method according to another embodiment. InFIG. 18B ,operation 1812 corresponds tooperation 1810 ofFIG. 18A . Inoperation 1812, theclient 130 requests theserver 120 to transmit information regarding a plurality of media data. Theclient 130 may transmit an HTTP request for a media presentation description to theserver 120 and receive the media presentation description from theserver 120 as HTTP response. The streaming method ofFIG. 18B is different from the streaming method ofFIG. 13B in that the information regarding the plurality of media data is requested and received without requesting and receiving information regarding content. The media presentation description received inoperation 1812 may be the media presentation descriptions illustrated inFIGS. 14A to 14H . - In
operation 1822, theclient 130 may request theserver 120 to transmit a header of chaptering data and receive the header of chaptering data from theserver 120. Inoperation 1822, theclient 130 may first request theserver 120 to transmit theheader 1710 of thechaptering data 1700 ofFIG. 17 and receive theheader 1710 from theserver 120. After the client receives theheader 1710 inoperation 1822, the client may request and receive the plurality ofstill image data 1720 based on theheader 1710, inoperation 1832. -
Operation 1842 corresponds tooperation 1830 ofFIG. 18A . Inoperation 1842, theclient 130 requests theserver 120 to transmit at least one media data from among the plurality of media data, based on the chaptering data received inoperations server 120. If a particular chapter is selected based on the chaptering data received inoperations -
FIG. 19 is a block diagram of a mediadata transmitting apparatus 1900 that may be included in theserver 120 ofFIG. 1 , according to an embodiment. Referring toFIG. 19 , the mediadata transmitting apparatus 1900 includes an information transmission or transmittingunit 1910 and a media data transmission or transmittingunit 1920. - The
information transmission unit 1910 receives a request for predetermined information from theclient 130 and transmits the requested information to theclient 130. Theinformation transmission unit 1910 may receive a request for at least one piece from among information regarding content and information regarding a plurality of media data from theclient 130, and transmit the requested information to theclient 130. Theinformation transmission unit 1910 may receive an HTTP request for at least one from among the information regarding the content and the information regarding the plurality of media data from theclient 130, and transmit the requested information to theclient 130 as HTTP response. - The information regarding the plurality of media data that the
information transmission unit 1910 transmits to theclient 130 may be a media presentation description. The media presentation description may be as described above with reference toFIGS. 9A to 9H and 14A to 14H. Thus, as described above with reference toFIGS. 14A to 14H , the media presentation description may include information regarding a plurality of chapters of content that is being streamed. - The media
data transmission unit 1920 receives a request for at least one media data, which is selected adaptively to a streaming environment from among the plurality of media data, from theclient 130, and transmits the requested media data to theclient 130. The mediadata transmission unit 1920 may receive a request for at least one media data, which is selected based on the media presentation description that theinformation transmission unit 1910 transmits to theclient 130, from theclient 130. Theserver 120 may receive a plurality of media data, which are encoded to have different qualities, respectively, from theencoding device 110, store the plurality of media data, and transmit at least one media data requested to theclient 130 from among the stored media data. Otherwise, theserver 120 may receive media data from theencoding device 110 and transmit the media data to theclient 130 in real time, in response to a request from theclient 130. - As described above with reference to
FIGS. 13A , 13B, 18A, and 18B, theclient 130 may request chaptering data based on the media presentation description that includes the information regarding the plurality of chapters. Then, the mediadata transmission unit 1920 may transmit the chaptering data to theclient 130. When theclient 130 requests at least one media data corresponding to a particular chapter, based on the chaptering data, the mediadata transmission unit 1920 may transmit at least one media data to theclient 130, starting from the particular chapter. - The
client 130 may select a chapter during streaming of content, and in this case, the streaming is stopped and at least one media data is transmitted to theclient 130, starting from the selected chapter. - The media
data transmission unit 1920 may transmit the entire chaptering data to theclient 130 at a time, as illustrated inFIGS. 13A and 18A , or may first transmit a header of the chaptering data and then transmit still image data as illustrated inFIGS. 13B and 18B . -
FIG. 20 is a diagram of a mediadata receiving apparatus 2000 that may be included in the client 1300 ofFIG. 1 , according to an embodiment. Referring toFIG. 20 , the mediadata receiving apparatus 2000 of theclient 130 includes aninformation receiving unit 2010 and a mediadata receiving unit 2020. - The
information receiving unit 2010 transmits a request for desired information to theserver 120, and receives the requested information from theserver 120. A request for at least one from among information regarding content and information regarding a plurality of media data may be transmitted to theserver 120 and may be received from theserver 120. According to the embodiment of one ofFIGS. 2A , 2B, 5A, 5B, 11A, 11B, 13A, 13B, 18A, and 18B, an HTTP request for at least one from among the information regarding the content and the information regarding the plurality of media data may be transmitted to theserver 120 and the at least one information may be received from theserver 120 as a reply to the HTTP request. - The information regarding the plurality of media data that the
server 120 transmits to theclient 130 may be a media presentation description. The media presentation description may be as described above with reference toFIGS. 9A to 9H and 14A to 14H. Accordingly, the media presentation description may include information regarding a plurality of chapters of content that is being streamed, as described above with reference toFIGS. 14A to 14H . - The media
data receiving unit 2020 transmits a request for at least one media data selected according to a streaming environment from among the plurality of media data, to theserver 120, and receives the requested media data from theclient 130. The mediadata receiving unit 2020 may transmit the request for the selected media data to theserver 120, based on the information regarding the plurality of media data that theinformation receiving unit 2010 receives from theserver 120. - The media
data receiving unit 2020 may request content sufficient for the streaming environment, based on the media presentation description received from theserver 120. The media presentation description includes information regarding the plurality of chapters as described above. Thus, the mediadata receiving unit 2020 may request and receive chaptering data, based on the media presentation description. The mediadata receiving unit 2020 may select a chapter based on the chaptering data, and may request theserver 120 to provide media data corresponding to the selectedchapter server 120. The mediadata receiving unit 2020 may receive the entire chaptering data from theserver 120 at a time as illustrated inFIGS. 13A and 18A , or may first receive a header of the chaptering data and then receive still image data as illustrated inFIGS. 13B and 18B . - According to the above embodiments, it is possible to stream media data regarding content having a plurality of chapters, adaptively according to a streaming environment.
- While the inventive concept has been particularly shown and described with reference to exemplary embodiments thereof, it will be understood by those of ordinary skill in the art that various changes in form and details may be made therein without departing from the spirit and scope of the inventive concept as defined by the following claims.
- A system according to an embodiment can also be embodied as computer readable codes on a computer readable recording medium.
- For example, a streaming apparatus of a server and a streaming apparatus of a client may include a bus coupled to each unit of the
apparatuses FIGS. 19 and 20 , and at least one processor connected to the bus. Also, the streaming apparatuses may further include a memory that is coupled to the bus so as to store a command, a received message, or a generated message and that is coupled to the at least one processor so as to perform commands as described above. - The computer readable recording medium may be any recording apparatus capable of storing data that is read by a computer system. Examples of the computer readable recording medium include read-only memory (ROM), random-access memory (RAM), CD-ROMs, magnetic tapes, floppy disks, optical data storage devices, etc. The computer readable recording medium can also be distributed over network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
Claims (16)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/051,514 US9197689B2 (en) | 2010-03-19 | 2011-03-18 | Method and apparatus for adaptively streaming content including plurality of chapters |
Applications Claiming Priority (6)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US31550010P | 2010-03-19 | 2010-03-19 | |
US36280510P | 2010-07-09 | 2010-07-09 | |
US201161439985P | 2011-02-07 | 2011-02-07 | |
KR1020110021043A KR20110105710A (en) | 2010-03-19 | 2011-03-09 | Method and apparatus for adaptively streaming content including a plurality of chapters |
KR10-2011-0021043 | 2011-03-09 | ||
US13/051,514 US9197689B2 (en) | 2010-03-19 | 2011-03-18 | Method and apparatus for adaptively streaming content including plurality of chapters |
Publications (2)
Publication Number | Publication Date |
---|---|
US20110231520A1 true US20110231520A1 (en) | 2011-09-22 |
US9197689B2 US9197689B2 (en) | 2015-11-24 |
Family
ID=44955988
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/051,514 Active 2031-10-15 US9197689B2 (en) | 2010-03-19 | 2011-03-18 | Method and apparatus for adaptively streaming content including plurality of chapters |
Country Status (5)
Country | Link |
---|---|
US (1) | US9197689B2 (en) |
EP (1) | EP2548373A4 (en) |
KR (1) | KR20110105710A (en) |
CN (1) | CN102812718A (en) |
WO (1) | WO2011115454A2 (en) |
Cited By (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20110078324A1 (en) * | 2009-09-29 | 2011-03-31 | Sony Corporation | Information processing apparatus and information processing method |
US20120072604A1 (en) * | 2009-05-29 | 2012-03-22 | France Telecom | technique for delivering content to a user |
US20130227106A1 (en) * | 2012-02-23 | 2013-08-29 | Edward Grinshpun | Method and apparatus for video session management |
WO2014011584A1 (en) * | 2012-07-09 | 2014-01-16 | Huawei Technologies Co., Ltd. | Content-specific identification and timing behavior in dynamic adaptive streaming over hypertext transfer protocol |
JP2014532349A (en) * | 2011-09-29 | 2014-12-04 | サムスン エレクトロニクス カンパニー リミテッド | Content transmission / reception method and apparatus |
US20160119677A1 (en) * | 2013-06-12 | 2016-04-28 | Lg Electronics Inc. | Apparatus for transmitting broadcast signals, apparatus for receiving broadcast signals, method for transmitting broadcast signals and method for receiving broadcast signals |
US20160219312A1 (en) * | 2013-09-27 | 2016-07-28 | Lg Electronics Inc. | Apparatus for transmitting broadcast signals, apparatus for receiving broadcast signals, method for transmitting broadcast signals and method for receiving broadcast signals |
US20180352273A1 (en) * | 2017-06-05 | 2018-12-06 | Disney Enterprises Inc. | Real-Time Sub-Second Download And Transcode Of A Video Stream |
CN109905781A (en) * | 2012-11-29 | 2019-06-18 | 三星电子株式会社 | Method and apparatus for receiving packets in a multimedia system |
CN111837403A (en) * | 2018-03-12 | 2020-10-27 | 高通股份有限公司 | Handling interactivity events for streaming media data |
Families Citing this family (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2013077698A1 (en) * | 2011-11-25 | 2013-05-30 | (주)휴맥스 | Method for linking mmt media and dash media |
WO2013077697A1 (en) * | 2011-11-25 | 2013-05-30 | (주)휴맥스 | Method for hybrid delivery of mmt pakcage and content and method for receiving content |
WO2016108268A1 (en) * | 2014-12-29 | 2016-07-07 | ソニー株式会社 | Transmitting device, transmitting method, receiving device and receiving method |
CN107040505B (en) * | 2016-02-04 | 2021-01-26 | 中兴通讯股份有限公司 | Media data transmission method and device |
US10917477B2 (en) * | 2016-05-25 | 2021-02-09 | Samsung Electronics Co., Ltd. | Method and apparatus for MMT integration in CDN |
WO2018057472A1 (en) | 2016-09-26 | 2018-03-29 | Dolby Laboratories Licensing Corporation | Content based stream splitting of video data |
US10778938B2 (en) * | 2018-12-20 | 2020-09-15 | Hulu, LLC | Video chunk combination optimization |
Citations (54)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5612742A (en) * | 1994-10-19 | 1997-03-18 | Imedia Corporation | Method and apparatus for encoding and formatting data representing a video program to provide multiple overlapping presentations of the video program |
US20020161739A1 (en) * | 2000-02-24 | 2002-10-31 | Byeong-Seok Oh | Multimedia contents providing system and a method thereof |
US6499060B1 (en) * | 1999-03-12 | 2002-12-24 | Microsoft Corporation | Media coding for loss recovery with remotely predicted data units |
US6536043B1 (en) * | 1996-02-14 | 2003-03-18 | Roxio, Inc. | Method and systems for scalable representation of multimedia data for progressive asynchronous transmission |
US20030072376A1 (en) * | 2001-10-12 | 2003-04-17 | Koninklijke Philips Electronics N.V. | Transmission of video using variable rate modulation |
US20030177503A1 (en) * | 2000-07-24 | 2003-09-18 | Sanghoon Sull | Method and apparatus for fast metadata generation, delivery and access for live broadcast program |
US20030189649A1 (en) * | 1996-10-25 | 2003-10-09 | Canon Kabushiki Kaisha | Camera control system, camera server, camera client, control method, and storage medium |
US20040064573A1 (en) * | 2000-12-15 | 2004-04-01 | Leaning Anthony R | Transmission and reception of audio and/or video material |
US20040064572A1 (en) * | 2002-09-27 | 2004-04-01 | Katsuhisa Yamaguchi | Digital service system |
US20050018873A1 (en) * | 1993-11-18 | 2005-01-27 | Rhoads Geoffrey B. | Method and system for managing, accessing and paying for the use of copyrighted electronic media |
US6851091B1 (en) * | 1998-09-17 | 2005-02-01 | Sony Corporation | Image display apparatus and method |
US20050071491A1 (en) * | 2003-09-27 | 2005-03-31 | Lg Electronics Inc. | Multimedia streaming service system and method |
US20050102371A1 (en) * | 2003-11-07 | 2005-05-12 | Emre Aksu | Streaming from a server to a client |
US20050183120A1 (en) * | 2004-01-13 | 2005-08-18 | Saurabh Jain | Multi-user personalized digital multimedia distribution methods and systems |
US20050193425A1 (en) * | 2000-07-24 | 2005-09-01 | Sanghoon Sull | Delivery and presentation of content-relevant information associated with frames of audio-visual programs |
US20050198282A1 (en) * | 2002-06-07 | 2005-09-08 | Stahl Thomas A. | Method and apparatus for controlling the distribution of digitally encoded data in a network |
US20050210145A1 (en) * | 2000-07-24 | 2005-09-22 | Vivcom, Inc. | Delivering and processing multimedia bookmark |
US20050262541A1 (en) * | 2004-05-21 | 2005-11-24 | Sony Corporation | Reception device, station selection method, and stream distribution system |
US6996618B2 (en) * | 2001-07-03 | 2006-02-07 | Hewlett-Packard Development Company, L.P. | Method for handling off multiple description streaming media sessions between servers in fixed and mobile streaming media systems |
US7043560B2 (en) * | 2001-06-19 | 2006-05-09 | Nokia, Inc. | Dynamic probing and reporting of bit rate information |
US20060117360A1 (en) * | 2003-01-28 | 2006-06-01 | Cooper Jeffrey A | Robust mode staggercasting fast channel change |
US7057535B2 (en) * | 2004-02-13 | 2006-06-06 | Hewlett-Packard Development Company, L.P. | Methods for scaling encoded data without requiring knowledge of the encoding scheme |
US20070025687A1 (en) * | 2005-07-27 | 2007-02-01 | Samsung Electronics Co., Ltd. | Video playback apparatus, control method thereof and personal video recorder |
US20070101164A1 (en) * | 2005-09-13 | 2007-05-03 | Hideo Ando | Information storage medium, information reproducing apparatus, and information reproducing method |
US20070177854A1 (en) * | 2006-01-31 | 2007-08-02 | Hideo Ando | Information reproducing system using information storage medium |
US7277958B2 (en) * | 2001-03-12 | 2007-10-02 | Edgestream, Inc. | Re-assembly of streaming files from separate connections |
US20080046578A1 (en) * | 2006-08-16 | 2008-02-21 | Van Der Gaast Tjietse | Controlled access to a video recording over an IP multimedia subsystem, IMS, telecommunications network |
US20080162713A1 (en) * | 2006-12-27 | 2008-07-03 | Microsoft Corporation | Media stream slicing and processing load allocation for multi-user media systems |
US20080177865A1 (en) * | 2007-01-19 | 2008-07-24 | Samsung Electronics Co., Ltd | System and method for providing real-time streaming service between terminals |
US20080195743A1 (en) * | 2004-04-30 | 2008-08-14 | Brueck David F | Apparatus, system, and method for multi-bitrate content streaming |
US20090018681A1 (en) * | 2007-07-10 | 2009-01-15 | Samsung Elecatronics Co., Ltd. | Apparatus and method of controlling reproduction of media signal using tag |
US20090031007A1 (en) * | 2007-07-27 | 2009-01-29 | Realnetworks, Inc. | System and method for distributing media data |
US7504968B2 (en) * | 2004-02-13 | 2009-03-17 | Hewlett-Packard Development Company, L.P. | Media data decoding device |
US20090089535A1 (en) * | 2006-01-05 | 2009-04-02 | Thorsten Lohmar | Media container file management |
US20090106288A1 (en) * | 2006-11-21 | 2009-04-23 | Bailiang Yang | Method and system for supporting media data of various coding formats |
US20090110060A1 (en) * | 2007-10-30 | 2009-04-30 | Mauricio Cortes | Method and apparatus for performing lower complexity multiple bit rate video encoding using metadata |
US20090141888A1 (en) * | 2007-12-04 | 2009-06-04 | Samsung Electronics Co., Ltd. | Method and apparatus for performing trick play on scrambled data stream |
US20090161994A1 (en) * | 2007-12-21 | 2009-06-25 | Hand Held Products, Inc | Using metadata tags in video recordings produced by portable encoded information reading terminals |
US20090201487A1 (en) * | 2007-08-17 | 2009-08-13 | Princeton Satellite Systems, Inc. | Multi spectral vision system |
US20090258594A1 (en) * | 2008-04-10 | 2009-10-15 | Martin-Cocher Gaelle | Method and System for Progressive Delivery and Synchronization of Discrete Content in Rich Media Services |
US20090300145A1 (en) * | 2008-05-30 | 2009-12-03 | Microsoft Corporation | Media streaming with seamless ad insertion |
US20100046611A1 (en) * | 2004-08-17 | 2010-02-25 | Tadamasa Toma | Image encoding device, and image decoding device |
US20100054329A1 (en) * | 2008-08-27 | 2010-03-04 | Novafora, Inc. | Method and System for Encoding Order and Frame Type Selection Optimization |
US20100235528A1 (en) * | 2009-03-16 | 2010-09-16 | Microsoft Corporation | Delivering cacheable streaming media presentations |
US20100235427A1 (en) * | 2006-03-28 | 2010-09-16 | Pioneer Corporation | Content delivery system, server device, content delivery method, and program |
US8059711B2 (en) * | 2003-01-28 | 2011-11-15 | Thomson Licensing | Robust mode staggercasting |
US8341662B1 (en) * | 1999-09-30 | 2012-12-25 | International Business Machine Corporation | User-controlled selective overlay in a streaming media |
US8365235B2 (en) * | 2007-12-18 | 2013-01-29 | Netflix, Inc. | Trick play of streaming media |
US20130089142A1 (en) * | 2011-10-10 | 2013-04-11 | Cisco Technology, Inc. | Bandwidth-Friendly Representation Switching in Adaptive Streaming |
US20130298170A1 (en) * | 2009-06-12 | 2013-11-07 | Cygnus Broadband, Inc. | Video streaming quality of experience recovery using a video quality metric |
US20140053214A1 (en) * | 2006-12-13 | 2014-02-20 | Quickplay Media Inc. | Time synchronizing of distinct video and data feeds that are delivered in a single mobile ip data network compatible stream |
US20140143439A1 (en) * | 2012-11-20 | 2014-05-22 | General Instrument Corporation | Method and apparatus for streaming media content to client devices |
US20140185670A1 (en) * | 2012-12-30 | 2014-07-03 | Qualcomm Incorporated | Progressive refinement with temporal scalability support in video coding |
US8838680B1 (en) * | 2011-02-08 | 2014-09-16 | Google Inc. | Buffer objects for web-based configurable pipeline media processing |
Family Cites Families (62)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH0822061B2 (en) | 1993-03-02 | 1996-03-04 | エヌ・ティ・ティ・データ通信株式会社 | Video / audio coding data multiplexing device and multiplexing data reading device |
JP3377788B1 (en) | 1995-09-29 | 2003-02-17 | 松下電器産業株式会社 | Reproduction method, reproduction apparatus, recording method, recording apparatus, optical disk |
SG80607A1 (en) | 1995-09-29 | 2001-05-22 | Matsushita Electric Ind Co Ltd | Method and device for recording and reproducing interleaved bitstream on and from medium |
JP2000013761A (en) | 1998-06-18 | 2000-01-14 | Sony Corp | Device and method for transmitting information, device and method for receiving information and providing medium |
JP4292654B2 (en) | 1999-03-19 | 2009-07-08 | ソニー株式会社 | Recording apparatus and method, reproducing apparatus and method, and recording medium |
JP2001024994A (en) | 1999-07-07 | 2001-01-26 | Matsushita Electric Ind Co Ltd | Transmitter, receiver, recorder and program recording medium |
KR100872138B1 (en) | 2000-02-24 | 2008-12-08 | 오병석 | On-demand multimedia contents providing system and method |
JP4529240B2 (en) | 2000-06-13 | 2010-08-25 | ソニー株式会社 | Information processing apparatus and method, information processing system, and recording medium |
US7103668B1 (en) | 2000-08-29 | 2006-09-05 | Inetcam, Inc. | Method and apparatus for distributing multimedia to remote clients |
FI20011871L (en) | 2001-09-24 | 2003-03-25 | Nokia Corp | Multimedia data processing |
WO2003036980A1 (en) | 2001-10-26 | 2003-05-01 | Koninklijke Philips Electronics N.V. | Spatial scalable compression scheme using spatial sharpness enhancement techniques |
JP2005506816A (en) | 2001-10-26 | 2005-03-03 | コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ | A mechanism of spatially extensible compression using adaptive content filtering |
JP2004088766A (en) | 2002-07-22 | 2004-03-18 | Matsushita Electric Ind Co Ltd | Data management apparatus and data management system |
JP2004140584A (en) | 2002-10-17 | 2004-05-13 | Toshiba Corp | Content delivering/reproducing system, advertisement content inserting method, and client terminal |
JP2004140654A (en) | 2002-10-18 | 2004-05-13 | Nec Engineering Ltd | Method and system for image data transfer |
JP4209665B2 (en) | 2002-12-02 | 2009-01-14 | パナソニック株式会社 | Receiving apparatus and receiving method |
US20040119814A1 (en) | 2002-12-20 | 2004-06-24 | Clisham Allister B. | Video conferencing system and method |
JP2004312304A (en) | 2003-04-04 | 2004-11-04 | Sony Corp | Decoding apparatus and method, reproducing apparatus and method, and storage media |
US6895410B2 (en) | 2003-05-02 | 2005-05-17 | Nokia Corporation | Method and apparatus for providing a multimedia data stream |
KR20040096718A (en) * | 2003-05-10 | 2004-11-17 | 삼성전자주식회사 | Multimedia data decoding apparatus, audio data receiving method and audio data structure therein |
JP2004364227A (en) | 2003-06-09 | 2004-12-24 | Sony Corp | Receiving apparatus, tuning method, and stream distribution system |
JP2005039667A (en) | 2003-07-17 | 2005-02-10 | Sony Corp | System and method for transmitting and receiving data, data receiver and data transmitter |
JP2005073138A (en) | 2003-08-27 | 2005-03-17 | Casio Comput Co Ltd | Information reproducing apparatus and information reproducing processing program |
KR100547139B1 (en) | 2003-09-03 | 2006-01-26 | 학교법인 고황재단 | Method and apparatus for transmitting MBP media data using the ITF FOS protocol |
WO2005043783A1 (en) | 2003-10-30 | 2005-05-12 | Matsushita Electric Industrial Co., Ltd. | Mobile-terminal-oriented transmission method and apparatus |
US8250622B2 (en) | 2003-10-30 | 2012-08-21 | Panasonic Corporation | Method and apparatus for broadcasting to a portable terminal |
KR101022471B1 (en) | 2004-01-17 | 2011-03-16 | 삼성전자주식회사 | Information storage medium recording multimedia data, method of reproducing and reproducing apparatus |
JP2005229153A (en) | 2004-02-10 | 2005-08-25 | Sony Corp | Dimmer system and dimmer method, distributor and distribution method, receiver and reception method, recorder and recording method, and reproducing apparatus and reproducing method |
KR101145261B1 (en) | 2004-02-27 | 2012-05-24 | 삼성전자주식회사 | Information storage medium containing multimedia data, reproducing method and apparatus thereof |
JP2005303927A (en) | 2004-04-15 | 2005-10-27 | Sony Corp | Information processing system, information processing apparatus and method, recording medium, and program |
CN101014947A (en) | 2004-04-30 | 2007-08-08 | 移动网络有限公司 | Apparatus, system, and method for adaptive-rate shifting of streaming content |
US7543073B2 (en) | 2004-12-10 | 2009-06-02 | Microsoft Corporation | System and process for performing an exponentially weighted moving average on streaming data to establish a moving average bit rate |
US20080301380A1 (en) | 2005-02-18 | 2008-12-04 | Masanori Itho | Data Processor |
WO2006105158A2 (en) | 2005-03-29 | 2006-10-05 | Microsoft Corp. | System and method for transferring web page data |
JP4541962B2 (en) | 2005-04-25 | 2010-09-08 | パナソニック株式会社 | Multiplexer, playback device |
JP4356645B2 (en) | 2005-04-28 | 2009-11-04 | ソニー株式会社 | Subtitle generation apparatus and method |
JP2007011584A (en) | 2005-06-29 | 2007-01-18 | Fujifilm Holdings Corp | Multimedia data processor, multimedia data processing method, and multimedia data processing program |
JP2007025959A (en) | 2005-07-14 | 2007-02-01 | Fujifilm Holdings Corp | Multimedia data processor, multimedia data processing method and multimedia data processing program |
US20080040498A1 (en) | 2006-08-10 | 2008-02-14 | Nokia Corporation | System and method of XML based content fragmentation for rich media streaming |
JP4785687B2 (en) | 2006-09-15 | 2011-10-05 | キヤノン株式会社 | Image control apparatus and method |
JP4862600B2 (en) | 2006-10-12 | 2012-01-25 | パナソニック電工株式会社 | Display device for residential equipment monitoring system |
KR100805308B1 (en) | 2006-10-13 | 2008-02-20 | 에스케이 텔레콤주식회사 | Content recommendation service method in mobile communication terminal and mobile communication terminal for same |
EP2103129A4 (en) | 2006-11-20 | 2014-07-23 | Sk Planet Co Ltd | System, server and method for providing supplementary information service related to broadcast content |
AU2007336816C1 (en) | 2006-12-22 | 2011-10-06 | Apple Inc. | Tagging media assets, locations, and advertisements |
CN100551043C (en) | 2007-02-08 | 2009-10-14 | 华为技术有限公司 | A kind of method of fast forwarding and fast rewinding playing video data and streaming media server |
JP2008236667A (en) | 2007-03-23 | 2008-10-02 | Victor Co Of Japan Ltd | Digital broadcast receiver |
US8949926B2 (en) | 2007-04-23 | 2015-02-03 | Lg Electronics Inc. | Method for protecting contents, method for sharing contents and device based on security level |
KR101369747B1 (en) | 2007-05-10 | 2014-03-06 | 삼성전자주식회사 | Information recording medium, appratus and method for reproducing video contents |
CN101321265B (en) | 2007-06-07 | 2011-03-16 | 中兴通讯股份有限公司 | Method and system for implementing peer-to-peer network media order frame-across broadcast mode |
JP4609802B2 (en) | 2007-07-06 | 2011-01-12 | Necアクセステクニカ株式会社 | Home gateway |
CN101365128A (en) | 2007-08-10 | 2009-02-11 | 中兴通讯股份有限公司 | Peer-to-peer network system for synthetic video service |
KR101128848B1 (en) | 2007-09-13 | 2012-03-23 | 에스케이플래닛 주식회사 | Server, System and Method for Providing Multi Angle Mobile Broadcasting Service |
KR20090036765A (en) | 2007-10-10 | 2009-04-15 | 삼성전자주식회사 | How to set output bitrate for video data transmission in WiBro system |
KR100889986B1 (en) | 2007-11-30 | 2009-03-25 | 엔에이치엔(주) | System and Method for Providing Suggested Keywords for Interactive Broadcasting Terminal |
KR101529503B1 (en) | 2007-12-14 | 2015-06-30 | 엘지전자 주식회사 | A Method For Downloading/Providing Contents, Electronic Device and Contents Server Therefor |
US8140390B2 (en) | 2008-02-12 | 2012-03-20 | At&T Intellectual Property I, Lp | System and method for displaying partial advertising data during trick play |
CN101247511B (en) | 2008-03-21 | 2016-04-06 | 中国电信股份有限公司 | IPTV content correlated information exhibition method and system |
JPWO2009119394A1 (en) | 2008-03-28 | 2011-07-21 | 日本電気株式会社 | Video acquisition method, video acquisition device, video acquisition system, and video acquisition program |
US8387150B2 (en) | 2008-06-27 | 2013-02-26 | Microsoft Corporation | Segmented media content rights management |
KR20100007368A (en) | 2008-07-14 | 2010-01-22 | 주식회사 케이티 | System for controlling bit rate of streaming service and method thereof |
CN101459809B (en) | 2008-11-26 | 2010-06-23 | 北京惠信博思技术有限公司 | Method and system for digital television program playing |
JP2009159625A (en) | 2009-04-03 | 2009-07-16 | Hitachi Ltd | How to store digital broadcast streams |
-
2011
- 2011-03-09 KR KR1020110021043A patent/KR20110105710A/en not_active Withdrawn
- 2011-03-18 US US13/051,514 patent/US9197689B2/en active Active
- 2011-03-18 CN CN2011800146968A patent/CN102812718A/en active Pending
- 2011-03-18 WO PCT/KR2011/001898 patent/WO2011115454A2/en active Application Filing
- 2011-03-18 EP EP11756585.3A patent/EP2548373A4/en not_active Withdrawn
Patent Citations (54)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050018873A1 (en) * | 1993-11-18 | 2005-01-27 | Rhoads Geoffrey B. | Method and system for managing, accessing and paying for the use of copyrighted electronic media |
US5612742A (en) * | 1994-10-19 | 1997-03-18 | Imedia Corporation | Method and apparatus for encoding and formatting data representing a video program to provide multiple overlapping presentations of the video program |
US6536043B1 (en) * | 1996-02-14 | 2003-03-18 | Roxio, Inc. | Method and systems for scalable representation of multimedia data for progressive asynchronous transmission |
US20030189649A1 (en) * | 1996-10-25 | 2003-10-09 | Canon Kabushiki Kaisha | Camera control system, camera server, camera client, control method, and storage medium |
US6851091B1 (en) * | 1998-09-17 | 2005-02-01 | Sony Corporation | Image display apparatus and method |
US6499060B1 (en) * | 1999-03-12 | 2002-12-24 | Microsoft Corporation | Media coding for loss recovery with remotely predicted data units |
US8341662B1 (en) * | 1999-09-30 | 2012-12-25 | International Business Machine Corporation | User-controlled selective overlay in a streaming media |
US20020161739A1 (en) * | 2000-02-24 | 2002-10-31 | Byeong-Seok Oh | Multimedia contents providing system and a method thereof |
US20050193425A1 (en) * | 2000-07-24 | 2005-09-01 | Sanghoon Sull | Delivery and presentation of content-relevant information associated with frames of audio-visual programs |
US20050210145A1 (en) * | 2000-07-24 | 2005-09-22 | Vivcom, Inc. | Delivering and processing multimedia bookmark |
US20030177503A1 (en) * | 2000-07-24 | 2003-09-18 | Sanghoon Sull | Method and apparatus for fast metadata generation, delivery and access for live broadcast program |
US20040064573A1 (en) * | 2000-12-15 | 2004-04-01 | Leaning Anthony R | Transmission and reception of audio and/or video material |
US7277958B2 (en) * | 2001-03-12 | 2007-10-02 | Edgestream, Inc. | Re-assembly of streaming files from separate connections |
US7043560B2 (en) * | 2001-06-19 | 2006-05-09 | Nokia, Inc. | Dynamic probing and reporting of bit rate information |
US6996618B2 (en) * | 2001-07-03 | 2006-02-07 | Hewlett-Packard Development Company, L.P. | Method for handling off multiple description streaming media sessions between servers in fixed and mobile streaming media systems |
US20030072376A1 (en) * | 2001-10-12 | 2003-04-17 | Koninklijke Philips Electronics N.V. | Transmission of video using variable rate modulation |
US20050198282A1 (en) * | 2002-06-07 | 2005-09-08 | Stahl Thomas A. | Method and apparatus for controlling the distribution of digitally encoded data in a network |
US20040064572A1 (en) * | 2002-09-27 | 2004-04-01 | Katsuhisa Yamaguchi | Digital service system |
US20060117360A1 (en) * | 2003-01-28 | 2006-06-01 | Cooper Jeffrey A | Robust mode staggercasting fast channel change |
US8059711B2 (en) * | 2003-01-28 | 2011-11-15 | Thomson Licensing | Robust mode staggercasting |
US20050071491A1 (en) * | 2003-09-27 | 2005-03-31 | Lg Electronics Inc. | Multimedia streaming service system and method |
US20050102371A1 (en) * | 2003-11-07 | 2005-05-12 | Emre Aksu | Streaming from a server to a client |
US20050183120A1 (en) * | 2004-01-13 | 2005-08-18 | Saurabh Jain | Multi-user personalized digital multimedia distribution methods and systems |
US7057535B2 (en) * | 2004-02-13 | 2006-06-06 | Hewlett-Packard Development Company, L.P. | Methods for scaling encoded data without requiring knowledge of the encoding scheme |
US7504968B2 (en) * | 2004-02-13 | 2009-03-17 | Hewlett-Packard Development Company, L.P. | Media data decoding device |
US20080195743A1 (en) * | 2004-04-30 | 2008-08-14 | Brueck David F | Apparatus, system, and method for multi-bitrate content streaming |
US20050262541A1 (en) * | 2004-05-21 | 2005-11-24 | Sony Corporation | Reception device, station selection method, and stream distribution system |
US20100046611A1 (en) * | 2004-08-17 | 2010-02-25 | Tadamasa Toma | Image encoding device, and image decoding device |
US20070025687A1 (en) * | 2005-07-27 | 2007-02-01 | Samsung Electronics Co., Ltd. | Video playback apparatus, control method thereof and personal video recorder |
US20070101164A1 (en) * | 2005-09-13 | 2007-05-03 | Hideo Ando | Information storage medium, information reproducing apparatus, and information reproducing method |
US20090089535A1 (en) * | 2006-01-05 | 2009-04-02 | Thorsten Lohmar | Media container file management |
US20070177854A1 (en) * | 2006-01-31 | 2007-08-02 | Hideo Ando | Information reproducing system using information storage medium |
US20100235427A1 (en) * | 2006-03-28 | 2010-09-16 | Pioneer Corporation | Content delivery system, server device, content delivery method, and program |
US20080046578A1 (en) * | 2006-08-16 | 2008-02-21 | Van Der Gaast Tjietse | Controlled access to a video recording over an IP multimedia subsystem, IMS, telecommunications network |
US20090106288A1 (en) * | 2006-11-21 | 2009-04-23 | Bailiang Yang | Method and system for supporting media data of various coding formats |
US20140053214A1 (en) * | 2006-12-13 | 2014-02-20 | Quickplay Media Inc. | Time synchronizing of distinct video and data feeds that are delivered in a single mobile ip data network compatible stream |
US20080162713A1 (en) * | 2006-12-27 | 2008-07-03 | Microsoft Corporation | Media stream slicing and processing load allocation for multi-user media systems |
US20080177865A1 (en) * | 2007-01-19 | 2008-07-24 | Samsung Electronics Co., Ltd | System and method for providing real-time streaming service between terminals |
US20090018681A1 (en) * | 2007-07-10 | 2009-01-15 | Samsung Elecatronics Co., Ltd. | Apparatus and method of controlling reproduction of media signal using tag |
US20090031007A1 (en) * | 2007-07-27 | 2009-01-29 | Realnetworks, Inc. | System and method for distributing media data |
US20090201487A1 (en) * | 2007-08-17 | 2009-08-13 | Princeton Satellite Systems, Inc. | Multi spectral vision system |
US20090110060A1 (en) * | 2007-10-30 | 2009-04-30 | Mauricio Cortes | Method and apparatus for performing lower complexity multiple bit rate video encoding using metadata |
US20090141888A1 (en) * | 2007-12-04 | 2009-06-04 | Samsung Electronics Co., Ltd. | Method and apparatus for performing trick play on scrambled data stream |
US8365235B2 (en) * | 2007-12-18 | 2013-01-29 | Netflix, Inc. | Trick play of streaming media |
US20090161994A1 (en) * | 2007-12-21 | 2009-06-25 | Hand Held Products, Inc | Using metadata tags in video recordings produced by portable encoded information reading terminals |
US20090258594A1 (en) * | 2008-04-10 | 2009-10-15 | Martin-Cocher Gaelle | Method and System for Progressive Delivery and Synchronization of Discrete Content in Rich Media Services |
US20090300145A1 (en) * | 2008-05-30 | 2009-12-03 | Microsoft Corporation | Media streaming with seamless ad insertion |
US20100054329A1 (en) * | 2008-08-27 | 2010-03-04 | Novafora, Inc. | Method and System for Encoding Order and Frame Type Selection Optimization |
US20100235528A1 (en) * | 2009-03-16 | 2010-09-16 | Microsoft Corporation | Delivering cacheable streaming media presentations |
US20130298170A1 (en) * | 2009-06-12 | 2013-11-07 | Cygnus Broadband, Inc. | Video streaming quality of experience recovery using a video quality metric |
US8838680B1 (en) * | 2011-02-08 | 2014-09-16 | Google Inc. | Buffer objects for web-based configurable pipeline media processing |
US20130089142A1 (en) * | 2011-10-10 | 2013-04-11 | Cisco Technology, Inc. | Bandwidth-Friendly Representation Switching in Adaptive Streaming |
US20140143439A1 (en) * | 2012-11-20 | 2014-05-22 | General Instrument Corporation | Method and apparatus for streaming media content to client devices |
US20140185670A1 (en) * | 2012-12-30 | 2014-07-03 | Qualcomm Incorporated | Progressive refinement with temporal scalability support in video coding |
Cited By (25)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120072604A1 (en) * | 2009-05-29 | 2012-03-22 | France Telecom | technique for delivering content to a user |
US20110078324A1 (en) * | 2009-09-29 | 2011-03-31 | Sony Corporation | Information processing apparatus and information processing method |
US8312162B2 (en) * | 2009-09-29 | 2012-11-13 | Sony Corporation | Information processing apparatus and information processing method |
US11647071B2 (en) | 2011-09-29 | 2023-05-09 | Samsung Electronics Co., Ltd. | Method and apparatus for transmitting and receiving content |
JP2014532349A (en) * | 2011-09-29 | 2014-12-04 | サムスン エレクトロニクス カンパニー リミテッド | Content transmission / reception method and apparatus |
US11082479B2 (en) | 2011-09-29 | 2021-08-03 | Samsung Electronics Co., Ltd. | Method and apparatus for transmitting and receiving content |
US10659519B2 (en) | 2011-09-29 | 2020-05-19 | Samsung Electronics Co., Ltd. | Method and apparatus for transmitting and receiving content |
US20130227106A1 (en) * | 2012-02-23 | 2013-08-29 | Edward Grinshpun | Method and apparatus for video session management |
US10616297B2 (en) | 2012-07-09 | 2020-04-07 | Futurewei Technologies, Inc. | Content-specific identification and timing behavior in dynamic adaptive streaming over hypertext transfer protocol |
CN104471914A (en) * | 2012-07-09 | 2015-03-25 | 华为技术有限公司 | Content-specific identification and timing behavior in dynamic adaptive streaming over hypertext transfer protocol |
WO2014011584A1 (en) * | 2012-07-09 | 2014-01-16 | Huawei Technologies Co., Ltd. | Content-specific identification and timing behavior in dynamic adaptive streaming over hypertext transfer protocol |
EP3091711A1 (en) * | 2012-07-09 | 2016-11-09 | Huawei Technologies Co., Ltd. | Content-specific identification and timing behavior in dynamic adaptive streaming over hypertext transfer protocol |
CN109905781A (en) * | 2012-11-29 | 2019-06-18 | 三星电子株式会社 | Method and apparatus for receiving packets in a multimedia system |
US20160119677A1 (en) * | 2013-06-12 | 2016-04-28 | Lg Electronics Inc. | Apparatus for transmitting broadcast signals, apparatus for receiving broadcast signals, method for transmitting broadcast signals and method for receiving broadcast signals |
US9800934B2 (en) * | 2013-06-12 | 2017-10-24 | Lg Electronics Inc. | Apparatus for transmitting broadcast signals, apparatus for receiving broadcast signals, method for transmitting broadcast signals and method for receiving broadcast signals |
US10904620B2 (en) * | 2013-06-12 | 2021-01-26 | Lg Electronics, Inc. | Apparatus for transmitting broadcast signals, apparatus for receiving broadcast signals, method for transmitting broadcast signals and method for receiving broadcast signals |
US10448105B2 (en) | 2013-06-12 | 2019-10-15 | Lg Electronics Inc. | Apparatus for transmitting broadcast signals, apparatus for receiving broadcast signals, method for transmitting broadcast signals and method for receiving broadcast signals |
US20200029123A1 (en) * | 2013-06-12 | 2020-01-23 | Lg Electronics Inc. | Apparatus for transmitting broadcast signals, apparatus for receiving broadcast signals, method for transmitting broadcast signals and method for receiving broadcast signals |
US10334295B2 (en) * | 2013-09-27 | 2019-06-25 | Lg Electronics Inc. | Apparatus for transmitting broadcast signals, apparatus for receiving broadcast signals, method for transmitting broadcast signals and method for receiving broadcast signals |
US20160219312A1 (en) * | 2013-09-27 | 2016-07-28 | Lg Electronics Inc. | Apparatus for transmitting broadcast signals, apparatus for receiving broadcast signals, method for transmitting broadcast signals and method for receiving broadcast signals |
US10027999B2 (en) * | 2013-09-27 | 2018-07-17 | Lg Electronics Inc. | Apparatus for transmitting broadcast signals, apparatus for receiving broadcast signals, method for transmitting broadcast signals and method for receiving broadcast signals |
US9723341B2 (en) * | 2013-09-27 | 2017-08-01 | Lg Electronics Inc. | Apparatus for transmitting broadcast signals, apparatus for receiving broadcast signals, method for transmitting broadcast signals and method for receiving broadcast signals |
US20180352273A1 (en) * | 2017-06-05 | 2018-12-06 | Disney Enterprises Inc. | Real-Time Sub-Second Download And Transcode Of A Video Stream |
US10701413B2 (en) * | 2017-06-05 | 2020-06-30 | Disney Enterprises, Inc. | Real-time sub-second download and transcode of a video stream |
CN111837403A (en) * | 2018-03-12 | 2020-10-27 | 高通股份有限公司 | Handling interactivity events for streaming media data |
Also Published As
Publication number | Publication date |
---|---|
EP2548373A2 (en) | 2013-01-23 |
US9197689B2 (en) | 2015-11-24 |
CN102812718A (en) | 2012-12-05 |
KR20110105710A (en) | 2011-09-27 |
WO2011115454A3 (en) | 2012-01-12 |
WO2011115454A2 (en) | 2011-09-22 |
EP2548373A4 (en) | 2014-05-28 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9197689B2 (en) | Method and apparatus for adaptively streaming content including plurality of chapters | |
US9967598B2 (en) | Adaptive streaming method and apparatus | |
US9277252B2 (en) | Method and apparatus for adaptive streaming based on plurality of elements for determining quality of content | |
US9756364B2 (en) | Streaming method and apparatus operating by inserting other content into main content | |
US10425666B2 (en) | Method and apparatus for adaptive streaming using segmentation | |
EP2499794B1 (en) | Method and apparatus for transmitting and receiving data | |
US9860573B2 (en) | Method and apparatus for providing and receiving data | |
US9699486B2 (en) | Method and apparatus for transmitting and receiving data | |
US20120272281A1 (en) | Method and apparatus for transmitting media data, and method and apparatus for receving media data |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: SAMSUNG ELECTRONICS CO., LTD., KOREA, REPUBLIC OF Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:HA, HO-JIN;CHA, SOON-BACK;KEUM, JI-EUN;AND OTHERS;REEL/FRAME:025982/0167 Effective date: 20110318 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 4 |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 8 |