CA2621257A1 - System and method for transferring multiple data channels - Google Patents

System and method for transferring multiple data channels Download PDF

Info

Publication number
CA2621257A1
CA2621257A1 CA002621257A CA2621257A CA2621257A1 CA 2621257 A1 CA2621257 A1 CA 2621257A1 CA 002621257 A CA002621257 A CA 002621257A CA 2621257 A CA2621257 A CA 2621257A CA 2621257 A1 CA2621257 A1 CA 2621257A1
Authority
CA
Canada
Prior art keywords
data
terminal
server
bitrate
bitstream
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
CA002621257A
Other languages
French (fr)
Inventor
Cheuk Chan
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
PacketVideo Corp
Original Assignee
Packetvideo Corp.
Cheuk Chan
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 Packetvideo Corp., Cheuk Chan filed Critical Packetvideo Corp.
Publication of CA2621257A1 publication Critical patent/CA2621257A1/en
Abandoned legal-status Critical Current

Links

Classifications

    • 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, manipulating MPEG-4 scene graphs
    • H04N21/23406Processing of video elementary streams, e.g. splicing of video streams, manipulating MPEG-4 scene graphs involving management of server-side video buffer
    • 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/1066Session management
    • H04L65/1101Session protocols
    • 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/611Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio for multicast or broadcast
    • 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/613Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio for the control of the source by the destination
    • 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, manipulating MPEG-4 scene graphs
    • H04N21/23424Processing of video elementary streams, e.g. splicing of video streams, manipulating MPEG-4 scene graphs involving splicing one content stream with another content stream, e.g. for inserting or substituting an advertisement
    • 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, manipulating MPEG-4 scene graphs
    • H04N21/2343Processing of video elementary streams, e.g. splicing of video streams, manipulating MPEG-4 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, manipulating MPEG-4 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/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/24Monitoring of processes or resources, e.g. monitoring of server load, available bandwidth, upstream requests
    • H04N21/2402Monitoring of the downstream path of the transmission network, e.g. bandwidth available
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/438Interfacing the downstream path of the transmission network originating from a server, e.g. retrieving MPEG packets from an IP network
    • H04N21/4383Accessing a communication channel
    • H04N21/4384Accessing a communication channel involving operations to reduce the access time, e.g. fast-tuning for reducing channel switching latency
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/44Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream, rendering scenes according to MPEG-4 scene graphs
    • H04N21/44004Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream, rendering scenes according to MPEG-4 scene graphs involving video buffer management, e.g. video decoder buffer or video display buffer
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/44Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream, rendering scenes according to MPEG-4 scene graphs
    • H04N21/44016Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream, rendering scenes according to MPEG-4 scene graphs involving splicing one content stream with another content stream, e.g. for substituting a video clip

Abstract

A system and a method transfer multiple data channels between a server and a terminal via a stream session over a network. The system and the method utilize a bitstream switching, a fast buffer filling and/or a fast playback start to facilitate a switch from a first data channel and a second data channel. The first data channel and/or the second data channel is delivered to and/or is transferred to the terminal from the server over the network via a streaming session. The server transfers second data of the second data channel to the terminal via one or more tracks which are encoded at more than one bitrate and/or are configured in one or more configurations. The terminal requests a change between the first track and/or the second track without terminating the stream session for the first data channel between the terminal and the server.

Description

SPECIFICATION
Title "SYSTEM AI.3'D METHOD FOR TRANSFERRING MULTIPLE DATA CHANNELS"
This application claims the benefit of U.S. Provisional Application Serial No.: 60/719,381, filed September 22, 2005.
BACKGROUND OF THE INVENTION
The present invention generally relates to a system and a method for transferring multiple data channels. More specifically, the present invention relates to a system and a method for transferring multiple data channels from a server to a terminal via a network. First data of a first data channel may be transferred, may be sent and/or may be transmitted from the server to the terminal over the network via a streaming session which may be .established between the terminal and the server. The terminal may change to, may switch to and/or may display a second data channel by requesting, by receiving and/or by displaying the second data of the second data channel. The terminal may change to and/or may switch to the second data channel from the first data channel without terminating the streaming session established for the first _ - - - - - -data channel. A bitstream switching, a fast buffer filling and or a fast playback start of the server and/or the terminal may be utilized by the server and/or the terminal to change to, to switch to and/or to display the second data channel. A delay time for switching to the second data channel from the first data channel and displaying the second data of the second data channel may be minimized by the bitstream switching, the fast buffer filling and/or the fast playback start the terminal.
It is generally known, for example, that a user may download, may display, may view and/or may watch a first content source via a terminal. The first content source may include first data of a first data channel which may be transmitted from a server and/or may be delivered to the terminal from the server over an internet protocol (hereinafter ' IP' ) network. The first data of the first data channel may be streamed, may be transferred and/or may be transmitted from the server to the terminal over the IP network via a streaming session, such as, for example, a unicast streaming session and/or a multicast streaming session.
To receive the first data of the first data channel from the server, the terminal must join and/or must establish a first streaming session for the first data channel. First, the terminal must send and/or must transmit a request to the server for a description of the first streaming session to be forwarded to and/or to be transmitted to the terminal via the network. Then, the terminal must send and/or must transmit a request to the server for establishing the first data channel between the server and the terminal. Next, the terminal must send and/or must transmit a request to the server for initiating and/or for commencing a transmission of the first data of the first data channel from the server to the terminal via the first streaming session. Finally, the terminal must fill a pre-roll buffer at the terminal prior to rendering the first data to the user via an output means. As a result.,_ a- fir-st-_st.reaming-session for t-he- first- data- of the first data channel is transmitted to the terminal and/or is displayed by the terminal to the user via the first streaming session and/or the output means.
The user may switch from viewing, from downloading, from displaying and/or from watching the first data channel associated with the first content source to a second data channel associated with a second content source via the terminal, the server and/or the network. However, to view the second data channel of the second content source, the terminal must terminate the first streaming session for the first data of the first data channel.
Next, the terminal must tear down and/or must terminate the first streaming session between the server and the terminal for the first data channel. Then, the terminal must join and must establish a second streaming session for the second data channel as set forth above to receive the second data of the second data channel.
Finally, a second stream of second data of the second data channel is transmitted to, is transferred to,. is sent to and/or is displayed by the terminal via the second streaming session. As a result, the user may view, may download, may display and/or may watch the second data channel and/or the second content source via the terminal. However, a delay period of time, such as, for example, fifteen seconds may elapse from the time of the switching to and/or selecting the second content source and v~.ewing the second data of the second data channel via the second streaming session. The delay period of time may be inconvenient to and/or may be troublesome to the user for switching from the first content source to the second content source.
A need, therefore, exists for a system and a method for transferring multiple data channels. Further, a need exists for a system and a method for transferring multiple data channels which may switch from a first data channel to a second data channel without terminating a' first streaming session for the first data channel-. - - -Sti1l- f-urt-her; - -a-- need--exists -for a- system--and --a method - -for transferring multiple data channels which may switch from a first data channel to a second data channel without requiring a terminal to join and/or to establish a second streaming session for L'I-Le second daLta channel. Moreover, a need exists for a system and a method for transferring multiple data which may utilize a bitstream switching, a fast buffer filling and/or a fast playback start of a terminal to switch from a first data channel to a second data channel. Furthermore, a need exists for a system and a method for transferring multiple data channels which may minimize a delay period of time for switching from a first data channel to a second data channel and displaying the second data channel via a terminal.

