SYNCHRONIZATION OF COMPUTER PERIPHERAL EFFECTS

Information

  • Patent Application
  • 20170052909
  • Publication Number
    20170052909
  • Date Filed
    August 19, 2015
    9 years ago
  • Date Published
    February 23, 2017
    7 years ago
Abstract
Synchronization of effects across multiple devices using local, distributed control, and eliminating the need for central direction of the effects with the associated large bandwidth required. In one embodiment, each device stores data and instructions for creating its own effects. The devices periodically communicate with a host or each other to maintain synchronization, and compensate for any drift. This approach minimizes the use of bandwidth and battery power in the devices.
Description
BACKGROUND OF THE INVENTION

The present invention relates to the synchronization of lighting and other effects on computer peripheral devices.


Many devices, such as keyboards and mice, have decorative or indicator lighting. In particular, many input and control devices used for gaming have such lighting and other effects, such as vibrations. An example describing keyboard lighting effects is US Pub. No. 20150108903,


Logitech and other keyboard and peripheral makers have keyboards and other devices with cosmetic lighting effects. Razer and Corsair make keyboards with lighting effects that are customizable and can be synchronized with lighting effects on other devices, such as a mouse. It is believed that such devices use a personal computer as the synchronization source, with the PC sending out commands to each device over a wired USB connection. The PC coordinates the synchronization.


BRIEF SUMMARY OF THE INVENTION

The present invention provides the synchronization of effects across multiple devices using local, distributed control, and eliminating the need for central direction of the effects with the associated large bandwidth required. In one embodiment, each device stores data and instructions for creating its own effects. The devices periodically communicate with a host or each other to maintain synchronization, and compensate for any drift. This approach minimizes the use of bandwidth and battery power in the devices.


In one embodiment, each device initiates an identified effect in response to a start signal from a host. The device then periodically provides an indication to the host of where it is in the effect sequence. The host sends a synchronization correction message to the device when it is out of synchronization by more than a predetermined amount. The report can simply be a timer indicating the position in the effect, which is synchronized with a timer in the host. In one embodiment, the device report signal is sent only once, in the first half, or near the beginning of an effect cycle, such as ¼ or ⅓ into the effect.


In one embodiment, the user can select an effect, and select to have it synchronized with other devices. Once synchronized, the devices stay synchronized without further user input, even if the user changes the effects.


In one embodiment, the effect is displayed simultaneously on a host computer, and is separately generated on the host computer.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram of multiple synchronized devices according to an embodiment of the invention.



FIG. 2 is a timing diagram illustrating the drift and synchronizing between a host and multiple devices according to an embodiment of the invention.



FIG. 3 is a diagram of the messaging for synchronizing between a host and a device according to an embodiment of the invention.





DETAILED DESCRIPTION OF THE INVENTION


FIG. 1 is a block diagram of multiple synchronized devices according to an embodiment of the invention. A keyboard 102, mouse 104 and personal computer 106 are shown. Keyboard 102 has a lighting system 108, and mouse 104 has a lighting system 110. Additional devices with their own lighting systems, or other effects to be synchronized, can be added. For example, a game pad or game controller can also have lighting or other effects. Other input devices would include a headset, a joystick, touchpad, steering wheel, or any other computer or gaming input device. Alternately, effects systems can be placed in non-peripheral devices, such as a mousepad, a stand, or the frame or display of the host itself.


Keyboard 102 also has a vibrator 112 and a speaker 114 for providing haptic and sound effects which can be synchronized as well. A controller 116 controls the various effects systems using a program in program memory 118 and data in a data memory 120. In one embodiment, program memory 118 can be partially in firmware or ROM. A transceiver 122 allows the wireless downloading of effects, and the wireless reporting of effect timing.


Mouse 104 can similarly have a vibrator 124 and speaker 126. It also has a controller 128, data memory 130, program memory 132, transceiver 134 and antenna 136. The transceiver and antenna also allows for the downloading of synchronization effects and programs and the reporting back to personal computer 106 or to keyboard 102 of the status of the various effects.


Personal computer 106 has its own transceiver 140. Alternately, a router or hub 142 could be used to interconnect the various devices that provide the communication link. In addition, the router or hub or other device could function as the host, as well as providing the communication link.



FIG. 2 is a timing diagram illustrating the drift and synchronizing between a host and the devices according to an embodiment of the invention. FIG. 2 shows a host 202, a device A (204) and a device B (206). These could be, for example, the PC, keyboard and mouse of FIG. 1. When activated, device 204 sends a report 208 to the host indicating that it has arrived and is active. The host can then send a command 210 to the device to start the effect on the device (alternately, the device can notify the host when it is starting the effect). At the same time, the host will independently compute and run the effect itself (or start a timer for the effect period) so that it can monitor the appropriate progress in the effect on the devices. The computed effect can also be displayed on the host. Alternately, the host can simply run a timer for the effect.


