TRANSFERRING USER SETTINGS FROM ONE DEVICE TO ANOTHER

Information

  • Patent Application
  • 20150067099
  • Publication Number
    20150067099
  • Date Filed
    March 12, 2014
    10 years ago
  • Date Published
    March 05, 2015
    9 years ago
Abstract
A cloud-based computer system changes the modern paradigm from being device-centric to being person-centric. The system makes all user data, settings, and licensed content for a user available in the cloud. This allows transferring user settings from a first device to a second device that is of the same type. A conversion mechanism also allows converting user settings for a first device to corresponding user settings for a second device that is of a different type. In addition to transferring user settings from the cloud, the user settings for the first device can be transferred to an external memory device, which may then be removed and connected to a second device, which can then use the user settings on the external memory device to program the second device.
Description
BACKGROUND

1. Technical Field


This disclosure generally relates to electronic devices, and more specifically relates to transferring user settings from one device to another.


2. Background Art


Modern technology has greatly simplified many aspects of our lives. For example, the Internet has made vast amounts of information available at the click of a mouse. Smart phones allow not only making phone calls, but also provide a mobile computing platform by providing the ability to run apps, view e-mail, and access many different types of information, including calendar, contacts, etc.


Some cloud-based services allow storing data in the cloud, and providing access to that data from any device that has Internet access. Dropbox is an example of a cloud-based file service. A subscriber to Dropbox defines a file folder that is synchronized to the cloud, then all data written to the file folder will be automatically stored in the cloud, making that data automatically available to the user via any device that has an Internet connection. While services like Dropbox are very useful, they have their drawbacks. For example, a Dropbox user must remember to store data in a Dropbox folder or sub-folder. Many different software applications have default settings that save files to a folder that may not be a Dropbox folder. The user must know to change the default folder settings to a Dropbox folder if the data is to be available via Dropbox. But many users lack the knowledge or sophistication to realize all the changes that need to be made to a computer to assure all of the user's data is stored to Dropbox. As a result, if the user's hard drive crashes and data is not recoverable from the hard drive, the user may discover some of their data was not stored to a Dropbox folder or sub-folder, resulting in loss of that data when the hard drive crashed.


The evolution of modern technology has resulted in a world that is “device-centric.” This means each device must be configured to a user's needs. If a user owns a smart phone, tablet computer, and laptop computer, the user must take the time to configure each of these devices to his or her liking. This effort represents a significant investment of time for the user. For example, let's assume a user has been using the iPhone 4 for over a year, and decides to change to the Samsung Galaxy S4 phone. Depending on the vendor of the Samsung Galaxy S4 phone, the vendor may be able to transfer the phone contacts on the iPhone 4 to the new Samsung phone, but none of the apps or other data can be transferred. As a result, the decision to change to a new smart phone platform will require hours of time for the user to download apps and configure the new phone to his or her liking. The same problem exists when a user buys a new computer. The user must take the time to install all the software the user wants to use on the computer, and must take the time to configure the desired settings and preferences on the new computer. Again, this can be a very time-consuming proposition. It is not unusual for a user to spend many hours installing software and configuring a new computer system to his or her liking. For professionals who do not have the support of an IT department, taking the time to configure a new computer system either takes hours out of their work day, or takes hours of their personal time after work. In either case, the user loses hours of valuable time setting up a new computer system.


Not only must a user configure each of his or her devices, the configuration and capabilities of each device differ greatly. Apps installed on a smart phone are not made to run on a laptop or desktop computer. Software installed on a desktop or laptop computer are not made to run on smart phones. The result is the user must configure each device and install the software or apps to make the device as functional as the user needs it to be. This requires significant thought and expertise from the user to know how to configure each device.


BRIEF SUMMARY

A cloud-based computer system changes the modern paradigm from being device-centric to being person-centric. The system makes all user data, settings, and licensed content for a user available in the cloud. This allows transferring user settings from a first device to a second device that has the same hardware architecture type and the same system software type as the first device. A conversion mechanism also allows converting user settings for a first device to corresponding user settings for a second device that has a different hardware architecture type and/or different system software type. In addition to transferring user settings from the cloud, the user settings for the first device can be transferred to an external device, which may then be connected to a second device, which can then use the user settings on the external device to program the second device. A television receiver, such as a cable box, a digital video recorder (DVR), a satellite television receiver, etc. is one example of a device that can be programmed from settings of a different device.


The foregoing and other features and advantages will be apparent from the following more particular description, as illustrated in the accompanying drawings.





BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWING(S)

The disclosure will be described in conjunction with the appended drawings, where like designations denote like elements, and:



FIG. 1 is block diagram showing the Universal Me (U-Me) system;



FIG. 2 is block diagram showing additional details of the U-Me system;



FIG. 3 is block diagram showing a computer system that runs the U-Me system;



FIG. 4 is a block diagram showing how a user using a physical device can access information in the U-Me system;



FIG. 5 is a block diagram showing various features of the U-Me system;



FIG. 6 is a block diagram showing examples of user data;



FIG. 7 is a block diagram showing examples of user licensed content;



FIG. 8 is a block diagram showing examples of user settings;



FIG. 9 is a block diagram showing examples of universal templates;



FIG. 10 is a block diagram showing examples of device-specific templates;



FIG. 11 is a block diagram showing examples of phone templates;



FIG. 12 is a block diagram showing examples of tablet templates;



FIG. 13 is a block diagram showing examples of laptop templates;



FIG. 14 is a block diagram showing examples of desktop templates;



FIG. 15 is a block diagram showing examples of television templates;



FIG. 16 is a block diagram showing examples of software templates;



FIG. 17 is a block diagram showing examples of vehicle templates;



FIG. 18 is a block diagram showing examples of home automation templates;



FIG. 19 is a block diagram showing examples of gaming system templates;



FIG. 20 is a block diagram showing examples of audio system templates;



FIG. 21 is a block diagram showing examples of security system templates;



FIG. 22 is a block diagram showing examples of device interfaces;



FIG. 23 is a block diagram of a universal user interface;



FIG. 24 is a flow diagram of a method for programming a physical device with user settings;



FIG. 25 is a flow diagram of a first suitable method for performing step 2410 in FIG. 24 using a mapping between two physical devices;



FIG. 26 is a block diagram showing the generation of settings for Device2 from settings for Device 1 as shown in the flow diagram in FIG. 25;



FIG. 27 is a block diagram of a second suitable method for performing step 2410 in FIG. 24 using a universal template;



FIG. 28 is a block diagram showing the generation of settings for Device2 from a universal template as shown in the flow diagram in FIG. 27;



FIG. 29 is a block diagram of a third suitable method for performing step 2410 in FIG. 24 using settings from a first device and a universal template;



FIG. 30 is a block diagram showing the generation of settings for Device2 as shown in the flow diagram in FIG. 29;



FIG. 31 is a table showing mapping of some channel numbers for DirecTV to channel numbers for Dish Network;



FIG. 32 is a table showing examples of user television settings;



FIG. 33 is a flow diagram of a method for converting channel numbers for Dish Network to channel numbers for DirecTV;



FIG. 34 is a block diagram of a television receiver that includes a user settings transfer mechanism for exporting user settings to an external device and for importing user settings from an external device;



FIG. 35 is a flow diagram of a method for storing user settings to an external device;



FIG. 36 is a flow diagram of a method for programming user settings for a second device based on the user's settings for a first device; and



FIG. 37 is a flow diagram of a method for providing default settings for a device and for returning the device to its default settings after a user leaves.





DETAILED DESCRIPTION

The evolution of technology has resulted in a device-centric world. Early desktop computer systems allowed a user to define certain settings or preferences that defined how the computer system functioned. This trend has continued to our modern times. Each computer system allows installing software according to the user's needs, and allows setting numerous settings or preferences that define how the computer system functions. A user who buys a new computer system typically must spend many hours installing software and setting user preferences and settings to get the computer system to a state where it is usable according to the user's needs.


The same device-centric approach has been used with cell phones, and now with smart phones. When a user purchases a new phone, the user typically must spend many hours installing apps and setting the appropriate preferences and settings so the smart phone will perform the functions the user desires. Some phone vendors provide a service that can transfer a person's contacts from their old phone to the new phone, and some provide a backup service for those contacts should the person lose or damage their phone. This backup service, however, typically backs up only the contacts, and does not back up apps or settings on the phone. Thus, even with the backup service, when a user gets a new phone, the user still spends hours downloading and installing apps, ringtones, etc. and setting all the system settings to configure the phone to the user's liking.