The present invention relates to a system and a method for transferring multiple data channels between a server and a terminal via a stream session over a network. More specifically, the present invention relates to a system and a method for transferring multiple data channels which may provide a bitstream switching, a fast buffer filling and/or a fast playback start of a terminal to facilitate a switch between a first data channel and a second data channel. The first data channel and/or the second data channel may be delivered to and/or may be transferred to the terminal from the server over the network via a streaming session, such as, for example, a unicast streaming session, a multicast streaming session and/or the like. The system and the method may identify the first data channel and/or the second data channel as a first track and/or a second track, respectively. The terminal may request a change for the first track and/or the second track without terminating the stream session between the terminal and the server. As a result, the system and/or the method may minimize a delay period of time for requesting a switch to the first track or the second track and displaying the first data channel or the second data channel, respectively.
-- -- ---- In---an- embodiment-- of- --the- present invention, --a - syst-em--for transferring multiple data channels is provided. The system has server storing first data and second data wherein the first data is encoded at a first bitrate and the second data is encoded at a second bitrate wherein the second bitrate is a greater bitrate than the first bitrate> Additionally, the system has a terminal electrically connected to the server via a communication network wherein the terminal and the server communicate via the communication network wherein the terminal has a buffer which receives a first portion of the second data. Further, the server establishes a streaming session with the terminal via the communication network wherein the server transmits the first data to the terminal at the first bitrate wherein the terminal displays the first data. Moreover, the server transmits the first portion of the second data to the buffer of the terminal at a third bitrate without terminating the streaming session wherein the third bitrate is a greater bitrate than the second bitrate wherein the terminal displays the first portion of the seconcl data from the buffer at the second bitrate.
In an embodiment, the system has an output means connected to the terminal wherein the first data and the second data are displayed via the output means.
In an embodiment, the steaming session is a unicast streaming session or a multicast streaming session.
In an embodiment, the communication network is wireless.
In an embodiment, the system has a second portion of the second data which is transmitted to the terminal from the server at the second bitrate.
In an embodiment, the system has a bitstream transmitted from the server to the terminal via the streaming session wherein the portion of the second data fills the buffer of the terminal via the bitstream.
In an embodiment, the first data and the second data are video frames -and- aud-io -s-ignals-.
In another embodiment of the present invention, a method for transferring multiple data channels is provided. The method has the step of storing first data and second data in a server wherein the first data is encoded at a first bitrate and the second data is encoded at a second bitrate which is a greater bitrate than the first bitrate wherein a portion of the second data is encoded at a third bitrate wherein the portion of the second data is stored in the server wherein the third bitrate is a greater bitrate than the second bitrate. Additionally, the method has the step of connecting a terminal to the server via a communication network wherein the terminal and the server communicate via the communication network wherein the terminal has a buffer which receives the portion of the second data. Further, the method has the step of transmitting a first bitstream at the first bitrate from the server to the terminal wherein the terminal receives the first data via the first bitstream wherein the terminal displays the first data. Still further, the method has the step of switching from the first data to the second data without terminating communication between the terminal and the server wherein the server transmits the portion of the second data to the terminal at the third bitrate wherein the portion of the second data fills the buffer of the terminal. Moreover, the method has the step of transmitting a second bitstream at the secoad bitrate from the server to the terminal wherein the terminal receives the second data via the second bitstream wherein the server transmits the second bitstream at the second bitrate after the portion of the second data from the buffer is displayed by the terminal.
In an embodiment, the method has the step of establishing a streaming session between the server and the terminal wherein the terminal receives the first bitstream and the second bitstream.
In an embodiment, the method has the step of transmitting a request from the terminal to the server wherein the request instructs the server _ to-_switch_from_- the__fi.rst bitstream- to -the-second bitstream.
In an embodiment, the communication network is wireless.
In an embodiment, the method has the step of initiating a data channel between the server and the terminal wherein the terminal receives the first bitstream or the second bitstream from the server.
In an embodiment, the method has the step of initiating playback of the portion of the second data before the buffer is filled with the portion of the second data.
In an embodiment, the buffer of the terminal is a pre-roll buffer or a jitter buffer.
In another embodiment of the present invention, a method for transferring multiple data channels is provided. The method has the step of establishing a streaming session between a server and a terminal over a communication network wherein the server stores first data and second data wherein the server communicates the first data and the second data to the server via the streaming session wherein the terminal has a buffer which receives a portion the second data. Additionally, the method has the step of transmitting a first bitstream at a first bitrate from the server to the terminal wherein the terminal receives the first data from the server wherein the terminal displays the first data. Further, the method has the step of requesting a second bitstream from the server wherein the terminal receives the second data from the server wherein the second data is encoded at a second bitrate by the server wherein the second bitrate is a greater bitrate than the first bitrate. Moreover, the method has the step of transmitting a portion of the second data from the server to the terminal wherein the portion of the second data is transmitted to the terminal at a third bitrate without terminating the streaming session between the server and the terminal. The third bitrate is a greater bitrate than the first bitrate and the second bitrate --- --whe-r-ein--the ---buffe-r- -of the terrminal receives-- the portion of the--second data from the server wherein the terminal displays the portion of the second data from the buffer.
In an embodiment, the method has the step of transmitting the second bitstream at the second bitrate from the server to the terminal wherein the terminal displays the second data from the second bitstream.
In an embodiment, the method has the step of filling the buffer of the terminal with the portion of the second data received from the server at the third bitrate wherein the second data is displayed by the terminal.
In an embodiment, the method has the step of establishing a data channel between the server and the terminal wherein the terminal receives the first bitstream and the second bitstream.
In an embodiment, the method has the step of switching from the first bitstream to the second bitstream without terminating the streaming session between the server and the terminal.
In an embodiment, the communication network is wireless.
It is, therefore, an advantage of the present invention to provide a system and a method for transferring multiple data channels from a server to a terminal over a network via a streaming session between the terminal and the server.
Another advantage of the present invention is to provide a system and a method for transferring multiple data channels which may transfer, may transmit and/or may deliver a first data channel and/or a second data channel from a server to a terminal via a unicast streaming session and/or a multicast streaming session.
And, another advantage of the present invention is to provide a system and a method for transferring multiple data channels which may switch between a first data channel and a second data channel without terminating a streaming session for the first data channel between a server and a terminal.
Yet another advantage of the present invention is to provide -- - a- system and--a- -method -f-or-- t-r-ansfe-r--r--ing -mu-ltipl-e -da-ta -ch-annels which may switch from a first data channel to a second data channel without terminating a streaming session for the first data channel and/or without joining a streaming session for the second data channel.
A further advantage of the present invention is to provide a system and a method for transferring multiple data channels which may minimize a delay period of time for requesting a switch from a first data channel to a second data channel and displaying the second data channel via a terminal and/or a streaming session.
Moreover an advantage of the present invention is to provide a system and a method for transferring multiple data channels which may provide a bitstream switchirig, a fast buffer filling and/or a fast playback start of a terminal for switching between a first data channel and a second data channel.
.And, another advantage of the present invention is to provide a system and a method for transferring multiple data channels which may provide a television-like service to a terminal from a server via an internet protocol network.
Yet another advantage of the present invention is to provide a system and a method for transferring multiple data channels which may facilitate a rapid channel switching between a terminal and a server.
Another advantage of the present invention is toprovide a system and a method for transferring multiple data channels which may identify a first data channel and/or a second data channel as a first track encoded at a first bitrate and/or in a first configuration and/or a second track, respectively, encoded at a second bitrate and/or in a second configuration.
Yet another advantage of the present invention is to provide a system and a method for transferring multiple data channels which may identify a request to switch from a first data channel to a second data channel as a request to switch from a first track to a -_- se-cond-t-r-ack-,-- respectively,---and/-o-r--to-switch--from- a first bitstream- ----to a second bitstream, respectively.
A still further advantage of the present invention is to provide a system and a method for transferring multiple data channels which may prevent multiple round trip communication delays between a server and a terminal requesting to switch between a first data channel and a second data channel.
Moreover, an advantage of the present invention is to provide a system and a method for transferring multiple data channels which may deliver data via a bitstream from a server to a terminal at a rate of speed greater than a real time rate of speed by sending the data at a transmission rate of speed above an encoded bitrate of the bitstream.
And, another advantage of the present invention is to provide a system and a method for transferring multiple data channels which may provide a server for subsampling data and/or for sending the data via a bitstream to a terminal at a transmission rate of speed similar to an encoded bitrate of the bitstream.
Yet another advantage of the present invention is to provide a system and a method for transferring multiple data channels which may fill a buffer at a terminal to display video frames and/or audio signals from a bitstream and/or which may switch to a bitrate of the bitstream to display the video frames and/or the audio signals of the bitstream. .
Moreover, an advantage of the present invention is to provide a system and a method for transferring multiple data channels which may provide a playback speed less than a real time rate of speed based on an arrival rate of data in a bitstream.
And, another advantage of the present invention is to provide a system and a method for transferring multiple data channels which may send seconds worth of data to a terminal and/or may send the data at a real time rate of speed.
Additional features and advantages of the present invention are. described -- in, - ----a-nd -- will- --be- --apparent- -from, - - the -detailed- -description of the presently preferred embodiments and from the drawings.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 illustrates a black box diagram of a system in an embodiment of the present invention.
DETAILED DESCRIPTION OF THE PREFERRED EMB DIMENTS
The present invention relates to a system and a method for transferring multiple data channels between a server and a terminal over a network. The multiple data channels may have a first data channel and/or a second data channel which may provide first data from a first content source and/or second data from a second content source, respectively. The first data channel and/or the second data channel may be transmitted, may be transferred and/or may be sent from the server to the terminal via a streaming session established between the server and the terminal. The terminal and/or the server may switch between the first data channel and/or the second data channel without terminating the streaming session.
The terminal may utilize a bitstream switching, a fast buffer filling and/or a fast playback start to facilitate a switching between the first data channel and/or the second data channel. The streaming session may not be terminated by the server and/or the terminal to switch between the first data channel and/or the second data channel. As a result, a delay period of time for requesting to switch to the first data channel and/or the second data channel and to display the first data channel and/or_ the second data channel, respectively, may be minimized by the server and/or the terminal.
Referring now to the drawings wherein like numerals refer to like parts, FIG. 1 illustrates a system 10 which may have a server 11 for transferring a first data of a first data channel and/or a second data of a second data channel to the terminal 12 via a data communication network 14 (hereinafter "the network 14 "). The first - _ data and/or the__ second -data--ma-y- -be, -for---examp3.-e; - audio --si-gnals~ - - --video frames, data streams and/or the like. The first data channel and/or the second data channel may relate to a first content source dfid/or a second content source, respectively, and/or to a media service, such as, for example, a television service, a radio service, a cable television service, a satellite service and/or the like. The terminal 12 may be connected to and/or may be in communication with the server 11 via the network 14. The present invention should not be limited to a specific embodiment of the media service related to the first data channel and/or the second data channel.
The terminal 12 may be, for example, a computer terminal, a mobile device and/or an electronic device which may be capable of transmitting, of receiving, of processing, of accepting and/or of displaying the first data and/or the second data. Further, the mobile device may be, for example, a 3G mobile device, an internet protocol (hereinafter "IP") video cellular telephone, a PDA, a laptop computer and/or the like. It should be understood that the terminal 12 may be any terminal capable of transmitting, capable of receiving, capable of processing and/or capable of displaying the first data and/or the second data known to one having ordinary skill in the art.
The network 14 may be, for example, an IP network, a wireless network, a wireline network, a local-area network, a-wide-area network and/or the like. The terminal 12 may be remote with respect to and/or may be remotely connected to the server 11 via the network 14. The present invention should not be limited to a specific embodiment of the network 14. It should be understood that the network 14 may be any network capable of connecting and/or providing communication between the terminal 12 and the server 11 known to one having ordinary skill in the art.
The first data of the first data channel and/or the second data of the second data channel may be packetized by the server 11.
The first- data and/or the -secoind data -may be delivered to; may be transmitted to, may be transferred to and/or may be sent to the terminal 12 from the server 11 over the network 14. The first data and/or the second data may be streamed from the server 11 to the terminal 12 via the network 14 over a streaming session which may be established between the server 11 and the terminal 12. The streaming session may be, for example, a unicast streaming session, a multicast streaming session and/or the like. It should be understood that the invention is not limited to a specific embodiment of the streaming session.
The terminal 12 may join, may commence and/or may initiate the streaming session for the first data channel between the terminal 12 and the server 11 via the network 14. As a result, the terminal 12 may access, may receive, may request and/or may display the first data of the first data channel. The terminal 12 may transmit, may transfer and/or may send a request via the network 14 to the server 11 for forwarding a description of the streaming session to the terminal 12. The terminal 12 may receive the description of the streaming session from the server 11 via the network 14. The terminal 12 may transmit, may transfer and/or may send a request via the network 14 to the server 11. for establishing, for commencing and/or for initiating the first data channel and/or the streaming session between the terminal 12 and the server 11. As a result, the server 11 may establish, may commence and/or may initiate the first data channel and/or the streaming session between the server 11 and the terminal 12 via the network 14.
The terminal 12 may transmit and/or may send a request to the server 11 via the network 14 to transmit to transfer and/or to communicate the first data of the first data channel from the server 11 to the terminal 12 via the network 14. The server 11 may stream, may transfer and/or may transmit the first data to the terminal 12 via the network 14. The first data received from the --server 11- may fill-a---pre--roll buffer at -the- terminal -12:- The pre-roll buffer at the terminal 12 may capture and/or may play the video frames associated with the first data and/or the audio signals associated with the first data via an output means 16 associated with the terminal 12. The output means 16 may be, for example, a monitor, a projector, a light emitting diode, a liquid crystal display and/or a speaker. The terminal 12 may render, may display and/or may reproduce the first data of the first data channel to a user 18 via the output means 16. The present invention should not be limited to a specific embodiment of the output means 16.
The user 18 may desire to view, to hear, to download and/or to receive the second data channel of the second content source via the terminal 12 and/or the output means 16. The user 18 may switch the streaming session from the first data channel associated with the first content source to the second data channel associated with the second content source. The server 11 may transfer, may transmit and/or may send the second data o.f the second data channel to the terminal 12 over the network 14 via the streaming session.
The server 11 and/or the terminal 12 may utilize a bitstream switching, a fast buffer filling and/or a fast playback start to facilitate a switching between the first data of the first data channel and the second data of the second data channel. As a result, a delay period of time for requesting a switch to the second data channel and displaying and/or rendering the second data of the second data channel, respectively, via the output means 16 may be minimized by the terminal 12. As a result, the user may view, may display and/or may hear the second data of the second data channel via the output means 16 of the terminal~12.
The bitstream switching of the terminal 12 may switch from a first bitstream to a second bitstream during a transmission of the first data and/or the second data to accommodate a change in a channel condition of the first data channel and/or the second data ---- c-hanne-l-.--- Th-e- channel---cond-ition--may- -be,- for - example, - a channel -throughput condition, a channel noise condition and/or the like.
For example, the bitstream switch may switch and/or may change from a first bitstream encoded at a first bitrate to a second bitstream encoded at a second bitrate. The first bitrate of the first bitstream may be greater than the second bitrate of the second bitstream. Switching from the first bitstream to the second bitstream may accommodate for a decrease in the channel throughput and/or may compensate for higher noise levels in the first data channel and/or the second data channel.
The bitstream switching may create and/or may produce bitstreams at multiple bitrates. The bitstreams may be created and/or may be produced simultaneously and/or may be synchronized in time. The bitstream switching may utilize an encoder to produce multiple bitstreams at different bitrates simultaneously using the first data of the first data channel and/or the second data of the second data channel. Alternatively, the bitstream switching may utilize multiple encoders that may each produce a bitstream which may be encoded at different bitrates. The terminal 12 and/or the server 11 may switch bitstreams from a first bitstream encoded at a first bitrate to a second bitstream encoded at a second bitrate.
The second bitrate may be similar to a real time rate of speed as a channel condition, such as, for example, the channel throughput condition of the fir.st data channel and/or of the second data channel may change.
For video-on-demand (hereinafter ' VOD ') streaming, bitstreams of the VOD streaming may be p're-encoded at multiple bitrates and .may be stored as separate tracks inside a file or as a track in multiple files. The bitstream switching of the terminal 12 between different bitrates may switch from a first track encoded at a first bitrate to a second track encoded at a second bitrate within a file or may switch between two files of the multiple files. As a result, the user 18 may view the first data of the first data channel or __ the second data of the second data channel at one or more bitrates to accommodate the channel throughput condition of the first data channel or the second data channel, respectively. The bitstream switching may facilitate a change from the first bitstream at the first bitrate to the second bitstream at the second bitrate.
Switching from the first bitstream to the second bitstream may be based on an adaptive algorithm which may measure the channel throughput condition of the first data channel and/or the second data channel. The adaptive algorithm may govern and/or may control the switching from the first bitstream to the second bitstream based on a measurement of the channel throughput condition of the first channel and/or the second channel.
The fast buffer filling and/or the fast playback start of the terminal 12 may be utilized to enable and/or to facilitate a viewing and/or a displaying of the first data and/or the second data at a first playback rate of speed which may be greater than a normal playback rate of speed. The fast buffer filling and/or the fast playback start may fill the pre-roll buffer and/or a jitter buffer of the terminal 12 with the first data and/or the second data at a buffer rate of speed which may be greater than the normal playback rate of speed. The normal playback rate of speed may be based on consumption of the first data and/or the second data by the terminal 12 and/or the output means to display, to reproduce, to render and/or to transmit the fzrst data and/or the second data to the user 18. As a result, the terminal 12 and/or the output means 16 may initiate, may transmit, may display and/or may render the first data and/or the second data to the user 18 via the output ,means 16 without filling a capacity of the pre-roll buffer and/or the jitter buffer.
The server 11 may transfer, may transmit arid/or may send the first data of the first data channel and/or the second data of the second data channel to the terminal 12 via the network 14. The first data of the first data channel may be delivered to the - - - -- -terminal 12 via the network 14 over the stxeaming-session between-the terminal 12 and the server 11. The server 11 and/or the terminal 12 may facilitate a rapid channel switch from the first data channel to the second data channel at the terminal 12.
The server 11 and/or the terminal 12 may identify and/or may recognize the first data channel and/or the second data channel as a first track and/or a second track. The first data channel may have the first data in a first bitstream and/or in a second bitstream. The second data channel may have the second data in a third bitstream and/or in a fourth bitstream. The first bitstream, the second bitstream, the third bitstream and/or the fourth bitstream may be identified by the server 11 and/or the terminal 12 as a first track, a second track, a third track and/or a fourth track, respectively. The first track, the second track, the third track and/or the fourth track may be encoded at a first bitrate, a second bitrate, a third bitrate and/or a fourth bitrate, respectively. Further, the first track, the second track, the third track and/or the fourth track may:be configured in a first configuration, a second configuration, a third configuration and/or a fourth configuration, respectively. The first track, the second track, the third track and/or the fourth track may enable the terminal 12 and/or the server 11 to switch between the first data channel and the second data channel.
The terminal 12 may send and/or may transmit a request to change channels to the server 11. The request to change channels may request the server 11 to change and/or to switch from a first track or a second track to a third track or a fourth track.
Alternatively, the request to change channels may request the server 11 to change from a first bitstream or a second bitstream to a third bitstream or a fourth bitstream. The server 11 may transmit, may transfer and/or may send the third channel, the fourth channel, the third bitstream and/or the fourth bitstream to the terminal 12 via the network 14 over the streaming session. The ---__ - - -- - - -terminal 12 may receive, may-display and/or may render--the-second --data from the third track, the fourth track, the third bitstream, and/or the fourth bitstream to the user 18 via the output means 16.
The request to change channels may prevent the terminal 12 and/or the server 11 from terminating and/or from closing the streamina session. Further, the request to change channels may przvent the terminal 12 and/or the server 11 from establishing and/or from initiating a stream session for the second data channel. Still further, the request to change channels may prevent multiple round trip communication delays. As a result, the delay period of time for transmitting the request to change channels to the server and displaying the second data to the user 18 may be minimized by the request to change channels.
The server 11 may store k seconds worth of the second data for the third bitstream and/or the fourth bitstream. A maximum size of the jitter buffer in the terminal 12 may be represented by and/or may relate to a value of k. The value of k may denote and/or may relate to an amount of time which may follow a viewing time of the first data and/or the second data from the streaming session.
The user 18 may select to switch and/or to change from the first track or the second track of the first data channel to the third track and/or the fourth track of the second data channel for viewing via the terminal 12 and/or the output means 16. The server 11 may transmit, may transfer and/or may send the k seconds worth of the second data at N times the third bitrate of the third track and/or the fourth bitrate of the fourth track.. As a result, the second data of the second data channel may be transferred and/or may be delivered to the terminal 12 at a delivery rate of speed greater than a real time rate of speed by sending and/or by transferring the second data at a first transmission rate of speed greater than the third bitrate of the third track and/or the fourth bitrate of the fourth track. The delivery rate of speed and/or the first transmission rate of speed may depend on and/or may be based - - - - -on a ratio of an available channel--bandwi.dth over -the third bi r-a - e of the third track and the fourth bitrate of the fourth track. A
value of N may be the ratio of the available channel bandwidth versus the third bitrate of the third track and/or the fourth bitrate of the fourth track. The value of N may be, for example, a rate factor of the first transmission rate of speed for transmitting the second data at a speed great than the real time rate of speed. The available channel bandwidth may exceed the third bitrate or the fourth bitrate. As a result, the ratio may be equal to N > 1 and/or the terminal 12 may receiving and/or may displaying the second data of the third track or the fourth track.
The available channel bandwidth may be similar to and/or may be equal to the third bitrate of the third track and/or the fourth bitrate of the fourth track. As a result, the ratio may be equal to N= 1. The server 11 may subsample the second data in the third track and/or the fourth track by a factor of L, and a value of L
may be greater than one. The value of L may be a rate factor for subsampling the second data for transmitting the second data at the real time rate of speed. The server 11 may send and/or may transmit the second data at a second transmission rate of speed which may be similar to and/or may be equal to the third bitrate of the third track and/or the fourth bitrate of the fourth track. The server 11 may switch, may initiate and/or may resume sending and/or transferring the second data of the third bitrate or of the fourth bitrate in a real time rate of speed.
The server 11' may send and/or may transfer the k seconds worth of the second data to the terminal 12. As a result, the second data may be delivered and/or may be transferred at the delivery rate of speed which may be greater than the real time rate of speed via subsampling the second data. The server 11 may send or may transmit the second data to the terminal 12 via the streaming session at the second transmission rate of speed which may be similar to and/or may be equal to the third bitrate of the third track and/or the fourth bitrate of the fourth track. -The-fast-buffer filling of the terminal 12 may playback and/or may display the second data at a subsampled rate of speed to allow the pre-roll buffer and/or the jitter buffer to build up from and/or to fill with the second data. The server 11 may switch and/or may change to transferring, to sending and/or to transmitting the second data to the terminal 12 at the:third bitrate or the fourth bitrate. The k seconds worth of the second data may be played out, may be consumed and/or may be displayed by the terminal 12 and/or the output mean 16.
The terminal 12 may display and/or may render the second data of the third track and/or the fourth track to the user 18 at a playback rate of speed less than the real time rate of speed. As a result, the playback rate of speed for the second data may be reduced and/or may be decreased based on an arrival rate of speed of the second data from the server 11 to the terminal 12 via the streaming session. The second data of the third track or the fourth track may be delivered to the terminal 12 via the streaming session at the second transmission rate of speed which may be similar to or may be equal to the third bitrate of the third track or the fourth bitrate of the fourth track. However, the terminal 12 may display and/or may render the second data to the user 18 via the terminal 12 and/or the output means 16 at the playback rate of speed which may be less than the real time rate of speed. by a factor of 1/P. A value of P may be greater than 1. The value of P may be a rate factor of the playback rate of speed for transmitting the second data in the real time rate of speed.
The terminal 12 may receive the k seconds worth of the second data from the server 11 via the network 14 over the streaming session. The terminal 12 may display and/or may render the video frames and/or the audio signals associated with the second data to the user 18 via the terminal 12 and/or the output means 16. The M
seconds worth of the second data may have received from the server - ----- ------_ 11. The fast playback start of the terminal 12 may-display-and/or-may render the video frames and/or the audio signals. A value of M may be less than the value of k. The value of M may be an amount of second of time prior to playback of the second data by the terminal 12 and/or the output means 16. The fast playback start may be utilized with and/or in conjunction with the fast buffer filling at the terminal 12 when N may be. greater than one, L may be greater than one and/or P may be greater than one. After the server 11 may have sent the k seconds worth of the second data, the server 11 may begin, may initiate and/or may resume sending the second data for the second data channel at a real time rate of speed.
In an example, the values of k, N and M may be six, two and one, respectively. The server 11 may store six seconds worth of the second data via the third track or the fourth track. The server 11 may send, may transfer and/or may transmit the second data to the terminal 12 at a transmission rate of speed which may be twice the third bitrate of the third track or the fourth bitrate of the fourth track. As a result, the second data may fill the pre-roll buffer at the terminal 12 within three seconds. The terminal 12 may play, may display and/or may render the video frames and/or the audio signal associated with the second data.
One second of the three seconds for filling the pre-roll buffer may have elapsed and/or may have played via the terminal 12 and/or the output means 16. The two second for filling the pre-roll buffer may continue to arrive from the server 11. After the terminal 12 may have played, may have displayed and/or.may have rendered the six seconds worth of the second data in the pre-roll buffer, the terminal 12 may initiate, may begin and/or may resume playing, displaying and/or rendering the second data at the real time rate of speed.
In another example, the values of k, L and M may be six, two and one, resnectsveiy. Thc server 11 mav store six seconds worth _---of the second data and/or may subsamplc the second--data-by a- factor--- --of two. The server 11 may send, may transmit and/or may transfer a subsample of the second data to the terminal 12 via the network 14 over the streaming session. The server 11 may transfer the sabsampi.c of the second data to the terminal 12 at a transmission rate of speecA which may be equal to the third bitrate of the third track or the fourth bitrate of the fourth track. As a result, the second data may fill the pre-roll buffer at the terminal 12 within three seconds. The terminal 12 may play, may display and/or may render the second data to the user 18 via the terminal 12 and/or the output means 16. The terminal 12 may display and/or may render the second data via the terminal 12 and/or the output means 16.
One second of the three seconds for filling the pre-roll buffer may have elapsed and/or may have played via the terminal 12 and/or the output means 16. The two seconds worth of the second data for filling the pre-roll buffer may continue to arrive from the server 11 via the streaming session. After the terminal 12 may have displayed and/or may have rendered the s,ix seconds worth of the second data in the pre-roll buffer, the terminal 12 may initiate and/or may resume displaying and/or rendering the second data to the user 18 via the terminal 12 and/or the output means 16 at the real time rate of speed.
In yet another example, the values for k, P and M may be equal to three, two an.d one, respectively. The server 11 may store three seconds worth of the second data and/or may send, may transfer and/or may transmit the second data to the terminal 12 in the third track or the fourth 'track via the network 14 over the streaming session. The server 11 may transfer and/or may send the second data to the terminal 12 at the transmission rate of speed which may be equal to the third bitrate of the third track and/or the fourth bitrate of the fourth track. As a result, the second data may fill the pre-roll buffer at'the terminal 12 within three seconds.
The terminal 12 may play, may display and/or may render the second data to the user 18 via the terminal 12 and/o-r t-he-output- means 16.- --The terminal 12 may display and/or may render the second data after one second of the three seconds for filling the pre-roll buffer may have elapsed. The terminal 12 may display and/or may render the second data at the playback rate of speed which may be equal to half of an original intended presentation time frame. The two seconds for filling the pre-roll buffer may continue to arrive from the server 11. After the terminal 12 may have played, may have displayed and/or may have rendered the three seconds worth of second data in the pre-roll buffer, the server 11 may initiate and/or may resume displaying and/or rendering the second data in the real time rate of speed. The present invention should not be deemed as limited to a specific embodiment of the values of k, N, L, and/or M.
The system 10 may transfer, may transmit and/or may send multiple data channels from the server 11 to the terminal 10 over the network 14. The multiple data channels may have the first data channel and/or the second data channel which may provide the first data from the first content source and/or the second data from the second content source, respectively. The first data channel and/or the second data channel may be transmitted, may be transferred and/or may be sent from the server 11 to the terminal 12 via a streaming session which may be established between the server 11 and the terminal 12. The terminal 12 and/or the server 11 may switch between the first data channel and/or the second data channel without terminating the streaming session. The terminal 12 and/or the server 11 may utilize a bitstream switching, a fast buffer filling and/or a fast playback start to facilitate switching between the first data channel and/or the second data channel.
The first data of the first data channel may be transferred to the terminal 12 via the first track encoded at the first bitrate and/or configured in the first configuration and/or the second track encoded at the second bitrate and/or configured in the second -- -- - -- - ---configuration. The second data-of the-second-data-Ghannelmay be transferred to the terminal 12 via the third track encoded at the third bitrate and/or configured in the third configuration and/or a fourth track encoded at the fourth bitrate and/or configured in the fourth configuration. The streaming session may not be terminated by the server 11 and/or the terminal 12 to switch between the first data channel and/or the second data channel. As a result, the delay period of time for requesting to switch to the first data channel and/or the second data channel and displaying the first data channel and/or the second data channel, respectively, may be minimized by the server 11 and/or the terminal 12.
It should be understood that various changes and modifications to the presently preferred embodiments described herein will be apparent to those skilled in the art. Such changes and modifications may be made without departing from the spirit and scope of the present invention and without diminishing its attendant advantages. It is, therefore, intended that such changes and modifications be covered by the appended claims.