Device 204 then periodically reports the effect status as indicated by commands 212, 214 and 216. In the example shown, the host determines that there is 1% drift at report 212, 2% drift at report 214 and 3% drift at report 216. In this particular example, the host is programmed to reestablish synchronization, and correct the drift, when the drift equals or exceeds 3%. Thus, the host sends a synchronization signal 218 to device 204. Device 204 continues to send reports, such as a report 220, which may indicate a 1% drift again.


In the example shown, a second device 206 is activated and sends a device arrival notification 222 to the host. The host then starts the same effect on both devices at the same time, using command 224 to device 204 and command 226 to device 206 (alternately, the same command can be broadcast to both). This is followed by the continuous reports from devices 204 and 206 as shown, with the host sending a synchronization command to device 204 and device 206 when the reports indicate that a particular device is 3% or more out of synchronization.


As can be seen in FIG. 2, Device A and Device B are different such that Device A tends to drift away from the host at a faster rate than Device B. When the device is attached, the host initiates the effect on the device and remembers the time (relative to the host) when the effect was started. The device periodically sends an event to indicate the position of the device effect. The event is sent from the device at around ⅓ of the effect period. For example, if the period of the event is 12 seconds, the event is sent 4 seconds after the beginning of the effect. The host checks the position of the effect and compares it to its local position. Once the drift has exceeded a heuristically determined percentage (usually based on what is perceptible to the user). a request is sent to the device to go “backwards” or “forwards” relative to the drift amount. The figure uses an example of 3% drift. At the end of the effect, the device slows down or jumps ahead appropriately such that it is closer in sync with the host. When Device B is attached, the effect is restarted on all the devices, and the clock is reset on the host. Synchronization between multiple devices is accomplished by syncing to the same host.


In more detail, in one embodiment, after the first device is activated, the host reads the effect parameters of the device. The host (LGS) takes the period of the effect as a reference. The host runs a timer LGSTIMER_REF with the same period. LGS sends SWControl to enable device 1. LGS can initialize its own LGSTIMER_REF with the device1 effect period counter just received. It will thus avoid large corrections on the device. At this point LGS and device1 should have both timer effects synchronized. If the device 1 period counter drifts from LGSTIMER_REF, LGS sends the drift value to device 1. The drift value is calculated this way:

















drift=Min[ Period- abs(LGSTIMER_REF- DeviceCounter) ,



abs(LGSTIMER_REF-DeviceCounter)]











the sign of drift is:

















negative if Period- abs(LGSTIMER_REF- DeviceCounter) >



abs(LGSTIMER_REF-DeviceCounter)



positive if Period - abs(LGSTIMER_REF - DeviceCounter) <



abs(LGSTIMER_REF -DeviceCounter)










Device 2 can be subsequently activated. LGS reads effect parameters of device 2. LGS makes sure the effect parameters are the same as device 1, if not LGS should write the same settings (at least in terms of effect period). LGS sends SWControl enable to device 2. LGS receives device2_period_counter, compares it to LGSTIMER_REF and sends to device 2 the drift value, so that device 2 will make the adjustment. Depending on the drift value, during the first steps the effect on device 2 can stop or speed up for a moment. The drift comparison is repeated on each device.



FIG. 3 is a diagram of the messaging for synchronizing between a host and a device according to an embodiment of the invention. This diagram is an example of a sawtooth effect started from a host to the device. The host keeps the master clock of the synchronized event. Due to errors on the device, the effect plays longer on the device than the host. The host waits for 3% drift before asking the device to synchronize itself to the host. When the request is sent by the host to the device, the device adjusts the effect to finish the period quicker by the drift amount, as shown by abbreviated sawtooth 302. When the next period of the device effect starts, it is back in sync with the host effect. In the example of FIG. 3, the report from the device is sent near the beginning of each cycle, or sawtooth, of the effect.


In one embodiment, a user interface is provided on the PC or other host device. The user can select synchronization once, and thereafter synchronization is maintained for all effects without further input from the user. The synchronization is maintained when devices power off and on again, with the effects starting again. The user can change the effects, such as the type of effect, color, etc., and the synchronization is carried over and maintained. In one embodiment, the User Interface allows the user to apply the same effect to all devices. In another embodiment, the user can change the effect on one device. If synchronization has been selected, the new effect will then be propagated to all the other devices automatically by the host.