While many aspects of modern life have been simplified through the use of technology, other aspects have yet to take advantage of technology in a significant way. For example, let's assume a person is watching television (TV), and the TV has a failure that causes the TV to quit working. The user may then try to remember where she bought the TV, when she bought the TV, and whether the TV is still under warranty. The user must typically then locate a stack or file of paper receipts, then go through the stack or file hoping to find the paper receipt for the TV. Even when the user is able to locate the paper receipt, the receipt itself may not indicate the warranty information for the TV. She may have to search for the hard copy documentation she received with the TV. In the alternative, she could contact the store or the manufacturer to determine the warranty for the TV. And when the TV is under warranty, the user will have to make a photocopy of the receipt and send the copy of the receipt with the TV when the TV is returned for warranty service. This system of paper receipts is grossly inefficient, and does not benefit from technology available today.


One aspect of modern life that has been greatly simplified through the use of technology is how music is purchased and used. Apple's iPod was a revolutionary device that allowed storing a large number of songs, which the user may listen to at his or her convenience. To satisfy concerns in the music industry regarding the ease of pirating (performing illegal copying) of digital music files, Apple developed the iTunes software application that allows a user to purchase music, which is stored on the user's computer system in their iTunes account. This music may be copied from the computer system to a suitable Apple device, such as an iPod or iPad. However, music from an iPod or iPad cannot be copied to the user's computer because this would make illegal copying of music very easy. Thus, all of a user's music is stored in the user's computer system in their iTunes software. So what happens when the user's hard drive crashes? Recovering the music in an iTunes account that was on a hard drive that crashed is not an easy process. This is because the iTunes account is tied to the computer system on which iTunes is installed. This shows that iTunes is device-centric as well, which means if the device that hosts iTunes crashes, the music that was stored on the device is difficult to recover.


Another aspect of our modern life that has not fully taken advantage of modern technology is data storage and retrieval. As referenced in the Background section above, Dropbox is an online service that allows storing information to the cloud. However, Dropbox is based on the folder/subfolder (or directory/subdirectory) paradigm. Thus, when using Dropbox, the user must remember to store the data in a Dropbox folder or subfolder, and then must also store the data in a location and use a file name the user is likely to remember. Relying on the memory of a user to remember where the user stored something on a computer system is very inefficient and error-prone. Many users have experienced storing a file to their computer system, then having to search many files across many directories in an attempt to locate the file they stored. Database systems provide very structured ways of storing information, which results in supporting very powerful ways of retrieving information in the database via queries. However, these powerful database tools for storing and retrieving information have not been employed in helping most users to store and retrieve information on their computer systems or smart phones.


Photography is an area that has greatly benefitted from modern technology. Digital cameras and cell phones allow capturing very high-resolution photographs and video in digital form that can be easily stored to an electronic device. While photography itself has been revolutionized by technology, the technology for storing and retrieving photographs has lagged far behind. Many people who have used digital cameras for years have many directories or folders on a computer system that contain thousands of digital photos and videos. When a person uses a digital camera or cell phone to take a photo, the device typically names the photo with a cryptic name that includes a number that is sequential. For example, a Nikon camera may name a photo file with a name such as “DSC0012.jpg.”. The digital file for the next photo is the next number in sequence, such as DSC0013.jpg. Once the photo files are transferred to a computer and are deleted on the digital camera or cell phone, the digital camera or cell phone may reuse file names that were used previously. To avoid overwriting existing photos, many users choose to create a new directory or folder each time photos are downloaded from a camera or cell phone. This results in two significant problems. First, the file name for a photo may be shared by multiple photos in multiple directories. Second, the names of files give the user no information regarding the photo. Thus, to locate a particular photo of interest, the user may have to navigate a large number of directories, searching thumbnails of the photos in each directory to locate the desired photo. This is grossly inefficient and relies on the memory of the user to locate a desired photo. A user can more efficiently locate photos if the user takes the time to carefully name directories or folders and also takes the time to carefully name individual photo files. But this is very time-consuming, and most users don't take the time needed to name folders and photo files in a way that would make retrieval of the photos easier. Most people who take digital photos have thousands of photos that have cryptic names in dozens or hundreds of different directories or folders that may also have cryptic names. The result is that finding a particular photo may be very difficult.


While there are programs that allow organizing digital photos, they have not gained widespread acceptance due to their expense and the time required and difficulty for a user to organize their photos using these programs. As a result, these programs have done little to address the widespread problem of most users having thousands of digital photos that are stored using cryptic names in many different directories or folders, making retrieval of photographs difficult.


The disclosure herein presents a paradigm shift, from the device-centric world we live in today, to a person-centric world. This shift gives rise to many different opportunities that are not available in the world we live in today. A system called Universal Me (U-Me) disclosed herein is a cloud-based system that is person-centric. The U-Me system makes a user's data, licensed content and settings available in the cloud to any suitable device that user may choose to use.


Referring to FIG. 1, the Universal Me (U-Me) system 100 includes multiple user accounts 110, shown in FIG. 1 as 110A, . . . , 110N. Each user account includes data, licensed content, and settings that correspond to the user. Thus, User 1 account 110A includes corresponding data 120A, licensed content 130A, and settings 140A. In similar fashion, UserN account 110N includes corresponding data 120N, licensed content 130N, and settings 140N. Any or all of the user's data, licensed content and settings may be made available on any device 150 the user may use. Examples of suitable devices are shown in FIG. 1 to include a smart phone 150A, a tablet computer 150B, a laptop computer 150C, a desktop computer 150D, and other device 150N. The devices shown in FIG. 1 are examples of suitable devices the user could use to access any of the data, licensed content, or settings in the user's account. The disclosure and claims herein expressly extend to using any type of device to access the user's data, licensed content, or settings, whether the device is currently known or developed in the future.


The U-Me system 100 may include virtual devices in a user's account. Referring to FIG. 2, the User 1 account 110A is shown to include a virtual smart phone 250A that corresponds to the physical smart phone 150A; a virtual tablet computer 250B that corresponds to the physical tablet computer 150B; a virtual laptop computer 250C that corresponds to the physical laptop computer 150C; a virtual desktop computer 250D that corresponds to a physical desktop computer 150D; and a virtual other device 250N that corresponds to a physical other device 150N. The virtual devices preferably include all information that makes a physical device function, including operating system software and settings, software applications (including apps) and their settings, and user settings. It may be impossible due to access limitations on the physical device to copy all the information that makes the physical device function. For example, the operating system may not allow for the operating system code to be copied. The virtual devices contain as much information as they are allowed to contain by the physical devices. In the most preferred implementation, the virtual devices contain all information that makes the physical devices function. In this scenario, if a user accidentally flushes his smart phone down the toilet, the user can purchase a new smart phone, and all the needed information to configure the new smart phone exactly as the old one is available in the virtual smart phone stored in the user's U-Me account. Once the user downloads a U-Me app on the new smart phone, the phone will connect to the user's U-Me account, authenticate the user, and the user will then have the option of configuring the new device exactly as the old device was configured using the information in the virtual smart phone in the user's U-Me account.



FIG. 2 in conjunction with FIG. 3 supports a computer-implemented method executing on at least one processor comprising the steps of storing user data corresponding to a first user, storing first user settings corresponding to the first user for a plurality of software applications, storing second user settings corresponding to the first user for a plurality of physical devices, and making the user data, the first user settings, and the second user settings available to the first user on a first device used by the first user.


There may be some software on a physical device that cannot be copied to the corresponding virtual device. When this is the case, the U-Me account will prompt the user with a list of things to do before the new physical device can be configured using the data in the virtual device. For example, if the user had just applied an operating system update and the new phone did not include that update, the user will be prompted to update the operating system before continuing. If an app installed on the old phone cannot be copied to the user's U-Me account, the U-Me app could prompt the user to install the app before the rest of the phone can be configured. The virtual device preferably contains as much information as possible for configuring the new device, but when information is missing, the U-Me system prompts the user to perform certain tasks as prerequisites. Once the tasks have been performed by the user, the U-Me system can take over and configure the phone using the information stored in the corresponding virtual device.


Referring to FIG. 3, a computer system 300 is an example of one suitable computer system that could host the universal me system 100. Server computer system 300 is an IBM System i computer system. However, those skilled in the art will appreciate that the disclosure and claims herein apply equally to any computer system, regardless of whether the computer system is a complicated multi-user computing apparatus, a single user workstation, or an embedded control system. As shown in FIG. 3, computer system 300 comprises one or more processors 310, a main memory 320, a mass storage interface 330, a display interface 340, and a network interface 350. These system components are interconnected through the use of a system bus 360. Mass storage interface 330 is used to connect mass storage devices, such as local mass storage device 355, to computer system 300. One specific type of local mass storage device 355 is a readable and writable CD-RW drive, which may store data to and read data from a CD-RW 395.


