The present disclosure relates generally to accessory management applications, and more specifically to an apparatus for associating physical characteristics with commands.
It is common today for gainers to utilize more than one gaming accessory while utilizing a gaming or other software application. This is especially true of garners who play Massively Multiplayer On-line (MMO) games in a team or individual configuration. Garners can have at their disposal accessories such as a keyboard, a general purpose gaming pad, a mouse, a gaming console controller, a headset with a built-in microphone to communicate with other players, a joystick, a computer display, or other common gaming accessories.
In addition, a gamer can utilize biometric sensing devices to serve as another option to control and/or manage gaming and other software applications. A gamer can frequently use a combination of these accessories during a game (e.g., biometric sensing devices, headset, a keyboard, and mouse) or even use one accessory to replace the function of another accessory. Efficient management and utilization of these accessories can frequently impact the gamer's experience during a game.
One embodiment of the present disclosure entails a computer-readable storage medium having computer instructions to present in a graphical user interface a plurality of associable actions and a biometric sensing accessory, wherein a fingerprint is detectable by the biometric sensing accessory and the fingerprint is correlated to an input function associated with the biometric sensing accessory, associate one of the plurality of associable actions with the input function, detect a stimulation of the input function by monitoring the biometric sensing accessory, wherein the stimulation of the input function occurs based on a detection of the fingerprint, retrieve the action associated with the input function, and transmit the action to an operating system.
One embodiment of the present disclosure entails a biometric accessory having a controller to detect at least one of navigation information and biometric information associated with a user of the accessory, and transmit at least one of the navigation information and biometric information to a software application, wherein an input function of the accessory which is correlated with at least one of the navigation information and the biometric information is assigned to an action of a plurality of associable actions by the software application, wherein a stimulation of the input function is detected by the software application, wherein the action is retrieved by the software application based on the stimulation being detected, and wherein the retrieved associable action is transmitted by the software application to an operating system.
One embodiment of the present disclosure entails a computer-readable storage medium having computer instructions to receive from a software application operably coupled to a biometric sensing accessory an action associated with an input function of the biometric sensing accessory, wherein the input function is correlated to at least one of navigation information and biometric information detected by the biometric sensing accessory, wherein a stimulation of the input function is detected by the software application, and wherein the action is retrieved by the software application when the stimulation is detected, and perform the received action.
In the present context, an accessory can represent any type of device which can be communicatively coupled to the computing device and which can control aspects of the OS and/or a software application operating in the computing device. An accessory can represent for example a keyboard, a biometric sensing device, a gaming pad, a mouse, a gaming console controller, a joystick, a microphone, or a headset with a microphone—just to mention a few. The keyboard and gaming pad represent accessories of a similar category since their operational parameters are alike.
A mouse, on the other hand, represents an accessory which can have disparate operational parameters from the keyboard or gaming pad. For instance, the operational parameters of a keyboard generally consist of alphanumeric keys, control keys (e.g., Shift, Alt, Ctrl), and function keys while the operational parameters of a mouse consist of navigation data generated by a tracking device such as a laser sensor, buttons to invoke GUI selections, and settings thereof (e.g., counts or dots per inch, acceleration, scroll speed, jitter control, line straightening control, and so on). Such distinctions can be used to identify disparate categories of accessories.
Additionally, a biometric sensing device or other device capable of recognizing and/or sensing the physical characteristics of or detecting actions performed by a person can have different operational parameters as well. In the case of a biometric sensing device, such as a fingerprint detection pad, the operational parameters can include, but are not limited to including, navigation or input data generated by sensing a finger or fingers dragged across the surface of the pad and input or other data generated by sensing a finger pressing against the pad. The navigation and input data can also be generated by sensing other actions performed with respect to the pad. The pad, for example, can include a touchscreen, which can detect a user's touch through the use of capacitive, resistive, surface acoustic wave, projected capacitance, infrared, strain gauge, optical, and/or acoustic pulse touchscreen technologies.
Notably, the biometric sensing device can be configured to detect each fingerprint of a user or other users and each fingerprint can be correlated with a particular input function of the biometric sensing device. In other words, the fingerprints can serve as inputs. Additionally, combinations of fingers can be correlated with input functions of the biometric sensing device as well. For example, a combination of a user's thumb and index finger can be correlated to an input function. The biometric sensing device can also be configured to detect and correlate eye movements, blood pressure, heart rates, body movements, and other physical characteristics of a person to various other input functions of the sensing device.
Furthermore, the sensing device can be configured to detect a user's act of touching the surface of the pad or touchscreen, the user's dragging of a finger or fingers on the surface of the screen, and other actions which are independent of the physical characteristics of the user and utilize these actions as inputs. The biometric sensing device can exist as a single device, multiple devices, a pad integrated with a display, and in other configurations. The sensing device can be further configured to have a keypad or a touchscreen keypad and can have touch zones, where each zone can be tailored to perform a particular function. The joysticks, game controllers or any other input devices represent additional categories of accessories supported by the AMS.
In step 406, the AMS application presents a GUI 101 such as depicted in
In step 408, the AMS application can be programmed to detect a user-selection of a particular software application such as a game. This step can be the result of the user entering in a Quick Search field 160 the name of a gaming application (e.g., World of Warcraft™). Upon identifying a gaming application, the AMS application can retrieve in step 410 from a remote or local database gaming application actions which can be presented in a scrollable section 139 of the GUI represented as “Actions” 130. The actions can be tactical actions 132, communication actions 134, menu actions 136, and movement actions 138, or any other types of actions, which can be used to invoke and manage features of the gaming application.
The actions presented descriptively in section 130 of the GUI can represent a sequence of accessory input functions which a user can stimulate by button depressions, navigation, performing actions with the sensing device 116, or speech. For example, depressing the left index finger on the biometric sensing device 116 can represent the tactical action “Reload”, while the simultaneous keyboard depressions “Ctrl A” can represent the tactical action “Melee Attack”. For ease of use, the “Actions” 130 section of the GUI is presented descriptively rather than by a description of the input function(s) of a particular accessory.
Any one of the Actions 130 can be associated with one or more input functions of the accessories by way of a simple drag and drop action. For instance, a user can select a “Melee Attack” by placing a pointer 133 over an iconic symbol associated with this action by utilizing the mouse 108 or by dragging the pointer 133 using a pad/touchscreen of the biometric sensing device 116. Upon doing so, the symbol can be highlighted to indicate to the user that the icon is selectable. At this point, the user can select the icon by holding the left mouse button and drag the symbol (or by utilizing the touch screen of the sensing device 116) to any of the input functions (e.g., buttons) of the keyboard 108, mouse 110, or biometric sensing device 116 to make an association with an input function of one of these accessories.
For example, the user can drag the Melee Attack symbol to a particular region of a touchscreen of the sensing device 116 thereby causing an association between the associated region and the gaming action of a Melee Attack. When the region of the sensing device 116 is tapped or otherwise touched during normal operation of a game, the AMS application can detect the selection as a “trigger” to generate the key sequence “Ctrl A” which is understood by the gaming application as request for a Melee Attack. The gaming application receives from the AMS application by way of an operating system the “Ctrl A” sequence as if it had been generated by a Qwerty keyboard.
Additionally, the sensing device 116 and/or the AMS application can be configured to record the fingerprints, a combination of fingerprints, eye movements, body movements, heart rates, blood pressure, and other physical characteristics of the user and correlate the characteristics to input functions of the sensing device 116. The user can then associate any one of the actions 130 to an input function correlated with a particular physical characteristic. As an example, the biometric sensing device 116 is illustratively shown in split window 120 of
For example, the fingerprint corresponding to the left ring finger 116i of the user can be associated with the “Night Vision” action under the Tactics 132 menu and the right thumb can be assigned to “Melee Attack.” Upon tapping a touch screen of the sensing device 116 with the user's left ring finger 116i during a game, a night vision mode can be triggered during game play. By tapping the screen again with the ring finger 116i, the night vision mode can be toggled off or even lead to another action. Of course, each finger or combination of fingers can be associated with a particular action. Similarly, a user's eye movement to the left can be associated with the “Move Left” action and eye movement to the right can be associated with the “Move Right” action under the Movement 138 menu.
With this in mind, attention is directed to step 412 where the AMS application can respond to a user selection of a profile. A profile can be a device profile or master profile invoked by selecting GUI button 156 or 158, each of which can identify the association of actions with input functions of one or more accessories. If a profile selection is detected in step 412, the AMS application can retrieve macro(s) and/or prior associations of actions with the accessories as defined by the profile. For example, if a certain set of fingers or finger combinations are associated with certain actions for a particular video game in a selected profile, the associations of actions stored in the profile can be retrieved in anticipation of playing the video game. The actions and/or macros defined in the profile can also be presented in step 416 by the AMS application in the actions column 130 of the GUI 101 to modify or create new associations.
In step 418, the AMS application can also respond to a user selection to create a macro. A macro in the present context can represent a subset of actions that can be presented in the Actions column 130. Any command which can be recorded by the AMS application can be used to define a macro. A command can represent a sequence of input functions of an accessory, identification of a software application to be initiated by an operating system (OS), or any other recordable stimulus to initiate, control or manipulate software applications. For instance, a macro can represent a user entering the identity of a software application (e.g., instant messaging tool) to be initiated by an OS. A macro can also represent recordable speech delivered by a microphone singly or in combination with a headset for detection by another software application through speech recognition or for delivery of the recorded speech to other parties. In an embodiment, the macro can represent recordable taps, finger drags, or other actions performed on a touchscreen/pad of the sensing device 116 In yet another embodiment a macro can represent recordable navigation of an accessory such as a mouse or joystick, recordable selections of buttons on a keyboard, a mouse, or a mouse pad, and so on. Macros can also be combinations of the above illustrations. Macros can be created from the GUI 101 by selecting a “Record Macro” button 148. The macro can be given a name and category in user-defined fields 140 and 142.
Upon selecting the Record Macro button 148, a macro can be generated by selection of input functions on an accessory (e.g., Ctrl A, speech, touch screen region, etc.) and/or by manual entry in field 144 (e.g., typing the name and location of a software application to be initiated by an OS). Once the macro is created, it can be tested by selecting button 150 which can repeat the sequence specified in field 144. The clone button 152 can be selected to replicate the macro sequence if desired. Fields 152 can also present timing characteristics of the stimulation sequence in the macro with the ability to customize such timing. Once the macro has been fully defined, selection of button 154 records the macro in step 420. The recording step can be combined with a step for adding the macro to the associable items Actions column 130, thereby providing the user the means to associate the macro with input functions of the accessories.
In step 422, the AMS application can respond to drag and drop associations between actions and input functions of the keyboard 108 and the biometric sensing device 116. If an association is detected, the AMS application can proceed to step 424 where it can determine if a profile has been identified in step 412 to record the association(s) detected. If a profile has been identified, the associations are recorded in said profile in step 426. If a profile was not been identified in step 412, the AMS application can create a profile in step 428 for recording the detected associations. In the same step, the user can name the newly created profile as desired. The newly created profile can also be associated with one or more software applications in step 430 for future reference.
The GUI 101 presented by the AMS application can have other functions. For example, the GUI 101 can provide options for layout of the accessory selected (button 122), how the keyboard is illuminated when associations between input functions and actions are made (button 134), and configuration options for the accessory (button 126). Configuration options can include operational settings of the mouse 110 such as Dots Per Inch or Counts Per Inch, and so on. The AMS application can adapt the GUI 101 to present more than one functional perspective. For instance, by selecting button 102, the AMS application can adapt the GUI 101 to present a means to create macros and associate actions to accessory input functions as depicted in
It should be noted that the steps of method 400 in whole or in part can be repeated until a desirable pattern of associations of actions to input functions of the selected accessories has been accomplished. It would be apparent to an artisan with ordinary skill in the art that there can be numerous other approaches to accomplish similar results. These undisclosed approaches are contemplated by the present disclosure.
In step 506 the AMS application can receive instructions describing all or a portion of the input functions of the unknown accessory. These instructions can come from a user who defines each input function individually or responds to inquiries provided by the AMS application. The AMS application can for example make an assumption as to the keyboard layout and highlight each key with a proposed function which the user can verify or modify. Once the AMS application has been provided instructions in step 506, the AMS application can create an accessory identity in step 508 which can be defined by the user. In steps 510 and 512, the AMS application can associate and record the accessory instructions with the identity for future recognition of the accessory. In step 514, the AMS application can present a depiction of the new accessory with its identity along with the other selectable accessories in section 117.
Method 500 can provide a means for universal detection and identification of any accessory which can be used to control or manage software applications operating in a computing device.
Once one or more stimulations have been detected in step 604, the AMS application can proceed to step 606 to determine if action(s) have been associated with the detected stimulation(s). If, for example, the stimulations detected correspond to keyboard 108 and/or taps/drags on the touchscreen of the sensing device 116, the AMS application can determine if actions have been associated and recorded for such stimulations. If these stimulations “trigger” one or more actions, the AMS application can proceed to step 608 where it retrieves the stimulation definition of these actions for each accessory reporting a stimulation. In step 610, the AMS application can substitute the detected stimulations with the stimulations defined by the action.
To illustrate this substitution, suppose for example that the detected stimulation was “Ctrl A” simultaneously depressed on a keyboard. Suppose further that an action associated with this stimulus consists of a macro that combines finger dragging with a navigation of the sending device 116 (e.g., moving one's finger quickly in a backward motion for a given distance), and a request to invoke an instant messaging (IM) session with a particular individual using Skype™ or some other common IM tool. In step 610, the AMS application would substitute “Ctrl A” for stimulations consisting of the finger drags, navigation and a request for an IM application. The substitute stimulations would then be reported in step 612 to an operating system (OS).
In step 616, the OS can determine whether to pass the substitute stimulations to an active software application in operation (e.g., a gaming application) and/or to invoke another software application. The active software application can be operating from the same computer system from which the OS and the AMS application operate or can be operating at a remote system such as an on-line server or family of servers (e.g., World of Warcraft) awaiting stimulation data from the computer system. In this illustration, the macro comprises both stimulation feedback for the active software application and a request to initiate an IM session.
Accordingly, the OS conveys in step 618 the sensing device's 116 stimulation signals to the active software application (e.g., gaming application), and in a near simultaneous fashion invokes the IM session in step 620 with a specific individual (or organization). In another example, if a user's right thumb is assigned to the “Melee Attack” action and the user's left thumb is assigned to “Throw Frag,” the OS can transmit the actions to a gaming application which is currently executing and an in-game entity (such as a video game character) can perform the received actions.
In order to provide a further example, and now referring also to
Similarly,
Referring back to step 606, the illustrations above cover a scenario in which the AMS application has detected an association of actions to accessory stimuli. If however the AMS application does not detect such an association, then the detected stimulus (or stimuli) supplied by one or more accessories is transmitted to the OS in step 614. For example, it may be that a stimulation based on the depressions of “Ctrl A” has no particular association to an action. In this case, the AMS application passes this stimulation to the OS with no substitutes. In step 616 the OS can determine if this stimulation invokes a new software application in step 620 or is conveyed to the previously initiated software application.
Contemporaneous to the embodiments described above, the AMS application can also record in step 622 statistics relating to the detected accessory stimulations. A portion of the AMS application can operate as a background process which performs statistical analysis on the stimulations detected. By selecting button 104 in
A color scale 203 defines the frequency of usage of the input functions of the keyboard. The first end of the scale (navy blue) represents a single detected depression, while an opposite end of the scale (bright red) represents 500 detected depressions. Based on this scale, the AMS application maps by color in step 624 stimulations of the keyboard. For example, the key grouping 208 depict a color coding with the highest detectable usage, while the F7 key (reference 210) indicates the fewest depressions. Keys having zero depressions are not color coded to readily identify the color mapping of keys which were used at least once.
The AMS application provides additional functions in a playback panel of the GUI which can help a user understand how the color coded keys were used during an active software application such as a video game. In this section of the GUI, the AMS application can present the user with a playback control function 202 which the user can select to replay, pause, forward or rewind the usage of these keys. When usage playback is selected, the user can for instance see the color coded keys highlighted in real-time with a temporary white border to visualize how the keys were selected. A time clock 204 provides the user the elapsed time of the playback sequence. Button 212 allows the user to retrieve statistics from other sessions, while button 214 provides the user a means to save statistics from a given session.
The GUI of
In addition to a symbolic representation as shown in
The AMS application can utilize an understanding of the layout of the accessory (in this case, the keyboard or sensing device) to determine from the statistics ways that the user can improve response time or ergonomic use. For example, the AMS application can determine from a layout analysis that the key combination <Alt .> can be reassigned to a macro based on the trigger <Ctrl F> which could provide the user a faster response time and free up the user's right hand for other tasks. The AMS application can also provide alternative suggestions. For example, the AMS application can also suggest creating single button macros for each of the key combinations <Alt .> and <Ctrl A> which can be assigned to keys on the keyboard or left and right buttons of a mouse. The latter suggestion of assigning macros to the mouse can help the user free up his/her left hand.
Similarly, with regard to the sensing device 116, the AMS application can utilize information about the sensing device 116 to recommend to the user better or optimal associations. For example, the AMS application may determine that a particular region of the sensing device's 116 touchscreen is over-utilized and that distributing finger touches or drags over a larger portion of the screen would be more advantageous. Additionally, the AMS application may determine that particular combinations of fingers associated with certain actions would be more advantageous than current associations. For example, as shown in
The AMS application can utilize present and next generation algorithms to determine how to improve response times and ergonomic usage of accessory devices. The AMS application can for example have at its disposal an understanding of the layout of each accessory, the type of software being controlled by the accessory (e.g., World of Warcraft), type of operations commonly used to control the software (e.g., known actions as shown in the actions column 130 of
From these illustrations, it would be apparent to an artisan of ordinary skill in the art that innumerable algorithms can be developed to analyze accessory usage and thereby suggest improvements. These undisclosed embodiments are contemplated by the present disclosure.
From the foregoing descriptions, it would be evident to an artisan with ordinary skill in the art that the aforementioned embodiments can be modified, reduced, or enhanced without departing from the scope and spirit of the claims described below. For example, method 400 can be adapted to define more than one programmable layer for an accessory. Such a feature can extend the functionality of an accessory into multi-layer paradigms of input functions. The GUI of
The user can also specify which layer to present in
The trigger for switching between layers can be a toggle function (e.g., selecting the tab key on a Qwerty keyboard or tapping a certain region of a touchscreen of the sensing device) to switch between layers in a round robin fashion (layer 1→layer 2→layer 3→to layer 1→and so on). Alternatively, the user can define a hold and release trigger to switch between layers. In this embodiment, the user moves to another layer while pressing a button (e.g., a “Shift” key) or portion of a touchscreen of the sensing device 116 and returns to the preceding layer upon its release. In yet another embodiment, the trigger to switch layers can be defined differently per layer. The user can for example select the letter “A” in layer 1 to proceed to layer 2, and select the letter “B” in layer 2 to return to layer 1 or proceed to yet another layer 3. There can be numerous combinations of layers and triggers which can be defined to substantially expand the capability of single accessory. Additionally, triggers can be of any kind, tactile, speech, etc.
In another embodiment, method 400 can be adapted so that a user can define super macros and/or super profiles. A super macro can represent nested macros (combinations of macros). Method 400 can be adapted so that the user can customize the timing for executing nested macros. Similarly, a super profile can represent nested profiles (combinations of profiles). A super profile can for example comprise sub-profiles, each sub-profile defining associations of actions to input functions of a particular accessory.
In yet another embodiment, method 400 can be adapted to establish audio profiles for headset accessories. When a user select a headset accessory such as 114, GUI 101 can be adapted to provide the user options to establish an sound output (equalizer) setting to optimize performance for a particular gaming application. For instance GUI 101 can present an equalizer so that the user can raise the volume of high frequencies to an enemy's footsteps from a longer distance in a gaming application.
In still another embodiment, the method 400 can be adapted to allow a user to authenticate into the AMS application and/or a software application accessible by the AMS application based on a detection of an authorized fingerprint or other physical characteristic detected by the sensing device 116.
The foregoing embodiments are a subset of possible embodiments contemplated by the present disclosure. Other suitable modifications can be applied to the present disclosure. Accordingly, the reader is directed to the claims for a fuller understanding of the breadth and scope of the present disclosure.
The machine may comprise a server computer, a client user computer, a personal computer (PC), a tablet PC, a laptop computer, a desktop computer, a control system, a network router, switch or bridge, or any machine capable of executing a set of instructions (sequential or otherwise) that specify actions to be taken by that machine. It will be understood that a device of the present disclosure includes broadly any electronic device that provides voice, video or data communication. Further, while a single machine is illustrated, the term “machine” shall also be taken to include any collection of machines that individually or jointly execute a set (or multiple sets) of instructions to perform any one or more of the methodologies discussed herein.
The computer system 1000 may include a processor 1002 (e.g., a central processing unit (CPU), a graphics processing unit (GPU, or both), a main memory 1004 and a static memory 1006, which communicate with each other via a bus 1008. The computer system 1000 may further include a video display unit 1010 (e.g., a liquid crystal display (LCD), a flat panel, a solid state display, or a cathode ray tube (CRT)). The computer system 1000 may include an input device 1012 (e.g., a keyboard), a cursor control device 1014 (e.g., a mouse), a disk drive unit 1016, a signal generation device 1018 (e.g., a speaker or remote control) and a network interface device 1020.
The disk drive unit 1016 may include a machine-readable medium 1022 on which is stored one or more sets of instructions (e.g., software 1024) embodying any one or more of the methodologies or functions described herein, including those methods illustrated above. The instructions 1024 may also reside, completely or at least partially, within the main memory 1004, the static memory 1006, and/or within the processor 1002 during execution thereof by the computer system 1000. The main memory 1004 and the processor 1002 also may constitute machine-readable media.
Dedicated hardware implementations including, but not limited to, application specific integrated circuits, programmable logic arrays and other hardware devices can likewise be constructed to implement the methods described herein. Applications that may include the apparatus and systems of various embodiments broadly include a variety of electronic and computer systems. Some embodiments implement functions in two or more specific interconnected hardware modules or devices with related control and data signals communicated between and through the modules, or as portions of an application-specific integrated circuit. Thus, the example system is applicable to software, firmware, and hardware implementations.
In accordance with various embodiments of the present disclosure, the methods described herein are intended for operation as software programs running on a computer processor. Furthermore, software implementations can include, but not limited to, distributed processing or component/object distributed processing, parallel processing, or virtual machine processing can also be constructed to implement the methods described herein.
The present disclosure contemplates a machine readable medium containing instructions 1024, or that which receives and executes instructions 1024 from a propagated signal so that a device connected to a network environment 1026 can send or receive voice, video or data, and to communicate over the network 1026 using the instructions 1024. The instructions 1024 may further be transmitted or received over a network 1026 via the network interface device 1020.
While the machine-readable medium 1022 is shown in an example embodiment to be a single medium, the term “machine-readable medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) that store the one or more sets of instructions. The term “machine-readable medium” shall also be taken to include any medium that is capable of storing, encoding or carrying a set of instructions for execution by the machine and that cause the machine to perform any one or more of the methodologies of the present disclosure.
The term “machine-readable medium” shall accordingly be taken to include, but not be limited to: solid-state memories such as a memory card or other package that houses one or more read-only (non-volatile) memories, random access memories, or other re-writable (volatile) memories; magneto-optical or optical medium such as a disk or tape; and carrier wave signals such as a signal embodying computer instructions in a transmission medium; and/or a digital file attachment to e-mail or other self-contained information archive or set of archives is considered a distribution medium equivalent to a tangible storage medium. Accordingly, the disclosure is considered to include any one or more of a machine-readable medium or a distribution medium, as listed herein and including art-recognized equivalents and successor media, in which the software implementations herein are stored.
Although the present specification describes components and functions implemented in the embodiments with reference to particular standards and protocols, the disclosure is not limited to such standards and protocols. Each of the standards for Internet and other packet switched network transmission (e.g., TCP/IP, UDP/IP, HTML, HTTP) represent examples of the state of the art. Such standards are periodically superseded by faster or more efficient equivalents having essentially the same functions. Accordingly, replacement standards and protocols having the same functions are considered equivalents.
The illustrations of embodiments described herein are intended to provide a general understanding of the structure of various embodiments, and they are not intended to serve as a complete description of all the elements and features of apparatus and systems that might make use of the structures described herein. Many other embodiments will be apparent to those of skill in the art upon reviewing the above description. Other embodiments may be utilized and derived therefrom, such that structural and logical substitutions and changes may be made without departing from the scope of this disclosure. Figures are also merely representational and may not be drawn to scale. Certain proportions thereof may be exaggerated, while others may be minimized Accordingly, the specification and drawings are to be regarded in an illustrative rather than a restrictive sense.
Such embodiments of the inventive subject matter may be referred to herein, individually and/or collectively, by the term “invention” merely for convenience and without intending to voluntarily limit the scope of this application to any single invention or inventive concept if more than one is in fact disclosed. Thus, although specific embodiments have been illustrated and described herein, it should be appreciated that any arrangement calculated to achieve the same purpose may be substituted for the specific embodiments shown. This disclosure is intended to cover any and all adaptations or variations of various embodiments. Combinations of the above embodiments, and other embodiments not specifically described herein, will be apparent to those of skill in the art upon reviewing the above description.
The Abstract of the Disclosure is provided to comply with 37 C.F.R. §1.72(b), requiring an abstract that will allow the reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, it can be seen that various features are grouped together in a single embodiment for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed embodiment. Thus the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separately claimed subject matter.