USRE45793E1 - Accessing digital media - Google Patents

Accessing digital media Download PDF

Info

Publication number
USRE45793E1
USRE45793E1 US13/445,791 US201213445791A USRE45793E US RE45793 E1 USRE45793 E1 US RE45793E1 US 201213445791 A US201213445791 A US 201213445791A US RE45793 E USRE45793 E US RE45793E
Authority
US
United States
Prior art keywords
records
database
local
server
remote
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.)
Active, expires
Application number
US13/445,791
Inventor
Amandeep Jawa
Jeffrey L. Robbin
David Heller
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Apple Inc
Original Assignee
Apple Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Apple Inc filed Critical Apple Inc
Priority to US13/445,791 priority Critical patent/USRE45793E1/en
Priority to US14/866,639 priority patent/USRE47934E1/en
Application granted granted Critical
Publication of USRE45793E1 publication Critical patent/USRE45793E1/en
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/40Information retrieval; Database structures therefor; File system structures therefor of multimedia data, e.g. slideshows comprising image and additional audio data
    • G06F16/48Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/40Information retrieval; Database structures therefor; File system structures therefor of multimedia data, e.g. slideshows comprising image and additional audio data
    • G06F16/41Indexing; Data structures therefor; Storage structures
    • G06F17/30017
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/40Information retrieval; Database structures therefor; File system structures therefor of multimedia data, e.g. slideshows comprising image and additional audio data
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/40Information retrieval; Database structures therefor; File system structures therefor of multimedia data, e.g. slideshows comprising image and additional audio data
    • G06F16/43Querying
    • G06F16/438Presentation of query results
    • G06F16/4387Presentation of query results by the use of playlists
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99931Database or file accessing
    • Y10S707/99933Query processing, i.e. searching
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99941Database schema or data structure
    • Y10S707/99944Object-oriented database structure
    • Y10S707/99945Object-oriented database structure processing
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99941Database schema or data structure
    • Y10S707/99948Application of database or data structure, e.g. distributed, multimedia, or image
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99951File or database maintenance
    • Y10S707/99952Coherency, e.g. same view to multiple users
    • Y10S707/99953Recoverability