Main memory 320 preferably contains data 321, an operating system 322, and the Universal Me System 100. Data 121 represents any data that serves as input to or output from any program in computer system 100. Operating system 322 is a multitasking operating system. The Universal Me System 100 is the cloud-based system described in detail in this specification. The Universal Me System 100 as shown in FIG. 3 is a software mechanism that provides all of the functionality of the U-Me system.


Computer system 300 utilizes well known virtual addressing mechanisms that allow the programs of computer system 300 to behave as if they only have access to a large, contiguous address space instead of access to multiple, smaller storage entities such as main memory 320 and local mass storage device 355. Therefore, while data 321, operating system 322, and Universal Me System 100 are shown to reside in main memory 320, those skilled in the art will recognize that these items are not necessarily all completely contained in main memory 320 at the same time. It should also be noted that the term “memory” is used herein generically to refer to the entire virtual memory of computer system 300, and may include the virtual memory of other computer systems coupled to computer system 300.


Processor 310 may be constructed from one or more microprocessors and/or integrated circuits. Processor 310 executes program instructions stored in main memory 320. Main memory 320 stores programs and data that processor 310 may access. When computer system 300 starts up, processor 310 initially executes the program instructions that make up the operating system 322. Processor 310 also executes the Universal Me System 100.


Although computer system 300 is shown to contain only a single processor and a single system bus, those skilled in the art will appreciate that the Universal Me system may be practiced using a computer system that has multiple processors and/or multiple buses. In addition, the interfaces that are used preferably each include separate, fully programmed microprocessors that are used to off-load compute-intensive processing from processor 310. However, those skilled in the art will appreciate that these functions may be performed using I/O adapters as well.


Display interface 340 is used to directly connect one or more displays 365 to computer system 300. These displays 365, which may be non-intelligent (i.e., dumb) terminals or fully programmable workstations, are used to provide system administrators and users the ability to communicate with computer system 300. Note, however, that while display interface 340 is provided to support communication with one or more displays 365, computer system 300 does not necessarily require a display 365, because all needed interaction with users and other processes may occur via network interface 350.


Network interface 350 is used to connect computer system 300 to other computer systems or workstations 375 via network 370. Network interface 350 broadly represents any suitable way to interconnect electronic devices, regardless of whether the network 370 comprises present-day analog and/or digital techniques or via some networking mechanism of the future. Network interface 350 preferably includes a combination of hardware and software that allow communicating on the network 370. Software in the network interface 350 preferably includes a communication manager that manages communication with other computer systems 375 via network 370 using a suitable network protocol. Many different network protocols can be used to implement a network. These protocols are specialized computer programs that allow computers to communicate across a network. TCP/IP (Transmission Control Protocol/Internet Protocol) is an example of a suitable network protocol that may be used by the communication manager within the network interface 350.


As will be appreciated by one skilled in the art, aspects of the U-Me system may be embodied as a system, method or computer program product. Accordingly, aspects of the U-Me system may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, aspects of the U-Me system may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.


Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.


A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.


Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.


Computer program code for carrying out operations for aspects of the U-Me system may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).


Aspects of the U-Me system are described below with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.


These computer program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.


The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.



FIG. 4 shows another view of a configuration for running the U-Me system 100. The U-Me system 100 runs in a cloud, shown in FIG. 4 as cloud 410. A user connects to the U-Me system 100 using some physical device 150 that may include a browser 430 and/or software 440 (such as an application or app) that allows the user to interact with the U-Me system 100. Note the physical device 150 is connected to the U-Me system 100 by a network connection 420, which is representative of network 370 shown in FIG. 3, and which can include any suitable wired or wireless network or combination of networks. The network connection 420 in the most preferred implementation is an Internet connection, which makes the U-Me system available to any physical device that has Internet access. Note, however, other types of networks may be used, such as satellite networks and wireless networks. The disclosure and claims herein expressly extend to any suitable network or connection for connecting a physical device to the U-Me system 100.


Various features of the U-Me system are represented in FIG. 5. U-Me system 100 includes user data 120, user licensed content 130, and user settings 140, as the specific examples in FIGS. 1 and 2 illustrate. U-Me system 100 further includes a universal user interface 142, universal templates 152, device-specific templates 154, device interfaces 156, a virtual machine mechanism 158, a conversion mechanism 160, a data tracker 162, a data search engine 164, an alert mechanism 166, a licensed content transfer mechanism 168, a retention/destruction mechanism 170, a macro/script mechanism 172, a sharing mechanism 174, a virtual device mechanism 176, an eReceipt mechanism 178, a vehicle mechanism 180, a photo mechanism 182, a medical info mechanism 184, a home automation mechanism 186, a license management mechanism 188, a sub-account mechanism 190, a credit card monitoring mechanism 192, and a user authentication mechanism 194. Each of these features is discussed in more detail below. The virtual devices 150 in FIG. 2 are preferably created and maintained by the virtual device mechanism 176 in FIG. 5.



FIG. 6 shows some specific examples of user data 120 that could be stored in a user's U-Me account, including personal files 610, contacts 615, e-mail 620, calendar 625, tasks 630, financial info 635, an electronic wallet 640, photos 645, reminders 650, eReceipts 655, medical information 660, and other data 665. The user data shown in FIG. 6 are examples shown for the purpose of illustration. The disclosure and claims herein extend to any suitable data that can be generated by a user, generated for a user, or any other data relating in any way to the user, including data known today as well as data developed in the future.


Personal files 610 can include any files generated by the user, including word processor files, spreadsheet files, .pdf files, e-mail attachments, etc. Contacts 615 include information for a user's contacts, preferably including name, address, phone number(s), e-mail address, etc. E-mail 620 is e-mail for the user. E-mail 620 may include e-mail from a single e-mail account, or e-mail from multiple e-mail accounts. E-mail 620 may aggregate e-mails from different sources, or may separate e-mails from different sources into different categories or views. Calendar 625 includes an electronic calendar in any suitable form and format. Tasks 630 include tasks that a user may set and tasks set by the U-Me system. Financial info 635 can include any financial information relating to the user, including bank statements, tax returns, investment account information, etc. Electronic wallet 640 includes information for making electronic payments, including credit card and bank account information for the user. Google has a product for Android devices called Google Wallet. The electronic wallet 640 can include the features of known products such as Google Wallet, as well as other features not known in the art.


Photos 645 include electronic files for photographs and videos. While it is understood that a user may have videos that are separate from photographs, the term “photos” as used herein includes both photographs and videos for the sake of convenience in discussing the function of the U-Me system. Reminders 650 include any suitable reminders for the user, including reminders for events on the calendar 625, reminders for tasks 630, and reminders set by the U-Me system for other items or events. eReceipts 655 includes electronic receipts in the form of electronic files that may include warranty information and/or links that allow a user to make a warranty claim. Medical info 660 includes any suitable medical information relating to the user, including semi-private medical information, private medical information, and information provided by medical service providers, insurance companies, etc.



FIG. 7 shows some specific examples of user licensed content 130 that could be stored in a user's U-Me account, including purchased music 710, stored music 715, purchased movies 720, stored movies 725, eBooks 730, software 735, games 740, sheet music 745, purchased images 750, online subscriptions 755, and other licensed content 760. The user licensed content shown in FIG. 7 are examples shown for the purpose of illustration. The disclosure and claims herein extend to any suitable user licensed content, including user licensed content known today as well as user licensed content developed in the future.


Purchased music 710 includes music that was purchased from an online source. Note the purchased music 710 could include entire music files, or could include license information that authorizes the user to stream a music file on-demand. Stored music 715 includes music the user owns and which has been put into electronic format, such as music recorded (i.e., ripped) from a compact disc. Purchased movies 720 include movies that were purchased from an online source. Note the purchased movies 720 could include an entire movie file, or could include license information that authorizes the user to stream a movie on-demand. Stored movies 725 include movies the user owns and which have been put into electronic format, such as movies recorded from a digital video disc (DVD). eBooks 730 include books for the Apple iPad, books for the Kindle Fire, and books for the Barnes & Noble Nook. Of course, eBooks 730 could include books in any suitable electronic format.


