WO2013098468A1 - Method and apparatus for flexible caching of delivered media - Google Patents

Method and apparatus for flexible caching of delivered media Download PDF

Info

Publication number
WO2013098468A1
WO2013098468A1 PCT/FI2012/051189 FI2012051189W WO2013098468A1 WO 2013098468 A1 WO2013098468 A1 WO 2013098468A1 FI 2012051189 W FI2012051189 W FI 2012051189W WO 2013098468 A1 WO2013098468 A1 WO 2013098468A1
Authority
WO
WIPO (PCT)
Prior art keywords
representation
segment
primary
alternative
cached
Prior art date
Application number
PCT/FI2012/051189
Other languages
French (fr)
Inventor
Chenghao Liu
Miska Hannuksela
Original Assignee
Nokia Corporation
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Nokia Corporation filed Critical Nokia Corporation
Priority to CN201280065154.8A priority Critical patent/CN104025548B/en
Priority to PL12862371T priority patent/PL2798818T3/en
Priority to ES12862371T priority patent/ES2731948T3/en
Priority to EP12862371.7A priority patent/EP2798818B1/en
Publication of WO2013098468A1 publication Critical patent/WO2013098468A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/568Storing data temporarily at an intermediate stage, e.g. caching
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/61Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
    • H04L65/612Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio for unicast
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/75Media network packet handling
    • H04L65/765Media network packet handling intermediate
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/80Responding to QoS
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/21Server components or server architectures
    • H04N21/222Secondary servers, e.g. proxy server, cable television Head-end
    • H04N21/2225Local VOD servers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/234Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
    • H04N21/2343Processing 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/23439Processing 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
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network 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/61Network physical structure; Signal processing
    • H04N21/6106Network physical structure; Signal processing specially adapted to the downstream path of the transmission network
    • H04N21/6125Network physical structure; Signal processing specially adapted to the downstream path of the transmission network involving transmission via Internet
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network 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/63Control signaling related to video distribution between client, server and network components; Network processes for video distribution between server and clients or between remote clients, e.g. transmitting basic layer and enhancement layers over different transmission paths, setting up a peer-to-peer communication via Internet between remote STB's; Communication protocols; Addressing
    • H04N21/637Control signals issued by the client directed to the server or network components
    • H04N21/6377Control signals issued by the client directed to the server or network components directed to server
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/80Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
    • H04N21/83Generation or processing of protective or descriptive data associated with content; Content structuring
    • H04N21/845Structuring of content, e.g. decomposing content into time segments
    • H04N21/8456Structuring of content, e.g. decomposing content into time segments by decomposing the content in the time domain, e.g. in time segments

Definitions

  • Embodiments of the present invention relate generally to communication technology, and, more particularly, relate to a method and apparatus for accepting multiple representations via Dynamic Adaptive Streaming over Hypertext Transfer Protocol (HTTP) (DASH).
  • HTTP Dynamic Adaptive Streaming over Hypertext Transfer Protocol
  • E-UTRAN evolved-UTRAN
  • LTE Long Term Evolution
  • DASH digital versatile disc
  • the DASH standard provides media content for distribution based on a media presentation structure.
  • the media presentation structure of DASH focuses on the media content and not the method(s) a client can use for accessing the content.
  • a streaming client apparatus operation may be modified in such a way that the streaming client apparatus grants permission to have a respective segment from certain other representations as a response to a segment request.
  • some example embodiments may modify a proxy operation such that a proxy cache apparatus may be configured to determine if alternative segments can be used in responses and, in an instance in which the request segment or any of the alternative segments are readily available in the proxy cache apparatus, selecting one of those segments to respond to the segment request.
  • a method comprises causing a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a caching proxy.
  • the method of this embodiment may also include causing the caching proxy to respond with at least one of the primary representation or the alternative representation based on the caching status at a caching proxy.
  • the caching proxy is configured to determine whether the request enables an alternative representation to be included in a response.
  • the method of this embodiment may also include receiving at least one of the primary representation or the alternative representation for the segment from the caching proxy.
  • an apparatus in another embodiment, includes at least one processor and at least one memory including computer program code with the at least one memory and the computer program code being configured, with the at least one processor, to cause the apparatus to at least cause a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a caching proxy.
  • the at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to cause the caching proxy to respond with at least one of the primary representation or the alternative representation based on the caching status at a caching proxy.
  • the caching proxy is configured to determine whether the request enables an alternative representation to be included in a response.
  • the at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to receive at least one of the primary representation or the alternative representation for the segment from the caching proxy.
  • a computer program product includes at least one non-transitory computer-readable storage medium having computer-readable program instruction stored therein with the computer-readable program instructions including program instructions configured to cause a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a caching proxy.
  • the computer-readable program instructions may also include program instructions configured to cause the caching proxy to respond with at least one of the primary representation or the alternative representation based on the caching status at a caching proxy.
  • the caching proxy is configured to determine whether the request enables an alternative representation to be included in a response.
  • the computer-readable program instructions may also include program instructions configured to receive at least one of the primary representation or the alternative representation for the segment from the caching proxy.
  • an apparatus in yet another embodiment, includes means for causing a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a caching proxy.
  • the apparatus of this embodiment may also include means for causing the caching proxy to respond with at least one of the primary representation or the alternative representation based on the caching status at a caching proxy.
  • the caching proxy is configured to determine whether the request enables an alternative representation to be included in a response.
  • the apparatus of this embodiment may also include means for receiving at least one of the primary representation or the alternative representation for the segment from the caching proxy.
  • a method comprises causing a request for a caching proxy to provide a selectable cached alternative representation uniform resource indicator (URI) to be transmitted.
  • the method of this embodiment may also include receiving a list and range of URFs for the selectable cached alternative representation for agent driven content negotiation.
  • the method of this embodiment may also include causing a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted.
  • the resource is requested based on predetermined selection criteria.
  • an apparatus in another embodiment, includes at least one processor and at least one memory including computer program code with the at least one memory and the computer program code being configured, with the at least one processor, to cause the apparatus to at least cause a request for a caching proxy to provide a selectable cached alternative representation URI to be transmitted.
  • the at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to receive a list and range of URI's for the selectable cached alternative representation for agent driven content negotiation.
  • the at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to cause a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted.
  • the resource is requested based on predetermined selection criteria.
  • a computer program product includes at least one non-transitory computer-readable storage medium having computer-readable program instruction stored therein with the computer-readable program instructions including program instructions configured to cause a request for a caching proxy to provide a selectable cached alternative representation URI to be transmitted.
  • the computer-readable program instructions may also include program instructions configured to receive a list and range of URI's for the selectable cached alternative representation for agent driven content negotiation.
  • the computer-readable program instructions may also include program instructions configured to cause a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted. In some example embodiments, the resource is requested based on predetermined selection criteria.
  • an apparatus in yet another embodiment, includes means for causing a request for a caching proxy to provide a selectable cached alternative representation URI to be transmitted.
  • the apparatus of this embodiment may also include means for receiving a list and range of URI's for the selectable cached alternative representation for agent driven content negotiation.
  • the apparatus of this embodiment may also include means for causing a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted. In some example embodiments, the resource is requested based on predetermined selection criteria.
  • a method comprises receiving a request for at least one of a primary representation or an alternative representation for a segment.
  • the method of this embodiment may also include determining whether the request comprises an indication that a client will accept the alternative representation of the segment.
  • the method of this embodiment may also include determining whether at least one of a primary URI associated with the primary representation is cached.
  • the method of this embodiment may also include causing the primary representation of the segment to be transmitted in an instance in which the primary URI is cached.
  • the method of this embodiment may also include determining whether at least one of the alternative URIs associated with the alternative representations is cached.
  • the method of this embodiment may also include causing the alternative representation of the segment to be transmitted in an instance in which at least one of the alternative URIs is cached and the primary URI is not cached.
  • an apparatus in another embodiment, includes at least one processor and at least one memory including computer program code with the at least one memory and the computer program code being configured, with the at least one processor, to cause the apparatus to at least receive a request for at least one of a primary representation or an alternative representation for a segment.
  • the at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to determine whether the request comprises an indication that a client will accept the alternative representation of the segment.
  • the at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to determine whether at least one of a primary URI associated with the primary representation is cached.
  • the at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to cause the primary representation of the segment to be transmitted in an instance in which the primary URI is cached.
  • the at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to determine whether at least one of the alternative URIs associated with the alternative representations is cached.
  • the at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to cause the alternative representation of the segment to be transmitted in an instance in which at least one of the alternative URIs is cached and the primary URI is not cached.
  • a computer program product includes at least one non-transitory computer-readable storage medium having computer-readable program instruction stored therein with the computer-readable program instructions including program instructions configured to receive a request for at least one of a primary representation or an alternative representation for a segment.
  • the computer- readable program instructions may also include program instructions configured to determine whether the request comprises an indication that a client will accept the alternative representation of the segment.
  • the computer-readable program instructions may also include program instructions configured to determine whether at least one of a primary URI associated with the primary representation is cached.
  • the computer-readable program instructions may also include program instructions configured to cause the primary representation of the segment to be transmitted in an instance in which the primary URI is cached.
  • the computer-readable program instructions may also include program instructions configured to determine whether at least one of the alternative URIs associated with the alternative representations is cached.
  • the computer-readable program instructions may also include program instructions configured to cause the alternative representation of the segment to be transmitted in an instance in which at least one of the alternative URIs is cached and the primary URI is not cached.
  • an apparatus in yet another embodiment, includes means for receiving a request for at least one of a primary representation or an alternative representation for a segment.
  • the apparatus of this embodiment may also include means for determining whether the request comprises an indication that a client will accept the alternative representation of the segment.
  • the apparatus of this embodiment may also include means for determining whether at least one of a primary URI associated with the primary representation is cached.
  • the apparatus of this embodiment may also include means for causing the primary representation of the segment to be transmitted in an instance in which the primary URI is cached.
  • the apparatus of this embodiment may also include means for determining whether at least one of the alternative URIs associated with the alternative representations is cached.
  • the apparatus of this embodiment may also include means for causing the alternative representation of the segment to be transmitted in an instance in which at least one of the alternative URIs is cached and the primary URI is not cached.
  • a method comprises receiving a request for at least one of a primary representation or an alternative representation for a segment.
  • the method of this embodiment may also include determining whether the request comprises an indication that a client will accept the alternative representation of the segment.
  • the method of this embodiment may also include causing a list and range of URI's for a selectable cached alternative representation for agent driven content negotiation to be transmitted.
  • the method of this embodiment may also include receiving a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
  • an apparatus in another embodiment, includes at least one processor and at least one memory including computer program code with the at least one memory and the computer program code being configured, with the at least one processor, to cause the apparatus to at least receive a request for at least one of a primary representation or an alternative representation for a segment.
  • the at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to determine whether the request comprises an indication that a client will accept the alternative representation of the segment.
  • the at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to cause a list and range of URI's for a selectable cached alternative representation for agent driven content negotiation to be transmitted.
  • the at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to receive a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
  • a computer program product includes at least one non-transitory computer-readable storage medium having computer-readable program instruction stored therein with the computer-readable program instructions including program instructions configured to receive a request for at least one of a primary representation or an alternative representation for a segment.
  • the computer- readable program instructions may also include program instructions configured to determine whether the request comprises an indication that a client will accept the alternative representation of the segment.
  • the computer-readable program instructions may also include program instructions configured to cause a list and range of URI's for a selectable cached alternative representation for agent driven content negotiation to be transmitted.
  • the computer-readable program instructions may also include program instructions configured to receive a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
  • an apparatus in yet another embodiment, includes means for receiving a request for at least one of a primary representation or an alternative representation for a segment.
  • the apparatus of this embodiment may also include means for determining whether the request comprises an indication that a client will accept the alternative representation of the segment.
  • the apparatus of this embodiment may also include means for causing a list and range of URI's for a selectable cached alternative representation for agent driven content negotiation to be transmitted.
  • the apparatus of this embodiment may also include means for receiving a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
  • Figure 1 illustrates a block diagram of a system for accepting multiple representations for DASH according to some example embodiments of the current invention
  • Figure 2 illustrates a block diagram of a mobile terminal representative of one embodiment of a streaming client apparatus according to some example embodiments of the current invention
  • Figure 3 illustrates a block diagram of an apparatus according to some example embodiments of the current invention
  • Figures 4a and 4b illustrate an example representation fluctuation at a client
  • Figure 5 illustrates a flowchart according to an example method for operation of a streaming client apparatus for server driven content negotiation according to some example embodiments of the current invention
  • Figures 6a and 6b illustrate flowcharts according to an example method for operation of a streaming client apparatus for agent-driven content negotiation according to some example embodiments of the current invention
  • Figure 7 illustrates a flowchart according to an example method for operation of proxy cache apparatus for server-driven content negotiation according to some example embodiments of the current invention
  • Figure 8 illustrates a flowchart according to an example method for operation of proxy cache apparatus for agent-driven content negotiation according to some example embodiments of the current invention
  • Figure 9 illustrates a flowchart according to an example method for operation of a streaming client apparatus for server driven content negotiation according to some example embodiments of the current invention
  • Figure 10 illustrates a flowchart according to an example method for operation of a streaming client apparatus for agent-driven content negotiation according to some example embodiments of the current invention
  • Figure 11 illustrates a flowchart according to an example method for operation of a proxy cache apparatus for server-driven content negotiation according to some example embodiments of the current invention.
  • Figure 12 illustrates a flowchart according to an example method for operation of a proxy cache apparatus for agent-driven content negotiation according to some example embodiments of the current invention.
  • data may be used interchangeably, according to some example embodiments of the present invention, to refer to data capable of being transmitted, received, operated on, displayed, and/or stored. Thus, use of any such terms should not be taken to limit the spirit and scope of the disclosure.
  • a computing device is described herein to receive data from another computing device, it will be appreciated that the data may be received directly from the another computing device or may be received indirectly via one or more intermediary computing devices, such as, for example, one or more servers, relays, routers, network access points, base stations, and/or the like.
  • Computer-readable medium refers to any medium configured to participate in providing information to a processor, including instructions for execution. Such a medium may take many forms, including, but not limited to a non- transitory computer-readable storage medium (for example, non- volatile media, volatile media), and transmission media.
  • Transmission media include, for example, coaxial cables, copper wire, fiber optic cables, and carrier waves that travel through space without wires or cables, such as acoustic waves and electromagnetic waves, including radio, optical and infrared waves.
  • Signals include man-made transient variations in amplitude, frequency, phase, polarization or other physical properties transmitted through the transmission media.
  • non-transitory computer-readable media examples include a floppy disk, a flexible disk, hard disk, magnetic tape, any other non-transitory magnetic medium, a compact disc read only memory (CD-ROM), compact disc compact disc-rewritable (CD-RW), digital versatile disc (DVD), Blu-Ray, any other non-transitory optical medium, punch cards, paper tape, optical mark sheets, any other physical medium with patterns of holes or other optically recognizable indicia, a random access memory (RAM), a programmable read only memory (PROM), an erasable programmable read only memory (EPROM), a FLASH-EPROM, any other memory chip or cartridge, a carrier wave, or any other non- transitory medium from which a computer can read.
  • RAM random access memory
  • PROM programmable read only memory
  • EPROM erasable programmable read only memory
  • FLASH-EPROM any other memory chip or cartridge, a carrier wave, or any other non- transitory medium from which a computer can read
  • computer-readable storage medium is used herein to refer to any computer-readable medium except transmission media. However, it will be appreciated that where embodiments are described to use a computer-readable storage medium, other types of computer-readable mediums may be substituted for or used in addition to the computer-readable storage medium in alternative embodiments.
  • circuitry refers to all of the following: (a) hardware-only circuit implementations (such as implementations in only analog and/or digital circuitry); (b) to combinations of circuits and computer program product(s) comprising software (and/or firmware instructions stored on one or more computer readable memories), such as (as applicable): (i) to a combination of processor(s) or (ii) to portions of processor(s)/software (including digital signal processor(s)), software, and memory(ies) that work together to cause an apparatus, such as a mobile phone or server, to perform various functions described herein); and (c) to circuits, such as, for example, a microprocessor(s) or a portion of a microprocessor(s), that require software or firmware for operation, even if the software or firmware is not physically present.
  • circuitry would also cover an implementation of merely a processor (or multiple processors) or portion of a processor and its (or their) accompanying software and/or firmware.
  • circuitry would also cover, for example and if applicable to the particular claim element, a baseband integrated circuit or applications processor integrated circuit for a mobile phone or a similar integrated circuit in a server, a cellular network device, other network device, and/or other computing device.
  • the various DASH standards define a format of a media presentation.
  • a media presentation may comprise a sequence of one or more consecutive periods. Each period may comprise one or more representations of media content, which typically differ by encoding choice (e.g., bitrate, resolution, language, codec, etc.).
  • a representation may comprise one or more media components, such that each media component defines an encoded version of a particular media type (e.g., audio, video, timed text, etc.).
  • Each representation may comprise one or more media segments, each of which may contain media data and/or metadata related to the media content of the media presentation.
  • Each media segment may be referenced by a unique HTTP Uniform Resource Locator (URL), which in some instances may be restricted by a byte range.
  • URL Uniform Resource Locator
  • the various representations of a media presentation may be assigned to one or more adaptation sets, such that representations in the same adaptation set are alternatives to each other and may be automatically switched during download and playback of the media presentation based on a number of factors associated with the download and playback (e.g., available bandwidth, time of access, etc.).
  • a media presentation is represented and described by a Media
  • MPD Presentation Description
  • the media presentation may be represented by an MPD defined as a well-formatted Extensible Markup Language (XML) document according to a particular XML schema.
  • XML Extensible Markup Language
  • an MPD, as well as the associated media presentation may be accessible according to various types of delivery methods.
  • the media presentation defined by the MPD may be accessible via unicast (e.g., via Packet-Switched Streaming (PSS) service), multicast (e.g., Multimedia Broadcast Multicast Services (MBMS)), and broadcast (e.g., via Digital Video Broadcasting - Handheld (DVB-H), MBMS, etc.) connections.
  • unicast e.g., via Packet-Switched Streaming (PSS) service
  • multicast e.g., Multimedia Broadcast Multicast Services (MBMS)
  • MBMS Multimedia Broadcast Multicast Services
  • broadcast e.g., via Digital Video Broadcasting - Handheld (DVB-H), MBMS, etc.
  • a caching proxy that is a part of the delivery network
  • a caching proxy server is a server that acts as an intermediary for requests from clients seeking resources and further accelerates service requests by retrieving content saved from a previous request made by the same client or even by other clients.
  • the client may be configured to dynamically request different segments for different representations as DASH supports rate adaptation.
  • segments from multiple representations may be cached by a caching proxy and the cached segments for each cached representation are not likely to form a complete representation.
  • a segment fetch time denotes the time period from requesting a segment to receive the last byte of the segment by the client. For example, it may take much less time for a client to fetch a segment which is cached at the proxy compared to fetching a segment which is not cached at the proxy.
  • the varying segment fetch time may further result into a variation in the buffered media time.
  • a rate adaptation algorithm may use the segment fetch time or buffered media time or both to determine switch-up or switch-down representation level (where the representation level represents the level of media bitrates within an Adaptation Set, which may be controlled for example by quantization and/or spatial resolution and/or temporal resolution).
  • clients may change the representation level due to the varying segment fetch time depending on which proxy server or originating server responds to the segment requests even if the throughput in the delivery network did not change and therefore there was no reason for changing representation levels.
  • the terms primary representation and the secondary representation(s) may be used herein to denote the highest preferred representation and the alternative representation(s), respectively, each of which may be associated with a preference.
  • the primary representation in some embodiments, may be considered to be equal to the representation used conventionally in DASH.
  • the secondary representation(s) and alternative representation(s) may be used interchangeably.
  • the primary segment and the secondary segment are used to indicate the segments which belong to the primary representation and the secondary representation, respectively.
  • the secondary segment may have the same start time and segment duration with the respective primary segment and the secondary segment and the respective primary segment should belong to different representations which are in the same Adaptation Set.
  • the term "user agent” is used to refer to the program that initiates a request, such as a WWW browser, editor, or spider (web-traversing robot) that are configured to operate on a streaming client apparatus, and the term “origin server” may be used to refer to the program that can originate authoritative responses to a request.
  • Figures 4a and 4b illustrate an example to demonstrate the problem of representation fluctuation at a client.
  • the content provider provided four representations and each representation consists of ten segments with the same segment duration.
  • four representations are cached by a proxy and each representation is incompletely cached.
  • the segments #1 (201), #2 (202), #3 (203), #4 (204), #5 (205) and #6 (206) are cached and the other segments of representation 1 not shown in 212 are not cached.
  • a greater number of representations may be provided by the content provider to achieve fine-grained rate adaptation.
  • clients may adaptively switch between the provided representations, it may take time to cache a complete representation, to cache a complete Adaptation Set, to cache a complete Group, to cache a complete Period, and a complete media clip.
  • the proxy receives a GET segment #1 of representation 1 request from the client (221) and sends the cached segment #1 of representation 1 (201) to the client (222).
  • the segment #1 fetch time is shown in 223.
  • the proxy receives a GET segment #2 of representation 2 (224), the proxy sends the cached segment #2 of representation 2 (207) to the client (225).
  • the segment fetching time #2 is shown in 226.
  • the proxy receives a request for the GET segment #3 of representation 2 from the streaming client (227) and fetches the segment #3 of the representation 2 from remote location in 228 and 229, e.g. streaming server in this example.
  • the proxy then sends the segment #3 of the representation 2 to the client (230).
  • the segment #3 fetch time is shown in 231.
  • the segment #3 fetch time (231) is much larger than the segment fetch time #2 (226), which may cause the client to switch-down representation level using the rate adaptation algorithm, such as using the rate adaptation method in Chenghao Liu, Imed Bouazizi and
  • the proxy receives a GET segment #4 of representation 1 from the client (232), the proxy sends the cached segment #4 of representation 1 (204) to the client (233).
  • the client may switch-up representation level again after receiving the segment #4.
  • a representation level may fluctuate between different representation levels instead of converging to a representation level, as shown in the Figure 4b because the client fetches the segment from the proxy and remote streaming server in-turn.
  • incorrect switching-up representation level may result in frequent playback interruption at DASH client since the limited bandwidth and relatively large Round Trip Time (RTT) between an origin server to proxy caches, especially when the origin server is located overseas relative to the DASH client.
  • RTT Round Trip Time
  • a buffered media time based rate adaptation method may be deployed to smooth the variation in the segment fetch time.
  • missing several consecutive segments in the proxy and caching several consecutive segments may cause the high variation in the buffered media time and result in buffer draining-up.
  • buffered media time based rate adaptation method may decline the rate adaptation speed, which may further cause buffer draining-up.
  • DASH client may frequently suffer from playback interruption due to the limited bandwidth and relatively large Round Trip Time (RTT) between an origin server to proxy caches, and incorrect rate adaptation.
  • Methods, apparatuses, and computer program products are herein provided for appending the syntax of DASH segment requests to indicate that segments from other representations are allowed in responses.
  • some example embodiments may be configured to modify a streaming client apparatus operation in such a way that it grants the permission to have a respective segment from certain other representations as a response to a segment request.
  • some example embodiments may modify a proxy operation such that a proxy cache apparatus may be configured to determine if alternative segments can be used in responses and, in an instance in which the request segment or any of the alternative segments are readily available in the proxy cache apparatus, selecting one of those segments to respond to the segment request.
  • a proxy may be configured to respond to a request with a primary or alternative representation- hence, for example, the overall network traffic as well as the number of accesses to an origin server may be reduced. Moreover, for example, the average response time experienced by a client may decrease, as it is more likely that a proxy can respond to a request. Consequently, DASH clients (e.g. a streaming client apparatus) are likely to make fewer incorrect rate adaptation decisions due to late-arriving segments and are also likely to face fewer interruptions in playback due to the same reason.
  • DASH clients e.g. a streaming client apparatus
  • Figure 1 illustrates a block diagram of a system
  • the system 100 may include one or more streaming client apparatuses 102 (also known as a DASH client, user agent or the like), one or more proxy cache apparatuses 104 (also known as a proxy), and/or one or more serving network apparatuses 108.
  • the system 100 may further comprise a network 106.
  • the network 106 may comprise one or more wireline networks, one or more wireless networks, or some combination thereof.
  • the network 106 may, for example, comprise a serving network (e.g., a serving cellular network) for one or more streaming client apparatuses 102 and/or more proxy cache apparatuses 104.
  • the network 106 may comprise, in certain embodiments, one or more streaming client apparatuses 102, one or more proxy cache apparatuses 104, and/or one or more serving network apparatuses 108 themselves. According to example embodiments, the network 106 may comprise the Internet. The network 106 may comprise, in some embodiments, a Content Delivery Network (CDN), which may also be referred to as a Content Distribution Network. In various embodiments, the network 106 may comprise a wired access link connecting one or more streaming client apparatuses 102 or one or more proxy cache apparatuses 104 to the rest of the network 106 using, for example,
  • CDN Content Delivery Network
  • the network 106 may comprise a public land mobile network (for example, a cellular network), such as may be implemented by a network operator (for example, a cellular access provider).
  • the network 106 may operate in accordance with universal terrestrial radio access network (UTRAN) standards, evolved UTRAN (E-UTRAN) standards, current and future implementations of Third Generation Partnership Project (3 GPP) LTE (also referred to as LTE-A) standards, current and future implementations of International Telecommunications Union (ITU) International Mobile Telecommunications - Advanced (IMT-A) systems standards, and/or the like.
  • UTRAN universal terrestrial radio access network
  • E-UTRAN evolved UTRAN
  • 3 GPP Third Generation Partnership Project
  • LTE-A also referred to as LTE-A
  • ITU International Telecommunications Union
  • IMT-A International Mobile Telecommunications - Advanced
  • one or more streaming client apparatuses 102 may be configured to connect directly with one or more serving network apparatuses 108 via, for example, an air interface without routing communications via one or more elements of the network 106.
  • one or more of the streaming client apparatuses 102 may be configured to communicate with one or more of the serving network apparatuses 108 over the network 106.
  • the serving network apparatuses 108 may comprise one or more nodes of the network 106.
  • the serving network apparatuses 108 may be at least partially embodied on one or more computing devices that comprise an element of a radio access network (RAN) portion of the network 106.
  • RAN radio access network
  • the serving network apparatuses 108 may, for example, be at least partially embodied on an access point of the network 106 (for example, a macrocell, microcell, picocell, femtocell, closed subscriber group (CSG) cell, base station, base transceiver station (BTS), node B, evolved node B, access point (AP), group owner, mesh station (STA), mesh point, and/or the like), which may, for example be configured to provide access to the network 106 (e.g., via a radio uplink) to one or more of the streaming client apparatuses 102.
  • the serving network apparatuses 108 may comprise an Access Network Discovery and Selection Function (ANDSF), and/or the like.
  • each of the serving network apparatuses 108 may comprise a network node or a plurality of network nodes collectively configured to perform one or more operations attributed to the serving network apparatuses 108 as described with respect to various example embodiments disclosed herein.
  • ANDSF Access Network Discovery and Selection Function
  • one or more streaming client apparatuses 102 may be configured to connect with the one or more proxy cache apparatuses 104.
  • the one or more proxy cache apparatuses 104 may be in communication with the one or more serving network apparatuses 108 in the same or similar fashions as described with respect to the one or more of the streaming client apparatuses 102 described above.
  • the system 100 may be configured according to an architecture for providing for distribution of media content.
  • the system 100 may be configured as an HTTP streaming system.
  • the system 100 may be configured to distribute one or more media presentations, as defined by a DASH standard such as 3 GPP DASH (3 GPP Technical Specification 26.246) or Moving Picture Experts Group (MPEG) DASH (ISO/IEC International Standard 23009-1) both of which are incorporated by reference herein.
  • a DASH standard such as 3 GPP DASH (3 GPP Technical Specification 26.246) or Moving Picture Experts Group (MPEG) DASH (ISO/IEC International Standard 23009-1) both of which are incorporated by reference herein.
  • the system 100 may be configured to implement a server-driven alternative representation method, for example a streaming client apparatus 102 may cause a proxy cache apparatus 104 to respond to an HTTP request with a primary representation or an alternative representation depending on the caching status at a proxy cache apparatus 104.
  • the system 100 may also be configured to implement an agent-driven alternative representation method, for example a streaming client apparatus 102 may cause a proxy cache apparatus 104 to provide the cached alternative resources' uniform resource indicator (URI) for selection.
  • URI uniform resource indicator
  • a streaming client apparatus 102 may request optimum resource for agent-driven content negotiation.
  • an alternative representation as described herein may represent a representation cached by a proxy cache apparatus 104 that is accepted by a streaming client apparatus 102 as an alternative to the requested primary representation. Moreover, the signaling for the alternative representations occurs between a streaming client apparatus 102 and a proxy cache apparatus 104.
  • a list of alternative URLs, representations, resources, or alike is provided in the segment request syntax.
  • the list can be unordered, i.e. a streaming client apparatus 102 may not have an indicated preference which one(s) of the members of the list it would like to receive in the response.
  • the list can be ordered, i.e. a certain item in the list may be preferred to be received instead of any items following that certain item in the list.
  • the list may be a combination of ordered and unordered items, where it is indicated whether a particular list item is listed in priority order relative to other ordered items or whether the placement of a particular list item in the list indicates no preference relative to other list items.
  • the preferences between the list items may be explicitly indicated for example by giving or deriving a priority value for each list item. The same priority value may be used if the client has no preference between the respective list items.
  • some embodiments of the system 100 may comprise server-driven content negotiation, where the streaming client apparatus 102 indicates its preferences in the HTTP GET request and the proxy cache apparatus 104 selects the resource that suits streaming client's needs and preferences.
  • server-driven content negotiation where the proxy cache apparatus 104 may respond with a number of alternative URIs from which the client can choose the best URI suited for its needs.
  • a streaming client apparatus 102 may be embodied as any computing device, such as, for example, a desktop computer, laptop computer, mobile terminal, mobile computer, mobile phone, mobile communication device, tablet computing device, game device, digital camera/camcorder, audio/video player, television device, radio receiver, digital video recorder, positioning device, wrist watch, portable digital assistant (PDA), fixed transceiver device (e.g., attached to traffic lights, energy meters, light bulbs, and/or the like), a chipset, an apparatus comprising a chipset, any combination thereof, and/or the like.
  • PDA portable digital assistant
  • a streaming client apparatus 102 may be embodied as a mobile terminal, such as that illustrated in Figure 2.
  • Figure 2 illustrates a block diagram of a mobile terminal 10 representative of one embodiment of a streaming client apparatus 102.
  • the mobile terminal 10 illustrated and hereinafter described is merely illustrative of one type of computing device (i.e., streaming client apparatus 102) that may implement and/or benefit from various embodiments and, therefore, should not be taken to limit the scope of the disclosure.
  • While several embodiments of the electronic device are illustrated and will be hereinafter described for purposes of example, other types of electronic devices, such as mobile telephones, mobile computers, portable digital assistants (PDAs), pagers, laptop computers, desktop computers, gaming devices, televisions, and other types of electronic systems, may employ various embodiments of the invention.
  • PDAs portable digital assistants
  • pagers pagers
  • laptop computers desktop computers
  • gaming devices televisions, and other types of electronic systems
  • the mobile terminal 10 may include an antenna 12 (or multiple antennas 12) in communication with a transmitter 14 and a receiver 16.
  • the mobile terminal 10 may also include a processor 20 configured to provide signals to and receive signals from the transmitter and receiver, respectively.
  • the processor 20 may, for example, be embodied as various means including circuitry, one or more microprocessors with accompanying digital signal processor(s), one or more processor(s) without an accompanying digital signal processor, one or more coprocessors, one or more multi-core processors, one or more controllers, processing circuitry, one or more computers, various other processing elements including integrated circuits such as, for example, an ASIC (application specific integrated circuit) or FPGA (field programmable gate array), or some combination thereof.
  • ASIC application specific integrated circuit
  • FPGA field programmable gate array
  • the processor 20 may comprise a plurality of processors.
  • These signals sent and received by the processor 20 may include signaling information in accordance with an air interface standard of an applicable cellular system, and/or any number of different wireline or wireless networking techniques, comprising but not limited to Wi-Fi, wireless local access network (WLAN) techniques such as BluetoothTM (BT), Ultra- wideband (UWB), Institute of Electrical and Electronics Engineers (IEEE) 802.11, 802.16, and/or the like.
  • WLAN wireless local access network
  • BT BluetoothTM
  • UWB Ultra- wideband
  • IEEE Institute of Electrical and Electronics Engineers
  • these signals may include speech data, user generated data, user requested data, and/or the like.
  • the mobile terminal may be capable of operating with one or more air interface standards, communication protocols, modulation types, access types, and/or the like. More particularly, the mobile terminal may be capable of operating in accordance with various first generation (1G), second generation (2G), 2.5G, third-generation (3G) communication protocols, fourth-generation (4G) communication protocols, Internet Protocol Multimedia Subsystem (IMS) communication protocols (for example, session initiation protocol (SIP)), and/or the like.
  • the mobile terminal may be capable of operating in accordance with 2G wireless communication protocols IS- 136 (Time Division Multiple Access (TDMA)), Global System for Mobile communications (GSM), IS-95 (Code Division Multiple Access (CDMA)), and/or the like.
  • TDMA Time Division Multiple Access
  • GSM Global System for Mobile communications
  • CDMA Code Division Multiple Access
  • the mobile terminal may be capable of operating in accordance with 2.5G wireless communication protocols General Packet Radio Service (GPRS), Enhanced Data GSM Environment (EDGE), and/or the like. Further, for example, the mobile terminal may be capable of operating in accordance with 3G wireless communication protocols such as Universal Mobile Telecommunications System (UMTS), Code Division Multiple Access 2000 (CDMA2000), Wideband Code Division Multiple Access (WCDMA), Time Division-Synchronous Code Division Multiple Access (TD-SCDMA), and/or the like. The mobile terminal may be additionally capable of operating in accordance with 3.9G wireless communication protocols such as Long Term Evolution (LTE) or Evolved Universal Terrestrial Radio Access Network (E- UTRAN) and/or the like. Additionally, for example, the mobile terminal may be capable of operating in accordance with fourth-generation (4G) wireless communication protocols such as LTE Advanced and/or the like as well as similar wireless communication protocols that may be developed in the future.
  • 4G fourth-generation
  • NAMPS Narrow-band Advanced Mobile Phone System
  • Total Access Communication System mobile terminals may also benefit from embodiments of this invention, as should dual or higher mode phones (for example, digital/analog or TDMA/CDM A/analog phones). Additionally, the mobile terminal 10 may be capable of operating according to Wi-Fi or Worldwide Interoperability for Microwave Access (WiMAX) protocols.
  • Wi-Fi Wireless Fidelity
  • WiMAX Worldwide Interoperability for Microwave Access
  • the processor 20 may comprise circuitry for implementing audio/video and logic functions of the mobile terminal 10.
  • the processor 20 may comprise a digital signal processor device, a microprocessor device, an analog-to-digital converter, a digital-to-analog converter, and/or the like. Control and signal processing functions of the mobile terminal may be allocated between these devices according to their respective capabilities.
  • the processor may additionally comprise an internal voice coder (VC) 20a, an internal data modem (DM) 20b, and/or the like.
  • the processor may comprise functionality to operate one or more software programs, which may be stored in memory.
  • the processor 20 may be capable of operating a connectivity program, such as a web browser.
  • the connectivity program may allow the mobile terminal 10 to transmit and receive web content, such as location-based content, according to a protocol, such as Wireless Application Protocol (WAP), hypertext transfer protocol (HTTP), and/or the like.
  • WAP Wireless Application Protocol
  • HTTP hypertext transfer protocol
  • the mobile terminal 10 may be capable of using Transmission Control Protocol/Internet Protocol (TCP/IP) to transmit and receive web content across the internet or other networks.
  • TCP/IP Transmission Control Protocol/Internet Protocol
  • the mobile terminal 10 may also comprise a user interface including, for example, an earphone or speaker 24, a ringer 22, a microphone 26, a display 28, a user input interface, and/or the like, which may be operationally coupled to the processor 20.
  • the processor 20 may comprise user interface circuitry configured to control at least some functions of one or more elements of the user interface, such as, for example, the speaker 24, the ringer 22, the microphone 26, the display 28, and/or the like.
  • the processor 20 and/or user interface circuitry comprising the processor 20 may be configured to control one or more functions of one or more elements of the user interface through computer program instructions (for example, software and/or firmware) stored on a memory accessible to the processor 20 (for example, volatile memory 40, non-volatile memory 42, and/or the like).
  • the mobile terminal may comprise a battery for powering various circuits related to the mobile terminal, for example, a circuit to provide mechanical vibration as a detectable output.
  • the user input interface may comprise devices allowing the mobile terminal to receive data, such as a keypad 30, a touch display (not shown), a joystick (not shown), and/or other input device.
  • the keypad may comprise numeric (0-9) and related keys (#, *), and/or other keys for operating the mobile terminal.
  • the mobile terminal 10 may also include one or more means for sharing and/or obtaining data.
  • the mobile terminal may comprise a short-range radio frequency (RF) transceiver and/or interrogator 64 so data may be shared with and/or obtained from electronic devices in accordance with RF techniques.
  • the mobile terminal may comprise other short-range transceivers, such as, for example, an infrared (IR) transceiver 66, a BluetoothTM (BT) transceiver 68 operating using BluetoothTM brand wireless technology developed by the BluetoothTM Special Interest Group, a wireless universal serial bus (USB) transceiver 70 and/or the like.
  • IR infrared
  • BT BluetoothTM
  • USB wireless universal serial bus
  • the BluetoothTM transceiver 68 may be capable of operating according to low power/energy or ultra-low power/energy BluetoothTM technology (for example, WibreeTM) radio standards.
  • the mobile terminal 10 and, in particular, the short-range transceiver may be capable of transmitting data to and/or receiving data from electronic devices within a proximity of the mobile terminal, such as within 10 meters, for example.
  • the mobile terminal may be capable of transmitting and/or receiving data from electronic devices according to various wireless networking techniques, including 6LoWpan, Wi-Fi, Wi-Fi low power, WLAN techniques such as IEEE 802.11 techniques, IEEE 802.15 techniques, IEEE 802.16 techniques, and/or the like.
  • the mobile terminal 10 may comprise memory, such as a removable or non-removable subscriber identity module (SIM) 38, a soft SIM 38, a fixed SIM 38, a removable or non-removable universal subscriber identity module (USIM) 38, a soft USIM 38, a fixed USIM 38, a removable user identity module (R-UIM), and/or the like, which may store information elements related to a mobile subscriber.
  • SIM subscriber identity module
  • USIM universal subscriber identity module
  • R-UIM removable user identity module
  • the mobile terminal may comprise other removable and/or fixed memory.
  • volatile memory 40 may include Random Access Memory (RAM) including dynamic and/or static RAM
  • Non-volatile memory 42 which may be embedded and/or removable, may include, for example, read-only memory, flash memory, magnetic storage devices (for example, hard disks, floppy disk drives, magnetic tape, etc.), optical disc drives and/or media, non-volatile random access memory (NVRAM), and/or the like.
  • NVRAM non-volatile random access memory
  • the memories may store one or more software programs, instructions, pieces of information, data, and/or the like which may be used by the mobile terminal for performing functions of the mobile terminal.
  • the memories may comprise an identifier, such as an international mobile equipment identification (IMEI) code, capable of uniquely identifying the mobile terminal 10.
  • IMEI international mobile equipment identification
  • Figure 3 illustrates a block diagram of an apparatus 300 according to an example embodiment.
  • the streaming client apparatus 102, the proxy cache apparatus 104, and/or the serving network apparatus 108 may be implemented in or otherwise embodied by the apparatus 300.
  • These means may comprise one or more of a processor 110, memory 112, communication interface 114, user interface 116, or flexible caching module 118.
  • the means of the apparatus 300 as described herein may be embodied as, for example, circuitry, hardware elements (e.g., a suitably programmed processor, combinational logic circuit, and/or the like), a computer program product comprising computer-readable program instructions (e.g., software or firmware) stored on a computer-readable medium (for example memory 112) that is executable by a suitably configured processing device (e.g., the processor 110), or some combination thereof.
  • a suitably configured processing device e.g., the processor 110
  • Figure 3 may be embodied as a chip or chip set.
  • the apparatus 300 may comprise one or more physical packages (for example, chips) including materials, components and/or wires on a structural assembly (for example, a baseboard).
  • the structural assembly may provide physical strength, conservation of size, and/or limitation of electrical interaction for component circuitry included thereon.
  • the processor 110, memory 112, communication interface 114, user interface 116, and/or flexible caching module 118 may be embodied as a chip or chip set.
  • the apparatus 300 may therefore, in some example embodiments, be configured to implement embodiments of the present invention on a single chip or as a single "system on a chip.”
  • the apparatus 300 may comprise component(s) configured to implement embodiments of the present invention on a single chip or as a single "system on a chip.”
  • a chip or chipset may constitute means for performing one or more operations for providing the functionalities described herein and/or for enabling user interface navigation with respect to the functionalities and/or services described herein.
  • the processor 110 may, for example, be embodied as various means including one or more microprocessors with accompanying digital signal processor(s), one or more processor(s) without an accompanying digital signal processor, one or more coprocessors, one or more multi-core processors, one or more controllers, processing circuitry, one or more computers, various other processing elements including integrated circuits such as, for example, an ASIC (application specific integrated circuit) or FPGA (field programmable gate array), one or more other hardware processors, or some combination thereof. Accordingly, although illustrated in Figure 3 as a single processor, in some embodiments the processor 110 may comprise a plurality of processors.
  • the plurality of processors may be in operative communication with each other and may be collectively configured to perform one or more functionalities of the apparatus 300 as described herein.
  • the plurality of processors may be embodied on a single computing device or distributed across a plurality of computing devices collectively configured to function as the apparatus 300.
  • the processor 110 may be embodied as or comprise the processor 20.
  • the processor 110 is configured to execute instructions stored in the memory 112 or otherwise accessible to the processor 110. These instructions, when executed by the processor 110, may cause the apparatus 300 to perform one or more of the functionalities of the apparatus 300 as described herein.
  • the processor 1 10 may comprise an entity capable of performing operations according to embodiments of the present invention while configured accordingly.
  • the processor 110 when the processor 110 is embodied as an ASIC, FPGA or the like, the processor 110 may comprise specifically configured hardware for conducting one or more operations described herein.
  • the processor 110 when the processor 110 is embodied as an executor of instructions, such as may be stored in the memory 112, the instructions may specifically configure the processor 110 to perform one or more algorithms and operations described herein.
  • the memory 112 may comprise, for example, volatile memory, non-volatile memory, or some combination thereof.
  • the memory 112 may comprise one or more tangible and/or non-transitory computer-readable storage media that may include volatile and/or non-volatile memory.
  • the memory 112 may comprise a plurality of memories. The plurality of memories may be embodied on a single computing device or may be distributed across a plurality of computing devices collectively configured to function as the apparatus 300.
  • the memory 112 may comprise a hard disk, random access memory, cache memory, flash memory, a compact disc read only memory (CD-ROM), digital versatile disc read only memory (DVD-ROM), an optical disc, circuitry configured to store information, or some combination thereof.
  • the memory 112 may comprise the volatile memory 40 and/or the non-volatile memory 42.
  • the memory 112 may be configured to store information, data, applications, instructions, or the like for enabling the apparatus 300 to carry out various functions in accordance with various example embodiments.
  • the memory 112 is configured to buffer input data for processing by the processor 110.
  • the memory 112 may be configured to store program instructions for execution by the processor 110.
  • the memory 1 12 may store information in the form of static and/or dynamic information. This stored information may be stored and/or used by the flexible caching module 118 during the course of performing its functionalities.
  • the communication interface 114 may be embodied as any device or means embodied in circuitry, hardware, a computer program product comprising computer readable program instructions stored on a computer readable medium (for example, the memory 112) and executed by a processing device (for example, the processor 110), or a combination thereof that is configured to receive and/or transmit data from/to another computing device.
  • the communication interface 114 may be at least partially embodied as or otherwise controlled by the processor 1 10.
  • the communication interface 114 may be in communication with the processor 110, such as via a bus.
  • the communication interface 114 may include, for example, an antenna, a transmitter, a receiver, a transceiver and/or supporting hardware or software for enabling communications with one or more remote computing devices.
  • the communication interface 114 may be configured to receive and/or transmit data using any protocol that may be used for communications between computing devices.
  • the communication interface 114 may be configured to receive and/or transmit data using any protocol that may be used for transmission of data over a wireless network, wireline network, some combination thereof, or the like by which the streaming client apparatus
  • the communication interface 114 may be configured to enable communication between the apparatus 300 and another device, such as another apparatus 300.
  • the communication interface 114 may be configured to enable communication via the network 106.
  • the communication interface 114 may additionally be in communication with the memory 112, user interface 116, and/or flexible caching module 118, such as via a bus.
  • the user interface 116 may be in communication with the processor 110 to receive an indication of a user input and/or to provide an audible, visual, mechanical, or other output to a user.
  • the user interface 116 may include, for example, a keyboard, a mouse, a joystick, a display, a touch screen display, a microphone, a speaker, and/or other input/output mechanisms.
  • the user interface 1 16 may additionally be configured to detect and/or receive indication of a touch gesture or other input to the touch screen display.
  • the user interface 116 may be in communication with the memory 112, communication interface 114, and/or flexible caching module 118, such as via a bus.
  • the flexible caching module 118 may be embodied as various means, such as circuitry, hardware, a computer program product comprising computer readable program instructions stored on a computer readable medium (for example, the memory 112) and executed by a processing device (for example, the processor 110), or some combination thereof and, in some embodiments, is embodied as or otherwise controlled by the processor 110.
  • the flexible caching module 118 may be in communication with the processor 1 10.
  • the flexible caching module 118 may further be in communication with one or more of the memory 112, communication interface 114, or user interface 116, such as via a bus.
  • the flexible caching module 118 is configured to set an @segmentAlignment in an MPD to a non-false value.
  • a setting may indicate that presentation start and end times of media components of any particular media type are temporally aligned in all Segments across all Representations in the Adaptation Set (in which the @segmentAlignment is included).
  • the streaming client apparatus 102 may be configured to use an "Accept-Alternative-URI" header field to specify URIs that are acceptable as responses to a GET request in which the "Accept-Alternative-URI" header field is included.
  • the "Accept-Alternative-URI" header field may be used in server-driven content negotiation.
  • a syntax of an "Accept-Alternative-URI” header field may be specified as follows using a form of the Augmented Backus-Naur Form (ABNF):
  • the proxy cache apparatus 104 of Figure 1 may be configured to respond to a GET request, such as by using the processor 110, the communications interface 114, the flexible caching module 118 or the like in an instance in which the requested resource or any of the resources listed in the "Accept-Alternative- URI" header and any of those resources fulfills the other requirements of the request, indicated for example by one of more of the header fields for enabling server-driven content negotiation or cache control directives of the request.
  • "Accept-Alternative-URI” may be used with a "Connection” header field and may specify the "Accept-Alternative-URI.”
  • a "Connection” header field may enable a streaming client apparatus 102 to specify that the "Accept-Alternative-URI” option is desired for the connection between the streaming client apparatus 102 and the proxy cache apparatus 104.
  • a "Connection” ABNF syntax for "Accept-Alternative-URI" is defined as follows
  • Connection l#connectin-token
  • Connection-token Accept-Alternative-URI
  • the proxy cache apparatus 104 may parse a received Connection header field before a message is forwarded and, for each connection-token in this field, remove any header field(s) from the message with the same name as the connection-token, specifically Accept-Alternative-URI, and then remove the Connection header field itself or replace it with the sender's own connection options for the forwarded message.
  • a HTTP GET request may be forwarded in an instance in which a proxy has no requested resource or any of the resources listed in the "Accept-Alternative- URI" available.
  • an example HTTP GET request may include a first URI (for a particular segment of a first representation) including a number of accepted q values and an indication of a segment from another representation that may be a proper response.
  • the segment from the other representation may originally have had a different URI than the requested URL Hence, the same resource may appear in subsequent proxies or caches under different URIs.
  • Cache directives may therefore be used to prevent caching of the response in any subsequent proxies/caches.
  • a HTTP GET segment #1 may include an example of "Accept- Alternative-
  • example.com/contents/rep-5/seg-l .3gp may be identified as the primary URI, and http://example.com/contents/rep-4/seg-l .3gp and example.com/contents/rep-3/seg-l .3gp may be identifies as alternative URIs.
  • a proxy cache apparatus 104 determines a resource for the primary URI, it may be configured to respond to a streaming client apparatus 102 with the primary URI.
  • the proxy cache apparatus 104 may respond, such as by the processor
  • the proxy cache apparatus 104 may respond with the resource example.com/contents/rep-4/seg-l .3gp. Otherwise, a proxy cache apparatus 104 may respond with the resource corresponding to GET http://example.com/contents/rep-
  • the proxy cache apparatus may select the resource used in the response according to the q value.
  • a proxy cache apparatus 104 may process the directive of "Connection" header field to move the connection-token, specifically Accept- Alternative-URI header field in this example.
  • the "Connection" header field may be configured to allow the sender, such as a streaming client apparatus 102, to specify options that are desired for a particular connection.
  • a header field such as an "Accept-"
  • Alternative-Representation header may be added by a flexible caching module 118 to a request.
  • the example header field may be used to indicate to a proxy cache apparatus 104 that alternative representations in addition to the primary representation are acceptable.
  • the example header field may also include a list of accepted alternative Representation@id values, which in some embodiments a streaming client apparatus 102 may have determined.
  • the syntax of an example "Accept-Alternative-Representation" header field includes but is not limited to:
  • representationid-range / ( [representationid] "-" [ representationid] )
  • representationid-list representationid *("
  • the flexible caching module 118 may use a
  • the URI-Template may be the same or similar to the primary URI except that it may have a different representationID.
  • a representationID is typically a certain integer value but may alternatively be any string to be used with a representation-list.
  • the Representation@id values which are represented by representationid syntax element in the ABNF syntax above, may be any alphanumeric strings of a certain set of values, such as non-negative integer values.
  • the URI-Template may contain a placeholder for the representationID and a placeholder may appear in the URI-Template as "$representationID$".
  • the flexible caching module 118 may indicate that alternative representation IDs are accepted by using a range or a list of representation IDs.
  • the first given representationid and the second given representationid may indicate the start and end of alternative representation IDs for a continuous range.
  • an order or sorting of Representation@id values may be specified, such as arranging integer values in ascending order or alphanumeric strings in alphabetical order.
  • the representationid-range syntax may specify all values from the first given representationid until the second given representationid, inclusive, in the specified order or sorting of Representation@id to identify alternative representations.
  • the start alternative representation ID may be larger than, or lower than, the end alternative representation ID.
  • the start and end alternative representation ID may be assigned an associated start-quality value and end-quality value, respectively, which represents the preference of the corresponding boundary representation ID.
  • the quality value of other alternative representation IDs excepting the start and end alternative representation ID can be derived, such as by the flexible caching module 118, by uniformly distributing a quality value between start-quality value and end-quality value.
  • a list a list of accepting representation IDs can be listed.
  • Each representation ID may be assigned an associated quality value which represents the preference of the representation having such representation ID.
  • Accept-Alternative-Representation with range may be interpreted for example as an instance in which a primary representation was not cached for seg-1.3gp, the streaming client apparatus 102 may then be configured to accept three alternative representations for seg.l .3gp including representations which have an ID equal to 4, 3, or 2 with the preference of 0.8, 0.5, and 0.2, respectively.
  • a list based Accept-Representation may include:
  • the example of Accept- Alternative-Representation may be interpreted as in an instance in which a primary representation was not cached for segment#l, the streaming client apparatus 102 may be configured to, such as by a streaming client apparatus 102 accepts one of the secondary representation IDs #5, #4 and #3 for that segment.
  • the streaming client apparatus 102 prefers, such as by the processor 110, the flexible caching module 118 or the like, the segment of representation ID #5, but if the proxy cache apparatus 104 does not cache it, then the proxy cache apparatus 104 can send the segment of representation ID #4 and if that does not exist, the proxy cache apparatus 104 can send the representation ID #3 for segment #1".
  • An example of HTTP GET segment request at a streaming client apparatus 102 using the proposed "Accept- Alternative-Representation" header field is given as follows.
  • the example may be interpreted as a streaming client apparatus 102 requesting, such as by the processor 110, the flexible caching module 118 or the like, a representation ID #5 for segment#l and representation ID #6 for segment#2, sequentially.
  • the streaming client apparatus 102 indicates that it also accepts alternative representation IDs #4 and #3 in the case of missing representation ID #5.
  • the streaming client apparatus 102 alternatively accepts representation IDs #5, in the case of missing representation ID #6.
  • the URI-template may also contain other placeholders such as those specified in MPEG DASH, namely $Number$ for segment identifier, $Bandwidth$ for the bandwidth of the Representation (which streaming client apparatus 102, may derive, such as by the processor 110, the value of Representation@bandwidth attribute of the desired representation), and $Time$ for the segment time (streaming client apparatus 102, may derive, such as by the processor 110, the segment timeline, particularly the SegmentTimeline@t attribute).
  • the values to be inserted in place of the placeholders when resolving a URI from the URI-template are passed within the Accept-Alternative-Representation header similarly to the accepted representation IDs.
  • a header field in a request such as "Accept-
  • Cached- Alternative-Representation may be specified by a flexible caching module 118.
  • "Accept-Cached-Alternative-Representation” may be used to direct a proxy cache apparatus 104 to reply with a list and range of URIs for the cached alternative resources for agent-driven content negotiation.
  • "Accept-Cached-Alternative-Representation” may also include a secondary URIs' template for searching the cached alternative resources.
  • the primary URI in the HTTP GET request may also include an indication including a URI template to request a caching proxy to reply with a list and range of URIs for the cached alternative resources for agent-driven content negotiation.
  • the URI of the primarily requested resource should result when substituting $RepresentationID$ in the URI template with the Representation@id value of the representation that is primarily requested.
  • An example of an HTTP GET segment request at a streaming client apparatus 102 using the proposed "Accept-Cached- Alternative- Representation" header field includes but is not limited to:
  • the "Accept-Cached- Alternative-Representation" header field may be interpreted as a primary representation #5 that is not cached for seg-1.3gp.
  • a streaming client apparatus 102 may request, such as by the processor 110, the communications interface 114, the flexible caching module 118 or like, a proxy cache apparatus 104 to respond all cached secondary URIs, which matches the template specified in an "Accept-Cached- Alternative-Representation" for the alternative resources.
  • each media-range in an Accept header may be followed by one or more accept-parameters, beginning with the "q" parameter for indicating a relative quality factor.
  • the first "q" parameter (if any) separates the media-range parameter(s) from the accept-parameters.
  • quality factors allow a streaming client apparatus 102 to indicate, such as by the processor 110, the flexible caching module 118 or the like, the relative degree of preference for that media-range, using the q value scale from 0 to 1.
  • the q value may be used to determine selection criteria for an alternative representation.
  • a media type DASH and sub-types representation-x are specified for server-driven content negotiation, they include but are not limited to:
  • x can be a integer value or alternatively any string.
  • a Representation of an Adaptation Set may be associated with a content type.
  • a specific content type can be associated with a "q" parameter to indicate the preference of such content type.
  • An example of an adaption set to accept secondary representations using the "Accept" header field include but are not limited to:
  • "Accept" header field may include
  • the example accept header field may list one or multiple secondary subtypes that are configured to indicate to a proxy cache apparatus 104 that a streaming client apparatus 102, accepts a particular content type.
  • An embodiment of HTTP GET segment request may include
  • An example of "Accept" using the defined media type/subtype includes but is not limited to a HTTP GET segment#l request:
  • the example may be interpreted as the primary content type that a streaming client apparatus 102 is dash/representation-5 for seg-1.3gp. If the primary content type is not cached by a proxy cache apparatus 104, then a streaming client apparatus 102 may also accept content type dash/representation-4. Otherwise, if content type dash/representation-5 and dash/representation-4 are not cached, then a streaming client apparatus 102 may also accept content type dash/representation-3. Otherwise, (if the primary content type and secondary content type are not cached by a caching proxy), then a proxy cache apparatus 104 may should process the directive of "Connection" header field to move the connection-token, specifically "Accept" header field in this example.
  • a proxy cache apparatus 104 may be configured to be aware of the new content type dash/representation-x.
  • a "Response-URI" header field for HTTP GET responses may be specified.
  • "Response-URI” may be used to indicate to a streaming client apparatus 102 that an alternative URI is provided due to the missing primary URI at a caching proxy for server-driven content negotiation.
  • the header field may include the selected URI.
  • the syntax and semantics of "Response-URI" header field is specified as follows.
  • a status code such as "208 Alternative Content” may be used in a HTTP response to indicate to a streaming client apparatus 102 that the resource in a response does not include the resource for the primary URI.
  • URI indicates the URI of responding resources.
  • Response header field "Response-URI” may be used to respond to an HTTP GET request with header field "Accept-Alternative-URI”.
  • "Accept-Alternative-URI” and "Response- URI” may be cooperatively used to signal from a streaming client apparatus 102 to a proxy cache apparatus 104 the accepted alternative URIs at a streaming client apparatus 102 and to signal from a streaming client apparatus 102 to a proxy cache apparatus 104 the URI for the resource which is delivered to an streaming client apparatus 102.
  • "Accept- Alternative-URI” is used by an "Accept- Alternative-URI” aware proxy cache apparatus, such as proxy cache apparatus 104, which may be configured to identify a secondary resource to serve a streaming client apparatus 102 request in a case a proxy cache apparatus 104 cannot determine and/or locate a resource for the primary URL Specifically, an "Accept-Alternative-URI” header aware caching proxy checks (e.g. sequentially) whether or not a secondary resource, as specified in "Accept-Alternative- URI" header field, is cached by the proxy cache apparatus 104.
  • a status code such as "208 Alternative Content” (as described above) may be used in a HTTP response to indicate a streaming client apparatus 102 that the resource in a response is not the resource for the primary URL
  • a new defined "Response-URI" header field is used to indicate the selected URI for the responding resource.
  • An example streaming client apparatus 102 HTTP GET segment#l request may include but is not limited to:
  • An example Proxy cache apparatus 104 HTTP response includes but is not limited to:
  • a proxy cache apparatus 104 may check, such as by a processor 110, a flexible caching module 118 or the like, a resource for a primary URI "http://example.com/contents/rep-5/seg-l .3gp.” In an instance in which the primary URI is not found, the proxy cache apparatus 104 may sequentially check, such as by a processor 110, a flexible caching module 118 or the like, the resources for the secondary URIs specified in an "Accept-Alternative-URI" header field.
  • the proxy cache apparatus 104 does not find the resource for "http://example.com/contents/rep-4/seg- 1.3gp" and finds the resource for "http://example.com/contents/rep-3/seg-l .3gp".
  • a status code "208 Alternative Content” and header field Response-URI: http://example.com/contents/rep-3/seg-l .3gp may be sent in a HTTP response to inform the streaming client apparatus 102 that the secondary resource is delivered and the selected URI for the secondary resource.
  • "Vary" header field may include "Accept- Alternative-URI" header field to express the parameters the proxy cache apparatus 104 uses to select a representation that is subject to server-driven negotiation.
  • Response-URI may be used to signal a proxy cache apparatus 104 the accepted alternative representation IDs and to signal a streaming client apparatus 102 a representation ID used to construct the URI for the secondary resource, which is delivered to the streaming client apparatus 102.
  • "Accept- Alternative-Representation" may be used in an instance in which a proxy cache apparatus 104 cannot locate a resource for the primary URI by a proxy cache apparatus 104 to construct the secondary URIs.
  • one or multiple secondary URI(s) may be constructed by replacing the $representationID$ with the corresponding representationlDs specified in a range or list of representationlDs.
  • a proxy cache apparatus 104 may be configured to sequentially check whether or not a secondary resource, as specified in the constructed secondary URIs, is cached by the proxy cache apparatus 104.
  • a status code such as "208 Alternative Content” may be used in a HTTP response to indicate a streaming client apparatus 102, that the resource in a response is not the resource for the primary URI.
  • a "Response-URI” may be included in HTTP header field to indicate the selected URI for the responding resource.
  • a "Response-Representation” may be included in HTTP header field to indicate the selected representation for the responding resource.
  • An example streaming client apparatus 102 HTTP GET segment#l request includes but is not limited to:
  • An example proxy cache apparatus 104 HTTP response may include but is not limited to:
  • a proxy cache apparatus 104 may be configured to check a resource for the primary URI "http://example.com/contents/rep-5/seg-l .3gp." In an instance in which a primary URI is not found, the proxy cache apparatus 104 may then be configured to construct example secondary URIs http://example.com/contents/rep-4/seg- 1.3gp and http://example.com/contents/rep-5/seg-l .3gp using the URI template and representationID specified in a Accept-Alternative-Representation header field. Then the proxy cache apparatus 104 may be configured to sequentially check the resources for the secondary URIs.
  • the proxy cache apparatus 104 does not find the resource for "http://example.com/contents/rep-4/seg-l .3gp" but finds the resource for "http://example.com/contents/rep-3/seg-l .3gp". So a status code "208 Alternative Content” and header field Response-URI: http://example.com/contents/rep-3/seg-l .3gp may be sent to a streaming client apparatus 102 in a HTTP response to inform the streaming client apparatus 102 that the secondary resource is delivered and the selected URI for the secondary resource.
  • "Vary" header field may include "Accept-Alternative- Representation" header field to express the parameters the proxy cache apparatus 104 uses to select a representation that is subject to server-driven negotiation.
  • a header field in a request such as
  • Response-Representation may be specified, such as by the flexible caching module 118. "Response-Representation” may be configured to indicate to a streaming client apparatus 102, that an alternative representation is being provided by the proxy cache apparatus 104. For example, because the primary representation was not available at a proxy cache apparatus 104, the header field may include the selected Representation@id.
  • Representation header field may include a HTTP response, status code such as "208 Alternative Content” which may be used to indicate to a streaming client apparatus 102 that the resource in a response is not the resource for the primary URI.
  • "Accept- Alternative-Representation” should be included in a "Vary" header field to express the parameters the caching proxy server uses to select a representation that is subject to server- driven negotiation.
  • Response-Representation l#representationID
  • a RepresentationID may indicate the representation ID of the secondary representation ID.
  • Response header field "Response- Representation” may be used with request header field "Accept-Alternative- Representation. "
  • "Accept-Alternative-Representation” and “Response-Representation” may be cooperatively used to signal a proxy cache apparatus 104 the accepted alternative representation IDs and to signal a streaming client apparatus 102 a representation ID used to construct the URI for the secondary resource.
  • "Accept-Alternative-Representation” may be used in an instance in which a proxy cache apparatus 104 cannot locate, such as by the processor 110, the flexible caching module 1 18 or the like, a resource for the primary URI by an "Accept- Alternative-Representation" aware caching proxy, such as the proxy cache apparatus 104, to construct the secondary URIs.
  • a proxy cache apparatus 104 may be constructed by replacing the $representationID$ with the corresponding representationlDs specified in a range or list of representationlDs.
  • the proxy cache apparatus 104 may then be configured to sequentially determine whether or not a secondary resource, as specified in the constructed secondary URIs, is cached by the proxy cache apparatus 104.
  • a status code such as "208 Alternative Content” may be used in a HTTP response to indicate that the resource in a response is not the resource for the primary URI.
  • a "Response-URI” may be included in HTTP header field to indicate the selected URI for the responding resource.
  • a "Response-Representation” may be included in HTTP header field to indicate the selected representation for the responding resource.
  • An example streaming client apparatus 102 HTTP GET segment#l includes but is not limited to:
  • An example proxy cache apparatus 104 HTTP response includes but is not limited to:
  • a "Response-Representation" header field is included in the response header field instead of "Response-URI" and is configured to inform a streaming client apparatus 102 that the secondary resource is delivered and the selected representation ID for the secondary resource.
  • "Vary" header field include "Accept- Alternative-Representation” header field to express the parameters the proxy cache apparatus 104 uses to select a representation that is subject to server-driven negotiation.
  • a header field in a request such as "Cached-
  • Alternative-Representation may be specified, such as by a flexible caching module 118, which is used to signal a streaming client apparatus 102 with a list and/or a range of URIs for the cached alternative resources for agent-driven content negotiation.
  • the example syntax of "Cached-Alternative-Representation" header field may include but is not limited to:
  • representationid-range / ( [ representationid] "-" [ representationid] )
  • representationid-list representationid *("
  • the semantics of the symbols may be equal to the semantics of the symbols specified "Accept-Alternative-Representation".
  • the difference of the header fields "Cached-Alternative-Representation” and "Accept- Alternative-Representation” is that the former signal from a proxy cache apparatus 104 to a streaming client apparatus 102 and the later signal is from a streaming client apparatus 102 to a proxy cache apparatus 104.
  • the preference of representation on a streaming client apparatus 102 may be included in "Accept- Alternative-Representation” and the preference of representation at a caching it not included in "Cached-Alternative- Representation” .
  • Figure 5 illustrates a flowchart according to an example method for operation of streaming client apparatus 102 with respect to server driven content negotiation.
  • Figure 5 illustrates operations that may be performed at the streaming client apparatus 102.
  • the operations illustrated in and described with respect to Figure 5 may, for example, be performed by, with the assistance of, and/or under the control of one or more of the processor 110, memory 112, communication interface 114, or flexible caching module 118.
  • a streaming client apparatus 102 may be configured to specify a primary and secondary representation for a segment (also referred as a resource) for the alternative resources and the corresponding preference.
  • a streaming client apparatus 102 may also be configured to signal a proxy cache apparatus 104 with the primary and secondary representation for a segment in a way that a proxy cache apparatus 104 is configured to derive a primary and secondary URIs for the primary and alternative resources and the corresponding preference.
  • a streaming client apparatus 102 is configured to cause a primary URI of the primary representation for a segment to be added in a HTTP request and in operation 303 a template that indicates that the streaming client apparatus 102 is configured to accept representation IDs in an "Accept- Alternative- Representation" header field to specify the secondary representations for a segment.
  • the processor 110, memory 112, and/or flexible caching module 118 may, for example, provide means for performing operations 302 and 303.
  • the streaming client apparatus 102 may be configured to add a "Accept- Alternative- Representation" in a "Connection" header field to indicate a connection between proxy cache apparatus 104 and the streaming client apparatus 102.
  • the processor 110, memory 112, and/or flexible caching module 118 may, for example, provide means for performing operation 304.
  • a streaming client apparatus 102 may be configured to cause an HTTP request to be transmitted to a proxy cache apparatus 104 or a serving network apparatus 108.
  • the processor 110, memory 112, communication interface 114, user interface 116, and/or flexible caching module 118 may, for example, provide means for performing operation 305.
  • Figures 6a and 6b illustrate flowcharts according to an example method for operation of streaming client apparatus 102 with respect to agent-driven content negotiation.
  • Figures 6a and 6b illustrate operations that may be performed at the streaming client apparatus 102.
  • the operations illustrated in and described with respect to Figures 6a and 6b may, for example, be performed by, with the assistance of, and/or under the control of one or more of the processor 110, memory 112, communication interface 114, or flexible caching module 1 18.
  • a streaming client apparatus 102 may be configured to cause a proxy cache apparatus 104 to reply with a list and range of URIs for cached alternative resources for agent-driven content negotiation.
  • the streaming client apparatus 102 may also be configured to cause a template to be transmitted in an "Accept-Cached- Alternative-Representation" header field to and to cause a proxy cache apparatus 104 to transmit possible representations a streaming client apparatus 102 may accept.
  • Representation header field may be used with regard to signaling from a streaming client apparatus 102 to a proxy cache apparatus 104 and such signaling may be performed in, but is not limited to: (a) sending an "Accept-Cached- Alternative-Representation" header and (b) receiving a "Cached- Alternative-Representation" header.
  • a streaming client apparatus 102 may be configured to add a primary URI of the primary representation for a segment in a HTTP request and in operation 403 add a template in an "Accept-Cached-Alternative- Representation" header field to signal a proxy cache apparatus 104 to determine one or more secondary representations for a segment.
  • the processor 110, memory 112, and/or flexible caching module 118 may, for example, provide means for performing operations 402 and 403.
  • a streaming client apparatus 102 may cause a HTTP request to be transmitted to a proxy cache apparatus 104 or a serving network apparatus 108.
  • the processor 110, memory 112, communication interface 114, user interface 116, and/or flexible caching module 118 may, for example, provide means for performing operation 404.
  • a streaming client apparatus 102 may be configured to receive a "Cached- Alternative-Representation" from a proxy cache apparatus 104.
  • the processor 110, memory 112, communication interface 114, and/or flexible caching module 1 18 may, for example, provide means for performing operation 412.
  • a streaming client apparatus 102 may be configured to parse a
  • the streaming client apparatus 102 may conclude a best or advantageous representation for a segment and further may cause a GET segment request to be transmitted for a segment.
  • the processor 110, memory 112, communication interface 114, user interface 116, and/or flexible caching module 1 18 may, for example, provide means for performing operations 413 and 414.
  • Figure 7 illustrates a flowchart according to an example method for operation of a proxy cache apparatus 104 for server-driven content negotiation.
  • Figure 7 illustrates operations that may be performed at the proxy cache apparatus 104.
  • the operations illustrated in and described with respect to Figure 7 may, for example, be performed by, with the assistance of, and/or under the control of one or more of the processor 110, memory 112, communication interface 114, or flexible caching module 118.
  • a proxy cache apparatus 104 may be configured to determine a primary and/or secondary URIs for alternative resources and the corresponding preference by a streaming client apparatus 102 by using the proposed signaling, such as "Accept- Alternative-URI" header field and "Accept-Alternative-Representation" header field.
  • the proposed signaling such as "Accept- Alternative-URI" header field and "Accept-Alternative-Representation" header field.
  • other similar headers or directives too which can be used to specify secondary URIs for the alternative resources.
  • a proxy cache apparatus 104 may be configured to determine whether to cache resources for the primary and/or the secondary URI and further may be configured to select a high priority resource which is cached by the proxy cache apparatus 104. In an instance in which a secondary resource for the primary and secondary URI is not located, a proxy cache apparatus 104 causes a request, such as a HTTP request, to be transmitted to a serving network apparatus 108 or another proxy cache which may cache the primary or secondary resources.
  • a proxy cache apparatus 104 may be configured to cause the primary resource to be transmitted to the streaming client apparatus 102.
  • a proxy cache apparatus 104 may be configured to cache the received segment in an instance in which it was not already cached.
  • the processor 110, memory 112, communication interface 114, and/or flexible caching module 118 may, for example, provide means for performing operations 502-505.
  • a proxy cache apparatus 104 may be configured to determine whether or not "Accept-Alternative-Representation" is included in a header field. See operation 506. If "Accept-Alternative-Representation" is included in a header field, then, as shown in operation 507, a proxy cache apparatus 104 may be configured to construct the secondary URIs for the alternative resources and, as is shown in operation 508, sequentially check whether or not a secondary URI's resource is cached by a proxy cache apparatus 104 from a high preference to a low preference as indicated by an "Accept- Alternative- Representation".
  • a proxy cache apparatus 104 may be configured to cause an alternative segment to be transmitted to a streaming client apparatus 102 in a response immediately or after a predetermined period amount of time. See operation 510.
  • the processor 110, memory 112, communication interface 114, and/or flexible caching module 118 may, for example, provide means for performing operations 510, and 506-509.
  • a proxy cache apparatus 104 may be configured to add a selected representation ID in a "Response- Representation" response header field or add the selected secondary URI in a "response- URI” response header field, which is delivered to a streaming client apparatus 102.
  • a proxy cache apparatus 104 may include "Accept- Alternative-Representation" header field name in a "Vary" header field to express the parameters to select a representation that is subject to server-driven negotiation.
  • the processor 110, memory 112, communication interface 114, and/or flexible caching module 118 may, for example, provide means for performing operation 511.
  • a proxy cache apparatus 104 may request and cache the requested segment identified by a primary URI from a remote location if the requested segment is not currently being caused to be retrieved and/or fetched from a remote location and to serve future request after responding to a streaming client apparatus
  • a proxy cache apparatus 104 may cause a requested segment from a remote location to be requested in an instance in which a number of HTTP GET requests are received in a certain time interval that exceed a predetermined duration, and the requested segment is not being fetched from a remote location.
  • the processor 110, memory 1 12, communication interface 114, and/or fiexible caching module 118 may, for example, provide means for performing operation 512.
  • a proxy cache apparatus 104 may be configured to remove "Accept-Alternative-Representation" as indicated in connection header field. Then, at operation 514, a proxy cache apparatus 104 may determine whether the requested segment is currently being fetched from a remote location.
  • the proxy cache apparatus 104 cause the requested segment to be retrieved from one or multiple remote locations and may then cause the requested segment to be transmitted to a streaming client apparatus 102. Otherwise, if the requested segment is not fully cached by a proxy cache apparatus 104 but is currently being retrieved from a remote location as shown in operation 514, then a proxy cache apparatus 104 may cause the requested segment to be transmitted to a streaming client apparatus 102 as is shown in operation 504. If the requested segment is not cached by a proxy cache apparatus 104, then the proxy cache apparatus 104 may be configured to cache the segment at operation 505 and ends a caching proxy operation for server-driven content negotiation in DASH at operation 516.
  • the processor 110, memory 112, communication interface 114, and/or fiexible caching module 118 may, for example, provide means for performing operations 506, 509, and 513-516.
  • Figure 8 illustrates a flowchart according to an example method for operation of a proxy cache apparatus 104 for agent-driven content negotiation.
  • Figure 8 illustrates operations that may be performed at the proxy cache apparatus 104.
  • the operations illustrated in and described with respect to Figure 8 may, for example, be performed by, with the assistance of, and/or under the control of one or more of the processor 110, memory 112, communication interface 114, or flexible caching module 118.
  • a proxy cache apparatus 104 may be configured to analyze possible candidate URIs that are cached a proxy cache apparatus 104 using the signaling, such as "Accept- Alternative-URI" header field and "accept" defined media type.
  • a proxy cache apparatus 104 may be configured to cause a primary resource to be transmitted to a streaming client apparatus 102.
  • a proxy cache apparatus 104 caches the received segment in an instance in which the received segment is not already cached. See operation 605.
  • the processor 110, memory 112, communication interface 114, and/or flexible caching module 118 may, for example, provide means for performing operations 602-605.
  • a proxy cache apparatus 104 receives a HTTP GET segment request from a streaming client apparatus 102 and the requested primary resource identified by a primary URI is not cached as is shown in operation 603.
  • a proxy cache apparatus 104 may be configured to determine whether "Accept-Cached-Alternative-Representation" is included in a header field.
  • a proxy cache apparatus 104 may be configured to parse a URI template for the alternative resources from "Accept-Cached-Alternative-Representation" and as shown in operation 608, proxy cache apparatus 104 may locate cached alternative resources that matches the URI template of the secondary resources. See operation 609.
  • the processor 110, memory 112, communication interface 1 14, and/or flexible caching module 118 may, for example, provide means for performing operations 606-609.
  • the proxy cache apparatus 104 may be configured add all the matching URIs in a "Cached- Alternative- Representation" response header field and further may cause it to be transmitted to a streaming client apparatus 102.
  • "Accept-Cached- Alternative- Representation" header field is not found, a proxy cache apparatus 104 is not aware of the new defined header field of HTTP, or no such as cached alternative resources' URI is found, then at operation 611, a proxy cache apparatus 104 may be configured to remove "Accept-Cached-Alternative-Representation" as indicated in connection header field.
  • a proxy cache apparatus 104 may be configured to determine whether the requested segment is already being fetched from a remote location.
  • a proxy cache apparatus 104 may be configured to fetch the requested segment from one or multiple remote locations and further may cause the requested segment to be transmitted to a streaming client apparatus 102. As is shown in operation 614, if the requested segment is not cached by a proxy cache apparatus 104, the proxy cache apparatus 104 may cache the segment.
  • the processor 110, memory 112, communication interface 114, and/or flexible caching module 118 may, for example, provide means for performing operations 610-614.
  • Figure 9 illustrates a flowchart according to an example method for operation of streaming client apparatus 102 for server driven content negotiation. See also for example Figure 5.
  • the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the fiexible caching module 118 or the like, for causing a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a proxy cache apparatus, wherein the proxy cache apparatus is configured to derive a primary URI for the primary representation and at least one secondary URI for the alternative representation and corresponding preferences.
  • the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining the primary URI of the primary representation for the segment to be transmitted to the proxy cache apparatus.
  • the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the fiexible caching module 118 or the like, for causing a template that specifies the alternative representation URI for the segment to be created, wherein the template comprises an indication to accept an alternative representation of the segment.
  • a connection header field is configured to provide an indication of one or more URIs that are permitted as responses from the proxy cache apparatus.
  • the alternative representation is a representation that is cached by the proxy cache apparatus and is configured to be an alternative to the primary representation.
  • the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing the proxy cache apparatus 104 to respond with at least one of the primary representation or the alternative representation based on the caching status at a proxy cache apparatus, wherein the proxy cache apparatus 104 is configured to determine whether the request enables an alternative representation to be included in a response.
  • the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for receiving at least one of the primary representation or the alternative representation for the segment from the proxy cache apparatus.
  • Figure 10 illustrates a flowchart according to an example method for operation of streaming client apparatus 102 with respect to agent-driven content negotiation. See also for example Figure 6.
  • the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing a request for a proxy cache apparatus to provide a selectable cached alternative representation URI to be transmitted.
  • the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing a primary URI of a primary representation for a segment to be transmitted in the request.
  • the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the flexible caching module 118 or the like, for causing a template that specifies the secondary representation URI for the segment to be created, wherein the template comprises an indication to accept secondary representation of the segment.
  • the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for receiving a list and range of URI's for the selectable cached alternative representation for agent driven content negotiation.
  • the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted, wherein the resource is requested based on a predetermined selection criteria.
  • the request is transmitted to at least one of a proxy cache apparatus 104 or a serving network apparatus.
  • the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for receiving a message from the proxy cache apparatus; determining the one or more selectable cached alternative representations are available from the proxy cache apparatus based on the received message and causing at least one of the one or more cached alternative representations to be requested, wherein the resource is requested based on a predetermined selection criteria.
  • Figure 11 illustrates a flowchart according to an example method for operation of proxy cache apparatus 104 for server-driven content negotiation. See also for example Figure 7.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for receiving a request for at least one of a primary representation or an alternative representation for a segment.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining whether the request comprises an indication that a client will accept the alternative representation of the segment.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining whether at least one of a primary URI associated with the primary representation is cached.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining a secondary URI for the alternative representation in an instance in which the request comprises an indication that the streaming client apparatus will accept the alternative representation of the segment and the primary URI is not cached.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining whether the alternative representation that is associated with the secondary URI is cached.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing the primary representation of the segment to be requested in an instance in which the secondary URI is not cached.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing the alternative representation of the segment to be transmitted in an instance in which the secondary URI is cached.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing the primary representation of the segment to be transmitted in an instance in which the primary URI is cached.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for determining a cached alternative representation to cause to be transmitted, wherein the determination is based on a predetermined selection criteria and causing the primary representation associated with the primary URI to be requested in an instance in which it is not cached.
  • Figure 12 illustrates a flowchart according to an example method for operation of proxy cache apparatus 104 for agent-driven content negotiation. See also for example Figure 8.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 1 10, the communications interface 114, the flexible caching module 118 or the like, for receiving a request for at least one of a primary representation or an alternative representation for a segment.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining whether the request comprises an indication that a client will accept the alternative representation of the segment.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing a list and range of URI 's for a selectable cached alternative representation for agent driven content negotiation to be transmitted.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining whether at least one of a primary URI associated with the primary representation is cached.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing the primary representation of the segment to be transmitted in an instance in which the primary URI is cached.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for receiving a template that specifies the secondary representation URI for the segment to be created, wherein the template comprises an indication to accept secondary representation of the segment and in some embodiments parsing the template.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining at least one alternative representation that is associated with the secondary representation URI in the received template.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for receiving a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
  • the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing one or more selectable cached alternative representations to be transmitted and receiving a request for at least one of the one or more cached alternative representations.
  • FIG. 5-12 illustrate flowcharts of a system, method, and computer program product according to example embodiments of the invention. It will be understood that each block of the flowchart, and combinations of blocks in the flowchart, may be implemented by various means, such as hardware and/or a computer program product comprising one or more computer-readable mediums (as opposed to a computer-readable transmission medium which describes a propagating signal) having one or more computer program code instructions, program instructions, or executable computer-readable program code instructions stored therein. For example, one or more of the procedures described herein may be embodied by computer program instructions of a computer program product.
  • the computer program product(s) that embodies the procedures described herein may be stored by one or more memory devices (e.g., memory 112, volatile memory 40, or non-volatile memory 42) of a mobile terminal, server, or other computing device (e.g., the streaming client apparatus 102) and executed by a processor (e.g., the processor 110 or processor 20) in the computing device.
  • the computer program instructions comprising the computer program product(s) that embodies the procedures described above may be stored by memory devices of a plurality of computing devices.
  • any such computer program product may be loaded onto a computer or other programmable apparatus to produce a machine, such that the computer program product including the instructions which execute on the computer or other programmable apparatus creates means for implementing the functions specified in the flowchart block(s).
  • the computer program product may comprise one or more computer-readable memories on which the computer program instructions may be stored such that the one or more computer-readable memories can direct a computer or other programmable apparatus to function in a particular manner, such that the computer program product may comprise an article of manufacture which implements the function specified in the flowchart block(s).
  • the computer program instructions of one or more computer program products may also be loaded onto a computer or other programmable apparatus to cause a series of operations to be performed on the computer or other programmable apparatus to produce a computer-implemented process such that the instructions which execute on the computer or other programmable apparatus provide operations for implementing the functions specified in the flowchart block(s).
  • Retrieval, loading, and execution of the program code instructions may be performed sequentially such that one instruction is retrieved, loaded, and executed at a time. In some example embodiments, retrieval, loading and/or execution may be performed in parallel such that multiple instructions are retrieved, loaded, and/or executed together.
  • execution of instructions associated with the operations of the flowchart by a processor, or storage of instructions associated with the blocks or operations of the flowchart in a computer-readable storage medium support combinations of operations for performing the specified functions. It will also be understood that one or more operations of the flowchart, and combinations of blocks or operations in the flowchart, may be implemented by special purpose hardware-based computer systems and/or processors which perform the specified functions, or combinations of special purpose hardware and program code instructions.
  • a URI template scheme may be used primarily for representation IDs. It is noted that any other URI template scheme may be used similarly with various embodiments. Placeholders other than $RepresentationID$ may be additionally or alternatively present in the URI template scheme.
  • a local HTTP cache located in the same device as a streaming client apparatus 102 may also be used.
  • a local HTTP cache may operate similarly to the proxy cache apparatus 104 described in various embodiments. However, in the case that a local HTTP cache cannot serve the primary or secondary resource requested in an HTTP GET request, the local HTTP cache may leave the Connection header unresolved and hence not remove headers related to the alternative resources as specified in various embodiments.
  • URIs or URI templates in requests and/or responses, where the URI or URI template indicates a segment in a representation announced in an MPD.
  • a URI or URI template could alternatively or additionally specify a sub- segment, i.e. a part of a segment, typically a single byte range within a segment.
  • a sub- segment may contain such a part of a segment that it can be processed by a streaming client apparatus 102 prior to receiving subsequent sub-segments of the same segment.
  • a sub-segment may be determined for example during preparing the content and indicated through one or more Segment Index boxes included in the segment.
  • a streaming client apparatus may receive and parse one or more Segment Index boxes of a segment and determine sub-segments and their URIs or URI templates accordingly.
  • a URI or URI template for a sub-segment may contain the URI or URI template, respectively, of the segment and a byte range part specifying the sub-segment.
  • the various embodiments of the present invention provide many advantages over the current art. Some example embodiments more segments are fetched from a proxy cache instead of remote location. Consequently, bandwidth (in the network between proxy cache and origin server) is saved. In other embodiments, advantageously DASH clients are likely to make fewer incorrect rate adaptation decisions and more consistently request the same representation level and hence provide a more stable quality to end-users. Further embodiments described herein are configured to reduce the delay to fetch segments at the client, therefore resulting in fewer interruptions/re-bufferings. [00173] The above described functions may be carried out in many ways. For example, any suitable means for carrying out each of the functions described above may be employed to carry out embodiments of the invention.
  • a suitably configured processor may provide all or a portion of the elements of the invention.
  • all or a portion of the elements of the invention may be configured by and operate under control of a computer program product.
  • the computer program product for performing the methods of embodiments of the invention may comprise a computer-readable storage medium, such as the non- volatile storage medium (for example, the memory 112), and computer-readable program code portions, such as a series of computer instructions, embodied in the computer-readable storage medium.

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

Various methods are described for selecting an access method for flexible caching in DASH. One example method may comprise causing a request for at least one of a primary representation for a segment and one or multiple alternative representations for the segment to be transmitted to a caching proxy. The method of this example embodiment may further comprise causing the caching proxy to respond with at least one of the primary representation or the alternative representation based on the caching status at a caching proxy. In some example embodiments, the caching proxy is configured to determine whether the request enables an alternative representation to be included in a response. Furthermore, the method of this example embodiment may comprise receiving at least one of the primary representation or the alternative representation for the segment from the caching proxy. Similar and related example methods, example apparatuses, and example computer program products are also provided.

Description

METHOD AND APPARATUS FOR FLEXIBLE CACHING OF DELIVERED MEDIA
TECHNICAL FIELD
[0001] Embodiments of the present invention relate generally to communication technology, and, more particularly, relate to a method and apparatus for accepting multiple representations via Dynamic Adaptive Streaming over Hypertext Transfer Protocol (HTTP) (DASH).
BACKGROUND
[0002] The modern communications era has brought about a tremendous expansion of wireline and wireless networks. Computer networks, television networks, and telephony networks are experiencing an unprecedented technological expansion, fueled by consumer demand. Wireless and mobile networking technologies have addressed related consumer demands, while providing more flexibility and immediacy of information transfer.
[0003] Current and future networking technologies continue to facilitate ease of information transfer and convenience to users. In order to provide easier or faster information transfer and convenience, telecommunication industry service providers are developing improvements to existing networks. In this regard, for example, improvements are being made to the universal mobile telecommunications system (UMTS) terrestrial radio access network (UTRAN). Further, for example, the evolved-UTRAN (E-UTRAN) is currently being developed. The E-UTRAN, which is also known as Long Term Evolution (LTE), is aimed at upgrading prior technologies by improving efficiency, lowering costs, improving services, making use of new spectrum opportunities, and providing better integration with other open standards.
[0004] As a result of improved networking technologies, the capacity for visual and audible media content distribution over the Internet has continued to increase. Users desire efficient and optimized access to this growing amount of media content through various access methods. An emerging standard for distributing media content to devices is known as DASH. The DASH standard provides media content for distribution based on a media presentation structure. The media presentation structure of DASH, however, focuses on the media content and not the method(s) a client can use for accessing the content.
SUMMARY [0005] Methods, apparatuses, and computer program products are herein provided for appending the syntax of DASH segment requests to indicate that segments from other representations are allowed in responses. Further, and in some example embodiments, as described herein, a streaming client apparatus operation may be modified in such a way that the streaming client apparatus grants permission to have a respective segment from certain other representations as a response to a segment request. Further still, some example embodiments may modify a proxy operation such that a proxy cache apparatus may be configured to determine if alternative segments can be used in responses and, in an instance in which the request segment or any of the alternative segments are readily available in the proxy cache apparatus, selecting one of those segments to respond to the segment request.
[0006] In some example embodiments, a method is provided that comprises causing a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a caching proxy. The method of this embodiment may also include causing the caching proxy to respond with at least one of the primary representation or the alternative representation based on the caching status at a caching proxy. In some example embodiments, the caching proxy is configured to determine whether the request enables an alternative representation to be included in a response. The method of this embodiment may also include receiving at least one of the primary representation or the alternative representation for the segment from the caching proxy.
[0007] In another embodiment, an apparatus is provided that includes at least one processor and at least one memory including computer program code with the at least one memory and the computer program code being configured, with the at least one processor, to cause the apparatus to at least cause a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a caching proxy. The at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to cause the caching proxy to respond with at least one of the primary representation or the alternative representation based on the caching status at a caching proxy. In some example embodiments, the caching proxy is configured to determine whether the request enables an alternative representation to be included in a response. The at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to receive at least one of the primary representation or the alternative representation for the segment from the caching proxy.
[0008] In the further embodiment, a computer program product may be provided that includes at least one non-transitory computer-readable storage medium having computer-readable program instruction stored therein with the computer-readable program instructions including program instructions configured to cause a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a caching proxy. The computer-readable program instructions may also include program instructions configured to cause the caching proxy to respond with at least one of the primary representation or the alternative representation based on the caching status at a caching proxy. In some example embodiments, the caching proxy is configured to determine whether the request enables an alternative representation to be included in a response. The computer-readable program instructions may also include program instructions configured to receive at least one of the primary representation or the alternative representation for the segment from the caching proxy.
[0009] In yet another embodiment, an apparatus is provided that includes means for causing a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a caching proxy. The apparatus of this embodiment may also include means for causing the caching proxy to respond with at least one of the primary representation or the alternative representation based on the caching status at a caching proxy. In some example embodiments, the caching proxy is configured to determine whether the request enables an alternative representation to be included in a response. The apparatus of this embodiment may also include means for receiving at least one of the primary representation or the alternative representation for the segment from the caching proxy.
[0010] In some example embodiments, a method is provided that comprises causing a request for a caching proxy to provide a selectable cached alternative representation uniform resource indicator (URI) to be transmitted. The method of this embodiment may also include receiving a list and range of URFs for the selectable cached alternative representation for agent driven content negotiation. The method of this embodiment may also include causing a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted. In some example embodiments, the resource is requested based on predetermined selection criteria. [0011] In another embodiment, an apparatus is provided that includes at least one processor and at least one memory including computer program code with the at least one memory and the computer program code being configured, with the at least one processor, to cause the apparatus to at least cause a request for a caching proxy to provide a selectable cached alternative representation URI to be transmitted. The at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to receive a list and range of URI's for the selectable cached alternative representation for agent driven content negotiation. The at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to cause a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted. In some example embodiments, the resource is requested based on predetermined selection criteria.
[0012] In the further embodiment, a computer program product may be provided that includes at least one non-transitory computer-readable storage medium having computer-readable program instruction stored therein with the computer-readable program instructions including program instructions configured to cause a request for a caching proxy to provide a selectable cached alternative representation URI to be transmitted. The computer-readable program instructions may also include program instructions configured to receive a list and range of URI's for the selectable cached alternative representation for agent driven content negotiation. The computer-readable program instructions may also include program instructions configured to cause a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted. In some example embodiments, the resource is requested based on predetermined selection criteria.
[0013] In yet another embodiment, an apparatus is provided that includes means for causing a request for a caching proxy to provide a selectable cached alternative representation URI to be transmitted. The apparatus of this embodiment may also include means for receiving a list and range of URI's for the selectable cached alternative representation for agent driven content negotiation. The apparatus of this embodiment may also include means for causing a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted. In some example embodiments, the resource is requested based on predetermined selection criteria.
[0014] In some example embodiments, a method is provided that comprises receiving a request for at least one of a primary representation or an alternative representation for a segment. The method of this embodiment may also include determining whether the request comprises an indication that a client will accept the alternative representation of the segment. The method of this embodiment may also include determining whether at least one of a primary URI associated with the primary representation is cached. The method of this embodiment may also include causing the primary representation of the segment to be transmitted in an instance in which the primary URI is cached. The method of this embodiment may also include determining whether at least one of the alternative URIs associated with the alternative representations is cached. The method of this embodiment may also include causing the alternative representation of the segment to be transmitted in an instance in which at least one of the alternative URIs is cached and the primary URI is not cached.
[0015] In another embodiment, an apparatus is provided that includes at least one processor and at least one memory including computer program code with the at least one memory and the computer program code being configured, with the at least one processor, to cause the apparatus to at least receive a request for at least one of a primary representation or an alternative representation for a segment. The at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to determine whether the request comprises an indication that a client will accept the alternative representation of the segment. The at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to determine whether at least one of a primary URI associated with the primary representation is cached. The at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to cause the primary representation of the segment to be transmitted in an instance in which the primary URI is cached. The at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to determine whether at least one of the alternative URIs associated with the alternative representations is cached. The at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to cause the alternative representation of the segment to be transmitted in an instance in which at least one of the alternative URIs is cached and the primary URI is not cached.
[0016] In the further embodiment, a computer program product may be provided that includes at least one non-transitory computer-readable storage medium having computer-readable program instruction stored therein with the computer-readable program instructions including program instructions configured to receive a request for at least one of a primary representation or an alternative representation for a segment. The computer- readable program instructions may also include program instructions configured to determine whether the request comprises an indication that a client will accept the alternative representation of the segment. The computer-readable program instructions may also include program instructions configured to determine whether at least one of a primary URI associated with the primary representation is cached. The computer-readable program instructions may also include program instructions configured to cause the primary representation of the segment to be transmitted in an instance in which the primary URI is cached. The computer-readable program instructions may also include program instructions configured to determine whether at least one of the alternative URIs associated with the alternative representations is cached. The computer-readable program instructions may also include program instructions configured to cause the alternative representation of the segment to be transmitted in an instance in which at least one of the alternative URIs is cached and the primary URI is not cached.
[0017] In yet another embodiment, an apparatus is provided that includes means for receiving a request for at least one of a primary representation or an alternative representation for a segment. The apparatus of this embodiment may also include means for determining whether the request comprises an indication that a client will accept the alternative representation of the segment. The apparatus of this embodiment may also include means for determining whether at least one of a primary URI associated with the primary representation is cached. The apparatus of this embodiment may also include means for causing the primary representation of the segment to be transmitted in an instance in which the primary URI is cached. The apparatus of this embodiment may also include means for determining whether at least one of the alternative URIs associated with the alternative representations is cached. The apparatus of this embodiment may also include means for causing the alternative representation of the segment to be transmitted in an instance in which at least one of the alternative URIs is cached and the primary URI is not cached.
[0018] In some example embodiments, a method is provided that comprises receiving a request for at least one of a primary representation or an alternative representation for a segment. The method of this embodiment may also include determining whether the request comprises an indication that a client will accept the alternative representation of the segment. The method of this embodiment may also include causing a list and range of URI's for a selectable cached alternative representation for agent driven content negotiation to be transmitted. The method of this embodiment may also include receiving a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
[0019] In another embodiment, an apparatus is provided that includes at least one processor and at least one memory including computer program code with the at least one memory and the computer program code being configured, with the at least one processor, to cause the apparatus to at least receive a request for at least one of a primary representation or an alternative representation for a segment. The at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to determine whether the request comprises an indication that a client will accept the alternative representation of the segment. The at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to cause a list and range of URI's for a selectable cached alternative representation for agent driven content negotiation to be transmitted. The at least one memory and computer program code may also be configured to, with the at least one processor, cause the apparatus to receive a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
[0020] In the further embodiment, a computer program product may be provided that includes at least one non-transitory computer-readable storage medium having computer-readable program instruction stored therein with the computer-readable program instructions including program instructions configured to receive a request for at least one of a primary representation or an alternative representation for a segment. The computer- readable program instructions may also include program instructions configured to determine whether the request comprises an indication that a client will accept the alternative representation of the segment. The computer-readable program instructions may also include program instructions configured to cause a list and range of URI's for a selectable cached alternative representation for agent driven content negotiation to be transmitted. The computer-readable program instructions may also include program instructions configured to receive a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
[0021] In yet another embodiment, an apparatus is provided that includes means for receiving a request for at least one of a primary representation or an alternative representation for a segment. The apparatus of this embodiment may also include means for determining whether the request comprises an indication that a client will accept the alternative representation of the segment. The apparatus of this embodiment may also include means for causing a list and range of URI's for a selectable cached alternative representation for agent driven content negotiation to be transmitted. The apparatus of this embodiment may also include means for receiving a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
[0022] The above summary is provided merely for purposes of summarizing some example embodiments of the invention so as to provide a basic understanding of some aspects of the invention. Accordingly, it will be appreciated that the above described example embodiments are merely examples and should not be construed to narrow the scope or spirit of the invention in any way. It will be appreciated that the scope of the invention encompasses many potential embodiments, some of which will be further described below, in addition to those here summarized. BRIEF DESCRIPTION OF THE DRAWING(S)
[0023] Having thus described some example embodiments of the invention in general terms, reference will now be made to the accompanying drawings, which are not necessarily drawn to scale, and wherein:
[0024] Figure 1 illustrates a block diagram of a system for accepting multiple representations for DASH according to some example embodiments of the current invention;
[0025] Figure 2 illustrates a block diagram of a mobile terminal representative of one embodiment of a streaming client apparatus according to some example embodiments of the current invention;
[0026] Figure 3 illustrates a block diagram of an apparatus according to some example embodiments of the current invention;
[0027] Figures 4a and 4b illustrate an example representation fluctuation at a client;
[0028] Figure 5 illustrates a flowchart according to an example method for operation of a streaming client apparatus for server driven content negotiation according to some example embodiments of the current invention;
[0029] Figures 6a and 6b illustrate flowcharts according to an example method for operation of a streaming client apparatus for agent-driven content negotiation according to some example embodiments of the current invention; [0030] Figure 7 illustrates a flowchart according to an example method for operation of proxy cache apparatus for server-driven content negotiation according to some example embodiments of the current invention;
[0031] Figure 8 illustrates a flowchart according to an example method for operation of proxy cache apparatus for agent-driven content negotiation according to some example embodiments of the current invention;
[0032] Figure 9 illustrates a flowchart according to an example method for operation of a streaming client apparatus for server driven content negotiation according to some example embodiments of the current invention;
[0033] Figure 10 illustrates a flowchart according to an example method for operation of a streaming client apparatus for agent-driven content negotiation according to some example embodiments of the current invention;
[0034] Figure 11 illustrates a flowchart according to an example method for operation of a proxy cache apparatus for server-driven content negotiation according to some example embodiments of the current invention; and
[0035] Figure 12 illustrates a flowchart according to an example method for operation of a proxy cache apparatus for agent-driven content negotiation according to some example embodiments of the current invention.
DETAILED DESCRIPTION
[0036] Example embodiments of the present invention will now be described more fully hereinafter with reference to the accompanying drawings, in which some, but not all embodiments of the invention are shown. Indeed, the invention may be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will satisfy applicable legal requirements. Like reference numerals refer to like elements throughout.
[0037] The terms "data," "content," "information," and similar terms may be used interchangeably, according to some example embodiments of the present invention, to refer to data capable of being transmitted, received, operated on, displayed, and/or stored. Thus, use of any such terms should not be taken to limit the spirit and scope of the disclosure. Further, where a computing device is described herein to receive data from another computing device, it will be appreciated that the data may be received directly from the another computing device or may be received indirectly via one or more intermediary computing devices, such as, for example, one or more servers, relays, routers, network access points, base stations, and/or the like.
[0038] The term "computer-readable medium" as used herein refers to any medium configured to participate in providing information to a processor, including instructions for execution. Such a medium may take many forms, including, but not limited to a non- transitory computer-readable storage medium (for example, non- volatile media, volatile media), and transmission media. Transmission media include, for example, coaxial cables, copper wire, fiber optic cables, and carrier waves that travel through space without wires or cables, such as acoustic waves and electromagnetic waves, including radio, optical and infrared waves. Signals include man-made transient variations in amplitude, frequency, phase, polarization or other physical properties transmitted through the transmission media. Examples of non-transitory computer-readable media include a floppy disk, a flexible disk, hard disk, magnetic tape, any other non-transitory magnetic medium, a compact disc read only memory (CD-ROM), compact disc compact disc-rewritable (CD-RW), digital versatile disc (DVD), Blu-Ray, any other non-transitory optical medium, punch cards, paper tape, optical mark sheets, any other physical medium with patterns of holes or other optically recognizable indicia, a random access memory (RAM), a programmable read only memory (PROM), an erasable programmable read only memory (EPROM), a FLASH-EPROM, any other memory chip or cartridge, a carrier wave, or any other non- transitory medium from which a computer can read. The term computer-readable storage medium is used herein to refer to any computer-readable medium except transmission media. However, it will be appreciated that where embodiments are described to use a computer-readable storage medium, other types of computer-readable mediums may be substituted for or used in addition to the computer-readable storage medium in alternative embodiments.
[0039] As used herein, the term 'circuitry' refers to all of the following: (a) hardware-only circuit implementations (such as implementations in only analog and/or digital circuitry); (b) to combinations of circuits and computer program product(s) comprising software (and/or firmware instructions stored on one or more computer readable memories), such as (as applicable): (i) to a combination of processor(s) or (ii) to portions of processor(s)/software (including digital signal processor(s)), software, and memory(ies) that work together to cause an apparatus, such as a mobile phone or server, to perform various functions described herein); and (c) to circuits, such as, for example, a microprocessor(s) or a portion of a microprocessor(s), that require software or firmware for operation, even if the software or firmware is not physically present.
[0040] This definition of 'circuitry' applies to all uses of this term in this application, including in any claims. As a further example, as used in this application, the term "circuitry" would also cover an implementation of merely a processor (or multiple processors) or portion of a processor and its (or their) accompanying software and/or firmware. The term "circuitry" would also cover, for example and if applicable to the particular claim element, a baseband integrated circuit or applications processor integrated circuit for a mobile phone or a similar integrated circuit in a server, a cellular network device, other network device, and/or other computing device.
[0041] The various DASH standards (e.g., 3 GPP DASH, MPEG DASH, etc.) define a format of a media presentation. A media presentation may comprise a sequence of one or more consecutive periods. Each period may comprise one or more representations of media content, which typically differ by encoding choice (e.g., bitrate, resolution, language, codec, etc.). A representation may comprise one or more media components, such that each media component defines an encoded version of a particular media type (e.g., audio, video, timed text, etc.). Each representation may comprise one or more media segments, each of which may contain media data and/or metadata related to the media content of the media presentation. Each media segment may be referenced by a unique HTTP Uniform Resource Locator (URL), which in some instances may be restricted by a byte range. The various representations of a media presentation may be assigned to one or more adaptation sets, such that representations in the same adaptation set are alternatives to each other and may be automatically switched during download and playback of the media presentation based on a number of factors associated with the download and playback (e.g., available bandwidth, time of access, etc.).
[0042] Typically, a media presentation is represented and described by a Media
Presentation Description (MPD), which may also be referred to as a playlist file, manifest file, or streaming manifest file. For example, the media presentation may be represented by an MPD defined as a well-formatted Extensible Markup Language (XML) document according to a particular XML schema. According to DASH standards, an MPD, as well as the associated media presentation, may be accessible according to various types of delivery methods. For example, the media presentation defined by the MPD may be accessible via unicast (e.g., via Packet-Switched Streaming (PSS) service), multicast (e.g., Multimedia Broadcast Multicast Services (MBMS)), and broadcast (e.g., via Digital Video Broadcasting - Handheld (DVB-H), MBMS, etc.) connections.
[0043] In some example embodiments and in an instance in which only one representation is provided for a particular media clip that is delivered over DASH, then a caching proxy (that is a part of the delivery network) has typically cached all its segments after a client plays-out a whole video clip. A caching proxy server is a server that acts as an intermediary for requests from clients seeking resources and further accelerates service requests by retrieving content saved from a previous request made by the same client or even by other clients. However, the client may be configured to dynamically request different segments for different representations as DASH supports rate adaptation. Hence, segments from multiple representations may be cached by a caching proxy and the cached segments for each cached representation are not likely to form a complete representation.
[0044] The caching of multiple incomplete representations may cause a variation in a segment fetch time of different segments at the client. A segment fetch time denotes the time period from requesting a segment to receive the last byte of the segment by the client. For example, it may take much less time for a client to fetch a segment which is cached at the proxy compared to fetching a segment which is not cached at the proxy. The varying segment fetch time may further result into a variation in the buffered media time. A rate adaptation algorithm may use the segment fetch time or buffered media time or both to determine switch-up or switch-down representation level (where the representation level represents the level of media bitrates within an Adaptation Set, which may be controlled for example by quantization and/or spatial resolution and/or temporal resolution). Hence, clients may change the representation level due to the varying segment fetch time depending on which proxy server or originating server responds to the segment requests even if the throughput in the delivery network did not change and therefore there was no reason for changing representation levels.
[0045] The terms primary representation and the secondary representation(s) may be used herein to denote the highest preferred representation and the alternative representation(s), respectively, each of which may be associated with a preference. The primary representation, in some embodiments, may be considered to be equal to the representation used conventionally in DASH. As described herein, the secondary representation(s) and alternative representation(s) may be used interchangeably. Similarly to the terminology related to representations, the primary segment and the secondary segment are used to indicate the segments which belong to the primary representation and the secondary representation, respectively. In addition, the secondary segment may have the same start time and segment duration with the respective primary segment and the secondary segment and the respective primary segment should belong to different representations which are in the same Adaptation Set.
[0046] The term "user agent" is used to refer to the program that initiates a request, such as a WWW browser, editor, or spider (web-traversing robot) that are configured to operate on a streaming client apparatus, and the term "origin server" may be used to refer to the program that can originate authoritative responses to a request.
[0047] Figures 4a and 4b illustrate an example to demonstrate the problem of representation fluctuation at a client. In this example, it is assumed that the content provider provided four representations and each representation consists of ten segments with the same segment duration. As shown in the Figure 4a, four representations are cached by a proxy and each representation is incompletely cached. For the representation 1 (212), the segments #1 (201), #2 (202), #3 (203), #4 (204), #5 (205) and #6 (206) are cached and the other segments of representation 1 not shown in 212 are not cached. Typically, a greater number of representations may be provided by the content provider to achieve fine-grained rate adaptation. As clients may adaptively switch between the provided representations, it may take time to cache a complete representation, to cache a complete Adaptation Set, to cache a complete Group, to cache a complete Period, and a complete media clip.
[0048] By way of example and shown with reference to Figure 4a and 4b, the proxy receives a GET segment #1 of representation 1 request from the client (221) and sends the cached segment #1 of representation 1 (201) to the client (222). The segment #1 fetch time is shown in 223. For the second segment, the proxy receive a GET segment #2 of representation 2 (224), the proxy sends the cached segment #2 of representation 2 (207) to the client (225). The segment fetching time #2 is shown in 226. The proxy receives a request for the GET segment #3 of representation 2 from the streaming client (227) and fetches the segment #3 of the representation 2 from remote location in 228 and 229, e.g. streaming server in this example. The proxy then sends the segment #3 of the representation 2 to the client (230). The segment #3 fetch time is shown in 231. The segment #3 fetch time (231) is much larger than the segment fetch time #2 (226), which may cause the client to switch-down representation level using the rate adaptation algorithm, such as using the rate adaptation method in Chenghao Liu, Imed Bouazizi and
Moncef Gabbouj, "Rate adaptation for adaptive HTTP streaming," Proceedings of ACM MMSys 2011, which is incorporated by reference herein. The proxy receives a GET segment #4 of representation 1 from the client (232), the proxy sends the cached segment #4 of representation 1 (204) to the client (233). As the segment #4 is fetched using relatively shorter duration as shown in 234, the client may switch-up representation level again after receiving the segment #4. Hence a representation level may fluctuate between different representation levels instead of converging to a representation level, as shown in the Figure 4b because the client fetches the segment from the proxy and remote streaming server in-turn. Furthermore, incorrect switching-up representation level may result in frequent playback interruption at DASH client since the limited bandwidth and relatively large Round Trip Time (RTT) between an origin server to proxy caches, especially when the origin server is located overseas relative to the DASH client. A buffered media time based rate adaptation method may be deployed to smooth the variation in the segment fetch time. However, missing several consecutive segments in the proxy and caching several consecutive segments may cause the high variation in the buffered media time and result in buffer draining-up. Furthermore, buffered media time based rate adaptation method may decline the rate adaptation speed, which may further cause buffer draining-up. For segment fetch time based and buffered media time based rate adaptation method for DASH over proxy cache, DASH client may frequently suffer from playback interruption due to the limited bandwidth and relatively large Round Trip Time (RTT) between an origin server to proxy caches, and incorrect rate adaptation.
[0049] Methods, apparatuses, and computer program products are herein provided for appending the syntax of DASH segment requests to indicate that segments from other representations are allowed in responses. Further some example embodiments, as described herein, may be configured to modify a streaming client apparatus operation in such a way that it grants the permission to have a respective segment from certain other representations as a response to a segment request. Further still, some example embodiments may modify a proxy operation such that a proxy cache apparatus may be configured to determine if alternative segments can be used in responses and, in an instance in which the request segment or any of the alternative segments are readily available in the proxy cache apparatus, selecting one of those segments to respond to the segment request.
[0050] Previously, a specific single segment (or more generically a single resource) identified by a specific URL could be requested with one HTTP GET request. That is there was no alternative or options for other segments (from other representations) to be indicated. Hence, proxies have not had means to respond to requests with alternative resources. Using the systems and methods as described herein, a proxy may be configured to respond to a request with a primary or alternative representation- hence, for example, the overall network traffic as well as the number of accesses to an origin server may be reduced. Moreover, for example, the average response time experienced by a client may decrease, as it is more likely that a proxy can respond to a request. Consequently, DASH clients (e.g. a streaming client apparatus) are likely to make fewer incorrect rate adaptation decisions due to late-arriving segments and are also likely to face fewer interruptions in playback due to the same reason.
[0051] Referring now to Figure 1, Figure 1 illustrates a block diagram of a system
100 for accepting multiple representations for DASH according to an example embodiment. It will be appreciated that the system 100 as well as the illustrations in other figures are each provided as an example of some embodiments and should not be construed to narrow the scope or spirit of the disclosure in any way. In this regard, the scope of the disclosure encompasses many potential embodiments in addition to those illustrated and described herein. As such, while Figure 1 illustrates one example of a configuration of a system for accepting multiple representations for DASH, numerous other configurations may also be used to implement embodiments of the present invention.
[0052] The system 100 may include one or more streaming client apparatuses 102 (also known as a DASH client, user agent or the like), one or more proxy cache apparatuses 104 (also known as a proxy), and/or one or more serving network apparatuses 108. The system 100 may further comprise a network 106. The network 106 may comprise one or more wireline networks, one or more wireless networks, or some combination thereof. The network 106 may, for example, comprise a serving network (e.g., a serving cellular network) for one or more streaming client apparatuses 102 and/or more proxy cache apparatuses 104. The network 106 may comprise, in certain embodiments, one or more streaming client apparatuses 102, one or more proxy cache apparatuses 104, and/or one or more serving network apparatuses 108 themselves. According to example embodiments, the network 106 may comprise the Internet. The network 106 may comprise, in some embodiments, a Content Delivery Network (CDN), which may also be referred to as a Content Distribution Network. In various embodiments, the network 106 may comprise a wired access link connecting one or more streaming client apparatuses 102 or one or more proxy cache apparatuses 104 to the rest of the network 106 using, for example,
Digital Subscriber Line (DSL) technology. In some embodiments, the network 106 may comprise a public land mobile network (for example, a cellular network), such as may be implemented by a network operator (for example, a cellular access provider). The network 106 may operate in accordance with universal terrestrial radio access network (UTRAN) standards, evolved UTRAN (E-UTRAN) standards, current and future implementations of Third Generation Partnership Project (3 GPP) LTE (also referred to as LTE-A) standards, current and future implementations of International Telecommunications Union (ITU) International Mobile Telecommunications - Advanced (IMT-A) systems standards, and/or the like. It will be appreciated, however, that where references herein are made to a network standard and/or terminology particular to a network standard, the references are provided merely by way of example and not by way of limitation.
[0053] According to various embodiments, one or more streaming client apparatuses 102 may be configured to connect directly with one or more serving network apparatuses 108 via, for example, an air interface without routing communications via one or more elements of the network 106. Alternatively or additionally, one or more of the streaming client apparatuses 102 may be configured to communicate with one or more of the serving network apparatuses 108 over the network 106. In this regard, the serving network apparatuses 108 may comprise one or more nodes of the network 106. For example, in some example embodiments, the serving network apparatuses 108 may be at least partially embodied on one or more computing devices that comprise an element of a radio access network (RAN) portion of the network 106. In this regard, the serving network apparatuses 108 may, for example, be at least partially embodied on an access point of the network 106 (for example, a macrocell, microcell, picocell, femtocell, closed subscriber group (CSG) cell, base station, base transceiver station (BTS), node B, evolved node B, access point (AP), group owner, mesh station (STA), mesh point, and/or the like), which may, for example be configured to provide access to the network 106 (e.g., via a radio uplink) to one or more of the streaming client apparatuses 102. In some embodiments, the serving network apparatuses 108 may comprise an Access Network Discovery and Selection Function (ANDSF), and/or the like. Accordingly, each of the serving network apparatuses 108 may comprise a network node or a plurality of network nodes collectively configured to perform one or more operations attributed to the serving network apparatuses 108 as described with respect to various example embodiments disclosed herein.
[0054] Alternatively or additionally, according to some example embodiments, one or more streaming client apparatuses 102 may be configured to connect with the one or more proxy cache apparatuses 104. In such embodiments, the one or more proxy cache apparatuses 104 may be in communication with the one or more serving network apparatuses 108 in the same or similar fashions as described with respect to the one or more of the streaming client apparatuses 102 described above.
[0055] According to various embodiments, the system 100 may be configured according to an architecture for providing for distribution of media content. In this regard, the system 100 may be configured as an HTTP streaming system. For example, the system 100 may be configured to distribute one or more media presentations, as defined by a DASH standard such as 3 GPP DASH (3 GPP Technical Specification 26.246) or Moving Picture Experts Group (MPEG) DASH (ISO/IEC International Standard 23009-1) both of which are incorporated by reference herein.
[0056] According to various embodiments, the system 100 may be configured to implement a server-driven alternative representation method, for example a streaming client apparatus 102 may cause a proxy cache apparatus 104 to respond to an HTTP request with a primary representation or an alternative representation depending on the caching status at a proxy cache apparatus 104. According to various embodiments, the system 100 may also be configured to implement an agent-driven alternative representation method, for example a streaming client apparatus 102 may cause a proxy cache apparatus 104 to provide the cached alternative resources' uniform resource indicator (URI) for selection. Upon receiving a signaling from a proxy cache apparatus 104, a streaming client apparatus 102 may request optimum resource for agent-driven content negotiation.
[0057] In some example embodiments, an alternative representation as described herein may represent a representation cached by a proxy cache apparatus 104 that is accepted by a streaming client apparatus 102 as an alternative to the requested primary representation. Moreover, the signaling for the alternative representations occurs between a streaming client apparatus 102 and a proxy cache apparatus 104.
[0058] In various embodiments below, a list of alternative URLs, representations, resources, or alike is provided in the segment request syntax. The list can be unordered, i.e. a streaming client apparatus 102 may not have an indicated preference which one(s) of the members of the list it would like to receive in the response. Alternatively, the list can be ordered, i.e. a certain item in the list may be preferred to be received instead of any items following that certain item in the list. Alternatively, the list may be a combination of ordered and unordered items, where it is indicated whether a particular list item is listed in priority order relative to other ordered items or whether the placement of a particular list item in the list indicates no preference relative to other list items. Alternatively, the preferences between the list items may be explicitly indicated for example by giving or deriving a priority value for each list item. The same priority value may be used if the client has no preference between the respective list items.
[0059] Alternatively or additionally, some embodiments of the system 100 may comprise server-driven content negotiation, where the streaming client apparatus 102 indicates its preferences in the HTTP GET request and the proxy cache apparatus 104 selects the resource that suits streaming client's needs and preferences. In agent-driven content negotiation, where the proxy cache apparatus 104 may respond with a number of alternative URIs from which the client can choose the best URI suited for its needs.
[0060] A streaming client apparatus 102 may be embodied as any computing device, such as, for example, a desktop computer, laptop computer, mobile terminal, mobile computer, mobile phone, mobile communication device, tablet computing device, game device, digital camera/camcorder, audio/video player, television device, radio receiver, digital video recorder, positioning device, wrist watch, portable digital assistant (PDA), fixed transceiver device (e.g., attached to traffic lights, energy meters, light bulbs, and/or the like), a chipset, an apparatus comprising a chipset, any combination thereof, and/or the like.
[0061] In some example embodiments, a streaming client apparatus 102 may be embodied as a mobile terminal, such as that illustrated in Figure 2. In this regard, Figure 2 illustrates a block diagram of a mobile terminal 10 representative of one embodiment of a streaming client apparatus 102. It should be understood, however, that the mobile terminal 10 illustrated and hereinafter described is merely illustrative of one type of computing device (i.e., streaming client apparatus 102) that may implement and/or benefit from various embodiments and, therefore, should not be taken to limit the scope of the disclosure. While several embodiments of the electronic device are illustrated and will be hereinafter described for purposes of example, other types of electronic devices, such as mobile telephones, mobile computers, portable digital assistants (PDAs), pagers, laptop computers, desktop computers, gaming devices, televisions, and other types of electronic systems, may employ various embodiments of the invention.
[0062] As shown, the mobile terminal 10 may include an antenna 12 (or multiple antennas 12) in communication with a transmitter 14 and a receiver 16. The mobile terminal 10 may also include a processor 20 configured to provide signals to and receive signals from the transmitter and receiver, respectively. The processor 20 may, for example, be embodied as various means including circuitry, one or more microprocessors with accompanying digital signal processor(s), one or more processor(s) without an accompanying digital signal processor, one or more coprocessors, one or more multi-core processors, one or more controllers, processing circuitry, one or more computers, various other processing elements including integrated circuits such as, for example, an ASIC (application specific integrated circuit) or FPGA (field programmable gate array), or some combination thereof. Accordingly, although illustrated in Figure 2 as a single processor, in some example embodiments the processor 20 may comprise a plurality of processors. These signals sent and received by the processor 20 may include signaling information in accordance with an air interface standard of an applicable cellular system, and/or any number of different wireline or wireless networking techniques, comprising but not limited to Wi-Fi, wireless local access network (WLAN) techniques such as Bluetooth™ (BT), Ultra- wideband (UWB), Institute of Electrical and Electronics Engineers (IEEE) 802.11, 802.16, and/or the like. In addition, these signals may include speech data, user generated data, user requested data, and/or the like. In this regard, the mobile terminal may be capable of operating with one or more air interface standards, communication protocols, modulation types, access types, and/or the like. More particularly, the mobile terminal may be capable of operating in accordance with various first generation (1G), second generation (2G), 2.5G, third-generation (3G) communication protocols, fourth-generation (4G) communication protocols, Internet Protocol Multimedia Subsystem (IMS) communication protocols (for example, session initiation protocol (SIP)), and/or the like. For example, the mobile terminal may be capable of operating in accordance with 2G wireless communication protocols IS- 136 (Time Division Multiple Access (TDMA)), Global System for Mobile communications (GSM), IS-95 (Code Division Multiple Access (CDMA)), and/or the like. Also, for example, the mobile terminal may be capable of operating in accordance with 2.5G wireless communication protocols General Packet Radio Service (GPRS), Enhanced Data GSM Environment (EDGE), and/or the like. Further, for example, the mobile terminal may be capable of operating in accordance with 3G wireless communication protocols such as Universal Mobile Telecommunications System (UMTS), Code Division Multiple Access 2000 (CDMA2000), Wideband Code Division Multiple Access (WCDMA), Time Division-Synchronous Code Division Multiple Access (TD-SCDMA), and/or the like. The mobile terminal may be additionally capable of operating in accordance with 3.9G wireless communication protocols such as Long Term Evolution (LTE) or Evolved Universal Terrestrial Radio Access Network (E- UTRAN) and/or the like. Additionally, for example, the mobile terminal may be capable of operating in accordance with fourth-generation (4G) wireless communication protocols such as LTE Advanced and/or the like as well as similar wireless communication protocols that may be developed in the future.
[0063] Some Narrow-band Advanced Mobile Phone System (NAMPS), as well as
Total Access Communication System (TACS), mobile terminals may also benefit from embodiments of this invention, as should dual or higher mode phones (for example, digital/analog or TDMA/CDM A/analog phones). Additionally, the mobile terminal 10 may be capable of operating according to Wi-Fi or Worldwide Interoperability for Microwave Access (WiMAX) protocols.
[0064] It is understood that the processor 20 may comprise circuitry for implementing audio/video and logic functions of the mobile terminal 10. For example, the processor 20 may comprise a digital signal processor device, a microprocessor device, an analog-to-digital converter, a digital-to-analog converter, and/or the like. Control and signal processing functions of the mobile terminal may be allocated between these devices according to their respective capabilities. The processor may additionally comprise an internal voice coder (VC) 20a, an internal data modem (DM) 20b, and/or the like. Further, the processor may comprise functionality to operate one or more software programs, which may be stored in memory. For example, the processor 20 may be capable of operating a connectivity program, such as a web browser. The connectivity program may allow the mobile terminal 10 to transmit and receive web content, such as location-based content, according to a protocol, such as Wireless Application Protocol (WAP), hypertext transfer protocol (HTTP), and/or the like. The mobile terminal 10 may be capable of using Transmission Control Protocol/Internet Protocol (TCP/IP) to transmit and receive web content across the internet or other networks.
[0065] The mobile terminal 10 may also comprise a user interface including, for example, an earphone or speaker 24, a ringer 22, a microphone 26, a display 28, a user input interface, and/or the like, which may be operationally coupled to the processor 20. In this regard, the processor 20 may comprise user interface circuitry configured to control at least some functions of one or more elements of the user interface, such as, for example, the speaker 24, the ringer 22, the microphone 26, the display 28, and/or the like. The processor 20 and/or user interface circuitry comprising the processor 20 may be configured to control one or more functions of one or more elements of the user interface through computer program instructions (for example, software and/or firmware) stored on a memory accessible to the processor 20 (for example, volatile memory 40, non-volatile memory 42, and/or the like). Although not shown, the mobile terminal may comprise a battery for powering various circuits related to the mobile terminal, for example, a circuit to provide mechanical vibration as a detectable output. The user input interface may comprise devices allowing the mobile terminal to receive data, such as a keypad 30, a touch display (not shown), a joystick (not shown), and/or other input device. In embodiments including a keypad, the keypad may comprise numeric (0-9) and related keys (#, *), and/or other keys for operating the mobile terminal.
[0066] As shown in Figure 2, the mobile terminal 10 may also include one or more means for sharing and/or obtaining data. For example, the mobile terminal may comprise a short-range radio frequency (RF) transceiver and/or interrogator 64 so data may be shared with and/or obtained from electronic devices in accordance with RF techniques. The mobile terminal may comprise other short-range transceivers, such as, for example, an infrared (IR) transceiver 66, a Bluetooth™ (BT) transceiver 68 operating using Bluetooth™ brand wireless technology developed by the Bluetooth™ Special Interest Group, a wireless universal serial bus (USB) transceiver 70 and/or the like. The Bluetooth™ transceiver 68 may be capable of operating according to low power/energy or ultra-low power/energy Bluetooth™ technology (for example, Wibree™) radio standards. In this regard, the mobile terminal 10 and, in particular, the short-range transceiver may be capable of transmitting data to and/or receiving data from electronic devices within a proximity of the mobile terminal, such as within 10 meters, for example. Although not shown, the mobile terminal may be capable of transmitting and/or receiving data from electronic devices according to various wireless networking techniques, including 6LoWpan, Wi-Fi, Wi-Fi low power, WLAN techniques such as IEEE 802.11 techniques, IEEE 802.15 techniques, IEEE 802.16 techniques, and/or the like.
[0067] The mobile terminal 10 may comprise memory, such as a removable or non-removable subscriber identity module (SIM) 38, a soft SIM 38, a fixed SIM 38, a removable or non-removable universal subscriber identity module (USIM) 38, a soft USIM 38, a fixed USIM 38, a removable user identity module (R-UIM), and/or the like, which may store information elements related to a mobile subscriber. In addition to the SIM, the mobile terminal may comprise other removable and/or fixed memory. The mobile terminal
10 may include volatile memory 40 and/or non- volatile memory 42. For example, volatile memory 40 may include Random Access Memory (RAM) including dynamic and/or static
RAM, on-chip or off-chip cache memory, and/or the like. Non-volatile memory 42, which may be embedded and/or removable, may include, for example, read-only memory, flash memory, magnetic storage devices (for example, hard disks, floppy disk drives, magnetic tape, etc.), optical disc drives and/or media, non-volatile random access memory (NVRAM), and/or the like. Like volatile memory 40 non-volatile memory 42 may comprise a cache area for temporary storage of data. The memories may store one or more software programs, instructions, pieces of information, data, and/or the like which may be used by the mobile terminal for performing functions of the mobile terminal. For example, the memories may comprise an identifier, such as an international mobile equipment identification (IMEI) code, capable of uniquely identifying the mobile terminal 10.
[0068] Referring now to Figure 3, Figure 3 illustrates a block diagram of an apparatus 300 according to an example embodiment. In the example embodiment, the streaming client apparatus 102, the proxy cache apparatus 104, and/or the serving network apparatus 108 may be implemented in or otherwise embodied by the apparatus 300. These means may comprise one or more of a processor 110, memory 112, communication interface 114, user interface 116, or flexible caching module 118. The means of the apparatus 300 as described herein may be embodied as, for example, circuitry, hardware elements (e.g., a suitably programmed processor, combinational logic circuit, and/or the like), a computer program product comprising computer-readable program instructions (e.g., software or firmware) stored on a computer-readable medium (for example memory 112) that is executable by a suitably configured processing device (e.g., the processor 110), or some combination thereof.
[0069] In some example embodiments, one or more of the means illustrated in
Figure 3 may be embodied as a chip or chip set. In other words, the apparatus 300 may comprise one or more physical packages (for example, chips) including materials, components and/or wires on a structural assembly (for example, a baseboard). The structural assembly may provide physical strength, conservation of size, and/or limitation of electrical interaction for component circuitry included thereon. In this regard, the processor 110, memory 112, communication interface 114, user interface 116, and/or flexible caching module 118 may be embodied as a chip or chip set. The apparatus 300 may therefore, in some example embodiments, be configured to implement embodiments of the present invention on a single chip or as a single "system on a chip." As another example, in some example embodiments, the apparatus 300 may comprise component(s) configured to implement embodiments of the present invention on a single chip or as a single "system on a chip." As such, in some cases, a chip or chipset may constitute means for performing one or more operations for providing the functionalities described herein and/or for enabling user interface navigation with respect to the functionalities and/or services described herein.
[0070] The processor 110 may, for example, be embodied as various means including one or more microprocessors with accompanying digital signal processor(s), one or more processor(s) without an accompanying digital signal processor, one or more coprocessors, one or more multi-core processors, one or more controllers, processing circuitry, one or more computers, various other processing elements including integrated circuits such as, for example, an ASIC (application specific integrated circuit) or FPGA (field programmable gate array), one or more other hardware processors, or some combination thereof. Accordingly, although illustrated in Figure 3 as a single processor, in some embodiments the processor 110 may comprise a plurality of processors. The plurality of processors may be in operative communication with each other and may be collectively configured to perform one or more functionalities of the apparatus 300 as described herein. The plurality of processors may be embodied on a single computing device or distributed across a plurality of computing devices collectively configured to function as the apparatus 300. In embodiments wherein the apparatus 300 is embodied as a mobile terminal 10, the processor 110 may be embodied as or comprise the processor 20. In some example embodiments, the processor 110 is configured to execute instructions stored in the memory 112 or otherwise accessible to the processor 110. These instructions, when executed by the processor 110, may cause the apparatus 300 to perform one or more of the functionalities of the apparatus 300 as described herein. As such, whether configured by hardware or software methods, or by a combination thereof, the processor 1 10 may comprise an entity capable of performing operations according to embodiments of the present invention while configured accordingly. Thus, for example, when the processor 110 is embodied as an ASIC, FPGA or the like, the processor 110 may comprise specifically configured hardware for conducting one or more operations described herein. Alternatively, as another example, when the processor 110 is embodied as an executor of instructions, such as may be stored in the memory 112, the instructions may specifically configure the processor 110 to perform one or more algorithms and operations described herein.
[0071] The memory 112 may comprise, for example, volatile memory, non-volatile memory, or some combination thereof. In this regard, the memory 112 may comprise one or more tangible and/or non-transitory computer-readable storage media that may include volatile and/or non-volatile memory. Although illustrated in Figure 3 as a single memory, the memory 112 may comprise a plurality of memories. The plurality of memories may be embodied on a single computing device or may be distributed across a plurality of computing devices collectively configured to function as the apparatus 300. In various example embodiments, the memory 112 may comprise a hard disk, random access memory, cache memory, flash memory, a compact disc read only memory (CD-ROM), digital versatile disc read only memory (DVD-ROM), an optical disc, circuitry configured to store information, or some combination thereof. In embodiments wherein the apparatus 300 is embodied as a mobile terminal 10, the memory 112 may comprise the volatile memory 40 and/or the non-volatile memory 42. The memory 112 may be configured to store information, data, applications, instructions, or the like for enabling the apparatus 300 to carry out various functions in accordance with various example embodiments. For example, in some example embodiments, the memory 112 is configured to buffer input data for processing by the processor 110. Additionally or alternatively, the memory 112 may be configured to store program instructions for execution by the processor 110. The memory 1 12 may store information in the form of static and/or dynamic information. This stored information may be stored and/or used by the flexible caching module 118 during the course of performing its functionalities.
[0072] The communication interface 114 may be embodied as any device or means embodied in circuitry, hardware, a computer program product comprising computer readable program instructions stored on a computer readable medium (for example, the memory 112) and executed by a processing device (for example, the processor 110), or a combination thereof that is configured to receive and/or transmit data from/to another computing device. In an example embodiment, the communication interface 114 may be at least partially embodied as or otherwise controlled by the processor 1 10. In this regard, the communication interface 114 may be in communication with the processor 110, such as via a bus. The communication interface 114 may include, for example, an antenna, a transmitter, a receiver, a transceiver and/or supporting hardware or software for enabling communications with one or more remote computing devices. The communication interface 114 may be configured to receive and/or transmit data using any protocol that may be used for communications between computing devices. In this regard, the communication interface 114 may be configured to receive and/or transmit data using any protocol that may be used for transmission of data over a wireless network, wireline network, some combination thereof, or the like by which the streaming client apparatus
102 and one or more computing devices or computing resources may be in communication. As an example, the communication interface 114 may be configured to enable communication between the apparatus 300 and another device, such as another apparatus 300. As a further example, the communication interface 114 may be configured to enable communication via the network 106. The communication interface 114 may additionally be in communication with the memory 112, user interface 116, and/or flexible caching module 118, such as via a bus.
[0073] The user interface 116 may be in communication with the processor 110 to receive an indication of a user input and/or to provide an audible, visual, mechanical, or other output to a user. As such, the user interface 116 may include, for example, a keyboard, a mouse, a joystick, a display, a touch screen display, a microphone, a speaker, and/or other input/output mechanisms. In embodiments wherein the user interface 1 16 comprises a touch screen display, the user interface 1 16 may additionally be configured to detect and/or receive indication of a touch gesture or other input to the touch screen display. The user interface 116 may be in communication with the memory 112, communication interface 114, and/or flexible caching module 118, such as via a bus.
[0074] The flexible caching module 118 may be embodied as various means, such as circuitry, hardware, a computer program product comprising computer readable program instructions stored on a computer readable medium (for example, the memory 112) and executed by a processing device (for example, the processor 110), or some combination thereof and, in some embodiments, is embodied as or otherwise controlled by the processor 110. In embodiments wherein the flexible caching module 118 is embodied separately from the processor 110, the flexible caching module 118 may be in communication with the processor 1 10. The flexible caching module 118 may further be in communication with one or more of the memory 112, communication interface 114, or user interface 116, such as via a bus.
[0075] In some example embodiments, the flexible caching module 118 is configured to set an @segmentAlignment in an MPD to a non-false value. Such a setting may indicate that presentation start and end times of media components of any particular media type are temporally aligned in all Segments across all Representations in the Adaptation Set (in which the @segmentAlignment is included).
[0076] In some example embodiments, the streaming client apparatus 102, such as by using the processor 110, the flexible caching module 118 or the like, may be configured to use an "Accept-Alternative-URI" header field to specify URIs that are acceptable as responses to a GET request in which the "Accept-Alternative-URI" header field is included. In some example embodiments the "Accept-Alternative-URI" header field may be used in server-driven content negotiation. A syntax of an "Accept-Alternative-URI" header field may be specified as follows using a form of the Augmented Backus-Naur Form (ABNF):
Accept-Alternative-URI = # (Alternative-URI [OWS ";" OWS "q=" qvalue] )
Alternative-URI="http : " "//" alternative authority path- abempty [ "?" query]
[0077] In some example embodiments, the proxy cache apparatus 104 of Figure 1 may be configured to respond to a GET request, such as by using the processor 110, the communications interface 114, the flexible caching module 118 or the like in an instance in which the requested resource or any of the resources listed in the "Accept-Alternative- URI" header and any of those resources fulfills the other requirements of the request, indicated for example by one of more of the header fields for enabling server-driven content negotiation or cache control directives of the request.
[0078] In some example embodiments, "Accept-Alternative-URI" may be used with a "Connection" header field and may specify the "Accept-Alternative-URI." A "Connection" header field may enable a streaming client apparatus 102 to specify that the "Accept-Alternative-URI" option is desired for the connection between the streaming client apparatus 102 and the proxy cache apparatus 104. A "Connection" ABNF syntax for "Accept-Alternative-URI" is defined as follows
Connection = l#connectin-token
Connection-token = Accept-Alternative-URI
[0079] In some embodiments, the proxy cache apparatus 104, such as the by the processor 110, the flexible caching module 118 or the like, may parse a received Connection header field before a message is forwarded and, for each connection-token in this field, remove any header field(s) from the message with the same name as the connection-token, specifically Accept-Alternative-URI, and then remove the Connection header field itself or replace it with the sender's own connection options for the forwarded message. In some cases, a HTTP GET request may be forwarded in an instance in which a proxy has no requested resource or any of the resources listed in the "Accept-Alternative- URI" available.
[0080] In some example embodiments, an example HTTP GET request may include a first URI (for a particular segment of a first representation) including a number of accepted q values and an indication of a segment from another representation that may be a proper response. The segment from the other representation may originally have had a different URI than the requested URL Hence, the same resource may appear in subsequent proxies or caches under different URIs. Cache directives may therefore be used to prevent caching of the response in any subsequent proxies/caches.
[0081] A HTTP GET segment #1 may include an example of "Accept- Alternative-
URI" usage:
GET http : //example . com/contents/rep-5/seg-1.3gp
Connection : Accept-Alternative-URI
Accept-Alternative-URI : http : //example . com/contents/rep- 4/seg-l .3gp; q=0.8,
http : //example . com/contents/rep-3/seg-1.3gp; q=0.6
[0082] An example HTTP GET segment#2 request:
GET http://example.com/contents/rep-6/seg-2.3gp
Connection : Accept-Alternative-URI
Accept-Alternative-URI : http : //example . com/contents/rep-
5/seg-l .3gp; q=0.8,
http : //example . com/contents/rep-4/seg-1.3gp; q=0.5
[0083] With reference to the example of an HTTP GET request for segment #1 above, example.com/contents/rep-5/seg-l .3gp may be identified as the primary URI, and http://example.com/contents/rep-4/seg-l .3gp and example.com/contents/rep-3/seg-l .3gp may be identifies as alternative URIs.
[0084] In an instance in which a proxy cache apparatus 104 determines a resource for the primary URI, it may be configured to respond to a streaming client apparatus 102 with the primary URI.
[0085] In an instance in which the primary resource is not cached at a proxy cache apparatus 104, then the proxy cache apparatus 104 may respond, such as by the processor
110, the communications interface 114, the flexible caching module 118 or the like, with a resource, such as a secondary resource. With reference to the example of an HTTP GET request for segment #1 above, the proxy cache apparatus 104 may respond with the resource example.com/contents/rep-4/seg-l .3gp. Otherwise, a proxy cache apparatus 104 may respond with the resource corresponding to GET http://example.com/contents/rep-
3/seg-1.3gp. If more than one of the identified secondary resources are available in the proxy cache apparatus 104, the proxy cache apparatus may select the resource used in the response according to the q value. A proxy cache apparatus 104 may process the directive of "Connection" header field to move the connection-token, specifically Accept- Alternative-URI header field in this example. The "Connection" header field may be configured to allow the sender, such as a streaming client apparatus 102, to specify options that are desired for a particular connection.
[0086] In some example embodiments, a header field, such as an "Accept-
Alternative-Representation" header, may be added by a flexible caching module 118 to a request. The example header field may be used to indicate to a proxy cache apparatus 104 that alternative representations in addition to the primary representation are acceptable. The example header field may also include a list of accepted alternative Representation@id values, which in some embodiments a streaming client apparatus 102 may have determined. The syntax of an example "Accept-Alternative-Representation" header field includes but is not limited to:
Accept-Alternative-Representation = #URI-Template;
( "representationID" "=" representationid-rangespec [accept- params ] )
URI-Template = http ":" hier-part [ "?" query ] [ "#" fragment ]
hier-part = "//" authority path-abempty
/ path-absolute-including $representationID$
/ path-rootless-including $representationID$
/ path-empty-including $representationID$
representationid-rangespec = ("*"
/ (representationid-range)
/ (representationid-list)
)
representationid-range = / ( [representationid] "-" [ representationid] )
representationid-list = representationid *(","
representationid)
representationid = *ALPHA
accept-params = ( [OWS ";" OWS "q=" qvalue]
/ [OWS ";" OWS "q=" qvalue-range ] )
qvalue-range = start-qvalue "-" end-qvalue
[0087] In some example embodiments, the flexible caching module 118 may use a
URI-Template and an representationid-rangespec to construct an alternative URL The URI-Template may be the same or similar to the primary URI except that it may have a different representationID. In a primary URI, a representationID is typically a certain integer value but may alternatively be any string to be used with a representation-list. In other words, the Representation@id values, which are represented by representationid syntax element in the ABNF syntax above, may be any alphanumeric strings of a certain set of values, such as non-negative integer values. The URI-Template may contain a placeholder for the representationID and a placeholder may appear in the URI-Template as "$representationID$". The flexible caching module 118 may indicate that alternative representation IDs are accepted by using a range or a list of representation IDs. When a range is used, the first given representationid and the second given representationid may indicate the start and end of alternative representation IDs for a continuous range. For use of the representationid-range syntax, an order or sorting of Representation@id values may be specified, such as arranging integer values in ascending order or alphanumeric strings in alphabetical order. The representationid-range syntax may specify all values from the first given representationid until the second given representationid, inclusive, in the specified order or sorting of Representation@id to identify alternative representations. The start alternative representation ID may be larger than, or lower than, the end alternative representation ID. The start and end alternative representation ID may be assigned an associated start-quality value and end-quality value, respectively, which represents the preference of the corresponding boundary representation ID. The quality value of other alternative representation IDs excepting the start and end alternative representation ID can be derived, such as by the flexible caching module 118, by uniformly distributing a quality value between start-quality value and end-quality value. When a list is used, a list of accepting representation IDs can be listed. Each representation ID may be assigned an associated quality value which represents the preference of the representation having such representation ID. The default value is q=\ , which indicates the highest preference. On the other hand, q=0 indicates the lowest preference.
[0088] An example of Accept-Alternative-Representation with range is given as follows
Accept-Alternative-Representation :
http : / /example . com/contents/rep-$representationID$/seg-1.3gp; representationID=4-2 ; q=0.8-0.2 [0089] The example of Accept-Alternative-Representation with range may be interpreted for example as an instance in which a primary representation was not cached for seg-1.3gp, the streaming client apparatus 102 may then be configured to accept three alternative representations for seg.l .3gp including representations which have an ID equal to 4, 3, or 2 with the preference of 0.8, 0.5, and 0.2, respectively.
[0090] In some embodiments, a list based Accept-Representation may include:
Accept-Alternative-Representation :
http : / /example . com/contents/rep-$representationID$/seg-1.3gp; representationID=5 ; q=l , representationID=4 ; q=0.8 ,
representationID=3 ; q=0.5
[0091] The example of Accept- Alternative-Representation may be interpreted as in an instance in which a primary representation was not cached for segment#l, the streaming client apparatus 102 may be configured to, such as by a streaming client apparatus 102 accepts one of the secondary representation IDs #5, #4 and #3 for that segment. In some example embodiments, the streaming client apparatus 102 prefers, such as by the processor 110, the flexible caching module 118 or the like, the segment of representation ID #5, but if the proxy cache apparatus 104 does not cache it, then the proxy cache apparatus 104 can send the segment of representation ID #4 and if that does not exist, the proxy cache apparatus 104 can send the representation ID #3 for segment #1". An example of HTTP GET segment request at a streaming client apparatus 102 using the proposed "Accept- Alternative-Representation" header field is given as follows.
[0092] HTTP GET segment#l request:
GET http : //example . com/contents/rep-5/seg-1.3gp
Accept-Alternative-Representation :
http : //example . com/contents/rep-$representationID$/seg-1.3gp; representationID=4-3; q=0.8-0.2
[0093] HTTP GET segment#2 request:
GET http : //example . com/contents/rep-6/seg-2.3gp
Accept-Alternative-Representation :
http : //example . com/contents/rep-$representationID$/seg-2.3gp; representationID=5 ; q=0.8
[0094] The example may be interpreted as a streaming client apparatus 102 requesting, such as by the processor 110, the flexible caching module 118 or the like, a representation ID #5 for segment#l and representation ID #6 for segment#2, sequentially. For segment#l , the streaming client apparatus 102 indicates that it also accepts alternative representation IDs #4 and #3 in the case of missing representation ID #5. For segment#2, the streaming client apparatus 102 alternatively accepts representation IDs #5, in the case of missing representation ID #6.
[0095] In some example embodiments, the URI-template may also contain other placeholders such as those specified in MPEG DASH, namely $Number$ for segment identifier, $Bandwidth$ for the bandwidth of the Representation (which streaming client apparatus 102, may derive, such as by the processor 110, the value of Representation@bandwidth attribute of the desired representation), and $Time$ for the segment time (streaming client apparatus 102, may derive, such as by the processor 110, the segment timeline, particularly the SegmentTimeline@t attribute). In some example embodiments, the values to be inserted in place of the placeholders when resolving a URI from the URI-template are passed within the Accept-Alternative-Representation header similarly to the accepted representation IDs. [0096] In other example embodiments, a header field in a request such as "Accept-
Cached- Alternative-Representation" may be specified by a flexible caching module 118. "Accept-Cached-Alternative-Representation" may be used to direct a proxy cache apparatus 104 to reply with a list and range of URIs for the cached alternative resources for agent-driven content negotiation. "Accept-Cached-Alternative-Representation" may also include a secondary URIs' template for searching the cached alternative resources.
[0097] The syntax of "Accept-Cached-Alternative-Representation" header field includes but is not limited to:
Accept-Cached-Alternative-Representation = #URI -Template;
URI-Template = http ":" hier-part [ "?" query ] [ "#" fragment
]
hier-part = "//" authority path-abempty
/ path-absolute-including $representationID$
/ path-rootless-including $representationID$
/ path-empty-including $representationID$
[0098] By way of example, the primary URI in the HTTP GET request may also include an indication including a URI template to request a caching proxy to reply with a list and range of URIs for the cached alternative resources for agent-driven content negotiation. The URI of the primarily requested resource should result when substituting $RepresentationID$ in the URI template with the Representation@id value of the representation that is primarily requested. An example of an HTTP GET segment request at a streaming client apparatus 102 using the proposed "Accept-Cached- Alternative- Representation" header field includes but is not limited to:
GET http://example.com/contents/rep-5/seg-l.3gp
Accept-Cached-Alternative-Representation :
http : / /example . com/contents/rep-$representationID$/seg-1.3gp;
[0099] The "Accept-Cached- Alternative-Representation" header field, for example, may be interpreted as a primary representation #5 that is not cached for seg-1.3gp. A streaming client apparatus 102 may request, such as by the processor 110, the communications interface 114, the flexible caching module 118 or like, a proxy cache apparatus 104 to respond all cached secondary URIs, which matches the template specified in an "Accept-Cached- Alternative-Representation" for the alternative resources.
[00100] In some example embodiments and as described herein, each media-range in an Accept header may be followed by one or more accept-parameters, beginning with the "q" parameter for indicating a relative quality factor. The first "q" parameter (if any) separates the media-range parameter(s) from the accept-parameters. In some example embodiments, quality factors allow a streaming client apparatus 102 to indicate, such as by the processor 110, the flexible caching module 118 or the like, the relative degree of preference for that media-range, using the q value scale from 0 to 1. In some embodiments the q value may be used to determine selection criteria for an alternative representation.
[00101] In some example embodiments, a media type DASH and sub-types representation-x are specified for server-driven content negotiation, they include but are not limited to:
new content type = type/subtype
type=dash
subtype=representation-x
where x can be a integer value or alternatively any string.
[00102] In some example embodiments, a Representation of an Adaptation Set may be associated with a content type. A specific content type can be associated with a "q" parameter to indicate the preference of such content type. An example of an adaption set to accept secondary representations using the "Accept" header field include but are not limited to:
[00103] "Accept" header field may include
Accept: (dash/representation-x, q=qvalue)
[00104] The example accept header field may list one or multiple secondary subtypes that are configured to indicate to a proxy cache apparatus 104 that a streaming client apparatus 102, accepts a particular content type. An embodiment of HTTP GET segment request may include
URI = scheme ":" hier-part [ "?" query ]
hier-part = "//" authority path-abempty
/ path-absolute
/ path-rootless
/ path-empty
query = content-type=dash/representation-x
Accept: (dash/representation-x, q=qvalue)
[00105] An example of "Accept" using the defined media type/subtype includes but is not limited to a HTTP GET segment#l request:
GET http : //example . com/contents/seg-1.3gp?content- type=dash/representation-5
Connection: Accept
Accept: dash/representation-4 ; q=0.8, dash/representation-3 ; q=0.6
[00106] The example may be interpreted as the primary content type that a streaming client apparatus 102 is dash/representation-5 for seg-1.3gp. If the primary content type is not cached by a proxy cache apparatus 104, then a streaming client apparatus 102 may also accept content type dash/representation-4. Otherwise, if content type dash/representation-5 and dash/representation-4 are not cached, then a streaming client apparatus 102 may also accept content type dash/representation-3. Otherwise, (if the primary content type and secondary content type are not cached by a caching proxy), then a proxy cache apparatus 104 may should process the directive of "Connection" header field to move the connection-token, specifically "Accept" header field in this example.
[00107] To use the content type based accepting multiple representation method, a proxy cache apparatus 104 may be configured to be aware of the new content type dash/representation-x.
[00108] In some embodiments, the subtype may be additionally defined to identify the Adaptation Set, e.g. subtype=adaptation-set-X-representation-Y, which may be used by replacing X and Y with integer values of Adaptation Set ID and Representation ID.
[00109] In an embodiment, a "Response-URI" header field for HTTP GET responses may be specified. "Response-URI" may be used to indicate to a streaming client apparatus 102 that an alternative URI is provided due to the missing primary URI at a caching proxy for server-driven content negotiation. The header field may include the selected URI. The syntax and semantics of "Response-URI" header field is specified as follows. In a HTTP response, a status code, such as "208 Alternative Content", may be used in a HTTP response to indicate to a streaming client apparatus 102 that the resource in a response does not include the resource for the primary URI. In a server driven content negotiation case, "Accept-Alternative-URI" or "Accept-Alternative-Representation" should be included in a "Vary" header field to express the parameters the caching proxy server uses to select a representation that is subject to server-driven negotiation.
Response-URI = 1#URI
[00110] URI indicates the URI of responding resources. Response header field "Response-URI" may be used to respond to an HTTP GET request with header field "Accept-Alternative-URI".
[00111] In some example embodiments, "Accept-Alternative-URI" and "Response- URI" may be cooperatively used to signal from a streaming client apparatus 102 to a proxy cache apparatus 104 the accepted alternative URIs at a streaming client apparatus 102 and to signal from a streaming client apparatus 102 to a proxy cache apparatus 104 the URI for the resource which is delivered to an streaming client apparatus 102. [00112] "Accept- Alternative-URI" is used by an "Accept- Alternative-URI" aware proxy cache apparatus, such as proxy cache apparatus 104, which may be configured to identify a secondary resource to serve a streaming client apparatus 102 request in a case a proxy cache apparatus 104 cannot determine and/or locate a resource for the primary URL Specifically, an "Accept-Alternative-URI" header aware caching proxy checks (e.g. sequentially) whether or not a secondary resource, as specified in "Accept-Alternative- URI" header field, is cached by the proxy cache apparatus 104. In a case a secondary resource is delivered to a streaming client apparatus 102, a status code such as "208 Alternative Content" (as described above) may be used in a HTTP response to indicate a streaming client apparatus 102 that the resource in a response is not the resource for the primary URL In such as case, a new defined "Response-URI" header field is used to indicate the selected URI for the responding resource.
[00113] An example of signaling "Accept-Alternative-URI" and "Response-URI" between a streaming client apparatus 102 and a proxy cache apparatus 104 is given as follows.
[00114] An example streaming client apparatus 102 HTTP GET segment#l request may include but is not limited to:
GET http : / /example . com/contents/rep-5/seg-1.3gp
Accept-Alternative-URI : http : / /example . com/contents/rep-4/seg- 1.3gp; q=0.8 ,
http : / /example . com/contents/rep-3/seg-1.3gp; q=0.6
[00115] An example Proxy cache apparatus 104 HTTP response includes but is not limited to:
HTTP/1.1 208 Alternative Content
DATE: Fri Oct 17 13:00:01 EST 2011
Server: Apache/2.0
Vary: Accept-Alternative-URI
Response-URI : http : / /example . com/contents/rep-3/seg-1.3gp
[00116] In some examples, a proxy cache apparatus 104 may check, such as by a processor 110, a flexible caching module 118 or the like, a resource for a primary URI "http://example.com/contents/rep-5/seg-l .3gp." In an instance in which the primary URI is not found, the proxy cache apparatus 104 may sequentially check, such as by a processor 110, a flexible caching module 118 or the like, the resources for the secondary URIs specified in an "Accept-Alternative-URI" header field. In this example, the proxy cache apparatus 104 does not find the resource for "http://example.com/contents/rep-4/seg- 1.3gp" and finds the resource for "http://example.com/contents/rep-3/seg-l .3gp". A status code "208 Alternative Content" and header field Response-URI: http://example.com/contents/rep-3/seg-l .3gp may be sent in a HTTP response to inform the streaming client apparatus 102 that the secondary resource is delivered and the selected URI for the secondary resource. In addition, "Vary" header field may include "Accept- Alternative-URI" header field to express the parameters the proxy cache apparatus 104 uses to select a representation that is subject to server-driven negotiation.
[00117] In another embodiment, "Accept- Alternative-Representation" and
"Response-URI" may be used to signal a proxy cache apparatus 104 the accepted alternative representation IDs and to signal a streaming client apparatus 102 a representation ID used to construct the URI for the secondary resource, which is delivered to the streaming client apparatus 102.
[00118] "Accept- Alternative-Representation" may be used in an instance in which a proxy cache apparatus 104 cannot locate a resource for the primary URI by a proxy cache apparatus 104 to construct the secondary URIs. Specifically, one or multiple secondary URI(s) may be constructed by replacing the $representationID$ with the corresponding representationlDs specified in a range or list of representationlDs. A proxy cache apparatus 104 may be configured to sequentially check whether or not a secondary resource, as specified in the constructed secondary URIs, is cached by the proxy cache apparatus 104.
[00119] In an instance in which a secondary resource is delivered to a streaming client apparatus 102, a status code such as "208 Alternative Content" may be used in a HTTP response to indicate a streaming client apparatus 102, that the resource in a response is not the resource for the primary URI. In some example embodiments, a "Response-URI" may be included in HTTP header field to indicate the selected URI for the responding resource. In another embodiment, a "Response-Representation" may be included in HTTP header field to indicate the selected representation for the responding resource.
[00120] An example streaming client apparatus 102 HTTP GET segment#l request includes but is not limited to:
GET http : / /example . com/contents/rep-5/seg-1.3gp
Accept-Alternative-Representation :
http : / /example . com/contents/rep-$representationID$/seg-1.3gp; representationID=4-3; q=0.8-0.2
[00121] An example proxy cache apparatus 104 HTTP response may include but is not limited to:
HTTP/1.1 208 Alternative Content
DATE: Fri Oct 17 13:00:01 EST 2011
Server: Apache/2.0 Vary : Accept-Alternative-Representation
Response-URI : http : //example . com/contents/rep-3/seg-1.3gp
[00122] In this example, a proxy cache apparatus 104 may be configured to check a resource for the primary URI "http://example.com/contents/rep-5/seg-l .3gp." In an instance in which a primary URI is not found, the proxy cache apparatus 104 may then be configured to construct example secondary URIs http://example.com/contents/rep-4/seg- 1.3gp and http://example.com/contents/rep-5/seg-l .3gp using the URI template and representationID specified in a Accept-Alternative-Representation header field. Then the proxy cache apparatus 104 may be configured to sequentially check the resources for the secondary URIs. In this example, the proxy cache apparatus 104 does not find the resource for "http://example.com/contents/rep-4/seg-l .3gp" but finds the resource for "http://example.com/contents/rep-3/seg-l .3gp". So a status code "208 Alternative Content" and header field Response-URI: http://example.com/contents/rep-3/seg-l .3gp may be sent to a streaming client apparatus 102 in a HTTP response to inform the streaming client apparatus 102 that the secondary resource is delivered and the selected URI for the secondary resource. In addition, "Vary" header field may include "Accept-Alternative- Representation" header field to express the parameters the proxy cache apparatus 104 uses to select a representation that is subject to server-driven negotiation.
[00123] In some example embodiments, a header field in a request such as
"Response-Representation" may be specified, such as by the flexible caching module 118. "Response-Representation" may be configured to indicate to a streaming client apparatus 102, that an alternative representation is being provided by the proxy cache apparatus 104. For example, because the primary representation was not available at a proxy cache apparatus 104, the header field may include the selected Representation@id.
[00124] In some example embodiments, the syntax and semantics of "Response-
Representation" header field may include a HTTP response, status code such as "208 Alternative Content" which may be used to indicate to a streaming client apparatus 102 that the resource in a response is not the resource for the primary URI. "Accept- Alternative-Representation" should be included in a "Vary" header field to express the parameters the caching proxy server uses to select a representation that is subject to server- driven negotiation.
Response-Representation = l#representationID [00125] In some example embodiments, a RepresentationID may indicate the representation ID of the secondary representation ID. Response header field "Response- Representation" may be used with request header field "Accept-Alternative- Representation. "
[00126] "Accept-Alternative-Representation" and "Response-Representation" may be cooperatively used to signal a proxy cache apparatus 104 the accepted alternative representation IDs and to signal a streaming client apparatus 102 a representation ID used to construct the URI for the secondary resource.
[00127] In some example embodiments, "Accept-Alternative-Representation" may be used in an instance in which a proxy cache apparatus 104 cannot locate, such as by the processor 110, the flexible caching module 1 18 or the like, a resource for the primary URI by an "Accept- Alternative-Representation" aware caching proxy, such as the proxy cache apparatus 104, to construct the secondary URIs. Specifically, one or multiple secondary URI(s) may be constructed by replacing the $representationID$ with the corresponding representationlDs specified in a range or list of representationlDs. The proxy cache apparatus 104 may then be configured to sequentially determine whether or not a secondary resource, as specified in the constructed secondary URIs, is cached by the proxy cache apparatus 104.
[00128] In an instance in which a secondary resource is delivered to a streaming client apparatus 102, a status code such as "208 Alternative Content" may be used in a HTTP response to indicate that the resource in a response is not the resource for the primary URI. In some example embodiments, a "Response-URI" may be included in HTTP header field to indicate the selected URI for the responding resource. In another embodiment, a "Response-Representation" may be included in HTTP header field to indicate the selected representation for the responding resource.
[00129] An example of signaling "Accept-Alternative-Representation" and "Response-Representation" between a streaming client apparatus 102 and a proxy cache apparatus 104 is given as follow.
[00130] An example streaming client apparatus 102 HTTP GET segment#l includes but is not limited to:
GET http : / /example . com/contents/rep-5/seg-1.3gp
Accept-Alternative-Representation :
http : / /example . com/contents/rep-$representationID$/seg-1.3gp; representationID=4-3; q=0.8-0.2
[00131] An example proxy cache apparatus 104 HTTP response includes but is not limited to:
HTTP/1.1 208 Alternative Content DATE: Fri Oct 17 13:00:01 EST 2011
Server: Apache/2.0
Vary : Accept-Alternative-Representation
Response-Representation: 3
[00132] In this example, a "Response-Representation" header field is included in the response header field instead of "Response-URI" and is configured to inform a streaming client apparatus 102 that the secondary resource is delivered and the selected representation ID for the secondary resource. In addition, "Vary" header field include "Accept- Alternative-Representation" header field to express the parameters the proxy cache apparatus 104 uses to select a representation that is subject to server-driven negotiation.
[00133] In another embodiment, a header field in a request such as "Cached-
Alternative-Representation" may be specified, such as by a flexible caching module 118, which is used to signal a streaming client apparatus 102 with a list and/or a range of URIs for the cached alternative resources for agent-driven content negotiation.
[00134] The example syntax of "Cached-Alternative-Representation" header field may include but is not limited to:
Cached-Alternative-Representation = #URI-Template;
( "representationID" "=" representationid-rangespec)
URI-Template = http " : "hier-part [ "?" query ] [ "#" fragment ]
hier-part = "//" authority path-abempty
/ path-absolute-including $representationID$
/ path-rootless-including $representationID$
/ path-empty-including $representationID$
representationid-rangespec = ("*"
/ (representationid-range)
/ (representationid-list)
)
representationid-range = / ( [ representationid] "-" [ representationid] )
representationid-list = representationid *(","
representationid)
representationid = *ALPHA
[00135] In some example embodiments, the semantics of the symbols may be equal to the semantics of the symbols specified "Accept-Alternative-Representation". The difference of the header fields "Cached-Alternative-Representation" and "Accept- Alternative-Representation" is that the former signal from a proxy cache apparatus 104 to a streaming client apparatus 102 and the later signal is from a streaming client apparatus 102 to a proxy cache apparatus 104. In addition, the preference of representation on a streaming client apparatus 102 may be included in "Accept- Alternative-Representation" and the preference of representation at a caching it not included in "Cached-Alternative- Representation" .
[00136] Figure 5 illustrates a flowchart according to an example method for operation of streaming client apparatus 102 with respect to server driven content negotiation. In this regard, Figure 5 illustrates operations that may be performed at the streaming client apparatus 102. The operations illustrated in and described with respect to Figure 5 may, for example, be performed by, with the assistance of, and/or under the control of one or more of the processor 110, memory 112, communication interface 114, or flexible caching module 118. In some example embodiments, a streaming client apparatus 102 may be configured to specify a primary and secondary representation for a segment (also referred as a resource) for the alternative resources and the corresponding preference. A streaming client apparatus 102 may also be configured to signal a proxy cache apparatus 104 with the primary and secondary representation for a segment in a way that a proxy cache apparatus 104 is configured to derive a primary and secondary URIs for the primary and alternative resources and the corresponding preference.
[00137] As is shown in operation 302, a streaming client apparatus 102 is configured to cause a primary URI of the primary representation for a segment to be added in a HTTP request and in operation 303 a template that indicates that the streaming client apparatus 102 is configured to accept representation IDs in an "Accept- Alternative- Representation" header field to specify the secondary representations for a segment. The processor 110, memory 112, and/or flexible caching module 118 may, for example, provide means for performing operations 302 and 303.
[00138] In some example embodiments and as is shown in operation 304, the streaming client apparatus 102 may be configured to add a "Accept- Alternative- Representation" in a "Connection" header field to indicate a connection between proxy cache apparatus 104 and the streaming client apparatus 102. The processor 110, memory 112, and/or flexible caching module 118 may, for example, provide means for performing operation 304. In operation 305, a streaming client apparatus 102 may be configured to cause an HTTP request to be transmitted to a proxy cache apparatus 104 or a serving network apparatus 108. The processor 110, memory 112, communication interface 114, user interface 116, and/or flexible caching module 118 may, for example, provide means for performing operation 305.
[00139] Figures 6a and 6b illustrate flowcharts according to an example method for operation of streaming client apparatus 102 with respect to agent-driven content negotiation. In this regard, Figures 6a and 6b illustrate operations that may be performed at the streaming client apparatus 102. The operations illustrated in and described with respect to Figures 6a and 6b may, for example, be performed by, with the assistance of, and/or under the control of one or more of the processor 110, memory 112, communication interface 114, or flexible caching module 1 18. In some example embodiments, a streaming client apparatus 102 may be configured to cause a proxy cache apparatus 104 to reply with a list and range of URIs for cached alternative resources for agent-driven content negotiation. The streaming client apparatus 102 may also be configured to cause a template to be transmitted in an "Accept-Cached- Alternative-Representation" header field to and to cause a proxy cache apparatus 104 to transmit possible representations a streaming client apparatus 102 may accept.
[00140] In some example embodiments, an "Accept-Cached-Alternative-
Representation" header field may be used with regard to signaling from a streaming client apparatus 102 to a proxy cache apparatus 104 and such signaling may be performed in, but is not limited to: (a) sending an "Accept-Cached- Alternative-Representation" header and (b) receiving a "Cached- Alternative-Representation" header.
[00141] As shown in operation 402, a streaming client apparatus 102 may be configured to add a primary URI of the primary representation for a segment in a HTTP request and in operation 403 add a template in an "Accept-Cached-Alternative- Representation" header field to signal a proxy cache apparatus 104 to determine one or more secondary representations for a segment. The processor 110, memory 112, and/or flexible caching module 118 may, for example, provide means for performing operations 402 and 403. Then in operation 404, a streaming client apparatus 102 may cause a HTTP request to be transmitted to a proxy cache apparatus 104 or a serving network apparatus 108. The processor 110, memory 112, communication interface 114, user interface 116, and/or flexible caching module 118 may, for example, provide means for performing operation 404.
[00142] As shown in operation 412, a streaming client apparatus 102 may be configured to receive a "Cached- Alternative-Representation" from a proxy cache apparatus 104. The processor 110, memory 112, communication interface 114, and/or flexible caching module 1 18 may, for example, provide means for performing operation 412. As is shown in operation 413, a streaming client apparatus 102 may be configured to parse a
"Cached-Alternative-Representation" to derive cached representations for a segment at a proxy cache apparatus 104, and at operation 414, the streaming client apparatus 102 may conclude a best or advantageous representation for a segment and further may cause a GET segment request to be transmitted for a segment. The processor 110, memory 112, communication interface 114, user interface 116, and/or flexible caching module 1 18 may, for example, provide means for performing operations 413 and 414.
[00143] Figure 7 illustrates a flowchart according to an example method for operation of a proxy cache apparatus 104 for server-driven content negotiation. In this regard, Figure 7 illustrates operations that may be performed at the proxy cache apparatus 104. The operations illustrated in and described with respect to Figure 7 may, for example, be performed by, with the assistance of, and/or under the control of one or more of the processor 110, memory 112, communication interface 114, or flexible caching module 118. A proxy cache apparatus 104 may be configured to determine a primary and/or secondary URIs for alternative resources and the corresponding preference by a streaming client apparatus 102 by using the proposed signaling, such as "Accept- Alternative-URI" header field and "Accept-Alternative-Representation" header field. As will be appreciated, other similar headers or directives too which can be used to specify secondary URIs for the alternative resources.
[00144] In some example embodiments, a proxy cache apparatus 104 may be configured to determine whether to cache resources for the primary and/or the secondary URI and further may be configured to select a high priority resource which is cached by the proxy cache apparatus 104. In an instance in which a secondary resource for the primary and secondary URI is not located, a proxy cache apparatus 104 causes a request, such as a HTTP request, to be transmitted to a serving network apparatus 108 or another proxy cache which may cache the primary or secondary resources.
[00145] As is shown in operation 502 and in an instance in which a proxy cache apparatus 104 receives a HTTP GET segment request from a user agent and in an instance in which the requested primary resource is cached by a proxy cache apparatus 104 as is shown in operation 503, a proxy cache apparatus 104 may be configured to cause the primary resource to be transmitted to the streaming client apparatus 102. In some example embodiments and as is shown in operation 505, after causing the transmission in operation 504, a proxy cache apparatus 104 may be configured to cache the received segment in an instance in which it was not already cached. The processor 110, memory 112, communication interface 114, and/or flexible caching module 118 may, for example, provide means for performing operations 502-505. [00146] In an instance in which the proxy cache apparatus 104 receives a HTTP
GET segment request from a streaming client apparatus 102 and in an instance in which the requested primary resource identified by a primary URI is not cached by a caching proxy, then a proxy cache apparatus 104 may be configured to determine whether or not "Accept-Alternative-Representation" is included in a header field. See operation 506. If "Accept-Alternative-Representation" is included in a header field, then, as shown in operation 507, a proxy cache apparatus 104 may be configured to construct the secondary URIs for the alternative resources and, as is shown in operation 508, sequentially check whether or not a secondary URI's resource is cached by a proxy cache apparatus 104 from a high preference to a low preference as indicated by an "Accept- Alternative- Representation". In an instance in which a resource associated with on the secondary URIs is cached by a caching proxy at operation 509, then a proxy cache apparatus 104 may be configured to cause an alternative segment to be transmitted to a streaming client apparatus 102 in a response immediately or after a predetermined period amount of time. See operation 510. The processor 110, memory 112, communication interface 114, and/or flexible caching module 118 may, for example, provide means for performing operations 510, and 506-509.
[00147] In some example embodiments and as shown in operation 511, a proxy cache apparatus 104 may be configured to add a selected representation ID in a "Response- Representation" response header field or add the selected secondary URI in a "response- URI" response header field, which is delivered to a streaming client apparatus 102. Alternatively or additionally, a proxy cache apparatus 104 may include "Accept- Alternative-Representation" header field name in a "Vary" header field to express the parameters to select a representation that is subject to server-driven negotiation. The processor 110, memory 112, communication interface 114, and/or flexible caching module 118 may, for example, provide means for performing operation 511.
[00148] As is shown in operation 512, a proxy cache apparatus 104 may request and cache the requested segment identified by a primary URI from a remote location if the requested segment is not currently being caused to be retrieved and/or fetched from a remote location and to serve future request after responding to a streaming client apparatus
102 request with an alternative resource. Alternatively or additionally a proxy cache apparatus 104 may cause a requested segment from a remote location to be requested in an instance in which a number of HTTP GET requests are received in a certain time interval that exceed a predetermined duration, and the requested segment is not being fetched from a remote location. The processor 110, memory 1 12, communication interface 114, and/or fiexible caching module 118 may, for example, provide means for performing operation 512.
[00149] In an instance in which a "Accept-Alternative-Representation" header field is not found or a proxy cache apparatus 104 is not aware of the new defined header field of HTTP in operation 506 or any of secondary URI's resource is not cached by a proxy cache apparatus 104 in operation 509, then at operation 513, a proxy cache apparatus 104 may be configured to remove "Accept-Alternative-Representation" as indicated in connection header field. Then, at operation 514, a proxy cache apparatus 104 may determine whether the requested segment is currently being fetched from a remote location. If the requested segment is not currently being fetched then at operation 515, the proxy cache apparatus 104 cause the requested segment to be retrieved from one or multiple remote locations and may then cause the requested segment to be transmitted to a streaming client apparatus 102. Otherwise, if the requested segment is not fully cached by a proxy cache apparatus 104 but is currently being retrieved from a remote location as shown in operation 514, then a proxy cache apparatus 104 may cause the requested segment to be transmitted to a streaming client apparatus 102 as is shown in operation 504. If the requested segment is not cached by a proxy cache apparatus 104, then the proxy cache apparatus 104 may be configured to cache the segment at operation 505 and ends a caching proxy operation for server-driven content negotiation in DASH at operation 516. The processor 110, memory 112, communication interface 114, and/or fiexible caching module 118 may, for example, provide means for performing operations 506, 509, and 513-516.
[00150] Figure 8 illustrates a flowchart according to an example method for operation of a proxy cache apparatus 104 for agent-driven content negotiation. In this regard, Figure 8 illustrates operations that may be performed at the proxy cache apparatus 104. The operations illustrated in and described with respect to Figure 8 may, for example, be performed by, with the assistance of, and/or under the control of one or more of the processor 110, memory 112, communication interface 114, or flexible caching module 118. In some example embodiments, a proxy cache apparatus 104 may be configured to analyze possible candidate URIs that are cached a proxy cache apparatus 104 using the signaling, such as "Accept- Alternative-URI" header field and "accept" defined media type. Other similar headers or directives may be used to derive URI templates for a secondary URI for an alternative resource. [00151] As is shown in operation 602 and in an instance in which a HTTP GET segment request is received from a streaming client apparatus 102 and the requested primary resource was cached by a proxy cache apparatus 104, as shown in operation 603, a proxy cache apparatus 104 may be configured to cause a primary resource to be transmitted to a streaming client apparatus 102. In some example embodiments, a proxy cache apparatus 104 caches the received segment in an instance in which the received segment is not already cached. See operation 605. The processor 110, memory 112, communication interface 114, and/or flexible caching module 118 may, for example, provide means for performing operations 602-605.
[00152] In an instance in which a proxy cache apparatus 104 receives a HTTP GET segment request from a streaming client apparatus 102 and the requested primary resource identified by a primary URI is not cached as is shown in operation 603. As is shown in operation 606, a proxy cache apparatus 104 may be configured to determine whether "Accept-Cached-Alternative-Representation" is included in a header field. If Accept- Cached- Alternative-Representation" is included in a header field, then as is shown in operation 607, a proxy cache apparatus 104 may be configured to parse a URI template for the alternative resources from "Accept-Cached-Alternative-Representation" and as shown in operation 608, proxy cache apparatus 104 may locate cached alternative resources that matches the URI template of the secondary resources. See operation 609. The processor 110, memory 112, communication interface 1 14, and/or flexible caching module 118 may, for example, provide means for performing operations 606-609.
[00153] As shown in operation 610, in an instance in which a proxy cache apparatus
104 determines one or multiple such alternative resources' URI, then the proxy cache apparatus 104 may be configured add all the matching URIs in a "Cached- Alternative- Representation" response header field and further may cause it to be transmitted to a streaming client apparatus 102. In an instance in which "Accept-Cached- Alternative- Representation" header field is not found, a proxy cache apparatus 104 is not aware of the new defined header field of HTTP, or no such as cached alternative resources' URI is found, then at operation 611, a proxy cache apparatus 104 may be configured to remove "Accept-Cached-Alternative-Representation" as indicated in connection header field.
Then, as shown in operation 612, a proxy cache apparatus 104 may be configured to determine whether the requested segment is already being fetched from a remote location.
If it the requested segment is not being fetched, then at operation 613, a proxy cache apparatus 104 may be configured to fetch the requested segment from one or multiple remote locations and further may cause the requested segment to be transmitted to a streaming client apparatus 102. As is shown in operation 614, if the requested segment is not cached by a proxy cache apparatus 104, the proxy cache apparatus 104 may cache the segment. The processor 110, memory 112, communication interface 114, and/or flexible caching module 118 may, for example, provide means for performing operations 610-614.
[00154] Figure 9 illustrates a flowchart according to an example method for operation of streaming client apparatus 102 for server driven content negotiation. See also for example Figure 5. As shown in operation 902, the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the fiexible caching module 118 or the like, for causing a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a proxy cache apparatus, wherein the proxy cache apparatus is configured to derive a primary URI for the primary representation and at least one secondary URI for the alternative representation and corresponding preferences. As shown in operation 904, the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining the primary URI of the primary representation for the segment to be transmitted to the proxy cache apparatus. As shown in operation 906, the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the fiexible caching module 118 or the like, for causing a template that specifies the alternative representation URI for the segment to be created, wherein the template comprises an indication to accept an alternative representation of the segment. In some example embodiments, a connection header field is configured to provide an indication of one or more URIs that are permitted as responses from the proxy cache apparatus. In further example embodiments, the alternative representation is a representation that is cached by the proxy cache apparatus and is configured to be an alternative to the primary representation.
[00155] As shown in operation 908, the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing the proxy cache apparatus 104 to respond with at least one of the primary representation or the alternative representation based on the caching status at a proxy cache apparatus, wherein the proxy cache apparatus 104 is configured to determine whether the request enables an alternative representation to be included in a response. As shown in operation 908, the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for receiving at least one of the primary representation or the alternative representation for the segment from the proxy cache apparatus.
[00156] Figure 10 illustrates a flowchart according to an example method for operation of streaming client apparatus 102 with respect to agent-driven content negotiation. See also for example Figure 6. As shown in operation 1002, the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing a request for a proxy cache apparatus to provide a selectable cached alternative representation URI to be transmitted. As shown in operation 1004, the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing a primary URI of a primary representation for a segment to be transmitted in the request.
[00157] As shown in operation 1006, the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the flexible caching module 118 or the like, for causing a template that specifies the secondary representation URI for the segment to be created, wherein the template comprises an indication to accept secondary representation of the segment. As shown in operation 1008, the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for receiving a list and range of URI's for the selectable cached alternative representation for agent driven content negotiation. As shown in operation 1010, the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted, wherein the resource is requested based on a predetermined selection criteria. In some example embodiments, the request is transmitted to at least one of a proxy cache apparatus 104 or a serving network apparatus. [00158] In some example embodiments, the apparatus 300 that is embodied, for example, by the streaming client apparatus 102 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for receiving a message from the proxy cache apparatus; determining the one or more selectable cached alternative representations are available from the proxy cache apparatus based on the received message and causing at least one of the one or more cached alternative representations to be requested, wherein the resource is requested based on a predetermined selection criteria.
[00159] Figure 11 illustrates a flowchart according to an example method for operation of proxy cache apparatus 104 for server-driven content negotiation. See also for example Figure 7. As shown in operation 1102, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for receiving a request for at least one of a primary representation or an alternative representation for a segment. As shown in operation 1104, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining whether the request comprises an indication that a client will accept the alternative representation of the segment. As shown in operation 1106, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining whether at least one of a primary URI associated with the primary representation is cached.
[00160] As shown in operation 1108, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining a secondary URI for the alternative representation in an instance in which the request comprises an indication that the streaming client apparatus will accept the alternative representation of the segment and the primary URI is not cached. As shown in operation 1110, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining whether the alternative representation that is associated with the secondary URI is cached.
[00161] As shown in operation 1112, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing the primary representation of the segment to be requested in an instance in which the secondary URI is not cached. As shown in operation 1114, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing the alternative representation of the segment to be transmitted in an instance in which the secondary URI is cached. As shown in operation 1 116, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing the primary representation of the segment to be transmitted in an instance in which the primary URI is cached.
[00162] In some example embodiments, , the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for determining a cached alternative representation to cause to be transmitted, wherein the determination is based on a predetermined selection criteria and causing the primary representation associated with the primary URI to be requested in an instance in which it is not cached.
[00163] Figure 12 illustrates a flowchart according to an example method for operation of proxy cache apparatus 104 for agent-driven content negotiation. See also for example Figure 8. As shown in operation 1202, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 1 10, the communications interface 114, the flexible caching module 118 or the like, for receiving a request for at least one of a primary representation or an alternative representation for a segment. As shown in operation 1204, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining whether the request comprises an indication that a client will accept the alternative representation of the segment. As shown in operation 1206, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing a list and range of URI 's for a selectable cached alternative representation for agent driven content negotiation to be transmitted.
[00164] As shown in operation 1208, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining whether at least one of a primary URI associated with the primary representation is cached. As shown in operation 1210, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing the primary representation of the segment to be transmitted in an instance in which the primary URI is cached.
[00165] As shown in operation 1212, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for receiving a template that specifies the secondary representation URI for the segment to be created, wherein the template comprises an indication to accept secondary representation of the segment and in some embodiments parsing the template. As shown in operation 1214, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the flexible caching module 118 or the like, for determining at least one alternative representation that is associated with the secondary representation URI in the received template. As shown in operation 1214, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for receiving a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
[00166] In some example embodiments, the apparatus 300 that is embodied, for example, by the proxy cache apparatus 104 may include means, such as the processor 110, the communications interface 114, the flexible caching module 118 or the like, for causing one or more selectable cached alternative representations to be transmitted and receiving a request for at least one of the one or more cached alternative representations.
[00167] Figures 5-12 illustrate flowcharts of a system, method, and computer program product according to example embodiments of the invention. It will be understood that each block of the flowchart, and combinations of blocks in the flowchart, may be implemented by various means, such as hardware and/or a computer program product comprising one or more computer-readable mediums (as opposed to a computer-readable transmission medium which describes a propagating signal) having one or more computer program code instructions, program instructions, or executable computer-readable program code instructions stored therein. For example, one or more of the procedures described herein may be embodied by computer program instructions of a computer program product. In this regard, the computer program product(s) that embodies the procedures described herein may be stored by one or more memory devices (e.g., memory 112, volatile memory 40, or non-volatile memory 42) of a mobile terminal, server, or other computing device (e.g., the streaming client apparatus 102) and executed by a processor (e.g., the processor 110 or processor 20) in the computing device. In some embodiments, the computer program instructions comprising the computer program product(s) that embodies the procedures described above may be stored by memory devices of a plurality of computing devices. As will be appreciated, any such computer program product may be loaded onto a computer or other programmable apparatus to produce a machine, such that the computer program product including the instructions which execute on the computer or other programmable apparatus creates means for implementing the functions specified in the flowchart block(s).
[00168] Further, the computer program product may comprise one or more computer-readable memories on which the computer program instructions may be stored such that the one or more computer-readable memories can direct a computer or other programmable apparatus to function in a particular manner, such that the computer program product may comprise an article of manufacture which implements the function specified in the flowchart block(s). The computer program instructions of one or more computer program products may also be loaded onto a computer or other programmable apparatus to cause a series of operations to be performed on the computer or other programmable apparatus to produce a computer-implemented process such that the instructions which execute on the computer or other programmable apparatus provide operations for implementing the functions specified in the flowchart block(s). Retrieval, loading, and execution of the program code instructions may be performed sequentially such that one instruction is retrieved, loaded, and executed at a time. In some example embodiments, retrieval, loading and/or execution may be performed in parallel such that multiple instructions are retrieved, loaded, and/or executed together.
[00169] Accordingly, execution of instructions associated with the operations of the flowchart by a processor, or storage of instructions associated with the blocks or operations of the flowchart in a computer-readable storage medium, support combinations of operations for performing the specified functions. It will also be understood that one or more operations of the flowchart, and combinations of blocks or operations in the flowchart, may be implemented by special purpose hardware-based computer systems and/or processors which perform the specified functions, or combinations of special purpose hardware and program code instructions.
[00170] In various embodiments described herein, a URI template scheme may be used primarily for representation IDs. It is noted that any other URI template scheme may be used similarly with various embodiments. Placeholders other than $RepresentationID$ may be additionally or alternatively present in the URI template scheme. In various embodiments above, a local HTTP cache located in the same device as a streaming client apparatus 102 may also be used. A local HTTP cache may operate similarly to the proxy cache apparatus 104 described in various embodiments. However, in the case that a local HTTP cache cannot serve the primary or secondary resource requested in an HTTP GET request, the local HTTP cache may leave the Connection header unresolved and hence not remove headers related to the alternative resources as specified in various embodiments.
[00171] Various embodiments of the present invention have been described to include URIs or URI templates in requests and/or responses, where the URI or URI template indicates a segment in a representation announced in an MPD. In these embodiments a URI or URI template could alternatively or additionally specify a sub- segment, i.e. a part of a segment, typically a single byte range within a segment. A sub- segment may contain such a part of a segment that it can be processed by a streaming client apparatus 102 prior to receiving subsequent sub-segments of the same segment. A sub-segment may be determined for example during preparing the content and indicated through one or more Segment Index boxes included in the segment. A streaming client apparatus may receive and parse one or more Segment Index boxes of a segment and determine sub-segments and their URIs or URI templates accordingly. A URI or URI template for a sub-segment may contain the URI or URI template, respectively, of the segment and a byte range part specifying the sub-segment.
[00172] The various embodiments of the present invention provide many advantages over the current art. Some example embodiments more segments are fetched from a proxy cache instead of remote location. Consequently, bandwidth (in the network between proxy cache and origin server) is saved. In other embodiments, advantageously DASH clients are likely to make fewer incorrect rate adaptation decisions and more consistently request the same representation level and hence provide a more stable quality to end-users. Further embodiments described herein are configured to reduce the delay to fetch segments at the client, therefore resulting in fewer interruptions/re-bufferings. [00173] The above described functions may be carried out in many ways. For example, any suitable means for carrying out each of the functions described above may be employed to carry out embodiments of the invention. In example embodiments, a suitably configured processor (for example, the processor 110) may provide all or a portion of the elements of the invention. In other embodiments, all or a portion of the elements of the invention may be configured by and operate under control of a computer program product. The computer program product for performing the methods of embodiments of the invention may comprise a computer-readable storage medium, such as the non- volatile storage medium (for example, the memory 112), and computer-readable program code portions, such as a series of computer instructions, embodied in the computer-readable storage medium.
[00174] Many modifications and other embodiments of the inventions set forth herein will come to mind to one skilled in the art to which these inventions pertain having the benefit of the teachings presented in the foregoing descriptions and the associated drawings. Therefore, it is to be understood that the embodiments of the invention are not to be limited to the specific embodiments disclosed and that modifications and other embodiments are intended to be included within the scope of the appended claims. Moreover, although the foregoing descriptions and the associated drawings describe example embodiments in the context of certain example combinations of elements and/or functions, it should be appreciated that different combinations of elements and/or functions may be provided by alternative embodiments without departing from the scope of the appended claims. In this regard, for example, different combinations of elements and/or functions other than those explicitly described above are also contemplated as may be set forth in some of the appended claims. Although specific terms are employed herein, they are used in a generic and descriptive sense only and not for purposes of limitation.

Claims

THAT WHICH IS CLAIMED:
1. A method comprising:
causing, using a processor, a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a proxy cache apparatus;
receiving at least one of the primary representation or the alternative representation; and
receiving at least one of the primary representation or the alternative representation for the segment from the proxy cache apparatus.
2. A method according to claim 1, further comprising:
determining a primary uniform resource indicator of the primary representation for the segment to be transmitted to the proxy cache apparatus in the request.
3. A method according to any one of claims 1 or 2, further comprising:
including a uniform resource indicator of the primary representation for the segment into the request and including a uniform resource indicator of the alternative representation for the segment into the request.
4. A method according to any one of claims 1 - 3, further comprising:
creating a template that specifies an alternative representation uniform resource indicator for the segment, wherein the template comprises an indication to accept an alternative representation of the segment; and
causing the template to be included in the request.
5. A method according to claim 4, wherein a connection header field is configured to provide an indication that in an instance in which the proxy cache apparatus forwards the request, the proxy cache apparatus is configured to remove the uniform resource indicator of the alternative representation.
6. A method according to claim 4, wherein the alternative representation is a representation that is cached by the proxy cache apparatus and is configured to be an alternative to the primary representation.
7. A method according to claim 4, wherein the proxy cache apparatus is configured to derive a primary uniform resource indicator for the primary representation and at least one secondary uniform resource indicator for the alternative representation and corresponding preferences.
8. An apparatus comprising:
at least one processor; and
at least one memory including computer program code, the at least one memory and the computer program code configured to, with the at least one processor, cause the apparatus to at least:
cause a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a proxy cache apparatus;
receive at least one of the primary representation or the alternative representation; and
receive at least one of the primary representation or the alternative representation for the segment from the proxy cache apparatus.
9. An apparatus according to claim 8, wherein the at least one memory including the computer program code is further configured to, with the at least one processor, cause the apparatus to:
determine a primary uniform resource indicator of the primary representation for the segment to be transmitted to the proxy cache apparatus in the request.
10. An apparatus according to any one of claims 8 or 9, wherein the at least one memory including the computer program code is further configured to, with the at least one processor, cause the apparatus to:
include a uniform resource indicator of the primary representation for the segment into the request and including a uniform resource indicator of the alternative representation for the segment into the request.
11. An apparatus according to any one of claims 8-10, wherein the at least one memory including the computer program code is further configured to, with the at least one processor, cause the apparatus to:
create a template that specifies an alternative representation uniform resource indicator for the segment, wherein the template comprises an indication to accept an alternative representation of the segment; and
cause the template to be included in the request.
12. An apparatus according to claim 11, wherein a connection header field is configured to provide an indication that in an instance in which the proxy cache apparatus forwards the request, the proxy cache apparatus is configured to remove the uniform resource indicator of the alternative representation.
13. An apparatus according to claim 11, wherein the alternative representation is a representation that is cached by the proxy cache apparatus and is configured to be an alternative to the primary representation.
14. An apparatus according to claim 11, wherein the proxy cache apparatus is configured to derive a primary uniform resource indicator for the primary representation and at least one secondary uniform resource indicator for the alternative representation and corresponding preferences.
15. A computer program product comprising: at least one computer readable non-transitory memory medium having program code stored thereon, the program code which when executed by an apparatus cause the apparatus at least to:
cause a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a proxy cache apparatus;
receive at least one of the primary representation or the alternative representation; and
receive at least one of the primary representation or the alternative representation for the segment from the proxy cache apparatus.
16. A computer program product according to claim 15, further comprising program code instructions configured to:
determine a primary uniform resource indicator of the primary representation for the segment to be transmitted to the proxy cache apparatus in the request.
17. A computer program product according to any one of claims 15 or 16, further comprising program code instructions configured to:
include a uniform resource indicator of the primary representation for the segment into the request and including a uniform resource indicator of the alternative representation for the segment into the request.
18. A computer program product according to any one of claims 15 - 17, further comprising program code instructions configured to:
create a template that specifies an alternative representation uniform resource indicator for the segment, wherein the template comprises an indication to accept an alternative representation of the segment; and
cause the template to be included in the request.
19. A computer program product according to claim 18, wherein a connection header field is configured to provide an indication that in an instance in which the proxy cache apparatus forwards the request, the proxy cache apparatus is configured to remove the uniform resource indicator of the alternative representation.
20. A computer program product according to claim 18, wherein the alternative representation is a representation that is cached by the proxy cache apparatus and is configured to be an alternative to the primary representation.
21. A computer program product according to claim 18, wherein the proxy cache apparatus is configured to derive a primary uniform resource indicator for the primary representation and at least one secondary uniform resource indicator for the alternative representation and corresponding preferences.
22. An apparatus comprising:
means for causing a request for at least one of a primary representation for a segment or an alternative representation for the segment to be transmitted to a proxy cache apparatus;
means for receiving at least one of the primary representation or the alternative representation; and
means for receiving at least one of the primary representation or the alternative representation for the segment from the proxy cache apparatus.
23. An apparatus according to claim 22, further comprising:
means for determining a primary uniform resource indicator of the primary representation for the segment to be transmitted to the proxy cache apparatus in the request.
24. An apparatus according to any one of claims 22 or 23, further comprising: means for including a uniform resource indicator of the primary representation for the segment into the request and including a uniform resource indicator of the alternative representation for the segment into the request.
25. An apparatus according to any one of claims 22-24, further comprising:
means for creating a template that specifies an alternative representation uniform resource indicator for the segment, wherein the template comprises an indication to accept an alternative representation of the segment; and means for causing the template to be included in the request.
26. An apparatus according to claim 25, wherein a connection header field is configured to provide an indication that in an instance in which the proxy cache apparatus forwards the request, the proxy cache apparatus is configured to remove the uniform resource indicator of the alternative representation.
27. An apparatus according to claim 25, wherein the alternative representation is a representation that is cached by the proxy cache apparatus and is configured to be an alternative to the primary representation.
28. An apparatus according to claim 25, wherein the proxy cache apparatus is configured to derive a primary uniform resource indicator for the primary representation and at least one secondary uniform resource indicator for the alternative representation and corresponding preferences.
29. A method comprising:
causing a request for a proxy cache apparatus to provide a selectable cached alternative representation uniform resource indicator to be transmitted; receiving a list or a range of uniform resource indicators for a selectable cached alternative representation for agent driven content negotiation; and causing, using a processor, a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted, wherein the resource is requested based on a predetermined selection criteria.
30. A method according to claim 29, further comprising:
causing a primary uniform resource indicator of a primary representation for a segment to be transmitted in the request; and
causing a template that specifies a secondary representation uniform resource indicator for the segment to be created, wherein the template comprises an indication to accept secondary representation of the segment.
31. A method according to any one of claims 29 or 30, wherein the request is transmitted to at least one of a proxy caching apparatus or a serving network apparatus.
32. A method according to any one of claims 29-31 , further comprising:
receiving a message from the proxy cache apparatus;
determining one or more selectable cached alternative representations that are available from the proxy cache apparatus based on the message; and causing at least one of the one or more selectable cached alternative representations to be requested, wherein the resource is requested based on a predetermined selection criteria.
33. An apparatus comprising:
at least one processor; and
at least one memory including computer program code, the at least one memory and the computer program code configured to, with the at least one processor, cause the apparatus to at least:
cause a request for a proxy cache apparatus to provide a selectable cached alternative representation uniform resource indicator to be transmitted; receive a list or a range of uniform resource indicators for a selectable cached alternative representation for agent driven content negotiation; and
cause a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted, wherein the resource is requested based on a predetermined selection criteria.
34. An apparatus according to claim 33, wherein the at least one memory including the computer program code is further configured to, with the at least one processor, cause the apparatus to:
cause a primary uniform resource indicator of a primary representation for a segment to be transmitted in the request; and
cause a template that specifies a secondary representation uniform resource indicator for the segment to be created, wherein the template comprises an indication to accept secondary representation of the segment.
35. An apparatus according to any one of claims 33 or 34, wherein the request is transmitted to at least one of a proxy caching apparatus or a serving network apparatus.
36. An apparatus according to any one of claims 33-35, wherein the at least one memory including the computer program code is further configured to, with the at least one processor, cause the apparatus to:
receive a message from the proxy cache apparatus;
determine one or more selectable cached alternative representations that are available from the proxy cache apparatus based on the message; and cause at least one of the one or more selectable cached alternative representations to be requested, wherein the resource is requested based on a predetermined selection criteria.
37. A computer program product comprising: at least one computer readable non-transitory memory medium having program code stored thereon, the program code which when executed by an apparatus cause the apparatus at least to:
cause a request for a proxy cache apparatus to provide a selectable cached alternative representation uniform resource indicator to be transmitted;
receive a list or a range of uniform resource indicators for a selectable cached alternative representation for agent driven content negotiation; and
cause a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted, wherein the resource is requested based on a predetermined selection criteria.
38. A computer program product according to claim 37, further comprising program code instructions configured to:
cause a primary uniform resource indicator of a primary representation for a segment to be transmitted in the request; and
cause a template that specifies a secondary representation uniform resource indicator for the segment to be created, wherein the template comprises an indication to accept secondary representation of the segment.
39. A computer program product according to any one of claims 37 or 38, wherein the request is transmitted to at least one of a proxy caching apparatus or a serving network apparatus.
40. A computer program product according to any one of claims 37-39, further comprising program code instructions configured to:
receive a message from the proxy cache apparatus; determine one or more selectable cached alternative representations that are available from the proxy cache apparatus based on the message; and cause at least one of the one or more selectable cached alternative representations to be requested, wherein the resource is requested based on a predetermined selection criteria.
41. An apparatus comprising:
means for causing a request for a proxy cache apparatus to provide a selectable cached alternative representation uniform resource indicator to be transmitted;
means for receiving a list or a range of uniform resource indicators for a selectable cached alternative representation for agent driven content negotiation; and
means for causing a request for a resource of the selectable cached alternative representation for agent driven content negotiation to be transmitted, wherein the resource is requested based on a predetermined selection criteria.
42. An apparatus according to claim 41, further comprising:
means for causing a primary uniform resource indicator of a primary representation for a segment to be transmitted in the request; and
means for causing a template that specifies a secondary representation uniform resource indicator for the segment to be created, wherein the template comprises an indication to accept secondary representation of the segment.
43. An apparatus according to any one of claims 41 or 42, wherein the request is transmitted to at least one of a proxy caching apparatus or a serving network apparatus.
44. An apparatus according to any one of claims 41-43, further comprising:
means for receiving a message from the proxy cache apparatus; means for determining one or more selectable cached alternative representations that are available from the proxy cache apparatus based on the message; and
means for causing at least one of the one or more selectable cached alternative representations to be requested, wherein the resource is requested based on a predetermined selection criteria.
45. A method comprising:
receiving a request for at least one of a primary representation or an alternative representation for a segment;
determining whether the request comprises an indication that a streaming client apparatus will accept the alternative representation of the segment; determining, using a processor, whether at least one of a primary uniform resource indicator associated with the primary representation is cached; and causing the primary representation of the segment to be transmitted in an instance in which the primary uniform resource indicator is cached.
46. A method according to claim 45, further comprising:
determining a secondary uniform resource indicator for the alternative representation in an instance in which the request comprises an indication that the streaming client apparatus will accept the alternative representation of the segment and the primary uniform resource indicator is not cached.
47. A method according to any one of claims 45 and 46, further comprising:
determining whether the alternative representation that is associated with a secondary uniform resource indicator is cached;
causing the primary representation of the segment to be requested in an instance in which the secondary uniform resource indicator is not cached; and causing the alternative representation of the segment to be transmitted in an instance in which the secondary uniform resource indicator is cached.
48. A method according to any one of claims 45-47, further comprising:
determining a cached alternative representation to be transmitted based on a predetermined selection criteria.
49. A method according to any one of claims 45-48, further comprising:
causing the primary representation associated with the primary uniform resource indicator to be requested in an instance in which it is not cached.
50. An apparatus comprising:
at least one processor; and
at least one memory including computer program code, the at least one memory and the computer program code configured to, with the at least one processor, cause the apparatus to at least:
receive a request for at least one of a primary representation or an alternative representation for a segment;
determine whether the request comprises an indication that a streaming client apparatus will accept the alternative representation of the segment;
determine whether at least one of a primary uniform resource indicator associated with the primary representation is cached; and
cause the primary representation of the segment to be transmitted in an instance in which the primary uniform resource indicator is cached.
51. An apparatus according to claim 50, wherein the at least one memory including the computer program code is further configured to, with the at least one processor, cause the apparatus to:
determine a secondary uniform resource indicator for the alternative representation in an instance in which the request comprises an indication that the streaming client apparatus will accept the alternative representation of the segment and the primary uniform resource indicator is not cached.
52. An apparatus according to any one of claims 50 or 51, wherein the at least one memory including the computer program code is further configured to, with the at least one processor, cause the apparatus to:
determine whether the alternative representation that is associated with a secondary uniform resource indicator is cached;
cause the primary representation of the segment to be requested in an instance in which the secondary uniform resource indicator is not cached; and cause the alternative representation of the segment to be transmitted in an instance in which the secondary uniform resource indicator is cached.
53. An apparatus according to any one of claims 50-52 wherein the at least one memory including the computer program code is further configured to, with the at least one processor, cause the apparatus to:
determine a cached alternative representation to be transmitted based on a predetermined selection criteria.
54. An apparatus according to any one of claims 50-53, wherein the at least one memory including the computer program code is further configured to, with the at least one processor, cause the apparatus to:
cause the primary representation associated with the primary uniform resource indicator to be requested in an instance in which it is not cached.
55. A computer program product comprising:
at least one computer readable non-transitory memory medium having program code stored thereon, the program code which when executed by an apparatus cause the apparatus at least to:
receive a request for at least one of a primary representation or an alternative representation for a segment; determine whether the request comprises an indication that a streaming client apparatus will accept the alternative representation of the segment;
determine whether at least one of a primary uniform resource indicator associated with the primary representation is cached; and
cause the primary representation of the segment to be transmitted in an instance in which the primary uniform resource indicator is cached.
56. A computer program product according to claim 55, further comprising program code instructions configured to:
determine a secondary uniform resource indicator for the alternative representation in an instance in which the request comprises an indication that the streaming client apparatus will accept the alternative representation of the segment and the primary uniform resource indicator is not cached.
57. A computer program product according to any one of claims 55 or 56, further comprising program code instructions configured to:
determine whether the alternative representation that is associated with a secondary uniform resource indicator is cached;
cause the primary representation of the segment to be requested in an instance in which the secondary uniform resource indicator is not cached; and cause the alternative representation of the segment to be transmitted in an instance in which the secondary uniform resource indicator is cached.
58. A computer program product according to any one of claims 55 - 57, further comprising program code instructions configured to:
determine a cached alternative representation to be transmitted based on a predetermined selection criteria.
59. A computer program product according to any one of claims 55-58, further comprising program code instructions configured to: cause the primary representation associated with the primary uniform resource indicator to be requested in an instance in which it is not cached.
60. An apparatus comprising:
means for receiving a request for at least one of a primary representation or an alternative representation for a segment;
means for determining whether the request comprises an indication that a streaming client apparatus will accept the alternative representation of the segment;
means for determining, using a processor, whether at least one of a primary uniform resource indicator associated with the primary representation is cached; and
means for causing the primary representation of the segment to be transmitted in an instance in which the primary uniform resource indicator is cached.
61. An apparatus according to claim 60, further comprising:
means for determining a secondary uniform resource indicator for the alternative representation in an instance in which the request comprises an indication that the streaming client apparatus will accept the alternative representation of the segment and the primary uniform resource indicator is not cached.
62. An apparatus according to any one of claims 60 or 61, further comprising:
means for determining whether the alternative representation that is associated with a secondary uniform resource indicator is cached;
means for causing the primary representation of the segment to be requested in an instance in which the secondary uniform resource indicator is not cached; and means for causing the alternative representation of the segment to be transmitted in an instance in which the secondary uniform resource indicator is cached.
63. An apparatus according to any one of claims 60 - 62, further comprising:
means for determining a cached alternative representation to be transmitted based on a predetermined selection criteria.
64. An apparatus according to any one of claims 60 - 63, further comprising:
means for causing the primary representation associated with the primary uniform resource indicator to be requested in an instance in which it is not cached.
65. A method comprising:
receiving a request for at least one of a primary representation or an alternative representation for a segment;
determining, using a processor, whether the request comprises an indication that a streaming client apparatus will accept the alternative representation of the segment;
causing a list and range of uniform resource indicators for a selectable cached alternative representation for agent driven content negotiation to be transmitted; and
receiving a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
66. A method according to claim 65, further comprising:
determining whether at least one of a primary uniform resource indicator associated with the primary representation is cached; and
causing the primary representation of the segment to be transmitted in an instance in which the primary uniform resource indicator is cached.
67. A method according to any one of claims 65 or 66, further comprising:
causing one or more selectable cached alternative representations to be transmitted; and
receiving a request for at least one of the one or more selectable cached alternative representations.
68. A method according to any one of claims 65 - 67, further comprising:
determining whether at least one of a primary uniform resource indicator associated with the primary representation is cached; and
causing the primary representation of the segment to be transmitted in an instance in which the primary uniform resource indicator is cached.
69. A method according to any one of claims 65 - 68, further comprising:
receiving a template that specifies a secondary uniform resource indicator for an alternative representation for the segment to be created, wherein the template comprises an indication to accept secondary representation of the segment;
causing the template to be parsed; and
determining at least one alternative representation that is associated with the secondary uniform resource indicator in a received template.
70. An apparatus comprising:
at least one processor; and
at least one memory including computer program code, the at least one memory and the computer program code configured to, with the at least one processor, cause the apparatus to at least:
receive a request for at least one of a primary representation or an alternative representation for a segment; determine whether the request comprises an indication that a streaming client apparatus will accept the alternative representation of the segment;
cause a list and range of uniform resource indicators for a selectable cached alternative representation for agent driven content negotiation to be transmitted; and
receive a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
71. An apparatus according to claim 70, wherein the at least one memory including the computer program code is further configured to, with the at least one processor, cause the apparatus to:
determine whether at least one of a primary uniform resource indicator associated with the primary representation is cached; and
cause the primary representation of the segment to be transmitted in an instance in which the primary uniform resource indicator is cached.
72. An apparatus according to any one of claims 70 or 71, wherein the at least one memory including the computer program code is further configured to, with the at least one processor, cause the apparatus to:
cause one or more selectable cached alternative representations to be transmitted; and
receive a request for at least one of the one or more selectable cached alternative representations.
73. An apparatus according to any one of claims 70 - 72, wherein the at least one memory including the computer program code is further configured to, with the at least one processor, cause the apparatus to:
determine whether at least one of a primary uniform resource indicator associated with the primary representation is cached; and cause the primary representation of the segment to be transmitted in an instance in which the primary uniform resource indicator is cached.
74. An apparatus according to any one of claims 70 - 73, wherein the at least one memory including the computer program code is further configured to, with the at least one processor, cause the apparatus to:
receive a template that specifies a secondary uniform resource indicator for an alternative representation for the segment to be created, wherein the template comprises an indication to accept secondary representation of the segment;
cause the template to be parsed; and
determine at least one alternative representation that is associated with the secondary uniform resource indicator in a received template.
75. A computer program product comprising:
at least one computer readable non-transitory memory medium having program code stored thereon, the program code which when executed by an apparatus cause the apparatus at least to:
receive a request for at least one of a primary representation or an alternative representation for a segment;
determine whether the request comprises an indication that a streaming client apparatus will accept the alternative representation of the segment;
cause a list and range of uniform resource indicators for a selectable cached alternative representation for agent driven content negotiation to be transmitted; and
receive a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
76. A computer program product according to claim 75, further comprising program code instructions configured to:
determine whether at least one of a primary uniform resource indicator associated with the primary representation is cached; and
cause the primary representation of the segment to be transmitted in an instance in which the primary uniform resource indicator is cached.
77. A computer program product according to any one of claims 75 or 76, further comprising program code instructions configured to:
cause one or more selectable cached alternative representations to be transmitted; and
receive a request for at least one of the one or more selectable cached alternative representations.
78. A computer program product according to any one of claims 75 - 77, further comprising program code instructions configured to:
determine whether at least one of a primary uniform resource indicator associated with the primary representation is cached; and
cause the primary representation of the segment to be transmitted in an instance in which the primary uniform resource indicator is cached.
79. A computer program product according to any one of claims 75 - 78, further comprising program code instructions configured to:
receive a template that specifies a secondary uniform resource indicator for an alternative representation for the segment to be created, wherein the template comprises an indication to accept secondary representation of the segment;
cause the template to be parsed; and
determine at least one alternative representation that is associated with the secondary uniform resource indicator in a received template.
80. An apparatus comprising:
means for receiving a request for at least one of a primary representation or an alternative representation for a segment;
means for determining whether the request comprises an indication that a streaming client apparatus will accept the alternative representation of the segment;
means for causing a list and range of uniform resource indicators for a selectable cached alternative representation for agent driven content negotiation to be transmitted; and
means for receiving a request for a resource of the selectable cached alternative representation for agent driven content negotiation.
81. An apparatus according to claim 80, further comprising:
means for determining whether at least one of a primary uniform resource indicator associated with the primary representation is cached; and means for causing the primary representation of the segment to be transmitted in an instance in which the primary uniform resource indicator is cached.
82. An apparatus according to any one of claims 80 or 81, further comprising:
means for causing one or more selectable cached alternative representations to be transmitted; and
means for receiving a request for at least one of the one or more selectable cached alternative representations.
83. An apparatus according to any one of claims 80 - 82, further comprising:
means for determining whether at least one of a primary uniform resource indicator associated with the primary representation is cached; and means for causing the primary representation of the segment to be transmitted in an instance in which the primary uniform resource indicator is cached.
84. An apparatus according to any one of claims 80 - 83, further comprising: means for receiving a template that specifies a secondary uniform resource indicator for an alternative representation for the segment to be created, wherein the template comprises an indication to accept secondary representation of the segment;
means for causing the template to be parsed; and
means for determining at least one alternative representation that is associated with the secondary uniform resource indicator in a received template.
PCT/FI2012/051189 2011-12-29 2012-11-30 Method and apparatus for flexible caching of delivered media WO2013098468A1 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
CN201280065154.8A CN104025548B (en) 2011-12-29 2012-11-30 For the method and apparatus for the flexible caching for being delivered media
PL12862371T PL2798818T3 (en) 2011-12-29 2012-11-30 Method and apparatus for flexible caching of delivered media
ES12862371T ES2731948T3 (en) 2011-12-29 2012-11-30 Method and apparatus for flexible caching of distributed media
EP12862371.7A EP2798818B1 (en) 2011-12-29 2012-11-30 Method and apparatus for flexible caching of delivered media

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US13/340,123 US8977704B2 (en) 2011-12-29 2011-12-29 Method and apparatus for flexible caching of delivered media
US13/340,123 2011-12-29

Publications (1)

Publication Number Publication Date
WO2013098468A1 true WO2013098468A1 (en) 2013-07-04

Family

ID=48695853

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/FI2012/051189 WO2013098468A1 (en) 2011-12-29 2012-11-30 Method and apparatus for flexible caching of delivered media

Country Status (7)

Country Link
US (2) US8977704B2 (en)
EP (1) EP2798818B1 (en)
CN (1) CN104025548B (en)
ES (1) ES2731948T3 (en)
PL (1) PL2798818T3 (en)
TW (1) TWI602415B (en)
WO (1) WO2013098468A1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP3125495A1 (en) * 2015-07-27 2017-02-01 Palo Alto Research Center, Incorporated Content negotiation in a content centric network

Families Citing this family (46)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10917431B2 (en) 2010-11-29 2021-02-09 Biocatch Ltd. System, method, and device of authenticating a user based on selfie image or selfie video
US10069837B2 (en) * 2015-07-09 2018-09-04 Biocatch Ltd. Detection of proxy server
US10897482B2 (en) * 2010-11-29 2021-01-19 Biocatch Ltd. Method, device, and system of back-coloring, forward-coloring, and fraud detection
US11210674B2 (en) 2010-11-29 2021-12-28 Biocatch Ltd. Method, device, and system of detecting mule accounts and accounts used for money laundering
US12101354B2 (en) * 2010-11-29 2024-09-24 Biocatch Ltd. Device, system, and method of detecting vishing attacks
US20190158535A1 (en) * 2017-11-21 2019-05-23 Biocatch Ltd. Device, System, and Method of Detecting Vishing Attacks
US10834590B2 (en) 2010-11-29 2020-11-10 Biocatch Ltd. Method, device, and system of differentiating between a cyber-attacker and a legitimate user
US8977704B2 (en) * 2011-12-29 2015-03-10 Nokia Corporation Method and apparatus for flexible caching of delivered media
US9401968B2 (en) 2012-01-20 2016-07-26 Nokia Techologies Oy Method and apparatus for enabling pre-fetching of media
US9526091B2 (en) * 2012-03-16 2016-12-20 Intel Corporation Method and apparatus for coordination of self-optimization functions in a wireless network
KR20150082320A (en) * 2012-10-19 2015-07-15 인터디지탈 패튼 홀딩스, 인크 Multi-hypothesis rate adaptation for http streaming
US20140372569A1 (en) * 2013-06-14 2014-12-18 Samsung Electronics Co., Ltd. Controlling dash client rate adaptation
US20150180923A1 (en) * 2013-12-19 2015-06-25 International Business Machines Corporation Alternate playback of streaming media segments
EP3092811B1 (en) * 2014-01-07 2020-02-12 InterDigital VC Holdings, Inc. Method for providing a content part of a multimedia content to a client terminal, corresponding cache
KR20150083429A (en) * 2014-01-08 2015-07-17 한국전자통신연구원 Method of representing bit depth for video play using dash
US20150199498A1 (en) * 2014-01-10 2015-07-16 Furturewei Technologies, Inc. Flexible and efficient signaling and carriage of authorization acquisition information for dynamic adaptive streaming
US10044831B2 (en) * 2014-03-10 2018-08-07 Samsung Electronics Co., Ltd. Method and apparatus for transmitting messages to a dash client
EP2922266A1 (en) * 2014-03-20 2015-09-23 Thomson Licensing Method for operating a cache arranged along a transmission path between client terminals and at least one server, and corresponding cache.
FR3020542A1 (en) * 2014-04-23 2015-10-30 Orange METHOD FOR MANAGING THE SELECTION OF SEGMENT REPRESENTATION OF MULTIMEDIA CONTENT TRANSMITTED ON A COMMUNICATION NETWORK.
EP2953313A1 (en) * 2014-06-05 2015-12-09 Thomson Licensing Method for operating a cache arranged along a transmission path between client terminals and at least one server, and corresponding cache
EP2958294A1 (en) * 2014-06-16 2015-12-23 Thomson Licensing Method for operating a network equipment arranged along a transmission path between a client terminal and at least one server, and corresponding network equipment.
GB2528039A (en) * 2014-07-01 2016-01-13 Canon Kk Method for identifying objects across time periods and corresponding device
EP2963894A1 (en) * 2014-07-04 2016-01-06 Thomson Licensing Method for operating a cache arranged along a transmission path between client terminals and at least one server, and corresponding cache.
WO2016119735A1 (en) * 2015-01-30 2016-08-04 Mediatek Inc. Method and device for adaptive video content delivery using http
US10015229B2 (en) * 2015-02-24 2018-07-03 International Business Machines Corporation Metadata sharing to decrease file transfer time
US10560543B2 (en) * 2015-03-26 2020-02-11 Fortinet, Inc. Rule based cache processing in application delivery controller for load balancing
US10165025B2 (en) 2015-04-03 2018-12-25 Qualcomm Incorporated Techniques for HTTP live streaming over eMBMS
US10681107B2 (en) 2015-06-16 2020-06-09 Apple Inc. Adaptive video content for cellular communication
US10193994B2 (en) 2015-06-18 2019-01-29 Qualcomm Incorporated Signaling cached segments for broadcast
CN105094827B (en) * 2015-07-24 2018-08-28 上海新储集成电路有限公司 A kind of method that processor starts
US9516130B1 (en) * 2015-09-17 2016-12-06 Cloudflare, Inc. Canonical API parameters
US10104143B1 (en) * 2016-06-03 2018-10-16 Amazon Technologies, Inc. Manifest segmentation
US10116719B1 (en) 2016-06-03 2018-10-30 Amazon Technologies, Inc. Customized dash manifest
US10432690B1 (en) * 2016-06-03 2019-10-01 Amazon Technologies, Inc. Manifest partitioning
GB2552032B (en) 2016-07-08 2019-05-22 Aimbrain Solutions Ltd Step-up authentication
US11165841B2 (en) * 2016-10-18 2021-11-02 Expway Method for transmitting content to mobile user devices
KR102190880B1 (en) * 2016-12-30 2020-12-14 구글 엘엘씨 System and method for interrupting streaming content provided through inviolable manifest protocol
US10084855B2 (en) * 2017-01-23 2018-09-25 Akamai Technologies, Inc. Pixel-based load balancing
US11025724B2 (en) * 2017-07-24 2021-06-01 Facebook, Inc. Transport of control data in proxy-based network communications
US10560726B2 (en) 2017-07-26 2020-02-11 CodeShop BV System and method for delivery and caching of personalized media streaming content
EP3585059B1 (en) * 2018-06-20 2023-06-07 Deutsche Telekom AG Transmission of real-time data packets of programs from the internet
WO2021072417A1 (en) * 2019-10-11 2021-04-15 Theta Labs, Inc. Methods and systems for decentralized data streaming and delivery network
US11146667B2 (en) * 2019-11-15 2021-10-12 Cisco Technology, Inc. Configurable segmentation offload
CN112752152B (en) * 2020-12-28 2022-11-25 海信视像科技股份有限公司 Delivery video playing method and display equipment
US11438675B1 (en) 2021-05-06 2022-09-06 Penthera Partners, Inc. Subsequent look media presentation on a playing device
US11606353B2 (en) 2021-07-22 2023-03-14 Biocatch Ltd. System, device, and method of generating and utilizing one-time passwords

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110119394A1 (en) * 2009-11-04 2011-05-19 Futurewei Technologies, Inc. System and Method for Media Content Streaming
WO2011087449A1 (en) * 2010-01-18 2011-07-21 Telefonaktiebolaget L M Ericsson (Publ) Methods and arrangements for http media stream distribution
GB2481529A (en) * 2010-06-22 2011-12-28 Vodafone Ip Licensing Ltd Congestion control for streaming data
US20120284371A1 (en) * 2011-05-03 2012-11-08 Cisco Technology, Inc. Reducing Fetching Load on Cache Servers in Adaptive Streaming

Family Cites Families (95)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
GB2294173B (en) * 1994-10-11 1998-12-09 Mitsubishi Electric Corp Disk media, and method of and device for recording and playing back information on or from a disk media
US7412533B1 (en) * 1997-03-31 2008-08-12 West Corporation Providing a presentation on a network having a plurality of synchronized media types
US7490169B1 (en) * 1997-03-31 2009-02-10 West Corporation Providing a presentation on a network having a plurality of synchronized media types
US6289358B1 (en) * 1998-04-15 2001-09-11 Inktomi Corporation Delivering alternate versions of objects from an object cache
WO2000058870A2 (en) * 1999-03-31 2000-10-05 America Online, Inc. Handling a request for information provided by a network site
US6768992B1 (en) * 1999-05-17 2004-07-27 Lynne G. Jolitz Term addressable memory of an accelerator system and method
US6708213B1 (en) 1999-12-06 2004-03-16 Lucent Technologies Inc. Method for streaming multimedia information over public networks
WO2001075629A1 (en) * 2000-03-31 2001-10-11 Neomedia Technologies, Inc. System for accessing internet via wireless device using linkage url bar-code
US20050273514A1 (en) 2000-12-22 2005-12-08 Ray Milkey System and method for automated and optimized file transfers among devices in a network
CA2331474A1 (en) 2001-01-19 2002-07-19 Stergios V. Anastasiadis Stride-based disk space allocation scheme
US7555561B2 (en) * 2001-03-19 2009-06-30 The Aerospace Corporation Cooperative adaptive web caching routing and forwarding web content data broadcasting method
US7389533B2 (en) 2002-01-28 2008-06-17 Hughes Network Systems, Llc Method and system for adaptively applying performance enhancing functions
SE524679C2 (en) 2002-02-15 2004-09-14 Ericsson Telefon Ab L M Broadcast / multicast broadcast system data transmission information to a local area of a wireless network
US6868439B2 (en) 2002-04-04 2005-03-15 Hewlett-Packard Development Company, L.P. System and method for supervising use of shared storage by multiple caching servers physically connected through a switching router to said shared storage via a robust high speed connection
US9137324B2 (en) 2002-04-10 2015-09-15 International Business Machines Corporation Capacity on-demand in distributed computing environments
US7451229B2 (en) * 2002-06-24 2008-11-11 Microsoft Corporation System and method for embedding a streaming media format header within a session description message
US7418494B2 (en) 2002-07-25 2008-08-26 Intellectual Ventures Holding 40 Llc Method and system for background replication of data objects
US7171469B2 (en) * 2002-09-16 2007-01-30 Network Appliance, Inc. Apparatus and method for storing data in a proxy cache in a network
JP2004246747A (en) * 2003-02-17 2004-09-02 Hitachi Ltd Wrapping method and system of existing service
US7162533B2 (en) * 2004-04-30 2007-01-09 Microsoft Corporation Session description message extensions
US7573826B1 (en) * 2004-06-22 2009-08-11 Nortel Networks Limited Darwinian network
CN100465955C (en) * 2004-10-12 2009-03-04 国际商业机器公司 Method, system, and computer program product for caching web content
JP2006165928A (en) * 2004-12-07 2006-06-22 Hitachi Ltd Data distribution support method for traveling object
US7191215B2 (en) * 2005-03-09 2007-03-13 Marquee, Inc. Method and system for providing instantaneous media-on-demand services by transmitting contents in pieces from client machines
US7937379B2 (en) * 2005-03-09 2011-05-03 Vudu, Inc. Fragmentation of a file for instant access
US8364792B2 (en) * 2005-03-09 2013-01-29 Vudu, Inc. Method and system for distributing restricted media to consumers
US8230098B2 (en) * 2006-05-10 2012-07-24 At&T Intellectual Property Ii, L.P. System and method for streaming media objects
US9209934B2 (en) 2006-06-09 2015-12-08 Qualcomm Incorporated Enhanced block-request streaming using cooperative parallel HTTP and forward error correction
US9386064B2 (en) * 2006-06-09 2016-07-05 Qualcomm Incorporated Enhanced block-request streaming using URL templates and construction rules
US7711797B1 (en) 2006-07-31 2010-05-04 Juniper Networks, Inc. Optimizing batch size for prefetching data over wide area networks
US9100248B2 (en) * 2007-05-07 2015-08-04 Vorne Industries, Inc. Method and system for extending the capabilities of embedded devices through network clients
US8561116B2 (en) 2007-09-26 2013-10-15 Charles A. Hasek Methods and apparatus for content caching in a video network
WO2009054907A2 (en) * 2007-10-19 2009-04-30 Swarmcast, Inc. Media playback point seeking using data range requests
CA2720398C (en) * 2008-04-02 2016-08-16 Twilio Inc. System and method for processing telephony sessions
US8099089B2 (en) * 2008-05-13 2012-01-17 Nokia Corporation Method, user equipment and software product for media stream transfer between devices
JP2010003095A (en) * 2008-06-20 2010-01-07 Fujifilm Corp Web page data transmitter and its operation control method
EP2329385A4 (en) 2008-08-06 2016-09-14 Movik Networks Content caching in the radio access network (ran)
AU2010276462B1 (en) 2010-12-27 2012-01-12 Limelight Networks, Inc. Partial object caching
US20100169303A1 (en) * 2008-12-31 2010-07-01 David Biderman Playlists for real-time or near real-time streaming
US8717890B2 (en) 2009-01-30 2014-05-06 Movik Networks Application, usage and radio link aware transport network scheduler
US8909806B2 (en) * 2009-03-16 2014-12-09 Microsoft Corporation Delivering cacheable streaming media presentations
US8621044B2 (en) 2009-03-16 2013-12-31 Microsoft Corporation Smooth, stateless client media streaming
US9357065B2 (en) * 2009-03-18 2016-05-31 Centurylink Intellectual Property Llc System, method and apparatus for transmitting audio signals over a voice channel
US9549039B2 (en) 2010-05-28 2017-01-17 Radware Ltd. Accelerating HTTP responses in a client/server environment
US20130298170A1 (en) 2009-06-12 2013-11-07 Cygnus Broadband, Inc. Video streaming quality of experience recovery using a video quality metric
US9917874B2 (en) * 2009-09-22 2018-03-13 Qualcomm Incorporated Enhanced block-request streaming using block partitioning or request controls for improved client-side handling
WO2011039617A1 (en) * 2009-09-29 2011-04-07 Nokia Corporation System, method and apparatus for dynamic media file streaming
CN102771080B (en) 2009-12-01 2016-03-16 万特里克斯公司 Use the system and method that the efficient media of buffer memory transmits
CA2783592A1 (en) * 2009-12-11 2011-06-16 Nokia Corporation Apparatus and methods for describing and timing representations in streaming media files
US20110296048A1 (en) * 2009-12-28 2011-12-01 Akamai Technologies, Inc. Method and system for stream handling using an intermediate format
WO2011090715A2 (en) 2009-12-28 2011-07-28 Akamai Technologies, Inc. Edge server for format-agnostic streaming architecture
US9532092B1 (en) * 2009-12-30 2016-12-27 Akamai Technologies, Inc. Multiple bitrate format-agnostic streaming architecture
WO2011139305A1 (en) 2010-05-04 2011-11-10 Azuki Systems, Inc. Method and apparatus for carrier controlled dynamic rate adaptation and client playout rate reduction
US8683337B2 (en) * 2010-06-09 2014-03-25 Microsoft Corporation Seamless playback of composite media
CA2802904C (en) 2010-06-18 2019-06-18 Akamai Technologies, Inc. Extending a content delivery network (cdn) into a mobile or wireline network
US8918533B2 (en) * 2010-07-13 2014-12-23 Qualcomm Incorporated Video switching for streaming video data
KR20120010089A (en) 2010-07-20 2012-02-02 삼성전자주식회사 Method and apparatus for improving quality of multimedia streaming service based on hypertext transfer protocol
US8782268B2 (en) 2010-07-20 2014-07-15 Microsoft Corporation Dynamic composition of media
US9021047B2 (en) 2010-07-31 2015-04-28 Unwired Planet, Llc Method and system for delivering embedded objects in a webpage to a user agent using a network device
US8806050B2 (en) * 2010-08-10 2014-08-12 Qualcomm Incorporated Manifest file updates for network streaming of coded multimedia data
CA2810239C (en) * 2010-09-03 2018-11-27 Level 3 Communications, Llc Extending caching network functionality to an existing streaming media server
KR101206698B1 (en) 2010-10-06 2012-11-30 한국항공대학교산학협력단 Apparatus and method for providing streaming contents
US8468262B2 (en) 2010-11-01 2013-06-18 Research In Motion Limited Method and apparatus for updating http content descriptions
CN102469072A (en) 2010-11-08 2012-05-23 华为技术有限公司 Streaming media service method, system and client
WO2012065186A2 (en) * 2010-11-12 2012-05-18 Realnetworks, Inc. Traffic management in adaptive streaming protocols
US20120140645A1 (en) * 2010-12-03 2012-06-07 General Instrument Corporation Method and apparatus for distributing video
US8799759B2 (en) 2010-12-13 2014-08-05 International Business Machines Corporation Pre-rendering web content
US8880633B2 (en) 2010-12-17 2014-11-04 Akamai Technologies, Inc. Proxy server with byte-based include interpreter
US20120265853A1 (en) * 2010-12-17 2012-10-18 Akamai Technologies, Inc. Format-agnostic streaming architecture using an http network for streaming
US20120166667A1 (en) 2010-12-22 2012-06-28 Edward Hall Streaming media
KR20120083747A (en) 2011-01-18 2012-07-26 삼성전자주식회사 Method and apparatus for transmission in integrating system of broadcasting-communication service and multimedia service
US9232268B2 (en) 2011-02-23 2016-01-05 Broadcom Corporation Unified video delivery system for supporting IP video streaming service
US8489760B2 (en) * 2011-03-31 2013-07-16 Juniper Networks, Inc. Media file storage format and adaptive delivery system
EP2695352A4 (en) 2011-04-01 2014-12-31 Intel Corp Cross-layer optimized adaptive http streaming
US9026671B2 (en) * 2011-04-05 2015-05-05 Qualcomm Incorporated IP broadcast streaming services distribution using file delivery methods
EP2695361B1 (en) 2011-04-07 2016-01-06 Interdigital Patent Holdings, Inc. Method and apparatus for local data caching
WO2011100901A2 (en) * 2011-04-07 2011-08-25 华为技术有限公司 Method, device and system for transmitting and processing media content
US8849950B2 (en) 2011-04-07 2014-09-30 Qualcomm Incorporated Network streaming of video data using byte range requests
US20120278495A1 (en) 2011-04-26 2012-11-01 Research In Motion Limited Representation grouping for http streaming
US8510555B2 (en) * 2011-04-27 2013-08-13 Morega Systems Inc Streaming video server with virtual file system and methods for use therewith
US9358460B2 (en) 2011-04-28 2016-06-07 Numecent Holdings, Inc. Adaptive cloud-based application streaming
TW201720194A (en) 2011-06-01 2017-06-01 內數位專利控股公司 Content delivery network interconnection (CDNI) mechanism
US8856283B2 (en) * 2011-06-03 2014-10-07 Apple Inc. Playlists for real-time or near real-time streaming
KR101797507B1 (en) 2011-06-20 2017-11-15 엘지전자 주식회사 Media content transceiving method and transceiving apparatus using same
US8925021B2 (en) 2011-07-11 2014-12-30 Telefonaktiebolaget Lm Ericsson (Publ) Method and system for trick play in over-the-top video delivery
US9357275B2 (en) * 2011-09-06 2016-05-31 Qualcomm Incorporated Network streaming of coded video data
US9445136B2 (en) 2011-09-21 2016-09-13 Qualcomm Incorporated Signaling characteristics of segments for network streaming of media data
US20140219088A1 (en) 2011-09-30 2014-08-07 Ozgur Oyman Quality of experience enhancements over wireless networks
BR112014007669B1 (en) 2011-09-30 2021-03-02 Huawei Technologies Co., Ltd method and device for streaming streaming media
US9843844B2 (en) * 2011-10-05 2017-12-12 Qualcomm Incorporated Network streaming of media data
US10397294B2 (en) 2011-12-15 2019-08-27 Dolby Laboratories Licensing Corporation Bandwidth adaptation for dynamic adaptive transferring of multimedia
US9819717B2 (en) 2011-12-28 2017-11-14 Intel Corporation Video adaptation for content-aware wireless streaming
US8977704B2 (en) * 2011-12-29 2015-03-10 Nokia Corporation Method and apparatus for flexible caching of delivered media
US20130182643A1 (en) 2012-01-16 2013-07-18 Qualcomm Incorporated Method and system for transitions of broadcast dash service receptions between unicast and broadcast
US9401968B2 (en) 2012-01-20 2016-07-26 Nokia Techologies Oy Method and apparatus for enabling pre-fetching of media

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110119394A1 (en) * 2009-11-04 2011-05-19 Futurewei Technologies, Inc. System and Method for Media Content Streaming
WO2011087449A1 (en) * 2010-01-18 2011-07-21 Telefonaktiebolaget L M Ericsson (Publ) Methods and arrangements for http media stream distribution
GB2481529A (en) * 2010-06-22 2011-12-28 Vodafone Ip Licensing Ltd Congestion control for streaming data
US20120284371A1 (en) * 2011-05-03 2012-11-08 Cisco Technology, Inc. Reducing Fetching Load on Cache Servers in Adaptive Streaming

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
VAN LANCKER, W ET AL.: "HTTP adaptive streaming with media fragment URIs", PROCEEDINGS OF THE 2011 IEEE INTERNATIONAL CONFERENCE ON MULTIMEDIA AND EXPO, 1 January 2011 (2011-01-01), pages 1 - 6, XP002681037, DOI: doi:10.1109/ICME.2011.6012149

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP3125495A1 (en) * 2015-07-27 2017-02-01 Palo Alto Research Center, Incorporated Content negotiation in a content centric network
US20170034240A1 (en) * 2015-07-27 2017-02-02 Palo Alto Research Center Incorporated Content negotiation in a content centric network
CN106411996A (en) * 2015-07-27 2017-02-15 帕洛阿尔托研究中心公司 Content negotiation in a content centric network
US10701038B2 (en) * 2015-07-27 2020-06-30 Cisco Technology, Inc. Content negotiation in a content centric network
CN106411996B (en) * 2015-07-27 2021-08-24 思科技术公司 Content negotiation in content-centric networks

Also Published As

Publication number Publication date
CN104025548B (en) 2017-09-08
TW201342864A (en) 2013-10-16
CN104025548A (en) 2014-09-03
ES2731948T3 (en) 2019-11-19
PL2798818T3 (en) 2019-09-30
US20150113089A1 (en) 2015-04-23
EP2798818A1 (en) 2014-11-05
EP2798818A4 (en) 2015-08-26
US10523776B2 (en) 2019-12-31
US20130173737A1 (en) 2013-07-04
EP2798818B1 (en) 2019-04-17
US8977704B2 (en) 2015-03-10
TWI602415B (en) 2017-10-11

Similar Documents

Publication Publication Date Title
US10523776B2 (en) Method and apparatus for flexible caching of delivered media
US9401968B2 (en) Method and apparatus for enabling pre-fetching of media
US9712891B2 (en) Method and apparatus for selecting an access method for delivery of media
KR101401183B1 (en) Apparatus and methods for describing and timing representations in streaming media files
KR101364299B1 (en) Method and apparatus to facilitate client controlled sessionless adaptation
US8468262B2 (en) Method and apparatus for updating http content descriptions
KR20180123500A (en) Signaling of application content packaging and delivery
KR101766696B1 (en) Associating representations in adaptive streaming
JP7128967B2 (en) Method, apparatus and computer program for providing multimedia streaming content
KR20210109591A (en) Flexible interoperability and capability signaling using an initialization layer

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 12862371

Country of ref document: EP

Kind code of ref document: A1

WWE Wipo information: entry into national phase

Ref document number: 2012862371

Country of ref document: EP

NENP Non-entry into the national phase

Ref country code: DE