Claims (20)

1. A system for transferring multiple data channels, the system comprising:
a server storing first data and second data wherein the first data is encoded at a first bitrate and the second data is encoded at a second bitrate wherein the second bitrate is a greater bitrate than the first bitrate;
a terminal electrically connected to the server via a communication network wherein the terminal and the server communicate via the communication network wherein the terminal has a buffer which receives a first portion of the second data wherein the server establishes a streaming session with the terminal via the communication network wherein the server transmits the first data to the terminal at the first bitrate wherein the terminal displays the first data wherein the server transmits the first portion of the second data to the buffer of the terminal at a third bitrate without terminating the streaming session wherein the third bitrate is a greater bitrate than the second bitrate wherein the terminal displays the first portion of the second data from the buffer at the second bitrate.
2. The system of Claim 1 further comprising:
an output means connected to the terminal wherein the first data and the second data are displayed via the output means.
3. The system of Claim 1 wherein the steaming session is a unicast streaming session or a multicast streaming session.
4. The system of Claim 1 wherein the communication network is wireless.
5. The system of Claim 1 wherein a second portion of the second data is transmitted to the terminal from the server at the second bitrate.
6. The system of Claim 1 further comprising:

a bitstream transmitted from the server to the terminal via the streaming session wherein the portion of the second data fills the buffer of the terminal via the bitstream.
7. The system of Claim 1 wherein the first data and the second data are video frames and audio signals.
8. A method for transferring multiple data channels, the method comprising the steps of:
storing first data and second data in a server wherein the first data is encoded at a first bitrate and the second data is encoded at a second bitrate which is a greater bitrate than the first bitrate wherein a portion of the second data is encoded at a third bitrate wherein the portion of the second data is stored in the server wherein the third bitrate is a greater bitrate than the second bitrate;
connecting a terminal to the server via a communication network wherein the terminal and the server communicate via the communication network wherein the terminal has a buffer which receives the portion of the second data;
transmitting a first bitstream at the first bitrate from the server to the terminal wherein the terminal receives the first data via the first bitstream wherein the terminal displays the first data;
switching from the first data to the second data without terminating communication between the terminal and the server wherein the server transmits the portion of the second data to the terminal at the third bitrate wherein the portion of the second data fills the buffer of the terminal; and transmitting a second bitstream at the second bitrate from the server to the terminal wherein the terminal receives the second data via the second bitstream wherein the server transmits the second bitstream at the second bitrate after the portion of the second data from the buffer is displayed by the terminal.
9. The method of Claim 8 further comprising the step of:
establishing a streaming session between the server and the terminal wherein the terminal receives the first bitstream and the second bitstream.
10. The method of Claim 8 further comprising the step of:
transmitting a request from the terminal to the server wherein the request instructs the server to switch from the first bitstream to the second bitstream.
11. The method of Claim 8 wherein the communication network is wireless.
12. The method of Claim 8 further comprising the step of:
initiating a data channel between the server and the terminal wherein the terminal receives the first bitstream or the second bitstream from the server.
13. The method of Claim 8 further comprising the step of:
initiating playback of the portion of the second data before the buffer is filled with the portion of the second data.
14. The method of Claim 8 wherein the buffer of the terminal is a pre-roll buffer or a jitter buffer.
15. A method for transferring multiple data channels, the method comprising the steps of:
establishing a streaming session between a server and a terminal over a communication network wherein the server stores first data and second data wherein the server communicates the first data and the second data to the server via the streaming session wherein the terminal has a buffer which receives a portion the second data;
transmitting a first bitstream at a first bitrate from the server to the terminal wherein the terminal receives the first data from the server wherein the terminal displays the first data;
requesting a second bitstream from the server wherein the terminal receives the second data from the server wherein the second data is encoded at a second bitrate by the server wherein the second bitrate is a greater bitrate than the first bitrate; and transmitting a portion of the second data from the server to the terminal wherein the portion of the second data is transmitted to the terminal at a third bitrate without terminating the streaming session between the server and the terminal wherein the third bitrate is a greater bitrate than the first bitrate and the second bitrate wherein the buffer of the terminal receives the portion of the second data from the server wherein the terminal displays the portion of the second data from the buffer.
16. The method of Claim 15 further comprising the step of:
transmitting the second bitstream at the second bitrate from the server to the terminal wherein the terminal displays the second data from the second bitstream.
17. The method of Claim 15 further comprising the step of:
filling the buffer of the terminal with the portion of the second data received from the server at the third bitrate wherein the second data is displayed by the terminal.
18. The method of Claim 15 further comprising the step of:
establishing a data channel between the server and the terminal wherein the terminal receives the first bitstream and the second bitstream.
19. The method of Claim 15 further comprising the step of:
switching from the first bitstream to the second bitstream without terminating the streaming session between the server and the terminal.
20. The method of Claim 15 wherein the communication network is wireless.
CA002621257A 2005-09-22 2006-09-06 System and method for transferring multiple data channels Abandoned CA2621257A1 (en)

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US71938105P 2005-09-22 2005-09-22
US60/719,381 2005-09-22
US11/498,220 US7676591B2 (en) 2005-09-22 2006-08-02 System and method for transferring multiple data channels
US11/498,220 2006-08-02
PCT/US2006/034536 WO2007037923A2 (en) 2005-09-22 2006-09-06 System and method for transferring multiple data channels