Software 735 includes software licensed to the user and/or to the user's devices. In the most preferred implementation, software is licensed to the user and not to any particular device, which makes the software available to the user on any device capable of running the software. However, software 735 may also include software licensed to a user for use on only one device, as discussed in more detail below. Software 735 may include operating system software, software applications, apps, or any other software capable of running on any device. In addition, software 735 may include a backup of all software stored on all devices used by the user. Games 740 include any suitable electronic games, including games for computer systems and any suitable gaming system. Known gaming systems include Sony Playstation, Microsoft Xbox, Nintendo Wii, and others. Games 740 may include any games for any platform, whether currently known or developed in the future. Sheet music 745 includes sheet music that has been purchased by a user and is in electronic form. This may include sheet music files that are downloaded as well as hard copy sheet music that has been scanned. Some pianos now include an electronic display screen that is capable of displaying documents such as sheet music files. If a user owns such a piano, the user could access via the piano all of the user's stored sheet music 745 in the user's U-Me account. Purchased images 750 include any images purchased by the user, including clip art, pictures, etc. Online subscriptions 755 include content generated by the user on a subscription basis by any suitable provider. For example, if a user subscribes to Time magazine online, the online subscriptions 755 could include electronic copies of Time magazine.



FIG. 8 shows some specific examples of user settings 140 that could be stored in a user's U-Me account, including universal interface settings 810, phone settings 815, tablet settings 820, laptop settings 825, desktop settings 830, television settings 835, software settings 840, vehicle settings 845, home automation settings 850, gaming system settings 855, audio system settings 860, security system settings 865, user authentication settings 870, and other settings 875. The user settings shown in FIG. 8 are examples shown for the purpose of illustration. The software settings 840, which include user settings for software applications, include user preferences for each software application. Note the term “software application” is used herein to broadly encompass any software the user can use, whether it is operating system software, an application for a desktop, an app for a phone, or any other type of software. User settings for physical devices include user settings for each physical device. The term “physical device” is used herein to broadly any tangible device, whether currently known or developed in the future, that includes any combination of hardware and software. The disclosure and claims herein extend to any suitable user settings, including user settings known today as well as user settings developed in the future.


Universal interface settings 810 include settings for a universal interface for the U-Me system that can be presented to a user on any suitable device, which allows the user to interact with the U-Me system using that device. Phone settings 815 include settings for the user's phone, such as a smart phone. Apple iPhone and Samsung Galaxy S4 are examples of known smart phones. Tablet settings 820 include settings for the user's tablet computer. Examples of known tablet computers include the Apple iPad, Amazon Kindle, Barnes & Noble Nook, Samsung Galaxy Tab, and many others. Laptop settings 825 are settings for a laptop computer. Desktop settings 830 are settings for a desktop computer. Television settings 835 are settings for any suitable television device. For example, television settings 835 could include settings for a television, for a cable set-top box, for a satellite digital video recorder (DVR), for a remote control, and for many other television devices. Software settings 840 include settings specific to software used by the user. Examples of software settings include the configuration of a customizable menu bar on a graphics program such as Microsoft Visio; bookmarks in Google Chrome or favorites in Internet Explorer; default file directory for a word processor such as Microsoft Word; etc. Software settings 840 may include any suitable settings for software that may be defined or configured by a user.


Vehicle settings 845 include user settings relating to a vehicle, including such things as position of seats, position of mirrors, position of the steering wheel, radio presets, heat/cool settings, music playlists, and video playlists. Home automation settings 850 include settings for a home automation system, and may include settings for appliances, heating/ventilation/air conditioning (HVAC), lights, security, home theater, etc. Gaming system settings 855 include settings relating to any gaming system. Audio system settings 860 include settings for any suitable audio system, including a vehicle audio system, a home theater system, a handheld audio player, etc. The security system settings 865 may include settings for any suitable security system. User authentication settings 870 include settings related to the user's authentication to the U-Me system.


The U-Me system makes a user's data, licensed content, and settings available to the user on any device the user desires to use. This is a significant advantage for many reasons. First of all, even for people who are comfortable with technology, getting a device configured exactly as the user wants is time-consuming and often requires research to figure out how to configure the device. For example, let's assume a user installs the Google Chrome browser on a desktop computer. When the user downloads a file using Google Chrome, the downloaded file appears as a clickable icon on the lower left of the Google Chrome display. To open the file, the user clicks on the icon. Let's assume the user wants to always open .pdf files after they are downloaded. Because the user does not know how to configure Chrome to do this, the user does a quick search, and discovers that Chrome can be configured to always open .pdf files after they are downloaded by clicking on a down arrow next to the downloaded .pdf file icon, which brings up a pop-up menu, then selecting “Always open files of this type.” This configures Google Chrome to always open .pdf files after they are downloaded. However, the user cannot be expected to remember this small tidbit of knowledge. If the user made this setting change to Google Chrome when the desktop computer was new, and two years passes when the user gets a new desktop computer, it is highly unlikely the user will remember how to configure Google Chrome to automatically open .pdf files after they are downloaded. In any modern device, there are dozens or perhaps hundreds of such user settings. By storing these user settings in the user's U-Me account, the user will not have to remember each and every setting the user makes in each and every device. The same is true for configuring a smart phone. Often users have to search online to figure out how to do certain things, such as setting different ringtones for different contacts. In today's world, such settings are lost when a user changes to a different phone, which requires the user repeat the learning process to configure the new phone. With the U-Me system disclosed herein, all of the user's settings are saved to the user's U-Me account, allowing a new device to be easily configured using the stored user settings.


While the previous paragraph discusses an example of a user setting in Google Chrome, similar concepts apply to user data and user licensed content. There is currently no known way to make all of a user's data, licensed content, and settings available in the cloud so this information is available to the user on any device or system the user decides to use. The Universal Me system solves this problem. The system is called Universal Me because it “allows me to be me, anywhere” for each user. Thus, a user on vacation on Italy could find an Internet café, use a computer in the Internet café to access the user's universal interface to the U-Me system, and would then have access to all of the user's data, licensed content, and settings. Similarly, the user could borrow an iPad from a friend, and have access to all the user's data, licensed content, and settings. The power and flexibility of the U-Me system leads to its usage in many different scenarios, several of which are described in detail below.


While many different categories of user settings are shown in FIG. 8, these are shown by way of example. A benefit of the U-Me system is that a user only has to configure a device once, and the configuration for that device is stored in the user's U-Me account. Replacing a device that is lost, stolen, or broken is a simple matter of buying a new similar device, then following the instructions provided by the U-Me system to configure the new device to be identical to the old device. In the most preferred implementation, the U-Me system will back up all user data, licensed content, and settings related to the device to the user's U-Me account, which will allow the U-Me system to configure the new device automatically with minimal input from the user. However, features of the devices themselves may prevent copying all the relevant data, licensed content and settings to the user's U-Me account. When this is the case, the U-Me system will provide instructions to the user regarding what steps the user needs to take before the U-Me system can configure the device with the information stored in the user's U-Me account.


The U-Me system could use various templates that define settings for different physical devices. Referring to FIG. 9, universal templates 152 include phone templates 910, tablet templates 915, laptop templates 920, desktop templates 925, television templates 930, software templates 935, vehicle templates 940, home automation templates 945, gaming system templates 950, audio system templates 955, security system templates 960, eReceipt templates 965, medical information templates 970, and other templates 975. The universal templates shown in FIG. 9 are examples shown for the purpose of illustration. The disclosure and claims herein extend to any suitable universal templates, including universal templates related to devices known today as well as universal templates related to devices developed in the future.


The various universal templates in FIG. 9 include categories of devices that may include user settings. One of the benefits of the U-Me system is the ability for a user to store settings for any device or type of device that requires configuration by the user. This allows a user to spend time once to configure a device or type of device, and the stored settings in the user's U-Me account will allow automatically configuring identical or similar devices. The U-Me system expressly extends to storing any suitable user data and/or user licensed content and/or user settings for any suitable device in a user's U-Me account.


The universal templates 152 provide a platform-independent way of defining settings for a particular type of device. Thus, a universal phone template may be defined by a user using the U-Me system without regard to which particular phone the user currently has or plans to acquire. Because the universal templates are platform-independent, they may include settings that do not directly map to a specific physical device. Note, however, the universal templates may include information uploaded from one or more physical devices. The universal template can thus become a superset of user data, user licensed content, and user settings for multiple devices. The universal templates can also include settings that do not correspond to a particular setting on a particular device.


Referring to FIG. 10, device-specific templates 154 include phone templates 1005, tablet templates 1010, laptop templates 1015, desktop templates 1020, television templates 1025, software templates 1030, vehicle templates 1035, home automation templates 1040, gaming system templates 1045, audio system templates 1050, security system templates 1055, and other templates 1060. The device-specific templates shown in FIG. 10 are examples shown for the purpose of illustration. The disclosure and claims herein extend to any suitable device-specific templates, including device-specific templates for devices known today as well as device-specific templates for devices developed in the future.