Definitions

  • the present invention relates to digital media and, more particularly, to accessing digital media across networks.
  • Networks are the mechanism by which computers are able to communicate with one another.
  • devices that provide resources are called servers and devices that utilize those resources are called clients.
  • a device might be dedicated to one type of task or might act as both a client and a server, depending upon whether it is giving or requesting resources.
  • music, movies, pictures, and print are all types of entertainment-related media that someone might want to access from across a network.
  • a music library may reside on a family computer in the den, the media owner may want to listen to the music in the living room.
  • the present invention provides a method of retrieving media across a network.
  • a client connects to a network that includes a server.
  • the server includes at least one media database that has media and associated media information.
  • the client queries the server for at least a portion of the media information and then receives media information responsive to the query.
  • the client uses a client-side media management system to manage the received media information. Management of the received media information includes selecting media.
  • the client requests the selected media from across the network and, in response to the request, receives the requested media.
  • a client queries the server for server information and capabilities after connecting to the network. The client then receives a response that identifies the server and informs the client as to its capabilities. After receiving the server information, the client queries the server for database enumeration and receives a response that enumerates all databases, how much media is available, and how many media collections are available. After the database identification, the client queries the server for an enumeration of media collections in the database and receives a response that identifies media collections. The client then queries the server for data associated with an identified media collection, the query being capable of requesting a different level of detail than would be given by default. The response to the media collection query identifies data associated with the identified media collection in the requested level of detail. The client then executes the identified media collection, requesting media from the server when the media collection requires the media and receiving the requested media.
  • the invention provides a method of ensuring that a media database representation on a client is current.
  • the server first provides a media database that updates to a current revision indicator whenever the media database is modified. Then, the server receives a request from the client, the request pertaining to the database that includes a client-provided revision indicator. After receiving the request, the server compares the current revision indicator to the client-provided revision indicator. The server then responds to the request with a response that includes at least an identification of the current revision indicator if the client-provided revision indicator did not match the current revision indicator.
  • FIG. 1 is a block diagram illustrating an exemplary environment in which the present invention may be implemented
  • FIG. 2 is a block diagram illustrating an organizational structure of a server-side media management system on the server illustrated in FIG. 1 ;
  • FIG. 3 is a block diagram illustrating an organizational structure of a client-side media management system on the client illustrated in FIG. 1 ;
  • FIG. 4A is a representational control flow diagram illustrating one technique that can be used to determine the features of the server-side media management system illustrated in FIG. 2 ;
  • FIG. 4B is a representational control flow diagram illustrating one technique that could be used to enumerate databases of the server-side media management system illustrated in FIG. 2 ;
  • FIG. 4C is a representational control flow diagram illustrating one technique that could be used to populate a song records portion of the client-side media management system illustrated in FIG. 5 ;
  • FIG. 4D is a representational control flow diagram illustrating a technique that could be used to enumerate playlists of the server-side media management system illustrated in FIG. 2 ;
  • FIG. 4E is a representational control flow diagram illustrating a technique that could be used to populate a playlist records portion of the client-side media management system illustrated in FIG. 6 ;
  • FIG. 4F is a representational control flow diagram illustrating a technique that could be used to retrieve a song from a song database once a song is selected from the client-side media management system illustrated in FIG. 7 ;
  • FIG. 5 is a block diagram illustrating an organizational structure of the client-side media management system after receiving a reply to the SERVER-DATABASE request illustrated in FIG. 4B ;
  • FIG. 6 is a block diagram illustrating an organizational structure of the client-side media management system after receiving a reply to the DATABASE-SONGS request illustrated in FIG. 4C ;
  • FIG. 7 is a block diagram illustrating an organizational structure of the client-side media management system after receiving a reply to the PLAYLIST-SONGS request illustrated in FIG. 4E ;
  • FIG. 8 is a representational control flow diagram illustrating one technique that could be used to ensure the client and the server illustrated in FIG. 1 are synchronized.
  • FIG. 9 is a diagram illustrating an exemplary computing device in which various embodiments of the invention may be implemented.
  • the present invention generally allows for client machines to access a media database on a server.
  • Both data and metadata on the server describes and organizes the media in various ways and allows the server to manipulate the media.
  • the client requests the data and metadata and then uses the information on a local media management system, effectively creating a representation of the server on the client.
  • the client can request the media from the server, and the server can deliver the media to the client.
  • the invention can support both “thick” and “thin” clients.
  • Thick clients are typically software programs, such as iTunesTM software available from Apple Computer, Inc. of Cupertino, Calif., operating on hardware devices that support full user interface abilities and have considerable processor and memory resources.
  • Thin clients are software programs operating on hardware devices that may have limited user interface abilities and have reduced processing and memory resources. The invention allows for robust control features appropriate for thick clients, but can adapt to minimal control features for thin clients.
  • a client will first make a request to determine whether media is available on a server. Then, the client can make a series of requests to create a representation of the media available on the server on the client.
  • the representation contains information about the media available on the server (“media information”). Thick clients can choose to retrieve a complete representation of the server's available media, while thin clients may choose to retrieve a partial representation of the server's available media.
  • the client can then search, browse, sort, or otherwise interact with the media information now resident on the client. Further, the client (as instructed by its user) will typically select a media item to be presented (e.g., played). In such a case, the media content for the selected media item is streamed from the server to the client.
  • clients can receive notifications from the server when a media database has been changed.
  • Multiple connections can allow a client to use one connection to access media while using another connection to wait for a notification that the database has changed, or to browse media listings.
  • FIG. 1 is a block diagram illustrating an exemplary environment in which the present invention may be implemented.
  • a network 105 couples a server 110 to various clients 115 , 120 , 125 , and 130 .
  • the network 105 can generally be a data network, such as a LAN, WAN or the Internet.
  • the server 110 may or may not be a dedicated device. In the example shown in FIG. 1 , the server 110 is a general purpose computer.
  • the various clients 115 , 120 , 125 , and 130 can be thick or thin clients, with varying levels of processing power. Clients may include portable computers 115 , desktop computers 120 , specialized devices such as iPodsTM 125 available from Apple Computer, Inc. of Cupertino, Calif., or even network-aware audio/video components 130 that are designed to work across a network 105 .
  • the following discussion will, for simplicity, assume only the portable computer client 115 is requesting information from the server 110 .
  • FIG. 2 is a block diagram illustrating an organizational structure of a server-side media management system 200 on the server 110 .
  • the server-side media management system 200 includes a media manager 210 and a music database 205 .
  • the media manager 210 controls access to the music database 205 . More particularly, the media manager 210 receives requests from the client 115 , accesses the music database, and returns responses to the client 115 .
  • the music database 205 has a number of records 215 and 220 that are used to classify, identify and/or describe media (i.e., media items) in the music database 205 .
  • media i.e., media items
  • the digital media contained on the server 110 only contains music files that can be streamed over the network 105 .
  • any reference to “songs” or “music” made in this document could be generalized to any form of digital media, which can include sound files, picture data, movies, text files or any other types of media that can be digitally stored on a computer.
  • any reference to “playlists” can be generalized to media collections, including collections of mixed digital media.
  • the media manager 210 has or can obtain information about the database 205 that may, for example, include the name of the server, the version of the database being used, the type of security that is required, the number of databases available to the server, whether non-standard content codes are supported, whether persistent identification is supported, etc. It should be appreciated by those skilled in the art that the information about the database 205 may exist in a single record file or can be either partially or fully generated on demand, identifying the various pieces of information as needed.
  • the song records 215 contain metadata about each media item available in the database 205 .
  • the metadata might include, for example, the names of songs, an identification number, a persistent identification number, the artist, the album, the size of the song, the format of the song, the required bit rate, and any other appropriate information.
  • the type of information may depend on the type of media.
  • a video file might additionally have director and producer fields, but may not use the album field. Still pictures would have no need for bit rate information. While some fields may be standard, others may be specific to certain applications. For example, a video signal may have secondary audio program (SAP) information.
  • SAP secondary audio program
  • Both an identification number and a persistent identification number can be used. If supported, a persistent identification could be used to access the same information across server restarts. Typically, a server would assign each record a new identification number every time the media management system 200 restarted. However, persistent identification numbers would remain the same for as long as the record is available.
  • the playlist records 220 contain information about each playlist available in the music database 205 . Further, the information for a given playlist can include the identification numbers for each of the songs within the playlist. Playlists are collections of media that may or may not be in any particular order. Users may choose to combine media by genre, mood, artists, audience, or any other meaningful arrangement. While the playlists 220 on the server 110 will usually only include media contained in its own music database 205 , there is no reason the playlist records 220 cannot include media or playlists stored on other servers. However, certain non-standard content codes may need to be used, depending upon the implementation of the server-side media management system 200 .
  • FIG. 3 is a block diagram illustrating an organizational structure of a client-side media management system 300 on one of the clients 115 .
  • the client-side media management system 300 includes a media manager 305 .
  • the media manager 305 interacts with the media manager 210 of the server-side media management system 200 through the network 105 so as to replicate at least a portion of the music database 205 at the server 110 on the client 115 .
  • the client-side media management system 300 When the client-side media management system 300 first starts, it cannot access media on the server 110 because it does not as yet have any information about what media is available.
  • FIG. 4A is a representational control flow diagram illustrating one technique that can be used to determine the features of the server-side media management system 200 .
  • Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 403 and 406 .
  • the client 115 connects to the network 105 and first becomes aware of the server 110 .
  • the client 115 can use any connection mechanism that allows it to interact with the network 105 .
  • the client 115 were an iBookTM, available from Apple Computer, Inc. of Cupertino, it might use RendezvousTM networking technology, also available from Apple Computer, Inc. of Cupertino, Calif., in order to automatically configure itself with the network 105 .
  • the client is not aware of the server 110 , other mechanisms can be used. For example, a user might manually search for the server 110 , or the user might directly enter the address of the server 110 .
  • the client 115 can send a SERVER-INFO request to the server 110 at 412 .
  • the SERVER-INFO request is usually used to obtain information from the server prior to attempting any other transactions. If the network 105 uses the TCP/IP protocol, the request could be formatted as an HTTP GET request. The GET request might also allow for additional extensions to be added to the request, enabling, for example, the client 115 to include information about the client-side media management system 300 .
  • the server responds to the SERVER-INFO request with information describing a series of features supported by or required by the server.
  • the information might, for example, include information about the server-side media management system 200 , the number of available databases, whether and what login procedures are required, whether updates are supported, whether persistent identification numbers are supported, whether non-standard content codes are supported, and the protocol version.
  • the information provided to the client 115 at 415 permits the client-side media management system 300 to understand the capabilities of the server 110 . Although the client 115 is able to identify the server 110 , the client 115 does not yet have any information about the available media.
  • the client 115 can optionally issue a CONTENT CODE request at 421 .
  • the CONTENT CODE request is one mechanism by which the client 115 can obtain a list of content codes supported by the server 110 and associated string names mapped thereto.
  • the inclusion of the string name allows multiple developers to use the same codes for their individualized products. For example, one developer may assign the code “16000” to a feature that allows users to purchase corresponding albums over the network; while another developer may assign the same code to feature that provides users with the lyrics of songs that are being listened to.
  • the client 115 can determine whether it can support the content code. Uniqueness of the string name can, for example, be ensured by including the developer's URL as part of the string name.
  • the server 110 responds to the CONTENT CODE request the codes and their associated string names.
  • the client 115 can simply ignore the code/string pairs that it does not recognize. Otherwise, for those code/string pairs that the client 115 does recognize, the client 115 will associate the code with the associated string name.
  • the client 115 logs into the server 110 .
  • the login procedure might require a user name (or account name) and password so the user of the client can be authenticated.
  • the login procedure is only required if the server 110 requires it.
  • Certain security protocols might require that every future request made by the client 115 include certain parameters such as a session identification number.
  • FIG. 4B is a representational control flow diagram illustrating one technique that can be used to enumerate databases of the server-side media management system 200 .
  • Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 403 and 406 .
  • the client 115 can issue a SERVER-DATABASE request, which can be used to retrieve the list of all music databases from the server 110 .
  • the SERVER-DATABASE request may additionally include an index range and/or a query. Although available to both thick and thin clients, thin clients might use index ranges and/or queries to limit the amount of data contained in each server response.
  • the index range might be used in any request to constrain the items returned in the response to a subset of the total set of items, based on the position (or index) of the first item and the number of items requested.
  • an index range could be used to request: the second music database from a server, songs 10 through 20 from a music database, the last 5 playlists from a music database, the first 5 songs from a given playlist, or the 42nd song in a music database.
  • the query might be used in any request to constrain the items returned in the response to a subset of the total set of items, based on the specified criteria. For example, a query could request: songs in a database after a given year; playlists that contain a certain word in their name; songs in a database that do not contain a given word in their name; or some combination thereof.
  • the server 110 After processing the SERVER-DATABASE request at 436 , the server 110 issues a response at 439 . If no index range and/or query was given, the response would contain a complete list of the music databases available at the server 110 together with information about the one or more music databases.
  • the information about each database might, for example, include the database identification number, the persistent database identification number, the name for each database, the numbers of songs, and the number of playlists. With this information, the client-side media management system 300 becomes aware of the general structure of the one or more music databases at the server 110 .
  • FIG. 5 is a block diagram illustrating the organizational structure of the client-side media management system 300 shown in FIG. 3 after receiving a reply to the SERVER-DATABASE request.
  • the client 115 is able to identify the music database 510 , the number of available song records 515 , and the number of available playlists 520 . Once the general structure of the music database 510 is known, the client 115 can populate its representation using any number of techniques.
  • FIG. 4C is a representational control flow diagram illustrating one technique that could be used to populate the song records 515 portion of the client-side media management system 300 for a specific database 510 .
  • Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 403 and 406 .
  • the client issues a DATABASE-SONGS request to obtain metadata about available songs.
  • a thick client may choose to issue a DATABASE-SONGS request so that it can front load network traffic. Once metadata about a song is received and stored, the client 115 does not need to request that metadata again. Playlists would only need to correctly identify a song (e.g., using the song identification number), and the client-side media management system 300 would be able to associate it with the already-received metadata.
  • Thin clients may choose to issue an index range, query, metadata field specifier, or skip 445 all together.
  • a metadata field specifier would indicate that only certain metadata fields are desired.
  • Thick clients that use 445 may also choose to use these same index range, query or metadata field specifier techniques. For example, limiting the song metadata request to only songs in a certain genre might be a technique that is used to provide the user with a different user experience.
  • FIG. 6 is a block diagram illustrating the organizational structure of the client-side media management system 300 at 453 , after receiving a reply to the DATABASE-SONGS request.
  • the song records 605 may either be a partial or complete representation of the server-side song records 215 , having metadata that might, for example, include the names of songs, an identification number, a persistent identification number, the artist, the album, the size of the song, the format of the song, the required bit rate, and any other appropriate information. If the server-side management system 200 had multiple databases, a DATABASE-SONGS request (if used) would need to be issued for each database
  • FIG. 4D is a representational control flow diagram illustrating a technique that could be used to enumerate the playlist records 220 portion of the server-side media management system 200 .
  • Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 403 and 406 .
  • Playlists on the server 110 can either be user-identified or generated automatically by the server-side media management system 200 .
  • a “base playlist” might be automatically created as a special playlist that contains all the songs in the entire song database 205 while a “John Lennon playlist” might be a user-created collection of songs by John Lennon.
  • the server 110 After receiving the DATABASE-PLAYLIST request and performing any necessary filtering operations, the server 110 issues a reply at 457 .
  • the reply includes a list of all playlists in the music database 205 and information about those playlists.
  • the information about the playlists might, for example, include identification numbers and/or persistent identification numbers for the playlists, and any other information (e.g., whether the songs in the playlist are in order or can be shuffled) that may have been provided.
  • Multiple DATABASE-PLAYLIST requests may be required to populate multiple databases.
  • FIG. 4E is a representational control flow diagram illustrating a technique that could be used to populate the playlist records 520 portion of the client-side media management system 300 .
  • Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 403 and 406 .
  • the client 115 sends a PLAYLIST-SONGS request for that playlist at 463 .
  • the PLAYLIST-SONGS request could additionally request that metadata accompanying each song also be delivered in order to populate the song records 605 .
  • thick clients that do not have a mechanism for informing the server 110 of already-received song records 605 would run the risk of receiving duplicate song records 605 , thin clients that did not retain song records 605 might benefit from requesting song metadata along with each playlist.
  • FIG. 7 is a block diagram illustrating the organizational structure of the client-side media management system 300 after receiving a reply to the PLAYLIST-SONGS request at 469 .
  • the playlist record 705 may be a complete or partial representation of the corresponding server-side playlist record 220 .
  • Multiple PLAYLIST-SONGS requests may be required to populate multiple playlists.
  • FIG. 4F is a representational control flow diagram illustrating a technique that could be used to retrieve a song from the song database 205 once a song is selected. Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 403 and 406 .
  • the client 115 issues a SONG-DATA request to retrieve the song data from the server 110 .
  • the SONG-DATA request could include a format identifier.
  • the format identifier could specify that the song is requested in, for example, MPEG 3 encoded data (“mp3”), MPEG 4 advanced audio coding (“m4a”) audio interchange file format (“aiff”), or Windows sound file (“wav”).
  • the server 110 delivers the audio file to the client 115 .
  • the server 110 will stream the song by appending song data to an http header, therefore making the client 115 responsible for parsing the data as is appropriate for playing the song at the client 115 .
  • a client-side representation of a playlist 705 may not accurately represent the latest version of the corresponding server-side playlist 220 .
  • FIG. 8 is a representational control flow diagram illustrating one technique that could be used to ensure the client 115 and the server 110 are synchronized. Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 805 and 810 .
  • the client 115 issues an UPDATE request to retrieve the media data from the server 110 .
  • the UPDATE request can be a flag that informs the server 110 that the client 115 wants to be informed when data on the server 110 (e.g., music database 205 ) changes.
  • the flag is a revision indicator, such as a revision number or a time-stamp.
  • the server 110 processes the UPDATE request. In one embodiment, the server 110 will not respond to the UPDATE request until the server's music database has changed relative to the client's representation for that music database. If a revision number was used at 815 , the server 110 compares the revision number provided by the client 115 with the current revision number to determine if a change was made. The revision number of the server 110 represents the version of the music database 205 at the server 110 . Any subsequent changes to records 215 or 220 may cause the server 110 to increment its revision number by one. Depending upon the requirements of the system, a group of changes to records 215 or 220 may be batched so that the revision number only increments once.
  • Batching may be performed by standard techniques, including by operation (e.g., adding files as a group to the server), by time (e.g., waiting a certain period of time after the last change has been made to ensure no other changes will be made) or by number of operations (e.g., changing the revision number after a certain number of changes).
  • operation e.g., adding files as a group to the server
  • time e.g., waiting a certain period of time after the last change has been made to ensure no other changes will be made
  • number of operations e.g., changing the revision number after a certain number of changes.
  • a reply is issued at 825 .
  • the reply will contain the server's current revision number.
  • the server 110 could then the continue to monitor for changes in the server's current revision number, the client 115 might re-issue a new UPDATE request with the server's current revision number, essentially repeating operation 815 with the updated revision number.
  • Some systems might have the client 115 always start with a client-generated revision number of “1” and the server 110 always start with a revision number “2” in order to force the server 110 to issue an UPDATE reply the first time it receives an UPDATE request.
  • Such an approach can provide the client 115 with an impetus for populating its local representation of the music database 205 with a SERVER-DATABASE request (see FIG. 4B at 433 ). Additionally, an UPDATE reply might also be used to notify a client 115 that the server is about to terminate connection (possibly due to timeout or server shutdown), perhaps by issuing a current revision number of 0.
  • the client 115 could also include a revision number field in any of the requests 433 , 445 , 454 , and 463 .
  • the server 110 would then, on a request-by-request basis, check the revision number provided with the requests with the revision number for that particular request. If the revision numbers did not match, the server 110 would issue an UPDATE reply, specifying the current revision number and perhaps the corresponding reply. Otherwise, the server 110 would comply with the request as previously described.
  • the database requests 433 , 445 , 454 , and 463 would additionally support incremental updating in order to reduce network traffic (and to improve user experience through greater responsiveness). Incremental updates would allow the client to request only the changes from a historical revision number to a current revision number. If, for example, the client 115 had populated its playlists records 705 with information from revision “5,” and then the client is notified by the server 110 that the latest revision is “8,” the client can issue a new PLAYLIST-SONGS request 463 , requesting only the information that has changed from revision “5” to revision “8.” As long as the server 110 maintains or has access to a historical record of modifications from each revision number, it would be able to comply with the incremental request.
  • an optimization might allow for the server 110 to determine whether complying with the incremental request would actually be more efficient than re-sending the entire reply.
  • the PLAYLIST-SONGS reply 466 provides a full reply, the reply would advantageously include an indication that the data does not represent an incremental update, so the client 115 will be able to properly handle the information.
  • the techniques of the present invention may be implemented on software and/or hardware. For example, they can be implemented in an operating system, in a separate user process, in a library package bound into network applications, or on a specially constructed machine. In a specific embodiment of this invention, the technique of the present invention is implemented in software such as an operating system and/or in an application program running on the operating system.
  • a software or software/hardware hybrid implementation of the techniques of this invention may be implemented on a general-purpose programmable machine selectively activated or reconfigured by a computer program stored in memory.
  • the techniques of this invention may be implemented on a general-purpose network host machine such as a personal computer, workstation or server. Further, the invention may be at least partially implemented on a general-purpose computing device.
  • a computing device 900 suitable for implementing the techniques of the present invention includes a master central processing unit (CPU) 905 , interfaces 910 , memory 915 and a bus 920 .
  • the CPU 905 may be responsible for implementing specific functions associated with the functions of a desired computing device.
  • the CPU 905 preferably accomplishes all these functions under the control of software including an operating system (e.g., Mac OS X), and any appropriate applications software (e.g., iTunes).
  • an operating system e.g., Mac OS X
  • any appropriate applications software e.g., iTunes
  • CPU 905 may include one or more processors such as those from the Motorola family of microprocessors or the MIPS family of microprocessors.
  • the processor is specially designed hardware for controlling the operations of computing device 900 .
  • the interfaces 910 are typically provided as interface cards. Generally, they control the sending and receiving of data packets over the network and sometimes support other peripherals used with the computing device 900 .
  • the interfaces that may be provided are Ethernet interfaces, frame relay interfaces, cable interfaces, DSL interfaces, token ring interfaces, and the like.
  • various very high-speed interfaces may be provided such as fast Ethernet interfaces, Gigabit Ethernet interfaces, ATM interfaces, HSSI interfaces, POS interfaces, FDDI interfaces, ASI interfaces, DHEI interfaces and the like.
  • these interfaces may include ports appropriate for communication with the appropriate media. In some cases, they may also include an independent processor and, in some instances, volatile RAM.
  • computing device may employ one or more memories or memory modules (such as, for example, the memory 915 ) configured to store data, program instructions and/or other information relating to the functionality of the techniques described herein.
  • the program instructions may control the operation of an operating system and/or one or more applications, for example.
  • machine-readable media that include program instructions, state information, etc. for performing various operations described herein.
  • machine-readable media include, but are not limited to, magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD-ROM disks; magneto-optical media such as floptical disks; and hardware devices that are specially configured to store program instructions, such as read-only memory devices (ROM) and random access memory (RAM).
  • program instructions include both machine code, such as produced by a compiler, and higher level code that may be executed by the computer (e.g., using an interpreter).

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Databases & Information Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Multimedia (AREA)
  • Software Systems (AREA)
  • Library & Information Science (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Information Transfer Between Computers (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

Method and apparatus for accessing media across networks. The present invention generally allows for media to be provided across a network. A client requests media information from a server so the client can create a local representation of the server's database. The client is then able to manage the media information locally. When the client selects the desired media, it requests the selection from across the network. The server then delivers the selected media.

Description

CROSS REFERENCE TO RELATED APPLICATIONS
This application is a divisional of U.S. application Ser. No. 10/423,638 entitled “ACCESSING MEDIA ACROSS NETWORK,” filed on Apr. 25, 2003 now U.S. Pat. No. 6,728,729 from which priority under 35 U.S.C. §120 is claimed, and which is incorporated herein in its entirety and for all purposes.
BACKGROUND OF THE INVENTION
1. Field of the Invention
The present invention relates to digital media and, more particularly, to accessing digital media across networks.
2. Description of the Related Art
The ability of computers to be able to share information is of utmost importance in the information age. Networks are the mechanism by which computers are able to communicate with one another. Generally, devices that provide resources are called servers and devices that utilize those resources are called clients. Depending upon the type of network, a device might be dedicated to one type of task or might act as both a client and a server, depending upon whether it is giving or requesting resources.
Increasingly, the types of resources that people want to share are entertainment-related. Specifically, music, movies, pictures, and print are all types of entertainment-related media that someone might want to access from across a network. For example, although a music library may reside on a family computer in the den, the media owner may want to listen to the music in the living room.
However, sharing media data can be a network-intensive process. People have devoted significant resources to both reducing the load on networks and increasing the capability of networks to handle large data transfers. Due to advances in compression technology and network bandwidth, the throughput of information through networks has increased dramatically over the years.
Although the described technologies work well in many applications, there are continuing efforts to further improve the ability to transfer digital media.
SUMMARY OF THE INVENTION
The present invention provides a method of retrieving media across a network. First, a client connects to a network that includes a server. The server includes at least one media database that has media and associated media information. The client then queries the server for at least a portion of the media information and then receives media information responsive to the query. The client then uses a client-side media management system to manage the received media information. Management of the received media information includes selecting media. The client then requests the selected media from across the network and, in response to the request, receives the requested media.
In another aspect, a client queries the server for server information and capabilities after connecting to the network. The client then receives a response that identifies the server and informs the client as to its capabilities. After receiving the server information, the client queries the server for database enumeration and receives a response that enumerates all databases, how much media is available, and how many media collections are available. After the database identification, the client queries the server for an enumeration of media collections in the database and receives a response that identifies media collections. The client then queries the server for data associated with an identified media collection, the query being capable of requesting a different level of detail than would be given by default. The response to the media collection query identifies data associated with the identified media collection in the requested level of detail. The client then executes the identified media collection, requesting media from the server when the media collection requires the media and receiving the requested media.
In yet another aspect, the invention provides a method of ensuring that a media database representation on a client is current. The server first provides a media database that updates to a current revision indicator whenever the media database is modified. Then, the server receives a request from the client, the request pertaining to the database that includes a client-provided revision indicator. After receiving the request, the server compares the current revision indicator to the client-provided revision indicator. The server then responds to the request with a response that includes at least an identification of the current revision indicator if the client-provided revision indicator did not match the current revision indicator.
BRIEF DESCRIPTION OF THE DRAWINGS
The invention may best be understood by reference to the following description taken in conjunction with the accompanying drawings in which:
FIG. 1 is a block diagram illustrating an exemplary environment in which the present invention may be implemented;
FIG. 2 is a block diagram illustrating an organizational structure of a server-side media management system on the server illustrated in FIG. 1;
FIG. 3 is a block diagram illustrating an organizational structure of a client-side media management system on the client illustrated in FIG. 1;
FIG. 4A is a representational control flow diagram illustrating one technique that can be used to determine the features of the server-side media management system illustrated in FIG. 2;
FIG. 4B is a representational control flow diagram illustrating one technique that could be used to enumerate databases of the server-side media management system illustrated in FIG. 2;
FIG. 4C is a representational control flow diagram illustrating one technique that could be used to populate a song records portion of the client-side media management system illustrated in FIG. 5;
FIG. 4D is a representational control flow diagram illustrating a technique that could be used to enumerate playlists of the server-side media management system illustrated in FIG. 2;
FIG. 4E is a representational control flow diagram illustrating a technique that could be used to populate a playlist records portion of the client-side media management system illustrated in FIG. 6;
FIG. 4F is a representational control flow diagram illustrating a technique that could be used to retrieve a song from a song database once a song is selected from the client-side media management system illustrated in FIG. 7;
FIG. 5 is a block diagram illustrating an organizational structure of the client-side media management system after receiving a reply to the SERVER-DATABASE request illustrated in FIG. 4B;
FIG. 6 is a block diagram illustrating an organizational structure of the client-side media management system after receiving a reply to the DATABASE-SONGS request illustrated in FIG. 4C;
FIG. 7 is a block diagram illustrating an organizational structure of the client-side media management system after receiving a reply to the PLAYLIST-SONGS request illustrated in FIG. 4E;
FIG. 8 is a representational control flow diagram illustrating one technique that could be used to ensure the client and the server illustrated in FIG. 1 are synchronized; and
FIG. 9 is a diagram illustrating an exemplary computing device in which various embodiments of the invention may be implemented.
It is to be understood that, in the drawings, like reference numerals designate like structural elements. Also, it is understood that the depictions in the figures are not necessarily to scale.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
In the following description, numerous specific details are set forth to provide a thorough understanding of the present invention. However, it will be obvious to one skilled in the art that the present invention may be practiced without some or all of these specific details. In other instances, well known process steps have not been described in detail in order to avoid unnecessarily obscuring the present invention.
The present invention generally allows for client machines to access a media database on a server. Both data and metadata on the server describes and organizes the media in various ways and allows the server to manipulate the media. Instead of relying on the server to execute the media management system, the client requests the data and metadata and then uses the information on a local media management system, effectively creating a representation of the server on the client. Once media is selected on the client through the client-side media management system, the client can request the media from the server, and the server can deliver the media to the client.
The invention can support both “thick” and “thin” clients. Thick clients are typically software programs, such as iTunes™ software available from Apple Computer, Inc. of Cupertino, Calif., operating on hardware devices that support full user interface abilities and have considerable processor and memory resources. Thin clients are software programs operating on hardware devices that may have limited user interface abilities and have reduced processing and memory resources. The invention allows for robust control features appropriate for thick clients, but can adapt to minimal control features for thin clients.
Generally, a client will first make a request to determine whether media is available on a server. Then, the client can make a series of requests to create a representation of the media available on the server on the client. The representation contains information about the media available on the server (“media information”). Thick clients can choose to retrieve a complete representation of the server's available media, while thin clients may choose to retrieve a partial representation of the server's available media. After receiving the media information from the server, the client (as instructed by its user) can then search, browse, sort, or otherwise interact with the media information now resident on the client. Further, the client (as instructed by its user) will typically select a media item to be presented (e.g., played). In such a case, the media content for the selected media item is streamed from the server to the client.
In addition, clients can receive notifications from the server when a media database has been changed. Multiple connections can allow a client to use one connection to access media while using another connection to wait for a notification that the database has changed, or to browse media listings.
FIG. 1 is a block diagram illustrating an exemplary environment in which the present invention may be implemented. A network 105 couples a server 110 to various clients 115, 120, 125, and 130. The network 105 can generally be a data network, such as a LAN, WAN or the Internet. The server 110 may or may not be a dedicated device. In the example shown in FIG. 1, the server 110 is a general purpose computer. The various clients 115, 120, 125, and 130 can be thick or thin clients, with varying levels of processing power. Clients may include portable computers 115, desktop computers 120, specialized devices such as iPods™ 125 available from Apple Computer, Inc. of Cupertino, Calif., or even network-aware audio/video components 130 that are designed to work across a network 105. The following discussion will, for simplicity, assume only the portable computer client 115 is requesting information from the server 110.
FIG. 2 is a block diagram illustrating an organizational structure of a server-side media management system 200 on the server 110. The server-side media management system 200 includes a media manager 210 and a music database 205. The media manager 210 controls access to the music database 205. More particularly, the media manager 210 receives requests from the client 115, accesses the music database, and returns responses to the client 115.
The music database 205 has a number of records 215 and 220 that are used to classify, identify and/or describe media (i.e., media items) in the music database 205. For simplicity, the following discussion will assume the digital media contained on the server 110 only contains music files that can be streamed over the network 105. It should be appreciated that any reference to “songs” or “music” made in this document could be generalized to any form of digital media, which can include sound files, picture data, movies, text files or any other types of media that can be digitally stored on a computer. Similarly, any reference to “playlists” can be generalized to media collections, including collections of mixed digital media.
The media manager 210 has or can obtain information about the database 205 that may, for example, include the name of the server, the version of the database being used, the type of security that is required, the number of databases available to the server, whether non-standard content codes are supported, whether persistent identification is supported, etc. It should be appreciated by those skilled in the art that the information about the database 205 may exist in a single record file or can be either partially or fully generated on demand, identifying the various pieces of information as needed.
The song records 215 contain metadata about each media item available in the database 205. The metadata might include, for example, the names of songs, an identification number, a persistent identification number, the artist, the album, the size of the song, the format of the song, the required bit rate, and any other appropriate information. Of course, the type of information may depend on the type of media. A video file might additionally have director and producer fields, but may not use the album field. Still pictures would have no need for bit rate information. While some fields may be standard, others may be specific to certain applications. For example, a video signal may have secondary audio program (SAP) information. A mechanism for ensuring clients can properly process non-standard content codes is described in connection with FIG. 4A.
Both an identification number and a persistent identification number can be used. If supported, a persistent identification could be used to access the same information across server restarts. Typically, a server would assign each record a new identification number every time the media management system 200 restarted. However, persistent identification numbers would remain the same for as long as the record is available.
The playlist records 220 contain information about each playlist available in the music database 205. Further, the information for a given playlist can include the identification numbers for each of the songs within the playlist. Playlists are collections of media that may or may not be in any particular order. Users may choose to combine media by genre, mood, artists, audience, or any other meaningful arrangement. While the playlists 220 on the server 110 will usually only include media contained in its own music database 205, there is no reason the playlist records 220 cannot include media or playlists stored on other servers. However, certain non-standard content codes may need to be used, depending upon the implementation of the server-side media management system 200.
FIG. 3 is a block diagram illustrating an organizational structure of a client-side media management system 300 on one of the clients 115. The client-side media management system 300 includes a media manager 305. The media manager 305 interacts with the media manager 210 of the server-side media management system 200 through the network 105 so as to replicate at least a portion of the music database 205 at the server 110 on the client 115. When the client-side media management system 300 first starts, it cannot access media on the server 110 because it does not as yet have any information about what media is available.
FIG. 4A is a representational control flow diagram illustrating one technique that can be used to determine the features of the server-side media management system 200. Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 403 and 406. At 409 the client 115 connects to the network 105 and first becomes aware of the server 110. The client 115 can use any connection mechanism that allows it to interact with the network 105. For example, if the client 115 were an iBook™, available from Apple Computer, Inc. of Cupertino, it might use Rendezvous™ networking technology, also available from Apple Computer, Inc. of Cupertino, Calif., in order to automatically configure itself with the network 105. If the client is not aware of the server 110, other mechanisms can be used. For example, a user might manually search for the server 110, or the user might directly enter the address of the server 110.
Once the client 115 is aware of the server 110, it can send a SERVER-INFO request to the server 110 at 412. The SERVER-INFO request is usually used to obtain information from the server prior to attempting any other transactions. If the network 105 uses the TCP/IP protocol, the request could be formatted as an HTTP GET request. The GET request might also allow for additional extensions to be added to the request, enabling, for example, the client 115 to include information about the client-side media management system 300.
At 415 the server responds to the SERVER-INFO request with information describing a series of features supported by or required by the server. The information might, for example, include information about the server-side media management system 200, the number of available databases, whether and what login procedures are required, whether updates are supported, whether persistent identification numbers are supported, whether non-standard content codes are supported, and the protocol version.
The information provided to the client 115 at 415 permits the client-side media management system 300 to understand the capabilities of the server 110. Although the client 115 is able to identify the server 110, the client 115 does not yet have any information about the available media.
If the client 115 determines that the server 110 responded to the SERVER-INFO request with an indication that non-standard content codes are supported at 418, the client 115 can optionally issue a CONTENT CODE request at 421. The CONTENT CODE request is one mechanism by which the client 115 can obtain a list of content codes supported by the server 110 and associated string names mapped thereto.
The inclusion of the string name allows multiple developers to use the same codes for their individualized products. For example, one developer may assign the code “16000” to a feature that allows users to purchase corresponding albums over the network; while another developer may assign the same code to feature that provides users with the lyrics of songs that are being listened to. By allowing a string name to be included, the client 115 can determine whether it can support the content code. Uniqueness of the string name can, for example, be ensured by including the developer's URL as part of the string name.
At 424 the server 110 responds to the CONTENT CODE request the codes and their associated string names. At 427, the client 115 can simply ignore the code/string pairs that it does not recognize. Otherwise, for those code/string pairs that the client 115 does recognize, the client 115 will associate the code with the associated string name.
At 430 the client 115 logs into the server 110. The login procedure might require a user name (or account name) and password so the user of the client can be authenticated. The login procedure is only required if the server 110 requires it. Certain security protocols might require that every future request made by the client 115 include certain parameters such as a session identification number.
Once logged in, the client 115 is ready to begin populating its local representation of the music database 205. FIG. 4B is a representational control flow diagram illustrating one technique that can be used to enumerate databases of the server-side media management system 200. Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 403 and 406. At 433 the client 115 can issue a SERVER-DATABASE request, which can be used to retrieve the list of all music databases from the server 110. The SERVER-DATABASE request may additionally include an index range and/or a query. Although available to both thick and thin clients, thin clients might use index ranges and/or queries to limit the amount of data contained in each server response.
The index range might be used in any request to constrain the items returned in the response to a subset of the total set of items, based on the position (or index) of the first item and the number of items requested. For example, an index range could be used to request: the second music database from a server, songs 10 through 20 from a music database, the last 5 playlists from a music database, the first 5 songs from a given playlist, or the 42nd song in a music database.
The query might be used in any request to constrain the items returned in the response to a subset of the total set of items, based on the specified criteria. For example, a query could request: songs in a database after a given year; playlists that contain a certain word in their name; songs in a database that do not contain a given word in their name; or some combination thereof.
After processing the SERVER-DATABASE request at 436, the server 110 issues a response at 439. If no index range and/or query was given, the response would contain a complete list of the music databases available at the server 110 together with information about the one or more music databases. The information about each database might, for example, include the database identification number, the persistent database identification number, the name for each database, the numbers of songs, and the number of playlists. With this information, the client-side media management system 300 becomes aware of the general structure of the one or more music databases at the server 110.
FIG. 5 is a block diagram illustrating the organizational structure of the client-side media management system 300 shown in FIG. 3 after receiving a reply to the SERVER-DATABASE request. At 442, the client 115 is able to identify the music database 510, the number of available song records 515, and the number of available playlists 520. Once the general structure of the music database 510 is known, the client 115 can populate its representation using any number of techniques.
FIG. 4C is a representational control flow diagram illustrating one technique that could be used to populate the song records 515 portion of the client-side media management system 300 for a specific database 510. Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 403 and 406. At 445 the client issues a DATABASE-SONGS request to obtain metadata about available songs.
A thick client may choose to issue a DATABASE-SONGS request so that it can front load network traffic. Once metadata about a song is received and stored, the client 115 does not need to request that metadata again. Playlists would only need to correctly identify a song (e.g., using the song identification number), and the client-side media management system 300 would be able to associate it with the already-received metadata.
Thin clients may choose to issue an index range, query, metadata field specifier, or skip 445 all together. A metadata field specifier would indicate that only certain metadata fields are desired. Thick clients that use 445 may also choose to use these same index range, query or metadata field specifier techniques. For example, limiting the song metadata request to only songs in a certain genre might be a technique that is used to provide the user with a different user experience.
The server 110 performs any necessary filtering operations at 448 and then issues a reply at 451. FIG. 6 is a block diagram illustrating the organizational structure of the client-side media management system 300 at 453, after receiving a reply to the DATABASE-SONGS request. The song records 605 may either be a partial or complete representation of the server-side song records 215, having metadata that might, for example, include the names of songs, an identification number, a persistent identification number, the artist, the album, the size of the song, the format of the song, the required bit rate, and any other appropriate information. If the server-side management system 200 had multiple databases, a DATABASE-SONGS request (if used) would need to be issued for each database
FIG. 4D is a representational control flow diagram illustrating a technique that could be used to enumerate the playlist records 220 portion of the server-side media management system 200. Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 403 and 406.
At 454 the client issues a DATABASE-PLAYLIST request to obtain a list of available playlists. Playlists on the server 110 can either be user-identified or generated automatically by the server-side media management system 200. For example, a “base playlist” might be automatically created as a special playlist that contains all the songs in the entire song database 205 while a “John Lennon playlist” might be a user-created collection of songs by John Lennon.
After receiving the DATABASE-PLAYLIST request and performing any necessary filtering operations, the server 110 issues a reply at 457. The reply includes a list of all playlists in the music database 205 and information about those playlists. The information about the playlists might, for example, include identification numbers and/or persistent identification numbers for the playlists, and any other information (e.g., whether the songs in the playlist are in order or can be shuffled) that may have been provided. Multiple DATABASE-PLAYLIST requests may be required to populate multiple databases.
FIG. 4E is a representational control flow diagram illustrating a technique that could be used to populate the playlist records 520 portion of the client-side media management system 300. Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 403 and 406. Once a playlist is identified at 460, the client 115 sends a PLAYLIST-SONGS request for that playlist at 463. Depending upon whether operations 445 through 451 were already performed, the PLAYLIST-SONGS request could additionally request that metadata accompanying each song also be delivered in order to populate the song records 605. Although thick clients that do not have a mechanism for informing the server 110 of already-received song records 605 would run the risk of receiving duplicate song records 605, thin clients that did not retain song records 605 might benefit from requesting song metadata along with each playlist.
After receiving the PLAYLIST-SONGS request and performing any necessary filtering operations, the server 110 issues a reply at 466 containing the requested information. FIG. 7 is a block diagram illustrating the organizational structure of the client-side media management system 300 after receiving a reply to the PLAYLIST-SONGS request at 469. Each time the PLAYLIST-SONGS transaction between the client 115 and the server 110 is completed, another playlist record 705 is populated. The playlist record 705 may be a complete or partial representation of the corresponding server-side playlist record 220. Multiple PLAYLIST-SONGS requests may be required to populate multiple playlists.
FIG. 4F is a representational control flow diagram illustrating a technique that could be used to retrieve a song from the song database 205 once a song is selected. Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 403 and 406.
At 472 the client 115 issues a SONG-DATA request to retrieve the song data from the server 110. If a single song is stored in multiple formats on the server 100, the SONG-DATA request could include a format identifier. The format identifier could specify that the song is requested in, for example, MPEG 3 encoded data (“mp3”), MPEG 4 advanced audio coding (“m4a”) audio interchange file format (“aiff”), or Windows sound file (“wav”). At 475 the server 110 delivers the audio file to the client 115. In one embodiment, the server 110 will stream the song by appending song data to an http header, therefore making the client 115 responsible for parsing the data as is appropriate for playing the song at the client 115.
The preceding description assumes no mechanism is used to update the client 115 if the data on the server-side media management system 200 is modified during a session. For example, a client-side representation of a playlist 705 may not accurately represent the latest version of the corresponding server-side playlist 220.
FIG. 8 is a representational control flow diagram illustrating one technique that could be used to ensure the client 115 and the server 110 are synchronized. Operations performed by the client 115 and the server 110 are represented by corresponding vertical lines 805 and 810.
At 815 the client 115 issues an UPDATE request to retrieve the media data from the server 110. The UPDATE request can be a flag that informs the server 110 that the client 115 wants to be informed when data on the server 110 (e.g., music database 205) changes. In one embodiment, the flag is a revision indicator, such as a revision number or a time-stamp.
At 820 the server 110 processes the UPDATE request. In one embodiment, the server 110 will not respond to the UPDATE request until the server's music database has changed relative to the client's representation for that music database. If a revision number was used at 815, the server 110 compares the revision number provided by the client 115 with the current revision number to determine if a change was made. The revision number of the server 110 represents the version of the music database 205 at the server 110. Any subsequent changes to records 215 or 220 may cause the server 110 to increment its revision number by one. Depending upon the requirements of the system, a group of changes to records 215 or 220 may be batched so that the revision number only increments once. Batching may be performed by standard techniques, including by operation (e.g., adding files as a group to the server), by time (e.g., waiting a certain period of time after the last change has been made to ensure no other changes will be made) or by number of operations (e.g., changing the revision number after a certain number of changes).
Once the server 110 determines that the revision number provided by the client no longer equals the current revision number, a reply is issued at 825. In one embodiment, the reply will contain the server's current revision number. Although the server 110 could then the continue to monitor for changes in the server's current revision number, the client 115 might re-issue a new UPDATE request with the server's current revision number, essentially repeating operation 815 with the updated revision number. Some systems might have the client 115 always start with a client-generated revision number of “1” and the server 110 always start with a revision number “2” in order to force the server 110 to issue an UPDATE reply the first time it receives an UPDATE request. Such an approach can provide the client 115 with an impetus for populating its local representation of the music database 205 with a SERVER-DATABASE request (see FIG. 4B at 433). Additionally, an UPDATE reply might also be used to notify a client 115 that the server is about to terminate connection (possibly due to timeout or server shutdown), perhaps by issuing a current revision number of 0.
In addition to the UPDATE request, the client 115 could also include a revision number field in any of the requests 433, 445, 454, and 463. The server 110 would then, on a request-by-request basis, check the revision number provided with the requests with the revision number for that particular request. If the revision numbers did not match, the server 110 would issue an UPDATE reply, specifying the current revision number and perhaps the corresponding reply. Otherwise, the server 110 would comply with the request as previously described.
In one embodiment, the database requests 433, 445, 454, and 463 would additionally support incremental updating in order to reduce network traffic (and to improve user experience through greater responsiveness). Incremental updates would allow the client to request only the changes from a historical revision number to a current revision number. If, for example, the client 115 had populated its playlists records 705 with information from revision “5,” and then the client is notified by the server 110 that the latest revision is “8,” the client can issue a new PLAYLIST-SONGS request 463, requesting only the information that has changed from revision “5” to revision “8.” As long as the server 110 maintains or has access to a historical record of modifications from each revision number, it would be able to comply with the incremental request.
However, an optimization might allow for the server 110 to determine whether complying with the incremental request would actually be more efficient than re-sending the entire reply. In certain circumstances (e.g., when more than half of the songs in the playlist were deleted), it would use less network resources to reply with a full PLAYLIST-SONGS reply 466 instead of an incremental reply. However, when the PLAYLIST-SONGS reply 466 provides a full reply, the reply would advantageously include an indication that the data does not represent an incremental update, so the client 115 will be able to properly handle the information.
Generally, the techniques of the present invention may be implemented on software and/or hardware. For example, they can be implemented in an operating system, in a separate user process, in a library package bound into network applications, or on a specially constructed machine. In a specific embodiment of this invention, the technique of the present invention is implemented in software such as an operating system and/or in an application program running on the operating system.
A software or software/hardware hybrid implementation of the techniques of this invention may be implemented on a general-purpose programmable machine selectively activated or reconfigured by a computer program stored in memory. In an alternative embodiment, the techniques of this invention may be implemented on a general-purpose network host machine such as a personal computer, workstation or server. Further, the invention may be at least partially implemented on a general-purpose computing device.
Referring now to FIG. 9, a computing device 900 suitable for implementing the techniques of the present invention includes a master central processing unit (CPU) 905, interfaces 910, memory 915 and a bus 920. When acting under the control of appropriate software or firmware, the CPU 905 may be responsible for implementing specific functions associated with the functions of a desired computing device. The CPU 905 preferably accomplishes all these functions under the control of software including an operating system (e.g., Mac OS X), and any appropriate applications software (e.g., iTunes).
CPU 905 may include one or more processors such as those from the Motorola family of microprocessors or the MIPS family of microprocessors. In an alternative embodiment, the processor is specially designed hardware for controlling the operations of computing device 900.
The interfaces 910 are typically provided as interface cards. Generally, they control the sending and receiving of data packets over the network and sometimes support other peripherals used with the computing device 900. Among the interfaces that may be provided are Ethernet interfaces, frame relay interfaces, cable interfaces, DSL interfaces, token ring interfaces, and the like. In addition, various very high-speed interfaces may be provided such as fast Ethernet interfaces, Gigabit Ethernet interfaces, ATM interfaces, HSSI interfaces, POS interfaces, FDDI interfaces, ASI interfaces, DHEI interfaces and the like. Generally, these interfaces may include ports appropriate for communication with the appropriate media. In some cases, they may also include an independent processor and, in some instances, volatile RAM.
Regardless of computing device's configuration, it may employ one or more memories or memory modules (such as, for example, the memory 915) configured to store data, program instructions and/or other information relating to the functionality of the techniques described herein. The program instructions may control the operation of an operating system and/or one or more applications, for example.
Because such information and program instructions may be employed to implement the systems/methods described herein, the present invention relates to machine readable media that include program instructions, state information, etc. for performing various operations described herein. Examples of machine-readable media include, but are not limited to, magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD-ROM disks; magneto-optical media such as floptical disks; and hardware devices that are specially configured to store program instructions, such as read-only memory devices (ROM) and random access memory (RAM). Examples of program instructions include both machine code, such as produced by a compiler, and higher level code that may be executed by the computer (e.g., using an interpreter).
Although illustrative embodiments and applications of this invention are shown and described herein, many variations and modifications are possible which remain within the concept, scope, and spirit of the invention, and these variations would become clear to those of ordinary skill in the art after perusal of this application. Accordingly, the present embodiments are to be considered as illustrative and not restrictive, and the invention is not to be limited to the details given herein, but may be modified within the scope and equivalents of the appended claims.

Claims (33)

What is claimed is:
1. A method of retrieving digital media comprising:
querying a server for database enumeration via a client device to yield a first query;
receiving a response to the database enumeration query that includes at least information about at least one a remote digital media database coupled to the server, wherein the information about the at least one remote digital media database includes at least metadata about one or more remote records within the at least one remote digital media database, and wherein the one or more remote records pertain to one or more of digital media, digital media metadata or media collection data;
using the metadata to effectively provide a first representation of the one or more remote records at the client device;
querying, via the client device, the server for information required to populate one or more local records associated with the metadata after receiving the metadata to yield a second query, wherein the one or more local records are part of a local database at the client device;
receiving the information required to populate the one or more local records associated with the metadata in response to the querying of the server second query;
populating the one or more local records at the local database on the client device after receiving the information required to populate the one or more local records, thereby effectively providing one or more local populated records based on the metadata associated with the one or more remote records;
querying the remote database for information to update the local populated records at the local database;
using the one or more local populated records to effectively provide a second representation of the one or more remote records; and
subsequently retrieving digital media associated with at least one of the one or more local populated records,
wherein the one or more local records are part of a local database, and wherein said populating of the one or more local records operates to replicate at least a portion of the remote digital media database to the local database, and
wherein the first representation provides a first level of detail with respect to the one or more remote records, wherein the second representation provides a second level of detail with respect to the one or more remote records, and wherein the second level of detail represents the one or more records in greater detail than the first level of detail.
2. The method of claim 1, wherein the remote records pertain to both digital media metadata and media collections and multiple queries are required to populate the local records associated with the metadata.
3. The method of claim 1 further comprising using a local database management system to manage the information contained in the local records of the local database, the local records including media collection data records and digital media metadata records.
4. The method of claim 1, wherein the server is a remote device accessible across a network, and wherein said method further comprises:
querying the server for media collection enumeration with respect to the at least one digital media database; and
receiving a response to the media collection enumeration query that includes at least information about one or more media collections.
5. The method of claim 1 wherein, said retrieving of the digital media comprises:
requesting media from across a network; and
receiving the requested media across the network.
6. The method of claim 5 further comprising presenting the received media at a client device, wherein presenting the received media includes playing the media for a user.
7. A method as recited in claim 1, wherein the one or more populated records effectively provide a representation of the one or more remote records.
8. A method as recited in claim 1,
wherein the first representation represents the one or more remote records in accordance with a first aspect of representation; and
wherein the second representation represents the one or more remote records in accordance with a second aspect of representation that is different than the first aspect of representation.
9. A method as recited in claim 1, wherein said method further comprises:
querying the server for information required to provide a third representation of the one or more remote records.
10. A method as recited in claim 1, wherein said method further comprises:
querying the server for information required to further populate the at least one record in order to effectively provide a third representation of the one or more remote records.
11. A computing system for retrieving digital media, wherein said computing system comprises:
a processing unit configured to provide at least perform operations comprising:
means for querying a server for database enumeration;
means for receiving a response to the database enumeration query that includes at least information about at least one digital media database coupled to the server, wherein the information about the at least one digital media database includes at least metadata about one or more remote records within the at least one digital media database, wherein the metadata effectively represents the one or more remote records as a first representation, and wherein the one or more remote records pertain to one or more of digital media, digital media metadata or media collection data;
means for querying the server for information required to populate one or more local records associated with the metadata after receiving the metadata;
means for receiving the information required to populate the one or more local records associated with the metadata in response to the querying of the server;
means for populating the one or more local records after receiving the information required to populate the one or more local records, thereby effectively providing one or more populated records based on the metadata associated with the one or more remote records, wherein the one or more populated records effectively represents the one or more remote records as a second representation;
querying the remote database for information to update the local populated records at the local database;
means for subsequently retrieving digital media associated with at least one of the populated records,
wherein the one or more local records are part of a local database, and wherein said means for populating of the one or more local records operates to replicate at least a portion of the digital media database to the local database, and wherein the first representation provides a first level of detail with respect to the one or more remote records, wherein the second representation provides a second level of detail with respect to the one or more remote records, and wherein the second level of detail represents the one or more records in greater detail than the first level of detail.
12. A server for providing digital media to one or more devices, wherein said server comprises:
a processing unit configured to provide at least perform operations comprising:
means for receiving a query from a device for database enumeration;
means for sending the features of the server to the device in response to the query, the features including enumeration data about at least one digital media database, wherein the information about the at least one digital media database includes at least metadata about one or more records within the at least one digital media database, wherein the metadata can be used by the device to locally present one or more local records at the device as a first local presentation of at least a portion of the at least one digital media database, and wherein the records pertain to one or more of digital media, digital media metadata or media collection data;
means for receiving a querying query from the device for information required by the device to populate the one or more local records associated with the first local presentation;
means for sending the device information required to populate the one or more local records associated with the first local presentation, thereby allowing the device to populate the one or more local records after receiving the information required to populate the one or more local records in order to present the one or more local records as one or more populated records;
means for receiving a subsequent query from the device regarding at least one of the one or more populated records, the subsequent query requesting information for updating the one or more populated records; and
means for sending digital media associated with the at least one populated record after receiving the second query from the device,
wherein the one or more local records are part of a local database provided at the device, and wherein population of the one or more local records at the device operates to replicate at least a portion of the digital media database to the local database,
wherein the one or more populated records can be used to locally present the portion of the at least one digital media database at the device as a second local presentation, and
wherein the first local presentation provides a first level of detail with respect to the one or more populated records, wherein the second local presentation provides a second level of detail with respect to the one or more populated records, and wherein the second level of detail represents the one or more records in greater detail than the first level of detail.
13. A computer readable storage medium including at least executable computer program code tangibly stored thereon for retrieving digital media, comprising:
computer program code for querying a server for database enumeration;
computer program code for receiving a response to the database enumeration query that includes at least information about at least one digital media database, wherein the information about the at least one digital media database includes at least metadata about one or more remote records within the at least one digital media database, wherein the metadata effectively represents the one or more remote records as a first representation, and wherein the one or more remote records pertain to one or more of digital media, digital media metadata or media collection data, the metadata being used to effectively provide a first representation of the one or more remote records;
computer program code for querying the server, based on the metadata, for information required to populate one or more of the local records associated with the metadata after receiving the metadata;
computer program code for receiving the information required to populate the one or more of the local records associated with the metadata in response to the querying of the server,
computer program code for populating the one or more local records after receiving the information required to populate the one or more local records, thereby effectively providing one or more populated records based on the metadata associated with the one or more remote records, the one or more populated records being used to effectively provide a second representation of the one or more remote records; and
computer code for querying the remote database for information to update the local populated records at the local database; and
computer program code for retrieving digital media associated with at least one of the populated records based on the populated one or more records,
wherein the one or more local records are part of a local database, and wherein said computer program code for populating of the one or more local records operates to replicate at least a portion of the digital media database to the local database, and
wherein the first representation provides a first level of detail with respect to the one or more remote records, wherein the second representation provides a second level of detail with respect to the one or more remote records, and wherein the second level of detail represents the one or more records in greater detail than the first level of detail.
14. A computer readable storage medium as recited in claim 13, wherein the remote records pertain to both digital media metadata and media collections and multiple queries are required used to populate the local records associated with the metadata.
15. A computer readable storage medium as recited in claim 13,
wherein the first representation represents the one or more remote records in accordance with a first aspect of representation; and
wherein the second representation represents the one or more remote records in accordance with a second aspect of representation that is different than the first aspect of representation.
16. A computer readable storage medium as recited in claim 13, wherein the computer readable medium further comprises:
computer program code for querying the server for information required to provide a third representation of one or more remote records.
17. A computer readable storage medium as recited in claim 13, wherein the computer readable medium further comprises:
computer program code for querying the server for information required to further populate the one or more local records in order to effectively provide a third representation of the one or more remote records.
18. A computer readable storage medium as recited in claim 13, further comprising:
computer program code for determining whether the digital media database has been updated since the one or more local records were populated from information provided by the digital media database.
19. A computer readable storage medium including at least executable computer program code tangibly stored thereon for providing digital media to one or more devices, wherein said computer readable medium comprises:
computer program code for receiving a query from a device for database enumeration;
computer program code for sending the features of the server to the device in response to the query, the features including enumeration data about at least one digital media database, wherein the information about the at least one digital media database includes at least metadata about one or more records within the at least one digital media database, wherein the metadata can be used by the device to locally present one or more local records at the device as a first local presentation of at least a portion of the at least one digital media database, and wherein the records pertain to one or more of digital media, digital media metadata or media collection data;
computer program code for receiving a querying from the device for information required by the device to populate the one or more local records associated with the first local presentation;
computer program code for sending the device information required to populate the one or more records associated with the first local presentation, thereby allowing the device to populate the one or more local records after receiving the information required to populate the one or more local records in order to present the one or more local records as one or more populated records;
computer program code for receiving a subsequent query from the device regarding at least one of the one or more populated records, the subsequent query requesting information for updating the at least one of the one or more populated records; and
computer program code for sending digital media associated with the at least one populated record after receiving the second query from the device,
wherein the one or more local records are part of a local database, and wherein the population of the one or more local records at the device operates to replicate at least a portion of the digital media database to the local database,
wherein the one or more populated records can be used to locally present the portion of the at least one digital media database at the device as a second local presentation, and
wherein the first local presentation provides a first level of detail with respect to the one or more remote records, wherein the second local presentation provides a second level of detail with respect to the one or more remote records, and wherein the second level of detail represents the one or more records in greater detail than the first level of detail.
20. A computing device comprising:
a processor;
memory, operably connected with the processor,
wherein the processor is operable to perform instructions including:
connecting to a server, the server including media information;
querying the server for at least a portion of the media information;
receiving media information responsive to the query;
requesting at least one media item associated with the media information responsive to the query; and
receiving the media item,
wherein said querying includes a plurality of distinct queries to the server, and wherein said querying includes at least:
querying the server for database enumeration; and
wherein said receiving of the media information includes a plurality of distinct responses to the queries, and wherein said receiving includes at least:
receiving a response to the database enumeration query that includes descriptive information on at least one remote database, the descriptive information including how much media is available from the at least one remote database or how many media collections are available from the at least one remote database or both,
wherein said method further includes at least:
receiving the information required to populate the one or more of the local records associated with the metadata in response to the querying of the server;
populating the one or more local records after receiving the information required to populate the one or more local records, thereby effectively providing one or more populated records based on the metadata associated with the one or more remote records; and
querying the server for information to update the one or more populated records;
retrieving digital media associated with at least one of the populated records based on the populated one or more records,
wherein the one or more local records are part of a local database, and wherein by population of the one or more local records, at least a portion of the remote database is replicated to the local database,
wherein the metadata being used to effectively provide a first representation of the one or more remote records, wherein the one or more populated records being used to effectively provide a second representation of the one or more remote records, and
wherein the first representation provides a first level of detail with respect to the one or more remote records, wherein the second representation provides a second level of detail with respect to the one or more remote records, and wherein the second level of detail represents the one or more records in greater detail than the first level of detail.
21. The computing device of claim 20,
wherein said querying includes at least:
querying the server for media collection enumeration, and
wherein said receiving includes at least:
receiving a response to the media collection enumeration query that includes descriptive information on at least one media collection available from the at least one database.
22. The computing device of claim 20,
wherein said querying includes at least:
querying the server for server capabilities, and
wherein said receiving includes at least:
receiving a response to the server capabilities query that describes the server capabilities.
23. The computing device of claim 20, wherein querying the server for at least a portion of the media information includes at least a request for an enumeration of at least a portion of the media collections.
24. A computer readable storage medium as recited in claim 18, wherein said computer program code for determining whether the digital media database has been updated comprises:
computer program code for updating to a current revision indicator whenever the digital media database is modified;
computer program code for comparing the current revision indicator to a client-provided revision indicator, the client-provided revision indicator being provided with a request being received from a client, the request pertaining to the at least one digital media database and including a client-provided revision indicator, and
computer program code for responding to the request with a response that includes at least an identification of the current revision indicator if the client-provided revision indicator did not match the current revision indicator.
25. A method comprising:
querying a server for database enumeration to yield a first query, the database enumeration including information about a remote database coupled to the server, the information including how much media is available from the remote database or how many media collections are available from the remote database;
in response to the first query, receiving information about a remote database associated with the server, wherein the information includes metadata about one or more remote records in the remote database;
based on the information, providing a first representation of the one or more remote records in the remote database;
querying the server for content information to populate one or more local records to yield a second query, wherein the one or more local records are stored in a local database at a client device, and wherein the one or more local records to be populated are selected based on the first representation of the one or more remote records at the remote database;
in response to the second query, receiving the content information to populate the one or more local records stored in the local database;
querying the server for information to update the one or more local records at the local database;
based on the content information, populating the one or more local records in the local database to yield one or more populated records, wherein populating the one or more local records comprises replicating at least a portion of the remote database to the local database; and
providing, at the client device, a second representation of the one or more remote records based on the one or more populated records.
26. The method of claim 25, wherein the method is performed by a client-side media management system.
27. The method of claim 25, wherein:
the method is performed by a client-side media management system;
the query indicates the portion; and
the portion is at least partially based upon whether the client-side media management system has a limited memory, whereby the limited memory is not sufficient to store all the media information available from the server.
28. The method of claim 25, wherein:
the query indicates the portion; and
the portion is at least partially based upon providing a user with a customized experience.
29. The method of claim 25, wherein the server is a remotely located computing device that is connectable to the network.
30. A system comprising:
a processor; and
a memory having stored therein instructions which, when executed by the processor, cause the processor to perform operations comprising:
querying a server for database enumeration to yield a first query, the database enumeration including information about a remote database coupled to the server, the information including how much media is available from the remote database or how many media collections are available from the remote database;
in response to the first query, receiving information about a remote database associated with the server, wherein the information includes metadata about one or more remote records at the remote database;
based on the information, providing a first representation of the one or more remote records at the remote database;
querying the server for content information to populate one or more local records to yield a second query, wherein the one or more local records are stored in a local database, and wherein the one or more local records to be populated are selected based on the first representation of the one or more remote records at the remote database;
in response to the second query, receiving the content information to populate the one or more local records stored in the local database;
based on the content information, populating the one or more local records in the local database to yield one or more populated records, wherein populating the one or more local records comprises replicating at least a portion of the remote database to the local database;
querying the server for information to update the one or more populated records at the local database; and
providing, at the client device, a second representation of the one or more remote records based on the one or more populated records.
31. The computing device of claim 30, wherein the processor is operable to perform instructions including:
querying the server for server capabilities; and
receiving a response to the server capabilities query that describes the server.
32. The computing device of claim 30, wherein the processor is operable to perform instructions including:
querying the server for database enumeration; and
receiving a response to the database enumeration query that describes at least one database, the description including how much media is available from the at least one database or how many media collections are available from the at least one database or both.
33. The computing device of claim 30, wherein querying the server for at least a portion of the media information is a request for an enumeration of at least a portion of media collections.
US13/445,791 2003-04-25 2012-04-12 Accessing digital media Active 2024-11-20 USRE45793E1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
US13/445,791 USRE45793E1 (en) 2003-04-25 2012-04-12 Accessing digital media
US14/866,639 USRE47934E1 (en) 2003-04-25 2015-09-25 Accessing digital media

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US10/423,638 US6728729B1 (en) 2003-04-25 2003-04-25 Accessing media across networks
US10/799,412 US7698297B2 (en) 2003-04-25 2004-03-12 Accessing digital media
US13/445,791 USRE45793E1 (en) 2003-04-25 2012-04-12 Accessing digital media

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US10/799,412 Reissue US7698297B2 (en) 2003-04-25 2004-03-12 Accessing digital media

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US10/799,412 Continuation US7698297B2 (en) 2003-04-25 2004-03-12 Accessing digital media

Publications (1)

Publication Number Publication Date
USRE45793E1 true USRE45793E1 (en) 2015-11-03

Family

ID=32108167

Family Applications (4)

Application Number Title Priority Date Filing Date
US10/423,638 Expired - Lifetime US6728729B1 (en) 2003-04-25 2003-04-25 Accessing media across networks
US10/799,412 Ceased US7698297B2 (en) 2003-04-25 2004-03-12 Accessing digital media
US13/445,791 Active 2024-11-20 USRE45793E1 (en) 2003-04-25 2012-04-12 Accessing digital media
US14/866,639 Active 2024-11-20 USRE47934E1 (en) 2003-04-25 2015-09-25 Accessing digital media

Family Applications Before (2)

Application Number Title Priority Date Filing Date
US10/423,638 Expired - Lifetime US6728729B1 (en) 2003-04-25 2003-04-25 Accessing media across networks
US10/799,412 Ceased US7698297B2 (en) 2003-04-25 2004-03-12 Accessing digital media

Family Applications After (1)

Application Number Title Priority Date Filing Date
US14/866,639 Active 2024-11-20 USRE47934E1 (en) 2003-04-25 2015-09-25 Accessing digital media

Country Status (5)

Country Link
US (4) US6728729B1 (en)
EP (2) EP1843260A3 (en)
JP (3) JP4176801B2 (en)
CN (1) CN100533435C (en)
WO (1) WO2004097683A2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
USRE47934E1 (en) * 2003-04-25 2020-04-07 Apple Inc. Accessing digital media

Families Citing this family (300)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE10085457T1 (en) 1999-11-16 2003-08-28 Cfph Llc Systems and processes for reselling electronic goods
US8645137B2 (en) 2000-03-16 2014-02-04 Apple Inc. Fast, language-independent method for user authentication by voice
US20030172079A1 (en) * 2002-03-08 2003-09-11 Millikan Thomas N. Use of a metadata presort file to sort compressed audio files
US20030182139A1 (en) * 2002-03-22 2003-09-25 Microsoft Corporation Storage, retrieval, and display of contextual art with digital media files
US7478126B2 (en) * 2002-04-08 2009-01-13 Sony Corporation Initializing relationships between devices in a network
US7614081B2 (en) * 2002-04-08 2009-11-03 Sony Corporation Managing and sharing identities on a network
US20030191753A1 (en) * 2002-04-08 2003-10-09 Michael Hoch Filtering contents using a learning mechanism
US20030191720A1 (en) * 2002-04-08 2003-10-09 Himgan Wibisono Electronic tracking tag
US20060095450A1 (en) * 2002-09-27 2006-05-04 Millikan Thomas N Use of a metadata presort file to sort compressed audio files
US20060026376A1 (en) * 2002-10-16 2006-02-02 Microsoft Corporation Retrieving graphics from slow retrieval storage devices
US7054888B2 (en) * 2002-10-16 2006-05-30 Microsoft Corporation Optimizing media player memory during rendering
US7136874B2 (en) * 2002-10-16 2006-11-14 Microsoft Corporation Adaptive menu system for media players
US7668842B2 (en) * 2002-10-16 2010-02-23 Microsoft Corporation Playlist structure for large playlists
US7707231B2 (en) * 2002-10-16 2010-04-27 Microsoft Corporation Creating standardized playlists and maintaining coherency
US7043477B2 (en) * 2002-10-16 2006-05-09 Microsoft Corporation Navigating media content via groups within a playlist
US7216178B2 (en) * 2003-04-04 2007-05-08 Gibson Guitar Corp. System and method for distributing music to customers over the internet using uniquely identified proprietary devices
KR100745995B1 (en) * 2003-06-04 2007-08-06 삼성전자주식회사 Device for managing meta data and method thereof
US7757173B2 (en) * 2003-07-18 2010-07-13 Apple Inc. Voice menu system
JP2006345008A (en) * 2003-08-25 2006-12-21 Fujitsu Ten Ltd System and method for updating music database, device and method for transmitting music database, and terminal unit having musical piece database update function and method of updating musical piece database thereof
US7644446B2 (en) * 2003-10-23 2010-01-05 Microsoft Corporation Encryption and data-protection for content on portable medium
US7673062B2 (en) * 2003-11-18 2010-03-02 Yahoo! Inc. Method and apparatus for assisting with playback of remotely stored media files
US20060010167A1 (en) * 2004-01-21 2006-01-12 Grace James R Apparatus for navigation of multimedia content in a vehicle multimedia system
US7650513B2 (en) * 2004-01-21 2010-01-19 Gm Global Technology Operations, Inc. System and method for vehicle-to-vehicle migration of multimedia content
US7885926B2 (en) * 2004-01-21 2011-02-08 GM Global Technology Operations LLC System and apparatus for wireless synchronization of multimedia content
US7895378B2 (en) * 2004-04-27 2011-02-22 Apple Inc. Method and system for allowing a media player to transfer digital audio to an accessory
US7634605B2 (en) * 2004-04-27 2009-12-15 Apple Inc. Method and system for transferring stored data between a media player and an accessory
US7529870B1 (en) 2004-04-27 2009-05-05 Apple Inc. Communication between an accessory and a media player with multiple lingoes
US7441058B1 (en) * 2006-09-11 2008-10-21 Apple Inc. Method and system for controlling an accessory having a tuner
US8117651B2 (en) 2004-04-27 2012-02-14 Apple Inc. Method and system for authenticating an accessory
US7673083B2 (en) * 2004-04-27 2010-03-02 Apple Inc. Method and system for controlling video selection and playback in a portable media player
US7826318B2 (en) * 2004-04-27 2010-11-02 Apple Inc. Method and system for allowing a media player to transfer digital audio to an accessory
US7797471B2 (en) 2004-04-27 2010-09-14 Apple Inc. Method and system for transferring album artwork between a media player and an accessory
US7529871B1 (en) 2004-04-27 2009-05-05 Apple Inc. Communication between an accessory and a media player with multiple protocol versions
US7529872B1 (en) 2004-04-27 2009-05-05 Apple Inc. Communication between an accessory and a media player using a protocol with multiple lingoes
US7526588B1 (en) 2004-04-27 2009-04-28 Apple Inc. Communication between an accessory and a media player using a protocol with multiple lingoes
US7441062B2 (en) * 2004-04-27 2008-10-21 Apple Inc. Connector interface system for enabling data communication with a multi-communication device
US7502820B2 (en) * 2004-05-03 2009-03-10 Microsoft Corporation System and method for optimized property retrieval of stored objects
US8443038B2 (en) 2004-06-04 2013-05-14 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
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
US7774326B2 (en) * 2004-06-25 2010-08-10 Apple Inc. Methods and systems for managing data
US7730012B2 (en) 2004-06-25 2010-06-01 Apple Inc. Methods and systems for managing data
US7437358B2 (en) 2004-06-25 2008-10-14 Apple Inc. Methods and systems for managing data
US20060010075A1 (en) * 2004-07-08 2006-01-12 Dean Wolf Technique for facilitating resale of digital content over a computer network
WO2006017362A2 (en) * 2004-07-13 2006-02-16 Freedom Software, Inc. Storing and distributing encrypted digital content
US9948989B1 (en) * 2004-07-21 2018-04-17 Cox Communications, Inc. Interactive media content listing search and filtering system for a media content listing display system such as an electronic programming guide
US7562394B2 (en) 2004-07-23 2009-07-14 Findaway World Llc Personal media player apparatus and method
US20060020968A1 (en) * 2004-07-23 2006-01-26 Findaway World Llc Method for commercialization and advertising using a personal media player
US20060041613A1 (en) * 2004-08-18 2006-02-23 Fackelmayer Jonathan R O Method and system for visual art distribution and presentation
US8090309B2 (en) * 2004-10-27 2012-01-03 Chestnut Hill Sound, Inc. Entertainment system with unified content selection
US20190278560A1 (en) 2004-10-27 2019-09-12 Chestnut Hill Sound, Inc. Media appliance with auxiliary source module docking and fail-safe alarm modes
US7885622B2 (en) * 2004-10-27 2011-02-08 Chestnut Hill Sound Inc. Entertainment system with bandless tuning
US7735012B2 (en) * 2004-11-04 2010-06-08 Apple Inc. Audio user interface for computing devices
US9420021B2 (en) * 2004-12-13 2016-08-16 Nokia Technologies Oy Media device and method of enhancing use of media device
US7823214B2 (en) 2005-01-07 2010-10-26 Apple Inc. Accessory authentication for electronic devices
US8606383B2 (en) * 2005-01-31 2013-12-10 The Invention Science Fund I, Llc Audio sharing
US7876357B2 (en) * 2005-01-31 2011-01-25 The Invention Science Fund I, Llc Estimating shared image device operational capabilities or resources
US20060174203A1 (en) * 2005-01-31 2006-08-03 Searete Llc, A Limited Liability Corporation Of The State Of Delaware Viewfinder for shared image device
US20060285150A1 (en) * 2005-01-31 2006-12-21 Searete Llc, A Limited Liability Corporation Of The State Of Delaware Regional proximity for shared image device(s)
US9910341B2 (en) 2005-01-31 2018-03-06 The Invention Science Fund I, Llc Shared image device designation
US20070236505A1 (en) * 2005-01-31 2007-10-11 Searete Llc, A Limited Liability Corporation Of The State Of Delaware Resampling of transformed shared image techniques
US20060187230A1 (en) * 2005-01-31 2006-08-24 Searete Llc Peripheral shared image device sharing
US20060190968A1 (en) * 2005-01-31 2006-08-24 Searete Llc, A Limited Corporation Of The State Of The State Of Delaware Sharing between shared audio devices
US9082456B2 (en) 2005-01-31 2015-07-14 The Invention Science Fund I Llc Shared image device designation
US9124729B2 (en) 2005-01-31 2015-09-01 The Invention Science Fund I, Llc Shared image device synchronization or designation
US8902320B2 (en) 2005-01-31 2014-12-02 The Invention Science Fund I, Llc Shared image device synchronization or designation
US20060171603A1 (en) * 2005-01-31 2006-08-03 Searete Llc, A Limited Liability Corporation Of The State Of Delaware Resampling of transformed shared image techniques
US7920169B2 (en) * 2005-01-31 2011-04-05 Invention Science Fund I, Llc Proximity of shared image devices
US20060173972A1 (en) * 2005-01-31 2006-08-03 Searete Llc, A Limited Liability Corporation Of The State Of Delaware Audio sharing
US9325781B2 (en) 2005-01-31 2016-04-26 Invention Science Fund I, Llc Audio sharing
US9489717B2 (en) 2005-01-31 2016-11-08 Invention Science Fund I, Llc Shared image device
US20060187227A1 (en) * 2005-01-31 2006-08-24 Jung Edward K Storage aspects for imaging device
EP1861607A4 (en) * 2005-02-01 2012-05-02 Continental Automotive Canada Inc Cost optimized electric egr valve
EP1844386A4 (en) * 2005-02-04 2009-11-25 Strands Inc System for browsing through a music catalog using correlation metrics of a knowledge base of mediasets
US7818350B2 (en) 2005-02-28 2010-10-19 Yahoo! Inc. System and method for creating a collaborative playlist
KR20070116853A (en) * 2005-03-04 2007-12-11 뮤직아이피 코포레이션 Scan shuffle for building playlists
US10003762B2 (en) 2005-04-26 2018-06-19 Invention Science Fund I, Llc Shared image devices
US9819490B2 (en) 2005-05-04 2017-11-14 Invention Science Fund I, Llc Regional proximity for shared image device(s)
US9001215B2 (en) 2005-06-02 2015-04-07 The Invention Science Fund I, Llc Estimating shared image device operational capabilities or resources
KR100744724B1 (en) * 2005-06-24 2007-08-01 (주)뮤직소프트 System for managing online record shop and method for the same
US7836146B2 (en) * 2005-06-27 2010-11-16 Novarc L.L.C System and method for concurrently downloading digital content and recording to removable media
US20070022306A1 (en) * 2005-07-25 2007-01-25 Lindsley Brett L Method and apparatus for providing protected digital content
US8140601B2 (en) * 2005-08-12 2012-03-20 Microsoft Coporation Like processing of owned and for-purchase media
US7831605B2 (en) * 2005-08-12 2010-11-09 Microsoft Corporation Media player service library
US20070048713A1 (en) * 2005-08-12 2007-03-01 Microsoft Corporation Media player service library
US20070048714A1 (en) * 2005-08-12 2007-03-01 Microsoft Corporation Media player service library
US8677377B2 (en) 2005-09-08 2014-03-18 Apple Inc. Method and apparatus for building an intelligent automated assistant
KR100724940B1 (en) * 2005-12-05 2007-06-04 삼성전자주식회사 Contents update method of dms in dlna system
US20070136778A1 (en) * 2005-12-09 2007-06-14 Ari Birger Controller and control method for media retrieval, routing and playback
US20070226223A1 (en) * 2006-03-08 2007-09-27 Motorola, Inc. Method and apparatus for loading of information to a portable device
US7765192B2 (en) 2006-03-29 2010-07-27 Abo Enterprises, Llc System and method for archiving a media collection
US7444388B1 (en) * 2006-04-13 2008-10-28 Concert Technology Corporation System and method for obtaining media content for a portable media player
US8006019B2 (en) 2006-05-22 2011-08-23 Apple, Inc. Method and system for transferring stored data between a media player and an accessory
US20070298840A1 (en) * 2006-06-02 2007-12-27 Findaway World, Inc. Personal media player apparatus and method
US7945142B2 (en) * 2006-06-15 2011-05-17 Microsoft Corporation Audio/visual editing tool
US7415563B1 (en) 2006-06-27 2008-08-19 Apple Inc. Method and system for allowing a media player to determine if it supports the capabilities of an accessory
US7805682B1 (en) * 2006-08-03 2010-09-28 Sonos, Inc. Method and apparatus for editing a playlist
US8620699B2 (en) 2006-08-08 2013-12-31 Napo Enterprises, Llc Heavy influencer media recommendations
US9318108B2 (en) 2010-01-18 2016-04-19 Apple Inc. Intelligent automated assistant
US7558894B1 (en) 2006-09-11 2009-07-07 Apple Inc. Method and system for controlling power provided to an accessory
US8290820B2 (en) * 2006-09-13 2012-10-16 Microsoft Corporation Methods of maintaining a journal of media encounters between co-existing portable devices
US7900264B2 (en) * 2006-09-29 2011-03-01 Vixs Systems, Inc. Multimedia client/server system with copy protection recovery and methods for use therewith
JP4379471B2 (en) * 2006-12-29 2009-12-09 ソニー株式会社 Playback apparatus and playback control method
JP2008186569A (en) * 2007-01-05 2008-08-14 Sony Corp Reproduction device and reproduction control method
US7813697B2 (en) * 2007-01-05 2010-10-12 Apple Inc. Power efficient high speed communication systems and methods
US8463924B2 (en) * 2007-02-02 2013-06-11 Apple Inc. Remote access of media items
US8307092B2 (en) * 2007-02-21 2012-11-06 Napo Enterprises, Llc Method and system for collecting information about a user's media collections from multiple login points
US7920901B2 (en) * 2007-02-28 2011-04-05 Research In Motion Limited System and method for providing visual indicators in a media application
JP2008241918A (en) * 2007-03-26 2008-10-09 Yamaha Corp Music data providing system and site
US20080239888A1 (en) * 2007-03-26 2008-10-02 Yamaha Corporation Music Data Providing System
US8977255B2 (en) 2007-04-03 2015-03-10 Apple Inc. Method and system for operating a multi-function portable electronic device using voice-activation
US20080307106A1 (en) * 2007-06-08 2008-12-11 Apple Inc. Photo Streaming to Media Device
EP2169560A4 (en) * 2007-07-04 2012-05-30 Imatrix Corp E-mail processing apparatus, method of e-mail processing, e-mail processing program and e-mail processing system
US9699232B2 (en) 2007-08-24 2017-07-04 Iheartmedia Management Services, Inc. Adding perishable content to media stream based on user location preference
US9990655B2 (en) 2007-08-24 2018-06-05 Iheartmedia Management Services, Inc. Live media stream including personalized notifications
US11265355B2 (en) 2007-08-24 2022-03-01 Iheartmedia Management Services, Inc. Customized perishable media content based on user-specified preference for static or variable location
WO2009029222A1 (en) 2007-08-24 2009-03-05 Clear Channel Management Services, L.P. System and method for providing a radio-like experience
WO2009032708A2 (en) * 2007-09-04 2009-03-12 Apple Inc. Protocol for remote user interface for portable media device
JP5194673B2 (en) 2007-09-26 2013-05-08 株式会社日立製作所 Mobile terminal and information transmission / reception method
US9330720B2 (en) 2008-01-03 2016-05-03 Apple Inc. Methods and apparatus for altering audio output signals
US20090183060A1 (en) * 2008-01-12 2009-07-16 David Heller Unified Media Presentation for Media Devices
US8047966B2 (en) * 2008-02-29 2011-11-01 Apple Inc. Interfacing portable media devices and sports equipment
US8996376B2 (en) 2008-04-05 2015-03-31 Apple Inc. Intelligent text-to-speech conversion
US10496753B2 (en) 2010-01-18 2019-12-03 Apple Inc. Automatically adapting user interfaces for hands-free interaction
US8977710B2 (en) * 2008-06-18 2015-03-10 Qualcomm, Incorporated Remote selection and authorization of collected media transmission
US9716774B2 (en) 2008-07-10 2017-07-25 Apple Inc. System and method for syncing a user interface on a server device to a user interface on a client device
US20100030549A1 (en) 2008-07-31 2010-02-04 Lee Michael M Mobile device having human language translation capability with positional feedback
US8238811B2 (en) 2008-09-08 2012-08-07 Apple Inc. Cross-transport authentication
US8208853B2 (en) 2008-09-08 2012-06-26 Apple Inc. Accessory device authentication
US8898568B2 (en) 2008-09-09 2014-11-25 Apple Inc. Audio user interface
WO2010067118A1 (en) 2008-12-11 2010-06-17 Novauris Technologies Limited Speech recognition involving a mobile device
US8669457B2 (en) 2008-12-22 2014-03-11 Amazon Technologies, Inc. Dynamic generation of playlists
US20100169493A1 (en) * 2008-12-28 2010-07-01 Yamakawa Devender System and method of switching from streaming content to local content
JP5346628B2 (en) 2009-03-11 2013-11-20 株式会社堀場エステック Mass flow controller verification system, verification method, verification program
GB0906004D0 (en) * 2009-04-07 2009-05-20 Omnifone Ltd MusicStation desktop
US9858925B2 (en) 2009-06-05 2018-01-02 Apple Inc. Using context information to facilitate processing of commands in a virtual assistant
US10241752B2 (en) 2011-09-30 2019-03-26 Apple Inc. Interface for a virtual digital assistant
US10706373B2 (en) 2011-06-03 2020-07-07 Apple Inc. Performing actions associated with task items that represent tasks to perform
US10241644B2 (en) 2011-06-03 2019-03-26 Apple Inc. Actionable reminder entries
US9431006B2 (en) 2009-07-02 2016-08-30 Apple Inc. Methods and apparatuses for automatic speech recognition
US9106803B2 (en) * 2009-07-30 2015-08-11 Cellco Partnership Broadcast media information capture and communication via a wireless network
US10679605B2 (en) 2010-01-18 2020-06-09 Apple Inc. Hands-free list-reading by intelligent automated assistant
US10705794B2 (en) 2010-01-18 2020-07-07 Apple Inc. Automatically adapting user interfaces for hands-free interaction
US10553209B2 (en) 2010-01-18 2020-02-04 Apple Inc. Systems and methods for hands-free notification summaries
US10276170B2 (en) 2010-01-18 2019-04-30 Apple Inc. Intelligent automated assistant
DE202011111062U1 (en) 2010-01-25 2019-02-19 Newvaluexchange Ltd. Device and system for a digital conversation management platform
US8682667B2 (en) 2010-02-25 2014-03-25 Apple Inc. User profiling for selecting user specific voice input processing information
WO2012050618A1 (en) 2010-10-16 2012-04-19 James Charles Vago Multimedia methods, devices and systems
US10762293B2 (en) 2010-12-22 2020-09-01 Apple Inc. Using parts-of-speech tagging and named entity recognition for spelling correction
US9262612B2 (en) 2011-03-21 2016-02-16 Apple Inc. Device access using voice authentication
US8849950B2 (en) * 2011-04-07 2014-09-30 Qualcomm Incorporated Network streaming of video data using byte range requests
US10057736B2 (en) 2011-06-03 2018-08-21 Apple Inc. Active transport based notifications
US9087060B2 (en) * 2011-06-03 2015-07-21 Apple Inc. Partial sort on a host
US8994660B2 (en) 2011-08-29 2015-03-31 Apple Inc. Text correction processing
US8971546B2 (en) 2011-10-14 2015-03-03 Sonos, Inc. Systems, methods, apparatus, and articles of manufacture to control audio playback devices
US9665339B2 (en) 2011-12-28 2017-05-30 Sonos, Inc. Methods and systems to select an audio track
US9654821B2 (en) 2011-12-30 2017-05-16 Sonos, Inc. Systems and methods for networked music playback
US10134385B2 (en) 2012-03-02 2018-11-20 Apple Inc. Systems and methods for name pronunciation
US9483461B2 (en) 2012-03-06 2016-11-01 Apple Inc. Handling speech synthesis of content for multiple languages
US9280610B2 (en) 2012-05-14 2016-03-08 Apple Inc. Crowd sourcing information to fulfill user requests
US9721563B2 (en) 2012-06-08 2017-08-01 Apple Inc. Name recognition system
US9674587B2 (en) 2012-06-26 2017-06-06 Sonos, Inc. Systems and methods for networked music playback including remote add to queue
US9137564B2 (en) 2012-06-28 2015-09-15 Sonos, Inc. Shift to corresponding media in a playback queue
US9495129B2 (en) 2012-06-29 2016-11-15 Apple Inc. Device, method, and user interface for voice-activated navigation and browsing of a document
US9576574B2 (en) 2012-09-10 2017-02-21 Apple Inc. Context-sensitive handling of interruptions by intelligent digital assistant
US9547647B2 (en) 2012-09-19 2017-01-17 Apple Inc. Voice-based media searching
US9510055B2 (en) 2013-01-23 2016-11-29 Sonos, Inc. System and method for a media experience social interface
KR20240132105A (en) 2013-02-07 2024-09-02 애플 인크. Voice trigger for a digital assistant
US9368114B2 (en) 2013-03-14 2016-06-14 Apple Inc. Context-sensitive handling of interruptions
US10652394B2 (en) 2013-03-14 2020-05-12 Apple Inc. System and method for processing voicemail
WO2014144579A1 (en) 2013-03-15 2014-09-18 Apple Inc. System and method for updating an adaptive speech recognition model
AU2014233517B2 (en) 2013-03-15 2017-05-25 Apple Inc. Training an at least partial voice command system
US9501533B2 (en) 2013-04-16 2016-11-22 Sonos, Inc. Private queue for a media playback system
US9247363B2 (en) 2013-04-16 2016-01-26 Sonos, Inc. Playback queue transfer in a media playback system
US9361371B2 (en) 2013-04-16 2016-06-07 Sonos, Inc. Playlist update in a media playback system
US9703521B2 (en) 2013-05-29 2017-07-11 Sonos, Inc. Moving a playback queue to a new zone
US9953179B2 (en) 2013-05-29 2018-04-24 Sonos, Inc. Private queue indicator
US9495076B2 (en) 2013-05-29 2016-11-15 Sonos, Inc. Playlist modification
US10715973B2 (en) 2013-05-29 2020-07-14 Sonos, Inc. Playback queue control transition
US9735978B2 (en) 2013-05-29 2017-08-15 Sonos, Inc. Playback queue control via a playlist on a mobile device
US9684484B2 (en) 2013-05-29 2017-06-20 Sonos, Inc. Playback zone silent connect
US9798510B2 (en) 2013-05-29 2017-10-24 Sonos, Inc. Connected state indicator
WO2014197336A1 (en) 2013-06-07 2014-12-11 Apple Inc. System and method for detecting errors in interactions with a voice-based digital assistant
WO2014197334A2 (en) 2013-06-07 2014-12-11 Apple Inc. System and method for user-specified pronunciation of words for speech synthesis and recognition
US9582608B2 (en) 2013-06-07 2017-02-28 Apple Inc. Unified ranking with entropy-weighted information for phrase-based semantic auto-completion
WO2014197335A1 (en) 2013-06-08 2014-12-11 Apple Inc. Interpreting and acting upon commands that involve sharing information with remote devices
US10176167B2 (en) 2013-06-09 2019-01-08 Apple Inc. System and method for inferring user intent from speech inputs
KR101772152B1 (en) 2013-06-09 2017-08-28 애플 인크. Device, method, and graphical user interface for enabling conversation persistence across two or more instances of a digital assistant
EP3008964B1 (en) 2013-06-13 2019-09-25 Apple Inc. System and method for emergency calls initiated by voice command
US9232277B2 (en) 2013-07-17 2016-01-05 Sonos, Inc. Associating playback devices with playback queues
DE112014003653B4 (en) 2013-08-06 2024-04-18 Apple Inc. Automatically activate intelligent responses based on activities from remote devices
US9411942B2 (en) * 2013-08-30 2016-08-09 D&M Holdings, Inc. Network device, system and method for rendering an interactive multimedia playlist
US10028028B2 (en) 2013-09-30 2018-07-17 Sonos, Inc. Accessing last-browsed information in a media playback system
KR101766696B1 (en) * 2013-10-25 2017-08-09 후아웨이 테크놀러지 컴퍼니 리미티드 Associating representations in adaptive streaming
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
US10587693B2 (en) 2014-04-01 2020-03-10 Sonos, Inc. Mirrored queues
US9705950B2 (en) 2014-04-03 2017-07-11 Sonos, Inc. Methods and systems for transmitting playlists
US20150324552A1 (en) 2014-05-12 2015-11-12 Sonos, Inc. Share Restriction for Media Items
WO2015173649A1 (en) 2014-05-13 2015-11-19 Opera Software Asa Web access performance enhancement
US9620105B2 (en) 2014-05-15 2017-04-11 Apple Inc. Analyzing audio input for efficient speech and music recognition
US10592095B2 (en) 2014-05-23 2020-03-17 Apple Inc. Instantaneous speaking of content on touch devices
US9502031B2 (en) 2014-05-27 2016-11-22 Apple Inc. Method for supporting dynamic grammars in WFST-based ASR
US9842101B2 (en) 2014-05-30 2017-12-12 Apple Inc. Predictive conversion of language input
US10170123B2 (en) 2014-05-30 2019-01-01 Apple Inc. Intelligent assistant for home automation
US10289433B2 (en) 2014-05-30 2019-05-14 Apple Inc. Domain specific language for encoding assistant dialog
US9430463B2 (en) 2014-05-30 2016-08-30 Apple Inc. Exemplar-based natural language processing
US9785630B2 (en) 2014-05-30 2017-10-10 Apple Inc. Text prediction using combined word N-gram and unigram language models
CN110797019B (en) 2014-05-30 2023-08-29 苹果公司 Multi-command single speech input method
US10078631B2 (en) 2014-05-30 2018-09-18 Apple Inc. Entropy-guided text prediction using combined word and character n-gram language models
US9633004B2 (en) 2014-05-30 2017-04-25 Apple Inc. Better resolution when referencing to concepts
US9734193B2 (en) 2014-05-30 2017-08-15 Apple Inc. Determining domain salience ranking from ambiguous words in natural speech
US9715875B2 (en) 2014-05-30 2017-07-25 Apple Inc. Reducing the need for manual start/end-pointing and trigger phrases
US9760559B2 (en) 2014-05-30 2017-09-12 Apple Inc. Predictive text input
US9720642B2 (en) 2014-06-04 2017-08-01 Sonos, Inc. Prioritizing media content requests
US20150355818A1 (en) 2014-06-04 2015-12-10 Sonos, Inc. Continuous Playback Queue
US9654536B2 (en) 2014-06-04 2017-05-16 Sonos, Inc. Cloud queue playback policy
US20150356084A1 (en) 2014-06-05 2015-12-10 Sonos, Inc. Social Queue
US9672213B2 (en) 2014-06-10 2017-06-06 Sonos, Inc. Providing media items from playback history
US10659851B2 (en) 2014-06-30 2020-05-19 Apple Inc. Real-time digital assistant knowledge updates
US9338493B2 (en) 2014-06-30 2016-05-10 Apple Inc. Intelligent automated assistant for TV user interactions
US9460755B2 (en) 2014-07-14 2016-10-04 Sonos, Inc. Queue identification
US9485545B2 (en) * 2014-07-14 2016-11-01 Sonos, Inc. Inconsistent queues
US9467737B2 (en) 2014-07-14 2016-10-11 Sonos, Inc. Zone group control
US10462505B2 (en) 2014-07-14 2019-10-29 Sonos, Inc. Policies for media playback
US10498833B2 (en) 2014-07-14 2019-12-03 Sonos, Inc. Managing application access of a media playback system
US9874997B2 (en) 2014-08-08 2018-01-23 Sonos, Inc. Social playback queues
US10446141B2 (en) 2014-08-28 2019-10-15 Apple Inc. Automatic speech recognition based on user feedback
US9818400B2 (en) 2014-09-11 2017-11-14 Apple Inc. Method and apparatus for discovering trending terms in speech requests
US9742839B2 (en) 2014-09-12 2017-08-22 Sonos, Inc. Cloud queue item removal
US10789041B2 (en) 2014-09-12 2020-09-29 Apple Inc. Dynamic thresholds for always listening speech trigger
US10645130B2 (en) 2014-09-24 2020-05-05 Sonos, Inc. Playback updates
US9723038B2 (en) 2014-09-24 2017-08-01 Sonos, Inc. Social media connection recommendations based on playback information
US9860286B2 (en) 2014-09-24 2018-01-02 Sonos, Inc. Associating a captured image with a media item
EP3114625A1 (en) 2014-09-24 2017-01-11 Sonos, Inc. Social media connection recommendations based on playback information
US9959087B2 (en) 2014-09-24 2018-05-01 Sonos, Inc. Media item context from social media
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
US9886432B2 (en) 2014-09-30 2018-02-06 Apple Inc. Parsimonious handling of word inflection via categorical stem + suffix N-gram language models
US9668121B2 (en) 2014-09-30 2017-05-30 Apple Inc. Social reminders
US10127911B2 (en) 2014-09-30 2018-11-13 Apple Inc. Speaker identification and unsupervised speaker adaptation techniques
US9646609B2 (en) 2014-09-30 2017-05-09 Apple Inc. Caching apparatus for serving phonetic pronunciations
US10074360B2 (en) 2014-09-30 2018-09-11 Apple Inc. Providing an indication of the suitability of speech recognition
US9876780B2 (en) 2014-11-21 2018-01-23 Sonos, Inc. Sharing access to a media service
US10552013B2 (en) 2014-12-02 2020-02-04 Apple Inc. Data detection
US9711141B2 (en) 2014-12-09 2017-07-18 Apple Inc. Disambiguating heteronyms in speech synthesis
US9865280B2 (en) 2015-03-06 2018-01-09 Apple Inc. Structured dictation using intelligent automated assistants
US9886953B2 (en) 2015-03-08 2018-02-06 Apple Inc. Virtual assistant activation
US9721566B2 (en) 2015-03-08 2017-08-01 Apple Inc. Competing devices responding to voice triggers
US10567477B2 (en) 2015-03-08 2020-02-18 Apple Inc. Virtual assistant continuity
US9899019B2 (en) 2015-03-18 2018-02-20 Apple Inc. Systems and methods for structured stem and suffix language models
US9842105B2 (en) 2015-04-16 2017-12-12 Apple Inc. Parsimonious continuous-space phrase representations for natural language processing
CN107615734B (en) * 2015-05-26 2021-01-26 爱唯思有限公司 System and method for server failover and load balancing
US10083688B2 (en) 2015-05-27 2018-09-25 Apple Inc. Device voice control for selecting a displayed affordance
US10127220B2 (en) 2015-06-04 2018-11-13 Apple Inc. Language identification from short strings
US10101822B2 (en) 2015-06-05 2018-10-16 Apple Inc. Language input correction
US9578173B2 (en) 2015-06-05 2017-02-21 Apple Inc. Virtual assistant aided communication with 3rd party service in a communication session
US10186254B2 (en) 2015-06-07 2019-01-22 Apple Inc. Context-based endpoint detection
US10255907B2 (en) 2015-06-07 2019-04-09 Apple Inc. Automatic accent detection using acoustic models
US11025565B2 (en) 2015-06-07 2021-06-01 Apple Inc. Personalized prediction of responses for instant messaging
US10747498B2 (en) 2015-09-08 2020-08-18 Apple Inc. Zero latency digital assistant
US10671428B2 (en) 2015-09-08 2020-06-02 Apple Inc. Distributed personal assistant
US9697820B2 (en) 2015-09-24 2017-07-04 Apple Inc. Unit-selection text-to-speech synthesis using concatenation-sensitive neural networks
US10366158B2 (en) 2015-09-29 2019-07-30 Apple Inc. Efficient word encoding for recurrent neural network language models
US11010550B2 (en) 2015-09-29 2021-05-18 Apple Inc. Unified language modeling framework for word prediction, auto-completion and auto-correction
US11587559B2 (en) 2015-09-30 2023-02-21 Apple Inc. Intelligent device identification
US10691473B2 (en) 2015-11-06 2020-06-23 Apple Inc. Intelligent automated assistant in a messaging environment
US10049668B2 (en) 2015-12-02 2018-08-14 Apple Inc. Applying neural network language models to weighted finite state transducers for automatic speech recognition
US10223066B2 (en) 2015-12-23 2019-03-05 Apple Inc. Proactive assistance based on dialog communication between devices
US10446143B2 (en) 2016-03-14 2019-10-15 Apple Inc. Identification of voice inputs providing credentials
US9934775B2 (en) 2016-05-26 2018-04-03 Apple Inc. Unit-selection text-to-speech synthesis based on predicted concatenation parameters
US9972304B2 (en) 2016-06-03 2018-05-15 Apple Inc. Privacy preserving distributed evaluation framework for embedded personalized systems
US10249300B2 (en) 2016-06-06 2019-04-02 Apple Inc. Intelligent list reading
US10049663B2 (en) 2016-06-08 2018-08-14 Apple, Inc. Intelligent automated assistant for media exploration
DK179588B1 (en) 2016-06-09 2019-02-22 Apple Inc. Intelligent automated assistant in a home environment
US10586535B2 (en) 2016-06-10 2020-03-10 Apple Inc. Intelligent digital assistant in a multi-tasking environment
US10509862B2 (en) 2016-06-10 2019-12-17 Apple Inc. Dynamic phrase expansion of language input
US10490187B2 (en) 2016-06-10 2019-11-26 Apple Inc. Digital assistant providing automated status report
US10067938B2 (en) 2016-06-10 2018-09-04 Apple Inc. Multilingual word prediction
US10192552B2 (en) 2016-06-10 2019-01-29 Apple Inc. Digital assistant providing whispered speech
DK179415B1 (en) 2016-06-11 2018-06-14 Apple Inc Intelligent device arbitration and control
DK201670540A1 (en) 2016-06-11 2018-01-08 Apple Inc Application integration with a digital assistant
DK179343B1 (en) 2016-06-11 2018-05-14 Apple Inc Intelligent task discovery
DK179049B1 (en) 2016-06-11 2017-09-18 Apple Inc Data driven natural language event detection and classification
US10043516B2 (en) 2016-09-23 2018-08-07 Apple Inc. Intelligent automated assistant
US10593346B2 (en) 2016-12-22 2020-03-17 Apple Inc. Rank-reduced token representation for automatic speech recognition
DK201770439A1 (en) 2017-05-11 2018-12-13 Apple Inc. Offline personal assistant
DK179745B1 (en) 2017-05-12 2019-05-01 Apple Inc. SYNCHRONIZATION AND TASK DELEGATION OF A DIGITAL ASSISTANT
DK179496B1 (en) 2017-05-12 2019-01-15 Apple Inc. USER-SPECIFIC Acoustic Models
DK201770432A1 (en) 2017-05-15 2018-12-21 Apple Inc. Hierarchical belief states for digital assistants
DK201770431A1 (en) 2017-05-15 2018-12-20 Apple Inc. Optimizing dialogue policy decisions for digital assistants using implicit feedback
DK179549B1 (en) 2017-05-16 2019-02-12 Apple Inc. Far-field extension for digital assistant services
US11297369B2 (en) 2018-03-30 2022-04-05 Apple Inc. Remotely controlling playback devices
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
US10614857B2 (en) 2018-07-02 2020-04-07 Apple Inc. Calibrating media playback channels for synchronized presentation
US11184666B2 (en) 2019-04-01 2021-11-23 Sonos, Inc. Access control techniques for media playback systems
US11636855B2 (en) 2019-11-11 2023-04-25 Sonos, Inc. Media content based on operational data
WO2022051267A1 (en) * 2020-09-01 2022-03-10 Sigma Computing, Inc. Generating a data warehouse index

Citations (60)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH1132070A (en) 1997-05-02 1999-02-02 Sony Electron Inc Multi-media information system and multi-media information reproducing method
US5920856A (en) 1997-06-09 1999-07-06 Xerox Corporation System for selecting multimedia databases over networks
US5983218A (en) 1997-06-30 1999-11-09 Xerox Corporation Multimedia database for use over networks
JP2000348052A (en) 1999-06-07 2000-12-15 Nec Corp System, device and method for providing site map, and recording medium
US6243713B1 (en) 1998-08-24 2001-06-05 Excalibur Technologies Corp. Multimedia document retrieval by application of multimedia queries to a unified index of multimedia data for a plurality of multimedia data types
US20010042107A1 (en) 2000-01-06 2001-11-15 Palm Stephen R. Networked audio player transport protocol and architecture
JP2001318949A (en) 2000-05-09 2001-11-16 Onkyo Corp Contents delivery system
US6374260B1 (en) * 1996-05-24 2002-04-16 Magnifi, Inc. Method and apparatus for uploading, indexing, analyzing, and searching media content
US20020062252A1 (en) 2000-01-07 2002-05-23 Van Zoest Alexander T. System and method for providing access to electronic works
US20020082901A1 (en) * 2000-05-03 2002-06-27 Dunning Ted E. Relationship discovery engine
US20020101444A1 (en) * 2001-01-31 2002-08-01 Novak Michael J. Methods and systems for creating skins
US20020134220A1 (en) * 2001-03-21 2002-09-26 Hiroaki Yamane Play list generation device, audio information provision device, audio information provision system, method, program and recording medium
US20020147683A1 (en) * 2001-04-06 2002-10-10 Anthony Capobianco Method for purchasing web based digital media
US20020183042A1 (en) * 2001-05-29 2002-12-05 Kevin Thornton System and method for sampling audio recordings on a wireless communication device
US6498897B1 (en) * 1998-05-27 2002-12-24 Kasenna, Inc. Media server system and method having improved asset types for playback of digital media
US6505160B1 (en) * 1995-07-27 2003-01-07 Digimarc Corporation Connected audio and other media objects
US20030018709A1 (en) * 2001-07-20 2003-01-23 Audible Magic Playlist generation method and apparatus
EP1283487A2 (en) 2001-08-06 2003-02-12 Pioneer Corporation Management server device and terminal device for a contents providing system
US6523022B1 (en) 1997-06-09 2003-02-18 Allen Hobbs Method and apparatus for selectively augmenting retrieved information from a network resource
JP2003085893A (en) 2001-09-07 2003-03-20 Sony Corp Device and method for processing information, and program therefor
US20030061273A1 (en) * 2001-09-24 2003-03-27 Intel Corporation Extended content storage method and apparatus
US6587127B1 (en) * 1997-11-25 2003-07-01 Motorola, Inc. Content player method and server with user profile
US20030140313A1 (en) * 1999-04-26 2003-07-24 Smith Kim C. Method of creating default lists of content of probable interest
US20030159566A1 (en) * 2002-02-27 2003-08-28 Sater Neil D. System and method that facilitates customizing media
US20030174819A1 (en) * 2002-03-18 2003-09-18 Chien-Chung Su Method for providing information service by using a network-connection device and architecture thereof
US6653545B2 (en) * 2002-03-01 2003-11-25 Ejamming, Inc. Method and apparatus for remote real time collaborative music performance
US6662231B1 (en) * 2000-06-30 2003-12-09 Sei Information Technology Method and system for subscriber-based audio service over a communication network
US20040002943A1 (en) * 2002-06-28 2004-01-01 Merrill John Wickens Lamb Systems and methods for application delivery and configuration management of mobile devices
US20040015519A1 (en) * 2001-10-15 2004-01-22 Yukitoshi Maeda Content delivery server and content delivery system having the same
US20040024580A1 (en) * 2002-02-25 2004-02-05 Oak Technology, Inc. Server in a media system
US6697800B1 (en) * 2000-05-19 2004-02-24 Roxio, Inc. System and method for determining affinity using objective and subjective data
US20040060070A1 (en) * 2002-09-17 2004-03-25 Noriyasu Mizushima System for distributing videos synchronized with music, and method for distributing videos synchronized with music
US20040078357A1 (en) * 2002-10-16 2004-04-22 Microsoft Corporation Optimizing media player memory during rendering
US6728729B1 (en) 2003-04-25 2004-04-27 Apple Computer, Inc. Accessing media across networks
US6735628B2 (en) * 2000-01-24 2004-05-11 Friskit, Inc. Media search and continuous playback of multiple media resources distributed on a network
US20040091235A1 (en) * 2002-11-07 2004-05-13 Srinivas Gutta Tracking of partially viewed shows so that they can be marked for deletion when a personal video recorder runs out of space
US6741980B1 (en) * 1999-03-23 2004-05-25 Microstrategy Inc. System and method for automatic, real-time delivery of personalized informational and transactional data to users via content delivery device
US20040148362A1 (en) * 2001-11-02 2004-07-29 Lee Friedman Systems and methods for managing and aggregating media formats
US6775687B1 (en) * 1999-10-12 2004-08-10 International Business Machines Corporation Exchanging supplemental information fields between a client and a server
US20040192358A1 (en) * 2003-03-24 2004-09-30 Inventec Appliances Corp. Method of instantly receiving and playing back audio data from wireless network by wireless terminal
US20040204124A1 (en) * 2002-05-08 2004-10-14 Campbell Lowell Lete Method of minimizing the quantity of information stored in a wireless device
US20040214551A1 (en) * 2000-05-09 2004-10-28 Doo-Yong Kim Digital mobile telephone and methods for executing and providing multimerdia data for the digital mobile telephone
US20040243700A1 (en) * 2003-05-29 2004-12-02 Weast John C. Visibility of media contents of UPnP media servers and initiating rendering via file system user interface
US6829368B2 (en) * 2000-01-26 2004-12-07 Digimarc Corporation Establishing and interacting with on-line media collections using identifiers in media signals
US6865600B1 (en) * 2000-05-19 2005-03-08 Napster, Inc. System and method for selecting internet media channels
US6941324B2 (en) * 2002-03-21 2005-09-06 Microsoft Corporation Methods and systems for processing playlists
US6947182B1 (en) * 1999-07-26 2005-09-20 Canon Kabushiki Kaisha Network system and control method of the same
US6947959B1 (en) * 1992-10-01 2005-09-20 Quark, Inc. Digital media asset management system and process
US6976028B2 (en) * 2001-06-15 2005-12-13 Sony Corporation Media content creating and publishing system and process
US20060010075A1 (en) * 2004-07-08 2006-01-12 Dean Wolf Technique for facilitating resale of digital content over a computer network
US6987221B2 (en) * 2002-05-30 2006-01-17 Microsoft Corporation Auto playlist generation with multiple seed songs
US20060059231A1 (en) * 2002-09-18 2006-03-16 Masahiro Takatori Information acquiring device and information providing device
US7024485B2 (en) * 2000-05-03 2006-04-04 Yahoo! Inc. System for controlling and enforcing playback restrictions for a media file by splitting the media file into usable and unusable portions for playback
US7065342B1 (en) * 1999-11-23 2006-06-20 Gofigure, L.L.C. System and mobile cellular telephone device for playing recorded music
US7080030B2 (en) * 2001-02-28 2006-07-18 Digonex Technologies, Inc. Digital online exchange
US7099685B2 (en) * 2000-04-26 2006-08-29 Samsung Electronics Co., Ltd. Apparatus and method for providing multimedia service in a mobile terminal
US7117453B2 (en) * 2003-01-21 2006-10-03 Microsoft Corporation Media frame object visualization system
US7184976B1 (en) * 1999-09-09 2007-02-27 Canon Kabushiki Kaisha Apparatus which can be connected to network, and charging management system
US7213228B2 (en) * 2003-03-17 2007-05-01 Macrovision Corporation Methods and apparatus for implementing a remote application over a network
US7295995B1 (en) * 2001-10-30 2007-11-13 A9.Com, Inc. Computer processes and systems for adaptively controlling the display of items

Family Cites Families (38)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6016520A (en) * 1995-07-14 2000-01-18 Microsoft Corporation Method of viewing at a client viewing station a multiple media title stored at a server and containing a plurality of topics utilizing anticipatory caching
US5717914A (en) * 1995-09-15 1998-02-10 Infonautics Corporation Method for categorizing documents into subjects using relevance normalization for documents retrieved from an information retrieval system in response to a query
WO1997014244A1 (en) * 1995-10-11 1997-04-17 Sony Corporation Information providing device and portable communication terminal
US5806065A (en) * 1996-05-06 1998-09-08 Microsoft Corporation Data system with distributed tree indexes and method for maintaining the indexes
US5832499A (en) * 1996-07-10 1998-11-03 Survivors Of The Shoah Visual History Foundation Digital library system
US5813014A (en) * 1996-07-10 1998-09-22 Survivors Of The Shoah Visual History Foundation Method and apparatus for management of multimedia assets
US6405239B1 (en) * 1996-12-09 2002-06-11 Scientific-Atlanta, Inc. Using a hierarchical file system for indexing data broadcast to a client from a network of servers
JP3873362B2 (en) * 1997-04-04 2007-01-24 カシオ計算機株式会社 Network system and recording medium
US6594682B2 (en) * 1997-10-28 2003-07-15 Microsoft Corporation Client-side system for scheduling delivery of web content and locally managing the web content
US20020002039A1 (en) * 1998-06-12 2002-01-03 Safi Qureshey Network-enabled audio device
JPH11345201A (en) * 1998-05-29 1999-12-14 Ntt Data Corp Information providing system and information providing network system
US6834276B1 (en) * 1999-02-25 2004-12-21 Integrated Data Control, Inc. Database system and method for data acquisition and perusal
US6515656B1 (en) * 1999-04-14 2003-02-04 Verizon Laboratories Inc. Synchronized spatial-temporal browsing of images for assessment of content
US7281199B1 (en) * 1999-04-14 2007-10-09 Verizon Corporate Services Group Inc. Methods and systems for selection of multimedia presentations
US7337174B1 (en) * 1999-07-26 2008-02-26 Microsoft Corporation Logic table abstraction layer for accessing configuration information
KR100350792B1 (en) * 1999-09-22 2002-09-09 엘지전자 주식회사 Multimedia data browsing system based on user profile
AU7863600A (en) * 1999-10-05 2001-05-10 Zapmedia, Inc. System and method for distributing media assets to user devices and managing user rights of the media assets
US20040220791A1 (en) * 2000-01-03 2004-11-04 Interactual Technologies, Inc. A California Corpor Personalization services for entities from multiple sources
US20040220926A1 (en) * 2000-01-03 2004-11-04 Interactual Technologies, Inc., A California Cpr[P Personalization services for entities from multiple sources
US8589777B1 (en) * 2000-01-21 2013-11-19 International Business Machines Corporation Method and system for calculating cost of a compilation of content
US7346844B1 (en) * 2000-01-21 2008-03-18 International Business Machines, Corporation Method and system for moving content in a content object stored in a data repository
US7613993B1 (en) * 2000-01-21 2009-11-03 International Business Machines Corporation Prerequisite checking in a system for creating compilations of content
US7281034B1 (en) * 2000-01-24 2007-10-09 Friskit, Inc. System and method for media playback over a network using links that contain control signals and commands
JP2002055992A (en) * 2000-08-09 2002-02-20 Nippon Telegr & Teleph Corp <Ntt> Archive system and its retrieving method
US7689510B2 (en) * 2000-09-07 2010-03-30 Sonic Solutions Methods and system for use in network management of content
US20020111956A1 (en) * 2000-09-18 2002-08-15 Boon-Lock Yeo Method and apparatus for self-management of content across multiple storage systems
US6970860B1 (en) * 2000-10-30 2005-11-29 Microsoft Corporation Semi-automatic annotation of multimedia objects
US20020069418A1 (en) * 2000-12-06 2002-06-06 Ashwin Philips Network-enabled audio/video player
JP2002244968A (en) * 2001-02-19 2002-08-30 Matsushita Electric Ind Co Ltd Data display system, data display method, and recording medium
US20040019658A1 (en) * 2001-03-26 2004-01-29 Microsoft Corporation Metadata retrieval protocols and namespace identifiers
US6741996B1 (en) * 2001-04-18 2004-05-25 Microsoft Corporation Managing user clips
US20020188735A1 (en) * 2001-06-06 2002-12-12 Needham Bradford H. Partially replicated, locally searched peer to peer file sharing system
US7363384B2 (en) * 2001-07-11 2008-04-22 Sony Computer Entertainment America Inc. Selection of content in response to communication environment
JP2003085086A (en) * 2001-09-12 2003-03-20 Sony Corp Service provision system and method
AU2002351232A1 (en) * 2001-12-04 2003-06-17 Yahoo!Inc. Method and system for providing listener-requested music over a network
US7509667B1 (en) * 2002-08-15 2009-03-24 Sprint Communications Company L.P. Broadband content jukebox with profile-based caching
US7689715B1 (en) * 2002-12-20 2010-03-30 Symantec Operating Corporation Method and system for implementing a global name space service
US7131059B2 (en) * 2002-12-31 2006-10-31 Hewlett-Packard Development Company, L.P. Scalably presenting a collection of media objects

Patent Citations (63)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6947959B1 (en) * 1992-10-01 2005-09-20 Quark, Inc. Digital media asset management system and process
US6505160B1 (en) * 1995-07-27 2003-01-07 Digimarc Corporation Connected audio and other media objects
US6374260B1 (en) * 1996-05-24 2002-04-16 Magnifi, Inc. Method and apparatus for uploading, indexing, analyzing, and searching media content
JPH1132070A (en) 1997-05-02 1999-02-02 Sony Electron Inc Multi-media information system and multi-media information reproducing method
US5920856A (en) 1997-06-09 1999-07-06 Xerox Corporation System for selecting multimedia databases over networks
US6523022B1 (en) 1997-06-09 2003-02-18 Allen Hobbs Method and apparatus for selectively augmenting retrieved information from a network resource
US5983218A (en) 1997-06-30 1999-11-09 Xerox Corporation Multimedia database for use over networks
US6587127B1 (en) * 1997-11-25 2003-07-01 Motorola, Inc. Content player method and server with user profile
US6498897B1 (en) * 1998-05-27 2002-12-24 Kasenna, Inc. Media server system and method having improved asset types for playback of digital media
US6243713B1 (en) 1998-08-24 2001-06-05 Excalibur Technologies Corp. Multimedia document retrieval by application of multimedia queries to a unified index of multimedia data for a plurality of multimedia data types
US6741980B1 (en) * 1999-03-23 2004-05-25 Microstrategy Inc. System and method for automatic, real-time delivery of personalized informational and transactional data to users via content delivery device
US20030140313A1 (en) * 1999-04-26 2003-07-24 Smith Kim C. Method of creating default lists of content of probable interest
JP2000348052A (en) 1999-06-07 2000-12-15 Nec Corp System, device and method for providing site map, and recording medium
US6947182B1 (en) * 1999-07-26 2005-09-20 Canon Kabushiki Kaisha Network system and control method of the same
US7184976B1 (en) * 1999-09-09 2007-02-27 Canon Kabushiki Kaisha Apparatus which can be connected to network, and charging management system
US6775687B1 (en) * 1999-10-12 2004-08-10 International Business Machines Corporation Exchanging supplemental information fields between a client and a server
US7065342B1 (en) * 1999-11-23 2006-06-20 Gofigure, L.L.C. System and mobile cellular telephone device for playing recorded music
US20010042107A1 (en) 2000-01-06 2001-11-15 Palm Stephen R. Networked audio player transport protocol and architecture
US20020062252A1 (en) 2000-01-07 2002-05-23 Van Zoest Alexander T. System and method for providing access to electronic works
US6735628B2 (en) * 2000-01-24 2004-05-11 Friskit, Inc. Media search and continuous playback of multiple media resources distributed on a network
US6829368B2 (en) * 2000-01-26 2004-12-07 Digimarc Corporation Establishing and interacting with on-line media collections using identifiers in media signals
US7099685B2 (en) * 2000-04-26 2006-08-29 Samsung Electronics Co., Ltd. Apparatus and method for providing multimedia service in a mobile terminal
US7024485B2 (en) * 2000-05-03 2006-04-04 Yahoo! Inc. System for controlling and enforcing playback restrictions for a media file by splitting the media file into usable and unusable portions for playback
US20020082901A1 (en) * 2000-05-03 2002-06-27 Dunning Ted E. Relationship discovery engine
US20040214551A1 (en) * 2000-05-09 2004-10-28 Doo-Yong Kim Digital mobile telephone and methods for executing and providing multimerdia data for the digital mobile telephone
JP2001318949A (en) 2000-05-09 2001-11-16 Onkyo Corp Contents delivery system
US6865600B1 (en) * 2000-05-19 2005-03-08 Napster, Inc. System and method for selecting internet media channels
US6697800B1 (en) * 2000-05-19 2004-02-24 Roxio, Inc. System and method for determining affinity using objective and subjective data
US6662231B1 (en) * 2000-06-30 2003-12-09 Sei Information Technology Method and system for subscriber-based audio service over a communication network
US7073130B2 (en) * 2001-01-31 2006-07-04 Microsoft Corporation Methods and systems for creating skins
US20020101444A1 (en) * 2001-01-31 2002-08-01 Novak Michael J. Methods and systems for creating skins
US7080030B2 (en) * 2001-02-28 2006-07-18 Digonex Technologies, Inc. Digital online exchange
US20020134220A1 (en) * 2001-03-21 2002-09-26 Hiroaki Yamane Play list generation device, audio information provision device, audio information provision system, method, program and recording medium
US20020147683A1 (en) * 2001-04-06 2002-10-10 Anthony Capobianco Method for purchasing web based digital media
US20020183042A1 (en) * 2001-05-29 2002-12-05 Kevin Thornton System and method for sampling audio recordings on a wireless communication device
US6976028B2 (en) * 2001-06-15 2005-12-13 Sony Corporation Media content creating and publishing system and process
US20030018709A1 (en) * 2001-07-20 2003-01-23 Audible Magic Playlist generation method and apparatus
EP1283487A2 (en) 2001-08-06 2003-02-12 Pioneer Corporation Management server device and terminal device for a contents providing system
JP2003085893A (en) 2001-09-07 2003-03-20 Sony Corp Device and method for processing information, and program therefor
US20030061273A1 (en) * 2001-09-24 2003-03-27 Intel Corporation Extended content storage method and apparatus
US20040015519A1 (en) * 2001-10-15 2004-01-22 Yukitoshi Maeda Content delivery server and content delivery system having the same
US7295995B1 (en) * 2001-10-30 2007-11-13 A9.Com, Inc. Computer processes and systems for adaptively controlling the display of items
US20040148362A1 (en) * 2001-11-02 2004-07-29 Lee Friedman Systems and methods for managing and aggregating media formats
US20040024580A1 (en) * 2002-02-25 2004-02-05 Oak Technology, Inc. Server in a media system
US20030159566A1 (en) * 2002-02-27 2003-08-28 Sater Neil D. System and method that facilitates customizing media
US6653545B2 (en) * 2002-03-01 2003-11-25 Ejamming, Inc. Method and apparatus for remote real time collaborative music performance
US20030174819A1 (en) * 2002-03-18 2003-09-18 Chien-Chung Su Method for providing information service by using a network-connection device and architecture thereof
US6941324B2 (en) * 2002-03-21 2005-09-06 Microsoft Corporation Methods and systems for processing playlists
US20040204124A1 (en) * 2002-05-08 2004-10-14 Campbell Lowell Lete Method of minimizing the quantity of information stored in a wireless device
US6987221B2 (en) * 2002-05-30 2006-01-17 Microsoft Corporation Auto playlist generation with multiple seed songs
US20040002943A1 (en) * 2002-06-28 2004-01-01 Merrill John Wickens Lamb Systems and methods for application delivery and configuration management of mobile devices
US20040060070A1 (en) * 2002-09-17 2004-03-25 Noriyasu Mizushima System for distributing videos synchronized with music, and method for distributing videos synchronized with music
US20060059231A1 (en) * 2002-09-18 2006-03-16 Masahiro Takatori Information acquiring device and information providing device
US20040078357A1 (en) * 2002-10-16 2004-04-22 Microsoft Corporation Optimizing media player memory during rendering
US7054888B2 (en) * 2002-10-16 2006-05-30 Microsoft Corporation Optimizing media player memory during rendering
US20040091235A1 (en) * 2002-11-07 2004-05-13 Srinivas Gutta Tracking of partially viewed shows so that they can be marked for deletion when a personal video recorder runs out of space
US7117453B2 (en) * 2003-01-21 2006-10-03 Microsoft Corporation Media frame object visualization system
US7213228B2 (en) * 2003-03-17 2007-05-01 Macrovision Corporation Methods and apparatus for implementing a remote application over a network
US20040192358A1 (en) * 2003-03-24 2004-09-30 Inventec Appliances Corp. Method of instantly receiving and playing back audio data from wireless network by wireless terminal
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
US20040243700A1 (en) * 2003-05-29 2004-12-02 Weast John C. Visibility of media contents of UPnP media servers and initiating rendering via file system user interface
US20060010075A1 (en) * 2004-07-08 2006-01-12 Dean Wolf Technique for facilitating resale of digital content over a computer network

Non-Patent Citations (32)

* Cited by examiner, † Cited by third party
Title
"Apache: The Definitive Guide," Feb. 1999, O'Reilly & Associates.
"Apple Announces iTunes 2," Press Release, Apple Computer, Inc., Oct. 23, 2001, downloaded from: http://www.apple.com/pr/library/2001/oct/23itunes.html, on Jul. 10, 2002, 2 pages.
"Apple Introduces iTunes-World's Best and Easiest To Use Jukebox Software," Macworld Expo, San Francisco, Jan. 9, 2001, downloaded from http://www.apple.com/pr/library/2001/jan/09itunes.html, on Jul. 10, 2002, 2 pages.
"iCommune 2.0a1," Product Information, 2003, 4 pages.
"iCommune-Share your music over a network," downloaded from http://www.icommune.sourceforge.net/ on Nov. 12, 2003, 1 page.
"iHam on iRye: 2.0-VersionTracker," downloaded from: http://www.versiontracker.com/dyn/moreinfo/macosx/13021 on Nov. 12, 2003, 3 pages.
"Review: SoundJam MP Plus 2.5.1," Daniel Chvatik, Oct. 2000, downloaded from: http://www.atpm.com/6.10/soundjam.shtml on Nov. 12, 2003, 8 pages.
"Slim Devices, Product Information: Overview," downloaded from http://www.slimdevices.com/pi-overview.html, 2004, 2 pages.
"SoundJam MP Plus Manual, version 2.0"-MP3 Player and Encoder for Macintosh by Jeffrey Robbin, Bill Kincaid and Dave Heller, manual by Tom Negrino, published by Casady & Greene, Inc., 2000.
"Squeezebox-The wireless MP3 player for your digital stereo" downloaded from http://www.slimdevices.com/downloads/squeezebox.pdf, 2003, 2 pages.
"WWDC 2002 Keynote," May 6, 2002, downloaded from: http://www.digitalmedievalist.com/it/archive/000028.html on Nov. 12, 2003, 3 pages.
Debique et al., "ContentDirectory: 1 Service Template for Universal Plug and Play", Standardized Device Control Protocol Document of the UPNP Forum, Microsoft, version 1.01 Jun. 25, 2002, pp. 1-89.
European Search Report for European Patent Application No. 07012976.2 dated Jan. 22, 2008.
Ikeda, Fuyuhiko, "Mac People", vol. 8, No. 20, ASCII Corporation, Japan, Oct. 15, 2002, pp. 48-51.
iTunes 2, Playlist Related Help Screens, iTunes v2.0, Apple Computer Inc., Oct. 23, 2001.
iTunes, Playlist Related Help Screens, iTunes v1.0, Apple Computer, Inc., Jan. 2001.
Notification of Reason for Rejection, Japanese Patent Office, Japanese Patent Application No. 2002-510066, dated Apr. 1, 2008 (with translation).
Notification of Reason for Rejection, Japanese Patent Office, Japanese Patent Application No. 2008-29463, dated Apr. 6, 2009 (with translation).
Notification of Reason for Rejection, Japanese Patent Office, Japanese Patent Application No. 2008-29463, dated Sep. 16, 2008 (with translation).
Notification of the Third Office Action for Chinese Patent Application No. 200480008880.1, mailed Mar. 13, 2009.
Office Action Chinese Patent Office Chinese, Patent Application No. 200480008880.1, dated Nov. 28, 2008 (with translation).
Office Action for Japanese Patent Application No. 2008/29463 dated Oct. 20, 2009.
Office Action from Chinese Patent Office for Chinese Patent Application No. 200480008880.1 dated Nov. 23, 2007.
Office Action, European Patent Office, Patent Application No. 04760262.8, dated Feb. 24, 2009.
Office Action, European Patent Office, Patent Application No. 04760262.8, dated May 5, 2006.
Office Action, European Patent Office, Patent Application No. 07012976.2, dated Feb. 24, 2009.
Partial European Search Report from European Patent Office for European Patent Application No. 07012976.2 dated Nov. 2, 2007.
Ritchie et al., "UPnP AV Architecture: 0.83", Design Document Microsoft, Jun. 12, 2002, pp. 1-22.
Searchware Solutions, "iHam on iRye 2.0 Documentation," http://www.swssoftware.com, 10 pages.
SoundJam MP Plus, Representative Screens, published by Casady & Greene, Inc., Salinas, CA, 2000.
Specification Sheet, iTunes 2, Apple Computer, Inc., Oct. 31, 2001.
Written Opinion of the International Searching Authority dated Jan. 28, 2005 issued in International Application No. PCT/US2004/011621.

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
USRE47934E1 (en) * 2003-04-25 2020-04-07 Apple Inc. Accessing digital media

Also Published As

Publication number Publication date
US20040215611A1 (en) 2004-10-28
EP1618501A2 (en) 2006-01-25
EP1843260A3 (en) 2008-02-20
EP1843260A2 (en) 2007-10-10
JP2010146584A (en) 2010-07-01
WO2004097683A3 (en) 2005-03-17
JP4469398B2 (en) 2010-05-26
JP2007525726A (en) 2007-09-06
USRE47934E1 (en) 2020-04-07
WO2004097683A2 (en) 2004-11-11
JP5358463B2 (en) 2013-12-04
CN1768338A (en) 2006-05-03
CN100533435C (en) 2009-08-26
US7698297B2 (en) 2010-04-13
JP2008171442A (en) 2008-07-24
JP4176801B2 (en) 2008-11-05
US6728729B1 (en) 2004-04-27

Similar Documents

Publication Publication Date Title
USRE47934E1 (en) Accessing digital media
US7668901B2 (en) Methods and system using a local proxy server to process media data for local area users
US7530115B2 (en) Access to content addressable data over a network
US9378212B2 (en) Methods and systems for providing file data and metadata
EP1743247B1 (en) System and method for optimized property retrieval of stored objects
US8595340B2 (en) Method and system for managing digital content, including streaming media
US8683009B2 (en) Wireless synchronization between media player and host device
US6901428B1 (en) Accessing data from a database over a network
US8195607B2 (en) Fail over resource manager access in a content management system
US8909635B2 (en) Profiling content creation and retrieval in a content management system
US20020198944A1 (en) Method for distributing large files to multiple recipients
US20090327222A1 (en) Dynamic selection of media for playback
US20080133546A1 (en) Method and system for efficient and dynamically adaptable digitally-encoded-information distribution
US20020026521A1 (en) System and method for managing and distributing associated assets in various formats
US20050223277A1 (en) Online storage system
JP2002501254A (en) Access to content addressable data over a network
MXPA05010438A (en) System and method for determining target failback and target priority for a distributed file system.
JP2010257466A (en) Digital audio track set recognition system
US20030195929A1 (en) Methods and system using secondary storage to store media data accessible for local area users
US20030182257A1 (en) Method and system for migrating data while maintaining hard links
US20030182288A1 (en) Method and system for migrating data while maintaining access to data with use of the same pathname
JP2002537572A (en) A distributed production system for digitally encoding information.
JP2003516586A (en) Content collection
US20060031224A1 (en) Method, system and computer program product for managing database records with attributes located in multiple databases
JP2004192480A (en) Program installation system

Legal Events

Date Code Title Description
FEPP Fee payment procedure

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552)

Year of fee payment: 8

CC Certificate of correction
MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 12