Publications (1)

Publication Number Publication Date
CA2621257A1 true CA2621257A1 (en) 2007-04-05

Family

ID=37900216

Family Applications (1)

Application Number Title Priority Date Filing Date
CA002621257A Abandoned CA2621257A1 (en) 2005-09-22 2006-09-06 System and method for transferring multiple data channels

Country Status (7)

Country Link
US (2) US7676591B2 (en)
EP (1) EP1949679A4 (en)
JP (1) JP5069240B2 (en)
CN (2) CN101268691B (en)
AU (1) AU2006295191B2 (en)
CA (1) CA2621257A1 (en)
WO (1) WO2007037923A2 (en)

Families Citing this family (38)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101218579B (en) 2005-07-11 2012-12-19 派克维迪奥公司 System and method for transferring data
US7676591B2 (en) 2005-09-22 2010-03-09 Packet Video Corporation System and method for transferring multiple data channels
US7900818B2 (en) * 2005-11-14 2011-03-08 Packetvideo Corp. System and method for accessing electronic program guide information and media content from multiple locations using mobile devices
EP3641239B1 (en) * 2006-02-10 2022-08-03 III Holdings 2, LLC System and method for connecting mobile devices
US7965771B2 (en) * 2006-02-27 2011-06-21 Cisco Technology, Inc. Method and apparatus for immediate display of multicast IPTV over a bandwidth constrained network
US8214868B2 (en) * 2006-04-21 2012-07-03 Agere Systems Inc. Flexible traffic management and shaping processing for multimedia distribution
WO2008021091A2 (en) * 2006-08-11 2008-02-21 Packetvideo Corp. 'system and method for delivering interactive audiovisual experiences to portable devices'
US8031701B2 (en) 2006-09-11 2011-10-04 Cisco Technology, Inc. Retransmission-based stream repair and stream join
WO2008045401A2 (en) * 2006-10-12 2008-04-17 Packetvideo Corp. System and method for creating multimedia rendezvous points for mobile devices
US8769591B2 (en) * 2007-02-12 2014-07-01 Cisco Technology, Inc. Fast channel change on a bandwidth constrained network
US20080253369A1 (en) 2007-04-16 2008-10-16 Cisco Technology, Inc. Monitoring and correcting upstream packet loss
US8014400B2 (en) * 2007-08-10 2011-09-06 Sharp Laboratories Of America, Inc. Method for allocating data packet transmission among multiple links of a network, and network device and computer program product implementing the method
WO2009025747A1 (en) * 2007-08-21 2009-02-26 Packetvideo Corp. Mobile media router and method for using same
WO2009035578A1 (en) * 2007-09-11 2009-03-19 Packetvideo Corp. System and method for virtual storage for media service on a portable device
EP3503008A1 (en) * 2007-12-12 2019-06-26 III Holdings 2, LLC System and method for generating a recommendation on a mobile device
US8065325B2 (en) * 2007-12-12 2011-11-22 Packet Video Corp. System and method for creating metadata
US9497583B2 (en) 2007-12-12 2016-11-15 Iii Holdings 2, Llc System and method for generating a recommendation on a mobile device
US8787153B2 (en) * 2008-02-10 2014-07-22 Cisco Technology, Inc. Forward error correction based data recovery with path diversity
WO2009114111A2 (en) 2008-03-12 2009-09-17 Packetvideo Corp. System and method for reformatting digital broadcast multimedia for a mobile device
JP2009225339A (en) * 2008-03-18 2009-10-01 Sony Corp Information processor, information processing method, and computer program
JP2011523727A (en) * 2008-03-31 2011-08-18 パケットビデオ コーポレーション System and method for managing, controlling and / or rendering media over a network
US8544046B2 (en) * 2008-10-09 2013-09-24 Packetvideo Corporation System and method for controlling media rendering in a network using a mobile device
WO2010065107A1 (en) * 2008-12-04 2010-06-10 Packetvideo Corp. System and method for browsing, selecting and/or controlling rendering of media with a mobile device
US8976722B2 (en) 2008-12-18 2015-03-10 Qualcomm Incorporated Managing transmission protocols for group communications within a wireless communications network
US20100201870A1 (en) * 2009-02-11 2010-08-12 Martin Luessi System and method for frame interpolation for a compressed video bitstream
US9195775B2 (en) 2009-06-26 2015-11-24 Iii Holdings 2, Llc System and method for managing and/or rendering internet multimedia content in a network
US11647243B2 (en) 2009-06-26 2023-05-09 Seagate Technology Llc System and method for using an application on a mobile device to transfer internet media content
WO2011010688A1 (en) * 2009-07-22 2011-01-27 日本電気株式会社 Content delivery system, content delivery method and content delivery programme
EP2507681A4 (en) * 2009-12-02 2013-08-07 Packetvideo Corp System and method for transferring media content from a mobile device to a home network
US20110183651A1 (en) * 2010-01-28 2011-07-28 Packetvideo Corp. System and method for requesting, retrieving and/or associating contact images on a mobile device
JP5715262B2 (en) 2010-12-07 2015-05-07 トムソン ライセンシングThomson Licensing Method and apparatus for managing distribution of content via a plurality of terminal devices in a collaborative media system
WO2012109568A1 (en) 2011-02-11 2012-08-16 Packetvideo Corporation System and method for using an application on a mobile device to transfer internet media content
US8798777B2 (en) 2011-03-08 2014-08-05 Packetvideo Corporation System and method for using a list of audio media to create a list of audiovisual media
US8812621B2 (en) * 2011-05-03 2014-08-19 Cisco Technology, Inc. Reducing fetching load on cache servers in adaptive streaming
US9560392B2 (en) * 2012-09-07 2017-01-31 Google Inc. Dynamic bit rate encoding
US9100461B2 (en) * 2013-03-15 2015-08-04 Wowza Media Systems, LLC Automatically publishing streams to multiple destinations
CN103327364B (en) * 2013-06-08 2016-08-31 广东欧珀移动通信有限公司 A kind of radio transmitting method for audio and video playing and device
WO2015135576A1 (en) * 2014-03-11 2015-09-17 Telefonaktiebolaget L M Ericsson (Publ) Distributing media content services and alternative media content