The device-specific templates 154 provide platform-dependent templates. Thus, the user data, user licensed content, and user settings represented in a device-specific template includes specific items on a specific device or device type. The device-specific templates 154 may also include mapping information to map settings in a physical device to settings in a universal template. FIGS. 11-21 are related to device specific templates 154. Referring to FIG. 11, phone templates 1005 may include iPhone templates 1110, Android templates 1120 and Windows phone templates 1130, which represent different phone types. Phone templates 1005 may also include templates for a specific phone, such as iPhone 4 template 1140 and Samsung Galaxy S3 template 1150, as well as one or more other phone templates 1160 that may be for a phone type or for a specific phone.


Tablet templates 1010 are shown in FIG. 12 to include iPad templates 1210 and Nook templates 1220, which represent different tablet platforms. Tablet templates 1010 may also include templates for a specific tablet, such as a Kindle Fire HD template 1230 and an iPad mini 2 template 1240, as well as one or more other tablet templates 1250 that may be for a tablet type or for a specific tablet.


Laptop templates 1015 are shown in FIG. 13 to include Lenovo laptop templates 1310 and MacBook templates 1320, which represent different laptop computer types. Laptop templates 1015 may also include templates for a specific laptop, such as a Samsung Chromebook template 1330 and an HP Envy template 1340, as well as one or more other laptop templates 1350 that may be for a laptop type or for a specific laptop.


Desktop templates 1020 are shown in FIG. 14 to include HP desktop templates 1410 and Dell desktop templates 1420, which represent different laptop computer types. Desktop templates 1020 may also include templates for a specific desktop computer, such as an HP Pavilion PS-2355 desktop template 1430 and an Asus M11BB-B05 desktop template 1440, as well as one or more other desktop templates 1450 that may be for a desktop type or for a specific desktop computer.


Television templates 1025 are shown in FIG. 15 to include a Sony TV template 1510 and a satellite TV template 1520, which represent different types of television devices. Television templates 1025 may also include templates for a specific television device, such as a Mitsubishi WD-60638 template 1530, a Dish Network Hopper DVR template 1540, and an RCA RCU1010 remote template 1540, as well as one or more other television device templates 1560 that may be for a television device type or for a specific television-related device.


Software templates 1030 are shown in FIG. 16 to include a word processor template 1610 and an e-mail template 1620, which represent different types of software. Software templates 1030 may also include templates for specific software, such as a Microsoft Word template 1630 and a Google Chrome template 1640, as well as one or more other software templates 1650 that may be for a type of software or for specific software.


Vehicle templates 1035 are shown in FIG. 17 to include a Chevrolet template 1710 and a Toyota template 1720, which represent different types of vehicles. Vehicle templates 1035 may also include templates for specific vehicles, such as a Honda Civic LX template 1730 or a Ford F150 XLT template 1740, as well as one or more other vehicle templates 1750 that may be for a type of vehicle or for a specific vehicle. Note while the only vehicles shown in FIG. 17 are cars and a small truck, the vehicle templates 1035 could include templates for any type of vehicle, including cars, trucks, boats, large semi trucks, planes, and other vehicles. The “type” of the vehicle herein can also vary, and a single vehicle can correspond to many different types. For example, a 2012 Lexus RX350 could be categorized as a passenger vehicle, as a small SUV, as a Lexus, as a Lexus passenger vehicle, as a Lexus small SUV, etc. One of the significant advantages of the U-Me system is the ability to convert settings from a vehicle of one type to a vehicle of a different type. Thus, if a user normally drives a Ford F150 XLT pickup, the user's settings for his Ford pickup can be converted to corresponding settings in a Toyota rental car. Of course, brands or manufacturers are examples of “types” as well.


Home automation templates 1040 are shown in FIG. 18 to include a refrigerator template 1810, an HVAC template 1820, and an energy usage template 1830, which represent different things that may be controlled by a home automation system. Home automation templates 1040 may also include templates for specific home automation systems, such as Home Automation Inc. (HAI) Omni template 1840, Samsung refrigerator template 1850, lighting template 1860, as well as one or more other home automation templates 1870 that may be for a type of home automation controller or type of item controlled by a home automation controller or for a specific home automation controller or item controlled by a home automation controller.


Gaming system templates 1045 are shown in FIG. 19 to include Xbox templates 1910 and Playstation templates, which represent different types of gaming systems. Gaming templates 1045 may also include templates for specific gaming systems, such as Nintendo Wii U template 1930 and Xbox 360 template 1940, as well as one or more other gaming system templates 1950 that may be for a type of gaming system or for a specific gaming system.


Audio system templates 1050 are shown in FIG. 20 to include stereo receiver templates 2010, home theater templates 2020, and vehicle audio templates 2030, which represent different types of audio systems. Audio system templates 1050 may also include templates for specific audio systems, such as Sony STR-DH130 template 2040 and Yamaha RX-V375 template 2050, as well as one or more other audio system templates 2060 that may be for a type of audio system or for a specific audio system.


Security system templates 1055 are shown in FIG. 21 to include ADT templates 2110 and FrontPoint templates 2120, which represent different types of security systems from different manufacturers. Security system templates 1055 may also include templates for specific security systems, such as a Fortress SO2-B template 2130 and a Simplisafe2 template 2140, as well as one or more other security system templates 2150 that may be for a type of security system or for a specific audio system.


While the templates disclosed herein may be of any suitable format, it is expected that industry experts will have to spend time brainstorming and meeting to arrive at an industry standard. Thus, the automotive industry may generate an industry-standard template for cars, while the personal computer industry may generate a very different industry-standard template for desktop computers. Generating and publishing standard templates will greatly accelerate the acceptance of the U-Me system.


The device-specific templates shown in FIGS. 10-21 could be provided by any suitable entity. For example, the U-Me system may provide some of the device-specific templates. However, some device-specific templates will preferably be provided by manufacturers of devices. As discussed below, the U-Me system includes the capability of device manufacturers to become “U-Me Certified”, which means their devices have been designed and certified to appropriately interact with the U-Me system. Part of the U-Me certification process for a device manufacturer could be for the manufacturer to provide a universal template for each category of devices the manufacturer produces, a device-specific template for each category of devices the manufacturer produces, as well as a device-specific template for each specific device the manufacturer produces.


Referring to FIG. 22, device interfaces 156 preferably include phone interfaces 2205, tablet interfaces 2210, laptop interfaces 2215, desktop interfaces 2220, television interfaces 2225, software interfaces 2230, vehicle interfaces 2235, home automation interfaces 2240, gaming system interfaces 2245, audio system interfaces 2250, security system interfaces 2255, and other interfaces 2260. The device interfaces shown in FIG. 22 are examples shown for the purpose of illustration. The disclosure and claims herein extend to any suitable device interfaces, including device interfaces for devices known today as well as device interfaces for devices developed in the future.


Each device interface provides the logic and intelligence to interact with a specific type of device or with a specific device. Thus, phone interfaces 2205 could include an iPhone interface and an Android interface. In addition, phone interfaces 2205 could include different interfaces for the same type of device. Thus, phone interfaces 2205 could include separate phone interfaces for an iPhone 4 and an iPhone 5. In the alternative, phone interfaces 2205 could be combined into a single phone interface that has the logic and intelligence to communicate with any phone. In the most preferred implementation, a device interface is provided for each specific device that will interact with the U-Me system. This could be a requirement for a device to become U-Me certified, that the manufacturer of the device provide the device interface that meets U-Me specifications.


The U-Me system preferably includes a universal user interface 142 shown in FIG. 5. The universal user interface 2300 shown in FIG. 23 is one suitable example of a specific implementation for the universal user interface 142 shown in FIG. 5. The universal user interface 2300 in FIG. 23 includes several icons the user may select to access various features in the U-Me system. The icons shown in FIG. 23 include a data icon 2310, a licensed content icon 2320, a software icon 2330, a settings icon 2340, a devices icon 2350, and a templates icon 2360. Selecting the data icon 2310 gives the user access to the user data 120 stored in the user's U-Me account, including the types of data shown in FIG. 6. One way for the user to access the user data 120 is via a data search engine, discussed in more detail below. Selecting the licensed content icon 2320 gives the user access to any and all of the user's licensed content 130, including the categories of licensed content shown in FIG. 7. Selecting the software icon 2330 gives the user access to software available in the user's U-Me account. While software is technically a category of licensed content (see 735 in FIG. 7), a separate icon 2330 is provided in the universal user interface 2300 in FIG. 23 because most users would not mentally know to select the licensed content icon 2320 to run software. Selecting the software icon 2330 results in a display of the various software applications available in the user's U-Me account. The user may then select one of the software applications to run. The display of software icons could be considered a “virtual desktop” that is available anywhere via a browser or other suitable interface.


