Arrangement for synchronizing media files with portable devices
09544369 ยท 2017-01-10
Inventors
Cpc classification
H04N21/4126
ELECTRICITY
G06F16/40
PHYSICS
H04L67/1095
ELECTRICITY
Y10S707/913
GENERAL 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
G06F16/48
PHYSICS
International classification
Abstract
Arrangements are provided which improve the efficiency of the synchronization process. The same ensure that synchronizations of large quantities of content can be completed with a minimum of delay. One method prioritizes the various tasks that are to be performed prior to synchronization. Another method initiates dependent tasks while parsing a synchronization tasks list. Yet another method allows modification of an in-process synchronization operation to allow new synchronization tasks to be accomplished within the context of the same process, negating the need to restart synchronization.
Claims
1. A computer-readable medium, encoded with computer-executable instructions which, when executed by a processor, perform a method for synchronizing a content playback device with a content management device, the method comprising: performing an operation on one of a first plurality of containers stored on the content playback device, each container storing a first subset of content items within a media library, the subsets of content items identified by applying filters to the media library in accordance with a predefined scheme, the content items available for playback on the content playback device, the content management device including a second plurality of containers each storing a second subset of content items; comparing one or more of the second subset of content items within one of the second plurality of containers on the content management device with a corresponding one or more of the first subset of content items within one of the first plurality of containers on the content playback device; based at least in part on detecting a difference between any of the one or more of the second subset of content items on the content management device and any one of the corresponding ones of the one or more of the first subset of content items on the content playback device, performing a list of tasks to synchronize the one or more of the second subset of content items on the content management device for which the difference was detected with the corresponding ones of the one or more of the first subset of content items on the content playback device; and while performing the list of tasks, and based at least in part on detecting a concurrent user-directed addition, deletion or modification of a content item within one of the second plurality of containers on the content management device or within one of the first plurality of containers on the content playback device, modifying the lists of tasks to add, delete or modify the content item, respectively, in the other container of either the second plurality of containers on the content management device or the first plurality of containers on the content playback device to synchronize the corresponding content items within the first plurality of containers and the second plurality of containers.
2. The computer-readable medium of claim 1, in which each of the content items has metadata associated therewith and further comprising applying the filters to the metadata to identify the subset of content items.
3. The computer-readable medium of claim 1, in which the predefined scheme is formed based on user input.
4. The computer-readable medium of claim 1, in which different ones of the first plurality of containers in the media library include digital media files associated with different types of media selected from the group consisting of audio, video, images and multimedia.
5. The computer-readable medium of claim 1, in which the content items include songs and the filters identify subsets of content items defined by albums, artists and genres.
6. The computer-readable medium of claim 1, further comprising adding, deleting or modifying the content items, respectively, in accordance with the modified list of tasks while performing the modified list of tasks and before finishing at least partial synchronization.
7. The computer-readable medium of claim 1, further comprising: determining if a first task in the task list is to be performed immediately, or if a prerequisite task must be performed before the first task, performing the first task, otherwise performing the prerequisite task and then the first task; and during the time of performing the prerequisite task, commencing performance of a second task.
8. The computer-readable medium of claim 1, in which the tasks are selected from the group consisting of copying a content item to the content playback device, deleting a content item on the content playback device, moving a content item to the content playback device, modifying a content item on the content management device or on the content playback device, altering a format of a content item and altering a bit rate of a content item.
9. The computer-readable medium of claim 1, in which the content playback device is a portable media player.
10. A content management device comprising: a computer-readable medium; a first plurality of containers stored in the computer-readable medium, each container storing a first subset of content items within a media library, the first subsets of content items identified by applying filters to the media library in accordance with a predefined scheme, the content items available for playback on a content playback device; a processor responsive to the computer-readable medium and to a computer program, the computer program, when loaded into the processor, being operable to perform a method comprising: comparing one or more of the first subset of content items within one of the first plurality of containers on the content management device with a corresponding one or more of a second subset of content items within a second plurality of containers on the content playback device; based at least in part on detecting a difference between any of the one or more of the first subset of content items on the content management device and any one of the corresponding ones of the one or more of the second subset of content items on the content playback device for which the difference was detected performing a list of tasks to synchronize the one or more of the first subset of content items on the content management device for which the difference was detected with the corresponding ones of the one or more of the second subset of content items on the content playback device; while performing the list of tasks, and based at least in part on detecting a concurrent user-directed addition, deletion or modification of a content item within one of the first plurality of containers on the content management device or within one of the second plurality of containers on the content playback device, modifying the list of tasks to add, delete or modify the content item, respectively, in either the first plurality of containers on the content management device or the second plurality of containers on the content playback device to synchronize the corresponding content items within the first plurality of containers and the second plurality of containers.
11. The content management device of claim 10, in which the tasks are selected from the group consisting of copying a content item to one of the containers on the content management device, deleting a content item from one of the containers on the content management device, moving a content item to a container on the content management device and modifying a content item in a container on the content management device.
12. The content management device of claim 10, in which at least one of the containers in the first plurality of containers is a custom container created based on user input.
13. The content management device of claim 10, in which at least one of the containers in the first plurality of containers is a custom container created based on an analysis of user history.
14. The content management device of claim 10, further comprising an external drive, and further comprising: detecting at least one content item on the external drive; copying the content item to the content management device; copying metadata pertaining to the content item to the content management device; and modifying the task list to copy the at least one content item to the content playback device.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
(1)
(2)
(3)
(4)
(5)
(6)
(7)
(8)
(9)
(10)
(11)
DETAILED DESCRIPTION
(12) The following definitions are used in this description.
(13) Content items (elements 120, 120, and 120 of
(14) A content playback device (element 200 of
(15) A content management device (element 100 of
(16) Synchronization (alternatively elements 600 or 700 of
(17) Online service (e.g., element 310 of
(18) A playlist is a collection of media files to be played back in a given order as determined by the user.
(19) A container (elements 102, 102, 104, 104, 106, and 106 of
(20) Finally, a container may be associated with a content playback device when the same is the subject of an operation that transfers, copies, or otherwise causes the content items in the container to be placed onto the content playback device. This may be performed by a simple drag-and-drop operation or by any number of other such similar procedures.
(21) Turning to the drawings, where like numerals designate like components or steps,
(22) Using the metadata or other such information, one or more containers 102, 104, 106 (corresponding to containers 1, 2, and 3) may be defined, created, or generated. The containers 102, 104, 106 may be formed by the action of a filter on a content media library 130, and may be formed automatically or in a custom fashion. The containers may generally include content items in a natural organization unit. For example, one container may include all songs by a particular artist, or all songs from an album. Another container may include all shows from a television series, or all shows for that series from a given season. Another container may include all podcasts from a chosen publisher. Another container may include all songs of a given genre.
(23) The content management application may automatically create numerous such containers according to a predefined scheme, and the scheme may be updated periodically. For example, containers may be created that correspond to, for music, any and all albums, any and all artists, and any and all genres represented.
(24) Custom containers, which may be formed on the basis of user input, may be created in either a passive or an active sense. In the former, containers may be formed such as most played. In the latter, containers may be formed such as highest rated. Custom containers may also incorporate complicated filtering schemes, e.g., all alternative music of the 1980s from British bands.
(25)
(26)
(27)
(28) The content management device 100 may be connected to a network 300 via a wired link 114 or a wireless link 108. The content playback device 200 may also be connected to the network 300 via a link; a wireless link 112 is shown, although a wired link is also possible (not shown). An exemplary online service 310 is shown within the network, the same generally includes a set of content items 120, which the user may purchase and download either immediately or perform a download-on-demand later, at a time of the user's convenience.
(29)
(30) First, an initial optional step is shown of creating a media library 130 (step 400). In many cases, a media library will already have been created.
(31) A next step is to create containers (step 450). As noted above, containers may be generated in a number of ways, such as by the action of a filter on the media library 130. In more detail, as shown in
(32) Referring back to
(33)
(34) A content playback device or portable media player icon 480 is displayed in
(35) By clicking on the content playback device icon, or via an analogous procedure, the content items on the content playback device may be displayed. Referring to
(36) A number of containers 484-488 are also displayed on the left-hand-side of the interface of
(37) Following the association operation, a synchronization step may occur. The arrangement provide several types of synchronization operations, which may be employed separately or in combination.
(38) In one type of synchronization operation, a live or automatic synchronization of containers may occur (step 600). Referring to
(39) Live synchronization may be accomplished in at least one of three ways, which may also occur in various combinations. In one way, a synchronization operation may simply occur periodically (step 602). In this way, synchronization occurs every few minutes or on any other schedule as determined by the content management device or user. In a second way, a synchronization operation occurs whenever the content management device 100 detects a change in a container 102 (step 604). For example, if a content item 120 is added to a container 102, and the container 102 is associated with the content playback device 200, then a synchronization operation may occur as soon as is feasible, e.g., immediately or soon thereafter, without user initiation. In the same way, if a drag-and-drop operation is performed on a container, again a synchronization operation may occur as soon as is feasible.
(40) In a third way, and referring in addition to
(41) In another type of synchronization operation, and referring to
(42) As tasks are added to a work queue, the synchronization engine reviews them and determines when an action is capable of being immediately performed, where immediately performed means, for example, that a transfer can occur without any prerequisite tasks first being performed on the content item. If it is, the action is performed and a pointer moves to the next task. If the action is not capable of being immediately performed, then the synchronization engine queues a new task of higher priority that is necessary before the initial action can be performed, i.e., a prerequisite task. The pointer is reset to, e.g., the beginning of the queue. Once either of the tasks is performed, the pointer moves to the next item and repeats the process. If resources are available to take action on the next task, the next task is performed; otherwise, it moves on to the next item in the queue. In this way, increased efficiency is obtained in use of limited I/O bandwidth and/or CPU capabilities.
(43) In certain versions of the above arrangement, it is noted that the entire work queue may be reviewed or re-evaluated to ensure that the highest priority tasks are performed first, and that the performance of all the tasks is done in a manner to minimize the overall synchronization time.
(44) Referring in particular to the exemplary
(45)
(46) In the example of
(47) As the synchronization engine 110 reaches content item A (element 711), the same determines that a conversion is necessary before the transfer of the item 711 can occur. Consequently a conversion task is queued ahead of the transfer of the item 711, and this transfer is marked as dependent on the conversion. In
(48) The transfer of content item B (item 712) may then begin; however, the synchronization engine 110 determines that a download is necessary before the transfer of the item 712 can occur. Consequently a download task is queued ahead of the transfer of the item 712, and this transfer is marked as dependent on the conversion. In
(49) The transfer of content item C (item 713) may then begin; however, the synchronization engine 110 determines that a download is necessary before the transfer of the item 713 can occur. Consequently a download task is queued ahead of the transfer of the item 713, and this transfer is marked as dependent on the conversion. In
(50) The transfer of content item D (item 714) may then begin; in this case, the transfer of the item 714 can begin immediately, as no items are currently being transferred by the transfer module 702 and the item 714 requires no pre-processing.
(51) At this step in the sequence four tasks are happening contemporaneously. When the conversion of content item A, or the download of content item B or C, is completed, their respective transfers are re-attempted. It may be found that yet another task is prerequisite to the transfer, e.g., it may be that content item B or C has to be converted, in which case another prerequisite task is queued ahead of the same's transfer.
(52) If a content item E (not shown) were now introduced to the queue but required conversion, its conversion would be queued ahead of its transfer, but since there are no free conversion slots, the conversion itself would be delayed until a free resource was available. Similarly, if two more downloads were required, the first would start immediately while the second would be delayed until one of the three active downloads completed.
(53) In alternative arrangements, the availability of resources (e.g., for conversion, download, etc.) may be self-adjusting based on past experience, network utilization, etc.
(54) In another aspect of the method and user interface, as may be seen by comparing
(55) In another aspect of the arrangement, content items 120 may be synchronized to the content playback device 200 without adding the content item files to the user's media library 130. In particular, users may desire to place content items 120 directly on a content playback device 200 as part of media library 130 but without occupying space in their main media library 130. For example, many news items, lectures, podcasts, are only listened to once, and thus permanent storage is unnecessary and may be undesirable. Another example may be a data CD full of music files or the like, which are archived and need not necessarily be stored on the user's hard drive. Moreover, a data CD full of music files is not always available in the same way as a hard drive generally is. This method is further intended to encompass content items stored in an online store and downloaded on demand directly to a content playback device. In this way, users may, e.g., listen to an album prior to downloading the same onto their hard drive.
(56) In this method, the user may copy content from a normally-offline location, e.g., external drive 125, directly onto their content playback device. This allows the content items to be transferred but to not clutter the user's media library 130. In one implementation, metadata associated with the transferred files may still be maintained in the media library 130, allowing other functionality associated with the synchronization engine to apply to those content items, e.g., automatic content management such as ongoing metadata updates if the original files are altered in some way.
(57) Referring to
(58) In any case, and referring back to
(59) Thus, it can be seen that the arrangements described enable a convenient way to synchronize a content management device with a content playback device.
(60)
(61) As shown, operating environment 730 includes processor 732, computer-readable media 734, and computer-executable instructions 736. One or more internal buses 740 may be used to carry data, addresses, control signals, and other information within, to, or from operating environment 730 or elements thereof.
(62) Processor 732, which may be a real or a virtual processor, controls functions of the operating environment by executing computer-executable instructions 736. The processor may execute instructions at the assembly, compiled, or machine-level to perform a particular process.
(63) Computer-readable media 734 may represent any number and combination of local or remote devices, in any form, now known or later developed, capable of recording, storing, or transmitting computer-readable data, such as the above-noted computer-executable instructions 736, including user interface functions 738 and synchronization engine 110, and content items 120. In particular, the computer-readable media 734 may be, or may include, a semiconductor memory (such as a read only memory (ROM), any type of programmable ROM (PROM), a random access memory (RAM), or a flash memory, for example); a magnetic storage device (such as a floppy disk drive, a hard disk drive, a magnetic drum, a magnetic tape, or a magneto-optical disk); an optical storage device (such as any type of compact disk or digital versatile disk); a bubble memory; a cache memory; a core memory; a holographic memory; a memory stick; a paper tape; a punch card; or any combination thereof. The computer-readable media may also include transmission media and data associated therewith. Examples of transmission media/data include, but are not limited to, data embodied in any form of wireline or wireless transmission, such as packetized or non-packetized data carried by a modulated carrier signal.
(64) Computer-executable instructions 736 represent any signal processing methods or stored instructions. Generally, computer-executable instructions 736 are implemented as software components according to well-known practices for component-based software development, and encoded in computer-readable media. Computer programs may be combined or distributed in various ways. Computer-executable instructions 736, however, are not limited to implementation by any specific embodiments of computer programs, and in other instances may be implemented by, or executed in, hardware, software, firmware, or any combination thereof.
(65) Input interface(s) 742 are any now known or later developed physical or logical elements that facilitate receipt of input to operating environment 730.
(66) Output interface(s) 744 are any now known or later developed physical or logical elements that facilitate provisioning of output from operating environment 730.
(67) Network interface(s) 746 represent one or more physical or logical elements, such as connectivity devices or computer-executable instructions, which enable communication between operating environment 730 and external devices or services, via one or more protocols or techniques. Such communication may be, but is not necessarily, client-server type communication or peer-to-peer communication. Information received at a given network interface may traverse one or more layers of a communication protocol stack.
(68) Specialized hardware 748 represents any hardware or firmware that implements functions of operating environment 730. Examples of specialized hardware include encoder/decoders decrypters, application-specific integrated circuits, clocks, and the like.
(69) The methods shown and described above may be implemented in one or more general, multi-purpose, or single-purpose processors. Unless specifically stated, the methods described herein are not constrained to a particular order or sequence. In addition, some of the described methods or elements thereof can occur or be performed concurrently.
(70) Functions/components described herein as being computer programs are not limited to implementation by any specific embodiments of computer programs. Rather, such functions/components are processes that convey or transform data, and may generally be implemented by, or executed in, hardware, software, firmware, or any combination thereof.
(71) It will be appreciated that particular configurations of the operating environment may include fewer, more, or different components or functions than those described. In addition, functional components of the operating environment may be implemented by one or more devices, which are co-located or remotely located, in a variety of ways.
(72) Although the subject matter herein has been described in language specific to structural features and/or methodological acts, it is also to be understood that the subject matter defined in the claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims.
(73) It will further be understood that when one element is indicated as being responsive to another element, the elements may be directly or indirectly coupled. Connections depicted herein may be logical or physical in practice to achieve a coupling or communicative interface between elements. Connections may be implemented, among other ways, as inter-process communications among software processes, or inter-machine communications among networked computers.
(74) The word exemplary is used herein to mean serving as an example, instance, or illustration. Any implementation or aspect thereof described herein as exemplary is not necessarily to be constructed as preferred or advantageous over other implementations or aspects thereof.
(75) As it is understood that embodiments other than the specific embodiments described above may be devised without departing from the spirit and scope of the appended claims, it is intended that the scope of the subject matter herein will be governed by the following claims.