Family Cites Families (53)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6622171B2 (en) * 1998-09-15 2003-09-16 Microsoft Corporation Multimedia timeline modification in networked client/server systems
GB9822550D0 (en) * 1998-10-15 1998-12-09 British Telecomm Computer communications
FI106998B (en) * 1999-01-15 2001-05-15 Nokia Mobile Phones Ltd Bit rate control on a multimedia device
US6498865B1 (en) * 1999-02-11 2002-12-24 Packetvideo Corp,. Method and device for control and compatible delivery of digitally compressed visual data in a heterogeneous communication network
US6529552B1 (en) * 1999-02-16 2003-03-04 Packetvideo Corporation Method and a device for transmission of a variable bit-rate compressed video bitstream over constant and variable capacity networks
US6665751B1 (en) * 1999-04-17 2003-12-16 International Business Machines Corporation Streaming media player varying a play speed from an original to a maximum allowable slowdown proportionally in accordance with a buffer state
US6167092A (en) * 1999-08-12 2000-12-26 Packetvideo Corporation Method and device for variable complexity decoding of motion-compensated block-based compressed digital video
US7339993B1 (en) * 1999-10-01 2008-03-04 Vidiator Enterprises Inc. Methods for transforming streaming video data
US6804717B1 (en) * 2000-03-30 2004-10-12 Intel Corporation Providing quality of service by transmitting XML files indicating requested resources
US7127237B2 (en) * 2000-06-29 2006-10-24 Kabushiki Kaisha Toshiba Communication terminal having caller identification information display function
US7006631B1 (en) * 2000-07-12 2006-02-28 Packet Video Corporation Method and system for embedding binary data sequences into video bitstreams
US20020133247A1 (en) * 2000-11-11 2002-09-19 Smith Robert D. System and method for seamlessly switching between media streams
DE60139632D1 (en) * 2000-11-29 2009-10-01 British Telecomm TRANSFERRING AND RECEIVING REAL-TIME DATA
US20020136298A1 (en) * 2001-01-18 2002-09-26 Chandrashekhara Anantharamu System and method for adaptive streaming of predictive coded video data
US20020131496A1 (en) * 2001-01-18 2002-09-19 Vinod Vasudevan System and method for adjusting bit rate and cost of delivery of digital data
WO2002071736A2 (en) * 2001-03-05 2002-09-12 Intervideo, Inc. Systems and methods of error resilience in a video decoder
US7089309B2 (en) * 2001-03-21 2006-08-08 Theplatform For Media, Inc. Method and system for managing and distributing digital media
US6792449B2 (en) * 2001-06-28 2004-09-14 Microsoft Corporation Startup methods and apparatuses for use in streaming content
EP1407596B1 (en) * 2001-07-19 2017-10-25 BRITISH TELECOMMUNICATIONS public limited company Video stream switching
EP1292084A3 (en) * 2001-09-07 2005-10-26 Siemens Aktiengesellschaft Method of transmitting data in a packet-oriented data network
US20030048808A1 (en) * 2001-09-12 2003-03-13 Stahl Thomas Anthony Method and apparatus for changing received streaming content channels
JP4655439B2 (en) * 2001-09-13 2011-03-23 ソニー株式会社 Information processing apparatus and method, and program
US7274661B2 (en) * 2001-09-17 2007-09-25 Altera Corporation Flow control method for quality streaming of audio/video/media over packet networks
KR100408525B1 (en) * 2001-10-31 2003-12-06 삼성전자주식회사 System and method of network adaptive real- time multimedia streaming
US7162418B2 (en) * 2001-11-15 2007-01-09 Microsoft Corporation Presentation-quality buffering process for real-time audio
BR0214428A (en) * 2001-11-27 2004-11-03 Siemens Ag Process for exchanging useful information generated under different coding laws between at least two user terminal equipment
US7693220B2 (en) * 2002-01-03 2010-04-06 Nokia Corporation Transmission of video information
US6996173B2 (en) * 2002-01-25 2006-02-07 Microsoft Corporation Seamless switching of scalable video bitstreams
US7409456B2 (en) * 2002-04-10 2008-08-05 Akami Technologies, Inc. Method and system for enhancing live stream delivery quality using prebursting
JP3925311B2 (en) * 2002-06-03 2007-06-06 ソニー株式会社 Data distribution system
JP2005537742A (en) * 2002-08-28 2005-12-08 コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ Streaming multimedia data
US7139279B2 (en) * 2002-12-12 2006-11-21 Dilithium Networks Pty Ltd. Methods and system for fast session establishment between equipment using H.324 and related telecommunications protocols
US7206316B2 (en) * 2002-12-12 2007-04-17 Dilithium Networks Pty Ltd. Methods and system for fast session establishment between equipment using H.324 and related telecommunications protocols
US7650421B2 (en) * 2002-12-30 2010-01-19 Microsoft Corporation Adaptable accelerated content streaming
JP4350955B2 (en) * 2003-01-29 2009-10-28 富士通株式会社 COMMUNICATION RELAY METHOD, COMMUNICATION RELAY DEVICE, COMMUNICATION RELAY PROGRAM, AND COMPUTER-READABLE RECORDING MEDIUM CONTAINING COMMUNICATION RELAY PROGRAM
WO2004072764A2 (en) * 2003-02-13 2004-08-26 Nokia Corporation Method for signaling client rate capacity in multimedia streaming
US7444419B2 (en) * 2003-10-10 2008-10-28 Microsoft Corporation Media stream scheduling for hiccup-free fast-channel-change in the presence of network chokepoints
JP2005130330A (en) * 2003-10-27 2005-05-19 Sharp Corp Stream reproduction apparatus and method, stream reproduction program, and machine readable recording medium with stream reproduction program recorded thereon
WO2005086016A1 (en) * 2004-03-03 2005-09-15 Packetvideo Network Solutions, Inc. System and method for retrieving digital multimedia content from a network node
SE528466C2 (en) * 2004-07-05 2006-11-21 Ericsson Telefon Ab L M A method and apparatus for conducting a communication session between two terminals
US8259565B2 (en) * 2004-09-16 2012-09-04 Qualcomm Inc. Call setup in a video telephony network
KR20070112835A (en) * 2004-12-15 2007-11-27 딜리시움 네트웍스 피티와이 리미티드 Fast session setup extensions to h.324
US7668914B2 (en) * 2005-03-28 2010-02-23 Alcatel Lucent Milestone synchronization in broadcast multimedia streams
CN101218579B (en) * 2005-07-11 2012-12-19 派克维迪奥公司 System and method for transferring data
US7676591B2 (en) 2005-09-22 2010-03-09 Packet Video Corporation System and method for transferring multiple data channels
US20070156770A1 (en) * 2005-10-18 2007-07-05 Joel Espelien System and method for controlling and/or managing metadata of multimedia
US7900818B2 (en) * 2005-11-14 2011-03-08 Packetvideo Corp. System and method for accessing electronic program guide information and media content from multiple locations using mobile devices
EP3641239B1 (en) * 2006-02-10 2022-08-03 III Holdings 2, LLC System and method for connecting mobile devices
US7493106B2 (en) * 2006-03-17 2009-02-17 Packet Video Corp. System and method for delivering media content based on a subscription
US8161111B2 (en) * 2006-03-27 2012-04-17 Packet Video, Corp System and method for identifying common media content
US20070245399A1 (en) * 2006-03-27 2007-10-18 Joel Espelien System and method for assessing electronic program guide information
US8874645B2 (en) * 2006-03-28 2014-10-28 Packetvideo Corp. System and method for sharing an experience with media content between multiple devices
WO2007112111A2 (en) * 2006-03-29 2007-10-04 Packetvideo Corp. System and method for securing content ratings

