US20070110074A1 - System and Method for Synchronizing Media Presentation at Multiple Recipients - Google Patents
System and Method for Synchronizing Media Presentation at Multiple Recipients Download PDFInfo
- Publication number
- US20070110074A1 US20070110074A1 US11/306,557 US30655706A US2007110074A1 US 20070110074 A1 US20070110074 A1 US 20070110074A1 US 30655706 A US30655706 A US 30655706A US 2007110074 A1 US2007110074 A1 US 2007110074A1
- Authority
- US
- United States
- Prior art keywords
- client device
- media data
- host device
- media
- packets
- 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
Links
- 238000000034 method Methods 0.000 title claims description 44
- 230000001360 synchronised effect Effects 0.000 claims abstract description 48
- 238000012545 processing Methods 0.000 claims abstract description 45
- 238000004891 communication Methods 0.000 claims abstract description 30
- 230000004044 response Effects 0.000 claims description 37
- 230000008569 process Effects 0.000 claims description 15
- 230000001276 controlling effect Effects 0.000 claims 6
- 230000002596 correlated effect Effects 0.000 claims 3
- 230000006835 compression Effects 0.000 description 20
- 238000007906 compression Methods 0.000 description 20
- 230000005540 biological transmission Effects 0.000 description 16
- 239000000872 buffer Substances 0.000 description 16
- 230000000694 effects Effects 0.000 description 11
- 208000003028 Stuttering Diseases 0.000 description 8
- 230000003139 buffering effect Effects 0.000 description 8
- 230000007246 mechanism Effects 0.000 description 5
- 230000000737 periodic effect Effects 0.000 description 5
- 230000009286 beneficial effect Effects 0.000 description 4
- 238000012937 correction Methods 0.000 description 4
- 230000006855 networking Effects 0.000 description 4
- 230000002093 peripheral effect Effects 0.000 description 4
- 238000007726 management method Methods 0.000 description 3
- 239000003550 marker Substances 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 238000012546 transfer Methods 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 230000000903 blocking effect Effects 0.000 description 2
- 230000015556 catabolic process Effects 0.000 description 2
- 230000008859 change Effects 0.000 description 2
- 238000006731 degradation reaction Methods 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 239000000835 fiber Substances 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000005236 sound signal Effects 0.000 description 2
- UPLPHRJJTCUQAY-WIRWPRASSA-N 2,3-thioepoxy madol Chemical compound C([C@@H]1CC2)[C@@H]3S[C@@H]3C[C@]1(C)[C@@H]1[C@@H]2[C@@H]2CC[C@](C)(O)[C@@]2(C)CC1 UPLPHRJJTCUQAY-WIRWPRASSA-N 0.000 description 1
- 230000004075 alteration Effects 0.000 description 1
- 238000006243 chemical reaction Methods 0.000 description 1
- 239000003795 chemical substances by application Substances 0.000 description 1
- 239000002131 composite material Substances 0.000 description 1
- 230000001351 cycling effect Effects 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 238000002592 echocardiography Methods 0.000 description 1
- 238000005562 fading Methods 0.000 description 1
- 238000003780 insertion Methods 0.000 description 1
- 230000037431 insertion Effects 0.000 description 1
- 230000001151 other effect Effects 0.000 description 1
- 230000008447 perception Effects 0.000 description 1
- 238000011084 recovery Methods 0.000 description 1
- 230000007480 spreading Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/1095—Replication or mirroring of data, e.g. scheduling or transport for data synchronisation between network nodes
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/02—Details
- H04L12/16—Arrangements for providing special services to substations
- H04L12/18—Arrangements for providing special services to substations for broadcast or conference, e.g. multicast
- H04L12/1881—Arrangements for providing special services to substations for broadcast or conference, e.g. multicast with schedule organisation, e.g. priority, sequence management
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/1066—Session management
- H04L65/1101—Session protocols
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/75—Media network packet handling
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/75—Media network packet handling
- H04L65/756—Media network packet handling adapting media to device capabilities
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/242—Synchronization processes, e.g. processing of PCR [Program Clock References]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/43—Processing 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/4302—Content synchronisation processes, e.g. decoder synchronisation
- H04N21/4305—Synchronising client clock from received content stream, e.g. locking decoder clock with encoder clock, extraction of the PCR packets
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/80—Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
- H04N21/85—Assembly of content; Generation of multimedia applications
- H04N21/854—Content authoring
- H04N21/8547—Content authoring involving timestamps for synchronizing content
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/02—Details
- H04L12/16—Arrangements for providing special services to substations
- H04L12/18—Arrangements for providing special services to substations for broadcast or conference, e.g. multicast
Definitions
- the subject matter of the present disclosure relates to a system and method for synchronizing presentation of media at multiple recipients or devices on a network.
- the subject matter of the present disclosure is directed to overcoming, or at least reducing the effects of, one or more of the problems set forth above.
- the network media delivery system includes client devices and a host device.
- Each client device has a network interface for network communication, an engine for processing media data, and a media interface for delivering processed media.
- the host device which can be a computer, establishes network communication links with the client devices, which can be networked media stations.
- the media data can be audio, video, or multimedia.
- the network communication links are wireless links established between a wireless network interface on the host device and wireless network interfaces on the client devices.
- the host device sends media data to the client devices via the network.
- the media data can be sent wirelessly as unicast streams of packets containing media data that are transmitted at intervals to each client device.
- the host device controls processing of media data such that processed media is delivered in a synchronized manner at each of the client devices.
- the host device controls processing of media data such that processed media is delivered in a synchronized manner at the host device and at least one client device.
- the system uses Network Time Protocol (NTP) to initially synchronize local clocks at the client devices with a reference clock at the host device.
- the media data is preferably sent as Real-Time Transport Protocol (RTP) packets from the host device to the client device.
- RTP Real-Time Transport Protocol
- the system includes mechanisms for periodic synchronization, stretching, and compressing of time at the local clocks to handle clock drift.
- the system includes mechanisms for retransmission of lost packets of media data.
- the system can be used to deliver audio at multiple sets of speakers in an environment, such as a house, and can reduce effects of presenting the audio out of sync at the multiple sets of speakers to avoid user-perceivable echo.
- FIG. 1 illustrates an embodiment of a network media delivery system according to certain teachings of the present disclosure.
- FIG. 2 illustrates an embodiment of a networked media station or client device.
- FIG. 3 illustrates a process of operating the disclosed system in flowchart form.
- FIG. 4 illustrates an embodiment of an interface of a media application operating on a host device of the disclosed system.
- FIG. 5A illustrates portion of the disclosed system having a host device delivering packets to multiple client devices.
- FIG. 5B illustrates portion of the disclosed system having a host device and client devices performing retransmission of lost packet information.
- FIG. 6A illustrates an embodiment of a packet requesting retransmission of lost packets.
- FIG. 6B illustrates an embodiment of a response to retransmission request.
- FIG. 6C illustrates an embodiment of a response to a futile retransmission request.
- FIG. 7 illustrates portion of the disclosed system having a host device and multiple client devices exchanging time information.
- FIG. 8A illustrates an embodiment of a packet for synchronizing time.
- FIG. 8B illustrates an embodiment of a packet for announcing time.
- FIG. 9 illustrates portion of the disclosed system having a host device and a client device.
- FIG. 10 illustrates an algorithm to limit stuttering in playback of audio.
- a network media delivery system having a host device and multiple client devices is described herein.
- the following embodiments disclosed herein are described in terms of devices and applications compatible with computer systems manufactured by Apple Computer, Inc. of Cupertino, Calif. The following embodiments are illustrative only and should not be considered limiting in any respect.
- the system 10 includes a host device or computer system 20 and one or more networked media stations or client devices 50 , and various other devices.
- the system 10 in the present embodiment represents only one of several possible configurations and is meant to be illustrative only. Other possible configurations are discussed in the incorporated U.S. patent application Ser. No. 10/862,115.
- the host device 20 can have a wired or wireless connection to each of the client devices 50 without the use of a hub or base station 30 , or the host device 20 can have a wireless connection to the hub or base station 30 .
- the system 10 is used to distribute media (e.g., audio, video, multimedia, etc.) via network connections from the host device 20 to multiple client devices 50 located throughout an environment, such as a house, office, etc.
- the host device 20 is a personal computer, such as an AirPort-equipped Mac or a Wi-Fi-compliant Windows-based PC.
- the client devices 50 are networked media stations, such as disclosed in incorporated U.S. patent application Ser. No. 10/862,115.
- the client devices 50 are plugged into wall sockets, which provide power to the client devices 50 , and are coupled to entertainment devices, such as amplifiers 80 , powered speakers, televisions, stereo systems, videocassette recorders, DVD players, home theatre systems, or other devices capable of delivering media known in the art.
- the client device 50 includes an AC power adapter portion 52 and a network electronics portion 54 .
- the network electronics portion 54 includes a wired network interface 62 , a peripheral interface 64 , and a media interface 66 .
- the wired network interface 62 is an Ethernet interface, although other types of wired network interface known in the art could be provided.
- the peripheral interface 64 is illustrated as a USB interface, although other types of peripheral interfaces, such as IEEE 1394 (“Firewire”), RS-232 (serial interface), IEEE 1284 (parallel interface), could also be used.
- the media interface 66 is illustrated as an audio interface including both an analog lineout and an optical digital audio functionality.
- other media interfaces known in the art such as a multimedia interface or a video interface using composite video, S-video, component video, Digital Video Interface (DVI), High Definition Multimedia Interface (HTMI), etc., could also be provided.
- the network electronics portion 54 also includes a wireless networking interface 68 .
- the wireless network interface 68 preferably takes the form of a “Wi-Fi” interface according to the IEEE 802.11b or 802.11g standards know in the art. However, other wireless network standards could also be used, either in alternative to the identified standards or in addition to the identified standards. These other network standards can include the IEEE 802.11a standard or the Bluetooth standard, for example.
- the host device 20 runs a media application 22 .
- the media application 22 is iTunes software for media file management and playback produced by Apple Computer, Inc.
- the host device 20 is equipped with an Ethernet port that is connected via a cable 24 to a base station 30 .
- the base station 30 can be any variety of access points known in the art.
- the base station 30 includes wireless access, routing, switching and firewall functionality.
- the base station 30 is connected via a cable 42 to a modem 40 , which receives an Internet connection through a connection 44 .
- multimedia files stored on host device 20 can be played using stereo amplifiers 80 , which are connected to client devices 50 using one of the audio interfaces on the client devices 50 .
- the host device 20 and the client devices 50 preferably communicate via a wireless network segment (illustrated schematically by connections 32 ), but wired network segments formed by wired connections, such as Ethernet cables, could also provide communication between the host device and the client devices 50 .
- the client devices 50 communicate with the entertainment devices via a wired network segment 82 .
- the client devices 50 act as wireless base stations for a wireless network and enable the host device 20 to deliver media (e.g., audio, video, and multimedia content) at multiple locations in an environment.
- the client devices 50 are connected to stereo amplifiers 80 or other entertainment devices to playback media stored on the host device 20 .
- a line level audio or a digital fiber optic type of connector connects the client devices 50 to the stereo amplifiers 80 .
- Either type of connector can plug into the multimedia port ( 66 ; FIG. 2 ), which is a dual-purpose analog/optical digital audio mini-jack.
- a mini stereo to RCA adapter cable 82 is used, which connects to RCA-type right and left audio input ports on the stereo amplifier 80 .
- a Toslink digital fiber optic cable can be used, which would connect to digital audio input port on the stereo amplifiers 80 .
- the client devices 50 can also be connected to laptops 70 or personal computers that are capable of playing media (audio, video, etc.) so that the laptops and personal computers can also be considered entertainment devices.
- the laptops 70 or personal computers can have the same functionality as both a client device 50 and an entertainment device so that the laptops 70 and personal computers can be considered both a client device and an entertainment device.
- client device as used herein is meant to encompass not only the networked media stations associated with reference numeral 50 , but the term “client device” as used herein is also intended to encompass any device (e.g., laptop, personal computer, etc.) compatible with the network media delivery system 10 according to the present disclosure.
- client devices 50 for ease in discussion.
- the term “entertainment device” as used herein is meant to encompass not only stereo amplifiers 80 as shown in FIG. 1 , but the term “entertainment device” as used herein is also intended to encompass powered speakers, televisions, stereo systems, videocassette recorders, a DVD players, home theatre systems, laptops, personal computers, and other devices known in the art that capable of delivering media.
- the client devices 50 receive media data from the host device 20 over network connections and output this media data to the entertainment devices.
- audio, video, audio/video, and/or other forms of multimedia may be used, exemplary embodiments disclosed herein relate to sharing of audio with client devices 50 connected to entertainment devices, such as stereo amplifiers 80 , or with laptops 70 or other computers having internal speakers or the like.
- the audio can be stored on the host device 20 or can be obtained from the Internet 46 .
- the teachings of the present disclosure can be applied to video, audio/video, and/or other forms of multimedia in addition to the audio in the exemplary embodiments disclosed herein.
- various details of the network media delivery system are implemented using hardware and software developed by Apple Computer, Inc. Although certain details are somewhat specific to such an implementation, various principles described are also generally applicable to other forms of hardware and/or software.
- the system 10 delivers the same audio in separate locations of an environment (e.g., multiple rooms of a home).
- the system 10 addresses several issues related to playing the same audio in multiple, separate locations.
- One issue involves playing the audio in the separate locations in a synchronized manner with each other.
- the host device 20 and the client devices 50 have their own processors, memory, and transmission interfaces, sending or streaming audio from the host device 20 to the client devices 50 through a wireless or wired communication link will not likely result in synchronized playing of the audio at the separate locations.
- the client device 50 may be connected to different types of entertainment devices, which may have different latency and playback characteristics. It is undesirable to play the same audio in the separate locations out of sync because the listener will hear echoes and other undesirable audio effects.
- the system 10 addresses this issue by substantially synchronizing the playing of the audio in each location so that echo and other effects can be avoided. It should be noted that the level of precision required to substantially synchronize the playing of media at each location depends on the type of media being played, the perceptions of the user, spatial factors, and other details specific to an implementation.
- the disclosed system 10 preferably uses a retransmission scheme to recover lost audio.
- a process 100 of operating the network media delivery system of the present disclosure is illustrated in flowchart form.
- network discovery is performed, and the networked client devices 50 and other configured devices (e.g., a configured laptop 70 ) publish or announce their presence on the network using a predefined service type of a transfer control protocol (Block 102 ).
- the host device 20 browses the local sub-net for the designated service type (Block 104 ).
- the network discovery is used to initiate the interface between the host device 20 and client devices 50 and other compatible devices over the network of the system 10 .
- One example of such a network discovery uses Bonjour, which is a technology that enables automatic discovery of computers, devices, and services on IP networks. Bonjour uses standard IP protocols to allow devices to find each other automatically without the need for a user to enter IP addresses or configure DNS servers.
- Various aspects of Bonjour are generally known to those skilled in the art, and are disclosed in the technology brief entitled “MAC OS X: Bonjour,” dated April 2005, and published by Apple Computer, which is incorporated herein by reference in its entirety.
- the client devices 50 advertise over the network that they support audio streaming and particular audio capabilities (e.g., 44.1 kHz sample rate, 16-bit sample size, and 2-channel/stereo samples).
- the client devices 50 may also advertise security, encryption, compression, and other capabilities and/or parameters that are necessary for communicating with the client devices 50 .
- the media application 22 displays information about the found client devices 50 in a user interface operating on the host device 20 (Block 106 ).
- the media application 22 discovers the client devices by obtaining information of the user's step up of computers and networks for their house, office, or the like from another application containing such information.
- the media application 22 discovers the client devices 50 and recognizes these client devices 50 as potential destinations for audio data. Then, the media application 22 automatically provides these recognized devices 50 as part of a selectable destination for audio playback in a user interface.
- FIG. 4 shows an example of a user interface 200 associated with the media application, such as iTunes.
- the user interface 200 shows an icon 202 for selecting playback locations (e.g., networked client devices and other playback devices located in a house), which have detected on the network.
- a user may select the icon 202 to access a pop-up menu 204 in which the user can activate/deactivate (i.e., check or uncheck) one or more of the playback locations as destinations for audio playback.
- the user interface 200 can display possible destinations for audio playback in a number of ways.
- the display of possible destination can include a network schematic of the user's dwelling, office, or the like, that shows possible destination, or the display can be customized by the user.
- the user selects one or more of the client devices to be used for playback in the user interface (Block 108 ).
- the host device 20 uses Real-Time Streaming Protocol (RTSP) to set up and control the audio stream, and the host device 20 initiates an RTSP connection to each of the selected client devices 50 to determine which set of features the devices 50 support and to authenticate the user (if a password is required) (Block 110 ).
- RTSP Real-Time Streaming Protocol
- the user can then start playback using the user interface of the media application 22 (Block 112 ).
- the host device 20 makes an RTSP connection to each client device 50 to set it up for playback and to start sending the audio stream (Block 114 ).
- the host device 20 then sends a command to each client device 50 to initiate playback (Block 116 ).
- the device 50 negotiates timing information via User Datagram Protocol (UDP) packet exchanges with the host device 20 (Block 118 ).
- UDP User Datagram Protocol
- Each client device 50 determines whether the timing negotiation either succeeds or fails (Block 119 ).
- the client devices 50 do not respond to the command to initiate playback until the timing negotiation either succeeds or fails.
- the timing negotiation occurs early to guarantee that the client devices 50 have the initial timing information needed to synchronize their clocks with the host device 20 before any audio packets are processed by the client devices 50 . ⁇ If the negotiation succeeds, the client device 50 can be used for playback (Block 120 ).
- the associated client device 50 can perform a number of possible operations (Block 121 ). For example, the client device 50 can return an error to the host device 20 in response to the command, and the session on this device 50 can be terminated. In another possible operation, the associated client device 50 can retry to negotiate the timing information. Alternatively, the associated client device 50 can ignore the fact that negotiating timing information has failed. This may be suitable when the user is not interested in the audio playing in synchronized manner in the multiple locations associated with the client devices 50 . For example, the client device may be located by the pool or out in the garage and does not necessarily need to deliver the audio in synch with the other devices.
- the host device 20 sends audio data to the client devices 50 , which process the audio data and deliver processed audio to the connected entertainment devices.
- An example of the process of playing back audio is discussed below with reference to the flowchart of FIG. 3B with concurrent reference to element numerals of FIG. 1 .
- Various buffering, error checking, and other data transfer steps have been omitted from the general description of FIG. 3B .
- the host device 20 is connected to a wireless network established by the access point 30 , which can also provide for a shared connection to the Internet or other network 46 .
- the client devices 50 are also connected to the wireless network and have their multimedia ports connected to stereo amplifiers 80 or other entertainment device having output speakers or other multimedia output capability.
- a digital media file (e.g., a song in ACC format) is stored on the host device 20 .
- the host device 20 transcodes a portion of the media file from the format (e.g., AAC) in which it is stored to a format that is understood by client device 50 (Block 124 ).
- This transcoding step is not necessarily required if the file is stored on the host device 20 in a format that is understood by the client device 50 .
- a block of audio data for transmission is created (Block 126 ).
- This audio data is preferably compressed and encrypted (Block 128 ). Encryption is not necessarily required, but it is advantageous for digital rights management purposes.
- the host device 20 then transmits the audio data over the wireless network to the client devices 50 (Block 130 ).
- the client devices 50 decrypt and decompress the received audio data (Block 132 ), and the client devices 50 decode the audio data based on the encoding performed in Block 124 (Block 134 ).
- the decoding results in raw audio data, which may be, for example, in the form of PCM data.
- This data is converted to analog audio signals by digital-to-audio converters (DAC) (Block 136 ), and the audio signals are output to the stereo amplifiers 80 for playing with their loudspeakers (Block 138 ).
- DAC digital-to-audio converters
- the network media delivery system 10 of the present disclosure preferably uses User Datagram Protocol (UDP) as its underlying transport for media data.
- UDP User Datagram Protocol
- UDP is beneficial for synchronized playback to the multiple client devices 50 because synchronized playback places time constraints on the network protocol.
- audio is extremely time sensitive and has a definite lifetime of usefulness, for example, a packet of media data, such as audio, can become useless if it is received after a point in time when it should have been presented. Accordingly, UDP is preferred because it provides more flexibility with respect to the time sensitive nature of audio data and other media data.
- the disclosed system is preferably configured to handle at least a small percentage of lost packets.
- the lost packets can be recovered using Forward Error Correction (FEC), can be hidden using loss concealment techniques (e.g. repetition, waveform substitution, etc.), or can be recovered via retransmission techniques, such as those disclosed herein.
- FEC Forward Error Correction
- TCP Transmission Control Protocol
- retransmission using TCP may need to address problems with blocking of transmissions. If a TCP segment is lost and a subsequent TCP segment arrives out of order, for example, it is possible that the subsequent segment is held off until the first segment is retransmitted and arrives at the receiver.
- UDP is preferred for time critical portions of the protocol because it can avoid some of the problems associated with blockage of transmission.
- UDP allows the host's media application 22 to control retransmission of lost data because the media application 22 can track time constraints associated with pieces of audio data to be delivered. Based on the known time constraints, the media application 22 can then decide whether retransmission of lost packets of audio data would be beneficial or futile.
- time critical portions of the disclosed system such as time syncing, can be implemented using UDP, and audio data delivery can use TCP with a buffering system that addresses blocking problems associated with TCP.
- FIG. 5A a portion of the disclosed system 300 is shown with a host device 320 and at least two client devices 350 A-B.
- Each of the client devices 350 has a processor 352 , a memory 354 , a transmission interface 356 , and an audio interface 358 .
- the client devices 350 also include a UDP stack and can include a TCP stack depending on the implementation.
- the transmission interfaces 356 can be a Wi-Fi-compatible wireless network interface
- the audio interface 358 can provide an analog and/or an optical digital output.
- the processor 352 and memory 354 can be conventional hardware components known in the art.
- the memory 354 has two audio buffers 361 and 362 .
- each of the client devices 350 has a local clock, a playback engine, and other features.
- the host device 320 uses several commands to set up a connection with and to control operation of the client devices 350 .
- These commands include ANNOUNCE (used for identification of active client devices), SETUP (used to setup connection and operation), RECORD (used to initiate playback at client devices), PAUSE (used to pause playback), FLUSH (used to flush memory at the client devices), TEARDOWN (used to stop playback), OPTIONS (used to configure options), GET_PARAMETER (used to get parameters from the client devices), and SET_PARAMETER (used to set parameters at the client devices).
- ANNOUNCE used for identification of active client devices
- SETUP used to setup connection and operation
- RECORD used to initiate playback at client devices
- PAUSE used to pause playback
- FLUSH used to flush memory at the client devices
- TEARDOWN used to stop playback
- OPTIONS used to configure options
- GET_PARAMETER used to get parameters from the client devices
- SET_PARAMETER
- the client devices 350 are authenticated when initially establishing a connection to the media application 322 running on the host device 320 .
- the media application 322 opens network connections to the transmission interface 356 of the client devices 350 .
- network connections between the host device 320 and the client devices 350 are separated into an audio channel for sending audio data and a control channel used to set up connection and operation between the devices 320 and 350 .
- a single channel could be used for data and control information.
- the host device 320 begins sending data to the client devices 350 .
- the client devices 350 receive the audio data, buffer some portion of the data, and begin playing back the audio data once the buffer has reached a predetermined capacity.
- RTSP Real Time Streaming Protocol
- the media application 322 at the host device 320 preferably uses Real-Time Transport Protocol (RTP) encapsulated in User Datagram Protocol (UDP) packets 330 to deliver audio data from the host device 320 to the client devices 350 .
- RTP Real-Time Transport Protocol
- UDP User Datagram Protocol
- RTSP, RTP, and UDP are standards known to those skilled in the art. Therefore, some implementation details are not discussed here. Details of RTSP can be found in “Real-Time Streaming Protocol,” RFC 2326, which is available from http://www.ietf.org/rfc/rfc2326.txt and which is hereby incorporated by reference in its entirety. Details of RTP can be found in “Real-Time Transport Protocol,” RFC 3550, which is available from http://www.ietf.org/rfc/rfc3550.txt and which is hereby incorporated by reference in its entirety.
- the packets 330 have RTP headers and include both sequence numbers and timestamps.
- the data payload of the RTP packets 330 contains the audio data to be played back by the client devices 350 .
- the media files, from which the packets 330 are derived, can be stored on host device 320 in one or more formats, including, for example, MP3 (Motion Picture Expert's Group Layer 3), AAC (Advanced Audio Coding a/k/a MPEG-4 audio), WMA (Windows Media Audio), etc.
- the media application 322 running on the host device 320 decodes these various audio formats to construct the packets 330 so that the client devices 350 do not need decoders for multiple formats. This also reduces the hardware performance requirements of the client devices 350 .
- Another advantage of performing decoding on the host device 320 is that various effects may be applied to the audio stream, for example, cross fading between tracks, volume control, equalization, and/or other audio effects. Many of these effects would be difficult or impossible to apply if the client device 350 were to apply them, for example, because of the computational resources required.
- other embodiments of the present disclosure can allow for decoding at the client devices 350 for audio and other forms of media.
- the host device 320 preferably uses a separate unicast stream 310 A-B of RTP packets 330 for each of the client devices 350 A-B.
- the separate unicast streams 310 A-B are intended to deliver the same media information (e.g., audio) to each of the client devices 350 A-B so that the same media can be presented at the same time from multiple client devices 350 A-B.
- each of the separate unicast streams 310 A-B can be used to deliver separate media information (e.g., audio) to each of the client devices 350 A-B.
- the user may wish to unicast separate media information in some situations, for example, if a first destination of a first unicast stream of audio is a client device in a game room of a house and a second destination of a second unicast stream of different audio is a client device in the garage of the house. Therefore, it may be preferred in some situations to enable to the user to not only select sending the same media information by unicast streams to multiple client devices by to also allow the user to send different media information by separate unicast streams to multiple client devices.
- the user interface 200 of FIG. 4 can include a drop down menu or other way for the user to make such a related selection.
- Separate unicast streams 310 are preferred because multicasting over wireless networks can produce high loss rates and can be generally unreliable. All the same, the disclosed system 300 can use multicasting over the wireless network. In general, though, bandwidth limitations (i.e. fixed multicast rate), negative effects on unicast performance (low-rate multicast slows down other unicast traffic due to multicast packets taking longer), and loss characteristics associated with multicasting over wireless (multicast packets are not acknowledged at the wireless layer) make multicasting less desirable than using multiple, unicast streams 310 A-B as preferred. Use of multiple, unicast streams 310 A-B does correspond to an increase in bandwidth as additional client devices 350 are added to a group of designated locations for playback.
- the increase in bandwidth associated with multiple, unicast streams 310 A-B may correspond to about 1 Mbit/sec bandwidth required for each client device 350 so that the host device 320 can send compressed audio data to the access point (e.g., 30 ; FIG. 1 ) and another 1 Mbit/sec so that the access point can forward the compressed audio data to the client device 350 .
- the access point e.g., 30 ; FIG. 1
- the host device 320 begins sending normal RTP packets 330 containing the audio data for playback. These RTP packets 330 are sent at regular intervals, based on the number of samples per second, which can be about 44,100 Hz for audio. The RTP packets 330 are sent at the regular intervals in a throttled and evenly spaced manner in order to approximate the audio playback rate of the remote client devices 350 because the UDP-based connection does not automatically control the sending of data in relation to the rate at which that data is consumed on the remote client devices 350 .
- each of the multiple client devices 350 has their own audio buffers 361 , 362 , network conditions, etc., it may not be desirable to use a feedback scheme when sending the packets 330 . Accordingly, the host device 320 sends audio data at a rate that preferably does not significantly under-run or over-run a playback engine 353 of any of the remote client devices 350 . To accomplish this, the host device 320 estimates a fixed delay 340 to insert between packets 330 to maintain the desired audio playback rate.
- each of the client devices 350 can also detect any skew between its clock and the clock of the sending host device 320 . Then, based on the detected skew, each client device 350 can insert simulated audio samples or remove audio samples in the audio it plays back in order to compensate for that skew.
- the RTP packets 330 have timestamps and sequence numbers.
- the client device 350 decrypts and decompresses the payload (see Encryption and Compression section below), then inserts the packet 320 , sorted by its timestamp, into a packet queue.
- the two audio buffers 361 and 362 are alternatingly cycled as audio is played back.
- Each audio buffer 361 and 362 can store a 250-ms interval of audio.
- the received RTP packets in the packet queue are processed when one of the two, cycling audio buffers 361 and 362 completes playback.
- the audio is USB-based so this is a USB buffer completion process.
- the engine 353 To process the queued packets, the engine 353 assembles the queued RTP packets in one of the audio buffers 361 or 362 . During the assembly, the engine 353 calculates when each of queued RTP packets should be inserted into the audio stream. The RTP timestamp in the packets combined with time sync information (see the Time Synchronization section below) is used to determine when to insert the packets. The engine 353 performs this assembly process and runs through the queued packets to fill the inactive audio buffer 361 or 362 before the currently playing audio buffer 361 or 362 has completed.
- each of the audio buffers 361 and 362 can store 250-ms of audio
- the client device 350 has a little less than 250-ms to assemble all the RTP packets, conceal any losses, and compensate for any clock skew. If there are any gaps in the audio (e.g., the device's audio clock is skewed from the host's audio clock, a packet was lost and not recovered, etc.), then those gaps can be concealed by inserting simulated audio samples or removing existing audio samples.
- each client station 350 is provided with a plurality of private keys embedded in read only memory (ROM).
- ROM read only memory
- the media application at the host device 320 is then provided with a corresponding plurality of public keys. This allows identification data transmitted from the networked client devices 350 to the media application to be digitally signed by the client device 350 using its private key, by which it can be authenticated by the media application at the host device 320 using the appropriate public key.
- data sent from the media application at the host device 320 to the networked client stations 350 is encrypted using a public key so that only a client device 350 using the corresponding private key can decrypt the data.
- the media software and networked media station can determine which of their respective pluralities of keys to use based on the exchange of a key index, telling them which of their respective keys to use without the necessity of transmitting entire keys.
- the decoded audio data is preferably compressed by host device 320 before transmission to the client devices 350 .
- This compression is most preferably accomplished using a lossless compression algorithm to provide maximum audio fidelity.
- One suitable compressor is the Apple Lossless Encoder, which is available in conjunction with Apple's iTunes software.
- the client devices 350 require a decoder for the compression codec used.
- the RTP packets 330 are preferably compressed using the Apple Lossless algorithm and are preferably encrypted using the Advanced Encryption Standard (AES) with a 128-bit key size. Loss is still inevitable even though the system 300 uses a UDP-based protocol that attempts to recover from packet loss via retransmission and/or Forward Error Correction (FEC). For this reason, encryption and compression preferably operate on a per-packet basis. In this way, each packet 330 can be completely decoded entirely on its own, without the need for any surrounding packets 330 .
- the Apple Lossless algorithm is used to compress each individual packet 330 rather than compressing a larger stream of audio and packetizing the compressed stream.
- the AES-128 algorithm is used in frame-based cipher block chaining (CBC) mode to encrypt payloads of the RTP packets 330 and the RTP payload portion of RTCP retransmission packets ( 380 ; FIG. 5B ) discussed below. Because each packet 330 represents a single audio frame, no other packets are required to decrypt each packet correctly.
- the system preferably supports any combination of encryption and compression, such as both encryption and compression, encryption only, compression only, or neither encryption nor compression. Encryption and compression are configured during the RTSP ANNOUNCE command.
- the format used to configure encryption and compression is based on the Session Description Protocol (SDP) and embedded as RTSP header fields. Compression uses an SDP “m” (media description) combined with an “rtpmap” and “fmtp” to specify the media formats being used numerically and how those numbers map to actual compression formats and algorithms.
- the RTP packets 330 received from the host device 320 have RTP sequence numbers. Based on those RTP sequence numbers, the client device 350 can determine whether packets 330 that have been lost during transmission or for other reasons. The lost RTP packets 330 cannot be queued for playback in the audio buffers 361 and 362 of the client devices 350 so that gaps will result in the audio. To address this issue, the client devices 350 requests that the lost packet(s) be retransmitted. Referring to FIG. 5B , portion of the disclosed system 300 is shown again to discuss how the system 300 attempts to retransmit packets lost during original transmission.
- the system 300 preferably uses Real-Time Transport Control Protocol (RTCP) when packet loss is detected.
- RTCP Real-Time Transport Control Protocol
- the sequence numbers associated with the received RTP packets ( 330 ; FIG. 5A ) are used to determine if any packets have been lost in the transmission. If there is a gap in the sequence numbers, the client device 350 sends a retransmission request 370 to the sender (e.g., host device 320 or other linked client device 350 ) requesting all the missing packets.
- the retransmission request 370 can request up to a maximum of 128 lost packets per detected gap.
- the host device 320 In response to the retransmission request 370 , the host device 320 sends one or more retransmission responses 380 for lost packets. Due to limitations of the maximum transmission unit (MTU) on RTCP packet sizes, only one response can be sent per retransmission response packet 380 . This means that a single retransmission request packet 370 from a device 350 may generate up to 128 retransmission response packets 380 from the host device 320 if all of the lost packets are found in the host's recently sent packets.
- MTU maximum transmission unit
- FIG. 6A shows an example of an RTCP Retransmit Request Packet 370 for use with the disclosed system.
- the Sequence Number Base refers to the sequence number of the first (lost) packet requested by this RTCP Retransmit Request Packet 370 .
- the Sequence Number Count refers to the number of (lost) packets to retransmit, starting at the base indicated.
- the client device 350 sending the RTCP Retransmission Request packet 370 tracks the retransmission requests that it sends in a queue to facilitate sending additional requests if a response to the retransmission request 370 is not received in a timely manner.
- a retransmission request 370 has not been responded to in a timely manner, another retransmission request 370 is sent from the client device 350 .
- the process of retrying can be continued until a maximum time has elapsed since the first retransmission request 370 was sent. After that maximum time, it is likely too late to deal with the lost packet anyway because the lost packets time for insertion in one of the audio buffers 361 or 362 has passed.
- the initial retransmit request 370 includes all the missing packets. However, if a response 380 is not received in a timely manner, the missing packets are spread out among multiple requests 370 over time when reattempts are made. Spreading out among multiple requests can maintain a uniform delivery of request and response packets. This also prioritizes packets by time and defers delivery of packets whose presentation time is later.
- the host device 320 When the host device 320 receives a retransmission request 370 , the host device 320 searches a list of recently sent packets stored at the device 320 . If the requested packet in the request 370 is found, the host device 320 sends a retransmission response 380 to the client device 350 .
- An example of an RTP extension for an RTCP Retransmit Response Packet 380 is shown in FIG. 6B .
- the RTCP Retransmit Response Packet 380 includes the complete RTP packet (e.g., header and payload) being retransmitted.
- the retransmission packet 380 is only sent to the sender of the retransmission request 370 , unlike the normal RTP packets ( 330 ; FIG. 5A ) that are sent to all devices participating in the session.
- a negative response 390 is sent so the corresponding client device 350 knows that any further attempt to request that particular packet is futile.
- An example of an RTP extension for an RTCP Futile Retransmit Response Packet 390 is shown in FIG. 6C .
- the RTCP Futile Retransmit Response Packet 390 includes the 16-bit sequence number of the failed packet followed by a 16-bit pad containing zero.
- the client device 350 receiving a retransmission response packet 380 inserts the packet 380 into the packet queue in the same way used for inserting packets received as part of the normal RTP packet stream discussed above with reference to FIG. 5A .
- the retransmission response packet 380 is already out-of-sequence and, therefore, does not trigger new retransmission requests based on its sequence number. If an existing packet already exists at the same timestamp as the incoming packet, either via the normal RTP stream or via retransmission, the packet is dropped as a duplicate.
- Scheduling retransmission is based on regular reception of RTP packets ( 330 ; FIG. 5A ) rather than explicit timers. This simplifies the code required and reduces retransmission overhead, but it also throttles retransmission during burst outages (e.g. wireless interference resulting in packet loss during a period). Since retransmissions only occur when RTP packets 330 are received, retransmissions are deferred beyond a possible window when packets 330 may have been lost anyway.
- the disclosed system 300 supports individual volume control by using a relative volume setting specified using a header field as part of an RTSP SET_PARAMETER request.
- the volume is expressed as a floating-point decibel level (e.g. 0 dB for full volume).
- the disclosed system 330 can set other parameters related to the delivery of media at multiple locations using similar techniques. For example, the disclosed system 300 can be used to set equalization levels at each location individually.
- portion 300 of the disclosed system is shown having a host device 320 and multiple client devices 350 exchanging timing information.
- the timebase on the multiple client devices 350 is synchronized with a reference clock 324 on the host device 320 .
- the host device 320 can be a Mac or Windows-based system running the media application 322 .
- the host device 320 does not need to run any special server software, and only the media application 322 according to the present disclosure is required.
- the reference clock 324 at the host device 320 does not need to be synchronized with an external clock, such provided by an NTP server. Rather, the client devices 350 only need to be synchronized to the same reference clock 324 even if that clock 324 is wrong with respect to an external clock.
- the reference clock 324 is maintained within the media application 322 running on the host device 320 . If the host device 320 is a Macintosh computer, then the reference clock 324 can use the PowerPC timebase registers. If the host device 320 is a Windows-based computer, the reference clock 324 can use the Pentium performance counter registers.
- the reference clock 324 of the host's media application 322 is separate from the normal wall-clock time of the host device 320 , which is maintained by an NTP agent and synchronized to an external clock. The reference clock 324 of the host's media application 322 does not need to be synchronized to an external clock and in some cases this would actually be undesirable.
- a time difference between the reference clock 324 and the local clock of a client device 350 can be explicitly skewed or adjusted to account for spatial effects or differences, such at the client device 350 being located farther away than another.
- the user interface associated with the disclosed system 300 such as interface 200 of FIG. 4 , may include a drop-down menu or other control for intentionally manipulating skew.
- the media application 322 uses time sync information based on the principals of the Network Time Protocol (NTP) encapsulated in Real-Time Transport Control Protocol (RTCP) packets.
- NTP Network Time Protocol
- RTCP Real-Time Transport Control Protocol
- NTP is not used directly to avoid collisions with existing NTP services (e.g., date/time synchronization with an external clock) and to avoid permission issues due to NTP's use of a privileged port number.
- NTP Network Time Protocol
- RTCP Real-Time Transport Control Protocol
- NTP is known in the art and provides the basis for inter-media synchronization support in the Real-Time Transport Protocol (RTP). Details of NTP can be found in “Network Time Protocol,” RFC 1305, which is available from http://www.ietf.org/rfc/rfc1305.txt and is incorporated herein by reference in its entirety.
- each client device 350 is provided with a high-resolution clock 364 based on the local clock hardware of each client device 350 (see Local Clock Implementation section below), the high-resolution clocks 364 are synchronized with the reference clock 324 of the host device 320 using the NTP techniques.
- Synchronizing the local clocks 364 of the client devices 350 with the reference clock 324 preferably does not jump to a new time with every correction (referred to as stepping) because stepping can introduce discontinuities in time and can cause time to appear to go backward, which can create havoc on processing code that relies on time.
- the time synchronization techniques of the present disclosure preferably correct time smoothly using clock slewing so that time advances in a linear and monotonically increasing manner.
- frequent micro-corrections below a tolerance threshold, are performed to the running clocks 364 at the client devices 350 to bring their timebase gradually in sync with the timebase of the reference clock 324 of the host's media application 322 .
- the clock slewing techniques also predict the relative clock skew between the local clocks 364 and the host's reference clock 324 by analyzing past history of clock offsets and disciplining the local clocks 364 to run at the same rate as the host's reference clock 324 .
- a centralized reference clock 324 is used for several client devices 350 on a local network
- one way to disseminate time information is to send broadcast/multicast NTP packets periodically from the host device 320 to the client devices 350 .
- Sending NTP packets by multicasting must account for losses and performance degradation that may result from the wireless 802.11b and 802.11g communication links between the host device 320 and the client devices 350 .
- the client devices 350 periodically send unicast requests 410 to the host device 320 so that the client devices 350 can synchronize their clocks 364 with the reference clock 324 . Then, the client devices 350 use responses 420 from the host device 320 corresponding to their requests 410 to continually track the clock offset and propagation delay between the client device 350 and host device 320 so the client devices 350 can update their local clocks 364 .
- synchronization of the audio playback at the client devices 350 is achieved by maintaining local clocks 364 that are synchronized to the host device's clock 324 . Since all client devices participating in a particular session are synchronized to the reference clock 324 . When the clocks 324 and 364 are synchronized, the client devices 350 can play audio in-sync without ever communicating with each other.
- the client devices 350 can use the synchronized timebase to determine when to playback packets of audio data.
- audio data is delivered to the client devices 350 using RTP packets ( 330 ; FIG. 5A ) that contain an RTP timestamp describing the time of a packet's audio relative to other packets in the audio stream.
- the client device 350 uses this timestamp information to reconstruct audio at the correct presentation time for playback. Accordingly, each client device 350 correlates the NTP timebase of its local clock 364 with the RTP timestamps provided in the RTP packets of the audio stream.
- RTP does not define a standard packet format for synchronizing time.
- RTCP sender report which contains some timing information, but not everything that is needed to synchronize time (e.g., there is no originate time for receivers to determine the round trip time).
- sender reports There are also rules preventing sender reports from being sent before any RTP data has been sent, which is critical for playing the initial audio samples in sync.
- the host's media application 322 preferably defines an RTP extension for an RTCP TimeSync packet for the requests and responses 410 and 420 .
- An embodiment of an RTCP TimeSync packet 430 is shown in FIG. 8A .
- the RTCP TimeSync Packet 430 includes a header, the RTP timestamp at NTP Transmit (T3) time, NTP Originate (T1) timestamp, most significant word; NTP Originate (T1) timestamp, least significant word; NTP Receive (T2) timestamp, most significant word; NTP Receive (T2) timestamp, least significant word; NTP Transmit (T3) timestamp, most significant word; NTP Transmit (T3) timestamp, least significant word.
- the Marker bit (M) is not used for these TimeSync packets 430 .
- the packet types (PT) include ‘210’ for a client device request to synchronize time in a manner similar to an NTP client device request and include ‘211’ for a host device response to a client device request.
- the ‘RTP Timestamp’ is the RTP timestamp at the same instant as the transmit time (T3). This should be 0.
- the times T1-T3 come from NTP and are used in the same manner as NTP.
- the RTCP TimeSync request packets 410 from the client devices 350 are sent once the RTSP RECORD command is received so that the client devices 350 can initially synchronize time. Then, the client devices 350 periodically send RTCP TimeSync request packets 410 .
- the periodic intervals for synchronizing time can be at random intervals between two and three seconds apart.
- the RTCP TimeSync response packets 420 are sent by the host device 320 in response to receiving a valid RTCP TimeSync request packet 410 .
- the host's media application 322 also defines an RTP extension for an RTCP TimeAnnounce packet 450 .
- the RTCP TimeAnnounce packets 450 are sent periodically (e.g., once a second) by the host device 320 to update the client devices 350 with the current timing relationship between NTP and RTP.
- the RTCP TimeAnnounce packets 450 can be sent sooner if the host device 320 changes the NTP to RTP timing relationship. For example, when a new song starts, the host's media application 322 can send a new RTCP TimeAnnounce packet 450 with the marker bit (M) set to indicate that the NTP to RTP timing relationship has changed.
- M marker bit
- the RTCPTimeAnnounce Packet 450 includes an RTP timestamp; an NTP timestamp, high 32 bits; an NTP timestamp, low 32 bits; and an RTP timestamp when the new timeline should be applied.
- the Marker bit (M) is used to indicate an explicit change in the NTP to RTP timing relationship.
- the packet type (PT) is defined as ‘212’ to indicate that the host device is announcing a new NTP to RTP relationship.
- the “RTP Timestamp” is the RTP timestamp at the same instant as the NTP timestamp.
- the “NTP Timestamp” is the NTP timestamp at the same instant as the RTP timestamp.
- the field “RTP Apply Timestamp” refers to the RTP timestamp when the new timeline should be applied.
- the local clock 364 of the client device 350 maintains a 64-bit nanoseconds counter that starts at zero on system boot and uses the 60-Hz clock interrupt to increment the nanoseconds counter.
- the 32-bit timer counter is used to determine how much time has passed since the last clock interrupt. This determined amount of time since the last clock interrupt is referred to as the tick delta and is in units of 1/100 of a microsecond.
- the tick delta is then converted to nanoseconds and is added to the nanoseconds counter to maintain the current time. The tick delta is used in this manner to avoid drift due to interrupt latency.
- the nanoseconds counter is adjusted in very small increments during each clock interrupt to “slew” to the target time. These small increments are chosen based on a fraction of the amount of adjustment needed and based on the tick delta. This prevents time from appearing to go backward so that time always increases in a linear and monotonic manner.
- the client device 350 can predict what the next NTP clock offset will be in the future to further adjust the local clock 364 .
- the client device 350 uses a moving average of NTP clock offsets to estimate the slope of the clock skew between each of client device 350 and host device 320 . This slope is then extrapolated to estimate the amount of adjustment necessary to keep the local clock 364 at the client device 350 in sync with the reference clock 324 .
- the client device 350 then makes very small adjustments to the per-clock interrupt increment, in addition to the adjustments made for clock slewing, to simulate the faster or slower clock frequency of the host's reference clock 324 . This allows the local clock 364 to remain synchronized between NTP update intervals and may even allow the reference clock 324 to remain synchronized in the absence of future NTP clock updates).
- the host device 320 is schematically shown having the media application 322 and reference clock 324 , as described previously.
- the host device 320 is schematically shown having an engine 323 , a processor 325 , a transmission interface 326 , and an audio interface 327 .
- the host device 320 can be a computer. Therefore, the processor 325 can be a conventional computer processor, the transmission interface 326 can be a Wi-Fi compatible wireless network interface, and the audio interface 327 can be a sound card or the like for playing audio.
- the media application 322 can be a software program stored in memory on the computer and operating on the computer processor 325 .
- the media application 322 can include the engine 324 for processing media (e.g., audio) data and can include the reference clock 324 for synchronizing time.
- audio data needs to be scheduled for playback at a constant or consistent rate.
- One way to achieve this is for the media application 322 on the host device 320 to send packets 330 of audio data at a constant rate and to have the timeline for presenting that audio data with the client device 350 tied to the send rate of the packets 330 .
- the send rate of the packets 330 and the presentation timeline at the client device 350 must have a one-to-one correspondence, which can restrict the ability to buffer the audio data at the client device 350 .
- buffering of the audio data at the client devices 350 is desirable for handling lost packets, clock skew, etc. If five seconds of buffering is desired at the client device 350 , there will be a five-second delay between the time when the audio data arrives at the client device and the time when it is actually played. Unfortunately, users can readily perceive such a high level of latency when buffering is used with such a one-to-one correspondence between the packet send rate and the presentation time of the audio.
- the sending of packets 330 is preferably decoupled or separated from the timeline for presenting the audio data of those packets 330 .
- the media application 322 maintains two simulated timelines 328 and 329 .
- a first packet timeline 328 corresponds to when packets 330 should be sent
- a second playback timeline 329 corresponds to when the audio data in those packets 330 should be presented or delivered (i.e., played for the user).
- the separate timelines 328 and 329 allow the send rate of the packets 330 to vary as needed so that the system 300 can provide buffering without introducing latency.
- the packet send rate of the first packet timeline 328 can be temporarily increased to front-load the buffers in memory 354 on the client devices 350 and can be later reduced back to the real-time send rate of the packets 330 .
- the separate timelines 328 and 329 also avoid problems associated with fluctuations in the presentation time of audio caused by scheduled latency of the operating systems on the devices.
- the second playback timeline 329 which corresponds to when the audio data in the packets 330 should be presented or delivered, is constructed by the host device 320 .
- the host device 320 uses the reference clock 324 and a desired playback rate of the audio, the host device 320 estimates the number of audio samples that would have played at a given point in time at the client device 350 to construct the playback timeline 329 .
- This second playback timeline 329 is then published from the host device 320 to the client devices 350 as part of the time announcements 450 sent periodically from the host device 320 to the client devices 350 .
- the client device 350 uses the periodic time announcements 450 to establish and maintain the relationship between the RTP timestamps in the audio packets 330 and the corresponding NTP presentation time for the audio packets 330 so that the client device 350 can deliver the audio in synch with other devices.
- the periodic time announcements 450 are not designed to take effect immediately when received by the client devices 350 since the announcements 450 may come in advance of when they are effective.
- the time announcement packets 450 contain an additional RTP timestamp that indicates when the announced time should take effect at the client device 350 . Therefore, a time announcement packet 450 is saved at a client device 350 once it is received. When audio playback reaches the RTP timestamp of that saved time announcement packet 450 , the client device 350 applies the time change contained in that saved time announcement package 450 .
- the disclosed system 300 preferably provides a way for each client device 350 to report its latency characteristics (and that of its associated entertainment device) to the host device 320 so that these latency characteristics can be taken into consideration when determining how to synchronize the playback of media at the client devices 350 .
- Determination of the latency characteristics of the client devices 350 preferably occurs at initial set up of the system 300 .
- the media application 322 at the host device 320 sends RTSP SETUP requests 312 to the client devices 350 at initial set up.
- the client devices 350 use a header field to report the latency characteristics associated with the client devices 350 .
- the values of the field are preferably given as the number of RTP timestamp units of latency. For example, a client device 350 having 250-ms of latency at a 44,100-Hz sample rate would report its audio-latency as 11025 RTP timestamp units.
- the host's media application 322 determines a maximum latency of all client devices 350 in the group being used for playback. This maximum latency is then added to the playback timeline 329 .
- the disclosed system 300 allows for synchronized local playback at the host device 320 running the media application 322 .
- the host device 320 can play the same audio to its local speakers (not shown) that is being played by the client devices 350 , and the host device 350 can have that same audio play in sync with the all the other devices 350 .
- the host device 320 uses many of the same principles as applied to the client devices 350 . Rather than receiving packets of audio data over a wireless network, however, audio data is delivered directly to a local playback engine 323 of the media application 322 .
- the packets of audio data delivered to the synchronized local playback engine 323 within the media application 322 are generated before being compressed and encrypted. Since these packets do not leave media application 322 , no compression or encryption is necessary.
- the host device 320 uses CoreAudio to playback audio. CoreAudio can be used for both Mac-based or Windows-based computers because QuickTime 7 provides support for CoreAudio on Windows-based computers.
- CoreAudio can be used for both Mac-based or Windows-based computers because QuickTime 7 provides support for CoreAudio on Windows-based computers.
- an output AudioUnit is opened, and a callback is installed. The callback is called when CoreAudio needs audio data to play.
- the media application 322 constructs the relevant audio data from the raw packets delivered to it along with the RTP->NTP timing information.
- CoreAudio has different latency characteristics than the latency characteristics associated with the client devices 350 , information is also gathered about the presentation latency associated with the audio stream of CoreAudio. This information is used to delay the CoreAudio audio stream so that it plays in sync with the known latency of the audio streams associated with the client devices 350 .
- the disclosed system 300 preferably limits stuttering in the playback of media.
- an algorithm 500 for limiting stutter in the playback of media is shown in flowchart form. This algorithm 500 can be performed by the host device of the disclosed system for each of the client devices. Using the algorithm 500 , the disclosed system detects audible “glitches” caused by gaps in the media (e.g., audio). These gaps can be caused by loss of packets, packets arriving too late, changes to the synchronized timeline, large amounts of clock skew, or other reasons.
- the system determines the number of such “glitches” occurring in a period of time for each of the client devices (Block 502 ). Then, a determination is made whether the number of glitches is greater than a predetermined limit (Block 504 ). For example, the audio is analyzed over a period of 250-ms to determine whether the 250-ms period is either “glitching” (bad) or “glitch-free” (good). A credit system is used to make this determination. Each time a glitching period is detected, the system takes away a number of credits from a credit score of the client device. The credit score is capped at a minimum value to prevent a long sequence of glitching periods from requiring protracted period of time for the client device to recover, because the intention is to allow the client device to recover quickly as soon as its audio situation clears up.
- the client device is put on probation (Block 506 ).
- audio is disabled and silenced, but the client device can still send retransmit requests to the host device as needed to recover lost packets of audio data.
- the audio is silenced during probation so that the client device will not produce an annoying stutter sound when a significant number of glitching periods are successively delivered in an interval of time. Even though the audio is silenced, retransmits remain enabled so that operation of the client device can improve to a point suitable to resume playback.
- the client device is set as “glitch free” (Block 505 ).
- a “glitch-free” period is detected, for example, a number of credits is added to the credit score for the client device.
- the number of credits is capped at a maximum value to prevent a long sequence of glitch-free periods from extending the number of glitches required before going into stutter avoidance mode because the intention is to be able to go into stutter avoidance mode quickly so that there is not any significant stutter produced.
- the number of glitches occurring in a predetermined unit of time (e.g., X seconds) is determined (Block 508 ).
- the number of glitches is compared to a predetermined limit or threshold (Block 510 ). If the client device is on probation for the predetermined unit of time (X seconds) and the number of credits reaches an upper threshold at Block 510 , the client devices is placed back into normal playback mode at Block 505 .
- the client device is put in jail (Block 512 ).
- the audio remains disabled and silenced.
- retransmits are now disabled. In this situation, the client device has not recovered for a significant period of time, and any retransmits may actually be making the situation worse.
- the recovery time may be improved by reducing congestion on the network.
- disabling retransmits may at least reduce the amount of traffic on the network and may allow other client devices to receive packets of audio data more reliably.
- the client device goes on parole to see if its situation has improved (Block 516 ). When on parole, audio is still disabled and silenced. However, retransmits are re-enabled. The number of glitches occurring in a predetermined unit of time (e.g., Z seconds) is determined (Block 518 ) and compared to a predetermined limit (Block 520 ). If the client device is on parole for the predetermined unit of time and the number of credits reaches an upper threshold at Block 520 , then client device returns to normal playback mode at Block 505 where audio and retransmits are both enabled. If the client device stays on parole for the predetermined unit of time and the number of credits does not reach the upper threshold at Block 520 , however, the client device goes back to jail at Block 512 .
- a predetermined unit of time e.g., Y seconds
- the high volume of data being exchanged by the disclosed system 300 can cause Address Resolution Protocol (ARP) requests, which are broadcast, to become lost.
- ARP Address Resolution Protocol
- ARP is a network protocol used to map a network layer protocol address to a data link layer hardware address.
- ARP can be used to resolve an IP address to a corresponding Ethernet address.
- ARP entries at the host device 320 can expire and can fail to be renewed during operation of the disclosed system 300 so that connections between the host device 320 and client devices 350 may appear to go down.
- one solution to this problem is to extend the expiration times of the ARP entries at the host device 320 as long as packets 330 from the host device 320 are being received by the client devices 350 .
- the ARP entry for a given client device 350 does not time out (as long as packets 330 are being received by that client device 350 ), and the client device 350 does not need to explicitly exchange ARP packets, which may tend to get lost as noted previously, with the host device 320 .
- the client devices 350 periodically (e.g., once a minute) send unsolicited, unicast ARP request packets (not shown) to the host device 320 .
- These unicast ARP request packets contain source addresses (Internet Protocol (IP) address and the hardware address of the client device 350 ) and target addresses (IP address and hardware address of the host device 320 ).
- IP Internet Protocol
- the unicast ARP request packets are more reliable than broadcast packets because the unicast packets are acknowledged and retried at a wireless layer.
- the host device 320 updates its ARP cache when it receives these unicast ARP request packets by refreshing the timeout for the corresponding ARP entries.
Landscapes
- Engineering & Computer Science (AREA)
- Signal Processing (AREA)
- Multimedia (AREA)
- Computer Networks & Wireless Communication (AREA)
- Computer Security & Cryptography (AREA)
- Business, Economics & Management (AREA)
- General Business, Economics & Management (AREA)
- Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
- Mobile Radio Communication Systems (AREA)
- Information Transfer Between Computers (AREA)
Abstract
Description
- This application is a continuation-in-part of U.S. patent application Ser. No. 10/862,115, filed Jun. 4, 2004 and entitled “Networked Media Station,” which is incorporated herein by reference in its entirety and to which priority is claimed.
- The subject matter of the present disclosure relates to a system and method for synchronizing presentation of media at multiple recipients or devices on a network.
- With the increasing capacity and capability of personal computers, as well as improved multimedia interfaces for these computers, it has become popular to use personal computers as a repository for multimedia content, such as songs, movies, etc. Particularly with music, the increased popularity of storing multimedia information on a personal computer has resulted in a variety of products and services to serve this industry. For example, a variety of stand-alone players of encoded multimedia information have been developed, including, for example, the iPod, produced by Apple Computer of Cupertino, Calif. Additionally, services have been developed around these devices, which allow consumers to purchase music and other multimedia information in digital form suitable for storage and playback using personal computers, including, for example, the iTunes music service, also run by Apple Computer.
- These products and services have resulted in an environment where many consumers use their personal computer as a primary vehicle for obtaining, storing, and accessing multimedia information. One drawback to such a system is that although the quality of multimedia playback systems for computers, e.g, displays, speakers, etc. have improved dramatically in the last several years, these systems still lag behind typical entertainment devices, e.g., stereos, televisions, projection systems, etc. in terms of performance, fidelity, and usability for the typical consumer.
- Thus, it would be beneficial to provide a mechanism whereby a consumer could easily obtain, store, and access multimedia content using a personal computer, while also being able to listen, view, or otherwise access this content using conventional entertainment devices, such as stereo equipment, televisions, home theatre systems, etc. Because of the increasing use of personal computers and related peripherals in the home, it would also be advantageous to integrate such a mechanism with a home networking to provide an integrated electronic environment for the consumer.
- In addition to these needs, there is also increasing interest in the field of home networking, which involves allowing disparate devices in the home or workplace to recognize each other and exchange data, perhaps under the control of some central hub. To date a number of solutions in this area have involved closed systems that required the purchase of disparate components from the same vendor. For example, audio speaker systems that allow computer-controlled switching of music from one location to another may be purchased as a system from a single vendor, but they may be expensive and/or may limit the consumer's ability to mix and match components of a home network from different vendors according to her own preferences. Thus, it would be beneficial to provide a mechanism by which various home networking components from differing vendors can nonetheless interact in a home network environment.
- The subject matter of the present disclosure is directed to overcoming, or at least reducing the effects of, one or more of the problems set forth above.
- A system and method for delivering network media at multiple devices is disclosed. For example, the network media delivery system includes client devices and a host device. Each client device has a network interface for network communication, an engine for processing media data, and a media interface for delivering processed media. The host device, which can be a computer, establishes network communication links with the client devices, which can be networked media stations. The media data can be audio, video, or multimedia. In one embodiment, the network communication links are wireless links established between a wireless network interface on the host device and wireless network interfaces on the client devices.
- The host device sends media data to the client devices via the network. The media data can be sent wirelessly as unicast streams of packets containing media data that are transmitted at intervals to each client device. In one embodiment, the host device controls processing of media data such that processed media is delivered in a synchronized manner at each of the client devices. In another embodiment, the host device controls processing of media data such that processed media is delivered in a synchronized manner at the host device and at least one client device.
- The system uses Network Time Protocol (NTP) to initially synchronize local clocks at the client devices with a reference clock at the host device. The media data is preferably sent as Real-Time Transport Protocol (RTP) packets from the host device to the client device. The system includes mechanisms for periodic synchronization, stretching, and compressing of time at the local clocks to handle clock drift. In addition, the system includes mechanisms for retransmission of lost packets of media data. In one embodiment, the system can be used to deliver audio at multiple sets of speakers in an environment, such as a house, and can reduce effects of presenting the audio out of sync at the multiple sets of speakers to avoid user-perceivable echo.
- The foregoing summary is not intended to summarize each potential embodiment or every aspect of the present disclosure.
- The foregoing summary, preferred embodiments, and other aspects of subject matter of the present disclosure will be best understood with reference to a detailed description of specific embodiments, which follows, when read in conjunction with the accompanying drawings, in which:
-
FIG. 1 illustrates an embodiment of a network media delivery system according to certain teachings of the present disclosure. -
FIG. 2 illustrates an embodiment of a networked media station or client device. -
FIG. 3 illustrates a process of operating the disclosed system in flowchart form. -
FIG. 4 illustrates an embodiment of an interface of a media application operating on a host device of the disclosed system. -
FIG. 5A illustrates portion of the disclosed system having a host device delivering packets to multiple client devices. -
FIG. 5B illustrates portion of the disclosed system having a host device and client devices performing retransmission of lost packet information. -
FIG. 6A illustrates an embodiment of a packet requesting retransmission of lost packets. -
FIG. 6B illustrates an embodiment of a response to retransmission request. -
FIG. 6C illustrates an embodiment of a response to a futile retransmission request. -
FIG. 7 illustrates portion of the disclosed system having a host device and multiple client devices exchanging time information. -
FIG. 8A illustrates an embodiment of a packet for synchronizing time. -
FIG. 8B illustrates an embodiment of a packet for announcing time. -
FIG. 9 illustrates portion of the disclosed system having a host device and a client device. -
FIG. 10 illustrates an algorithm to limit stuttering in playback of audio. - While the subject matter of the present disclosure is susceptible to various modifications and alternative forms, specific embodiments thereof have been shown by way of example in the drawings and are herein described in detail. The figures and written description are not intended to limit the scope of the inventive concepts in any manner. Rather, the figures and written description are provided to illustrate the inventive concepts to a person skilled in the art by reference to particular embodiments, as required by 35 U.S.C. § 112.
- A network media delivery system having a host device and multiple client devices is described herein. The following embodiments disclosed herein are described in terms of devices and applications compatible with computer systems manufactured by Apple Computer, Inc. of Cupertino, Calif. The following embodiments are illustrative only and should not be considered limiting in any respect.
- I. Components of the Network Media Delivery System
- Referring to
FIG. 1 , an embodiment of a network media delivery system 10 according to certain teachings of the present disclosure is illustrated. The system 10 includes a host device orcomputer system 20 and one or more networked media stations orclient devices 50, and various other devices. The system 10 in the present embodiment represents only one of several possible configurations and is meant to be illustrative only. Other possible configurations are discussed in the incorporated U.S. patent application Ser. No. 10/862,115. For example, thehost device 20 can have a wired or wireless connection to each of theclient devices 50 without the use of a hub orbase station 30, or thehost device 20 can have a wireless connection to the hub orbase station 30. ¶The system 10 is used to distribute media (e.g., audio, video, multimedia, etc.) via network connections from thehost device 20 tomultiple client devices 50 located throughout an environment, such as a house, office, etc. - The
host device 20 is a personal computer, such as an AirPort-equipped Mac or a Wi-Fi-compliant Windows-based PC. Theclient devices 50 are networked media stations, such as disclosed in incorporated U.S. patent application Ser. No. 10/862,115. Theclient devices 50 are plugged into wall sockets, which provide power to theclient devices 50, and are coupled to entertainment devices, such asamplifiers 80, powered speakers, televisions, stereo systems, videocassette recorders, DVD players, home theatre systems, or other devices capable of delivering media known in the art. - An example of the
client device 50 is discussed briefly with reference toFIG. 2 . Theclient device 50 includes an AC power adapter portion 52 and anetwork electronics portion 54. Thenetwork electronics portion 54 includes a wired network interface 62, a peripheral interface 64, and amedia interface 66. As illustrated, the wired network interface 62 is an Ethernet interface, although other types of wired network interface known in the art could be provided. Similarly, the peripheral interface 64 is illustrated as a USB interface, although other types of peripheral interfaces, such as IEEE 1394 (“Firewire”), RS-232 (serial interface), IEEE 1284 (parallel interface), could also be used. Likewise, themedia interface 66 is illustrated as an audio interface including both an analog lineout and an optical digital audio functionality. However, other media interfaces known in the art, such as a multimedia interface or a video interface using composite video, S-video, component video, Digital Video Interface (DVI), High Definition Multimedia Interface (HTMI), etc., could also be provided. - The
network electronics portion 54 also includes awireless networking interface 68. Thewireless network interface 68 preferably takes the form of a “Wi-Fi” interface according to the IEEE 802.11b or 802.11g standards know in the art. However, other wireless network standards could also be used, either in alternative to the identified standards or in addition to the identified standards. These other network standards can include the IEEE 802.11a standard or the Bluetooth standard, for example. - Returning to
FIG. 1 , thehost device 20 runs amedia application 22. In one exemplary embodiment, themedia application 22 is iTunes software for media file management and playback produced by Apple Computer, Inc. In the present configuration, which is only one of several possibilities, thehost device 20 is equipped with an Ethernet port that is connected via acable 24 to abase station 30. Thebase station 30 can be any variety of access points known in the art. Preferably, thebase station 30 includes wireless access, routing, switching and firewall functionality. Thebase station 30 is connected via acable 42 to amodem 40, which receives an Internet connection through aconnection 44. Using this arrangement, multimedia files stored onhost device 20 can be played usingstereo amplifiers 80, which are connected toclient devices 50 using one of the audio interfaces on theclient devices 50. Thehost device 20 and theclient devices 50 preferably communicate via a wireless network segment (illustrated schematically by connections 32), but wired network segments formed by wired connections, such as Ethernet cables, could also provide communication between the host device and theclient devices 50. Theclient devices 50 communicate with the entertainment devices via awired network segment 82. - The
client devices 50 act as wireless base stations for a wireless network and enable thehost device 20 to deliver media (e.g., audio, video, and multimedia content) at multiple locations in an environment. For example, theclient devices 50 are connected tostereo amplifiers 80 or other entertainment devices to playback media stored on thehost device 20. In one embodiment, a line level audio or a digital fiber optic type of connector connects theclient devices 50 to thestereo amplifiers 80. Either type of connector can plug into the multimedia port (66;FIG. 2 ), which is a dual-purpose analog/optical digital audio mini-jack. To interface withstereo amplifiers 80, a mini stereo toRCA adapter cable 82 is used, which connects to RCA-type right and left audio input ports on thestereo amplifier 80. Alternatively, a Toslink digital fiber optic cable can be used, which would connect to digital audio input port on thestereo amplifiers 80. These and other configurations are disclosed in incorporated U.S. patent application Ser. No. 10/862,115. - For the purposes of the present disclosure, the
client devices 50 can also be connected tolaptops 70 or personal computers that are capable of playing media (audio, video, etc.) so that the laptops and personal computers can also be considered entertainment devices. Moreover, thelaptops 70 or personal computers can have the same functionality as both aclient device 50 and an entertainment device so that thelaptops 70 and personal computers can be considered both a client device and an entertainment device. Accordingly, the term “client device” as used herein is meant to encompass not only the networked media stations associated withreference numeral 50, but the term “client device” as used herein is also intended to encompass any device (e.g., laptop, personal computer, etc.) compatible with the network media delivery system 10 according to the present disclosure. In the present disclosure, however, reference is made toclient devices 50 for ease in discussion. Furthermore, the term “entertainment device” as used herein is meant to encompass not onlystereo amplifiers 80 as shown inFIG. 1 , but the term “entertainment device” as used herein is also intended to encompass powered speakers, televisions, stereo systems, videocassette recorders, a DVD players, home theatre systems, laptops, personal computers, and other devices known in the art that capable of delivering media. - The
client devices 50 receive media data from thehost device 20 over network connections and output this media data to the entertainment devices. Although it is contemplated that audio, video, audio/video, and/or other forms of multimedia may be used, exemplary embodiments disclosed herein relate to sharing of audio withclient devices 50 connected to entertainment devices, such asstereo amplifiers 80, or withlaptops 70 or other computers having internal speakers or the like. The audio can be stored on thehost device 20 or can be obtained from theInternet 46. However, it will be appreciated that the teachings of the present disclosure can be applied to video, audio/video, and/or other forms of multimedia in addition to the audio in the exemplary embodiments disclosed herein. Furthermore, in the discussion that follows, various details of the network media delivery system are implemented using hardware and software developed by Apple Computer, Inc. Although certain details are somewhat specific to such an implementation, various principles described are also generally applicable to other forms of hardware and/or software. - During operation, the system 10 delivers the same audio in separate locations of an environment (e.g., multiple rooms of a home). The system 10 addresses several issues related to playing the same audio in multiple, separate locations. One issue involves playing the audio in the separate locations in a synchronized manner with each other. Because the
host device 20 and theclient devices 50 have their own processors, memory, and transmission interfaces, sending or streaming audio from thehost device 20 to theclient devices 50 through a wireless or wired communication link will not likely result in synchronized playing of the audio at the separate locations. In addition, theclient device 50 may be connected to different types of entertainment devices, which may have different latency and playback characteristics. It is undesirable to play the same audio in the separate locations out of sync because the listener will hear echoes and other undesirable audio effects. The system 10 addresses this issue by substantially synchronizing the playing of the audio in each location so that echo and other effects can be avoided. It should be noted that the level of precision required to substantially synchronize the playing of media at each location depends on the type of media being played, the perceptions of the user, spatial factors, and other details specific to an implementation. - Another issue related to playing of the same audio involves how to handle lost audio data at the separate locations. To address this issue, the disclosed system 10 preferably uses a retransmission scheme to recover lost audio. These and other issues and additional details of the disclosed network media delivery system are discussed below.
- II. Process of Operating the System
- Referring to
FIG. 3A , aprocess 100 of operating the network media delivery system of the present disclosure is illustrated in flowchart form. During discussion of theprocess 100, reference is concurrently made to components ofFIG. 1 to aid understanding. As an initial step in theprocess 100, network discovery is performed, and thenetworked client devices 50 and other configured devices (e.g., a configured laptop 70) publish or announce their presence on the network using a predefined service type of a transfer control protocol (Block 102). Thehost device 20 browses the local sub-net for the designated service type (Block 104). - The network discovery is used to initiate the interface between the
host device 20 andclient devices 50 and other compatible devices over the network of the system 10. One example of such a network discovery uses Bonjour, which is a technology that enables automatic discovery of computers, devices, and services on IP networks. Bonjour uses standard IP protocols to allow devices to find each other automatically without the need for a user to enter IP addresses or configure DNS servers. Various aspects of Bonjour are generally known to those skilled in the art, and are disclosed in the technology brief entitled “MAC OS X: Bonjour,” dated April 2005, and published by Apple Computer, which is incorporated herein by reference in its entirety. To provide the media sharing functionality between thehost device 20 and theclient devices 50, theclient devices 50 advertise over the network that they support audio streaming and particular audio capabilities (e.g., 44.1 kHz sample rate, 16-bit sample size, and 2-channel/stereo samples). Theclient devices 50 may also advertise security, encryption, compression, and other capabilities and/or parameters that are necessary for communicating with theclient devices 50. - When
complaint client devices 50 are discovered, the addresses and port numbers of the discovereddevices 50 are stored for use by the system 10. Then, themedia application 22 displays information about the foundclient devices 50 in a user interface operating on the host device 20 (Block 106). In one embodiment, for example, themedia application 22 discovers the client devices by obtaining information of the user's step up of computers and networks for their house, office, or the like from another application containing such information. In another embodiment, for example, themedia application 22 discovers theclient devices 50 and recognizes theseclient devices 50 as potential destinations for audio data. Then, themedia application 22 automatically provides these recognizeddevices 50 as part of a selectable destination for audio playback in a user interface. -
FIG. 4 shows an example of auser interface 200 associated with the media application, such as iTunes. Among other elements, theuser interface 200 shows anicon 202 for selecting playback locations (e.g., networked client devices and other playback devices located in a house), which have detected on the network. A user may select theicon 202 to access a pop-upmenu 204 in which the user can activate/deactivate (i.e., check or uncheck) one or more of the playback locations as destinations for audio playback. Of course, theuser interface 200 can display possible destinations for audio playback in a number of ways. For example, the display of possible destination can include a network schematic of the user's dwelling, office, or the like, that shows possible destination, or the display can be customized by the user. - Returning to
FIG. 3A , the user selects one or more of the client devices to be used for playback in the user interface (Block 108). Thehost device 20 then uses Real-Time Streaming Protocol (RTSP) to set up and control the audio stream, and thehost device 20 initiates an RTSP connection to each of the selectedclient devices 50 to determine which set of features thedevices 50 support and to authenticate the user (if a password is required) (Block 110). On thehost device 20, the user can then start playback using the user interface of the media application 22 (Block 112). Thehost device 20 makes an RTSP connection to eachclient device 50 to set it up for playback and to start sending the audio stream (Block 114). Thehost device 20 then sends a command to eachclient device 50 to initiate playback (Block 116). When eachclient device 50 receives the command, thedevice 50 negotiates timing information via User Datagram Protocol (UDP) packet exchanges with the host device 20 (Block 118). Eachclient device 50 then determines whether the timing negotiation either succeeds or fails (Block 119). Theclient devices 50 do not respond to the command to initiate playback until the timing negotiation either succeeds or fails. The timing negotiation occurs early to guarantee that theclient devices 50 have the initial timing information needed to synchronize their clocks with thehost device 20 before any audio packets are processed by theclient devices 50. ¶If the negotiation succeeds, theclient device 50 can be used for playback (Block 120). If the negotiation fails, however, the associatedclient device 50 can perform a number of possible operations (Block 121). For example, theclient device 50 can return an error to thehost device 20 in response to the command, and the session on thisdevice 50 can be terminated. In another possible operation, the associatedclient device 50 can retry to negotiate the timing information. Alternatively, the associatedclient device 50 can ignore the fact that negotiating timing information has failed. This may be suitable when the user is not interested in the audio playing in synchronized manner in the multiple locations associated with theclient devices 50. For example, the client device may be located by the pool or out in the garage and does not necessarily need to deliver the audio in synch with the other devices. - During playback at
Block 120, thehost device 20 sends audio data to theclient devices 50, which process the audio data and deliver processed audio to the connected entertainment devices. An example of the process of playing back audio is discussed below with reference to the flowchart ofFIG. 3B with concurrent reference to element numerals ofFIG. 1 . Various buffering, error checking, and other data transfer steps have been omitted from the general description ofFIG. 3B . - As discussed above, the
host device 20 is connected to a wireless network established by theaccess point 30, which can also provide for a shared connection to the Internet orother network 46. Theclient devices 50 are also connected to the wireless network and have their multimedia ports connected tostereo amplifiers 80 or other entertainment device having output speakers or other multimedia output capability. A digital media file (e.g., a song in ACC format) is stored on thehost device 20. Once playback is started (Block 122), thehost device 20 transcodes a portion of the media file from the format (e.g., AAC) in which it is stored to a format that is understood by client device 50 (Block 124). This transcoding step is not necessarily required if the file is stored on thehost device 20 in a format that is understood by theclient device 50. In any case, a block of audio data for transmission is created (Block 126). This audio data is preferably compressed and encrypted (Block 128). Encryption is not necessarily required, but it is advantageous for digital rights management purposes. - The
host device 20 then transmits the audio data over the wireless network to the client devices 50 (Block 130). Theclient devices 50 decrypt and decompress the received audio data (Block 132), and theclient devices 50 decode the audio data based on the encoding performed in Block 124 (Block 134). The decoding results in raw audio data, which may be, for example, in the form of PCM data. This data is converted to analog audio signals by digital-to-audio converters (DAC) (Block 136), and the audio signals are output to thestereo amplifiers 80 for playing with their loudspeakers (Block 138). - With the benefit of the description of the components of the disclosed network media delivery system and its process of operation provided in
FIGS. 1 through 4 , the discussion now turns to details related to how data is transferred between the host device and client devices, how lost data is handled, and how playback is synchronized, in addition to other details disclosed herein. - III. Network Transport Used for the System
- To transfer audio data and other information, the network media delivery system 10 of the present disclosure preferably uses User Datagram Protocol (UDP) as its underlying transport for media data. UDP is beneficial for synchronized playback to the
multiple client devices 50 because synchronized playback places time constraints on the network protocol. Because audio is extremely time sensitive and has a definite lifetime of usefulness, for example, a packet of media data, such as audio, can become useless if it is received after a point in time when it should have been presented. Accordingly, UDP is preferred because it provides more flexibility with respect to the time sensitive nature of audio data and other media data. - To use UDP or some similar protocol, the disclosed system is preferably configured to handle at least a small percentage of lost packets. The lost packets can be recovered using Forward Error Correction (FEC), can be hidden using loss concealment techniques (e.g. repetition, waveform substitution, etc.), or can be recovered via retransmission techniques, such as those disclosed herein. Although UDP is preferred for the reasons set forth herein, Transmission Control Protocol (TCP) can be used. Depending on the implementation, retransmission using TCP may need to address problems with blocking of transmissions. If a TCP segment is lost and a subsequent TCP segment arrives out of order, for example, it is possible that the subsequent segment is held off until the first segment is retransmitted and arrives at the receiver. This can result in a chain reaction and effective audio loss because data that has arrived successfully and in time for playback may not be delivered until it is too late. Due to some of the retransmission difficulties associated with TCP, the Partial Reliability extension of Stream Control Transmission Protocol (SCTP) can provide the retransmission functionality. Details related to the Partial Reliability of SCTP are disclosed in RFC 3758, which can be obtained from http://www.ieff.org/rfc/rfc3758.txt, which is incorporated herein by reference.
- UDP is preferred for time critical portions of the protocol because it can avoid some of the problems associated with blockage of transmission. For example, UDP allows the host's
media application 22 to control retransmission of lost data because themedia application 22 can track time constraints associated with pieces of audio data to be delivered. Based on the known time constraints, themedia application 22 can then decide whether retransmission of lost packets of audio data would be beneficial or futile. All the same, in other embodiments, time critical portions of the disclosed system, such as time syncing, can be implemented using UDP, and audio data delivery can use TCP with a buffering system that addresses blocking problems associated with TCP. - IV. Audio Streaming and Playback with System
- Before discussing how the client devices negotiate timing information in order to play audio in synchronization, the discussion first addresses how the disclosed system streams audio for playback. Referring to
FIG. 5A , a portion of the disclosedsystem 300 is shown with a host device 320 and at least twoclient devices 350A-B. Each of theclient devices 350 has aprocessor 352, amemory 354, atransmission interface 356, and anaudio interface 358. Theclient devices 350 also include a UDP stack and can include a TCP stack depending on the implementation. As noted previously with reference to the client device ofFIG. 2 , the transmission interfaces 356 can be a Wi-Fi-compatible wireless network interface, and theaudio interface 358 can provide an analog and/or an optical digital output. Theprocessor 352 andmemory 354 can be conventional hardware components known in the art. Thememory 354 has twoaudio buffers FIG. 5A , each of theclient devices 350 has a local clock, a playback engine, and other features. - The host device 320 uses several commands to set up a connection with and to control operation of the
client devices 350. These commands include ANNOUNCE (used for identification of active client devices), SETUP (used to setup connection and operation), RECORD (used to initiate playback at client devices), PAUSE (used to pause playback), FLUSH (used to flush memory at the client devices), TEARDOWN (used to stop playback), OPTIONS (used to configure options), GET_PARAMETER (used to get parameters from the client devices), and SET_PARAMETER (used to set parameters at the client devices). - Preferably, the
client devices 350 are authenticated when initially establishing a connection to the media application 322 running on the host device 320. Upon successful authentication, the media application 322 opens network connections to thetransmission interface 356 of theclient devices 350. Preferably, network connections between the host device 320 and theclient devices 350 are separated into an audio channel for sending audio data and a control channel used to set up connection and operation between thedevices 320 and 350. However, a single channel could be used for data and control information. Once the connections are established, the host device 320 begins sending data to theclient devices 350. In turn, theclient devices 350 receive the audio data, buffer some portion of the data, and begin playing back the audio data once the buffer has reached a predetermined capacity. - Communication between the host device 320 and the
client devices 350 preferably uses the Real Time Streaming Protocol (RTSP) standard. The media application 322 at the host device 320 preferably uses Real-Time Transport Protocol (RTP) encapsulated in User Datagram Protocol (UDP)packets 330 to deliver audio data from the host device 320 to theclient devices 350. RTSP, RTP, and UDP are standards known to those skilled in the art. Therefore, some implementation details are not discussed here. Details of RTSP can be found in “Real-Time Streaming Protocol,” RFC 2326, which is available from http://www.ietf.org/rfc/rfc2326.txt and which is hereby incorporated by reference in its entirety. Details of RTP can be found in “Real-Time Transport Protocol,” RFC 3550, which is available from http://www.ietf.org/rfc/rfc3550.txt and which is hereby incorporated by reference in its entirety. - The
packets 330 have RTP headers and include both sequence numbers and timestamps. The data payload of theRTP packets 330 contains the audio data to be played back by theclient devices 350. The media files, from which thepackets 330 are derived, can be stored on host device 320 in one or more formats, including, for example, MP3 (Motion Picture Expert's Group Layer 3), AAC (Advanced Audio Coding a/k/a MPEG-4 audio), WMA (Windows Media Audio), etc. Preferably, the media application 322 running on the host device 320 decodes these various audio formats to construct thepackets 330 so that theclient devices 350 do not need decoders for multiple formats. This also reduces the hardware performance requirements of theclient devices 350. Another advantage of performing decoding on the host device 320 is that various effects may be applied to the audio stream, for example, cross fading between tracks, volume control, equalization, and/or other audio effects. Many of these effects would be difficult or impossible to apply if theclient device 350 were to apply them, for example, because of the computational resources required. Although not preferred in the present embodiment, other embodiments of the present disclosure can allow for decoding at theclient devices 350 for audio and other forms of media. - The host device 320 preferably uses a separate
unicast stream 310A-B ofRTP packets 330 for each of theclient devices 350A-B. In the present embodiment, the separateunicast streams 310A-B are intended to deliver the same media information (e.g., audio) to each of theclient devices 350A-B so that the same media can be presented at the same time frommultiple client devices 350A-B. In another embodiment, each of the separateunicast streams 310A-B can be used to deliver separate media information (e.g., audio) to each of theclient devices 350A-B. The user may wish to unicast separate media information in some situations, for example, if a first destination of a first unicast stream of audio is a client device in a game room of a house and a second destination of a second unicast stream of different audio is a client device in the garage of the house. Therefore, it may be preferred in some situations to enable to the user to not only select sending the same media information by unicast streams to multiple client devices by to also allow the user to send different media information by separate unicast streams to multiple client devices. Theuser interface 200 ofFIG. 4 can include a drop down menu or other way for the user to make such a related selection. - Separate unicast streams 310 are preferred because multicasting over wireless networks can produce high loss rates and can be generally unreliable. All the same, the disclosed
system 300 can use multicasting over the wireless network. In general, though, bandwidth limitations (i.e. fixed multicast rate), negative effects on unicast performance (low-rate multicast slows down other unicast traffic due to multicast packets taking longer), and loss characteristics associated with multicasting over wireless (multicast packets are not acknowledged at the wireless layer) make multicasting less desirable than using multiple,unicast streams 310A-B as preferred. Use of multiple,unicast streams 310A-B does correspond to an increase in bandwidth asadditional client devices 350 are added to a group of designated locations for playback. If the average compression rate for audio data is about 75%, the increase in bandwidth associated with multiple,unicast streams 310A-B may correspond to about 1 Mbit/sec bandwidth required for eachclient device 350 so that the host device 320 can send compressed audio data to the access point (e.g., 30;FIG. 1 ) and another 1 Mbit/sec so that the access point can forward the compressed audio data to theclient device 350. - Once an RTSP session has been started and the RECORD command has been sent from the host device 320 to the
client devices 350, the host device 320 begins sendingnormal RTP packets 330 containing the audio data for playback. TheseRTP packets 330 are sent at regular intervals, based on the number of samples per second, which can be about 44,100 Hz for audio. TheRTP packets 330 are sent at the regular intervals in a throttled and evenly spaced manner in order to approximate the audio playback rate of theremote client devices 350 because the UDP-based connection does not automatically control the sending of data in relation to the rate at which that data is consumed on theremote client devices 350. - Because each of the
multiple client devices 350 has their ownaudio buffers packets 330. Accordingly, the host device 320 sends audio data at a rate that preferably does not significantly under-run or over-run aplayback engine 353 of any of theremote client devices 350. To accomplish this, the host device 320 estimates afixed delay 340 to insert betweenpackets 330 to maintain the desired audio playback rate. In one embodiment, thepackets 330 of audio data are sent with a delay of about 7.982-ms between packets 330 (i.e., 352 samples per packet/44,100 Hz=˜7.982-ms per packet), which corresponds to a rate of about 125 packets/sec. Because thedelay 340 is fixed, each of theclient devices 350 can also detect any skew between its clock and the clock of the sending host device 320. Then, based on the detected skew, eachclient device 350 can insert simulated audio samples or remove audio samples in the audio it plays back in order to compensate for that skew. - As alluded to above, the
RTP packets 330 have timestamps and sequence numbers. When anRTP packet 330 is received by aclient device 350, theclient device 350 decrypts and decompresses the payload (see Encryption and Compression section below), then inserts the packet 320, sorted by its timestamp, into a packet queue. The twoaudio buffers audio buffer - To process the queued packets, the
engine 353 assembles the queued RTP packets in one of theaudio buffers engine 353 calculates when each of queued RTP packets should be inserted into the audio stream. The RTP timestamp in the packets combined with time sync information (see the Time Synchronization section below) is used to determine when to insert the packets. Theengine 353 performs this assembly process and runs through the queued packets to fill theinactive audio buffer audio buffer audio buffers client device 350 has a little less than 250-ms to assemble all the RTP packets, conceal any losses, and compensate for any clock skew. If there are any gaps in the audio (e.g., the device's audio clock is skewed from the host's audio clock, a packet was lost and not recovered, etc.), then those gaps can be concealed by inserting simulated audio samples or removing existing audio samples. - V. Encryption and Compression
- For digital rights management purposes, it is desirable to determine whether the
client devices 350 are authorized to receive an audio data stream and/or whether the communications links between the host device 320 and theclient devices 350 are secure (encrypted). This requires some form of authentication, which is preferably based on a public key/private key system. In one embodiment, eachclient station 350 is provided with a plurality of private keys embedded in read only memory (ROM). The media application at the host device 320 is then provided with a corresponding plurality of public keys. This allows identification data transmitted from thenetworked client devices 350 to the media application to be digitally signed by theclient device 350 using its private key, by which it can be authenticated by the media application at the host device 320 using the appropriate public key. Similarly, data sent from the media application at the host device 320 to thenetworked client stations 350 is encrypted using a public key so that only aclient device 350 using the corresponding private key can decrypt the data. The media software and networked media station can determine which of their respective pluralities of keys to use based on the exchange of a key index, telling them which of their respective keys to use without the necessity of transmitting entire keys. - In addition to encryption, the decoded audio data is preferably compressed by host device 320 before transmission to the
client devices 350. This compression is most preferably accomplished using a lossless compression algorithm to provide maximum audio fidelity. One suitable compressor is the Apple Lossless Encoder, which is available in conjunction with Apple's iTunes software. Theclient devices 350 require a decoder for the compression codec used. - The
RTP packets 330 are preferably compressed using the Apple Lossless algorithm and are preferably encrypted using the Advanced Encryption Standard (AES) with a 128-bit key size. Loss is still inevitable even though thesystem 300 uses a UDP-based protocol that attempts to recover from packet loss via retransmission and/or Forward Error Correction (FEC). For this reason, encryption and compression preferably operate on a per-packet basis. In this way, eachpacket 330 can be completely decoded entirely on its own, without the need for any surroundingpackets 330. The Apple Lossless algorithm is used to compress eachindividual packet 330 rather than compressing a larger stream of audio and packetizing the compressed stream. Although compressing eachindividual packet 330 may reduce the effectiveness of the compression algorithm, the methodology simplifies operation for theclient devices 350 and allows them to be more tolerant to packet loss. Although compression rates are highly dependent on the content, music audio can have an average compression rate of about 75% of the original size when used by the disclosedsystem 300. - The AES-128 algorithm is used in frame-based cipher block chaining (CBC) mode to encrypt payloads of the
RTP packets 330 and the RTP payload portion of RTCP retransmission packets (380;FIG. 5B ) discussed below. Because eachpacket 330 represents a single audio frame, no other packets are required to decrypt each packet correctly. The system preferably supports any combination of encryption and compression, such as both encryption and compression, encryption only, compression only, or neither encryption nor compression. Encryption and compression are configured during the RTSP ANNOUNCE command. The format used to configure encryption and compression is based on the Session Description Protocol (SDP) and embedded as RTSP header fields. Compression uses an SDP “m” (media description) combined with an “rtpmap” and “fmtp” to specify the media formats being used numerically and how those numbers map to actual compression formats and algorithms. - VI. Retransmission of Lost Packets of Audio Data
- As noted above, the
RTP packets 330 received from the host device 320 have RTP sequence numbers. Based on those RTP sequence numbers, theclient device 350 can determine whetherpackets 330 that have been lost during transmission or for other reasons. The lostRTP packets 330 cannot be queued for playback in theaudio buffers client devices 350 so that gaps will result in the audio. To address this issue, theclient devices 350 requests that the lost packet(s) be retransmitted. Referring toFIG. 5B , portion of the disclosedsystem 300 is shown again to discuss how thesystem 300 attempts to retransmit packets lost during original transmission. - To handle retransmissions, the
system 300 preferably uses Real-Time Transport Control Protocol (RTCP) when packet loss is detected. As note above, the sequence numbers associated with the received RTP packets (330;FIG. 5A ) are used to determine if any packets have been lost in the transmission. If there is a gap in the sequence numbers, theclient device 350 sends aretransmission request 370 to the sender (e.g., host device 320 or other linked client device 350) requesting all the missing packets. In one embodiment, theretransmission request 370 can request up to a maximum of 128 lost packets per detected gap. - In response to the
retransmission request 370, the host device 320 sends one ormore retransmission responses 380 for lost packets. Due to limitations of the maximum transmission unit (MTU) on RTCP packet sizes, only one response can be sent perretransmission response packet 380. This means that a singleretransmission request packet 370 from adevice 350 may generate up to 128retransmission response packets 380 from the host device 320 if all of the lost packets are found in the host's recently sent packets. - Because RTP does not currently define a standard packet to be used for retransmissions, an RTP extension for an RTCP Retransmission Request packet is preferably defined.
FIG. 6A shows an example of an RTCPRetransmit Request Packet 370 for use with the disclosed system. The Sequence Number Base refers to the sequence number of the first (lost) packet requested by this RTCPRetransmit Request Packet 370. The Sequence Number Count refers to the number of (lost) packets to retransmit, starting at the base indicated. - In
FIG. 5A , theclient device 350 sending the RTCPRetransmission Request packet 370 tracks the retransmission requests that it sends in a queue to facilitate sending additional requests if a response to theretransmission request 370 is not received in a timely manner. When aretransmission request 370 has not been responded to in a timely manner, anotherretransmission request 370 is sent from theclient device 350. The process of retrying can be continued until a maximum time has elapsed since thefirst retransmission request 370 was sent. After that maximum time, it is likely too late to deal with the lost packet anyway because the lost packets time for insertion in one of theaudio buffers - When multiple, contiguous packets have been lost, the
initial retransmit request 370 includes all the missing packets. However, if aresponse 380 is not received in a timely manner, the missing packets are spread out amongmultiple requests 370 over time when reattempts are made. Spreading out among multiple requests can maintain a uniform delivery of request and response packets. This also prioritizes packets by time and defers delivery of packets whose presentation time is later. - When the host device 320 receives a
retransmission request 370, the host device 320 searches a list of recently sent packets stored at the device 320. If the requested packet in therequest 370 is found, the host device 320 sends aretransmission response 380 to theclient device 350. An example of an RTP extension for an RTCPRetransmit Response Packet 380 is shown inFIG. 6B . The RTCPRetransmit Response Packet 380 includes the complete RTP packet (e.g., header and payload) being retransmitted. Theretransmission packet 380, however, is only sent to the sender of theretransmission request 370, unlike the normal RTP packets (330;FIG. 5A ) that are sent to all devices participating in the session. - If the requested packet is not found by the host device 320, however, a
negative response 390 is sent so thecorresponding client device 350 knows that any further attempt to request that particular packet is futile. An example of an RTP extension for an RTCP FutileRetransmit Response Packet 390 is shown inFIG. 6C . The RTCP FutileRetransmit Response Packet 390 includes the 16-bit sequence number of the failed packet followed by a 16-bit pad containing zero. - In
FIG. 5B , theclient device 350 receiving aretransmission response packet 380 inserts thepacket 380 into the packet queue in the same way used for inserting packets received as part of the normal RTP packet stream discussed above with reference toFIG. 5A . By definition, however, theretransmission response packet 380 is already out-of-sequence and, therefore, does not trigger new retransmission requests based on its sequence number. If an existing packet already exists at the same timestamp as the incoming packet, either via the normal RTP stream or via retransmission, the packet is dropped as a duplicate. - Scheduling retransmission is based on regular reception of RTP packets (330;
FIG. 5A ) rather than explicit timers. This simplifies the code required and reduces retransmission overhead, but it also throttles retransmission during burst outages (e.g. wireless interference resulting in packet loss during a period). Since retransmissions only occur whenRTP packets 330 are received, retransmissions are deferred beyond a possible window whenpackets 330 may have been lost anyway. - VII. Controlling Relative Volume at Multiple Client Devices During Playback
- Because the disclosed
system 330 plays music at multiple locations at the same time, it may be desirable to be able to adjust the volume at each location individually. The disclosedsystem 300 supports individual volume control by using a relative volume setting specified using a header field as part of an RTSP SET_PARAMETER request. The volume is expressed as a floating-point decibel level (e.g. 0 dB for full volume). In addition to volume, the disclosedsystem 330 can set other parameters related to the delivery of media at multiple locations using similar techniques. For example, the disclosedsystem 300 can be used to set equalization levels at each location individually. - VII. Time Synchronization Between Host Device and Multiple Client Devices
- Referring to
FIG. 7 ,portion 300 of the disclosed system is shown having a host device 320 andmultiple client devices 350 exchanging timing information. To play the same audio on themultiple client devices 350 in synchronization with each other, the timebase on themultiple client devices 350 is synchronized with areference clock 324 on the host device 320. As noted previously, the host device 320 can be a Mac or Windows-based system running the media application 322. The host device 320 does not need to run any special server software, and only the media application 322 according to the present disclosure is required. Thereference clock 324 at the host device 320 does not need to be synchronized with an external clock, such provided by an NTP server. Rather, theclient devices 350 only need to be synchronized to thesame reference clock 324 even if thatclock 324 is wrong with respect to an external clock. - The
reference clock 324 is maintained within the media application 322 running on the host device 320. If the host device 320 is a Macintosh computer, then thereference clock 324 can use the PowerPC timebase registers. If the host device 320 is a Windows-based computer, thereference clock 324 can use the Pentium performance counter registers. Thereference clock 324 of the host's media application 322 is separate from the normal wall-clock time of the host device 320, which is maintained by an NTP agent and synchronized to an external clock. Thereference clock 324 of the host's media application 322 does not need to be synchronized to an external clock and in some cases this would actually be undesirable. For example, a time difference between thereference clock 324 and the local clock of aclient device 350 can be explicitly skewed or adjusted to account for spatial effects or differences, such at theclient device 350 being located farther away than another. In addition, there may be situations where a user may want to intentionally skew the clocks to produce effects. Accordingly, the user interface associated with the disclosedsystem 300, such asinterface 200 ofFIG. 4 , may include a drop-down menu or other control for intentionally manipulating skew. - To synchronize the timebase between the
client devices 350 and the host device 320, the media application 322 uses time sync information based on the principals of the Network Time Protocol (NTP) encapsulated in Real-Time Transport Control Protocol (RTCP) packets. Preferably, NTP is not used directly to avoid collisions with existing NTP services (e.g., date/time synchronization with an external clock) and to avoid permission issues due to NTP's use of a privileged port number. Even though the time sync information of the media application 322 is encapsulated in RTCP packets, the time synchronization works substantially the same as NTP and will be referred to as NTP henceforth. NTP is known in the art and provides the basis for inter-media synchronization support in the Real-Time Transport Protocol (RTP). Details of NTP can be found in “Network Time Protocol,” RFC 1305, which is available from http://www.ietf.org/rfc/rfc1305.txt and is incorporated herein by reference in its entirety. - Techniques of NTP, however, are preferably not used to provide moment-to-moment time directly to each
client device 350 due to issues related to network latency, bandwidth consumption, and CPU resources. Accordingly, techniques of NTP are used for periodic synchronization of time. In addition, eachclient device 350 is provided with a high-resolution clock 364 based on the local clock hardware of each client device 350 (see Local Clock Implementation section below), the high-resolution clocks 364 are synchronized with thereference clock 324 of the host device 320 using the NTP techniques. - Synchronizing the
local clocks 364 of theclient devices 350 with thereference clock 324 preferably does not jump to a new time with every correction (referred to as stepping) because stepping can introduce discontinuities in time and can cause time to appear to go backward, which can create havoc on processing code that relies on time. Instead, the time synchronization techniques of the present disclosure preferably correct time smoothly using clock slewing so that time advances in a linear and monotonically increasing manner. In the clock slewing techniques of the present disclosure, frequent micro-corrections, below a tolerance threshold, are performed to the runningclocks 364 at theclient devices 350 to bring their timebase gradually in sync with the timebase of thereference clock 324 of the host's media application 322. The clock slewing techniques also predict the relative clock skew between thelocal clocks 364 and the host'sreference clock 324 by analyzing past history of clock offsets and disciplining thelocal clocks 364 to run at the same rate as the host'sreference clock 324. - Because a
centralized reference clock 324 is used forseveral client devices 350 on a local network, one way to disseminate time information is to send broadcast/multicast NTP packets periodically from the host device 320 to theclient devices 350. Sending NTP packets by multicasting must account for losses and performance degradation that may result from the wireless 802.11b and 802.11g communication links between the host device 320 and theclient devices 350. Due to issues of performance degradation, loss rates, and lack of propagation delay information associated with broadcasting or multicasting,unicast NTP transactions 400 are preferably used. - As part of the
unicast NTP transactions 400, theclient devices 350 periodically send unicast requests 410 to the host device 320 so that theclient devices 350 can synchronize theirclocks 364 with thereference clock 324. Then, theclient devices 350use responses 420 from the host device 320 corresponding to their requests 410 to continually track the clock offset and propagation delay between theclient device 350 and host device 320 so theclient devices 350 can update theirlocal clocks 364. Thus, synchronization of the audio playback at theclient devices 350 is achieved by maintaininglocal clocks 364 that are synchronized to the host device'sclock 324. Since all client devices participating in a particular session are synchronized to thereference clock 324. When theclocks client devices 350 can play audio in-sync without ever communicating with each other. - With the timebase at the
client devices 350 synchronized with thereference clock 324 at the host device 320, theclient devices 350 can use the synchronized timebase to determine when to playback packets of audio data. As noted previously, audio data is delivered to theclient devices 350 using RTP packets (330;FIG. 5A ) that contain an RTP timestamp describing the time of a packet's audio relative to other packets in the audio stream. Theclient device 350 uses this timestamp information to reconstruct audio at the correct presentation time for playback. Accordingly, eachclient device 350 correlates the NTP timebase of itslocal clock 364 with the RTP timestamps provided in the RTP packets of the audio stream. - With respect to the unicast requests and
responses 410 and 420 noted above, RTP does not define a standard packet format for synchronizing time. There is an RTCP sender report, which contains some timing information, but not everything that is needed to synchronize time (e.g., there is no originate time for receivers to determine the round trip time). There are also rules preventing sender reports from being sent before any RTP data has been sent, which is critical for playing the initial audio samples in sync. - Therefore, the host's media application 322 preferably defines an RTP extension for an RTCP TimeSync packet for the requests and
responses 410 and 420. An embodiment of anRTCP TimeSync packet 430 is shown inFIG. 8A . TheRTCP TimeSync Packet 430 includes a header, the RTP timestamp at NTP Transmit (T3) time, NTP Originate (T1) timestamp, most significant word; NTP Originate (T1) timestamp, least significant word; NTP Receive (T2) timestamp, most significant word; NTP Receive (T2) timestamp, least significant word; NTP Transmit (T3) timestamp, most significant word; NTP Transmit (T3) timestamp, least significant word. The Marker bit (M) is not used for theseTimeSync packets 430. The packet types (PT) include ‘210’ for a client device request to synchronize time in a manner similar to an NTP client device request and include ‘211’ for a host device response to a client device request. The ‘RTP Timestamp’ is the RTP timestamp at the same instant as the transmit time (T3). This should be 0. The times T1-T3 come from NTP and are used in the same manner as NTP. - In
FIG. 7 , the RTCP TimeSync request packets 410 from theclient devices 350 are sent once the RTSP RECORD command is received so that theclient devices 350 can initially synchronize time. Then, theclient devices 350 periodically send RTCP TimeSync request packets 410. In one embodiment, the periodic intervals for synchronizing time can be at random intervals between two and three seconds apart. The RTCPTimeSync response packets 420 are sent by the host device 320 in response to receiving a valid RTCP TimeSync request packet 410. - The host's media application 322 also defines an RTP extension for an
RTCP TimeAnnounce packet 450. TheRTCP TimeAnnounce packets 450 are sent periodically (e.g., once a second) by the host device 320 to update theclient devices 350 with the current timing relationship between NTP and RTP. TheRTCP TimeAnnounce packets 450 can be sent sooner if the host device 320 changes the NTP to RTP timing relationship. For example, when a new song starts, the host's media application 322 can send a newRTCP TimeAnnounce packet 450 with the marker bit (M) set to indicate that the NTP to RTP timing relationship has changed. - As shown in the embodiment of
FIG. 8B , theRTCPTimeAnnounce Packet 450 includes an RTP timestamp; an NTP timestamp, high 32 bits; an NTP timestamp, low 32 bits; and an RTP timestamp when the new timeline should be applied. The Marker bit (M) is used to indicate an explicit change in the NTP to RTP timing relationship. The packet type (PT) is defined as ‘212’ to indicate that the host device is announcing a new NTP to RTP relationship. The “RTP Timestamp” is the RTP timestamp at the same instant as the NTP timestamp. The “NTP Timestamp” is the NTP timestamp at the same instant as the RTP timestamp. The field “RTP Apply Timestamp” refers to the RTP timestamp when the new timeline should be applied. - IX. Local Clock Implementation at Host Device
- Returning to
FIG. 7 , thelocal clock 364 of theclient device 350 is discussed in more detail. Thelocal clock 364 maintains a 64-bit nanoseconds counter that starts at zero on system boot and uses the 60-Hz clock interrupt to increment the nanoseconds counter. When an interrupt occurs, the 32-bit timer counter is used to determine how much time has passed since the last clock interrupt. This determined amount of time since the last clock interrupt is referred to as the tick delta and is in units of 1/100 of a microsecond. The tick delta is then converted to nanoseconds and is added to the nanoseconds counter to maintain the current time. The tick delta is used in this manner to avoid drift due to interrupt latency. - To maintain more accurate time, it may be preferable to allow time to be adjusted gradually. Accordingly, the nanoseconds counter is adjusted in very small increments during each clock interrupt to “slew” to the target time. These small increments are chosen based on a fraction of the amount of adjustment needed and based on the tick delta. This prevents time from appearing to go backward so that time always increases in a linear and monotonic manner.
- Additionally, the
client device 350 can predict what the next NTP clock offset will be in the future to further adjust thelocal clock 364. To make the prediction, theclient device 350 uses a moving average of NTP clock offsets to estimate the slope of the clock skew between each ofclient device 350 and host device 320. This slope is then extrapolated to estimate the amount of adjustment necessary to keep thelocal clock 364 at theclient device 350 in sync with thereference clock 324. Theclient device 350 then makes very small adjustments to the per-clock interrupt increment, in addition to the adjustments made for clock slewing, to simulate the faster or slower clock frequency of the host'sreference clock 324. This allows thelocal clock 364 to remain synchronized between NTP update intervals and may even allow thereference clock 324 to remain synchronized in the absence of future NTP clock updates). - X. Simulated Timelines for Audio Playback
- Referring to
FIG. 9 , additional details related to synchronized delivery of media with multiple client devices are discussed. InFIG. 9 , portion of the networkmedia delivery system 300 is again illustrated. The host device 320 is schematically shown having the media application 322 andreference clock 324, as described previously. In addition, the host device 320 is schematically shown having anengine 323, aprocessor 325, atransmission interface 326, and anaudio interface 327. As disclosed herein, the host device 320 can be a computer. Therefore, theprocessor 325 can be a conventional computer processor, thetransmission interface 326 can be a Wi-Fi compatible wireless network interface, and theaudio interface 327 can be a sound card or the like for playing audio. In addition, the media application 322 can be a software program stored in memory on the computer and operating on thecomputer processor 325. Furthermore, the media application 322 can include theengine 324 for processing media (e.g., audio) data and can include thereference clock 324 for synchronizing time. - To play audio in a synchronized manner on multiple client devices 350 (only one of which is shown in
FIG. 9 ), audio data needs to be scheduled for playback at a constant or consistent rate. One way to achieve this is for the media application 322 on the host device 320 to sendpackets 330 of audio data at a constant rate and to have the timeline for presenting that audio data with theclient device 350 tied to the send rate of thepackets 330. For example, packets of audio data can be sent about every 7.982-ms (i.e., 352 samples per packet/44,100 Hz=˜7.982-ms per packet, which corresponds to a rate of about 125 packets/sec), and the timeline for presenting that audio can correspond directly to this rate. While this works, the send rate of thepackets 330 and the presentation timeline at theclient device 350 must have a one-to-one correspondence, which can restrict the ability to buffer the audio data at theclient device 350. As discussed herein, buffering of the audio data at theclient devices 350 is desirable for handling lost packets, clock skew, etc. If five seconds of buffering is desired at theclient device 350, there will be a five-second delay between the time when the audio data arrives at the client device and the time when it is actually played. Unfortunately, users can readily perceive such a high level of latency when buffering is used with such a one-to-one correspondence between the packet send rate and the presentation time of the audio. - To provide buffering without this high level of latency, the sending of
packets 330 is preferably decoupled or separated from the timeline for presenting the audio data of thosepackets 330. To achieve this, the media application 322 maintains twosimulated timelines first packet timeline 328 corresponds to whenpackets 330 should be sent, and asecond playback timeline 329 corresponds to when the audio data in thosepackets 330 should be presented or delivered (i.e., played for the user). Theseparate timelines packets 330 to vary as needed so that thesystem 300 can provide buffering without introducing latency. If more buffering is needed, for example, the packet send rate of thefirst packet timeline 328 can be temporarily increased to front-load the buffers inmemory 354 on theclient devices 350 and can be later reduced back to the real-time send rate of thepackets 330. Theseparate timelines - The
second playback timeline 329, which corresponds to when the audio data in thepackets 330 should be presented or delivered, is constructed by the host device 320. Using thereference clock 324 and a desired playback rate of the audio, the host device 320 estimates the number of audio samples that would have played at a given point in time at theclient device 350 to construct theplayback timeline 329. Thissecond playback timeline 329 is then published from the host device 320 to theclient devices 350 as part of thetime announcements 450 sent periodically from the host device 320 to theclient devices 350. As discussed in greater detail previously, theclient device 350 uses theperiodic time announcements 450 to establish and maintain the relationship between the RTP timestamps in theaudio packets 330 and the corresponding NTP presentation time for theaudio packets 330 so that theclient device 350 can deliver the audio in synch with other devices. - By having the send rate of the packets 330 (represented by the packet timeline 328) separate from the presentation time (represented by the playback timeline 329), the
periodic time announcements 450 are not designed to take effect immediately when received by theclient devices 350 since theannouncements 450 may come in advance of when they are effective. As noted previously, however, thetime announcement packets 450 contain an additional RTP timestamp that indicates when the announced time should take effect at theclient device 350. Therefore, atime announcement packet 450 is saved at aclient device 350 once it is received. When audio playback reaches the RTP timestamp of that savedtime announcement packet 450, theclient device 350 applies the time change contained in that savedtime announcement package 450. - To play audio in a synchronized manner on multiple client devices 350 (only one of which is shown in
FIG. 9 ), it is also preferred to consider the amount of latency or delay between the time when the audio data is scheduled to be delivered at thedevice 350 and the time when the audio is actually delivered by the device 350 (and associated entertainment devices). Different types of client devices 350 (and associated entertainment devices) will typically have different latency characteristics. Accordingly, the disclosedsystem 300 preferably provides a way for eachclient device 350 to report its latency characteristics (and that of its associated entertainment device) to the host device 320 so that these latency characteristics can be taken into consideration when determining how to synchronize the playback of media at theclient devices 350. - Determination of the latency characteristics of the
client devices 350 preferably occurs at initial set up of thesystem 300. For example, the media application 322 at the host device 320 sends RTSP SETUP requests 312 to theclient devices 350 at initial set up. Inresponses 314 to the RTSP SETUP requests 312, theclient devices 350 use a header field to report the latency characteristics associated with theclient devices 350. The values of the field are preferably given as the number of RTP timestamp units of latency. For example, aclient device 350 having 250-ms of latency at a 44,100-Hz sample rate would report its audio-latency as 11025 RTP timestamp units. Based on the reported latency characteristics from theclient devices 350, the host's media application 322 determines a maximum latency of allclient devices 350 in the group being used for playback. This maximum latency is then added to theplayback timeline 329. - XI. Synchronized Local Playback at Host Device
- In addition to synchronized playback at
multiple client devices 350, the disclosedsystem 300 allows for synchronized local playback at the host device 320 running the media application 322. For example, the host device 320 can play the same audio to its local speakers (not shown) that is being played by theclient devices 350, and thehost device 350 can have that same audio play in sync with the all theother devices 350. To achieve this, the host device 320 uses many of the same principles as applied to theclient devices 350. Rather than receiving packets of audio data over a wireless network, however, audio data is delivered directly to alocal playback engine 323 of the media application 322. In addition, because local playback on the host device 320 is handled by the media application 322, there is no need for the host device 320 to synchronize time with itsown reference clock 324. - The packets of audio data delivered to the synchronized
local playback engine 323 within the media application 322 are generated before being compressed and encrypted. Since these packets do not leave media application 322, no compression or encryption is necessary. In one embodiment, the host device 320 uses CoreAudio to playback audio. CoreAudio can be used for both Mac-based or Windows-based computers becauseQuickTime 7 provides support for CoreAudio on Windows-based computers. During operation, an output AudioUnit is opened, and a callback is installed. The callback is called when CoreAudio needs audio data to play. When the callback is called, the media application 322 constructs the relevant audio data from the raw packets delivered to it along with the RTP->NTP timing information. Since CoreAudio has different latency characteristics than the latency characteristics associated with theclient devices 350, information is also gathered about the presentation latency associated with the audio stream of CoreAudio. This information is used to delay the CoreAudio audio stream so that it plays in sync with the known latency of the audio streams associated with theclient devices 350. - XII. Stutter Avoidance During Audio Playback
- In addition to the techniques discussed previously for handling lost RTP packets of audio data and for synchronizing clocks between the host device 320 and the
client devices 350, the disclosedsystem 300 preferably limits stuttering in the playback of media. Referring toFIG. 10 , analgorithm 500 for limiting stutter in the playback of media is shown in flowchart form. Thisalgorithm 500 can be performed by the host device of the disclosed system for each of the client devices. Using thealgorithm 500, the disclosed system detects audible “glitches” caused by gaps in the media (e.g., audio). These gaps can be caused by loss of packets, packets arriving too late, changes to the synchronized timeline, large amounts of clock skew, or other reasons. First, the system determines the number of such “glitches” occurring in a period of time for each of the client devices (Block 502). Then, a determination is made whether the number of glitches is greater than a predetermined limit (Block 504). For example, the audio is analyzed over a period of 250-ms to determine whether the 250-ms period is either “glitching” (bad) or “glitch-free” (good). A credit system is used to make this determination. Each time a glitching period is detected, the system takes away a number of credits from a credit score of the client device. The credit score is capped at a minimum value to prevent a long sequence of glitching periods from requiring protracted period of time for the client device to recover, because the intention is to allow the client device to recover quickly as soon as its audio situation clears up. - If the number of credits goes below a predefined threshold at
Block 504, the client device is put on probation (Block 506). When on probation, audio is disabled and silenced, but the client device can still send retransmit requests to the host device as needed to recover lost packets of audio data. The audio is silenced during probation so that the client device will not produce an annoying stutter sound when a significant number of glitching periods are successively delivered in an interval of time. Even though the audio is silenced, retransmits remain enabled so that operation of the client device can improve to a point suitable to resume playback. - If the number of glitches is not greater than the limit at
Block 504, then the client device is set as “glitch free” (Block 505). Each time a “glitch-free” period is detected, for example, a number of credits is added to the credit score for the client device. The number of credits is capped at a maximum value to prevent a long sequence of glitch-free periods from extending the number of glitches required before going into stutter avoidance mode because the intention is to be able to go into stutter avoidance mode quickly so that there is not any significant stutter produced. - For the client device on probation with audio silenced and retransmits enabled, the number of glitches occurring in a predetermined unit of time (e.g., X seconds) is determined (Block 508). The number of glitches is compared to a predetermined limit or threshold (Block 510). If the client device is on probation for the predetermined unit of time (X seconds) and the number of credits reaches an upper threshold at
Block 510, the client devices is placed back into normal playback mode atBlock 505. - If the client device remains on probation for the predetermined unit of time (X seconds) and the number of credits has not reached an upper threshold at
Block 510, then the client device is put in jail (Block 512). When in jail, the audio remains disabled and silenced. However, retransmits are now disabled. In this situation, the client device has not recovered for a significant period of time, and any retransmits may actually be making the situation worse. By disabling retransmits, the recovery time may be improved by reducing congestion on the network. In addition, disabling retransmits may at least reduce the amount of traffic on the network and may allow other client devices to receive packets of audio data more reliably. - If the client device remains in jail for a predetermined unit of time (e.g., Y seconds) at
Block 514, the client device goes on parole to see if its situation has improved (Block 516). When on parole, audio is still disabled and silenced. However, retransmits are re-enabled. The number of glitches occurring in a predetermined unit of time (e.g., Z seconds) is determined (Block 518) and compared to a predetermined limit (Block 520). If the client device is on parole for the predetermined unit of time and the number of credits reaches an upper threshold atBlock 520, then client device returns to normal playback mode atBlock 505 where audio and retransmits are both enabled. If the client device stays on parole for the predetermined unit of time and the number of credits does not reach the upper threshold atBlock 520, however, the client device goes back to jail atBlock 512. - XIII. Handling Address Resolution Protocol
- With reference again to
FIG. 5A , for example, the high volume of data being exchanged by the disclosedsystem 300 can cause Address Resolution Protocol (ARP) requests, which are broadcast, to become lost. This may be the case especially when the ARP requests are wirelessly broadcast. Address Resolution Protocol (ARP) is a network protocol used to map a network layer protocol address to a data link layer hardware address. For example, ARP can be used to resolve an IP address to a corresponding Ethernet address. When ARP requests are lost, ARP entries at the host device 320 can expire and can fail to be renewed during operation of the disclosedsystem 300 so that connections between the host device 320 andclient devices 350 may appear to go down. Because steady, unicast streams 310 ofpackets 330 are being exchanged during operation of the disclosedsystem 300, one solution to this problem is to extend the expiration times of the ARP entries at the host device 320 as long aspackets 330 from the host device 320 are being received by theclient devices 350. By extending the expiration time, the ARP entry for a givenclient device 350 does not time out (as long aspackets 330 are being received by that client device 350), and theclient device 350 does not need to explicitly exchange ARP packets, which may tend to get lost as noted previously, with the host device 320. - In another solution, the
client devices 350 periodically (e.g., once a minute) send unsolicited, unicast ARP request packets (not shown) to the host device 320. These unicast ARP request packets contain source addresses (Internet Protocol (IP) address and the hardware address of the client device 350) and target addresses (IP address and hardware address of the host device 320). The unicast ARP request packets are more reliable than broadcast packets because the unicast packets are acknowledged and retried at a wireless layer. To keep the ARP entries on the host device 320 for theclient devices 350 from expiring, the host device 320 updates its ARP cache when it receives these unicast ARP request packets by refreshing the timeout for the corresponding ARP entries. This prevents the host device 320 from needing to issue a broadcast ARP request when the ARP entry for aclient device 350 expires because the ARP entries effectively never expire as long as theclient devices 350 unicast ARP request packets to the host device 320. - The foregoing description of preferred and other embodiments is not intended to limit or restrict the scope or applicability of the inventive concepts conceived of by the Applicants. In exchange for disclosing the inventive concepts contained herein, the Applicants desire all patent rights afforded by the appended claims. Therefore, it is intended that the appended claims include all modifications and alterations to the full extent that they come within the scope of the following claims or the equivalents thereof.
Claims (64)
Priority Applications (16)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/306,557 US20070110074A1 (en) | 2004-06-04 | 2006-01-02 | System and Method for Synchronizing Media Presentation at Multiple Recipients |
US11/530,855 US20080229335A1 (en) | 2004-06-04 | 2006-09-11 | Network media device |
EP06846592.1A EP1969810B1 (en) | 2006-01-02 | 2006-12-13 | Host and client device for synchronizing media presentation at multiple recipients |
EP10195366.9A EP2290899B1 (en) | 2006-01-02 | 2006-12-13 | System and method for synchronizing media presentation at multiple recipients |
PCT/US2006/062003 WO2007079334A2 (en) | 2006-01-02 | 2006-12-13 | System and method for synchronizing media presentation at multiple recipients |
EP18174801.3A EP3389239B1 (en) | 2006-01-02 | 2006-12-13 | System and method for synchronizing media presentation at multiple recipients |
PCT/US2006/062355 WO2007079360A1 (en) | 2006-01-02 | 2006-12-20 | Network media device |
US11/696,679 US8681822B2 (en) | 2004-06-04 | 2007-04-04 | System and method for synchronizing media presentation at multiple recipients |
US13/175,442 US8443038B2 (en) | 2004-06-04 | 2011-07-01 | Network media device |
US13/869,238 US9448683B2 (en) | 2004-06-04 | 2013-04-24 | Network media device |
US14/167,742 US9729630B2 (en) | 2004-06-04 | 2014-01-29 | System and method for synchronizing media presentation at multiple recipients |
US15/246,011 US9876830B2 (en) | 2004-06-04 | 2016-08-24 | Network media device |
US15/659,603 US10264070B2 (en) | 2004-06-04 | 2017-07-25 | System and method for synchronizing media presentation at multiple recipients |
US15/878,208 US10200430B2 (en) | 2004-06-04 | 2018-01-23 | Network media device |
US16/256,535 US10986148B2 (en) | 2004-06-04 | 2019-01-24 | Network media device |
US16/295,267 US10972536B2 (en) | 2004-06-04 | 2019-03-07 | System and method for synchronizing media presentation at multiple recipients |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/862,115 US8797926B2 (en) | 2004-06-04 | 2004-06-04 | Networked media station |
US11/306,557 US20070110074A1 (en) | 2004-06-04 | 2006-01-02 | System and Method for Synchronizing Media Presentation at Multiple Recipients |
Related Parent Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/862,115 Continuation-In-Part US8797926B2 (en) | 2004-06-04 | 2004-06-04 | Networked media station |
US10/862,115 Continuation US8797926B2 (en) | 2004-06-04 | 2004-06-04 | Networked media station |
Related Child Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/862,115 Continuation-In-Part US8797926B2 (en) | 2004-06-04 | 2004-06-04 | Networked media station |
US11/530,855 Continuation-In-Part US20080229335A1 (en) | 2004-06-04 | 2006-09-11 | Network media device |
US11/696,679 Continuation US8681822B2 (en) | 2004-06-04 | 2007-04-04 | System and method for synchronizing media presentation at multiple recipients |
Publications (1)
Publication Number | Publication Date |
---|---|
US20070110074A1 true US20070110074A1 (en) | 2007-05-17 |
Family
ID=37941555
Family Applications (4)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/306,557 Abandoned US20070110074A1 (en) | 2004-06-04 | 2006-01-02 | System and Method for Synchronizing Media Presentation at Multiple Recipients |
US11/696,679 Active 2028-10-26 US8681822B2 (en) | 2004-06-04 | 2007-04-04 | System and method for synchronizing media presentation at multiple recipients |
US14/167,742 Expired - Lifetime US9729630B2 (en) | 2004-06-04 | 2014-01-29 | System and method for synchronizing media presentation at multiple recipients |
US15/659,603 Expired - Lifetime US10264070B2 (en) | 2004-06-04 | 2017-07-25 | System and method for synchronizing media presentation at multiple recipients |
Family Applications After (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/696,679 Active 2028-10-26 US8681822B2 (en) | 2004-06-04 | 2007-04-04 | System and method for synchronizing media presentation at multiple recipients |
US14/167,742 Expired - Lifetime US9729630B2 (en) | 2004-06-04 | 2014-01-29 | System and method for synchronizing media presentation at multiple recipients |
US15/659,603 Expired - Lifetime US10264070B2 (en) | 2004-06-04 | 2017-07-25 | System and method for synchronizing media presentation at multiple recipients |
Country Status (3)
Country | Link |
---|---|
US (4) | US20070110074A1 (en) |
EP (3) | EP2290899B1 (en) |
WO (1) | WO2007079334A2 (en) |
Cited By (113)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050091190A1 (en) * | 2003-10-24 | 2005-04-28 | Microsoft Corporation | Embedding a session description message in a real-time control protocol (RTCP) message |
US20070204196A1 (en) * | 2006-02-13 | 2007-08-30 | Digital Fountain, Inc. | Streaming and buffering using variable fec overhead and protection periods |
US20080065925A1 (en) * | 2006-09-08 | 2008-03-13 | Oliverio James C | System and methods for synchronizing performances of geographically-disparate performers |
US20080077619A1 (en) * | 2006-09-21 | 2008-03-27 | Apple Inc. | Systems and methods for facilitating group activities |
US20080304364A1 (en) * | 2007-06-08 | 2008-12-11 | Michael Holtzman | Memory device with circuitry for improving accuracy of a time estimate |
US20080307237A1 (en) * | 2007-06-08 | 2008-12-11 | Michael Holtzman | Method for improving accuracy of a time estimate used to authenticate an entity to a memory device |
US20080307508A1 (en) * | 2007-06-08 | 2008-12-11 | Conley Kevin M | Method for using time from a trusted host device |
US20080306710A1 (en) * | 2007-06-08 | 2008-12-11 | Michael Holtzman | Method for improving accuracy of a time estimate from a memory device |
US20090010283A1 (en) * | 2007-07-03 | 2009-01-08 | Arcadyan Technology Corporation | Synchronization method of electronic apparatuses |
US20090041020A1 (en) * | 2007-08-07 | 2009-02-12 | Avaya Technology Llc | Clock management between two endpoints |
US20090067551A1 (en) * | 2007-09-12 | 2009-03-12 | Digital Fountain, Inc. | Generating and communicating source identification information to enable reliable communications |
US20090189792A1 (en) * | 2002-10-05 | 2009-07-30 | Shokrollahi M Amin | Systematic encoding and decoding of chain reaction codes |
US20090245249A1 (en) * | 2005-08-29 | 2009-10-01 | Nec Corporation | Multicast node apparatus, multicast transfer method and program |
US20100024000A1 (en) * | 2007-06-08 | 2010-01-28 | Michael Holtzman | Method for improving accuracy of a time estimate used in digital rights management (DRM) license validation |
US20100100917A1 (en) * | 2008-10-16 | 2010-04-22 | Industrial Technology Research Institute | Mobile tv system and method for synchronizing the rendering of streaming services thereof |
US20100135334A1 (en) * | 2008-07-28 | 2010-06-03 | Harris Corporation, Corporation Of The State Of Delaware | Method, system and apparatus for synchronizing signals |
US20110040976A1 (en) * | 2009-08-17 | 2011-02-17 | Rahav Yairi | Method and Memory Device for Generating a Time Estimate |
US20110138487A1 (en) * | 2009-12-09 | 2011-06-09 | Ehud Cohen | Storage Device and Method for Using a Virtual File in a Public Memory Area to Access a Plurality of Protected Files in a Private Memory Area |
US8001472B2 (en) | 2006-09-21 | 2011-08-16 | Apple Inc. | Systems and methods for providing audio and visual cues via a portable electronic device |
US20120191816A1 (en) * | 2010-10-13 | 2012-07-26 | Sonos Inc. | Method and apparatus for collecting diagnostic information |
US8235724B2 (en) | 2006-09-21 | 2012-08-07 | Apple Inc. | Dynamically adaptive scheduling system |
US20120204237A1 (en) * | 2010-05-20 | 2012-08-09 | Eyal Ittah | Host Device and Method for Accessing a Virtual File in a Storage Device by Bypassing a Cache in the Host Device |
US20120243459A1 (en) * | 2009-12-10 | 2012-09-27 | Zhenyu Wu | Protocol booster for sctp in multicast networks |
US20120284757A1 (en) * | 2011-02-14 | 2012-11-08 | Ravi Rajapakse | Mobile source device media playback over rendering devices at lifestyle-determined locations |
US20120284419A1 (en) * | 2011-05-05 | 2012-11-08 | Manrique Brenes | Processing Media Streams |
US20120290644A1 (en) * | 2010-01-18 | 2012-11-15 | Frederic Gabin | Methods and Arrangements for HTTP Media Stream Distribution |
US20130067124A1 (en) * | 2007-03-26 | 2013-03-14 | Itay Sherman | Small removable audio player that attaches to a host media player |
US20130132603A1 (en) * | 2011-11-21 | 2013-05-23 | Etan GUR COHEN | Hybrid Networking System with Seamless Path Switching of Streams |
WO2014065902A1 (en) * | 2012-10-22 | 2014-05-01 | Arbitron, Inc. | Methods and systems for clock correction and/or synchronization for audio media measurement systems |
US8745496B2 (en) | 2006-09-21 | 2014-06-03 | Apple Inc. | Variable I/O interface for portable media device |
US20140192825A1 (en) * | 2013-01-08 | 2014-07-10 | Tangome, Inc. | Joint retransmission and frame synchronization for error resilience control |
US8806050B2 (en) | 2010-08-10 | 2014-08-12 | Qualcomm Incorporated | Manifest file updates for network streaming of coded multimedia data |
US8887020B2 (en) | 2003-10-06 | 2014-11-11 | Digital Fountain, Inc. | Error-correcting multi-stage code generator and decoder for communication systems having single transmitters or multiple transmitters |
US20140373081A1 (en) * | 2012-09-28 | 2014-12-18 | Sony Computer Entertainment America Llc | Playback synchronization in a group viewing a media title |
US20150030088A1 (en) * | 2013-07-26 | 2015-01-29 | Vixs Systems Inc. | Clock recovery for media stream in bursty network channel |
US8958375B2 (en) | 2011-02-11 | 2015-02-17 | Qualcomm Incorporated | Framing for an improved radio link protocol including FEC |
US8956290B2 (en) | 2006-09-21 | 2015-02-17 | Apple Inc. | Lifestyle companion system |
WO2015048693A1 (en) * | 2013-09-27 | 2015-04-02 | Aliphcom | Multiple data source aggregation for efficient synchronous multi-device media consumption |
US20150120953A1 (en) * | 2013-10-31 | 2015-04-30 | At&T Intellectual Property I, Lp | Synchronizing media presentation at multiple devices |
US9136878B2 (en) | 2004-05-07 | 2015-09-15 | Digital Fountain, Inc. | File download and streaming system |
US9178535B2 (en) | 2006-06-09 | 2015-11-03 | Digital Fountain, Inc. | Dynamic stream interleaving and sub-stream based delivery |
US9191151B2 (en) | 2006-06-09 | 2015-11-17 | Qualcomm Incorporated | Enhanced block-request streaming using cooperative parallel HTTP and forward error correction |
US20150365250A1 (en) * | 2013-01-17 | 2015-12-17 | Zte Corporation | Method of data retransmission in collaborative service transmission and access network gateway thereof |
US9225961B2 (en) | 2010-05-13 | 2015-12-29 | Qualcomm Incorporated | Frame packing for asymmetric stereo video |
US9236976B2 (en) | 2001-12-21 | 2016-01-12 | Digital Fountain, Inc. | Multi stage code generator and decoder for communication systems |
CN105247437A (en) * | 2013-05-31 | 2016-01-13 | 索尼克Ip股份有限公司 | Synchronizing multiple over the top streaming clients |
US9240810B2 (en) | 2002-06-11 | 2016-01-19 | Digital Fountain, Inc. | Systems and processes for decoding chain reaction codes through inactivation |
US9246633B2 (en) | 1998-09-23 | 2016-01-26 | Digital Fountain, Inc. | Information additive code generator and decoder for communication systems |
US9253233B2 (en) | 2011-08-31 | 2016-02-02 | Qualcomm Incorporated | Switch signaling methods providing improved switching between representations for adaptive HTTP streaming |
US9264069B2 (en) | 2006-05-10 | 2016-02-16 | Digital Fountain, Inc. | Code generator and decoder for communications systems operating using hybrid codes to allow for multiple efficient uses of the communications systems |
US9270299B2 (en) | 2011-02-11 | 2016-02-23 | Qualcomm Incorporated | Encoding and decoding using elastic codes with flexible source block mapping |
US9270414B2 (en) | 2006-02-21 | 2016-02-23 | Digital Fountain, Inc. | Multiple-field based code generator and decoder for communications systems |
US9281847B2 (en) | 2009-02-27 | 2016-03-08 | Qualcomm Incorporated | Mobile reception of digital video broadcasting—terrestrial services |
US9288010B2 (en) | 2009-08-19 | 2016-03-15 | Qualcomm Incorporated | Universal file delivery methods for providing unequal error protection and bundled file delivery services |
US9294226B2 (en) | 2012-03-26 | 2016-03-22 | Qualcomm Incorporated | Universal object delivery and template-based file delivery |
US9380355B2 (en) | 2009-02-05 | 2016-06-28 | Digimarc Corporation | Second screens and widgets |
US9380096B2 (en) | 2006-06-09 | 2016-06-28 | Qualcomm Incorporated | Enhanced block-request streaming system for handling low-latency streaming |
US20160188287A1 (en) * | 2014-12-31 | 2016-06-30 | Qualcomm Technologies International, Ltd. | Synchronised control |
US9386064B2 (en) | 2006-06-09 | 2016-07-05 | Qualcomm Incorporated | Enhanced block-request streaming using URL templates and construction rules |
US9419749B2 (en) | 2009-08-19 | 2016-08-16 | Qualcomm Incorporated | Methods and apparatus employing FEC codes with permanent inactivation of symbols for encoding and decoding processes |
US9426196B2 (en) | 2013-01-04 | 2016-08-23 | Qualcomm Incorporated | Live timing for dynamic adaptive streaming over HTTP (DASH) |
US9432433B2 (en) | 2006-06-09 | 2016-08-30 | Qualcomm Incorporated | Enhanced block-request streaming system using signaling or block creation |
WO2016145235A1 (en) * | 2015-03-12 | 2016-09-15 | Startimes Communication Network Technology Co. Ltd. | Location based services audio system |
US9448683B2 (en) | 2004-06-04 | 2016-09-20 | Apple Inc. | Network media device |
WO2016191516A1 (en) * | 2015-05-28 | 2016-12-01 | Bose Corporation | Audio data buffering |
US9549027B2 (en) | 2013-09-27 | 2017-01-17 | Dolby Laboratories Licensing Corporation | Network-synchronized media playback |
US9602802B2 (en) | 2010-07-21 | 2017-03-21 | Qualcomm Incorporated | Providing frame packing type information for video coding |
US9635082B2 (en) | 2011-09-27 | 2017-04-25 | Thomson Licensing | Method of saving content to a file on a server and corresponding device |
US9722943B2 (en) | 2012-12-17 | 2017-08-01 | Qualcomm Incorporated | Seamless switching for multihop hybrid networks |
US9729876B2 (en) | 2012-11-29 | 2017-08-08 | Thomson Licensing | Method for predicting a block of pixels from at least one patch |
US9729630B2 (en) | 2004-06-04 | 2017-08-08 | Apple Inc. | System and method for synchronizing media presentation at multiple recipients |
US20170272190A1 (en) * | 2014-07-25 | 2017-09-21 | Zte Corporation | Time synchronization method and apparatus for network devices and time synchronization server |
US9843844B2 (en) | 2011-10-05 | 2017-12-12 | Qualcomm Incorporated | Network streaming of media data |
US9894505B2 (en) | 2004-06-04 | 2018-02-13 | Apple Inc. | Networked media station |
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 |
WO2018111501A1 (en) | 2016-12-13 | 2018-06-21 | EVA Automation, Inc. | Wireless coordination of audio playback |
US10205981B2 (en) | 2013-05-31 | 2019-02-12 | Divx, Llc | Playback synchronization across playback devices |
CN109743528A (en) * | 2018-12-29 | 2019-05-10 | 广州市保伦电子有限公司 | A kind of audio collection of video conference and play optimization method, device and medium |
US20190349617A1 (en) * | 2007-05-11 | 2019-11-14 | Audinate Pty Limited | Systems, Methods and Computer-Readable Media for Configuring Receiver Latency |
WO2019226760A1 (en) * | 2018-05-24 | 2019-11-28 | Google Llc | Methods, systems, and media for synchronizing audio and video content on multiple media devices |
US10614857B2 (en) | 2018-07-02 | 2020-04-07 | Apple Inc. | Calibrating media playback channels for synchronized presentation |
US10776739B2 (en) | 2014-09-30 | 2020-09-15 | Apple Inc. | Fitness challenge E-awards |
US10783929B2 (en) | 2018-03-30 | 2020-09-22 | Apple Inc. | Managing playback groups |
US10931584B2 (en) * | 2018-08-23 | 2021-02-23 | Hewlett Packard Enterprise Development Lp | Data frame transmission |
US10972536B2 (en) | 2004-06-04 | 2021-04-06 | Apple Inc. | System and method for synchronizing media presentation at multiple recipients |
US10971161B1 (en) * | 2018-12-12 | 2021-04-06 | Amazon Technologies, Inc. | Techniques for loss mitigation of audio streams |
US10993274B2 (en) | 2018-03-30 | 2021-04-27 | Apple Inc. | Pairing devices by proxy |
US11016792B1 (en) | 2019-03-07 | 2021-05-25 | Amazon Technologies, Inc. | Remote seamless windows |
US11025982B2 (en) * | 2019-03-29 | 2021-06-01 | Twizted Design, Inc. | System and method for synchronizing content and data for customized display |
US11050701B2 (en) | 2012-11-14 | 2021-06-29 | Google Llc | System and method of embedding rich media into text messages |
SE2030143A1 (en) * | 2020-04-28 | 2021-10-29 | Stig Halvarsson | SYSTEM, DEVICE AND A METHOD FOR PROVIDING AN IMPROVED WiFiTM AUDIO SYSTEM |
US11165752B1 (en) * | 2017-06-13 | 2021-11-02 | Parallels International Gmbh | System and method for recovery of data packets transmitted over an unreliable network |
US11169756B2 (en) | 2000-11-20 | 2021-11-09 | Flexijet Technologies, Inc. | Method for capturing, storing, accessing, and outputting digital content |
US11194542B2 (en) | 2016-12-13 | 2021-12-07 | B&W Group Ltd. | Wireless coordination of audio sources |
US11204729B2 (en) | 2000-11-01 | 2021-12-21 | Flexiworld Technologies, Inc. | Internet based digital content services for pervasively providing protected digital content to smart devices based on having subscribed to the digital content service |
US11245772B1 (en) | 2019-03-29 | 2022-02-08 | Amazon Technologies, Inc. | Dynamic representation of remote computing environment |
US11252097B2 (en) | 2018-12-13 | 2022-02-15 | Amazon Technologies, Inc. | Continuous calibration of network metrics |
US11259192B2 (en) * | 2017-09-29 | 2022-02-22 | Apple Inc. | Ultra-low latency audio over bluetooth |
US11297369B2 (en) | 2018-03-30 | 2022-04-05 | Apple Inc. | Remotely controlling playback devices |
US11330341B1 (en) * | 2016-07-05 | 2022-05-10 | BoxCast, LLC | System, method, and protocol for transmission of video and audio data |
US11336954B1 (en) | 2018-12-12 | 2022-05-17 | Amazon Technologies, Inc. | Method to determine the FPS on a client without instrumenting rendering layer |
US11356326B2 (en) | 2018-12-13 | 2022-06-07 | Amazon Technologies, Inc. | Continuously calibrated network system |
US11368400B2 (en) | 2018-12-13 | 2022-06-21 | Amazon Technologies, Inc. | Continuously calibrated network system |
US20220229631A1 (en) * | 2003-07-28 | 2022-07-21 | Sonos, Inc | Synchronizing Playback by Media Playback Devices |
US11461168B1 (en) | 2019-03-29 | 2022-10-04 | Amazon Technologies, Inc. | Data loss protection with continuity |
US11467799B2 (en) | 2004-04-01 | 2022-10-11 | Sonos, Inc. | Guest access to a media playback system |
EP4027600A4 (en) * | 2019-09-29 | 2022-11-02 | Inspur Suzhou Intelligent Technology Co., Ltd. | Communication method, system and device and computer-readable storage medium |
US11550536B2 (en) | 2003-07-28 | 2023-01-10 | Sonos, Inc. | Adjusting volume levels |
WO2023056392A1 (en) * | 2021-10-01 | 2023-04-06 | Bytedance Inc. | Method, apparatus, and medium for video processing |
US11625221B2 (en) * | 2003-07-28 | 2023-04-11 | Sonos, Inc | Synchronizing playback by media playback devices |
US11650784B2 (en) | 2003-07-28 | 2023-05-16 | Sonos, Inc. | Adjusting volume levels |
WO2023240168A1 (en) * | 2022-06-09 | 2023-12-14 | Amazon Technologies, Inc. | Distribution of messages with guaranteed or synchronized time of delivery |
US12032870B2 (en) | 2016-12-13 | 2024-07-09 | B&W Group Ltd. | Wireless inter-room coordination of audio playback |
Families Citing this family (103)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8352400B2 (en) | 1991-12-23 | 2013-01-08 | Hoffberg Steven M | Adaptive pattern recognition based controller apparatus and method and human-factored interface therefore |
US7966078B2 (en) | 1999-02-01 | 2011-06-21 | Steven Hoffberg | Network media appliance system and method |
ATE378759T1 (en) | 2003-05-06 | 2007-11-15 | Cvon Innovations Ltd | MESSAGE TRANSMISSION SYSTEM AND INFORMATION SERVICE |
US7693887B2 (en) | 2005-02-01 | 2010-04-06 | Strands, Inc. | Dynamic identification of a new set of media items responsive to an input mediaset |
US7734569B2 (en) * | 2005-02-03 | 2010-06-08 | Strands, Inc. | Recommender system for identifying a new set of media items responsive to an input set of media items and knowledge base metrics |
US7797321B2 (en) | 2005-02-04 | 2010-09-14 | Strands, Inc. | System for browsing through a music catalog using correlation metrics of a knowledge base of mediasets |
US7840570B2 (en) | 2005-04-22 | 2010-11-23 | Strands, Inc. | System and method for acquiring and adding data on the playing of elements or multimedia files |
US8244179B2 (en) * | 2005-05-12 | 2012-08-14 | Robin Dua | Wireless inter-device data processing configured through inter-device transmitted data |
US7877387B2 (en) | 2005-09-30 | 2011-01-25 | Strands, Inc. | Systems and methods for promotional media item selection and promotional program unit generation |
US7650570B2 (en) * | 2005-10-04 | 2010-01-19 | Strands, Inc. | Methods and apparatus for visualizing a music library |
BRPI0620084B1 (en) | 2005-12-19 | 2018-11-21 | Apple Inc | method for identifying individual users in a defined user community, based on comparing the first user's profile with other user profiles, for a first community member, and method for measuring individual user similarity for a first user in a defined user community. users |
US20070244880A1 (en) | 2006-02-03 | 2007-10-18 | Francisco Martin | Mediaset generation system |
BRPI0708030A2 (en) | 2006-02-10 | 2011-05-17 | Strands Inc | systems and methods for prioritizing mobile media player files |
KR20080100342A (en) | 2006-02-10 | 2008-11-17 | 스트랜즈, 아이엔씨. | Dynamic interactive entertainment |
WO2007103923A2 (en) | 2006-03-06 | 2007-09-13 | La La Media, Inc | Article trading process |
US7827479B2 (en) * | 2007-01-03 | 2010-11-02 | Kali Damon K I | System and methods for synchronized media playback between electronic devices |
US9253222B2 (en) | 2007-02-22 | 2016-02-02 | Match.Com. L.L.C. | Synchronous delivery of media content in a collaborative environment |
US8671000B2 (en) | 2007-04-24 | 2014-03-11 | Apple Inc. | Method and arrangement for providing content to multimedia devices |
EP2043323A1 (en) * | 2007-09-28 | 2009-04-01 | THOMSON Licensing | Communication device able to synchronise the received stream with that sent to another device |
KR101303672B1 (en) * | 2007-10-15 | 2013-09-16 | 삼성전자주식회사 | Device and method of sharing contents by devices |
US8190683B2 (en) * | 2008-02-29 | 2012-05-29 | Microsoft Corporation | Synchronizing multiple user remote content playback |
WO2009120301A2 (en) * | 2008-03-25 | 2009-10-01 | Square Products Corporation | System and method for simultaneous media presentation |
US9003051B2 (en) * | 2008-04-11 | 2015-04-07 | Mobitv, Inc. | Content server media stream management |
US8966394B2 (en) | 2008-09-08 | 2015-02-24 | Apple Inc. | System and method for playlist generation based on similarity data |
WO2010040082A1 (en) | 2008-10-02 | 2010-04-08 | Strands, Inc. | Real-time visualization of user consumption of media items |
US8898257B1 (en) | 2008-10-20 | 2014-11-25 | At&T Intellectual Property I, L.P. | Multi-device complexity broker |
US10334324B2 (en) | 2008-11-26 | 2019-06-25 | Free Stream Media Corp. | Relevant advertisement generation based on a user operating a client device communicatively coupled with a networked media device |
US9961388B2 (en) | 2008-11-26 | 2018-05-01 | David Harrison | Exposure of public internet protocol addresses in an advertising exchange server to improve relevancy of advertisements |
US10567823B2 (en) | 2008-11-26 | 2020-02-18 | Free Stream Media Corp. | Relevant advertisement generation based on a user operating a client device communicatively coupled with a networked media device |
US9519772B2 (en) | 2008-11-26 | 2016-12-13 | Free Stream Media Corp. | Relevancy improvement through targeting of information based on data gathered from a networked device associated with a security sandbox of a client device |
US10631068B2 (en) | 2008-11-26 | 2020-04-21 | Free Stream Media Corp. | Content exposure attribution based on renderings of related content across multiple devices |
US10880340B2 (en) | 2008-11-26 | 2020-12-29 | Free Stream Media Corp. | Relevancy improvement through targeting of information based on data gathered from a networked device associated with a security sandbox of a client device |
US10977693B2 (en) | 2008-11-26 | 2021-04-13 | Free Stream Media Corp. | Association of content identifier of audio-visual data with additional data through capture infrastructure |
US9386356B2 (en) | 2008-11-26 | 2016-07-05 | Free Stream Media Corp. | Targeting with television audience data across multiple screens |
US10419541B2 (en) | 2008-11-26 | 2019-09-17 | Free Stream Media Corp. | Remotely control devices over a network without authentication or registration |
US9986279B2 (en) | 2008-11-26 | 2018-05-29 | Free Stream Media Corp. | Discovery, access control, and communication with networked services |
US9154942B2 (en) | 2008-11-26 | 2015-10-06 | Free Stream Media Corp. | Zero configuration communication between a browser and a networked media device |
US9026668B2 (en) | 2012-05-26 | 2015-05-05 | Free Stream Media Corp. | Real-time and retargeted advertising on multiple screens of a user watching television |
US8180891B1 (en) | 2008-11-26 | 2012-05-15 | Free Stream Media Corp. | Discovery, access control, and communication with networked services from within a security sandbox |
US8429530B2 (en) | 2009-06-11 | 2013-04-23 | Apple Inc. | User interface for media playback |
JP2011041018A (en) * | 2009-08-11 | 2011-02-24 | Sony Corp | Information processing apparatus, information processing method, program and communication terminal |
US20110060738A1 (en) | 2009-09-08 | 2011-03-10 | Apple Inc. | Media item clustering based on similarity data |
US8346976B2 (en) * | 2009-11-25 | 2013-01-01 | T-Mobile Usa, Inc. | Secured registration of a home network device |
KR20110090596A (en) * | 2010-02-04 | 2011-08-10 | 삼성전자주식회사 | Method and apparatus for correcting interarrival jitter |
US20110219308A1 (en) * | 2010-03-02 | 2011-09-08 | Twentieth Century Fox Film Corporation | Pre-processing and encoding media content |
US10264305B2 (en) * | 2010-03-02 | 2019-04-16 | Twentieth Century Fox Film Corporation | Delivery of encoded media content |
US8584256B2 (en) | 2010-04-21 | 2013-11-12 | Fox Entertainment Group, Inc. | Digital delivery system and user interface for enabling the digital delivery of media content |
US10339570B2 (en) | 2010-04-21 | 2019-07-02 | Fox Entertainment Group, Inc. | Customized billboard website advertisements |
US10712771B2 (en) * | 2010-08-13 | 2020-07-14 | Netflix, Inc. | System and method for synchronized playback of streaming digital content |
WO2012174301A1 (en) | 2011-06-14 | 2012-12-20 | Related Content Database, Inc. | System and method for presenting content with time based metadata |
US20130191745A1 (en) * | 2012-01-10 | 2013-07-25 | Zane Vella | Interface for displaying supplemental dynamic timeline content |
EP2567741A1 (en) * | 2011-09-07 | 2013-03-13 | Research In Motion Limited | Apparatus, and associated method, for providing synchronized media play out |
US9712573B2 (en) * | 2011-09-13 | 2017-07-18 | Qualcomm Incorporated | Synchronized wireless display devices |
US8983905B2 (en) | 2011-10-03 | 2015-03-17 | Apple Inc. | Merging playlists from multiple sources |
EP2592842A1 (en) * | 2011-11-14 | 2013-05-15 | Accenture Global Services Limited | Computer-implemented method, computer system, and computer program product for synchronizing output of media data across a plurality of devices |
US9654821B2 (en) | 2011-12-30 | 2017-05-16 | Sonos, Inc. | Systems and methods for networked music playback |
US8812740B2 (en) * | 2012-03-30 | 2014-08-19 | Broadcom Corporation | Communication over bandwidth-constrained network |
US9071628B2 (en) * | 2012-05-18 | 2015-06-30 | Andrew Milburn | Method and apparatus for managing bandwidth by managing selected internet access by devices in a Wi-Fi linked audience |
US9204174B2 (en) | 2012-06-25 | 2015-12-01 | Sonos, Inc. | Collecting and providing local playback system information |
US9674587B2 (en) | 2012-06-26 | 2017-06-06 | Sonos, Inc. | Systems and methods for networked music playback including remote add to queue |
CN102866828B (en) * | 2012-08-29 | 2015-11-25 | 腾讯科技(深圳)有限公司 | A kind of terminal control method and equipment |
USD716375S1 (en) | 2013-01-03 | 2014-10-28 | East Carolina University | Multi-user reading comprehension therapy device |
WO2014107367A1 (en) * | 2013-01-03 | 2014-07-10 | East Carolina University | Methods, systems, and devices for multi-user treatment for improvement of reading comprehension using frequency altered feedback |
US9510055B2 (en) | 2013-01-23 | 2016-11-29 | Sonos, Inc. | System and method for a media experience social interface |
US20140214961A1 (en) * | 2013-01-31 | 2014-07-31 | Lance Gordon Douglas | Methods and systems for continuous compilation of non-interactive video with supplemental renderings of interactive content to produce real-time, personalized video for individuals and/or groups in a shared experience |
US9501533B2 (en) | 2013-04-16 | 2016-11-22 | Sonos, Inc. | Private queue for a media playback system |
US9361371B2 (en) | 2013-04-16 | 2016-06-07 | Sonos, Inc. | Playlist update in a media playback system |
US9247363B2 (en) | 2013-04-16 | 2016-01-26 | Sonos, Inc. | Playback queue transfer in a media playback system |
US9307508B2 (en) | 2013-04-29 | 2016-04-05 | Google Technology Holdings LLC | Systems and methods for syncronizing multiple electronic devices |
US9684484B2 (en) | 2013-05-29 | 2017-06-20 | Sonos, Inc. | Playback zone silent connect |
US9912978B2 (en) * | 2013-07-29 | 2018-03-06 | Apple Inc. | Systems, methods, and computer-readable media for transitioning media playback between multiple electronic devices |
US20150220498A1 (en) | 2014-02-05 | 2015-08-06 | Sonos, Inc. | Remote Creation of a Playback Queue for a Future Event |
US9679054B2 (en) | 2014-03-05 | 2017-06-13 | Sonos, Inc. | Webpage media playback |
US20150324552A1 (en) | 2014-05-12 | 2015-11-12 | Sonos, Inc. | Share Restriction for Media Items |
US20150356084A1 (en) | 2014-06-05 | 2015-12-10 | Sonos, Inc. | Social Queue |
US9832507B2 (en) | 2014-06-27 | 2017-11-28 | Qualcomm Incorporated | System and method for synchronizing media output devices connected on a network |
US9874997B2 (en) | 2014-08-08 | 2018-01-23 | Sonos, Inc. | Social playback queues |
US9959087B2 (en) | 2014-09-24 | 2018-05-01 | Sonos, Inc. | Media item context from social media |
WO2016049342A1 (en) | 2014-09-24 | 2016-03-31 | Sonos, Inc. | Social media connection recommendations based on playback information |
US9723038B2 (en) | 2014-09-24 | 2017-08-01 | Sonos, Inc. | Social media connection recommendations based on playback information |
US9690540B2 (en) | 2014-09-24 | 2017-06-27 | Sonos, Inc. | Social media queue |
US9667679B2 (en) | 2014-09-24 | 2017-05-30 | Sonos, Inc. | Indicating an association between a social-media account and a media playback system |
US10645130B2 (en) | 2014-09-24 | 2020-05-05 | Sonos, Inc. | Playback updates |
US9860286B2 (en) | 2014-09-24 | 2018-01-02 | Sonos, Inc. | Associating a captured image with a media item |
EP3251118A1 (en) | 2015-01-28 | 2017-12-06 | Dynastrom ApS | Audio time synchronization using prioritized schedule |
JP6520556B2 (en) * | 2015-08-19 | 2019-05-29 | ヤマハ株式会社 | Content data delivery system and content data delivery method |
CN107852523B (en) * | 2015-09-30 | 2021-01-19 | 苹果公司 | Method, terminal and equipment for synchronizing media rendering between terminals |
US20170311005A1 (en) * | 2016-04-26 | 2017-10-26 | Szu-Tung Lin | Method of wireless audio transmission and playback |
FR3054393B1 (en) * | 2016-07-22 | 2019-08-16 | Tap Sound System | CONTROL OF CONNECTED MULTIMEDIA DEVICES |
US20180302454A1 (en) * | 2017-04-05 | 2018-10-18 | Interlock Concepts Inc. | Audio visual integration device |
US10936653B2 (en) | 2017-06-02 | 2021-03-02 | Apple Inc. | Automatically predicting relevant contexts for media items |
US10009862B1 (en) | 2017-09-06 | 2018-06-26 | Texas Instruments Incorporated | Bluetooth media device time synchronization |
US10764855B1 (en) * | 2018-02-26 | 2020-09-01 | Marvell Asia Pte, Ltd. | Synchronizing clocks in a wireless network |
US11233716B2 (en) * | 2018-03-28 | 2022-01-25 | Arlo Technologies, Inc. | System for real-time monitoring with backward error correction |
US11089341B2 (en) | 2018-05-11 | 2021-08-10 | Prowire Sport Llc | System and method for capturing and distributing a live audio stream of a live event in real-time |
US11606407B2 (en) * | 2018-07-05 | 2023-03-14 | Prowire Sport Limited | System and method for capturing and distributing live audio streams of a live event |
CN109194998B (en) * | 2018-08-14 | 2021-05-11 | Oppo广东移动通信有限公司 | Data transmission method and device, electronic equipment and computer readable medium |
US10884973B2 (en) * | 2019-05-31 | 2021-01-05 | Microsoft Technology Licensing, Llc | Synchronization of audio across multiple devices |
US10747495B1 (en) * | 2019-05-31 | 2020-08-18 | Microsoft Technology Licensing, Llc | Device aggregation representing multiple endpoints as one |
US11170800B2 (en) | 2020-02-27 | 2021-11-09 | Microsoft Technology Licensing, Llc | Adjusting user experience for multiuser sessions based on vocal-characteristic models |
CN111629403B (en) * | 2020-04-24 | 2022-10-11 | 四川速宝网络科技有限公司 | Host game acceleration method and system |
US11316912B2 (en) * | 2020-05-26 | 2022-04-26 | Grass Valley Canada | System and method for synchronizing transmission of media content using timestamps |
CN115134640A (en) * | 2021-03-25 | 2022-09-30 | 华为技术有限公司 | Synchronous playing method and device |
Citations (92)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4807224A (en) * | 1987-08-21 | 1989-02-21 | Naron Steven E | Multicast data distribution system and method |
US5553222A (en) * | 1993-05-10 | 1996-09-03 | Taligent, Inc. | Multimedia synchronization system |
US5664226A (en) * | 1994-09-08 | 1997-09-02 | International Business Machines Corporation | System for merging plurality of atomic data elements into single synchronized file by assigning ouput rate to each channel in response to presentation time duration |
US5664044A (en) * | 1994-04-28 | 1997-09-02 | International Business Machines Corporation | Synchronized, variable-speed playback of digitally recorded audio and video |
US5722041A (en) * | 1995-12-05 | 1998-02-24 | Altec Lansing Technologies, Inc. | Hybrid home-entertainment system |
US5790521A (en) * | 1994-08-01 | 1998-08-04 | The University Of Iowa Research Foundation | Marking mechanism for controlling consecutive packet loss in ATM networks |
US5875354A (en) * | 1996-03-01 | 1999-02-23 | Apple Computer, Inc. | System for synchronization by modifying the rate of conversion by difference of rate between first clock and audio clock during a second time period |
US5931906A (en) * | 1997-04-18 | 1999-08-03 | Creative Communications Group | System for creating a multimedia presentation by integrating local program materials with remotely accessible program materials |
US5953350A (en) * | 1995-03-13 | 1999-09-14 | Selsius Systems, Inc. | Multimedia client for multimedia/hybrid network |
US6085252A (en) * | 1996-04-23 | 2000-07-04 | Motorola Inc. | Device, system and method for real-time multimedia streaming |
US6092119A (en) * | 1994-02-14 | 2000-07-18 | Sony Corporation | Random access audio/video processor with compressed video resampling to allow higher bandwidth throughput |
US6101591A (en) * | 1998-03-25 | 2000-08-08 | International Business Machines Corporation | Method and system for selectively independently or simultaneously updating multiple system time clocks in an MPEG system |
US6212359B1 (en) * | 1996-07-15 | 2001-04-03 | Gregory D. Knox | Wireless Transceiver System For Digital Music |
US6243772B1 (en) * | 1997-01-31 | 2001-06-05 | Sharewave, Inc. | Method and system for coupling a personal computer with an appliance unit via a wireless communication link to provide an output display presentation |
US6263503B1 (en) * | 1999-05-26 | 2001-07-17 | Neal Margulis | Method for effectively implementing a wireless television system |
US6282714B1 (en) * | 1997-01-31 | 2001-08-28 | Sharewave, Inc. | Digital wireless home computer system |
US20010021305A1 (en) * | 2000-01-11 | 2001-09-13 | Nobukazu Sugiyama | Electronic device system |
US20020013852A1 (en) * | 2000-03-03 | 2002-01-31 | Craig Janik | System for providing content, management, and interactivity for thin client devices |
US20020019984A1 (en) * | 2000-01-14 | 2002-02-14 | Rakib Selim Shlomo | Headend cherrypicker with digital video recording capability |
US6374177B1 (en) * | 2000-09-20 | 2002-04-16 | Motorola, Inc. | Method and apparatus for providing navigational services in a wireless communication device |
US6397388B1 (en) * | 2000-09-29 | 2002-05-28 | Digeo, Inc. | Systems and devices for audio capture and communication during television broadcasts |
US20020074413A1 (en) * | 2000-12-19 | 2002-06-20 | Henzerling David P. | Wireless music device and method therefor |
US20020103554A1 (en) * | 2001-01-29 | 2002-08-01 | Hewlett-Packard Company | Interactive audio system |
US20030013492A1 (en) * | 2001-07-10 | 2003-01-16 | Bokhari Wasiq Mahood | System, method and computer program product for a content publisher for wireless devices |
US6529233B1 (en) * | 2000-09-29 | 2003-03-04 | Digeo, Inc. | Systems and methods for remote video and audio capture and communication |
US20030083954A1 (en) * | 2001-10-25 | 2003-05-01 | Takaaki Namba | Content usage rule management system |
US20030131360A1 (en) * | 2002-01-10 | 2003-07-10 | Joung Chul Yong | Interfacing system for stream source device and display apparatus and interfacing method thereof |
US20030134589A1 (en) * | 2001-03-07 | 2003-07-17 | Masaru Oba | Porable radio terminal with musuc data download function |
US20040001494A1 (en) * | 2002-07-01 | 2004-01-01 | Zarlink Semiconductor V.N. Inc | Architecture for obtaining playback time from a packet sequence number in AAL2 SSCS voice |
US6684060B1 (en) * | 2000-04-11 | 2004-01-27 | Agere Systems Inc. | Digital wireless premises audio system and method of operation thereof |
US20040057446A1 (en) * | 2002-07-16 | 2004-03-25 | Nokia Corporation | Method for enabling packet transfer delay compensation in multimedia streaming |
US20040072584A1 (en) * | 2002-03-01 | 2004-04-15 | Kern Ronald J. | Wireless distribution of multimedia content |
US6728729B1 (en) * | 2003-04-25 | 2004-04-27 | Apple Computer, Inc. | Accessing media across networks |
US6728585B2 (en) * | 2000-10-03 | 2004-04-27 | Freesystems Pte, Ltd. | Personal on-demand audio entertainment device that is untethered and allows wireless download of content |
US6744738B1 (en) * | 1999-06-12 | 2004-06-01 | Samsung Electronics Co., Ltd. | Wireless communication system for video packet transmission |
US6757913B2 (en) * | 1996-07-15 | 2004-06-29 | Gregory D. Knox | Wireless music and data transceiver system |
US20040128402A1 (en) * | 2000-09-27 | 2004-07-01 | Weaver David John | Architecture for optimizing audio and video output states for multimeda devices |
US20040133908A1 (en) * | 2003-01-03 | 2004-07-08 | Broadq, Llc | Digital media system and method therefor |
US20040132510A1 (en) * | 2002-12-26 | 2004-07-08 | Kabushiki Kaisha Toshiba | Wireless sound apparatus, and audio acquisition method in the apparatus |
US6766376B2 (en) * | 2000-09-12 | 2004-07-20 | Sn Acquisition, L.L.C | Streaming media buffering system |
US20040143442A1 (en) * | 2003-01-22 | 2004-07-22 | Knight Erik A. | Multiple-language audio information transmission system and device |
US20040157548A1 (en) * | 2003-02-06 | 2004-08-12 | Eyer Mark Kenneth | Home network interface legacy device adapter |
US20040177063A1 (en) * | 2003-03-06 | 2004-09-09 | Weber Barry Jay | Simplified searching for media services using a control device |
US20040177371A1 (en) * | 2003-03-07 | 2004-09-09 | Rami Caspi | System and method for integrated communications center |
US20040174896A1 (en) * | 2003-03-07 | 2004-09-09 | Rami Caspi | System and method for digital personal video stream manager |
US6845398B1 (en) * | 1999-08-02 | 2005-01-18 | Lucent Technologies Inc. | Wireless multimedia player |
US20050071375A1 (en) * | 2003-09-30 | 2005-03-31 | Phil Houghton | Wireless media player |
US6920179B1 (en) * | 1999-11-16 | 2005-07-19 | Agere Systems Inc. | Method and apparatus for video transmission over a heterogeneous network using progressive video coding |
US20050174488A1 (en) * | 2003-03-10 | 2005-08-11 | Sandeep Chennakeshu | Methods, devices, and systems for displaying information from a remote electronic device |
US6985966B1 (en) * | 2000-03-29 | 2006-01-10 | Microsoft Corporation | Resynchronizing globally unsynchronized multimedia streams |
US20060007943A1 (en) * | 2004-07-07 | 2006-01-12 | Fellman Ronald D | Method and system for providing site independent real-time multimedia transport over packet-switched networks |
US20060015580A1 (en) * | 2004-07-01 | 2006-01-19 | Home Box Office, A Delaware Corporation | Multimedia content distribution |
US20060030961A1 (en) * | 2004-08-06 | 2006-02-09 | Jeng-Tay Lin | Wireless streaming audio apparatus |
US7016443B1 (en) * | 1999-08-06 | 2006-03-21 | Siemens Aktiengesellschaft | Synchronization method and system for clock signal sources, in particular in packet transmission communication systems |
US20060062242A1 (en) * | 2004-09-23 | 2006-03-23 | Sony Corporation | Reliable audio-video transmission system using multi-media diversity |
US20060062243A1 (en) * | 2004-09-23 | 2006-03-23 | Dacosta Behram M | Reliable audio-video transmission system using multi-media diversity |
US20060069724A1 (en) * | 2000-09-28 | 2006-03-30 | Qwest Communications International Inc. | Portable wireless player and associated method |
US7024575B2 (en) * | 2002-11-14 | 2006-04-04 | Intel Corporation | Apparatus and method for time synchronization of a plurality of multimedia streams |
US20060074637A1 (en) * | 2004-10-01 | 2006-04-06 | Microsoft Corporation | Low latency real-time audio streaming |
US20060083194A1 (en) * | 2004-10-19 | 2006-04-20 | Ardian Dhrimaj | System and method rendering audio/image data on remote devices |
US7034891B2 (en) * | 2002-02-01 | 2006-04-25 | Lg Electronics Inc. | Interfacing system for stream source apparatus and display apparatus and interfacing method thereof |
US20060092844A1 (en) * | 2004-11-03 | 2006-05-04 | Electronics And Telecommunications Research Institute | Apparatus for transmitting WPAN MAC frames and method thereof |
US7047308B2 (en) * | 2001-08-31 | 2006-05-16 | Sharp Laboratories Of America, Inc. | System and method for simultaneous media playout |
US20060117371A1 (en) * | 2001-03-15 | 2006-06-01 | Digital Display Innovations, Llc | Method for effectively implementing a multi-room television system |
US20060126667A1 (en) * | 2004-12-10 | 2006-06-15 | Microsoft Corporation | Accelerated channel change in rate-limited environments |
US7076204B2 (en) * | 2001-10-30 | 2006-07-11 | Unwired Technology Llc | Multiple channel wireless communication system |
US7082320B2 (en) * | 2001-09-04 | 2006-07-25 | Telefonaktiebolaget Lm Ericsson (Publ) | Integration of wireless LAN and cellular distributed antenna |
US20060167982A1 (en) * | 2005-01-07 | 2006-07-27 | Apple Computer, Inc. | Restricted media sharing over networks |
US7084898B1 (en) * | 2003-11-18 | 2006-08-01 | Cisco Technology, Inc. | System and method for providing video conferencing synchronization |
US7096271B1 (en) * | 1998-09-15 | 2006-08-22 | Microsoft Corporation | Managing timeline modification and synchronization of multiple media streams in networked client/server systems |
US7174560B1 (en) * | 1999-02-25 | 2007-02-06 | Sharp Laboratories Of America, Inc. | Method of synchronizing events with a digital television audio-visual program |
US7185084B2 (en) * | 2001-09-05 | 2007-02-27 | Intel Corporation | Server-side measurement of client-perceived quality of service |
US7200357B2 (en) * | 2000-10-20 | 2007-04-03 | Universal Electronics Inc. | Automotive storage and playback device and method for using the same |
US7260714B2 (en) * | 2002-08-20 | 2007-08-21 | Sony Corporation | System and method for authenticating wireless component |
US7346698B2 (en) * | 2000-12-20 | 2008-03-18 | G. W. Hannaway & Associates | Webcasting method and system for time-based synchronization of multiple, independent media streams |
US7359671B2 (en) * | 2001-10-30 | 2008-04-15 | Unwired Technology Llc | Multiple channel wireless communication system |
US7369532B2 (en) * | 2002-02-26 | 2008-05-06 | Intel Corporation | Apparatus and method for an audio channel switching wireless device |
US7370129B2 (en) * | 2004-12-15 | 2008-05-06 | Microsoft Corporation | Retry strategies for use in a streaming environment |
US7391791B2 (en) * | 2001-12-17 | 2008-06-24 | Implicit Networks, Inc. | Method and system for synchronization of content rendering |
US7406294B1 (en) * | 2003-11-25 | 2008-07-29 | Frank Kung Fu Liu | Digital audio file reproduction system and method with wireless transfer capability |
US7474677B2 (en) * | 2003-08-12 | 2009-01-06 | Bose Corporation | Wireless communicating |
US7480746B2 (en) * | 2005-09-06 | 2009-01-20 | Home Xperience, Inc. | Extensible universal home automation integration framework and user interface |
US7483538B2 (en) * | 2004-03-02 | 2009-01-27 | Ksc Industries, Inc. | Wireless and wired speaker hub for a home theater system |
US7519686B2 (en) * | 2002-05-30 | 2009-04-14 | Icube | Wireless receiver for receiving multi-contents file and method for outputting data using the same |
US7519681B2 (en) * | 2005-06-30 | 2009-04-14 | Intel Corporation | Systems, methods, and media for discovering remote user interface applications over a network |
US7539777B1 (en) * | 2002-10-25 | 2009-05-26 | Cisco Technology, Inc. | Method and system for network time protocol forwarding |
US7542784B2 (en) * | 2005-02-25 | 2009-06-02 | Kleer Semiconductor Corporation | High quality, low power, wireless audio system |
US7555291B2 (en) * | 2005-08-26 | 2009-06-30 | Sony Ericsson Mobile Communications Ab | Mobile wireless communication terminals, systems, methods, and computer program products for providing a song play list |
US7561215B2 (en) * | 2004-01-06 | 2009-07-14 | Samsung Electronics Co., Ltd. | Method and apparatus for wirelessly controlling devices peripheral to AV device |
US7577261B2 (en) * | 2005-10-13 | 2009-08-18 | Realtek Semiconductor Corp. | Wireless audio system using wireless local area network |
US7698723B2 (en) * | 2000-12-28 | 2010-04-13 | At&T Intellectual Property I, L.P. | System and method for multimedia on demand services |
US7724780B2 (en) * | 2007-04-19 | 2010-05-25 | Cisco Technology, Ink. | Synchronization of one or more source RTP streams at multiple receiver destinations |
Family Cites Families (308)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5092352A (en) | 1983-12-14 | 1992-03-03 | American Brands, Inc. | Chewing tobacco product |
JPH0322259A (en) | 1989-03-22 | 1991-01-30 | Seiko Epson Corp | Small-sized data display and reproducing device |
US5045940A (en) | 1989-12-22 | 1991-09-03 | Avid Technology, Inc. | Video/audio transmission systsem and method |
US5963916A (en) | 1990-09-13 | 1999-10-05 | Intouch Group, Inc. | Network apparatus and method for preview of music products and compilation of market data |
US5835732A (en) | 1993-10-28 | 1998-11-10 | Elonex Ip Holdings, Ltd. | Miniature digital assistant having enhanced host communication |
US5386545A (en) | 1992-09-25 | 1995-01-31 | Archive Corporation | Target management method for data backup to a shared transfer station, multiple media element device |
US5666530A (en) | 1992-12-02 | 1997-09-09 | Compaq Computer Corporation | System for automatic synchronization of common file between portable computer and host computer via communication channel selected from a plurality of usable channels there between |
ATE153149T1 (en) | 1993-01-21 | 1997-05-15 | Apple Computer | DEVICE AND METHOD FOR DATA BACKUP OF STORAGE UNITS IN A COMPUTER NETWORK |
WO1994017473A1 (en) | 1993-01-21 | 1994-08-04 | Apple Computer, Inc. | Method and apparatus for data transfer and storage in a highly parallel computer network environment |
CA2095452C (en) | 1993-05-04 | 1997-03-18 | Phillip J. Beaudet | Dynamic hierarchical selection menu |
US5710922A (en) | 1993-06-02 | 1998-01-20 | Apple Computer, Inc. | Method for synchronizing and archiving information between computer systems |
US5535381A (en) | 1993-07-22 | 1996-07-09 | Data General Corporation | Apparatus and method for copying and restoring disk files |
US5818182A (en) | 1993-08-13 | 1998-10-06 | Apple Computer, Inc. | Removable media ejection system |
US5771354A (en) | 1993-11-04 | 1998-06-23 | Crawford; Christopher M. | Internet online backup system provides remote storage for customers using IDs and passwords which were interactively established when signing up for backup services |
WO1995016950A1 (en) | 1993-12-14 | 1995-06-22 | Apple Computer, Inc. | Method and apparatus for transferring data between a computer and a peripheral storage device |
US5583993A (en) | 1994-01-31 | 1996-12-10 | Apple Computer, Inc. | Method and apparatus for synchronously sharing data among computer |
US5745583A (en) | 1994-04-04 | 1998-04-28 | Honda Giken Kogyo Kabushiki Kaisha | Audio playback system |
DE4414088A1 (en) | 1994-04-22 | 1995-10-26 | Basf Ag | Gels with thermotropic properties |
US5594911A (en) * | 1994-07-13 | 1997-01-14 | Bell Communications Research, Inc. | System and method for preprocessing and delivering multimedia presentations |
US5640566A (en) | 1994-08-01 | 1997-06-17 | Apple Computer, Inc. | Method of forming an editor |
US6137476A (en) | 1994-08-25 | 2000-10-24 | International Business Machines Corp. | Data mouse |
US5534911A (en) | 1994-11-02 | 1996-07-09 | Levitan; Gutman | Virtual personal channel in a television system |
US5616876A (en) | 1995-04-19 | 1997-04-01 | Microsoft Corporation | System and methods for selecting music on the basis of subjective content |
US6307574B1 (en) | 1995-05-08 | 2001-10-23 | Apple Computer, Inc. | Graphical user interface with hierarchical structure for customizable menus and control objects |
US5613863A (en) | 1995-05-18 | 1997-03-25 | Motorola, Inc. | Power transformer |
US5845282A (en) | 1995-08-07 | 1998-12-01 | Apple Computer, Inc. | Method and apparatus for remotely accessing files from a desktop computer using a personal digital assistant |
US5835721A (en) | 1995-08-21 | 1998-11-10 | Apple Computer, Inc. | Method and system for data transmission over a network link between computers with the ability to withstand temporary interruptions |
US5884323A (en) | 1995-10-13 | 1999-03-16 | 3Com Corporation | Extendible method and apparatus for synchronizing files on two different computer systems |
US5727202A (en) | 1995-10-18 | 1998-03-10 | Palm Computing, Inc. | Method and apparatus for synchronizing information on two different computer systems |
US5815297A (en) | 1995-10-25 | 1998-09-29 | General Instrument Corporation Of Delaware | Infrared interface and control apparatus for consumer electronics |
US5703877A (en) | 1995-11-22 | 1997-12-30 | General Instrument Corporation Of Delaware | Acquisition and error recovery of audio data carried in a packetized data stream |
US5918213A (en) | 1995-12-22 | 1999-06-29 | Mci Communications Corporation | System and method for automated remote previewing and purchasing of music, video, software, and other multimedia products |
US5864868A (en) | 1996-02-13 | 1999-01-26 | Contois; David C. | Computer control system and user interface for media playing devices |
US5709521A (en) | 1996-05-21 | 1998-01-20 | Glass; Dennis | Lift assist bicycle carrier for car rooftop |
US6453281B1 (en) | 1996-07-30 | 2002-09-17 | Vxi Corporation | Portable audio database device with icon-based graphical user-interface |
US6283764B2 (en) | 1996-09-30 | 2001-09-04 | Fujitsu Limited | Storage medium playback system and method |
US5918303A (en) | 1996-11-25 | 1999-06-29 | Yamaha Corporation | Performance setting data selecting apparatus |
US5739451A (en) | 1996-12-27 | 1998-04-14 | Franklin Electronic Publishers, Incorporated | Hand held electronic music encyclopedia with text and note structure search |
US6006274A (en) | 1997-01-30 | 1999-12-21 | 3Com Corporation | Method and apparatus using a pass through personal computer connected to both a local communication link and a computer network for indentifying and synchronizing a preferred computer with a portable computer |
US5925843A (en) | 1997-02-12 | 1999-07-20 | Virtual Music Entertainment, Inc. | Song identification and synchronization |
US6008777A (en) | 1997-03-07 | 1999-12-28 | Intel Corporation | Wireless connectivity between a personal computer and a television |
US7111009B1 (en) | 1997-03-14 | 2006-09-19 | Microsoft Corporation | Interactive playlist generation using annotations |
US6262729B1 (en) | 1997-04-14 | 2001-07-17 | Apple Computer, Inc. | Method and apparatus for binding user interface objects to application objects |
US6243725B1 (en) | 1997-05-21 | 2001-06-05 | Premier International, Ltd. | List building system |
US6166314A (en) | 1997-06-19 | 2000-12-26 | Time Warp Technologies, Ltd. | Method and apparatus for real-time correlation of a performance to a musical score |
US6587404B1 (en) | 1997-07-09 | 2003-07-01 | Advanced Audio Devices, Llc | Optical storage device capable of recording a set of sound tracks on a compact disc |
JP2001516112A (en) | 1997-07-09 | 2001-09-25 | アドバンスト・オーディオ・デバイセス,エルエルシー | Optical recording device |
US6125369A (en) | 1997-10-02 | 2000-09-26 | Microsoft Corporation | Continuous object sychronization between object stores on different computers |
US6272545B1 (en) | 1997-10-24 | 2001-08-07 | Microsoft Corporation | System and method for interaction between one or more desktop computers and one or more mobile devices |
US6034621A (en) | 1997-11-18 | 2000-03-07 | Lucent Technologies, Inc. | Wireless remote synchronization of data between PC and PDA |
US6038199A (en) | 1997-11-21 | 2000-03-14 | Dictaphone Corporation | Portable digital audio recorder with adaptive control configurations |
US6295541B1 (en) | 1997-12-16 | 2001-09-25 | Starfish Software, Inc. | System and methods for synchronizing two or more datasets |
US6216131B1 (en) | 1998-02-06 | 2001-04-10 | Starfish Software, Inc. | Methods for mapping data fields from one data set to another in a data processing environment |
US6243328B1 (en) | 1998-04-03 | 2001-06-05 | Sony Corporation | Modular media storage system and integrated player unit and method for accessing additional external information |
DE69914863T2 (en) | 1998-05-08 | 2005-01-05 | Ntt Mobile Communications Network Inc. | RADIO COMMUNICATION SYSTEM AND METHOD AND DEVICE FOR FREQUENCY AWARD |
US6779019B1 (en) | 1998-05-29 | 2004-08-17 | Research In Motion Limited | System and method for pushing information from a host system to a mobile data communication device |
US6563769B1 (en) | 1998-06-11 | 2003-05-13 | Koninklijke Philips Electronics N.V. | Virtual jukebox |
US5969283A (en) | 1998-06-17 | 1999-10-19 | Looney Productions, Llc | Music organizer and entertainment center |
US6925595B1 (en) | 1998-08-05 | 2005-08-02 | Spyglass, Inc. | Method and system for content conversion of hypertext data using data mining |
US6959288B1 (en) | 1998-08-13 | 2005-10-25 | International Business Machines Corporation | Digital content preparation system |
US6226618B1 (en) | 1998-08-13 | 2001-05-01 | International Business Machines Corporation | Electronic content delivery system |
JP2000105598A (en) | 1998-08-24 | 2000-04-11 | Saehan Information Syst Inc | Recording/regenerating device for portable data, recording/regenerating method for digital data, and recording/regenerating system for computer music file data |
US6493758B1 (en) | 1998-09-08 | 2002-12-10 | Microsoft Corporation | Offline viewing of internet content with a mobile device |
US6279041B1 (en) | 1998-11-13 | 2001-08-21 | International Business Machines Corporation | Methods, systems and computer program products for differencing data communications using a message queue |
US6999826B1 (en) | 1998-11-18 | 2006-02-14 | Zoran Corporation | Apparatus and method for improved PC audio quality |
US20020194260A1 (en) | 1999-01-22 | 2002-12-19 | Kent Lawrence Headley | Method and apparatus for creating multimedia playlists for audio-visual systems |
US6138245A (en) | 1999-02-05 | 2000-10-24 | Neopoint, Inc. | System and method for automatic device synchronization |
US6993722B1 (en) | 1999-02-08 | 2006-01-31 | Cirrus Logic, Inc. | User interface system methods and computer program products for multi-function consumer entertainment appliances |
US6332175B1 (en) | 1999-02-12 | 2001-12-18 | Compaq Computer Corporation | Low power system and method for playing compressed audio data |
US20020026321A1 (en) * | 1999-02-26 | 2002-02-28 | Sadeg M. Faris | Internet-based system and method for fairly and securely enabling timed-constrained competition using globally time-sychronized client subsystems and information servers having microsecond client-event resolution |
US6247135B1 (en) | 1999-03-03 | 2001-06-12 | Starfish Software, Inc. | Synchronization process negotiation for computing devices |
US6356971B1 (en) | 1999-03-04 | 2002-03-12 | Sony Corporation | System for managing multimedia discs, tracks and files on a standalone computer |
US6338044B1 (en) | 1999-03-17 | 2002-01-08 | Loudeye Technologies, Inc. | Personal digital content system |
US6041023A (en) | 1999-03-29 | 2000-03-21 | Lakhansingh; Cynthia | Portable digital radio and compact disk player |
US6694200B1 (en) | 1999-04-13 | 2004-02-17 | Digital5, Inc. | Hard disk based portable device |
US6791907B2 (en) | 1999-04-22 | 2004-09-14 | Roxio, Inc. | Automobile audio system for collection, management and playback of audio data |
US6523124B1 (en) | 1999-04-23 | 2003-02-18 | Palm, Inc. | System and method for detection of an accessory device connection status |
JP2000339917A (en) | 1999-06-02 | 2000-12-08 | Keiichi Kato | Musical sound reproducing system |
US6061306A (en) | 1999-07-20 | 2000-05-09 | James Buchheim | Portable digital player compatible with a cassette player |
US6380947B1 (en) | 1999-07-22 | 2002-04-30 | At&T Corp. | Method and apparatus for displaying and tree scrolling a hierarchical data structure |
US6341316B1 (en) | 1999-09-10 | 2002-01-22 | Avantgo, Inc. | System, method, and computer program product for synchronizing content between a server and a client based on state information |
JP2001093226A (en) | 1999-09-21 | 2001-04-06 | Sony Corp | Information communication system and method, and information communication device and method |
CN1159917C (en) | 1999-10-07 | 2004-07-28 | 汤姆森特许公司 | Method and device for producing a trick mode in digital video system |
US7022905B1 (en) | 1999-10-18 | 2006-04-04 | Microsoft Corporation | Classification of information and use of classifications in searching and retrieval of information |
US7039656B1 (en) | 1999-10-20 | 2006-05-02 | Yodlee.Com, Inc. | Method and apparatus for synchronizing data records between a remote device and a data server over a data-packet-network |
JP2001117800A (en) | 1999-10-21 | 2001-04-27 | Matsushita Electric Ind Co Ltd | Data synchronization system among shared equipment and one or more terminals, shared equipment and terminal |
WO2001033569A1 (en) | 1999-11-02 | 2001-05-10 | Iomega Corporation | Portable audio playback device and removable disk drive |
US6804467B2 (en) | 1999-11-05 | 2004-10-12 | Jds Uniphase Inc. | Chromatic dispersion compensation device |
US20040223622A1 (en) | 1999-12-01 | 2004-11-11 | Lindemann Eric Lee | Digital wireless loudspeaker system |
US6978127B1 (en) | 1999-12-16 | 2005-12-20 | Koninklijke Philips Electronics N.V. | Hand-ear user interface for hand-held device |
KR100362149B1 (en) | 1999-12-22 | 2002-11-23 | 엘지전자 주식회사 | Data synchronous method between mobile terminal and computer |
US6220546B1 (en) | 1999-12-29 | 2001-04-24 | The Boeing Company | Aircraft engine and associated aircraft engine cowl |
GB0000873D0 (en) | 2000-01-14 | 2000-03-08 | Koninkl Philips Electronics Nv | Interconnection of audio/video devices |
US20020055934A1 (en) | 2000-01-24 | 2002-05-09 | Lipscomb Kenneth O. | Dynamic management and organization of media assets in a media player device |
US6389467B1 (en) | 2000-01-24 | 2002-05-14 | Friskit, Inc. | Streaming media search and continuous playback system of media resources located by multiple network addresses |
CN1416632A (en) | 2000-01-31 | 2003-05-07 | 爱普泰克微系统公司 | Broadband communications access device |
US6633314B1 (en) | 2000-02-02 | 2003-10-14 | Raja Tuli | Portable high speed internet device integrating cellular telephone and palm top computer |
US20010041021A1 (en) | 2000-02-04 | 2001-11-15 | Boyle Dennis J. | System and method for synchronization of image data between a handheld device and a computer |
US6778493B1 (en) * | 2000-02-07 | 2004-08-17 | Sharp Laboratories Of America, Inc. | Real-time media content synchronization and transmission in packet network apparatus and method |
US6248946B1 (en) | 2000-03-01 | 2001-06-19 | Ijockey, Inc. | Multimedia content delivery system and method |
US6798838B1 (en) | 2000-03-02 | 2004-09-28 | Koninklijke Philips Electronics N.V. | System and method for improving video transmission over a wireless network |
JP2001326914A (en) | 2000-03-08 | 2001-11-22 | Sony Corp | Distribution processing system for contents of electronic information, information distribution device, information processor and distribution processing method for contents of electronic information |
US6721489B1 (en) | 2000-03-08 | 2004-04-13 | Phatnoise, Inc. | Play list manager |
US20040193900A1 (en) | 2000-03-17 | 2004-09-30 | Mark Nair | System, method and apparatus for controlling the dissemination of digital works |
US6993251B1 (en) | 2000-03-31 | 2006-01-31 | Matsushita Electric Industrial Co., Ltd. | Method and apparatus for concealing disk soft errors in recorded digital television signals |
US6760721B1 (en) | 2000-04-14 | 2004-07-06 | Realnetworks, Inc. | System and method of managing metadata data |
US6636873B1 (en) | 2000-04-17 | 2003-10-21 | Oracle International Corporation | Methods and systems for synchronization of mobile devices with a remote database |
US8024419B2 (en) | 2000-05-12 | 2011-09-20 | Sony Corporation | Method and system for remote access of personal music |
US6956562B1 (en) | 2000-05-16 | 2005-10-18 | Palmsource, Inc. | Method for controlling a handheld computer by entering commands onto a displayed feature of the handheld computer |
US20010044835A1 (en) | 2000-05-17 | 2001-11-22 | Schober Joseph Frank | Selecting content to be communicated based on automatic detection of communication bandwidth |
US7343553B1 (en) | 2000-05-19 | 2008-03-11 | Evan John Kaye | Voice clip identification method |
JP3874235B2 (en) | 2000-05-29 | 2007-01-31 | ヤマハ株式会社 | Music playback device and portable terminal device |
US6874037B1 (en) | 2000-06-19 | 2005-03-29 | Sony Corporation | Method and apparatus for synchronizing device information |
KR100372589B1 (en) | 2000-06-26 | 2003-02-17 | 천길정 | Method for diagnosing the conditions of machine and diagnostic sensor |
US7075000B2 (en) | 2000-06-29 | 2006-07-11 | Musicgenome.Com Inc. | System and method for prediction of musical preferences |
JP2002083152A (en) | 2000-06-30 | 2002-03-22 | Victor Co Of Japan Ltd | Contents download system, portable terminal player, and contents provider |
AU2002224573A1 (en) | 2000-07-14 | 2002-02-05 | Infinite Broadcast Corporation | Multimedia player and browser system |
KR20020011027A (en) | 2000-07-31 | 2002-02-07 | 최병진 | Information input/output control method of moving communication terminal using computer |
US20020013784A1 (en) | 2000-07-31 | 2002-01-31 | Swanson Raymond H. | Audio data transmission system and method of operation thereof |
US6718348B1 (en) | 2000-08-25 | 2004-04-06 | Telefonaktiebolaget Lm Ericsson (Publ) | Non-time dependent synchronization of databases |
WO2002019096A2 (en) | 2000-08-31 | 2002-03-07 | Docubase | Reconfiguration and preservation of setup data |
US7142934B2 (en) | 2000-09-01 | 2006-11-28 | Universal Electronics Inc. | Audio converter device and method for using the same |
GB0023003D0 (en) | 2000-09-20 | 2000-11-01 | Koninkl Philips Electronics Nv | Method and apparatus for setting a parameter |
HRP20000624A2 (en) | 2000-09-20 | 2001-04-30 | Grabar Ivan | Mp3 jukebox |
US6490432B1 (en) | 2000-09-21 | 2002-12-03 | Command Audio Corporation | Distributed media on-demand information service |
JP2002108350A (en) | 2000-09-28 | 2002-04-10 | Internatl Business Mach Corp <Ibm> | Method and system for music distribution |
US6489986B1 (en) | 2000-09-29 | 2002-12-03 | Digeo, Inc. | Remote control device for video and audio capture and communication |
US6944880B1 (en) | 2000-09-29 | 2005-09-13 | Digeo, Inc. | Methods for audio capture and communication during television broadcasts |
US20020113824A1 (en) | 2000-10-12 | 2002-08-22 | Myers Thomas D. | Graphic user interface that is usable as a commercial digital jukebox interface |
US20020046315A1 (en) | 2000-10-13 | 2002-04-18 | Interactive Objects, Inc. | System and method for mapping interface functionality to codec functionality in a portable audio device |
US7667123B2 (en) | 2000-10-13 | 2010-02-23 | Phillips Mark E | System and method for musical playlist selection in a portable audio device |
JP3827518B2 (en) | 2000-10-23 | 2006-09-27 | シャープ株式会社 | Home network system |
WO2002037808A1 (en) | 2000-10-31 | 2002-05-10 | Sony Corporation | Information processing device, item display method, program storage medium |
US6529804B1 (en) | 2000-11-07 | 2003-03-04 | Motorola, Inc. | Method of and apparatus for enabling the selection of content on a multi-media device |
JP2002175139A (en) | 2000-12-07 | 2002-06-21 | Sony Corp | Information processor, menu display method and program storage medium |
US20020078075A1 (en) | 2000-12-15 | 2002-06-20 | Colson James C. | System, method, and program product for prioritizing synchronizable data |
GB0031221D0 (en) | 2000-12-21 | 2001-01-31 | Koninkl Philips Electronics Nv | Compressed-data processing arrangement and related method |
US8601519B1 (en) | 2000-12-28 | 2013-12-03 | At&T Intellectual Property I, L.P. | Digital residential entertainment system |
US6928433B2 (en) | 2001-01-05 | 2005-08-09 | Creative Technology Ltd | Automatic hierarchical categorization of music by metadata |
US6731312B2 (en) | 2001-01-08 | 2004-05-04 | Apple Computer, Inc. | Media player interface |
US20020138606A1 (en) | 2001-01-20 | 2002-09-26 | Jeremiah Robison | Method and apparatus for determining network connection by links |
US6630963B1 (en) * | 2001-01-23 | 2003-10-07 | Digeo, Inc. | Synchronizing a video program from a television broadcast with a secondary audio program |
WO2002065724A1 (en) | 2001-02-13 | 2002-08-22 | Mitsubishi Denki Kabushiki Kaisha | Multiple-level modulating method, multiple-level demodulating method, and multiple-level modulating/demodulating method |
US7133531B2 (en) | 2001-02-27 | 2006-11-07 | Nissim Karpenstein | Device using analog controls to mix compressed digital audio data |
US6785542B1 (en) | 2001-02-28 | 2004-08-31 | Palm Source, Inc. | Resource proxy for mobile wireless electronic devices |
US7216289B2 (en) | 2001-03-16 | 2007-05-08 | Microsoft Corporation | Method and apparatus for synchronizing multiple versions of digital data |
US7950037B2 (en) | 2001-03-16 | 2011-05-24 | Linda S. Mensch | Wireless entertainment system |
US6766407B1 (en) * | 2001-03-27 | 2004-07-20 | Microsoft Corporation | Intelligent streaming framework |
US20040250273A1 (en) | 2001-04-02 | 2004-12-09 | Bellsouth Intellectual Property Corporation | Digital video broadcast device decoder |
US20020156921A1 (en) | 2001-04-19 | 2002-10-24 | International Business Machines Corporation | Automatic backup of wireless mobile device data onto gateway server while device is idle |
US6947598B2 (en) | 2001-04-20 | 2005-09-20 | Front Porch Digital Inc. | Methods and apparatus for generating, including and using information relating to archived audio/video data |
US20020161865A1 (en) | 2001-04-25 | 2002-10-31 | Gateway, Inc. | Automated network configuration of connected device |
EP1253529A1 (en) | 2001-04-25 | 2002-10-30 | Sony France S.A. | Information type identification method and apparatus, e.g. for music file name content identification |
US7305691B2 (en) | 2001-05-07 | 2007-12-04 | Actv, Inc. | System and method for providing targeted programming outside of the home |
US7890661B2 (en) | 2001-05-16 | 2011-02-15 | Aol Inc. | Proximity synchronizing audio gateway device |
US8732232B2 (en) | 2001-05-16 | 2014-05-20 | Facebook, Inc. | Proximity synchronizing audio playback device |
US7010758B2 (en) | 2001-05-21 | 2006-03-07 | Leap Wireless International, Inc. | Dynamically defined context sensitive jump menu |
US7024491B1 (en) | 2001-05-23 | 2006-04-04 | Western Digital Ventures, Inc. | Remotely synchronizing a mobile terminal by adapting ordering and filtering synchronization rules based on a user's operation of the mobile terminal |
US8284739B2 (en) | 2001-05-24 | 2012-10-09 | Vixs Systems, Inc. | Method and apparatus for affiliating a wireless device with a wireless local area network |
US6993532B1 (en) | 2001-05-30 | 2006-01-31 | Microsoft Corporation | Auto playlist generator |
US7162543B2 (en) | 2001-06-06 | 2007-01-09 | Sap Ag | Process for synchronizing data between remotely located devices and a central computer system |
US7136934B2 (en) | 2001-06-19 | 2006-11-14 | Request, Inc. | Multimedia synchronization method and device |
KR100452581B1 (en) | 2001-06-20 | 2004-10-14 | (주)잉카엔트웍스 | Computer readable medium recording auto synchronization program that autosynchronize Internet contents with personal information processor and method for data synchronization |
US20020196912A1 (en) | 2001-06-26 | 2002-12-26 | Norris Mariah J. | Download and playback of audio content using short-distance wireless communication |
GB2393007B (en) | 2001-06-28 | 2005-08-03 | Trek 2000 Int Ltd | Method and devices for data transfer |
KR20040013113A (en) | 2001-07-06 | 2004-02-11 | 컴퓨터 어소시에이츠 싱크, 인코포레이티드 | Systems and methods of information backup |
US20030013332A1 (en) | 2001-07-12 | 2003-01-16 | Chih-Chiang Lin | Structure of plug-in power supply apparatus |
US20030018975A1 (en) | 2001-07-18 | 2003-01-23 | Stone Christopher J. | Method and system for wireless audio and video monitoring |
US6981259B2 (en) | 2001-08-02 | 2005-12-27 | Hewlett-Packard Development Company, L.P. | System and method for generating a virtual device |
JP2003051179A (en) | 2001-08-03 | 2003-02-21 | Sony Corp | Editing device and editing method |
US20030030733A1 (en) | 2001-08-08 | 2003-02-13 | Seaman Mark D. | System and method for synchronization of media data |
US7149813B2 (en) | 2001-08-14 | 2006-12-12 | Microsoft Corporation | Method and system for synchronizing mobile devices |
JP4936037B2 (en) | 2001-08-31 | 2012-05-23 | ソニー株式会社 | Information processing apparatus and method, and program |
BRPI0212368B1 (en) | 2001-09-06 | 2015-06-30 | Thomson Licensing Sa | Method for monitoring during processing of an audio data file having portions of data with different compression ratios and implementing audio data player |
EP1425746A1 (en) | 2001-09-10 | 2004-06-09 | Thomson Licensing S.A. | Method and apparatus for creating an indexed playlist in a digital audio data player |
JP3871274B2 (en) | 2001-09-10 | 2007-01-24 | トムソン ライセンシング | Method of adding contents information and index information of each playlist record to audio data file playlist |
BR0212418A (en) | 2001-09-11 | 2004-08-03 | Thomson Licensing Sa | Method and apparatus for activating automatic equalization mode |
US6965770B2 (en) | 2001-09-13 | 2005-11-15 | Nokia Corporation | Dynamic content delivery responsive to user requests |
JP4852228B2 (en) | 2001-09-26 | 2012-01-11 | インタラクト デヴァイシーズ インコーポレイテッド | System and method for communicating media signals |
US20030065802A1 (en) | 2001-09-28 | 2003-04-03 | Nokia Corporation | System and method for dynamically producing a multimedia content sample for mobile terminal preview |
US20030074457A1 (en) | 2001-10-17 | 2003-04-17 | Kluth Michael R. | Computer system with separable input device |
US7312785B2 (en) | 2001-10-22 | 2007-12-25 | Apple Inc. | Method and apparatus for accelerated scrolling |
US20030167318A1 (en) | 2001-10-22 | 2003-09-04 | Apple Computer, Inc. | Intelligent synchronization of media player with host computer |
JP4204977B2 (en) | 2001-10-22 | 2009-01-07 | アップル インコーポレイテッド | Intelligent sync operation for media players |
US6801964B1 (en) | 2001-10-25 | 2004-10-05 | Novell, Inc. | Methods and systems to fast fill media players |
US7721337B2 (en) | 2001-10-26 | 2010-05-18 | Ibiquity Digital Corporation | System and method for providing a push of background data |
US7184774B2 (en) | 2001-10-30 | 2007-02-27 | Motorola, Inc. | Coordination among mobile stations servicing terminal equipment |
US7043479B2 (en) | 2001-11-16 | 2006-05-09 | Sigmatel, Inc. | Remote-directed management of media content |
US7853341B2 (en) | 2002-01-25 | 2010-12-14 | Ksc Industries, Inc. | Wired, wireless, infrared, and powerline audio entertainment systems |
US20030158737A1 (en) | 2002-02-15 | 2003-08-21 | Csicsatka Tibor George | Method and apparatus for incorporating additional audio information into audio data file identifying information |
US7024214B2 (en) | 2002-02-26 | 2006-04-04 | Microsoft Corporation | Synchronizing over a number of synchronization mechanisms using flexible rules |
US7532862B2 (en) | 2002-03-19 | 2009-05-12 | Apple Inc. | Method and apparatus for configuring a wireless device through reverse advertising |
US6941324B2 (en) | 2002-03-21 | 2005-09-06 | Microsoft Corporation | Methods and systems for processing playlists |
US7430753B2 (en) | 2002-03-27 | 2008-09-30 | At&T Intellectual Property, I, L.P. | Method to enable cooperative processing and resource sharing between set-top boxes, personal computers, and local devices |
US9715500B2 (en) | 2004-04-27 | 2017-07-25 | Apple Inc. | Method and system for sharing playlists |
US7680849B2 (en) | 2004-10-25 | 2010-03-16 | Apple Inc. | Multiple media type synchronization between host computer and media device |
US20080086494A1 (en) | 2006-09-11 | 2008-04-10 | Apple Computer, Inc. | Transfer and synchronization of media data |
US7827259B2 (en) | 2004-04-27 | 2010-11-02 | Apple Inc. | Method and system for configurable automatic media selection |
US7797446B2 (en) | 2002-07-16 | 2010-09-14 | Apple Inc. | Method and system for updating playlists |
US8150937B2 (en) | 2004-10-25 | 2012-04-03 | Apple Inc. | Wireless synchronization between media player and host device |
KR100469422B1 (en) | 2002-04-08 | 2005-02-02 | 엘지전자 주식회사 | Method for browsing thumbnail image of mobile communication terminal |
JP3928852B2 (en) | 2002-04-08 | 2007-06-13 | ソニー・エリクソン・モバイルコミュニケーションズ株式会社 | Mobile communication terminal |
JP2003303137A (en) | 2002-04-09 | 2003-10-24 | Matsushita Electric Ind Co Ltd | Information processor, information processing method, and information processing program |
US6831881B2 (en) | 2002-04-09 | 2004-12-14 | Portalplayer, Inc. | Equalizer-effect media system and method |
US7146322B2 (en) | 2002-04-16 | 2006-12-05 | Sigmatel, Inc. | Interleaving of information into compressed digital audio streams |
JP2003319485A (en) | 2002-04-22 | 2003-11-07 | Pioneer Electronic Corp | Data transmission cord, data transmission head and headphone |
AU2003239385A1 (en) | 2002-05-10 | 2003-11-11 | Richard R. Reisman | Method and apparatus for browsing using multiple coordinated device |
US20040128198A1 (en) | 2002-05-15 | 2004-07-01 | Linwood Register | System and method for computer network-based enterprise media distribution |
US7437158B2 (en) | 2002-05-21 | 2008-10-14 | Incnetworks Inc. | Advanced multi-network client device for wideband multimedia access to private and public wireless networks |
US6987221B2 (en) | 2002-05-30 | 2006-01-17 | Microsoft Corporation | Auto playlist generation with multiple seed songs |
JP3778134B2 (en) | 2002-05-31 | 2006-05-24 | ヤマハ株式会社 | Music playback device |
JP3961347B2 (en) | 2002-06-19 | 2007-08-22 | シャープ株式会社 | Wireless receiver |
US20050021470A1 (en) | 2002-06-25 | 2005-01-27 | Bose Corporation | Intelligent music track selection |
US6996390B2 (en) | 2002-06-26 | 2006-02-07 | Microsoft Corporation | Smart car radio |
EP1520413A1 (en) | 2002-06-27 | 2005-04-06 | Koninklijke Philips Electronics N.V. | Controlling the content of a personalized visual channel |
US20040003151A1 (en) | 2002-07-01 | 2004-01-01 | Logitech Europe S.A. | Method and system for streaming transfer of data between a digital camera and a host |
KR100469099B1 (en) | 2002-07-02 | 2005-01-29 | 현대모비스 주식회사 | Coil spring mounting structure for suspension strut |
US7295809B2 (en) | 2002-07-19 | 2007-11-13 | Sony Ericsson Mobile Communications Ab | Portable audio playback device with bass enhancement |
US7228054B2 (en) | 2002-07-29 | 2007-06-05 | Sigmatel, Inc. | Automated playlist generation |
US7166791B2 (en) | 2002-07-30 | 2007-01-23 | Apple Computer, Inc. | Graphical user interface and methods of use thereof in a multimedia player |
US7956272B2 (en) | 2002-07-30 | 2011-06-07 | Apple Inc. | Management of files in a personal communication device |
GB0218961D0 (en) | 2002-08-15 | 2002-09-25 | Koninkl Philips Electronics Nv | Transmission method and system |
US9646339B2 (en) | 2002-09-16 | 2017-05-09 | Touchtunes Music Corporation | Digital downloading jukebox system with central and local music servers |
US7792799B2 (en) | 2002-10-10 | 2010-09-07 | Perlego Systems, Inc. | Backing up a wireless computing device |
JP4125089B2 (en) | 2002-10-22 | 2008-07-23 | キヤノン株式会社 | Data input device and data input method |
JP4028367B2 (en) | 2002-12-06 | 2007-12-26 | アルパイン株式会社 | Music data storage device and storage method |
US7296295B2 (en) | 2002-12-11 | 2007-11-13 | Broadcom Corporation | Media processing system supporting different media formats via server-based transcoding |
US20040117785A1 (en) | 2002-12-13 | 2004-06-17 | Samsung Electronics Co., Ltd. | Component download manager for a wireless mobile station and method of operation |
ATE361496T1 (en) | 2002-12-20 | 2007-05-15 | Koninkl Philips Electronics Nv | BACKUP DVD-RWS WITH PRECONFIGURATION |
US20040139180A1 (en) | 2003-01-10 | 2004-07-15 | Sony Corporation | Automobile media synchronization |
TW595227B (en) | 2003-03-05 | 2004-06-21 | Newsoft Technology Corp | One to many transmission method and system to transmit real-time video and audio data on wireless local area network |
TWI249924B (en) | 2003-03-11 | 2006-02-21 | Benq Corp | Universal media gateway |
US9274576B2 (en) | 2003-03-17 | 2016-03-01 | Callahan Cellular L.L.C. | System and method for activation of portable and mobile media player devices for wireless LAN services |
JP4570614B2 (en) | 2003-03-24 | 2010-10-27 | カルテンバッハ ウント ホイクト ゲゼルシャフト ミット ベシュレンクテル ハフツング | X-ray system with electronic sensor |
US7142250B1 (en) | 2003-04-05 | 2006-11-28 | Apple Computer, Inc. | Method and apparatus for synchronizing audio and video streams |
JP3825416B2 (en) * | 2003-04-14 | 2006-09-27 | 国立大学法人北陸先端科学技術大学院大学 | Data synchronization method, data synchronization system, and data synchronization program |
US7627343B2 (en) | 2003-04-25 | 2009-12-01 | Apple Inc. | Media player system |
US20040215534A1 (en) | 2003-04-25 | 2004-10-28 | Apple Computer, Inc. | Method and system for network-based allowance control |
KR100544481B1 (en) | 2003-05-13 | 2006-01-24 | 삼성전자주식회사 | Channel time allocation method in high rate WPAN |
US20040261040A1 (en) | 2003-06-23 | 2004-12-23 | Microsoft Corporation | Method and apparatus for media access control |
CN1810027A (en) | 2003-06-25 | 2006-07-26 | 皇家飞利浦电子股份有限公司 | Automatic and selective backup system on a home network |
US7107296B2 (en) | 2003-06-25 | 2006-09-12 | Microsoft Corporation | Media library synchronizer |
US20050010616A1 (en) | 2003-07-09 | 2005-01-13 | Burks David P. | System and method for restoring files |
TW200503608A (en) | 2003-07-15 | 2005-01-16 | Ind Tech Res Inst | Cooling plate having vortices generator |
US7418472B2 (en) | 2003-09-30 | 2008-08-26 | Microsoft Corporation | Systems and methods for determining remote device media capabilities |
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 |
US7996505B2 (en) | 2003-10-24 | 2011-08-09 | Microsoft Corporation | Network and interface selection on a computing device capable of establishing connections via multiple network communications media |
US6959562B2 (en) | 2003-12-15 | 2005-11-01 | The Coleman Company, Inc. | Portable frozen drink machine |
US7478381B2 (en) | 2003-12-15 | 2009-01-13 | Microsoft Corporation | Managing software updates and a software distribution service |
US7657706B2 (en) | 2003-12-18 | 2010-02-02 | Cisco Technology, Inc. | High speed memory and input/output processor subsystem for efficiently allocating and using high-speed memory and slower-speed memory |
US7336675B2 (en) | 2003-12-22 | 2008-02-26 | Intel Corporation | Optimized back-to-back enqueue/dequeue via physical queue parallelism |
US20050147130A1 (en) | 2003-12-23 | 2005-07-07 | Intel Corporation | Priority based synchronization of data in a personal area network |
US7266713B2 (en) | 2004-01-09 | 2007-09-04 | Intel Corporation | Apparatus and method for adaptation of time synchronization of a plurality of multimedia streams |
US20050201360A1 (en) | 2004-03-09 | 2005-09-15 | Redstone Douglas E. | Network radio-device and system for audio listening and broadcasting using a real-time transmission |
US20050207726A1 (en) | 2004-03-22 | 2005-09-22 | Jui-Ming Chen | Portable multimedia electronic device |
US20050235015A1 (en) | 2004-03-31 | 2005-10-20 | Microsoft Corporation | User-configurable device storage synchronization manager |
US7508815B2 (en) | 2004-03-31 | 2009-03-24 | Acterna Llc | Method and system for facilitating network troubleshooting |
US7606570B2 (en) | 2004-04-16 | 2009-10-20 | Broadcom Corporation | Method and system for extended network access notification via a broadband access gateway |
US20050235048A1 (en) | 2004-04-20 | 2005-10-20 | Jose Costa-Requena | Exchanging multimedia data via a communications device |
US20050265316A1 (en) | 2004-05-07 | 2005-12-01 | Hong Liu | Audio distribution |
US8762578B2 (en) | 2004-05-18 | 2014-06-24 | Koninklijke Philips N.V. | Method of data synchronization |
US8797926B2 (en) | 2004-06-04 | 2014-08-05 | Apple Inc. | Networked media station |
US20070110074A1 (en) | 2004-06-04 | 2007-05-17 | Bob Bradley | System and Method for Synchronizing Media Presentation at Multiple Recipients |
US8443038B2 (en) | 2004-06-04 | 2013-05-14 | Apple Inc. | Network media device |
US20080229335A1 (en) | 2004-06-04 | 2008-09-18 | Apple Computer, Inc. | Network media device |
US8214447B2 (en) | 2004-06-08 | 2012-07-03 | Bose Corporation | Managing an audio network |
US8566732B2 (en) | 2004-06-25 | 2013-10-22 | Apple Inc. | Synchronization of widgets and dashboards |
US7631119B2 (en) | 2004-06-25 | 2009-12-08 | Apple Inc. | Techniques for providing audio for synchronized playback by multiple devices |
US7196260B2 (en) | 2004-08-05 | 2007-03-27 | Motorola, Inc. | Entry of musical data in a mobile communication device |
TWI262148B (en) | 2004-09-22 | 2006-09-21 | Yamaha Motor Co Ltd | Headlight assembly structure for a motorcycle |
TWI280029B (en) | 2004-10-27 | 2007-04-21 | Inst Information Industry | Method and system for data authorization and mobile device using the same |
US20060106806A1 (en) | 2004-11-12 | 2006-05-18 | Smith Micro Software, Inc. | Software update for a plurality of mobile devices |
WO2006066052A2 (en) | 2004-12-16 | 2006-06-22 | Sonic Solutions | Methods and systems for use in network management of content |
US20060143455A1 (en) | 2004-12-28 | 2006-06-29 | Gitzinger Thomas E | Method and apparatus for secure pairing |
US7617513B2 (en) | 2005-01-04 | 2009-11-10 | Avocent Huntsville Corporation | Wireless streaming media systems, devices and methods |
US7389095B1 (en) * | 2005-01-24 | 2008-06-17 | Nvidia Corporation | Variable frequency clock generator for synchronizing data rates between clock domains in radio frequency wireless communication systems |
US7281141B2 (en) | 2005-01-31 | 2007-10-09 | Powersdsine, Ltd.-Microsemi Corporation | Bypass discharge path for a power sourcing equipment |
US7647346B2 (en) | 2005-03-29 | 2010-01-12 | Microsoft Corporation | Automatic rules-based device synchronization |
US7903690B2 (en) | 2005-04-28 | 2011-03-08 | Hewlett-Packard Development Company, L.P. | Method and system of sending an audio stream and a data stream |
US20060253279A1 (en) | 2005-05-04 | 2006-11-09 | Sung Chih-Ta S | Method and apparatus of wireless audio playback system |
US20060277216A1 (en) | 2005-06-02 | 2006-12-07 | Metalink Ltd. | Portable media storage device with wireless network connectivity |
EP2582158B1 (en) | 2005-06-05 | 2016-08-10 | Starkey Laboratories, Inc. | Communication system for wireless audio devices |
US20060288057A1 (en) | 2005-06-15 | 2006-12-21 | Ian Collins | Portable data backup appliance |
US9356982B2 (en) | 2005-08-05 | 2016-05-31 | Intel Corporation | System and method for transferring playlists |
US7676394B2 (en) | 2005-09-14 | 2010-03-09 | Jumptap, Inc. | Dynamic bidding and expected value |
US20080028008A1 (en) | 2006-07-31 | 2008-01-31 | Storage Appliance Corporation | Optical disc initiated data backup |
US9665629B2 (en) | 2005-10-14 | 2017-05-30 | Yahoo! Inc. | Media device and user interface for selecting media |
KR100678921B1 (en) | 2005-10-18 | 2007-02-05 | 삼성전자주식회사 | Method and apparatus for synchronizing multimedia contents with device which supports plural server environment |
KR100599204B1 (en) | 2005-11-11 | 2006-07-12 | 주식회사 리얼타임테크 | Wire and radio data synchronization system for mobile environment and synchronization method using the same |
US7702279B2 (en) | 2005-12-20 | 2010-04-20 | Apple Inc. | Portable media player as a low power remote control and method thereof |
US7464117B2 (en) | 2006-01-20 | 2008-12-09 | Microsoft Corporation | Using directory historical data to facilitate automated file updates |
US7693832B2 (en) | 2006-02-28 | 2010-04-06 | Microsoft Corporation | Rich set of synchronization rules across multiple accounts with multiple folder and consent types |
US7653761B2 (en) | 2006-03-15 | 2010-01-26 | Microsoft Corporation | Automatic delivery of personalized content to a portable media player with feedback |
US7634227B2 (en) | 2006-03-29 | 2009-12-15 | Sony Ericsson Mobile Communications Ab | Method and system for controlling audio data playback in an accessory device |
US7444388B1 (en) | 2006-04-13 | 2008-10-28 | Concert Technology Corporation | System and method for obtaining media content for a portable media player |
US7936484B2 (en) | 2006-06-14 | 2011-05-03 | Ronald Gabriel Roncal | Internet-based synchronized imaging |
US8479288B2 (en) | 2006-07-21 | 2013-07-02 | Research In Motion Limited | Method and system for providing a honeypot mode for an electronic device |
US9386269B2 (en) | 2006-09-07 | 2016-07-05 | Rateze Remote Mgmt Llc | Presentation of data on multiple display devices using a wireless hub |
EP1942528A1 (en) | 2007-01-04 | 2008-07-09 | Interuniversitair Microelektronica Centrum | Electronic device and process for manufacturing the same |
US8850140B2 (en) | 2007-01-07 | 2014-09-30 | Apple Inc. | Data backup for mobile device |
US10083184B2 (en) | 2007-01-07 | 2018-09-25 | Apple Inc. | Widget synchronization in accordance with synchronization preferences |
US20080168525A1 (en) | 2007-01-07 | 2008-07-10 | David Heller | Background Data Transmission between Media Device and Host Device |
US20080168185A1 (en) | 2007-01-07 | 2008-07-10 | Robbin Jeffrey L | Data Synchronization with Host Device in Accordance with Synchronization Preferences |
US8631088B2 (en) | 2007-01-07 | 2014-01-14 | Apple Inc. | Prioritized data synchronization with host device |
US20090290725A1 (en) | 2008-05-22 | 2009-11-26 | Apple Inc. | Automatic equalizer adjustment setting for playback of media assets |
US9094768B2 (en) | 2012-08-02 | 2015-07-28 | Crestron Electronics Inc. | Loudspeaker calibration using multiple wireless microphones |
US9826012B2 (en) * | 2013-11-12 | 2017-11-21 | Verizon and Redbox Digital Entertainment Services, LLC | Establishment and synchronization of a virtual theater based on transaction information and playback preference information |
US9763018B1 (en) | 2016-04-12 | 2017-09-12 | Sonos, Inc. | Calibration of audio playback devices |
-
2006
- 2006-01-02 US US11/306,557 patent/US20070110074A1/en not_active Abandoned
- 2006-12-13 WO PCT/US2006/062003 patent/WO2007079334A2/en active Application Filing
- 2006-12-13 EP EP10195366.9A patent/EP2290899B1/en active Active
- 2006-12-13 EP EP06846592.1A patent/EP1969810B1/en active Active
- 2006-12-13 EP EP18174801.3A patent/EP3389239B1/en active Active
-
2007
- 2007-04-04 US US11/696,679 patent/US8681822B2/en active Active
-
2014
- 2014-01-29 US US14/167,742 patent/US9729630B2/en not_active Expired - Lifetime
-
2017
- 2017-07-25 US US15/659,603 patent/US10264070B2/en not_active Expired - Lifetime
Patent Citations (99)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4807224A (en) * | 1987-08-21 | 1989-02-21 | Naron Steven E | Multicast data distribution system and method |
US5553222A (en) * | 1993-05-10 | 1996-09-03 | Taligent, Inc. | Multimedia synchronization system |
US6092119A (en) * | 1994-02-14 | 2000-07-18 | Sony Corporation | Random access audio/video processor with compressed video resampling to allow higher bandwidth throughput |
US5664044A (en) * | 1994-04-28 | 1997-09-02 | International Business Machines Corporation | Synchronized, variable-speed playback of digitally recorded audio and video |
US5790521A (en) * | 1994-08-01 | 1998-08-04 | The University Of Iowa Research Foundation | Marking mechanism for controlling consecutive packet loss in ATM networks |
US5664226A (en) * | 1994-09-08 | 1997-09-02 | International Business Machines Corporation | System for merging plurality of atomic data elements into single synchronized file by assigning ouput rate to each channel in response to presentation time duration |
US6587480B1 (en) * | 1995-03-13 | 2003-07-01 | Cisco Technology, Inc. | Multimedia client for multimedia/hybrid network |
US5953350A (en) * | 1995-03-13 | 1999-09-14 | Selsius Systems, Inc. | Multimedia client for multimedia/hybrid network |
US5722041A (en) * | 1995-12-05 | 1998-02-24 | Altec Lansing Technologies, Inc. | Hybrid home-entertainment system |
US5875354A (en) * | 1996-03-01 | 1999-02-23 | Apple Computer, Inc. | System for synchronization by modifying the rate of conversion by difference of rate between first clock and audio clock during a second time period |
US6085252A (en) * | 1996-04-23 | 2000-07-04 | Motorola Inc. | Device, system and method for real-time multimedia streaming |
US6212359B1 (en) * | 1996-07-15 | 2001-04-03 | Gregory D. Knox | Wireless Transceiver System For Digital Music |
US7502604B2 (en) * | 1996-07-15 | 2009-03-10 | Dima Wireless, Llc | Wireless environment method and apparatus |
US6757913B2 (en) * | 1996-07-15 | 2004-06-29 | Gregory D. Knox | Wireless music and data transceiver system |
US6243772B1 (en) * | 1997-01-31 | 2001-06-05 | Sharewave, Inc. | Method and system for coupling a personal computer with an appliance unit via a wireless communication link to provide an output display presentation |
US6282714B1 (en) * | 1997-01-31 | 2001-08-28 | Sharewave, Inc. | Digital wireless home computer system |
US5931906A (en) * | 1997-04-18 | 1999-08-03 | Creative Communications Group | System for creating a multimedia presentation by integrating local program materials with remotely accessible program materials |
US6101591A (en) * | 1998-03-25 | 2000-08-08 | International Business Machines Corporation | Method and system for selectively independently or simultaneously updating multiple system time clocks in an MPEG system |
US7096271B1 (en) * | 1998-09-15 | 2006-08-22 | Microsoft Corporation | Managing timeline modification and synchronization of multiple media streams in networked client/server systems |
US7174560B1 (en) * | 1999-02-25 | 2007-02-06 | Sharp Laboratories Of America, Inc. | Method of synchronizing events with a digital television audio-visual program |
US20010021998A1 (en) * | 1999-05-26 | 2001-09-13 | Neal Margulis | Apparatus and method for effectively implementing a wireless television system |
US6263503B1 (en) * | 1999-05-26 | 2001-07-17 | Neal Margulis | Method for effectively implementing a wireless television system |
US6744738B1 (en) * | 1999-06-12 | 2004-06-01 | Samsung Electronics Co., Ltd. | Wireless communication system for video packet transmission |
US6845398B1 (en) * | 1999-08-02 | 2005-01-18 | Lucent Technologies Inc. | Wireless multimedia player |
US7016443B1 (en) * | 1999-08-06 | 2006-03-21 | Siemens Aktiengesellschaft | Synchronization method and system for clock signal sources, in particular in packet transmission communication systems |
US6920179B1 (en) * | 1999-11-16 | 2005-07-19 | Agere Systems Inc. | Method and apparatus for video transmission over a heterogeneous network using progressive video coding |
US7689095B2 (en) * | 2000-01-11 | 2010-03-30 | Sony Corporation | Electronic device system |
US20010021305A1 (en) * | 2000-01-11 | 2001-09-13 | Nobukazu Sugiyama | Electronic device system |
US20020019984A1 (en) * | 2000-01-14 | 2002-02-14 | Rakib Selim Shlomo | Headend cherrypicker with digital video recording capability |
US20020013852A1 (en) * | 2000-03-03 | 2002-01-31 | Craig Janik | System for providing content, management, and interactivity for thin client devices |
US6985966B1 (en) * | 2000-03-29 | 2006-01-10 | Microsoft Corporation | Resynchronizing globally unsynchronized multimedia streams |
US6684060B1 (en) * | 2000-04-11 | 2004-01-27 | Agere Systems Inc. | Digital wireless premises audio system and method of operation thereof |
US6766376B2 (en) * | 2000-09-12 | 2004-07-20 | Sn Acquisition, L.L.C | Streaming media buffering system |
US6374177B1 (en) * | 2000-09-20 | 2002-04-16 | Motorola, Inc. | Method and apparatus for providing navigational services in a wireless communication device |
US20040128402A1 (en) * | 2000-09-27 | 2004-07-01 | Weaver David John | Architecture for optimizing audio and video output states for multimeda devices |
US20060069724A1 (en) * | 2000-09-28 | 2006-03-30 | Qwest Communications International Inc. | Portable wireless player and associated method |
US6529233B1 (en) * | 2000-09-29 | 2003-03-04 | Digeo, Inc. | Systems and methods for remote video and audio capture and communication |
US6397388B1 (en) * | 2000-09-29 | 2002-05-28 | Digeo, Inc. | Systems and devices for audio capture and communication during television broadcasts |
US6728585B2 (en) * | 2000-10-03 | 2004-04-27 | Freesystems Pte, Ltd. | Personal on-demand audio entertainment device that is untethered and allows wireless download of content |
US7200357B2 (en) * | 2000-10-20 | 2007-04-03 | Universal Electronics Inc. | Automotive storage and playback device and method for using the same |
US20020074413A1 (en) * | 2000-12-19 | 2002-06-20 | Henzerling David P. | Wireless music device and method therefor |
US7346698B2 (en) * | 2000-12-20 | 2008-03-18 | G. W. Hannaway & Associates | Webcasting method and system for time-based synchronization of multiple, independent media streams |
US7698723B2 (en) * | 2000-12-28 | 2010-04-13 | At&T Intellectual Property I, L.P. | System and method for multimedia on demand services |
US20020103554A1 (en) * | 2001-01-29 | 2002-08-01 | Hewlett-Packard Company | Interactive audio system |
US20030134589A1 (en) * | 2001-03-07 | 2003-07-17 | Masaru Oba | Porable radio terminal with musuc data download function |
US20060117371A1 (en) * | 2001-03-15 | 2006-06-01 | Digital Display Innovations, Llc | Method for effectively implementing a multi-room television system |
US20030013492A1 (en) * | 2001-07-10 | 2003-01-16 | Bokhari Wasiq Mahood | System, method and computer program product for a content publisher for wireless devices |
US7047308B2 (en) * | 2001-08-31 | 2006-05-16 | Sharp Laboratories Of America, Inc. | System and method for simultaneous media playout |
US7082320B2 (en) * | 2001-09-04 | 2006-07-25 | Telefonaktiebolaget Lm Ericsson (Publ) | Integration of wireless LAN and cellular distributed antenna |
US7185084B2 (en) * | 2001-09-05 | 2007-02-27 | Intel Corporation | Server-side measurement of client-perceived quality of service |
US20030083954A1 (en) * | 2001-10-25 | 2003-05-01 | Takaaki Namba | Content usage rule management system |
US7076204B2 (en) * | 2001-10-30 | 2006-07-11 | Unwired Technology Llc | Multiple channel wireless communication system |
US7359671B2 (en) * | 2001-10-30 | 2008-04-15 | Unwired Technology Llc | Multiple channel wireless communication system |
US7391791B2 (en) * | 2001-12-17 | 2008-06-24 | Implicit Networks, Inc. | Method and system for synchronization of content rendering |
US20030131360A1 (en) * | 2002-01-10 | 2003-07-10 | Joung Chul Yong | Interfacing system for stream source device and display apparatus and interfacing method thereof |
US7034891B2 (en) * | 2002-02-01 | 2006-04-25 | Lg Electronics Inc. | Interfacing system for stream source apparatus and display apparatus and interfacing method thereof |
US7369532B2 (en) * | 2002-02-26 | 2008-05-06 | Intel Corporation | Apparatus and method for an audio channel switching wireless device |
US20040072584A1 (en) * | 2002-03-01 | 2004-04-15 | Kern Ronald J. | Wireless distribution of multimedia content |
US7519686B2 (en) * | 2002-05-30 | 2009-04-14 | Icube | Wireless receiver for receiving multi-contents file and method for outputting data using the same |
US20040001494A1 (en) * | 2002-07-01 | 2004-01-01 | Zarlink Semiconductor V.N. Inc | Architecture for obtaining playback time from a packet sequence number in AAL2 SSCS voice |
US20040057446A1 (en) * | 2002-07-16 | 2004-03-25 | Nokia Corporation | Method for enabling packet transfer delay compensation in multimedia streaming |
US7260714B2 (en) * | 2002-08-20 | 2007-08-21 | Sony Corporation | System and method for authenticating wireless component |
US7539777B1 (en) * | 2002-10-25 | 2009-05-26 | Cisco Technology, Inc. | Method and system for network time protocol forwarding |
US7024575B2 (en) * | 2002-11-14 | 2006-04-04 | Intel Corporation | Apparatus and method for time synchronization of a plurality of multimedia streams |
US20040132510A1 (en) * | 2002-12-26 | 2004-07-08 | Kabushiki Kaisha Toshiba | Wireless sound apparatus, and audio acquisition method in the apparatus |
US20040133908A1 (en) * | 2003-01-03 | 2004-07-08 | Broadq, Llc | Digital media system and method therefor |
US20040143442A1 (en) * | 2003-01-22 | 2004-07-22 | Knight Erik A. | Multiple-language audio information transmission system and device |
US20040157548A1 (en) * | 2003-02-06 | 2004-08-12 | Eyer Mark Kenneth | Home network interface legacy device adapter |
US20040177063A1 (en) * | 2003-03-06 | 2004-09-09 | Weber Barry Jay | Simplified searching for media services using a control device |
US20040174896A1 (en) * | 2003-03-07 | 2004-09-09 | Rami Caspi | System and method for digital personal video stream manager |
US20040177371A1 (en) * | 2003-03-07 | 2004-09-09 | Rami Caspi | System and method for integrated communications center |
US20050174488A1 (en) * | 2003-03-10 | 2005-08-11 | Sandeep Chennakeshu | Methods, devices, and systems for displaying information from a remote electronic device |
US6728729B1 (en) * | 2003-04-25 | 2004-04-27 | Apple Computer, Inc. | Accessing media across networks |
US7698297B2 (en) * | 2003-04-25 | 2010-04-13 | Apple Inc. | Accessing digital media |
US7474677B2 (en) * | 2003-08-12 | 2009-01-06 | Bose Corporation | Wireless communicating |
US20050071375A1 (en) * | 2003-09-30 | 2005-03-31 | Phil Houghton | Wireless media player |
US7084898B1 (en) * | 2003-11-18 | 2006-08-01 | Cisco Technology, Inc. | System and method for providing video conferencing synchronization |
US7406294B1 (en) * | 2003-11-25 | 2008-07-29 | Frank Kung Fu Liu | Digital audio file reproduction system and method with wireless transfer capability |
US7561215B2 (en) * | 2004-01-06 | 2009-07-14 | Samsung Electronics Co., Ltd. | Method and apparatus for wirelessly controlling devices peripheral to AV device |
US7483538B2 (en) * | 2004-03-02 | 2009-01-27 | Ksc Industries, Inc. | Wireless and wired speaker hub for a home theater system |
US20060015580A1 (en) * | 2004-07-01 | 2006-01-19 | Home Box Office, A Delaware Corporation | Multimedia content distribution |
US20060007943A1 (en) * | 2004-07-07 | 2006-01-12 | Fellman Ronald D | Method and system for providing site independent real-time multimedia transport over packet-switched networks |
US20060030961A1 (en) * | 2004-08-06 | 2006-02-09 | Jeng-Tay Lin | Wireless streaming audio apparatus |
US20060062243A1 (en) * | 2004-09-23 | 2006-03-23 | Dacosta Behram M | Reliable audio-video transmission system using multi-media diversity |
US20060062242A1 (en) * | 2004-09-23 | 2006-03-23 | Sony Corporation | Reliable audio-video transmission system using multi-media diversity |
US20060074637A1 (en) * | 2004-10-01 | 2006-04-06 | Microsoft Corporation | Low latency real-time audio streaming |
US20060083194A1 (en) * | 2004-10-19 | 2006-04-20 | Ardian Dhrimaj | System and method rendering audio/image data on remote devices |
US7505483B2 (en) * | 2004-11-03 | 2009-03-17 | Electronics And Telecommunications Research Institute | Apparatus for transmitting WPAN MAC frames and method thereof |
US20060092844A1 (en) * | 2004-11-03 | 2006-05-04 | Electronics And Telecommunications Research Institute | Apparatus for transmitting WPAN MAC frames and method thereof |
US7477653B2 (en) * | 2004-12-10 | 2009-01-13 | Microsoft Corporation | Accelerated channel change in rate-limited environments |
US20060126667A1 (en) * | 2004-12-10 | 2006-06-15 | Microsoft Corporation | Accelerated channel change in rate-limited environments |
US7370129B2 (en) * | 2004-12-15 | 2008-05-06 | Microsoft Corporation | Retry strategies for use in a streaming environment |
US20060167982A1 (en) * | 2005-01-07 | 2006-07-27 | Apple Computer, Inc. | Restricted media sharing over networks |
US7542784B2 (en) * | 2005-02-25 | 2009-06-02 | Kleer Semiconductor Corporation | High quality, low power, wireless audio system |
US7519681B2 (en) * | 2005-06-30 | 2009-04-14 | Intel Corporation | Systems, methods, and media for discovering remote user interface applications over a network |
US7555291B2 (en) * | 2005-08-26 | 2009-06-30 | Sony Ericsson Mobile Communications Ab | Mobile wireless communication terminals, systems, methods, and computer program products for providing a song play list |
US7480746B2 (en) * | 2005-09-06 | 2009-01-20 | Home Xperience, Inc. | Extensible universal home automation integration framework and user interface |
US7577261B2 (en) * | 2005-10-13 | 2009-08-18 | Realtek Semiconductor Corp. | Wireless audio system using wireless local area network |
US7724780B2 (en) * | 2007-04-19 | 2010-05-25 | Cisco Technology, Ink. | Synchronization of one or more source RTP streams at multiple receiver destinations |
Cited By (204)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9246633B2 (en) | 1998-09-23 | 2016-01-26 | Digital Fountain, Inc. | Information additive code generator and decoder for communication systems |
US11204729B2 (en) | 2000-11-01 | 2021-12-21 | Flexiworld Technologies, Inc. | Internet based digital content services for pervasively providing protected digital content to smart devices based on having subscribed to the digital content service |
US11169756B2 (en) | 2000-11-20 | 2021-11-09 | Flexijet Technologies, Inc. | Method for capturing, storing, accessing, and outputting digital content |
US9236976B2 (en) | 2001-12-21 | 2016-01-12 | Digital Fountain, Inc. | Multi stage code generator and decoder for communication systems |
US9240810B2 (en) | 2002-06-11 | 2016-01-19 | Digital Fountain, Inc. | Systems and processes for decoding chain reaction codes through inactivation |
US9236885B2 (en) | 2002-10-05 | 2016-01-12 | Digital Fountain, Inc. | Systematic encoding and decoding of chain reaction codes |
US20090189792A1 (en) * | 2002-10-05 | 2009-07-30 | Shokrollahi M Amin | Systematic encoding and decoding of chain reaction codes |
USRE43741E1 (en) | 2002-10-05 | 2012-10-16 | Qualcomm Incorporated | Systematic encoding and decoding of chain reaction codes |
US20220229631A1 (en) * | 2003-07-28 | 2022-07-21 | Sonos, Inc | Synchronizing Playback by Media Playback Devices |
US11550536B2 (en) | 2003-07-28 | 2023-01-10 | Sonos, Inc. | Adjusting volume levels |
US11556305B2 (en) * | 2003-07-28 | 2023-01-17 | Sonos, Inc. | Synchronizing playback by media playback devices |
US11625221B2 (en) * | 2003-07-28 | 2023-04-11 | Sonos, Inc | Synchronizing playback by media playback devices |
US11635935B2 (en) | 2003-07-28 | 2023-04-25 | Sonos, Inc. | Adjusting volume levels |
US11650784B2 (en) | 2003-07-28 | 2023-05-16 | Sonos, Inc. | Adjusting volume levels |
US8887020B2 (en) | 2003-10-06 | 2014-11-11 | Digital Fountain, Inc. | Error-correcting multi-stage code generator and decoder for communication systems having single transmitters or multiple transmitters |
US8175097B2 (en) | 2003-10-24 | 2012-05-08 | Microsoft Corporation | Embedding a session description message in a real-time control protocol (RTCP) message |
US7492769B2 (en) * | 2003-10-24 | 2009-02-17 | Microsoft Corporation | Embedding a session description message in a real-time control protocol (RTCP) message |
US7586938B2 (en) | 2003-10-24 | 2009-09-08 | Microsoft Corporation | Methods and systems for self-describing multicasting of multimedia presentations |
US20090106443A1 (en) * | 2003-10-24 | 2009-04-23 | Microsoft Corporation | Embedding a Session Description Message in a Real-Time Control Protocol (RTCP) Message |
US20050089035A1 (en) * | 2003-10-24 | 2005-04-28 | Klemets Anders E. | Methods and systems for self-describing multicasting of multimedia presentations |
US20050091190A1 (en) * | 2003-10-24 | 2005-04-28 | Microsoft Corporation | Embedding a session description message in a real-time control protocol (RTCP) message |
US11467799B2 (en) | 2004-04-01 | 2022-10-11 | Sonos, Inc. | Guest access to a media playback system |
US11907610B2 (en) | 2004-04-01 | 2024-02-20 | Sonos, Inc. | Guess access to a media playback system |
US9236887B2 (en) | 2004-05-07 | 2016-01-12 | Digital Fountain, Inc. | File download and streaming system |
US9136878B2 (en) | 2004-05-07 | 2015-09-15 | Digital Fountain, Inc. | File download and streaming system |
US10264070B2 (en) | 2004-06-04 | 2019-04-16 | Apple Inc. | System and method for synchronizing media presentation at multiple recipients |
US10986148B2 (en) | 2004-06-04 | 2021-04-20 | Apple Inc. | Network media device |
US9894505B2 (en) | 2004-06-04 | 2018-02-13 | Apple Inc. | Networked media station |
US9729630B2 (en) | 2004-06-04 | 2017-08-08 | Apple Inc. | System and method for synchronizing media presentation at multiple recipients |
US10200430B2 (en) | 2004-06-04 | 2019-02-05 | Apple Inc. | Network media device |
US10972536B2 (en) | 2004-06-04 | 2021-04-06 | Apple Inc. | System and method for synchronizing media presentation at multiple recipients |
US9876830B2 (en) | 2004-06-04 | 2018-01-23 | Apple Inc. | Network media device |
US9448683B2 (en) | 2004-06-04 | 2016-09-20 | Apple Inc. | Network media device |
US20090245249A1 (en) * | 2005-08-29 | 2009-10-01 | Nec Corporation | Multicast node apparatus, multicast transfer method and program |
US9136983B2 (en) * | 2006-02-13 | 2015-09-15 | Digital Fountain, Inc. | Streaming and buffering using variable FEC overhead and protection periods |
US20070204196A1 (en) * | 2006-02-13 | 2007-08-30 | Digital Fountain, Inc. | Streaming and buffering using variable fec overhead and protection periods |
US9270414B2 (en) | 2006-02-21 | 2016-02-23 | Digital Fountain, Inc. | Multiple-field based code generator and decoder for communications systems |
US9264069B2 (en) | 2006-05-10 | 2016-02-16 | Digital Fountain, Inc. | Code generator and decoder for communications systems operating using hybrid codes to allow for multiple efficient uses of the communications systems |
US9209934B2 (en) | 2006-06-09 | 2015-12-08 | Qualcomm Incorporated | Enhanced block-request streaming using cooperative parallel HTTP and forward error correction |
US11477253B2 (en) | 2006-06-09 | 2022-10-18 | Qualcomm Incorporated | Enhanced block-request streaming system using signaling or block creation |
US9178535B2 (en) | 2006-06-09 | 2015-11-03 | Digital Fountain, Inc. | Dynamic stream interleaving and sub-stream based delivery |
US9432433B2 (en) | 2006-06-09 | 2016-08-30 | Qualcomm Incorporated | Enhanced block-request streaming system using signaling or block creation |
US9191151B2 (en) | 2006-06-09 | 2015-11-17 | Qualcomm Incorporated | Enhanced block-request streaming using cooperative parallel HTTP and forward error correction |
US9380096B2 (en) | 2006-06-09 | 2016-06-28 | Qualcomm Incorporated | Enhanced block-request streaming system for handling low-latency streaming |
US9386064B2 (en) | 2006-06-09 | 2016-07-05 | Qualcomm Incorporated | Enhanced block-request streaming using URL templates and construction rules |
US20110072150A1 (en) * | 2006-09-08 | 2011-03-24 | Oliverio James C | System and Methods for Synchronizing Performances of Geographically-Disparate Performers |
US20080065925A1 (en) * | 2006-09-08 | 2008-03-13 | Oliverio James C | System and methods for synchronizing performances of geographically-disparate performers |
US8745496B2 (en) | 2006-09-21 | 2014-06-03 | Apple Inc. | Variable I/O interface for portable media device |
US20080077619A1 (en) * | 2006-09-21 | 2008-03-27 | Apple Inc. | Systems and methods for facilitating group activities |
US8429223B2 (en) * | 2006-09-21 | 2013-04-23 | Apple Inc. | Systems and methods for facilitating group activities |
US11157150B2 (en) | 2006-09-21 | 2021-10-26 | Apple Inc. | Variable I/O interface for portable media device |
US9864491B2 (en) | 2006-09-21 | 2018-01-09 | Apple Inc. | Variable I/O interface for portable media device |
US10534514B2 (en) | 2006-09-21 | 2020-01-14 | Apple Inc. | Variable I/O interface for portable media device |
US8001472B2 (en) | 2006-09-21 | 2011-08-16 | Apple Inc. | Systems and methods for providing audio and visual cues via a portable electronic device |
US9646137B2 (en) | 2006-09-21 | 2017-05-09 | Apple Inc. | Systems and methods for providing audio and visual cues via a portable electronic device |
US8235724B2 (en) | 2006-09-21 | 2012-08-07 | Apple Inc. | Dynamically adaptive scheduling system |
US8956290B2 (en) | 2006-09-21 | 2015-02-17 | Apple Inc. | Lifestyle companion system |
US9881326B2 (en) | 2006-09-21 | 2018-01-30 | Apple Inc. | Systems and methods for facilitating group activities |
US20130067124A1 (en) * | 2007-03-26 | 2013-03-14 | Itay Sherman | Small removable audio player that attaches to a host media player |
US8612655B2 (en) * | 2007-03-26 | 2013-12-17 | Google Inc. | Small removable audio player that attaches to a host media player |
US8892795B2 (en) | 2007-03-26 | 2014-11-18 | Google Inc. | Small removable audio player that attaches to a host media player |
US11019381B2 (en) * | 2007-05-11 | 2021-05-25 | Audinate Pty Limited | Systems, methods and computer-readable media for configuring receiver latency |
US20190349617A1 (en) * | 2007-05-11 | 2019-11-14 | Audinate Pty Limited | Systems, Methods and Computer-Readable Media for Configuring Receiver Latency |
US11831935B2 (en) | 2007-05-11 | 2023-11-28 | Audinate Holdings Pty Limited | Systems, methods and computer-readable media for configuring receiver latency |
US20080306710A1 (en) * | 2007-06-08 | 2008-12-11 | Michael Holtzman | Method for improving accuracy of a time estimate from a memory device |
US20100024000A1 (en) * | 2007-06-08 | 2010-01-28 | Michael Holtzman | Method for improving accuracy of a time estimate used in digital rights management (DRM) license validation |
US20080307237A1 (en) * | 2007-06-08 | 2008-12-11 | Michael Holtzman | Method for improving accuracy of a time estimate used to authenticate an entity to a memory device |
US8869288B2 (en) | 2007-06-08 | 2014-10-21 | Sandisk Technologies Inc. | Method for using time from a trusted host device |
US20080307508A1 (en) * | 2007-06-08 | 2008-12-11 | Conley Kevin M | Method for using time from a trusted host device |
US8688924B2 (en) * | 2007-06-08 | 2014-04-01 | Sandisk Technologies Inc. | Method for improving accuracy of a time estimate from a memory device |
US8688588B2 (en) | 2007-06-08 | 2014-04-01 | Sandisk Technologies Inc. | Method for improving accuracy of a time estimate used in digital rights management (DRM) license validation |
US20080304364A1 (en) * | 2007-06-08 | 2008-12-11 | Michael Holtzman | Memory device with circuitry for improving accuracy of a time estimate |
US20090010283A1 (en) * | 2007-07-03 | 2009-01-08 | Arcadyan Technology Corporation | Synchronization method of electronic apparatuses |
US7936794B2 (en) * | 2007-08-07 | 2011-05-03 | Avaya Inc. | Clock management between two end points |
US20090041020A1 (en) * | 2007-08-07 | 2009-02-12 | Avaya Technology Llc | Clock management between two endpoints |
US9237101B2 (en) | 2007-09-12 | 2016-01-12 | Digital Fountain, Inc. | Generating and communicating source identification information to enable reliable communications |
US20090067551A1 (en) * | 2007-09-12 | 2009-03-12 | Digital Fountain, Inc. | Generating and communicating source identification information to enable reliable communications |
US8767778B2 (en) * | 2008-07-28 | 2014-07-01 | Imagine Communications Corp. | Method, system and apparatus for synchronizing signals |
US20100135334A1 (en) * | 2008-07-28 | 2010-06-03 | Harris Corporation, Corporation Of The State Of Delaware | Method, system and apparatus for synchronizing signals |
US8776144B2 (en) * | 2008-10-16 | 2014-07-08 | Industrial Technology Research Institute | Mobile TV system and method for synchronizing the rendering of streaming services thereof |
US20100100917A1 (en) * | 2008-10-16 | 2010-04-22 | Industrial Technology Research Institute | Mobile tv system and method for synchronizing the rendering of streaming services thereof |
US9380355B2 (en) | 2009-02-05 | 2016-06-28 | Digimarc Corporation | Second screens and widgets |
US9281847B2 (en) | 2009-02-27 | 2016-03-08 | Qualcomm Incorporated | Mobile reception of digital video broadcasting—terrestrial services |
US8751855B2 (en) | 2009-08-17 | 2014-06-10 | Sandisk Il Ltd. | Method and memory device for generating a time estimate |
US8448009B2 (en) | 2009-08-17 | 2013-05-21 | Sandisk Il Ltd. | Method and memory device for generating a time estimate |
US20110040976A1 (en) * | 2009-08-17 | 2011-02-17 | Rahav Yairi | Method and Memory Device for Generating a Time Estimate |
US9419749B2 (en) | 2009-08-19 | 2016-08-16 | Qualcomm Incorporated | Methods and apparatus employing FEC codes with permanent inactivation of symbols for encoding and decoding processes |
US9660763B2 (en) | 2009-08-19 | 2017-05-23 | Qualcomm Incorporated | Methods and apparatus employing FEC codes with permanent inactivation of symbols for encoding and decoding processes |
US9288010B2 (en) | 2009-08-19 | 2016-03-15 | Qualcomm Incorporated | Universal file delivery methods for providing unequal error protection and bundled file delivery services |
US9876607B2 (en) | 2009-08-19 | 2018-01-23 | Qualcomm Incorporated | Methods and apparatus employing FEC codes with permanent inactivation of symbols for encoding and decoding processes |
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 |
US11770432B2 (en) | 2009-09-22 | 2023-09-26 | Qualcomm Incorporated | Enhanced block-request streaming system for handling low-latency streaming |
US11743317B2 (en) | 2009-09-22 | 2023-08-29 | Qualcomm Incorporated | Enhanced block-request streaming using block partitioning or request controls for improved client-side handling |
US10855736B2 (en) | 2009-09-22 | 2020-12-01 | Qualcomm Incorporated | Enhanced block-request streaming using block partitioning or request controls for improved client-side handling |
US20110138487A1 (en) * | 2009-12-09 | 2011-06-09 | Ehud Cohen | Storage Device and Method for Using a Virtual File in a Public Memory Area to Access a Plurality of Protected Files in a Private Memory Area |
US9092597B2 (en) | 2009-12-09 | 2015-07-28 | Sandisk Technologies Inc. | Storage device and method for using a virtual file in a public memory area to access a plurality of protected files in a private memory area |
US20120243459A1 (en) * | 2009-12-10 | 2012-09-27 | Zhenyu Wu | Protocol booster for sctp in multicast networks |
US8976787B2 (en) * | 2009-12-10 | 2015-03-10 | Thomson Licensing | Protocol booster for SCTP in multicast networks |
US20120290644A1 (en) * | 2010-01-18 | 2012-11-15 | Frederic Gabin | Methods and Arrangements for HTTP Media Stream Distribution |
US9621610B2 (en) * | 2010-01-18 | 2017-04-11 | Telefonaktiebolaget Lm Ericsson (Publ) | Methods and arrangements for HTTP media stream distribution |
US9225961B2 (en) | 2010-05-13 | 2015-12-29 | Qualcomm Incorporated | Frame packing for asymmetric stereo video |
US8694598B2 (en) * | 2010-05-20 | 2014-04-08 | Sandisk Il Ltd. | Host device and method for accessing a virtual file in a storage device by bypassing a cache in the host device |
US20120204237A1 (en) * | 2010-05-20 | 2012-08-09 | Eyal Ittah | Host Device and Method for Accessing a Virtual File in a Storage Device by Bypassing a Cache in the Host Device |
US9602802B2 (en) | 2010-07-21 | 2017-03-21 | Qualcomm Incorporated | Providing frame packing type information for video coding |
US9456015B2 (en) | 2010-08-10 | 2016-09-27 | Qualcomm Incorporated | Representation groups for network streaming of coded multimedia data |
US9319448B2 (en) | 2010-08-10 | 2016-04-19 | Qualcomm Incorporated | Trick modes for network streaming of coded multimedia data |
US8806050B2 (en) | 2010-08-10 | 2014-08-12 | Qualcomm Incorporated | Manifest file updates for network streaming of coded multimedia data |
US20120191816A1 (en) * | 2010-10-13 | 2012-07-26 | Sonos Inc. | Method and apparatus for collecting diagnostic information |
US8958375B2 (en) | 2011-02-11 | 2015-02-17 | Qualcomm Incorporated | Framing for an improved radio link protocol including FEC |
US9270299B2 (en) | 2011-02-11 | 2016-02-23 | Qualcomm Incorporated | Encoding and decoding using elastic codes with flexible source block mapping |
US9414105B2 (en) * | 2011-02-14 | 2016-08-09 | Blackfire Research Corporation | Mobile source device media playback over rendering devices at lifestyle-determined locations |
US20120284757A1 (en) * | 2011-02-14 | 2012-11-08 | Ravi Rajapakse | Mobile source device media playback over rendering devices at lifestyle-determined locations |
US8677006B2 (en) * | 2011-05-05 | 2014-03-18 | Microsoft Corporation | Processing media streams |
US20120284419A1 (en) * | 2011-05-05 | 2012-11-08 | Manrique Brenes | Processing Media Streams |
US9253233B2 (en) | 2011-08-31 | 2016-02-02 | Qualcomm Incorporated | Switch signaling methods providing improved switching between representations for adaptive HTTP streaming |
US9635082B2 (en) | 2011-09-27 | 2017-04-25 | Thomson Licensing | Method of saving content to a file on a server and corresponding device |
US9843844B2 (en) | 2011-10-05 | 2017-12-12 | Qualcomm Incorporated | Network streaming of media data |
US20130132603A1 (en) * | 2011-11-21 | 2013-05-23 | Etan GUR COHEN | Hybrid Networking System with Seamless Path Switching of Streams |
US9461777B2 (en) * | 2011-11-21 | 2016-10-04 | Qualcomm Incorporated | Hybrid networking system with seamless path switching of streams |
US9294226B2 (en) | 2012-03-26 | 2016-03-22 | Qualcomm Incorporated | Universal object delivery and template-based file delivery |
US11051059B2 (en) * | 2012-09-28 | 2021-06-29 | Sony Interactive Entertainment LLC | Playback synchronization in a group viewing a media title |
US20140373081A1 (en) * | 2012-09-28 | 2014-12-18 | Sony Computer Entertainment America Llc | Playback synchronization in a group viewing a media title |
WO2014065902A1 (en) * | 2012-10-22 | 2014-05-01 | Arbitron, Inc. | Methods and systems for clock correction and/or synchronization for audio media measurement systems |
US11050701B2 (en) | 2012-11-14 | 2021-06-29 | Google Llc | System and method of embedding rich media into text messages |
US11595338B2 (en) * | 2012-11-14 | 2023-02-28 | Google Llc | System and method of embedding rich media into text messages |
US11063894B2 (en) | 2012-11-14 | 2021-07-13 | Google Llc | System and method of embedding rich media into text messages |
US11595339B2 (en) | 2012-11-14 | 2023-02-28 | Google Llc | System and method of embedding rich media into text messages |
US9729876B2 (en) | 2012-11-29 | 2017-08-08 | Thomson Licensing | Method for predicting a block of pixels from at least one patch |
US9722943B2 (en) | 2012-12-17 | 2017-08-01 | Qualcomm Incorporated | Seamless switching for multihop hybrid networks |
US9426196B2 (en) | 2013-01-04 | 2016-08-23 | Qualcomm Incorporated | Live timing for dynamic adaptive streaming over HTTP (DASH) |
US20140192825A1 (en) * | 2013-01-08 | 2014-07-10 | Tangome, Inc. | Joint retransmission and frame synchronization for error resilience control |
US9288036B2 (en) | 2013-01-08 | 2016-03-15 | Tangome, Inc. | Joint retransmission and frame synchronization for error resilience control |
US9019992B2 (en) * | 2013-01-08 | 2015-04-28 | Tangome, Inc. | Joint retransmission and frame synchronization for error resilience control |
US9742583B2 (en) * | 2013-01-17 | 2017-08-22 | Zte Corporation | Method of data retransmission in collaborative service transmission and access network gateway thereof |
US20150365250A1 (en) * | 2013-01-17 | 2015-12-17 | Zte Corporation | Method of data retransmission in collaborative service transmission and access network gateway thereof |
US10523984B2 (en) | 2013-05-31 | 2019-12-31 | Divx, Llc | Synchronizing multiple over the top streaming clients |
US10063896B2 (en) | 2013-05-31 | 2018-08-28 | Divx, Llc | Synchronizing multiple over the top streaming clients |
US11765410B2 (en) | 2013-05-31 | 2023-09-19 | Divx, Llc | Synchronizing multiple over the top streaming clients |
CN105247437A (en) * | 2013-05-31 | 2016-01-13 | 索尼克Ip股份有限公司 | Synchronizing multiple over the top streaming clients |
US10880620B2 (en) | 2013-05-31 | 2020-12-29 | Divx, Llc | Playback synchronization across playback devices |
US10205981B2 (en) | 2013-05-31 | 2019-02-12 | Divx, Llc | Playback synchronization across playback devices |
US20150030088A1 (en) * | 2013-07-26 | 2015-01-29 | Vixs Systems Inc. | Clock recovery for media stream in bursty network channel |
US9549027B2 (en) | 2013-09-27 | 2017-01-17 | Dolby Laboratories Licensing Corporation | Network-synchronized media playback |
WO2015048693A1 (en) * | 2013-09-27 | 2015-04-02 | Aliphcom | Multiple data source aggregation for efficient synchronous multi-device media consumption |
US20190297591A1 (en) * | 2013-10-31 | 2019-09-26 | At&T Intellectual Property I, L.P. | Synchronizing media presentation at multiple devices |
US20150120953A1 (en) * | 2013-10-31 | 2015-04-30 | At&T Intellectual Property I, Lp | Synchronizing media presentation at multiple devices |
US9974037B2 (en) | 2013-10-31 | 2018-05-15 | At&T Intellectual Property I, L.P. | Synchronizing media presentation at multiple devices |
US10805894B2 (en) * | 2013-10-31 | 2020-10-13 | At&T Intellectual Property I, L.P. | Synchronizing media presentation at multiple devices |
US10362550B2 (en) * | 2013-10-31 | 2019-07-23 | At&T Intellectual Property I, L.P. | Synchronizing media presentation at multiple devices |
US9210204B2 (en) * | 2013-10-31 | 2015-12-08 | At&T Intellectual Property I, Lp | Synchronizing media presentation at multiple devices |
US20170272190A1 (en) * | 2014-07-25 | 2017-09-21 | Zte Corporation | Time synchronization method and apparatus for network devices and time synchronization server |
US10776739B2 (en) | 2014-09-30 | 2020-09-15 | Apple Inc. | Fitness challenge E-awards |
US11468388B2 (en) | 2014-09-30 | 2022-10-11 | Apple Inc. | Fitness challenge E-awards |
US11868939B2 (en) | 2014-09-30 | 2024-01-09 | Apple Inc. | Fitness challenge e-awards |
US9671998B2 (en) * | 2014-12-31 | 2017-06-06 | Qualcomm Incorporated | Synchronised control |
WO2016108118A1 (en) * | 2014-12-31 | 2016-07-07 | Qualcomm Technologies International, Ltd. | Wireless broadcast of packetized audio data with control data |
US20160188287A1 (en) * | 2014-12-31 | 2016-06-30 | Qualcomm Technologies International, Ltd. | Synchronised control |
WO2016145235A1 (en) * | 2015-03-12 | 2016-09-15 | Startimes Communication Network Technology Co. Ltd. | Location based services audio system |
US10536790B2 (en) | 2015-03-12 | 2020-01-14 | StarTime Software Technology Co., Ltd. | Location based services audio system |
WO2016191516A1 (en) * | 2015-05-28 | 2016-12-01 | Bose Corporation | Audio data buffering |
US20160350067A1 (en) * | 2015-05-28 | 2016-12-01 | Bose Corporation | Audio Data Buffering |
US9928024B2 (en) * | 2015-05-28 | 2018-03-27 | Bose Corporation | Audio data buffering |
US10929093B2 (en) * | 2015-05-28 | 2021-02-23 | Bose Corporation | Audio data buffering |
US10255035B2 (en) * | 2015-05-28 | 2019-04-09 | Bose Corporation | Audio data buffering |
US11483626B1 (en) | 2016-07-05 | 2022-10-25 | BoxCast, LLC | Method and protocol for transmission of video and audio data |
US12126873B1 (en) | 2016-07-05 | 2024-10-22 | Boxcast Inc. | Method and protocol for transmission of video and audio data |
US11330341B1 (en) * | 2016-07-05 | 2022-05-10 | BoxCast, LLC | System, method, and protocol for transmission of video and audio data |
US12032870B2 (en) | 2016-12-13 | 2024-07-09 | B&W Group Ltd. | Wireless inter-room coordination of audio playback |
WO2018111501A1 (en) | 2016-12-13 | 2018-06-21 | EVA Automation, Inc. | Wireless coordination of audio playback |
EP3539335A4 (en) * | 2016-12-13 | 2019-12-04 | Eva Automation, Inc. | Wireless coordination of audio playback |
US10846048B2 (en) | 2016-12-13 | 2020-11-24 | EVA Automation, Inc. | Wireless coordination of audio playback |
EP4106425A1 (en) * | 2016-12-13 | 2022-12-21 | B&W Group Ltd | Wireless coordination of audio playback |
US11194542B2 (en) | 2016-12-13 | 2021-12-07 | B&W Group Ltd. | Wireless coordination of audio sources |
US11042349B2 (en) | 2016-12-13 | 2021-06-22 | B&W Group Ltd. | Source coordination of audio playback |
US11165752B1 (en) * | 2017-06-13 | 2021-11-02 | Parallels International Gmbh | System and method for recovery of data packets transmitted over an unreliable network |
US11259192B2 (en) * | 2017-09-29 | 2022-02-22 | Apple Inc. | Ultra-low latency audio over bluetooth |
US10993274B2 (en) | 2018-03-30 | 2021-04-27 | Apple Inc. | Pairing devices by proxy |
US10783929B2 (en) | 2018-03-30 | 2020-09-22 | Apple Inc. | Managing playback groups |
US12034994B2 (en) | 2018-03-30 | 2024-07-09 | Apple Inc. | Remotely controlling playback devices |
US11297369B2 (en) | 2018-03-30 | 2022-04-05 | Apple Inc. | Remotely controlling playback devices |
US11974338B2 (en) | 2018-03-30 | 2024-04-30 | Apple Inc. | Pairing devices by proxy |
WO2019226760A1 (en) * | 2018-05-24 | 2019-11-28 | Google Llc | Methods, systems, and media for synchronizing audio and video content on multiple media devices |
US11606596B2 (en) | 2018-05-24 | 2023-03-14 | Google Llc | Methods, systems, and media for synchronizing audio and video content on multiple media devices |
CN111837400A (en) * | 2018-05-24 | 2020-10-27 | 谷歌有限责任公司 | Methods, systems, and media for synchronizing audio content and video content on multiple media devices |
US10771866B2 (en) | 2018-05-24 | 2020-09-08 | Google Llc | Methods, systems, and media synchronizing audio and video content on multiple media devices |
US10614857B2 (en) | 2018-07-02 | 2020-04-07 | Apple Inc. | Calibrating media playback channels for synchronized presentation |
US10931584B2 (en) * | 2018-08-23 | 2021-02-23 | Hewlett Packard Enterprise Development Lp | Data frame transmission |
US10971161B1 (en) * | 2018-12-12 | 2021-04-06 | Amazon Technologies, Inc. | Techniques for loss mitigation of audio streams |
US11336954B1 (en) | 2018-12-12 | 2022-05-17 | Amazon Technologies, Inc. | Method to determine the FPS on a client without instrumenting rendering layer |
US11252097B2 (en) | 2018-12-13 | 2022-02-15 | Amazon Technologies, Inc. | Continuous calibration of network metrics |
US11356326B2 (en) | 2018-12-13 | 2022-06-07 | Amazon Technologies, Inc. | Continuously calibrated network system |
US11368400B2 (en) | 2018-12-13 | 2022-06-21 | Amazon Technologies, Inc. | Continuously calibrated network system |
CN109743528A (en) * | 2018-12-29 | 2019-05-10 | 广州市保伦电子有限公司 | A kind of audio collection of video conference and play optimization method, device and medium |
US11016792B1 (en) | 2019-03-07 | 2021-05-25 | Amazon Technologies, Inc. | Remote seamless windows |
US11025982B2 (en) * | 2019-03-29 | 2021-06-01 | Twizted Design, Inc. | System and method for synchronizing content and data for customized display |
US11461168B1 (en) | 2019-03-29 | 2022-10-04 | Amazon Technologies, Inc. | Data loss protection with continuity |
US11245772B1 (en) | 2019-03-29 | 2022-02-08 | Amazon Technologies, Inc. | Dynamic representation of remote computing environment |
US11792195B2 (en) | 2019-09-29 | 2023-10-17 | Inspur Suzhou Intelligent Technology Co., Ltd. | Communication method, system and device and computer-readable storage medium |
EP4027600A4 (en) * | 2019-09-29 | 2022-11-02 | Inspur Suzhou Intelligent Technology Co., Ltd. | Communication method, system and device and computer-readable storage medium |
SE544478C2 (en) * | 2020-04-28 | 2022-06-14 | Stig Halvarsson | System, device and a method for providing an improved wireless audio system |
SE2030143A1 (en) * | 2020-04-28 | 2021-10-29 | Stig Halvarsson | SYSTEM, DEVICE AND A METHOD FOR PROVIDING AN IMPROVED WiFiTM AUDIO SYSTEM |
US12034828B2 (en) * | 2020-04-28 | 2024-07-09 | Stidev Ab | System, device and a method for providing an improved WiFi™ audio system |
WO2023056392A1 (en) * | 2021-10-01 | 2023-04-06 | Bytedance Inc. | Method, apparatus, and medium for video processing |
WO2023240168A1 (en) * | 2022-06-09 | 2023-12-14 | Amazon Technologies, Inc. | Distribution of messages with guaranteed or synchronized time of delivery |
Also Published As
Publication number | Publication date |
---|---|
US8681822B2 (en) | 2014-03-25 |
US20180054481A1 (en) | 2018-02-22 |
US10264070B2 (en) | 2019-04-16 |
WO2007079334A3 (en) | 2007-08-30 |
EP2290899A2 (en) | 2011-03-02 |
US20070250761A1 (en) | 2007-10-25 |
EP3389239B1 (en) | 2020-09-09 |
WO2007079334A2 (en) | 2007-07-12 |
US20140244863A1 (en) | 2014-08-28 |
EP3389239A1 (en) | 2018-10-17 |
US9729630B2 (en) | 2017-08-08 |
EP1969810A2 (en) | 2008-09-17 |
EP1969810B1 (en) | 2013-08-21 |
EP2290899A3 (en) | 2014-11-26 |
EP2290899B1 (en) | 2018-11-21 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10264070B2 (en) | System and method for synchronizing media presentation at multiple recipients | |
US10972536B2 (en) | System and method for synchronizing media presentation at multiple recipients | |
EP1964365B1 (en) | Portable media player as a low power remote control and method thereof | |
US7805210B2 (en) | Synchronizing multi-channel speakers over a network | |
US20120099594A1 (en) | Media distribution architecture | |
JP5715669B2 (en) | Streaming data content in the network | |
US7185084B2 (en) | Server-side measurement of client-perceived quality of service | |
US20060013208A1 (en) | Method and device for the synchronised restitution of data flows | |
WO2011095056A1 (en) | Audio processing method and device for remote desktop protocol | |
JP4042396B2 (en) | Data communication system, data transmission apparatus, data reception apparatus and method, and computer program | |
JP3906678B2 (en) | Data communication system, data transmission apparatus, data reception apparatus and method, and computer program | |
Bhalla et al. | Transport Layer |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: APPLE COMPUTER, INC.,CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:BRADLEY, BOB;NEWBERRY, ROBERT DALE, JR.;SIGNING DATES FROM 20061101 TO 20061102;REEL/FRAME:018481/0109 |
|
AS | Assignment |
Owner name: APPLE INC.,CALIFORNIA Free format text: CHANGE OF NAME;ASSIGNOR:APPLE COMPUTER, INC.;REEL/FRAME:019265/0961 Effective date: 20070109 Owner name: APPLE INC., CALIFORNIA Free format text: CHANGE OF NAME;ASSIGNOR:APPLE COMPUTER, INC.;REEL/FRAME:019265/0961 Effective date: 20070109 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |