A portion of the disclosure of this patent document contains or may contain material which is subject to copyright protection. The copyright owner has no objection to the photocopy reproduction by anyone of the patent document or the patent disclosure in exactly the form it appears in the Patent and Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever.
This application relates to electronic gaming machines, and more particularly to synchronizing light and sound performances across adjacent gaming machines.
Electronic gaming machines (“EGMs”), otherwise known as slot machines, can be found in casinos throughout the world. EGMs accept wagers from players in exchange for the opportunity to win cash prizes. This opportunity to win is provided in conjunction with the play of an entertaining wagering game. The game is typically displayed on either a display screen or in conjunction with physical devices, such as reels, which indicate the game outcome.
Modern EGMs are equipped with several dozen, if not hundreds of individually controllable multicolor light devices, such as light emitting diodes (LEDs). These LEDs are often grouped together to form light bars which are molded into various areas of a housing of the EGM. The LEDs are controlled by a light controller to produce predefined light sequences in response to predefined events. The light controller can be instructed to perform light shows that correspond to various game outcomes or which correspond to an attract sequence designed to entice players to play the game on the EGM.
Modern EGMs also commonly have a speaker system designed to reproduce high quality music, voice and sound effects. The speaker system is typically connected to an audio processing device that is in communication with a central processor of the EGM. The audio processing device accesses audio files loaded into a main memory of the EGM to play sound through the speaker system. Sound is played through the speaker system in conjunction with the play of a game or an attract sequence.
Casinos arrange EGMs in banks, in which several EGMs are positioned side by side facing the same direction. Banks of EGMs which are endowed with light bars and speaker systems present an opportunity to perform banked light and sound shows. A banked light and sound show is a predefined collection of time synchronized light and sound sequences that specific EGMs within the bank perform in a synchronized manner. A synchronized banked light and sound show generally involves each EGM performing the exact same light and sound performance at the same time. However, a banked light and sound show may also involve some EGMs performing light or sound performances that are partially different from those performed by other EGMs in the bank to create an intended effect.
A banked light and sound show should be performed in such a manner as to avoid the perception by an observer that the performances of the individual EGMs are not synchronized. Banked light and sound shows that are unsynchronized can be distracting at best and annoying at worse, especially if the sound is so unsynchronized as to be discordant. Regardless of the degree of unsynchronization, a perceptibly unsynchronized banked light and sound show can leave an observer with the impression that EGM manufacturers have released an unpolished product or that the casino lacks high standards for the entertainment it provides.
These and other considerations have led to the evolution of the present disclosure.
The present application discloses useful techniques for synchronizing light and sound shows among banked EGMs. These techniques enable for the synchronized performance of light and sound shows on banked EGMs even if the clocks of the EGMs are not all synchronized. Additional advantages of the disclosures described herein include facilitating the relatively speedy execution of automatically scheduled light and sound shows, reducing the chance that an EGM will not be ready to execute an light and sound show at the scheduled time, and minimizing the chance that a player playing on an EGM will mistake an light and sound show for a game triggered event.
One aspect of the disclosure involves an electronic gaming machine which sends a query through a network interface to a time server for the current time. The electronic gaming machine receives a response through the network interface from the time server indicating the current time. The electronic gaming machine determines the time difference between a local clock and the indicated current time. The electronic game machine receives a request through the network interface to activate the light devices and the at least one speaker at a future time. The electronic gaming machine determines a scheduled time based on both the future time and the time difference, schedules the activation to occur at the scheduled time, and activates the light devices and the at least one speaker at the scheduled time.
Another aspect of the disclosure involves an electronic gaming machine having a first group of light devices determined to be within a viewing area of a player when the player is playing a wagering game on the electronic gaming machine and a second group of light devices determined not to be within the viewing area of the player when the player is playing the wagering game. The electronic gaming machine determines whether a player is detected at the electronic gaming machine, and if so, activates the first group of light devices at a scheduled time for activating the light devices only if a player is determined to not be using the electronic gaming machine.
Another aspect of the disclosure involves the electronic gaming machine determining whether content files for a scheduled activation of the light devices and speaker are stored on a data storage device of the electronic gaming machine. If the content files are determined not to be stored on the data storage device, the electronic gaming machine sends a request for the content files to a content host through a network interface. The electronic gaming machine receives any content files requested and stores the content files on a data storage device.
Additional aspects and a more complete appreciation of the present disclosure can be obtained from the following detailed description and the claims.
The details of one or more implementations are set forth in the accompanying drawings and the description below. Other features, aspects, and advantages of the disclosure will become apparent from the descriptions, the drawings, and the claims, in which:
The banked light and sound shows (“L&S shows”) of the present disclosure may be implemented on a plurality of electronic gaming machines (“EGMs”), an exemplary one of which is shown as EGM 10 in
An EGM processor 20 is communicatively coupled to the bill and ticket acceptor 14 and the push buttons 18. The EGM processor 20 is also communicatively coupled to a memory device 22, a persistent data storage device 24 a network interface 26, a reel controller 28, and a ticket printer 30. The data storage device 24 contains an operating system and game code which the EGM processor 20 loads into memory 22 and executes to control the operation of the game and the functionality of the EGM 10. The EGM processor 20 communicates with other devices or computers over a network through the network interface 26 for various purposes. The reel controller 28 is connected to and controls a plurality of stepper motors. Mounted to a separate one of each stepper motor is a physical reel 32. The reel controller 28 is operable to cause the stepper motors to activate, causing rotation of the physical reels 32. Each physical reel 32 has a plurality of different symbols (not shown) formed on its circumferential periphery. The ticket printer 30 prints a ticket voucher having a cash value corresponding to the number of credits attributed to the player when the cash out button is pressed.
Upon the initiation of a play of the game, the EGM processor 20 is operable to: deduct the wager amount from the player's available credits; randomly determine an outcome for the game; issue commands to the reel controller 28 which cause the reels 32 to commence spinning and then stop to indicate the outcome of the game, and to award the player any credits associated with a winning outcome. The alignment of a winning combination of symbols on one or more paylines indicates a win of the game. The paylines are typically permanently formed into a display glass positioned in front of the reels 32 but may also be indicated by other means, such as through a transparent display screen positioned in front of the reels, or by selectively lighting the symbols of winning combinations in sequence. A display screen 34 is attached to the cabinet 12 and positioned above the reels 32. The EGM processor 20 may use the display screen 34 for various purposes, such as displaying a bonus game, displaying a pay table for the game, and displaying images or videos while either in attract mode or as part of a L&S show.
A plurality of light units 36 are formed on the cabinet 12. The light units 36 may each contain one or several individually controllable light sources, such as colored LEDs. The light units 36 are connected to a light control device 38. The light control device 38 is communicatively coupled to the EGM processor 20. The light control device 38 receives commands from the EGM processor 20 to activate one or more light units 36 in a specific manner. The light control device 38 lights the light units 36 in accordance with the specific commands received from the EGM processor 20. The light control device 38 may be pre-programmed to activate the light units 36 in predefined ways in response to different predefined commands in order to relieve the EGM processor 20 from having to individually control every light source on the EGM 10. Additionally, the light control device 38 may receive from the processor 20 or through a communication link to the memory 22, a light control file that instructs the light control device 38 to perform a light show. The light control file typically includes instructions for lighting specific light units 36 at specific colors for specific durations at specific times. Such light control files may be custom tailored for the particular EGM platform, to take full advantage of the lighting capabilities of the platform, or may be generic and usable by multiple EGM platforms.
The light units 36 may be classified according to whether or not the participation of the particular light unit 36 in a L&S show would distract or confuse a player who is playing a game. A player is likely to not be amused if he initially mistakes an L&S show for a winning outcome on the game he is playing. Light units 36 that would likely be distracting are those in the viewing area in front of the player, such as the light units 36A in between and around the reels 32. Light units 36 that would be unlikely to be distracting are those that are not in the viewing area in front of the player, such as the light units 36B formed in the front corners of the cabinet 12. The EGM processor 20 may indicate to the light control device 38 whether or not a player is at the EGM 10 (for example, as indicated by a non-zero credit balance or a game currently in play). The light control device 38 may automatically exclude light units 36A from an L&S show when a player has been detected at the EGM 10, and may automatically include light units 36A in the L&S show when a player has not been detected at the EGM 10.
Also contained within the cabinet 12 is a sound processor 40. The sound processor 40 is coupled to the EGM processor 20, the memory 22 and one or more pairs of speakers 42. The sound processor 40 plays sound, for example, a song, through the speakers 42 by processing a sound file. For typical sound play, the EGM processor 20 loads the desired sound file into memory 22 and instructs the sound processor 40 to load and play the sound file. A particular sound file may be associated with a particular light control file, with both intended to be executed at the exact same time. This is typically the case for an L&S show. The memory 22 and the data storage device 24 are part of a memory hierarchy typical of computer systems in which operations with the memory 22 are much faster than with the data storage device 24, which is rather slow in comparison. To ensure that any latency of the data storage device 24 does not result in the light and sound parts of a L&S show being initiated at different times, both the light control file and the sound file may be pre-loaded into the memory 22 several seconds in advance prior to the planned initiation of the L&S show on the EGM 10.
A bank 44 of EGMs 10A-10D which implement an embodiment of the disclosure is shown in
An L&S show association typically involves the same concurrent performance of light and sound on the EGMs that are grouped within the association. However, an L&S show or L&S show association may also be EGM location aware. For example, an L&S show association that is EGM location aware may have a particular light or sound performance occur on the grouped EGMs in a specific order. This ordered performance could, for example, display a light performance that starts at one EGM at the end of a bank and is then displayed on the adjacent EGM and so on, until it is displayed at the EGM at the other end of the bank. An ordered performance such as this may be combined with a concurrent performance in a single L&S show association. The locations of the EGMs referred to herein are most conveniently defined as relative locations, such as a simple number assignment from one to eight for a bank of eight EGMs, which is useful to determine the EGMs on the end of the banks (those having the highest and lowest number assignment) as well as to determine whether two EGMs are adjacent (those having number assignments that differ by one). Other techniques for determining relative EGM location, such as grid location on a two-dimensional plot, could also be utilized.
In certain embodiments, the animation host 48 enables an administrator to schedule an L&S show to be performed on a periodic basis. Such L&S shows could be designed to entice players to play the games on the EGMs of the show. This type of show is in effect a banked attract L&S show and may be more effective than the attract mode of a single EGM. Banked attract L&S shows that are frequently scheduled may produce sound for only a small portion of the show, or even not all, to reduce both excess noise in the casino and power consumption.
In addition to enabling an administrator to schedule an L&S show, embodiments of the animation host 48 may include provisions for the automatic scheduling of an L&S show upon the occurrence of some predefined event. For example, a celebratory win L&S show could be triggered when one of the EGMs in a bank awards a large jackpot. The animation host 48 may receive an indication that the large jackpot was awarded, from either the EGM that awarded the award or from some server in the casino environment that is aware that the award was just awarded. The animation host 48 may then determine the nearby EGMs to the one that issued the award, from the relative location information, and put together a spontaneous L&S show association of the award EGM and the nearby EGMs involving an upbeat celebration oriented L&S show. The animation host 48 could then immediately schedule the L&S show to occur as soon as possible.
The animation host 48 may associate relative priority levels to various L&S shows, to enable the EGMs to perform the higher priority L&S show in the event of a scheduling conflict. For example, a casino operator might prefer to have a celebratory win L&S show interrupt a previously scheduled attract L&S show.
Another example of a spontaneous automatic scheduling of an L&S show could be when a particular bank of EGMs is determined to be on a payout streak (hot) or a stingy streak (cold). The animation host 48 could then play an appropriate ‘hot’ (for example, with red, orange and yellow lights, a video of a fire, and fire crackling noises) or ‘cold’ (for example, with white and blue lights, a video of a blizzard, and howling wind and cracking ice noises) L&S show on the bank.
In certain embodiments, the animation host 48 would have access to as much data and statistics regarding the EGMs as would be needed to define as many different triggers for automatic L&S shows as is desired. Other data not directly related to play on an EGM may also be used as a trigger for an L&S show, such as motion detectors which could prompt the animation host 48 to initiate an L&S show on a bank of EGMs near where motion (a person) was detected. Motion detection could be facilitated through use of a camera on the EGM facing outward towards the area in front of the EGM. Such cameras are commonly being incorporated into modern EGMs.
The act of scheduling a specific L&S show to occur on specific EGMs at a specific time involves communicating instructions to those EGMs that they are to perform the specific L&S show at the specific time. Upon receipt of the scheduling instructions, each EGM in the show determines whether or not it has the required content files for the L&S show or if it needs to download them from somewhere. If the EGMs need to download the content files for the scheduled L&S show, the EGM downloads them from a server on the network, such as the animation host 48, which hosts the content files. The EGMs in the scheduled L&S show load the content files into memory some time in advance (for example, 5-10 seconds) of the scheduled start time for the L&S show. As previously mentioned, loading the content files in advance of the start time of the L&S show helps to avoid any one of the EGMs in the show from starting late due to latency of the data storage device of the EGM.
It is desirable to initiate some automatically scheduled L&S shows as quickly as possible in order for the L&S show to be performed as contemporaneously as possible with the event that initiated the scheduling, such as the celebratory win L&S show. If each EGM of the celebratory win L&S show had to download the file content for the L&S show when the EGMs received instructions to schedule the show, the celebratory win L&S show would be delayed by at least as much time as it takes the EGMs to download the content files and then load them into memory. If this delay lasts several seconds, the celebratory L&S show will seem late with respect to the occurrence of the win. Therefore, it may be desirable to allocate some amount of the permanent storage space on the data storage device of the EGMs for the content files for some L&S shows to avoid this delay. To even further reduce delay, some content files could be permanently loaded into memory of the EGMs to enable for almost instantaneous initiation of an L&S show. In certain embodiments, the animation host 48 has the capability of instructing EGMs of an L&S show association to either download content files for a specific L&S show or to load those content files into memory, independently of a scheduling instruction. After affording the EGMs time to act on such loading instructions (or after an acknowledgement from the EGMs), the animation host 48 would have assurance, or ‘knowledge’ that the content files have been downloaded or loaded into memory. If the animation host 48 has ‘knowledge’ that the EGMs of an L&S show association already have needed content files for the L&S show, the animation host 48 could schedule the L&S show to occur sooner in the future than it otherwise could without that knowledge, for a particular degree of confidence that all of the EGMs of the L&S show will successfully perform the show at the scheduled time. Likewise, if the animation host 48 has ‘knowledge’ that the EGMs of an L&S show association have already loaded the needed content files into memory, the animation host 48 could schedule the L&S show to occur even sooner in the future than it could with the ‘knowledge’ that content files are merely on the data storage devices of the EGM.
It should be appreciated that the L&S show of certain embodiments initiates on the EGMs of the show at close to the same time to prevent the L&S show from appearing to be unsynchronized to an observer. Generally, so long as the L&S show is initiated on a bank of EGMs of the show within around 100 ms of each other, a casual observer will not notice that the light portion of the L&S show is not perfectly synchronized. However, human perception of unsynchronized sound is sharper, and the EGMs of an L&S show should be synchronized to initiate the L&S show within 30-35 ms of each other to avoid the perception of an observer that the sound from the L&S show is unsynchronized.
To ensure accurate accounting and for other purposes, the main clock of each EGM in a casino is usually synchronized to some time source, so that at least some grouping of EGMs in the casino, if not all of them, are time synchronized to some degree. The common method of synchronizing the time of EGMs in a casino environment is through either the Slot Accounting Service (SAS) protocol or the Network Time Protocol (NTP). However, despite the use of a time synchronization protocol on all of the EGMs in a particular group, those EGMs could still have main clocks that are out sync with each other by more than 30-35 ms (between the fastest and slowest clocks) for various reasons. Among these reasons are: (1) the potential use of multiple or different time servers in the casino environment each having a different reference clock time; (2) a high degree of time drift of an individual EGM; (3) time protocol settings that are loose enough for the EGMs to not always be sync'd within 30-35 ms; and (4) a particular EGM that is in the slow process of having its clock ‘corrected’ over a long period of time, as NTP may enable to avoid an instant change in a clock that is drastically different from the reference time. For at least these reasons, an L&S show that relies on scheduling based directly on the clock times of EGMs in a typical casino environment is susceptible to appearing unsynchronized.
To overcome certain problems of performing an L&S show on EGMs that have clocks which are out of sync, an embodiment of the present disclosure utilizes a modified NTP client on each EGM. The modified NTP client does not change or update the actual clock on the EGM. Instead, the modified NTP client maintains an offset which indicates the difference in time between the EGM clock and the clock of a designated reference time source. A convenient designated reference time source is the clock of the animation host 48. The animation host 48 is assumed to be the designated reference time source in the discussion below.
The animation host 48 executes an NTP server program which provides a reference time to each of the EGMs that are configured to participate in an L&S show. Each of the EGMs executes the modified NTP client. The modified NTP client obtains the current reference time from the animation host 48 on a periodic basis, such as every 15 seconds, or on an as needed basis, such as upon receipt of instructions by the EGM to schedule an L&S show. Upon receiving the current reference time, the modified NTP client compares the reference time to the EGM clock and records the time difference or offset. The time difference may be calculated, for example, as the reference time minus the EGM clock time after accounting for the impact of network latency. Network latency can be accounted for in various ways known in the computer arts. In certain embodiments, the time difference is accurate to at least the millisecond level.
When an EGM 10 receives instructions from the animation host 48 to schedule an L&S show at a specific time, the EGM 10 schedules the show to initiate at a time equal to the scheduled start time plus the recorded offset. In embodiments in which the modified NTP client updates the offset on a periodic basis, the EGM 10 may also check to see if the offset has changed, and if so reschedule the L&S show to reflect the updated offset. Scheduling the L&S shows in this manner on different EGMs that likely have different recorded offsets helps ensure that the L&S shows are initiated with a high degree of synchronizational accuracy. This offset technique is facilitated by EGMs that are capable of scheduling events to the millisecond level. EGMs that can only schedule events down to the second level, or minute level can still make use of the offset technique by scheduling a script to execute at the closest earliest schedulable time and having the script wait the appropriate number of milliseconds before initiating the L&S show.
If the content files for a scheduled L&S show are not ready and loaded into memory already when the scheduled time to perform the L&S show arrives, in certain embodiments, the EGM abstains from performing the L&S show to avoid performing out of sync with the other EGMs in the show, and informs the animation host 48 that the EGM was not able to perform the L&S show on time.
In one embodiment, the L&S show is scheduled by the EGM by the EGM scheduling the content files to execute. The content files may be executable themselves or may be associated with media program that executes using the content files as data. In the event that the content files are not already loaded into memory when the scheduled time arrives, the files will be loaded into memory upon their execution or use by the media program. In this embodiment, the executable content files or the media program do not themselves check to determine if the content files have been pre-loaded into memory. Therefore, in this embodiment, the EGM loads the content files into memory immediately upon receiving a request to schedule the L&S show, checks to ensure that the requested scheduled time has not already passed, and if not proceeds to schedule the L&S show at the scheduled time. This technique avoids the possibility of a delay in the start of the L&S show that could be caused by the EGM loading the content files into memory when the scheduled time arrives. If the scheduled time is far enough into the future, it may be undesirable to immediately load the content files into memory and to keep that memory blocked from other uses for a prolonged period of time. Thus, when the EGM receives a schedule request that is far enough into the future, the EGM may schedule the preloading of the content files into memory to occur a brief period of time in advance (for example, 5-10 seconds) ahead of the requested schedule time for the L&S show.
In another embodiment, the L&S show performance on an EGM is managed by a manager program executing on the EGMs. The manager program may be set to execute as a background process. The manager program may also include its own scheduling capability. The manager program is ideally capable of receiving the requests to schedule the L&S show (for example, by listening on a network port allocated for that purpose) and automatically preloads the associated content files a brief period of time in advance of the requested time to schedule the L&S show, and then executes the L&S show at the requested scheduled time. A manager program that performs the L&S show scheduling would utilize the offset record created by the modified NTP client. In some embodiments, the modified NTP client code may be incorporated into the manager program. The manager program could also prevent the light units 36A in the reel area from being used in an L&S show while a player is playing on the EGM. The manger program could also be responsible for scheduling traditional single EGM attract sequences. Ideally, an L&S show will have a higher priority than a standalone EGM attract sequence, in which case the manager program will enable a scheduled L&S show to interrupt an in progress standalone EGM attract sequence.
A method 50 which an animation host can execute in an embodiment of the disclosure is shown in
A method 64 which an EGM (for example, through a manager program) can execute to facilitate performing a L&S show in an embodiment of the disclosure is shown in
The improvements of the present disclosure as described above can significantly reduce the chances that a L&S show will appear to be out of sync to an observer. Various embodiments of the disclosure can also facilitate speedy execution of automatically scheduled L&S shows, reduce the chance that an EGM will not be ready to execute an L&S show at the scheduled time, and minimize the chance that a player playing on an EGM will mistake an L&S show for a game triggered event.
Various server functions previously described, such as those involving the L&S show association creation and scheduling, the NTP server for the modified NTP clients, and the hosting of content files may be hosted by the same or different servers. Although the disclosure has been described with reference to a physical reel EGM, other types of EGMs, such as video EGMs, are contemplated as being equally suitable for use with the disclosure.
Although the disclosure has been described with reference to a bank of EGMs positioned side by side and facing the same direction, any grouping of EGMs in any orientation relative to each other may implement the L&S shows of the disclosure. Likewise, the EGMs that implement L&S shows do not necessarily have to be in proximity to each other, though they typically will be for improved effect.
Various types of light devices besides LEDs may be used in embodiments of the disclosure. Additionally, some embodiments of the disclosure may involve EGMs having groups of light devices that are controllable as a group, as opposed to individually controllable.
Although various protocols have been described in reference to particular embodiments, this should not be construed as requiring the use of a particular protocol, or adherence to the specifications for a particular protocol. For example, the NTP server functionality could be implemented by a compact program with much less functionality than a full featured version of an NTP server.
The embodiments described above included a physical reel EGM. Other types of EGMs besides physical reel EGMs can be utilized just as easily with the disclosure.
Implementations of the subject matter and the operations described in this specification can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them. Implementations of the subject matter described in this specification can be implemented as one or more computer programs, i.e., one or more modules of computer program instructions, encoded on one or more computer storage medium for execution by, or to control the operation of, a data processing agent. Alternatively or in addition, the program instructions can be encoded on an artificially-generated propagated signal, e.g., a machine-generated electrical, optical, or electromagnetic signal, that is generated to encode information for transmission to suitable receiver agent for execution by a data processing agent. A computer storage medium can be, or be included in, a computer-readable storage device, a computer-readable storage substrate, a random or serial access memory array or device, or a combination of one or more of them. Moreover, while a computer storage medium is not a propagated signal, a computer storage medium can be a source or destination of computer program instructions encoded in an artificially-generated propagated signal. The computer storage medium can also be, or be included in, one or more separate components or media (e.g., multiple CDs, disks, or other storage devices). Accordingly, the computer storage medium may be tangible and non-transitory.
The operations described in this specification can be implemented as operations performed by a data processing agent on data stored on one or more computer-readable storage devices or received from other sources.
The term “client or “server” include all kinds of agent, devices, and machines for processing data, including by way of example a programmable processor, a computer, a system on a chip, or multiple ones, or combinations, of the foregoing. The agent can include special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit). The agent can also include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, a cross-platform runtime environment, a virtual machine, or a combination of one or more of them. The agent and execution environment can realize various different computing model infrastructures, such as web services, distributed computing and grid computing infrastructures.
A computer program (also known as a program, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, declarative or procedural languages, and it can be deployed in any form, including as a standalone program or as a module, component, subroutine, object, or other unit suitable for use in a computing environment. A computer program may, but need not, correspond to a file in a file system. A program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub-programs, or portions of code). A computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
The processes and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform actions by operating on input data and generating output. The processes and logic flows can also be performed by, and agent can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit).
Suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read-only memory or a random access memory or both. Devices suitable for storing computer program instructions and data include all forms of non-volatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
While this specification contains many specific implementation details, these should not be construed as limitations on the scope of any disclosures or of what may be claimed, but rather as descriptions of features specific to particular implementations of particular disclosures. Certain features that are described in this specification in the context of separate implementations can also be implemented in combination in a single implementation. Conversely, various features that are described in the context of a single implementation can also be implemented in multiple implementations separately or in any suitable subcombination. Moreover, although features may be described above as acting in certain combinations and even initially claimed as such, one or more features from a claimed combination can in some cases be excised from the combination, and the claimed combination may be directed to a subcombination or variation of a subcombination.
Similarly, while operations are depicted in the drawings in a particular order, this should not be understood as requiring that such operations be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results. In certain circumstances, multitasking and parallel processing may be advantageous. Moreover, the separation of various system components in the implementations described above should not be understood as requiring such separation in all implementations, and it should be understood that the described program components and systems can generally be integrated together in a single software product or packaged into multiple software products.
Thus, particular implementations of the subject matter have been described. Other implementations are within the scope of the following claims. In some cases, the actions recited in the claims can be performed in a different order and still achieve desirable results. In addition, the processes depicted in the accompanying figures do not necessarily require the particular order shown, or sequential order, to achieve desirable results. In certain implementations, multitasking or parallel processing may be utilized.
Number | Name | Date | Kind |
---|---|---|---|
3831172 | Olliges et al. | Aug 1974 | A |
4300225 | Lambl | Nov 1981 | A |
4314236 | Mayer et al. | Feb 1982 | A |
4339798 | Hedges et al. | Jul 1982 | A |
4344345 | Sano | Aug 1982 | A |
4363482 | Goldfarb | Dec 1982 | A |
RE31441 | Nutting et al. | Nov 1983 | E |
4496149 | Schwartzberg | Jan 1985 | A |
4582324 | Koza et al. | Apr 1986 | A |
4618150 | Kimura | Oct 1986 | A |
4624459 | Kaufman | Nov 1986 | A |
4660107 | Chippendale, Jr. | Apr 1987 | A |
4695053 | Vazquez, Jr. et al. | Sep 1987 | A |
4712189 | Mohri | Dec 1987 | A |
4732386 | Rayfiel | Mar 1988 | A |
4733593 | Rothbart | Mar 1988 | A |
4791558 | Chaitin et al. | Dec 1988 | A |
4876937 | Suzuki | Oct 1989 | A |
4974483 | Luzzatto | Dec 1990 | A |
4974857 | Beall et al. | Dec 1990 | A |
5096195 | Gimmon | Mar 1992 | A |
5119465 | Jack | Jun 1992 | A |
5179517 | Sarbin et al. | Jan 1993 | A |
5221801 | Bruti et al. | Jun 1993 | A |
5223828 | McKiel, Jr. | Jun 1993 | A |
5242163 | Fulton | Sep 1993 | A |
5258574 | Kawano | Nov 1993 | A |
5266736 | Saito | Nov 1993 | A |
5275400 | Weingardt et al. | Jan 1994 | A |
5287102 | McKiel, Jr. | Feb 1994 | A |
5331112 | Sato et al. | Jul 1994 | A |
5342047 | Heidel et al. | Aug 1994 | A |
5371345 | LeStrange et al. | Dec 1994 | A |
5390938 | Takeya | Feb 1995 | A |
5393061 | Manship et al. | Feb 1995 | A |
5393070 | Best | Feb 1995 | A |
5429507 | Kaplan | Jul 1995 | A |
5430835 | Williams et al. | Jul 1995 | A |
5446902 | Islam | Aug 1995 | A |
5449173 | Thomas et al. | Sep 1995 | A |
5469511 | Lewis et al. | Nov 1995 | A |
5470233 | Fruchterman et al. | Nov 1995 | A |
5472197 | Gwiasda et al. | Dec 1995 | A |
5508699 | Silverman | Apr 1996 | A |
5515764 | Rosen | May 1996 | A |
5577253 | Blickstein | Nov 1996 | A |
5606144 | Dabby | Feb 1997 | A |
5625845 | Allran | Apr 1997 | A |
5668996 | Radinsky | Sep 1997 | A |
5695188 | Ishibashi | Dec 1997 | A |
5697843 | Manship et al. | Dec 1997 | A |
5703310 | Kurakake et al. | Dec 1997 | A |
5707286 | Carlson | Jan 1998 | A |
5715459 | Celi | Feb 1998 | A |
5745761 | Celi | Apr 1998 | A |
5745762 | Celi | Apr 1998 | A |
5758875 | Giacalone, Jr. | Jun 1998 | A |
5762552 | Vuong et al. | Jun 1998 | A |
5766074 | Cannon et al. | Jun 1998 | A |
5772509 | Weiss | Jun 1998 | A |
5778231 | Van Hoff | Jul 1998 | A |
5792972 | Houston | Aug 1998 | A |
5802364 | Senator | Sep 1998 | A |
5807172 | Piechowiak | Sep 1998 | A |
5809303 | Senator | Sep 1998 | A |
5833538 | Weiss | Nov 1998 | A |
5839958 | Ozarow | Nov 1998 | A |
5848932 | Adams | Dec 1998 | A |
5854927 | Gelissen | Dec 1998 | A |
5876284 | Acres et al. | Mar 1999 | A |
5880386 | Wachi et al. | Mar 1999 | A |
5889990 | Coleman | Mar 1999 | A |
5892171 | Ide | Apr 1999 | A |
5902184 | Bennett et al. | May 1999 | A |
5908354 | Okuniewicz | Jun 1999 | A |
5910048 | Feinberg | Jun 1999 | A |
5911071 | Jordan | Jun 1999 | A |
5920720 | Toutonghi | Jul 1999 | A |
5923878 | Marsland | Jul 1999 | A |
5923880 | Rose | Jul 1999 | A |
5930509 | Yates | Jul 1999 | A |
5937193 | Evoy | Aug 1999 | A |
5946487 | Dangelo | Aug 1999 | A |
5946489 | Yellin | Aug 1999 | A |
5964843 | Eisler | Oct 1999 | A |
5966535 | Benedikt | Oct 1999 | A |
5967894 | Kinoshita et al. | Oct 1999 | A |
5970249 | Holze | Oct 1999 | A |
5971271 | Wynn et al. | Oct 1999 | A |
5978585 | Crelier | Nov 1999 | A |
5997401 | Crawford | Dec 1999 | A |
5999731 | Yellin | Dec 1999 | A |
6003038 | Chen | Dec 1999 | A |
6015346 | Bennett | Jan 2000 | A |
D421277 | McGahn et al. | Feb 2000 | S |
6021272 | Cahill | Feb 2000 | A |
6021273 | Criesemer | Feb 2000 | A |
6026238 | Bond | Feb 2000 | A |
6029000 | Woosley | Feb 2000 | A |
6031993 | Andrews | Feb 2000 | A |
6035120 | Ravichandran | Mar 2000 | A |
6056642 | Bennett | May 2000 | A |
6062979 | Inoue | May 2000 | A |
6066181 | DeMaster | May 2000 | A |
6071192 | Weiss | Jun 2000 | A |
6074432 | Guccione | Jun 2000 | A |
6075940 | Gosling | Jun 2000 | A |
6084169 | Hasegawa et al. | Jul 2000 | A |
6089976 | Schneider et al. | Jul 2000 | A |
6089978 | Adams | Jul 2000 | A |
6092147 | Levy | Jul 2000 | A |
6096095 | Halstead | Aug 2000 | A |
6102400 | Scott et al. | Aug 2000 | A |
6106393 | Sunaga et al. | Aug 2000 | A |
6110041 | Walker et al. | Aug 2000 | A |
6110043 | Olsen | Aug 2000 | A |
6110226 | Bothner | Aug 2000 | A |
6113495 | Walker et al. | Sep 2000 | A |
6117009 | Yoseloff | Sep 2000 | A |
6126165 | Sakamoto | Oct 2000 | A |
6131191 | Cierniak | Oct 2000 | A |
6138273 | Sturges | Oct 2000 | A |
6141794 | Dice | Oct 2000 | A |
6142875 | Kodachi et al. | Nov 2000 | A |
6146273 | Olsen | Nov 2000 | A |
6146276 | Okuniewicz | Nov 2000 | A |
6155925 | Giobbi et al. | Dec 2000 | A |
6159097 | Gura | Dec 2000 | A |
6174233 | Sunaga et al. | Jan 2001 | B1 |
6174235 | Walker et al. | Jan 2001 | B1 |
6175632 | Marx | Jan 2001 | B1 |
6198395 | Sussman | Mar 2001 | B1 |
6217448 | Olsen | Apr 2001 | B1 |
6238288 | Walker et al. | May 2001 | B1 |
6241612 | Heredia | Jun 2001 | B1 |
6254481 | Jaffe | Jul 2001 | B1 |
6270411 | Gura et al. | Aug 2001 | B1 |
6293869 | Kwan et al. | Sep 2001 | B1 |
6302790 | Brossard | Oct 2001 | B1 |
6306034 | Sakamoto et al. | Oct 2001 | B1 |
6309299 | Weiss | Oct 2001 | B1 |
6309301 | Sano | Oct 2001 | B1 |
6311982 | Lebensfeld et al. | Nov 2001 | B1 |
6328648 | Walker et al. | Dec 2001 | B1 |
6390923 | Yoshitomi et al. | May 2002 | B1 |
6409596 | Hayashida et al. | Jun 2002 | B1 |
6416411 | Tsukahara | Jul 2002 | B1 |
6516466 | Jackson | Feb 2003 | B1 |
6537152 | Seelig et al. | Mar 2003 | B2 |
6544122 | Araki et al. | Apr 2003 | B2 |
6554703 | Bussick et al. | Apr 2003 | B1 |
6561908 | Hoke | May 2003 | B1 |
6599195 | Araki et al. | Jul 2003 | B1 |
6638169 | Wilder et al. | Oct 2003 | B2 |
20020077165 | Bansemer et al. | Jun 2002 | A1 |
20030064798 | Grauzer et al. | Apr 2003 | A1 |
20030073490 | Hecht et al. | Apr 2003 | A1 |
20030227473 | Shih et al. | Dec 2003 | A1 |
20050164786 | Connelly | Jul 2005 | A1 |
20050261063 | Boyd | Nov 2005 | A1 |
20060068909 | Pryzby et al. | Mar 2006 | A1 |
20060079213 | Herberger et al. | Apr 2006 | A1 |
20070032281 | Nakatsuka et al. | Feb 2007 | A1 |
20070213134 | Aida | Sep 2007 | A1 |
20090194585 | Blackson | Aug 2009 | A1 |
20100103781 | Rai | Apr 2010 | A1 |
20100273555 | Beerhorst | Oct 2010 | A1 |
20110179943 | Bowen | Jul 2011 | A1 |
20120214594 | Kirovski et al. | Aug 2012 | A1 |
20130310163 | Smith et al. | Nov 2013 | A1 |
20140128160 | Gillet et al. | May 2014 | A1 |
20140206432 | Radek | Jul 2014 | A1 |
20150371486 | Castro | Dec 2015 | A1 |
Number | Date | Country |
---|---|---|
2 201 279 | Aug 1988 | GB |
11197292 | Dec 1997 | JP |
11216221 | Aug 1999 | JP |
02000296209 | Oct 2000 | JP |
Number | Date | Country | |
---|---|---|---|
20170092040 A1 | Mar 2017 | US |