Also Published As

Publication number Publication date
US20070076756A1 (en) 2007-04-05
US7676591B2 (en) 2010-03-09
EP1949679A4 (en) 2010-12-15
AU2006295191B2 (en) 2010-02-04
CN101268691A (en) 2008-09-17
EP1949679A2 (en) 2008-07-30
CN101268691B (en) 2012-01-04
WO2007037923A2 (en) 2007-04-05
CN102395027B (en) 2014-10-15
US20100070646A1 (en) 2010-03-18
CN102395027A (en) 2012-03-28
WO2007037923A3 (en) 2007-05-31
AU2006295191A1 (en) 2007-04-05
JP2009509461A (en) 2009-03-05
JP5069240B2 (en) 2012-11-07

Similar Documents

Publication Publication Date Title
US7676591B2 (en) System and method for transferring multiple data channels
TWI424747B (en) System and method for connection to a network and for reproducing an audio/video stream received from a server on the network
EP1955518B1 (en) Network based instant replay and time shifted playback
US8340113B2 (en) Method and arrangement for improved media session management
US7881335B2 (en) Client-side bandwidth allocation for continuous and discrete media
US20060230176A1 (en) Methods and apparatus for decreasing streaming latencies for IPTV
US20080263219A1 (en) Method and System to Minimize the Switching Delay Between Two Rtp Multimedia Streaming Sessions
US20090064242A1 (en) Fast channel switching for digital tv
JP2008507898A (en) High-speed channel switching in digital media systems
US20040034870A1 (en) Data streaming system and method
JP2008530835A (en) On-demand multi-channel streaming sessions over packet-switched networks
KR20060026010A (en) Data requesting and transmitting devices and processes
JP2007215069A (en) Transmission apparatus, transmission method, receiving apparatus, receiving method, and transmission reception system
KR20070104797A (en) Method of progressive streaming using a real-time streaming protocol
US20120284421A1 (en) Picture in picture for mobile tv
US20180338170A1 (en) Contiguous Streaming Of Media Stream
KR101164746B1 (en) System and method for compensating consecutive palyback delay of video playback service based on real-time streaming protocol
KR101642380B1 (en) Method of transmission of a digital content stream and corresponding method of reception
KR100859705B1 (en) System and method of transmitting live multimedia stream with temporary i-frame
US8401086B1 (en) System and method for increasing responsiveness to requests for streaming media
WO2009080114A1 (en) Method and apparatus for distributing media over a communications network
JP2008016894A (en) Transmission apparatus and receiving apparatus
HASHEMIZADEHNAEINI Transcoding H. 264 Video via FFMPEG encoder
Nuuri Internet protocol television (IPTV) services
JP2014072650A (en) Image content distributing apparatus

Legal Events

Date Code Title Description
EEER Examination request
FZDE Discontinued

Effective date: 20141216