Selecting the settings icon 2340 gives the user access to any and all of the user settings 140, including the categories of settings shown in FIG. 8. Selecting the devices icon 2350 gives the user access to virtual devices, where the virtual devices correspond to a physical device used by the user. The user will also have access to the device interfaces 156, including the device interfaces shown in FIG. 22. Accessing devices via the device interfaces allows the user to have remote control via the universal user interface over different physical devices. Selecting the templates icon 2360 gives the user access to the templates in the user's U-Me account, including: universal templates, including the universal templates shown in FIG. 9; and device-specific templates, including the device-specific templates shown in FIGS. 10-21. The devices icon 2350 and the templates icon 2360 provide access to information in the user's U-Me account pertaining to devices and templates, which can be part of the settings in the user's U-Me account. While the Devices icon 2350 and Templates icon 2360 could be displayed as a result of a user selecting the Setting icon 2240, these icons 2350 and 2360 that are separate from the settings icon 2340 are provided in FIG. 23 to make using the universal user interface 2300 more intuitive for the user.


The universal user interface gives the user great flexibility in accessing a user's U-Me account. In the most preferred implementation, the universal user interface is browser-based, which means it can be accessed on any device that has a web browser. Of course, other configurations for the universal user interface are also possible, and are within the scope of the disclosure and claims herein. For example, a user on vacation in a foreign country can go into an Internet café, invoke the login page for the U-Me system, log in, and select an icon that causes the universal user interface (e.g., 2300 in FIG. 23) to be displayed. The user then has access to any and all information stored in the user's U-Me account.


Because the universal user interface allows a user to access the user's U-Me account on any device, the universal user interface also provides a way for a user to change settings on the user's devices. Because the user's U-Me account includes virtual devices that mirror the configuration of their physical device counterparts, the user could use a laptop or desktop computer to define the settings for the user's phone. This can be a significant advantage, particularly for those who don't see well or who are not dexterous enough to use the tiny keypads on a phone. A simple example will illustrate. Let's assume a U-Me user wants to assign a specific ringtone to her husband's contact info in her phone. The user could sit down at a desktop computer, access the universal user interface 2300, select the Devices icon 2350, select a Phone icon, which then gives the user access to all of the settings in the phone. The user can then navigate a menu displayed on a desktop computer system using a mouse and full-sized keyboard to change settings on the phone instead of touching tiny links and typing on a tiny keyboard provided by the phone. The user could assign the ringtone to her husband's contact info in the settings in the virtual device in the U-Me account that corresponds to her phone. Once she makes the change in the virtual phone settings in the U-Me account, this change will be automatically propagated to her phone. The universal user interface may thus provide access to the user to set or change the settings for all of the user's physical devices.


The universal user interface 142 can include any suitable interface type. In fact, the universal user interface 142 can provide different levels of interfaces depending on preferences set by the user. Thus, the universal user interface may provide simple, intermediate, and power interfaces that vary in how the information is presented to the user depending on the user's preferences, which could reflect the technical prowess and capability of the user. Those who are the least comfortable with technology could select a simple interface, which could provide wizards and lots of help context to help a user accomplish a desired task. Those more comfortable with technology could select the intermediate interface, which provides fewer wizards and less help, but allows a user to more directly interact with and control the U-Me system. And those who are very technically-oriented can select the power interface, which provides few wizards or help, but allows the user to directly interact with and control many aspects of the U-Me system in a powerful way.


There are many different ways to program a device using the information in the user's U-Me account. Referring to FIG. 24, a method 2400 for programming a device called Device2 begins by determining settings for Device2 (step 2410), then programming the device with those settings (step 2420). There are different ways to determine the settings for Device2 in step 2410. Referring to FIG. 25, method 2500 shows one suitable implementation for step 2410 in FIG. 24. Settings for a device called Device1 are read (step 2510). A mapping from Device1 to Device2 is then read (step 2520). The settings for Device1 are then converted to the settings for Device2 (step 2530). This is shown graphically in FIG. 26, where the Device1 settings 2610 are converted using the Device1 to Device2 mapping 2620 to Device2 settings 2630. This first example in FIGS. 25 and 26 show how to program a device by converting settings from one device to settings for a different device. For example, let's assume a user has been using an iPhone 4, then decides to change to a Samsung Galaxy S4 phone. Assuming there are device-specific templates 154 for both phones, the conversion mechanism 160 in FIG. 5 can convert the settings on the iPhone 4 to settings on the Samsung Galaxy S4, provided there is a mapping in the phone templates between the device-specific settings of the two devices. The example in FIGS. 25 and 26 shows how to program a device by converting from settings of a different device.


A second suitable implementation for step 2410 in FIG. 24 is shown in FIGS. 27 and 28. In this implementation, Device2 is programmed from settings stored in the Universal Template corresponding to Device2. The universal template settings are read (step 2710). A mapping from the universal template to Device 2 is read (step 2720). The conversion mechanism then converts the settings from the universal template to the settings for Device2 (step 2730). This is shown graphically in FIG. 28, where universal template settings 2810 are converted using the universal template to Device2 mapping 2820 to generate Device2 settings 2630. This second implementation in FIGS. 27 and 28 vary from the first implementation in steps 25 and 26 because the conversion of settings is between the universal template settings to the Device2 settings, not from the settings of another device (such as Device1).


A third suitable implementation for step 2410 in FIG. 24 is shown in FIGS. 29 and 30. Device1 settings are read (step 2910). A mapping from Device1 to the universal template is also read (step 2920). The Device1 settings are then converted to the universal template settings (step 2930). A mapping from the universal template to Device2 is then read (step 2940). The universal template settings are then converted to Device 2 settings (step 2950). This is shown graphically in FIG. 30, where the Device1 settings are converted using the Device1 to universal template mapping 3020 to universal template settings 3030, which are then converted using the universal template to Device2 mapping 3040 to Device2 settings 3050. This third implementation converts settings between two devices, similar to the first implementation shown in FIGS. 25 and 26, but this is not a direct mapping between two devices, but is rather a mapping to and from universal template settings.


Note the examples in FIGS. 25-30 allow converting settings from one device to corresponding settings for a different device. The different device may be of the same type or may be of a different type. Type can be defined according to hardware platform, operating system, manufacturer, brand, or any other characteristic that characterizes a device. Thus, an iPhone and a Samsung Galaxy phone are devices of different types because they have a different hardware architecture type and run different system software. A Chevrolet and a Toyota are devices of different types because they are made by different manufacturers. An iPhone 4 and iPhone5 could be categorized as devices of the same type because they have the same hardware architecture type and run the same system software, even if the version of the system software is not the exact same. The disclosure and claims herein extends to any suitable definition or categorization for the “type” of a device. The conversion mechanism disclosed and claimed herein allows converting settings between devices of the same type, between devices of similar type, and also between devices of different types. For example, devices may be of the same type when they have the same hardware architecture type and run the same system software. Devices may be of similar type when they have the same hardware architecture type and run different system software. Devices may be of different types when they have different hardware architecture type and different system software.


We now consider one specific usage of the U-Me system with regards to television equipment with respect to FIGS. 31-37. We assume a user's television settings are store in the user's U-Me account. Examples of suitable television settings 835 are shown in FIG. 32 to include one or more favorite channels list 3210, shows set to record 3220, blocked channels 3230, parental controls 3240, channel numbers for stations 3250, and one or more passwords 3260. These are all settings the user can define, for example, in a DVR for Dish Network. For this specific example, we assume the user has Dish Network at the user's home, and programs the Dish Network DVR with some or all of the user television settings 835 shown in FIG. 32. We now assume the user travels to a new location during a vacation, such as a hotel room, a resort, a relative's house, etc., and we further assume the new location has DirecTV. Referring to FIG. 33, method 3300 begins by detecting the target system (at the new location) is a DirecTV system (step 3310). The user's Dish Network television settings are converted to equivalent or similar DirecTV settings in the user's U-Me account (step 3320). The converted DirecTV settings from the user's U-Me account are then downloaded to the DirecTV target system (e.g., DVR) at the new location (step 3330). The result is the user's Dish Network television settings are now available on the DirecTV DVR. One part of the conversion in step 3320 is converting the channel numbers from Dish Network to the equivalent channel numbers in DirecTV. A sample mapping for ten channels is shown at 3100 in FIG. 31. Note the channels ABC, NBC, CBS and Fox in the mapping 3100 show “local” instead of a number, because the channel numbers will vary from one geographic region to the next. The indication of “local” in the channel mapping will indicate a need to determine the location of the target system, and determining the appropriate mapping to the target system using the channel numbers that are specific to the geographic region where the target system is located. This is a task easily accomplished by the U-Me system.