Various methods can be used to accomplish the synchronization. The device can simply jump to the timing position the host commands. Alternately, the rate of change of the effect can be sped up, or slowed down, so there isn't an abrupt change as it comes back into synchronization. The change can take place in a portion of the effect where it will be less noticeable to the user, such as at the end of the effect cycle, or where it is the least bright.


Various other embodiments can be used. For longer effect cycles, multiple reports can be sent. Alternately, instead of periodically reporting, a device can send a single report, such as when ¼ or ⅓ of the effect has passed. This may be used, for example, for shorter effects. This cuts down on the amount of signaling required, with little noticeable difference for shorter effects, or for devices that maintain synchronization well. In one embodiment, the host can monitor how well a device stays synchronized over time, and can download a program change to the device to require reporting more or less often, depending on historical performance.


In another embodiment, the host need not have its own time, but can receive effect start and report signals from the multiple devices, compare them, and send out a correction to one or both. For example, one device could be instructed to slow down, and another to speed up, to lessen the abruptness of the change on one device.


In another embodiment, the devices can communicate directly with each other, rather than with a host. For example, a bigger device, such as a keyboard, may have more processing power than, for example, a mouse. The keyboard could then act both as a device and the host. Alternately, the host could be a smartphone or any other device.


In one embodiment, the program download to the device is done using WiFi, while the reports and synch commands use Bluetooth. In one embodiment, the reports and commands are sent as packets interspersed with transmitted data on a WiFi or other wireless channel, such as sound data to and from a headset.


A variety of effects can be used. For example, for lighting effects, individual keys or buttons could be lit up with different colors, or the same color. A wave or other pattern can periodically sweep through the buttons, or the effects can be provided on or around the keys hit by the user. The effects could also light up the whole housing, or its perimeter. The keys could be grouped in zones with the same color or effect. A glowing effect could simply increase and decrease the intensity. The lighting effects can be coordinated with sound effects, haptic effects or other effects, or those effects could be used instead of lighting effects.


In an alternate embodiment, the host can periodically send a synchronization command to the device, rather than having the device periodically report. However, the inventors have determined that less power is used with device reporting, since the device then needs to be constantly listening, and each command from the host must be processed, using power, regardless of whether synchronization is needed.


In one embodiment, effects are synchronized even though the effects are different. For example, one device may use RGB (Red, Green, Blue) colors, while another uses CMYK (Cyan, Magenta, Yellow, and Key [black]). The effects may also be different in brightness, or could be completely different effects that are coordinated in timing to achieve a desired overall effect, like the coordinating of different instruments in an orchestra.


In one embodiment, basic or simple effects are embedded in firmware or ROM. More complicated effects are programmed in software and downloaded to the device, and can operate independently of the firmware effects, or can utilize the firmware effects while adding to them. Alternately, more complex effects can be imbedded in higher value products. In one embodiment, effects are programmed in firmware, with parameters that can be downloaded to vary the effect.


As will be understood by those of skill in the art, the present invention can be embodied in other forms. Accordingly, the foregoing description is illustrating, but not limiting, of the scope of the invention which is set forth in the following claims.

