Utilizing version vectors across server and client changes to determine device usage by type, app, and time of day

US10872064B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-10872064-B2
Application numberUS-201816178794-A
CountryUS
Kind codeB2
Filing dateNov 2, 2018
Priority dateMar 21, 2013
Publication dateDec 22, 2020
Grant dateDec 22, 2020

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

Some examples include optimizing system performance by generating a version vector that includes a plurality of attributes associated with a computing device. For instance, the plurality of attributes associated with the computing device may include a device type of the computing device. The plurality of attributes from the version vector may be analyzed to determine a usage pattern of a user of the computing device. In addition, a configuration of the computing device may be adjusted based on the usage pattern. In some cases, adjusting of the configuration of the computing device may include adjusting, based on the usage pattern, one or more of a power consumption of the computing device or a CPU running time of the computing device.

First claim

Opening claim text (preview).

What is claimed: 1. A method of optimizing system performance, the method comprising: generating a version vector corresponding to updates having occurred on a computing device, the version vector including a plurality of attributes associated with the computing device, wherein the plurality of attributes associated with the computing device include a device type of the computing device and a time of day when a user of the computing device used one or more computer applications; analyzing the plurality of attributes from the version vector to determine a usage pattern of the user of the computing device, the usage pattern comprising a preference pattern, wherein the preference pattern is determined over time based in part on the device type of the computing device and based in part on a plurality of user selections made over time for a plurality of file updates to apply to a file during a plurality of conflicts of multiple concurrent file updates to the file on the computing device and another computing device, the plurality of user selections made over time determined from respective version vector data determined for the computing device and the other computing device; and adjusting a configuration of the computing device based on the usage pattern, wherein the adjusting of the configuration of the computing device comprises: adjusting, based on the usage pattern, a CPU running time of the computing device; and based on occurrence of a subsequent conflict of multiple concurrent file updates to the file on the computing device and the other computing device, automatically selecting, based on the preference pattern determined over time, and without user intervention, a particular file update of the subsequent conflict of multiple concurrent file updates to apply to the file on the computing device and on the other computing device. 2. The method of claim 1 , wherein the version vector is generated by a decentralized operating system in a communication network. 3. The method of claim 1 , wherein the plurality of attributes associated with the computing device further include a location where the user used the computer applications. 4. The method of claim 1 , wherein the usage pattern of the user includes one or more of a type of computing device used by the user, one or more computer applications being used by the user, a time of day when the user used the computer applications, and a location where the user used the computer applications. 5. The method of claim 1 , wherein the adjusting of the configuration of the computing device further comprises compressing one or more files associated with each of a plurality of applications on a plurality of computing devices when the usage pattern indicates that the user is unlikely to use said applications on said computing devices. 6. The method of claim 1 , wherein the adjusting of the configuration of the computing device further comprises downloading low resolution images for a computer application, if the usage pattern indicates that the user uses the computer application on a mobile computing device, the mobile computing device comprising one or more of smartphones and tablets. 7. The method of claim 1 , wherein the adjusting of the configuration of the computing device further comprises, when the computing device is low on battery, prioritizing a plurality of tasks according to the usage pattern, wherein the prioritizing comprises: performing a backup process to save data and a state of a plurality of computer applications; disabling a set of the computer applications whose usage is less than a specific threshold; and notifying, to the user, when to switch to another computing device. 8. The method of claim 1 , wherein the version vector is a first version vector, and the adjusting of the configuration of the computing device includes synchronizing data between a plurality of computing devices including the computing device and the other computing device, the synchronizing comprising: generating the first version vector, the first version vector corresponding to the file updates to the file on the computing device; generating a second version vector, the second version vector corresponding to updates to the file on the other computing device of the plurality of computing devices, the second version vector including a plurality of attributes associated with the other computing device, including a device type of the other computing device and a time of day when a user of the other computing device used one or more computer applications on the other computing device; determining the preference pattern over time based in part on the first version vector and the second version vector. 9. The method of claim 1 , wherein the usage pattern is determined for a group of users. 10. The method of claim 9 , further comprising: adjusting a server based on the usage pattern, the server providing a service to the computing device. 11. The method of claim 1 , wherein the adjusting of the configuration of the computing device comprises recommending, according to the usage pattern, a computer application to be downloaded on the computing device. 12. An apparatus for optimizing system performance, the apparatus comprising: a memory; and at least one processor coupled to the memory and configured to: generate a plurality of version vectors corresponding to updates having occurred on the apparatus, the plurality of version vectors including a plurality of attributes of the apparatus, the plurality of attributes including a device type of the apparatus and a time of day when a user of the apparatus used one or more computer applications; analyze the plurality of attributes from the plurality of version vectors to determine a usage pattern of the user of the apparatus, the usage pattern comprising a preference pattern, wherein the preference pattern is determined over time based in part on the device type of the apparatus and based in part on a plurality of user selections made over time for a plurality of file updates to apply to a file during a first plurality of conflicts of multiple concurrent file updates to the file on the apparatus and on a first computing device, the plurality of user selections made over time determined from respective version vector data determined for the apparatus and the first computing device; and adjusting a configuration of the apparatus based on the usage pattern, wherein the adjusting of the configuration of the apparatus comprises: adjusting, based on the usage pattern, a CPU running time of the apparatus; and based on occurrence of a subsequent conflict of multiple concurrent file updates to the file on the apparatus and the first computing device, automatically selecting, based on the preference pattern determined over time, and without user intervention, a particular file update of the subsequent conflict of multiple concurrent file updates to apply to the file on the apparatus and on the other computing device. 13. The apparatus of claim 12 , wherein the apparatus is a personal computing device or a server connected to a communication network. 14. The apparatus of claim 12 , wherein the at least one processor is further configured to determine the usage pattern for a group of users. 15. The apparatus of claim 12 , wherein, to adjust the configuration of the apparatus, the at least one processor is configured to compress one or more files associated with each of a plurality of applications on a plurality of computing devices, when the usage pattern indicates that the user is unlikely to use said applications on said computing devices.

Assignees

Inventors

Classifications

  • Admission control; Resource allocation · CPC title

  • Tracking the activity of the user (network monitoring arrangements H04L43/00; recording of computer activity G06F11/34) · CPC title

  • Energy efficient computing, e.g. low power processors, power management or thermal management · CPC title

  • Details of conversion of file system types or formats · CPC title

  • specially adapted for file transfer, e.g. file transfer protocol [FTP] · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US10872064B2 cover?
Some examples include optimizing system performance by generating a version vector that includes a plurality of attributes associated with a computing device. For instance, the plurality of attributes associated with the computing device may include a device type of the computing device. The plurality of attributes from the version vector may be analyzed to determine a usage pattern of a user o…
Who is the assignee on this patent?
Razer Asia Pacific Pte Ltd
What technology area does this patent fall under?
Primary CPC classification G06F16/178. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Dec 22 2020 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 1 related publication on this page (citations in our corpus or others sharing the same primary CPC).