Note that known DVRs for Dish Network and DirecTV do not allow downloading settings as discussed above with respect to method 3300 in FIG. 33. For television providers to work in conjunction with the U-Me system, each provider's DVR will need to be “U-Me Certified”, meaning the DVR includes logic and intelligence that allows the DVR to interact with the U-Me system. This certification process will also preferably provide a device-specific template for each DVR, along with information that allows mapping the settings from one provider to another provider. In the most preferred implementation, a universal template for a DVR could be defined with required fields, and each device-specific template for each DVR will have to have the required fields specified in the universal DVR template.


Referring to FIG. 34, one suitable example of a television receiver 3400 is shown to include one or more processors 3410, a memory 3420, one or more television receivers 3450A, . . . , 3450N that receive input from a TV signal input 3460, which receives a TV signal from a TV signal source, a TV signal output 3470 that is output to a television, a network connection 3480, and an external device interface 3490 that allows transferring user settings to and from an external device 3492. The memory 3420 preferably includes system code 3422, system settings 3424, user settings 3426, a user settings transfer mechanism 3430, and recorded shows 3440 (assuming the television received 3400 is a digital video recorder (DVR)). System code 3422 includes code executed by the one or more processors 3410 to make the television receiver 3400 function. System settings 3424 are settings that are required for the system to function correctly. For example, when the television receiver 3400 is a satellite television receiver, the system settings 3424 could include all system information required for the receiver to connect to one or more satellites. While this information may be entered by a human installer, these are different than “user settings” because the system settings are the settings needed for the television receiver 3400 to function properly. The user settings 3426, in contrast, are settings such as those configured by the end user (e.g., satellite TV subscriber) that specify preferences the user can set on the receiver 3400. Examples of suitable user television settings are shown in FIG. 32. While the channel numbers for stations 3250 are typically defined by the system and not by the user, they may be included in user television settings 835 so suitable translation of channel numbers can be performed, as described above.


The user settings transfer mechanism 3430 includes a user settings external write mechanism 3432, a user settings external read mechanism 3434, and a user settings conversion mechanism 3436. The user settings external write mechanism 3432 allows writing the user settings 3426, and possibly some of the system settings 3424, to an external device, such as external device 3492 coupled to external device interface 3490. The user settings written to the external device 3492 are represented in FIG. 34 as user settings 3494. The user settings external read mechanism 3434 allows reading user settings from an external device, such as reading user settings 3494 from external device 3492. The user settings external write mechanism 3432 thus writes user settings 3426 to the user settings 3494 in the external device 3492, while the user settings external read mechanism 3434 reads user settings 3494 from the external device 3492. Note the external device 3492 could be any device capable of storing the user settings 3494. For example, a thumb drive with a uniform serial bus (USB) interface is one suitable example of an external device 3492, which can be used by plugging the thumb drive into a suitable USB port on the television receiver 3400. Such a USB port is one suitable example for the external device interface 3490. Once plugged into the USB port, the television receiver 3400 could read user settings 3494 from the thumb drive or could write user settings 3494 to the thumb drive. Another suitable example of an external device 3492 is a smart phone that could be coupled to the television receiver in any suitable way, including via a Wi-Fi connection to the network connection 3480, via a Bluetooth interface (one specific implementation for external device interface 3490), or via a direct cable-type connection (e.g., USB) to a USB port, which is another suitable implementation of the external device interface 3490. Yet another suitable example of an external device 3492 is the U-Me system that could be accessed via the network connection 3480. The disclosure and claims herein expressly extend to any suitable external device capable of storing user settings, whether currently known or developed in the future, which can communicate with the television receiver 3400 in any suitable way, whether currently known or developed in the future.


The user settings conversion mechanism 3436 includes logic to convert user settings from one type of television receiver to another. This logic can include direct conversion between device settings, conversion to and from a universal template, and conversion from one device to a universal template followed by conversion from the universal template to the second device, as discussed in detail above with respect to FIGS. 24-30.


A simple example will illustrate. When the user settings 3494 in the external device 3492 are DirecTV settings, and the television receiver 3400 is a Dish Network receiver, the DirecTV settings could be read by the user settings external read mechanism 3434, and could then be converted to equivalent Dish Network user settings by the user settings conversion mechanism 3436. The converted settings may then be written to the user settings 3426, thereby programming the Dish Network receiver with settings similar to those used on the DirecTV system, represented by the user settings 3494. Note the user settings conversion mechanism 3436 could include the logic to convert in both directions, both from the television receiver 3400 to one or more different receivers, and from one or more different receivers to the television receiver 3400. For example, if the user has Dish Network but is going to his parent's cabin, which has DirecTV, the user could specify to convert the user settings in the Dish Network receiver to equivalent DirecTV settings, which could then be written to a thumb drive. Because the settings on the thumb drive are then DirecTV settings, the user could the plug the thumb drive into a USB port on the DirecTV receiver at his parents' cabin, and the DirecTV receiver could then program itself from those settings on the thumb drive.


The ability to store user settings external to the television receiver is a great advantage in many different scenarios. One such scenario is when a user upgrades to a new television receiver. For example, let's assume a Dish Network customer decides to upgrade from his current DVR that can record two channels at a time to a newer DVR that can record four channels at a time. There is currently no known way to transfer settings between the old DVR and the new DVR. The user is stuck with having to manually enter all the user settings, including those shown in FIG. 32, which can take a long time to do. With the ability to store user settings to an external device as disclosed herein, the user could store the user's settings from the old DVR to the external device, and the new DVR could then read those settings. If any conversion is needed between the old settings and the new settings, this can be handled by the user settings conversion mechanism 3436. The result is that most or all of the user's settings are available on the new DVR, thus greatly enhancing the ease and convenience of upgrading to a newer DVR. Another scenario is described above, where a user wants to take his settings with him to program his parents' DVR at their cabin. Another scenario is when a user wants to program a DVR at a hotel or vacation rental. The ability to store user settings external to the television receiver thus provides a very powerful tool that enhances the convenience of the user.


Referring to FIG. 35, a method 3500 represents one suitable method that could be performed by the television receiver 3400 in FIG. 34. The settings for Device1 are read (step 3510). These settings are then stored to an external device (step 3520). Method 3500 in FIG. 35 could be performed, by example, by the user settings external write mechanism 3432.


Referring to FIG. 36, a method 3600 represents one suitable method that could be performed by the television receiver 3400 in FIG. 34. The settings for Device1 are read from the external device (step 3610). When Device2 is the same type as Device1 (step 3620=YES), Device 2 is programmed with the settings for Device1 (step 3630). When Device2 is not the same type as Device1 (step 3620=NO), the settings for Device2 are determined from the settings for Device1 (step 3640), and Device2 is then programmed with the Device2 settings (step 3650). The settings are read from the external device in step 3610, for example, by the user settings external read mechanism 3434, while determining the settings for Device2 from the settings for Device1 could be performed, for example, by the user settings conversion mechanism 3436. Note the user settings conversion mechanism 3436 could convert the settings in any suitable way, including the ways discussed in detail above with reference to FIGS. 24-30.


The specific implementation shown in FIG. 34 shows the user settings conversion mechanism 3436 residing in the memory 3420 of a television receiver 3400. Note the function of the user settings conversion mechanism 3436 in FIG. 34 could additionally be performed or could alternatively be performed by the conversion mechanism 160 in the U-Me system 100 shown in FIG. 5. In this scenario, the user settings external write mechanism 3432 would write the user settings 3426 to the U-Me system, which could then convert those settings to corresponding settings for a second device. The settings for the second device could then be read from the U-Me system by a user settings external read mechanism in the second device, which can then be programmed with those settings.


In some situations, a user's settings might only be needed for a defined period of time, such as a temporary stay in a hotel or rental condo. In such a scenario it would be desirable to be able to clear out the user's settings once the user's stay is over. Method 3700 in FIG. 37 shows one suitable method for doing this. Default settings are defined for a television receiver Device1 (step 3710). Default settings can be any suitable set of user settings, which could include a lack of settings as when Device1 was new, or any set of user settings the hotel manager or condo owner may want to define. The programming of Device1 with external user settings is enabled (step 3720). This could be done, for example, by the hotel manager or condo owner sending a signal to Device1 that allows the user to program Device1 with his or her settings stored on an external device, such as the U-Me system, a thumb drive, a smart phone, etc. The user then programs Device1 with the user's settings read from the external device (step 3730). The user can then use Device1 with the user's settings. As long as the user's stay is not over (step 3740=NO), the user can continue to use Device1 with the user's settings. Once the user's stay is over (step 3740=YES), Device1 is programmed with its default settings (step 3750), thereby removing all of the user's settings that were previously programmed in step 3730. Note that restoring the device to its default settings can include erasing any shows the user recorded. This can be beneficial in assuring Device1 is in a default state for each guest. Thus, if one guest records horror movies on Device1, once the user checks out, Device1 will be returned to its default state, which will include erasing the horror movies the previous user recorded. This will prevent the next user (such as a family with kids) from seeing the horror movies on Device1 that were recorded by the previous user. Note the determination the user's stay is over in step 3740 can be made in any suitable way. For example, the user could enter into the DVR the date the user is checking out, and the DVR could then reset itself on that date at the appropriate checkout time. In the alternative, the hotel manager or condo owner could send a message to the DVR that instructs the DVR to reset itself to the default settings. Another option is for the hotel manager or condo owner to use a privileged mode in the DVR to define the time period when the user will be staying. Of course, other options are also possible. The disclosure and claims herein expressly extend to any suitable way to allow a user to program the user's settings to a device, followed by the device being reset to its default settings at some later time.