Claims
  • 1. A system for synchronizing effects among multiple devices, comprising: a first device;a first effect system in the first device programmed to provide a first effect over a period of time and to provide a series of first timing reports on the current timing of the first effect;a transceiver coupled to the first device and configured to receive the first timing reports from the first effect system and transmit the reports wirelessly;the first effect subsystem being programmed to receive a first synchronization signal and to modify the timing of the first effect in accordance with the first synchronization signal;non-transitory computer readable code for execution on a host, having instructions toprocess a signal indicating the synchronized start of the first effect and a second effect;initiate a host timer corresponding to the synchronized start of the first and second effects;receive the first report and a second report and compare them to the host timer;determine if the timing of the first effect has varied from the host timer by more than a predetermined amount;send the first synchronization signal to the first device if the first effect has varied from the host timer by more than the predetermined amount;determine if the timing of a second effect has varied from the host timer by more than a predetermined amount; andsend the second synchronization signal to a second device if the second effect has varied from the host timer by more than the predetermined amount.
  • 2. The system of claim 1 further comprising: a second device;a second effect system in said second device programmed to provide the second effect over a period of time and to provide a series of second reports on the current timing of the second effect;a second transceiver coupled to the second device and configured to receive the second reports and transmit the reports wirelessly;the second effect subsystem being programmed to receive a second synchronization signal and to modify the timing of the second effect in accordance with the second synchronization signal;
  • 3. The system of claim 1 wherein: the host transmits to the first and second devices a signal indicating the synchronized start of the first and second effects.
  • 4. The system of claim 1 wherein the first and second devices send the first and second reports once in each cycle of the first and second effects, in the first half of the effect cycle.
  • 5. The system of claim 1 wherein the reports include a device timer indicating the position in the effect, and wherein the host includes a host timer tracking the position of the effect.
  • 6. The system of claim 1 further comprising, on the host: a user interface allowing a user to change the effects; andcode for maintaining the devices synchronized without further user input after changes to the effects.
  • 7. A system for synchronizing effects among multiple devices, comprising: a first device;a first effect system in said first device programmed to provide a first effect over a period of time and to provide a series of first reports on the current timing of the first effect;a transceiver coupled to the first device and configured to receive the first reports and transmit the reports wirelessly;the first effect subsystem being programmed to receive a first synchronization signal and to modify the timing of the first effect in accordance with the first synchronization signal;non-transitory computer readable code for execution on a host, having instructions totransmit to the first and second devices a signal indicating the synchronized start of the first and second;initiate a host timer corresponding to the synchronized start of the first and second effects;receive the first report and a second report and compare them to the host timer;determine if the timing of the first effect has varied from the host timer by more than a predetermined amount;send the first synchronization signal to the first device if the first effect has varied from the host timer by more than the predetermined amount;determine if the timing of a second effect has varied from the host timer by more than a predetermined amount;send the second synchronization signal to a second device if the second effect has varied from the host timer by more than the predetermined amount;provide a user interface allowing a user to change the effects;maintain the devices synchronized without further user input after changes to the effectswherein the first and second devices send the first and second reports once in each cycle of the first and second effects, in the first half of the effect cycle;wherein the reports include a device timer indicating the position in the effect, and wherein the host includes a host timer tracking the position of the effect;and wherein the effects are one or more of lighting, sound and haptic effects.
  • 8. A method for synchronizing effects among multiple devices, comprising: providing a first effect in a first device over a period of time and to provide a series of first reports on the current timing of the first effect;transmitting the reports wirelessly;receiving a first synchronization signal and modifying the timing of the first effect in accordance with the first synchronization signal;processing, at a host, a signal indicating the synchronized start of the first effect and a second effect;initiating a host timer corresponding to the synchronized start of the first and second effects;receiving at the host the first report and a second report and comparing them to the host timer;determine if the timing of the first effect has varied from the host timer by more than a predetermined amount;sending the first synchronization signal to the first device if the first effect has varied from the host timer by more than the predetermined amount;determining if the timing of a second effect has varied from the host timer by more than a predetermined amount; andsending the second synchronization signal to a second device if the second effect has varied from the host timer by more than the predetermined amount.
  • 9. The method of claim 8 wherein: transmitting by the host to the first and second devices a signal indicating the synchronized start of the first and second effects.
  • 10. The method of claim 8 further comprising: sending the first and second reports once in each cycle of the first and second effects, in the first half of the effect cycle.
  • 11. The method of claim 8 further comprising: indicating with a device timer the position in the effect, andtracking the position of the effect with a host timer.
  • 12. The method of claim 8 further comprising: providing a user interface on the host allowing a user to change the effects; andmaintaining the devices synchronized without further user input after changes to the effects.
  • 13. Computer readable code on at least two non-transitory computer readable media for synchronizing effects among multiple devices, comprising: providing a first effect in a first device over a period of time and to provide a series of first reports on the current timing of the first effect;transmitting the reports wirelessly;receiving a first synchronization signal and modifying the timing of the first effect in accordance with the first synchronization signal;processing, at a host, a signal indicating the synchronized start of the first effect and a second effect;initiating a host timer corresponding to the synchronized start of the first and second effects;receiving at the host the first report and a second report and comparing them to the host timer;determine if the timing of the first effect has varied from the host timer by more than a predetermined amount;sending the first synchronization signal to the first device if the first effect has varied from the host timer by more than the predetermined amount;determining if the timing of a second effect has varied from the host timer by more than a predetermined amount; andsending the second synchronization signal to a second device if the second effect has varied from the host timer by more than the predetermined amount.
  • 14. The computer readable code of claim 13 further comprising non-transitory computer readable media for: transmitting by the host to the first and second devices a signal indicating the synchronized start of the first and second effects.
  • 15. The computer readable code of claim 13 further comprising non-transitory computer readable media for: sending the first and second reports once in each cycle of the first and second effects, in the first half of the effect cycle.
  • 16. The computer readable code of claim 13 further comprising non-transitory computer readable media for: indicating with a device timer the position in the effect, andtracking the position of the effect with a host timer.
  • 17. The computer readable code of claim 13 further comprising non-transitory computer readable media for: providing a user interface on the host allowing a user to change the effects; andmaintaining the devices synchronized without further user input after changes to the effects.
  • 18. The computer readable code of claim 13: wherein the effects are one or more of lighting, sound and haptic effects.