The figures and disclosure herein support a computer system comprising: at least one processor; a memory coupled to the at least one processor; first user settings corresponding to a user for a first device; a conversion mechanism executed by the at least one processor, the conversion mechanism converting the first user settings for the first device to corresponding second user settings for the user for a second device; and a software mechanism executed by the at least one processor that downloads the second user settings to the second device.


The figures and disclosure herein also support a computer-implemented method executing on at least one processor comprising: storing first user settings corresponding to a user for a first device; converting the first user settings for the first device to corresponding second user settings for the user for a second device; and downloading the second user settings to the second device.


The figures and disclosure herein further support an apparatus comprising: at least one processor; a memory coupled to the at least one processor, the memory comprising a first plurality of user television settings defined by a user; a television signal input for receiving a television signal from a television signal source; a television signal output for sending a television signal to a television; and a user settings transfer mechanism residing in the memory and executed by the at least one processor that reads a second plurality of user television settings from an external device coupled to the apparatus and programs at least one of the first plurality of user television settings based on at least one of the second plurality of user television settings.


While the implementation envisioned herein has the majority of storage for the user's information in the cloud, this cloud-based implementation may not be the ultimate end game. As technology advances, a handheld device like a smart phone could eventually have the capability of storing all of a user's information and could have sufficient computing capacity to perform all needed processing. Thus, the apparatus 300 shown in FIG. 3 could be representative of a handheld device, with the Universal Me system 100 running on the handheld device. In this scenario, when a user wants to program a television receiver or other device with the user's settings, the Universal Me app running on the user's smart phone could perform any needed conversion between different device types, and could download the settings to device via the smart phone's local interface (e.g., Bluetooth). As shown by this simple example, when the storage and computing capacity of smart phones becomes sufficiently large, most of the processing in the Universal Me system could be performed on the smart phone. The cloud would continue to be used for backup and for virtual devices, but much of the user's information could be stored on the user's smart phone, which could then be used to perform the many functions discussed herein without accessing the user's U-Me account in the cloud.


One of the long-term goals of the U-Me system is to create a place for all of a user's data, licensed content and settings. This includes settings for devices we have not yet dreamed of. The philosophy is very simple. If the user is going to spend time configuring any device to the user's liking by specifying settings for the device, let's store those settings in the user's U-Me account so those settings can be used to reconfigure an identical or similar device, or so those settings can be used to generate suitable settings for a different kind of device. Thus, if a person spends hours configuring a computerized sewing machine to perform certain functions by specifying many different settings for the sewing machine, let's store those settings to the user's U-Me account. This philosophy can extend to any and all devices known today and developed in the future.


It will take time for the U-Me system to be deployed and to gain acceptance in the marketplace. It will take even longer to get device manufacturers and licensed content providers on-board to the point they are providing devices and content that are U-Me certified. It may take even longer to realize the vision of having a user's data, licensed content, and settings available in cars, hotel rooms and resorts. The certification process is another possible revenue stream for the company providing the U-Me system. There will come a point when the U-Me system achieves critical mass, where the public demands compatibility with the U-Me system. At that point, even the most reluctant vendors will have to become U-Me certified to meet the demands of their customers.


The specification herein uses different terms for phones, including cell phones, smart phones, and just “phones.” These are all examples of different mobile phones. The disclosure and claims herein expressly extend to any and all mobile phones, whether currently known or developed in the future.


The specification herein discusses different types of computing devices, including smart phones, tablets, laptop computers, and desktop computers. The term “computer system” as used herein can extend to any or all of these devices, as well as other devices, whether currently known or developed in the future. In one specific context, a computer system is a laptop or desktop computer system, which is a different type than a phone or a tablet.


The disclosure herein uses some shortened terms for the sake of simplicity. For example, the word “information” is shortened in many instances to “info”, the word “photograph” is shortened in many instances to “photo”, the word “specifications” is shortened in some instances to “specs”, and the word “medications” is shortened in some instances to “meds.” Other shortened or colloquial terms may appear in the specification and drawings, which will be understood by those of ordinary skill in the art.


Many trademarks and service marks have been referenced in this patent application. Applicant has filed US federal service mark applications for “Universal Me” and for “U-Me”. All other trademarks and service marks herein are the property of their respective owners, and applicant claims no rights in these other marks.


One skilled in the art will appreciate that many variations are possible within the scope of the claims. Thus, while the disclosure is particularly shown and described above, it will be understood by those skilled in the art that these and other changes in form and details may be made therein without departing from the spirit and scope of the claims. For example, while the specific examples in the figures and discussed above relate to a television receiver device, the principles herein apply equally to any type of device that has user settings, whether currently known or developed in the future.

Claims
  • 1. A computer system comprising: at least one processor;a memory coupled to the at least one processor;first user settings corresponding to a user for a first device;a conversion mechanism executed by the at least one processor, the conversion mechanism converting the first user settings for the first device to corresponding second user settings for the user for a second device; anda software mechanism executed by the at least one processor that downloads the second user settings to the second device.
  • 2. The computer system of claim 1 wherein the first device comprises a first television receiver device and the second device comprises a second television receiver device.
  • 3. The computer system of claim 2 wherein the first user settings for the first television receiver device and the second user settings for the second television receiver device comprise shows set to record.
  • 4. The computer system of claim 2 wherein the first user settings for the first television receiver device and the second user settings for the second television receiver device comprise blocked channels and parental controls.
  • 5. The computer system of claim 2 wherein the first user settings for the first television receiver device and the second user settings for the second television receiver device comprise at least one favorite channels list.
  • 6. The computer system of claim 2 wherein the first user settings for the first television receiver device and the second user settings for the second television receiver device comprise at least one password.
  • 7. The computer system of claim 1 wherein the first device and the second device have the same hardware architecture type and have the same system software type.
  • 8. The computer system of claim 1 wherein the first device and the second device have different hardware architecture type and different system software type.
  • 9. A computer-implemented method executing on at least one processor comprising: storing first user settings corresponding to a user for a first device;converting the first user settings for the first device to corresponding second user settings for the user for a second device; anddownloading the second user settings to the second device.
  • 10. The method of claim 9 further comprising: configuring the second device using the second user settings.
  • 11. The method of claim 9 wherein the first device comprises a first television receiver device and the second device comprises a second television receiver device.
  • 12. The method of claim 11 wherein the first user settings for the first television receiver device and the second user settings for the second television receiver device comprise shows set to record.
  • 13. The method of claim 11 wherein the first user settings for the first television receiver device and the second user settings for the second television receiver device comprise blocked channels and parental controls.
  • 14. The method of claim 11 wherein the first user settings for the first television receiver device and the second user settings for the second television receiver device comprise at least one favorite channels list.
  • 15. The method of claim 11 wherein the first user settings for the first television receiver device and the second user settings for the second television receiver device comprise at least one password.
  • 16. The method of claim 9 wherein the first device and the second device have the same hardware architecture type and have the same system software type.
  • 17. The method of claim 9 wherein the first device and the second device have different hardware architecture type and different system software type.
  • 18. An apparatus comprising: at least one processor;a memory coupled to the at least one processor, the memory comprising a first plurality of user television settings defined by a user;a television signal input for receiving a television signal from a television signal source;a television signal output for sending a television signal to a television; anda user settings transfer mechanism residing in the memory and executed by the at least one processor that reads a second plurality of user television settings from an external device coupled to the apparatus and programs at least one of the first plurality of user television settings based on at least one of the second plurality of user television settings.
  • 19. The apparatus of claim 18 wherein the external device comprises a computer system coupled via a network connection to the apparatus.
  • 20. The apparatus of claim 18 wherein the external device comprises a removable memory coupled to the apparatus.
  • 21. The apparatus of claim 18 further comprising a conversion mechanism executed by the at least one processor, the conversion mechanism converting the second plurality of user television settings read from the external device and generates therefrom at least one of the first plurality of user television settings.
Continuation in Parts (1)
Number Date Country
Parent 14016038 Aug 2013 US
Child 14207490 US